/* ============================================================
   MO RAN SPA — Customer Portal (B2C) styles · mobile-first
   Brand tokens come from the tenant theme (set on :root by JS).
   ============================================================ */
:root{
  --brand:#2F5D45; --accent:#9C6B3F; --brand-ink:#244B35;
  --bg:#F6F1E7; --card:#FFFFFF; --paper:#FBF8F1;
  --ink:#2B2620; --stone:#6B6256; --mute:#938A7C;
  --line:#E8E0D1; --line-2:#F0E9DC;
  --ok:#2F8A5B; --okbg:#E7F3EC; --warn:#C7892F; --warnbg:#FBF1DD; --danger:#C0492F;
  --radius:18px; --radius-sm:12px;
  --shadow-sm:0 1px 3px rgba(43,38,32,.07);
  --shadow:0 10px 30px rgba(43,38,32,.12);
  --shadow-lg:0 24px 60px rgba(43,38,32,.20);
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Be Vietnam Pro","Manrope", ui-sans-serif, system-ui, -apple-system, "Segoe UI", "Noto Sans KR", sans-serif;
}
*{ box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html,body{ margin:0; height:100%; }
body{ background:#E7E0D0; color:var(--ink); font-family:var(--sans); font-size:15px; line-height:1.55; -webkit-font-smoothing:antialiased; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
a{ color:inherit; text-decoration:none; }

/* phone frame on desktop, full-bleed on mobile */
#portal-root{ min-height:100%; }
.phone{ position:relative; max-width:440px; margin:0 auto; min-height:100vh; background:var(--bg); display:flex; flex-direction:column; box-shadow:0 0 80px rgba(0,0,0,.18); overflow:hidden; }
@media(min-width:480px){ .phone{ min-height:auto; height:auto; margin:24px auto; border-radius:34px; min-height:760px; } body{ padding:0 16px; } }

/* ---------- Screen scaffold ---------- */
.scr{ flex:1; display:flex; flex-direction:column; overflow-y:auto; padding-bottom:96px; }
.scr::-webkit-scrollbar{ width:0; }
.pad{ padding:20px; }
.stack{ display:flex; flex-direction:column; gap:14px; }
.row{ display:flex; gap:12px; align-items:center; }
.between{ justify-content:space-between; }
.grow{ flex:1; }
.muted{ color:var(--mute); } .small{ font-size:.82rem; } .tiny{ font-size:.74rem; }
.center{ text-align:center; }

/* ---------- Brand header ---------- */
.brandbar{ background:linear-gradient(135deg, var(--brand-ink), var(--brand)); color:#fff; padding:22px 20px 26px; position:relative; overflow:hidden; }
.brandbar::after{ content:""; position:absolute; right:-40px; top:-40px; width:160px; height:160px; border-radius:50%; background:radial-gradient(circle, color-mix(in srgb,var(--accent) 55%, transparent), transparent 70%); }
.brandbar .row{ position:relative; z-index:1; }
.brandlogo{ width:44px; height:44px; border-radius:13px; background:#fff; padding:6px; object-fit:contain; flex:none; }
.brandbar h1{ font-family:var(--serif); font-weight:600; font-size:1.5rem; margin:0; line-height:1; }
.brandbar .sub{ font-size:.76rem; opacity:.8; letter-spacing:.04em; }
.brandbar .greet{ position:relative; z-index:1; margin-top:18px; }
.brandbar .greet .hi{ font-family:var(--serif); font-size:1.7rem; line-height:1.1; }

/* ---------- Loyalty card ---------- */
.loyalty{ background:linear-gradient(135deg, var(--accent), color-mix(in srgb,var(--accent) 60%, #5a3d23)); color:#fff; border-radius:var(--radius); padding:18px 20px; box-shadow:var(--shadow); position:relative; overflow:hidden; }
.loyalty::after{ content:""; position:absolute; inset:0; background:url('assets/logo/logo-icon.png') no-repeat right -20px bottom -20px/120px; opacity:.08; filter:brightness(0) invert(1); }
.loyalty .tier{ display:inline-flex; align-items:center; gap:7px; font-size:.72rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; background:rgba(255,255,255,.2); padding:4px 11px; border-radius:999px; }
.loyalty .pts{ font-family:var(--serif); font-size:2.6rem; font-weight:600; line-height:1; margin:12px 0 2px; }
.loyalty .pbar{ height:6px; border-radius:999px; background:rgba(255,255,255,.25); margin-top:12px; overflow:hidden; }
.loyalty .pbar > i{ display:block; height:100%; background:#fff; border-radius:999px; }
.loyalty .pkg{ margin-top:14px; padding-top:12px; border-top:1px solid rgba(255,255,255,.2); display:flex; align-items:center; justify-content:space-between; }
.loyalty .pkg b{ font-size:1.4rem; font-family:var(--serif); }

/* ---------- Cards ---------- */
.card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-sm); }
.card-p{ padding:16px 18px; }
.sec-t{ font-family:var(--serif); font-weight:600; font-size:1.3rem; margin:2px 0 10px; }
.eyebrow{ font-size:.7rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }

/* appointment row */
.appt{ display:flex; gap:14px; align-items:center; padding:14px 16px; }
.appt .when{ flex:none; width:54px; text-align:center; background:var(--paper); border:1px solid var(--line); border-radius:12px; padding:8px 0; }
.appt .when .d{ font-family:var(--serif); font-size:1.3rem; font-weight:600; line-height:1; color:var(--brand); }
.appt .when .m{ font-size:.64rem; text-transform:uppercase; letter-spacing:.08em; color:var(--mute); margin-top:2px; }
.appt .info b{ font-size:.98rem; }
.appt .info .meta{ font-size:.82rem; color:var(--stone); }
.badge{ display:inline-flex; align-items:center; gap:5px; padding:2px 9px; border-radius:999px; font-size:.7rem; font-weight:700; }
.badge.ok{ background:var(--okbg); color:var(--ok); } .badge.pkg{ background:#EAF0FB; color:#3A6FA0; }
.badge.done{ background:var(--line-2); color:var(--stone); } .badge.cancel{ background:#F8E7E1; color:var(--danger); }

/* ---------- Buttons ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; min-height:50px; padding:0 20px; border-radius:14px; font-weight:700; font-size:1rem; transition:transform .15s, background .15s, box-shadow .15s; }
.btn:active{ transform:scale(.97); }
.btn-pri{ background:var(--brand); color:#fff; box-shadow:0 8px 20px color-mix(in srgb,var(--brand) 35%, transparent); }
.btn-acc{ background:var(--accent); color:#fff; box-shadow:0 8px 20px color-mix(in srgb,var(--accent) 35%, transparent); }
.btn-ghost{ background:var(--card); color:var(--ink); border:1.5px solid var(--line); }
.btn-ghost:active{ background:var(--paper); }
.btn-block{ width:100%; }
.btn-sm{ min-height:40px; padding:0 14px; font-size:.88rem; border-radius:11px; }
.btn svg{ width:18px; height:18px; }
.btn:disabled{ opacity:.5; }

.cta-pulse{ position:relative; }
.cta-pulse::before{ content:""; position:absolute; inset:0; border-radius:inherit; box-shadow:0 0 0 0 color-mix(in srgb,var(--brand) 45%, transparent); animation:pulse 2.4s infinite; }
@keyframes pulse{ to{ box-shadow:0 0 0 14px transparent; } }

/* offer pill */
.offer{ display:flex; gap:12px; align-items:center; background:linear-gradient(100deg, var(--paper), #fff); border:1px dashed color-mix(in srgb,var(--accent) 50%, transparent); border-radius:var(--radius); padding:14px 16px; }
.offer .ic{ width:38px; height:38px; border-radius:11px; background:color-mix(in srgb,var(--accent) 14%, transparent); color:var(--accent); display:grid; place-items:center; flex:none; }

/* ---------- Tabbar ---------- */
.tabbar{ position:absolute; left:0; right:0; bottom:0; background:color-mix(in srgb,var(--card) 92%, transparent); backdrop-filter:blur(14px); border-top:1px solid var(--line); display:flex; padding:8px 6px calc(8px + env(safe-area-inset-bottom)); z-index:20; }
.tab{ flex:1; display:flex; flex-direction:column; align-items:center; gap:3px; padding:7px 0; color:var(--mute); border-radius:12px; font-size:.66rem; font-weight:700; transition:color .15s; }
.tab svg{ width:23px; height:23px; }
.tab.active{ color:var(--brand); }
.tab.active svg{ stroke-width:2.3; }

/* ---------- Booking steps ---------- */
.steps{ display:flex; align-items:center; gap:6px; padding:0 4px; }
.steps .st{ flex:1; height:5px; border-radius:999px; background:var(--line); transition:background .3s; }
.steps .st.on{ background:var(--brand); }
.pick{ display:flex; gap:12px; align-items:center; padding:15px 16px; border:1.5px solid var(--line); border-radius:14px; background:var(--card); transition:.15s; width:100%; text-align:left; }
.pick:active{ transform:scale(.99); }
.pick.sel{ border-color:var(--brand); background:color-mix(in srgb,var(--brand) 6%, #fff); box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 12%, transparent); }
.pick .tx{ flex:1; }
.pick .tx b{ font-size:1rem; }
.pick .tx .meta{ font-size:.8rem; color:var(--stone); }
.pick .price{ font-family:var(--serif); font-weight:600; font-size:1.2rem; color:var(--accent); white-space:nowrap; }
.pick .pkgtag{ font-size:.66rem; font-weight:700; color:#3A6FA0; background:#EAF0FB; padding:2px 7px; border-radius:6px; }
.ava{ width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--accent)); color:#fff; display:grid; place-items:center; font-weight:800; flex:none; }

/* day picker */
.days{ display:flex; gap:8px; overflow-x:auto; padding:2px; }
.days::-webkit-scrollbar{ height:0; }
.day{ flex:none; width:58px; padding:10px 0; border-radius:13px; border:1.5px solid var(--line); background:var(--card); text-align:center; transition:.15s; }
.day.sel{ background:var(--brand); border-color:var(--brand); color:#fff; }
.day .dow{ font-size:.66rem; text-transform:uppercase; letter-spacing:.06em; opacity:.7; }
.day .num{ font-family:var(--serif); font-size:1.35rem; font-weight:600; line-height:1.1; }
.slots{ display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.slot{ padding:11px 0; border-radius:11px; border:1.5px solid var(--line); background:var(--card); font-weight:700; font-size:.9rem; transition:.12s; }
.slot.sel{ background:var(--brand); border-color:var(--brand); color:#fff; }
.slot:disabled{ opacity:.35; }

/* confirm sheet */
.summary{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:4px 16px; }
.summary .li{ display:flex; justify-content:space-between; padding:13px 0; border-bottom:1px solid var(--line-2); }
.summary .li:last-child{ border-bottom:none; }
.summary .li .k{ color:var(--stone); }
.summary .li .v{ font-weight:700; text-align:right; }

/* success */
.success{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:32px; gap:8px; }
.checkmark{ width:84px; height:84px; border-radius:50%; background:var(--okbg); display:grid; place-items:center; color:var(--ok); margin-bottom:8px; animation:pop .4s cubic-bezier(.2,1.3,.4,1); }
.checkmark svg{ width:42px; height:42px; }
@keyframes pop{ from{ transform:scale(0); } }

/* ---------- OTP / login ---------- */
.login{ flex:1; display:flex; flex-direction:column; }
.login-hero{ background:linear-gradient(150deg,var(--brand-ink),var(--brand)); color:#fff; padding:46px 26px 40px; text-align:center; }
.login-hero img{ width:64px; height:64px; border-radius:17px; background:#fff; padding:8px; margin-bottom:16px; }
.login-hero h1{ font-family:var(--serif); font-size:2.1rem; margin:0; }
.login-hero p{ opacity:.85; margin:6px 0 0; font-size:.95rem; }
.login-body{ padding:28px 24px; display:flex; flex-direction:column; gap:16px; }
.inp{ width:100%; padding:15px 16px; border:1.5px solid var(--line); border-radius:14px; background:var(--card); font:inherit; font-size:1.05rem; color:var(--ink); }
.inp:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 4px color-mix(in srgb,var(--brand) 12%, transparent); }
.otp-boxes{ display:flex; gap:10px; justify-content:center; }
.otp-boxes input{ width:54px; height:64px; text-align:center; font-size:1.7rem; font-weight:700; border:1.5px solid var(--line); border-radius:14px; background:var(--card); }
.otp-boxes input:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 4px color-mix(in srgb,var(--brand) 12%, transparent); }
.demo-hint{ background:var(--warnbg); border:1px solid #ECD8A8; border-radius:12px; padding:11px 14px; font-size:.82rem; color:#8a6320; text-align:center; }
.demo-hint b{ font-family:var(--serif); font-size:1.1rem; letter-spacing:.1em; }

/* labels */
.label{ font-size:.74rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--mute); margin-bottom:6px; display:block; }
.divider{ height:1px; background:var(--line-2); margin:4px 0; }

/* reward */
.reward{ display:flex; gap:14px; align-items:center; padding:15px 16px; }
.reward .rp{ flex:none; font-family:var(--serif); font-weight:600; font-size:1.15rem; color:var(--accent); text-align:center; min-width:64px; }
.reward .rp .u{ font-family:var(--sans); font-size:.6rem; font-weight:700; letter-spacing:.08em; color:var(--mute); display:block; text-transform:uppercase; }

/* referral */
.refcode{ display:flex; align-items:center; justify-content:space-between; gap:10px; background:var(--brand-ink); color:#fff; border-radius:14px; padding:14px 18px; }
.refcode b{ font-family:var(--mono,monospace); font-size:1.3rem; letter-spacing:.08em; }

/* consent toggle */
.toggle{ position:relative; width:46px; height:27px; border-radius:999px; background:var(--line); transition:.2s; flex:none; }
.toggle::after{ content:""; position:absolute; top:3px; left:3px; width:21px; height:21px; border-radius:50%; background:#fff; box-shadow:0 1px 3px rgba(0,0,0,.2); transition:.2s; }
.toggle[data-on="1"]{ background:var(--brand); }
.toggle[data-on="1"]::after{ transform:translateX(19px); }

/* skeleton + spinner */
.skel{ background:linear-gradient(90deg,#efe8da,#f6f1e7,#efe8da); background-size:200% 100%; animation:sk 1.2s infinite; border-radius:12px; }
@keyframes sk{ to{ background-position:-200% 0; } }
.spin{ width:20px; height:20px; border:2.5px solid rgba(255,255,255,.4); border-top-color:#fff; border-radius:50%; animation:rot .7s linear infinite; }
@keyframes rot{ to{ transform:rotate(360deg); } }

/* empty / toast */
.empty{ text-align:center; padding:40px 24px; color:var(--mute); }
.empty .ic{ width:64px; height:64px; border-radius:50%; background:var(--paper); display:grid; place-items:center; margin:0 auto 14px; color:var(--accent); }
.ptoast{ position:fixed; left:50%; transform:translateX(-50%); bottom:108px; background:var(--brand-ink); color:#fff; padding:12px 20px; border-radius:999px; font-weight:600; font-size:.88rem; box-shadow:var(--shadow-lg); z-index:60; animation:tup .3s; max-width:380px; }
.ptoast.err{ background:var(--danger); } .ptoast.ok{ background:var(--ok); }
@keyframes tup{ from{ transform:translate(-50%,12px); opacity:0; } }

/* powered by */
.powered{ text-align:center; padding:18px; color:var(--mute); font-size:.76rem; }
.powered b{ color:var(--brand); }

/* sticky bottom action inside booking */
.actionbar{ position:sticky; bottom:0; padding:14px 20px calc(14px + env(safe-area-inset-bottom)); background:linear-gradient(transparent, var(--bg) 24%); }
