/* =====================================================================
   Rezvy — public booking pages
   Design source: design/Public Pages.html (Template 2 · Lado a Lado)
   Themed via the 7 theme tokens injected per page as :root custom props.
   One responsive DOM per page (desktop → mobile via media queries).
   ===================================================================== */

:root{
  /* surfaces & text derived from the injected theme tokens */
  --paper:    var(--surface, #fff);
  --paper-2:  color-mix(in oklab, var(--background, #f4f0fd) 72%, var(--surface, #fff));
  --ink-2:    color-mix(in oklab, var(--ink, #1e162e) 70%, var(--surface, #fff));
  --mute:     color-mix(in oklab, var(--ink, #1e162e) 48%, var(--surface, #fff));
  --line:     var(--border, #e4dbf6);
  --line-2:   color-mix(in oklab, var(--border, #e4dbf6) 52%, var(--surface, #fff));

  /* design aliases */
  --pri:      var(--primary);
  --pri-deep: var(--primary-dark);
  --sec:      var(--secondary);
  --bg:       var(--background, #f6f5fb);

  --green: #1f9d57;
  --red:   #d6453a;
  --serif: "Geist", system-ui, sans-serif;
  --mono:  "Geist Mono", ui-monospace, monospace;
}

*{ box-sizing:border-box; }
body.pub-page{
  margin:0; min-height:100vh; overflow-x:hidden;
  color:var(--ink); background:var(--bg);
  font-family:var(--serif); font-feature-settings:"ss01","cv11"; -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(ellipse 1100px 640px at 16% -12%, color-mix(in oklab,var(--primary) 12%,transparent), transparent 60%),
    radial-gradient(circle at 1px 1px, color-mix(in oklab,var(--ink) 4%,transparent) 1px, transparent 0);
  background-size:100% 100%, 30px 30px; background-repeat:no-repeat, repeat; background-attachment:fixed;
}
.pub-page a{ text-decoration:none; }
.mono{ font-family:var(--mono); }

/* page shell — the framed card */
.pub{ max-width:1120px; margin:0 auto; background:var(--surface); color:var(--ink); border:1px solid var(--line);
  border-radius:18px; overflow:hidden; box-shadow:0 1px 0 rgba(20,25,43,.04), 0 30px 70px -42px color-mix(in oklab,var(--primary) 40%,rgba(20,25,43,.45)); }
@media (min-width:1168px){ .pub{ margin:32px auto; } }
@media (max-width:1167px){ .pub{ border-radius:0; border-left:0; border-right:0; max-width:100%; } }

/* ===== ATOMS ======================================================= */
.mark{ display:inline-flex; align-items:center; justify-content:center; width:46px; height:46px; border-radius:14px;
  background:var(--logo, var(--brand-gradient)); color:#fff; flex-shrink:0; overflow:hidden;
  box-shadow:0 8px 18px -9px color-mix(in oklab,var(--primary) 70%,transparent); }
.mark img{ width:100%; height:100%; object-fit:cover; }
.mark span{ font-weight:700; font-size:18px; letter-spacing:-.02em; }
.mark.lg{ width:60px; height:60px; border-radius:18px; }
.mark.lg span{ font-size:23px; }

.lk{ display:inline-flex; align-items:center; gap:13px; min-width:0; }
.lk .nm{ font-size:17px; font-weight:600; letter-spacing:-.015em; line-height:1.15; color:var(--ink); }
.lk .nm .s{ display:block; font-size:11px; font-weight:400; color:var(--mute); margin-top:3px; letter-spacing:.04em; font-family:var(--mono); }

.chip-open{ display:inline-flex; align-items:center; gap:7px; padding:6px 12px; border-radius:999px; font-family:var(--mono);
  font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; font-weight:500;
  background:color-mix(in oklab,var(--green) 14%,var(--surface)); color:color-mix(in oklab,var(--green) 70%,var(--ink));
  border:1px solid color-mix(in oklab,var(--green) 28%,var(--surface)); }
.chip-open.closed{ background:var(--paper-2); color:var(--mute); border-color:var(--line); }
.chip-open .d{ width:6px; height:6px; border-radius:50%; background:var(--green); box-shadow:0 0 0 3px color-mix(in oklab,var(--green) 24%,transparent); }
.chip-open.closed .d{ background:var(--mute); box-shadow:none; }

.btn-pri{ display:inline-flex; align-items:center; justify-content:center; gap:9px; background:var(--pri); color:var(--on-pri,#fff); border:0; cursor:pointer;
  font-family:inherit; font-weight:600; font-size:14.5px; letter-spacing:-.005em; padding:0 22px; height:50px; border-radius:14px;
  box-shadow:0 10px 24px -10px color-mix(in oklab,var(--primary) 70%,transparent); transition:filter .12s; }
.btn-pri:hover{ filter:brightness(.95); }
.btn-pri:disabled{ opacity:.5; box-shadow:none; cursor:not-allowed; filter:none; }
.btn-pri .arr{ font-family:var(--mono); font-size:13px; }
.btn-ghost{ display:inline-flex; align-items:center; justify-content:center; gap:8px; background:var(--surface); color:var(--ink);
  border:1.5px solid var(--line); cursor:pointer; font-family:inherit; font-weight:600; font-size:14.5px; padding:0 20px; height:50px; border-radius:14px; }
.btn-pri.sm,.btn-ghost.sm{ height:42px; font-size:13.5px; padding:0 16px; border-radius:11px; }

.eyebrow{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--pri); font-weight:500; }
.cover-tag{ font-family:var(--mono); font-size:8.5px; letter-spacing:.08em; text-transform:uppercase; color:#fff;
  background:rgba(10,12,20,.42); padding:3px 8px; border-radius:6px; backdrop-filter:blur(6px); }

/* language switcher (dropdown) */
.lang{ position:relative; flex-shrink:0; }
.lang-trigger{ display:inline-flex; align-items:center; gap:7px; padding:7px 11px; border-radius:10px; cursor:pointer;
  background:var(--paper-2); border:1px solid var(--line); color:var(--ink); font:inherit; font-size:12px; }
.lang-trigger .fi{ border-radius:3px; }
.lang-menu{ position:absolute; right:0; top:calc(100% + 6px); min-width:170px; background:var(--surface); color:var(--ink);
  border:1px solid var(--line); border-radius:12px; box-shadow:0 18px 44px -16px rgba(20,25,43,.4); padding:6px; display:none; z-index:50; }
.lang.open .lang-menu{ display:block; }
.lang-menu a{ display:flex; align-items:center; gap:9px; padding:9px 10px; border-radius:8px; font-size:13px; }
.lang-menu a:hover{ background:var(--paper-2); }
.lang-menu a.on{ background:color-mix(in oklab,var(--pri) 8%,var(--surface)); color:var(--pri-deep); font-weight:600; }

/* ===== STORE CARDS (landing grid) ================================== */
.sech{ display:flex; justify-content:space-between; align-items:flex-end; gap:14px; margin-bottom:20px; }
.sech h2{ margin:0; font-size:clamp(20px,3vw,23px); font-weight:700; letter-spacing:-.022em; }
.sech .ct{ font-size:13px; color:var(--mute); }
.stores-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
@media (max-width:900px){ .stores-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .stores-grid{ grid-template-columns:1fr; } }

.scard{ border:1px solid var(--line); border-radius:18px; overflow:hidden; background:var(--surface); display:flex; flex-direction:column; color:var(--ink);
  box-shadow:0 1px 2px rgba(20,25,43,.04); transition:transform .15s, box-shadow .2s; }
a.scard:hover{ transform:translateY(-3px); box-shadow:0 30px 60px -34px color-mix(in oklab,var(--primary) 32%,rgba(20,25,43,.25)); }
.scard .ph{ height:138px; position:relative; background:var(--paper-2); }
.scard .ph .img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.scard .ph .img.fallback{ background:var(--brand-gradient, var(--pri)); }
.scard .ph .chip-open{ position:absolute; top:12px; left:12px; }
.scard .bd{ padding:15px 17px 17px; display:flex; flex-direction:column; gap:11px; flex:1; }
.scard .nm{ font-size:16.5px; font-weight:600; letter-spacing:-.012em; color:var(--ink); }
.scard .addr{ font-size:13px; color:var(--ink-2); display:flex; flex-direction:column; gap:4px; }
.scard .addr .hrs{ font-weight:500; color:var(--ink); font-family:var(--mono); font-size:11px; letter-spacing:.02em; }
.scard .tags{ display:flex; gap:5px; flex-wrap:wrap; }
.scard .tags .t{ font-family:var(--mono); font-size:9px; letter-spacing:.04em; text-transform:uppercase; padding:3px 7px; border-radius:6px;
  background:color-mix(in oklab,var(--pri) 7%,var(--surface)); color:var(--pri); border:1px solid color-mix(in oklab,var(--pri) 16%,var(--surface)); }
.scard .cta{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; padding-top:12px; border-top:1px solid var(--line-2); }
.scard .cta .fr{ font-size:11.5px; color:var(--mute); }
.scard .cta .fr b{ color:var(--ink); font-weight:700; font-size:14px; font-family:var(--mono); }
.scard .cta .go{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:600; color:var(--on-pri,#fff); background:var(--pri); padding:8px 14px; border-radius:10px; }
.scard .cta .go .arr{ font-family:var(--mono); font-size:11px; }

.pfoot{ padding:22px clamp(18px,5vw,40px); border-top:1px solid var(--line); display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap; background:var(--surface); }
.pfoot .t{ font-size:12px; color:var(--ink-2); }
.pfoot .rz{ display:inline-flex; align-items:center; gap:6px; font-size:11.5px; color:var(--mute); }
.pfoot .rz a{ color:var(--ink); font-weight:600; }
.pfoot-social{ display:inline-flex; align-items:center; gap:14px; }
.pfoot-social a{ display:inline-flex; color:var(--ink-2); transition:color .15s, transform .15s; }
.pfoot-social a:hover{ color:var(--primary); transform:translateY(-1px); }

/* ===== TEMPLATE 2 · SPLIT (landing + store hero) =================== */
.split{ display:grid; grid-template-columns:1fr 1.04fr; }
.panel{ background:color-mix(in oklab,var(--pri) 5%,var(--surface)); padding:clamp(28px,4vw,46px) clamp(20px,4vw,50px); display:flex; flex-direction:column; justify-content:center; }
.panel .bar{ display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:auto; }
.panel .back{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:500; color:var(--ink-2); }
.panel .mid{ padding:36px 0; }
.panel .chip-open{ margin-bottom:18px; }
.panel h1{ margin:0; font-size:clamp(34px,4.6vw,54px); line-height:1.0; letter-spacing:-.032em; font-weight:700; }
.panel .phrase{ margin:18px 0 0; font-size:clamp(15px,2vw,17.5px); line-height:1.5; color:var(--ink-2); max-width:430px; }
.panel .cta{ display:flex; gap:11px; margin-top:26px; flex-wrap:wrap; }
.panel .meta{ display:flex; gap:26px; margin-top:auto; padding-top:8px; flex-wrap:wrap; }
.panel .meta .m .v{ font-size:20px; font-weight:700; letter-spacing:-.02em; }
.panel .meta .m .k{ font-family:var(--mono); font-size:10px; letter-spacing:.05em; text-transform:uppercase; color:var(--mute); margin-top:3px; }
.panel .social{ display:flex; gap:8px; margin-top:20px; flex-wrap:wrap; }
.panel .social a{ display:inline-flex; align-items:center; gap:7px; padding:7px 12px; border-radius:9px; font-size:12.5px; color:var(--ink-2);
  background:var(--surface); border:1px solid var(--line); }
.panel .social a:hover{ border-color:var(--pri); color:var(--pri); }

.visual{ position:relative; min-height:100%; padding:18px 18px 18px 0; background:color-mix(in oklab, var(--pri) 5%, var(--surface)); }
.visual .img{ position:absolute; inset:18px 18px 18px 0; width:auto; height:auto; border-radius:22px; object-fit:cover;
  box-shadow:0 30px 60px -34px rgba(20,25,43,.4); }
.visual .img.fallback{ background:var(--brand-gradient, var(--pri)); }
.visual .cover-tag{ position:absolute; top:32px; right:34px; z-index:2; }
.visual .chip-float{ position:absolute; right:34px; bottom:34px; z-index:2; background:var(--surface); border-radius:14px; padding:12px 16px;
  display:flex; align-items:center; gap:11px; box-shadow:0 18px 40px -18px rgba(20,25,43,.45); }
.visual .chip-float .mark{ width:38px; height:38px; border-radius:11px; }
.visual .chip-float .tx .a{ font-size:13px; font-weight:600; letter-spacing:-.01em; }
.visual .chip-float .tx .b{ font-family:var(--mono); font-size:10px; color:var(--mute); text-transform:uppercase; letter-spacing:.04em; margin-top:2px; }

.stores{ padding:clamp(26px,4vw,38px) clamp(18px,5vw,40px) 8px; background:var(--surface); }
/* footer is flush by default; pages that need breathing room add .sp (e.g. the landing) */
.pfoot.sp{ margin-top:34px; }

@media (max-width:860px){
  .split{ grid-template-columns:1fr; }
  /* cover becomes a normal in-flow block on top — never overlaps the header */
  .visual{ order:-1; min-height:0; padding:0; position:static; }
  .visual .img{ position:static; inset:auto; width:100%; height:200px; border-radius:0; display:block; box-shadow:none; }
  .visual .cover-tag{ top:14px; right:16px; }
  .panel{ justify-content:flex-start; }
  .panel .mid{ padding:28px 0 0; }
  .panel .bar{ margin-bottom:22px; }
  .panel .meta{ margin-top:22px; padding-top:18px; border-top:1px solid var(--line); }
}

/* ===== DETAIL BODY (store page) ==================================== */
.detail{ display:grid; grid-template-columns:1fr 322px; }
@media (max-width:840px){ .detail{ grid-template-columns:1fr; } }
.detail .main{ padding:clamp(24px,3vw,32px) clamp(20px,3vw,36px); display:flex; flex-direction:column; gap:28px; border-right:1px solid var(--line-2); }
@media (max-width:840px){ .detail .main{ border-right:0; border-bottom:1px solid var(--line-2); } }
.detail .blk h3{ margin:0 0 13px; font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--mute); font-weight:500; }
.svc{ display:flex; flex-direction:column; gap:8px; }
.svc .it{ display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border:1px solid var(--line); border-radius:13px; gap:14px; background:var(--surface); }
.svc .it .l{ display:flex; align-items:center; gap:11px; min-width:0; }
.svc .it .dot{ width:9px; height:9px; border-radius:50%; flex-shrink:0; }
.svc .it .nm{ font-size:15px; font-weight:600; letter-spacing:-.008em; }
.svc .it .du{ font-family:var(--mono); font-size:10.5px; color:var(--mute); letter-spacing:.03em; margin-top:3px; }
.svc .it .pr{ font-family:var(--mono); font-size:15px; font-weight:600; letter-spacing:.01em; white-space:nowrap; }
.chips-row{ display:flex; flex-wrap:wrap; gap:6px; }
.chips-row .chip{ font-family:var(--mono); font-size:10px; letter-spacing:.04em; text-transform:uppercase; padding:5px 10px; border-radius:7px;
  background:var(--paper-2); color:var(--ink-2); border:1px solid var(--line-2); }
.sched{ border:1px solid var(--line); border-radius:13px; overflow:hidden; }
.sched .r{ display:flex; justify-content:space-between; gap:12px; padding:11px 16px; font-size:13px; border-top:1px solid var(--line-2); }
.sched .r:first-child{ border-top:0; }
.sched .r.today{ background:color-mix(in oklab,var(--pri) 7%,var(--surface)); }
.sched .r.today .dow{ color:var(--pri); font-weight:600; }
.sched .r .hrs{ font-family:var(--mono); font-size:12px; color:var(--ink-2); }
.sched .r.closed .hrs{ color:var(--mute); }
.menu-cat{ margin-bottom:18px; }
.menu-cat-title{ font-size:15px; font-weight:600; margin-bottom:10px; }
/* services nested under a real group: indent + subtle left rule so they read as "inside" the group */
.menu-cat.grouped .menu-item{ margin-left:16px; padding-left:14px; border-left:2px solid var(--line); }
.menu-item{ display:flex; align-items:center; gap:12px; padding:10px 0; border-top:1px solid var(--line-2); }
.menu-item:first-of-type{ border-top:0; }
.menu-item .img{ width:52px; height:52px; border-radius:10px; background-size:cover; background-position:center; flex-shrink:0; border:1px solid var(--line-2); }
.menu-item .l{ flex:1; min-width:0; }
.menu-item .nm{ font-size:14px; font-weight:600; }
.menu-item .desc{ font-size:12px; color:var(--mute); margin-top:2px; }
.menu-item .pr{ font-family:var(--mono); font-size:13.5px; font-weight:600; white-space:nowrap; }
.detail .side{ padding:clamp(24px,3vw,30px) clamp(20px,3vw,26px); background:color-mix(in oklab,var(--pri) 4%,var(--surface)); display:flex; flex-direction:column; gap:15px; }
.detail .side .card{ background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:17px; display:flex; flex-direction:column; gap:13px; }
.detail .side .row{ display:flex; gap:11px; align-items:flex-start; font-size:13px; }
.detail .side .row .ic{ width:30px; height:30px; border-radius:8px; background:color-mix(in oklab,var(--pri) 10%,var(--surface)); display:inline-flex; align-items:center; justify-content:center; color:var(--pri); flex-shrink:0; }
.detail .side .row .t{ font-weight:500; letter-spacing:-.005em; }
.detail .side .row .s{ font-size:12px; color:var(--mute); margin-top:1px; font-family:var(--mono); letter-spacing:.02em; }
.detail .side .pub-map{ height:150px; border-radius:12px; overflow:hidden; border:1px solid var(--line); cursor:pointer; margin-top:4px; }
.detail .side .pub-map .leaflet-container{ height:100%; width:100%; cursor:pointer; font:inherit; }
.detail .side .pub-map-dir{ display:inline-flex; align-items:center; gap:6px; margin-top:10px; font-size:12.5px; font-weight:600; color:var(--pri-deep); text-decoration:none; }
.detail .side .pub-map-dir:hover{ color:var(--pri); }
.detail .side .book{ display:flex; align-items:center; justify-content:center; gap:9px; padding:15px; border-radius:13px; background:var(--pri); color:var(--on-pri,#fff);
  font-size:15px; font-weight:600; letter-spacing:-.01em; box-shadow:0 16px 30px -14px color-mix(in oklab,var(--primary) 80%,transparent); }
.detail .side .book .arr{ font-family:var(--mono); font-size:13px; }

/* ===== BOOKING WIZARD ============================================= */
.ava{ display:inline-flex; align-items:center; justify-content:center; border-radius:50%; font-family:var(--mono); font-weight:600; flex-shrink:0; color:#fff; }
.ava.any{ background:var(--paper-2); color:var(--mute); }

.bk{ display:grid; grid-template-columns:1fr 340px; min-height:640px; background:var(--surface); color:var(--ink); }
@media (max-width:880px){ .bk{ grid-template-columns:1fr; min-height:0; } }
.bk button{ border:0; background:none; font:inherit; color:inherit; cursor:pointer; }
/* the reset above (.bk button) outranks .btn-pri — restore the button fills */
.bk .btn-pri{ background:var(--pri); color:var(--on-pri,#fff); }
.bk .btn-ghost{ background:var(--surface); color:var(--ink); }
.bk .btn-pri:disabled{ background:var(--pri); opacity:.5; }
.bk .aside{ order:2; background:color-mix(in oklab,var(--pri) 5%,var(--surface)); border-left:1px solid var(--line); padding:24px; display:flex; flex-direction:column; gap:16px; }
@media (max-width:880px){ .bk .aside{ border-left:0; border-top:1px solid var(--line); position:sticky; bottom:0; background:color-mix(in oklab,var(--surface) 92%,var(--pri)); backdrop-filter:blur(10px); padding:16px 18px 24px; } }
/* cover spans the sidebar edge-to-edge and sits flush against the top (cancels the aside padding) */
.bk .aside .cover{ height:150px; margin:-24px -24px 0; background-size:cover; background-position:center; }
@media (max-width:880px){ .bk .aside .cover{ display:none; } }
/* back-to-store link, top-left of the booking content (matches the store page back link) */
.bk .bk-back{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:500; color:var(--ink-2); margin-bottom:2px; }
.bk .bk-back:hover{ color:var(--pri); }
.bk .aside .biz{ display:flex; gap:12px; align-items:center; }
.bk .aside .biz .nm{ font-size:16px; font-weight:600; letter-spacing:-.01em; }
.bk .aside .biz .sub{ font-size:12px; color:var(--mute); font-family:var(--mono); margin-top:2px; }
@media (max-width:880px){ .bk .aside .biz{ display:none; } }
.bk .lbl{ font-family:var(--mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--mute); margin-bottom:11px; display:block; }
.bk .cart{ border-top:1px solid var(--line); padding-top:16px; display:flex; flex-direction:column; gap:13px; }
@media (max-width:880px){ .bk .cart{ display:none; } }
.bk .cart .empty{ font-size:13px; color:var(--mute); line-height:1.5; }
.bk .line{ display:flex; flex-direction:column; gap:6px; }
.bk .ln-top{ display:flex; justify-content:space-between; gap:10px; font-size:14px; font-weight:600; letter-spacing:-.01em; }
.bk .ln-pr{ font-family:var(--mono); }
.bk .ln-pro{ display:flex; align-items:center; gap:7px; font-size:12.5px; color:var(--ink-2); }
.bk .ln-pro .ln-du{ margin-left:auto; font-family:var(--mono); font-size:11px; color:var(--mute); }
.bk .when{ border-top:1px solid var(--line); padding-top:16px; }
@media (max-width:880px){ .bk .when{ display:none; } }
.bk .when-v{ font-size:14.5px; font-weight:600; letter-spacing:-.01em; }
.bk .totals{ margin-top:auto; border-top:1px solid var(--line); padding-top:16px; display:flex; justify-content:space-between; align-items:baseline; font-size:13px; color:var(--ink-2); }
.bk .totals b{ font-size:21px; color:var(--ink); font-family:var(--mono); }
.bk .bk-cta{ display:flex; flex-direction:column; gap:9px; }
.bk .bk-cta .btn-pri{ width:100%; }
.bk .bk-cta .btn-ghost{ width:100%; height:42px; }
@media (max-width:880px){ .bk .bk-cta .btn-ghost{ display:none; } }
.bk .main{ order:1; padding:clamp(20px,3vw,28px) clamp(18px,3vw,34px); display:flex; flex-direction:column; gap:22px; min-width:0; }
.bk .steps{ display:flex; align-items:center; gap:12px; }
.bk .steps .st{ display:flex; align-items:center; gap:9px; }
.bk .steps .st .n{ width:26px; height:26px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-family:var(--mono); font-size:12px; font-weight:600; background:var(--paper-2); color:var(--mute); }
.bk .steps .st .t{ font-size:13.5px; font-weight:500; color:var(--mute); }
.bk .steps .st.on .n{ background:var(--pri); color:var(--on-pri,#fff); }
.bk .steps .st{ cursor:pointer; }
.bk .steps .st[aria-disabled="true"]{ cursor:default; }
.bk .steps .st.on .t{ color:var(--ink); font-weight:600; }
.bk .steps .st.done .n{ background:color-mix(in oklab,var(--pri) 18%,var(--surface)); color:var(--pri); }
.bk .steps .st.done .t{ color:var(--ink-2); }
.bk .steps .sep{ flex:1; height:1px; background:var(--line); max-width:64px; }
@media (max-width:560px){ .bk .steps .st:not(.on) .t{ display:none; } .bk .steps .sep{ max-width:none; } }
.bk .sh h2{ margin:0; font-size:clamp(20px,3vw,25px); font-weight:700; letter-spacing:-.022em; }
.bk .sh p{ margin:7px 0 0; font-size:13.5px; color:var(--ink-2); line-height:1.5; max-width:540px; }
.bk .step{ display:flex; flex-direction:column; gap:18px; }

.bk .svc-list{ display:flex; flex-direction:column; gap:11px; }
.bk .svc-group-h{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--mute); margin:10px 0 -2px; }
.bk .svc-group-h:first-child{ margin-top:0; }
.bk .svc-card{ border:1px solid var(--line); border-radius:14px; overflow:hidden; background:var(--surface); }
.bk .svc-card.on{ border-color:color-mix(in oklab,var(--pri) 42%,var(--surface)); box-shadow:inset 0 0 0 1px color-mix(in oklab,var(--pri) 30%,var(--surface)); }
.bk .svc-head{ display:flex; align-items:center; gap:14px; padding:16px 18px; cursor:pointer; }
.bk .check{ width:24px; height:24px; border-radius:7px; border:1.5px solid var(--line); display:inline-flex; align-items:center; justify-content:center; color:var(--on-pri,#fff); font-size:14px; flex-shrink:0; }
.bk .check.on{ background:var(--pri); border-color:var(--pri); }
.bk .svc-meta{ flex:1; min-width:0; }
.bk .svc-nm{ font-size:15.5px; font-weight:600; letter-spacing:-.01em; }
.bk .svc-du{ font-family:var(--mono); font-size:11px; color:var(--mute); margin-top:2px; }
.bk .svc-pr{ font-family:var(--mono); font-size:15px; font-weight:600; }
.bk .pro-row{ border-top:1px solid var(--line-2); padding:14px 18px; background:color-mix(in oklab,var(--pri) 3%,var(--surface)); }
.bk .pro-lbl{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--mute); display:block; margin-bottom:11px; }
.bk .pro-chips{ display:flex; gap:8px; flex-wrap:wrap; }
.bk .pro-chip{ display:inline-flex; align-items:center; gap:9px; padding:6px 14px 6px 7px; border-radius:999px; border:1.5px solid var(--line); background:var(--surface); font-size:13px; font-weight:500; }
.bk .pro-chip.on{ border-color:var(--pri); background:color-mix(in oklab,var(--pri) 7%,var(--surface)); }
.bk .pro-chip>span{ display:flex; flex-direction:column; line-height:1.18; text-align:left; }
.bk .pro-chip>span i{ font-style:normal; font-family:var(--mono); font-size:9.5px; color:var(--mute); letter-spacing:.02em; }

/* time picker */
.bk .suggest{ display:flex; align-items:center; justify-content:space-between; width:100%; padding:13px 16px; border-radius:12px;
  border:1.5px solid color-mix(in oklab,var(--pri) 30%,var(--surface)); background:color-mix(in oklab,var(--pri) 7%,var(--surface)); cursor:pointer; }
.bk .suggest .s-l{ display:flex; align-items:center; gap:9px; font-size:13px; font-weight:600; }
.bk .suggest .s-dot{ width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 0 3px color-mix(in oklab,var(--green) 22%,transparent); }
.bk .suggest .s-t{ font-family:var(--mono); font-size:15px; font-weight:600; color:var(--pri); }
.bk .cal-h{ display:flex; justify-content:space-between; align-items:center; }
.bk .cal-m{ font-size:14px; font-weight:600; letter-spacing:-.01em; text-transform:capitalize; }
.bk .cal-month-sel{ font:inherit; font-size:14px; font-weight:600; color:var(--ink); border:1px solid var(--line); border-radius:9px; padding:6px 10px; background:var(--surface); cursor:pointer; text-transform:capitalize; max-width:220px; }
.bk .cal-month-sel:focus{ outline:none; border-color:var(--pri); box-shadow:0 0 0 3px color-mix(in oklab,var(--pri) 12%,transparent); }
.bk .cal-nav{ display:flex; gap:6px; color:var(--mute); }
.bk .cal-nav button{ width:26px; height:26px; border-radius:8px; border:1px solid var(--line); display:inline-flex; align-items:center; justify-content:center; font-size:15px; }
.bk .cal-nav button:disabled{ opacity:.35; }
.bk .days{ display:flex; gap:8px; overflow-x:auto; padding-bottom:2px; }
.bk .day{ flex:1; min-width:54px; border:1.5px solid var(--line); border-radius:12px; padding:11px 0; display:flex; flex-direction:column; align-items:center; gap:3px; background:var(--surface); cursor:pointer; }
.bk .day.on{ border-color:var(--pri); background:color-mix(in oklab,var(--pri) 8%,var(--surface)); }
.bk .day.closed{ opacity:.38; cursor:not-allowed; }
.bk .day .dd{ font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:.04em; color:var(--mute); }
.bk .day.on .dd{ color:var(--pri); }
.bk .day .dn{ font-size:17px; font-weight:700; letter-spacing:-.02em; }
.bk .period{ display:flex; flex-direction:column; gap:9px; }
.bk .p-lbl{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--mute); }
.bk .slots{ display:grid; grid-template-columns:repeat(6,1fr); gap:8px; }
@media (max-width:560px){ .bk .slots{ grid-template-columns:repeat(4,1fr); } }
.bk .slot{ padding:11px 0; border-radius:10px; border:1.5px solid var(--line); background:var(--surface); font-family:var(--mono); font-size:13px; font-weight:500; text-align:center; cursor:pointer; }
.bk .slot:hover{ border-color:var(--pri); }
.bk .slot.on{ border-color:var(--pri); background:var(--pri); color:var(--on-pri,#fff); }
.bk .slot.off{ opacity:.32; text-decoration:line-through; cursor:not-allowed; }
.bk .time-hint{ font-size:13px; color:var(--mute); }

/* assignment timeline */
.bk .assign{ border:1px solid var(--line); border-radius:14px; padding:16px; display:flex; flex-direction:column; gap:12px; background:color-mix(in oklab,var(--pri) 3%,var(--surface)); }
.tl{ display:flex; flex-direction:column; }
.tl-row{ display:grid; grid-template-columns:62px 22px 1fr auto; align-items:stretch; gap:12px; }
.tl-time{ font-family:var(--mono); font-size:13px; font-weight:600; line-height:1.15; padding:12px 0; align-self:center; }
.tl-time span{ display:block; font-size:10.5px; font-weight:400; color:var(--mute); margin-top:2px; }
.tl-line{ display:flex; align-items:center; justify-content:center; position:relative; }
.tl-line:before{ content:""; position:absolute; top:0; bottom:0; width:2px; background:color-mix(in oklab,var(--pri) 22%,var(--surface)); }
.tl-row:first-child .tl-line:before{ top:50%; }
.tl-row:last-child .tl-line:before{ bottom:50%; }
.tl-dot{ width:11px; height:11px; border-radius:50%; background:var(--pri); box-shadow:0 0 0 3px var(--surface); position:relative; z-index:1; }
.tl-body{ padding:11px 0; }
.tl-nm{ font-size:14px; font-weight:600; letter-spacing:-.01em; }
.tl-pro{ display:flex; align-items:center; gap:7px; font-size:12px; color:var(--ink-2); font-family:var(--mono); margin-top:5px; }
.tl-pr{ font-family:var(--mono); font-size:14px; font-weight:600; align-self:center; }

/* customer fields (step 3) */
.bk-form{ display:flex; flex-direction:column; gap:13px; }
.bk-form .fg-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:560px){ .bk-form .fg-row{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:6px; }
.field .lbl2{ font-size:12.5px; font-weight:500; color:var(--ink-2); }
.field .lbl2 .req{ color:var(--red); }
.field .lbl2 .optn{ color:var(--mute); font-weight:400; }
.field input.inp, .field textarea.inp{ width:100%; background:var(--surface); border:1.5px solid var(--line); border-radius:11px; padding:12px 14px; font-size:14px; color:var(--ink); font-family:inherit; min-height:46px; }
.field textarea.inp{ min-height:66px; resize:vertical; }
.field input.inp:focus, .field textarea.inp:focus{ outline:none; border-color:var(--pri); box-shadow:0 0 0 3px color-mix(in oklab,var(--pri) 12%,transparent); }
.field input.inp::placeholder, .field textarea.inp::placeholder, .phone-num::placeholder{ color:var(--mute); opacity:1; }
.bk .note{ font-size:12.5px; color:var(--mute); line-height:1.5; }
.bk-error{ background:color-mix(in oklab,var(--red) 8%,var(--surface)); border:1px solid color-mix(in oklab,var(--red) 30%,var(--surface)); color:var(--red); border-radius:12px; padding:12px 15px; font-size:13px; }
.bk-error ul{ margin:0; padding-left:18px; }

/* phone input */
.phone-wrap{ display:flex; align-items:stretch; border:1.5px solid var(--line); border-radius:11px; background:var(--surface); overflow:hidden; min-height:46px; }
.phone-wrap:focus-within{ border-color:var(--pri); box-shadow:0 0 0 3px color-mix(in oklab,var(--pri) 12%,transparent); }
.phone-dial{ position:relative; display:inline-flex; align-items:center; gap:6px; padding:0 10px; background:var(--paper-2); border-right:1px solid var(--line); cursor:pointer; }
.phone-dial-sel{ position:absolute; inset:0; opacity:0; width:100%; cursor:pointer; }
.phone-dial-caret{ font-size:9px; color:var(--mute); }
.phone-num{ flex:1; border:0; background:transparent; padding:0 13px; font-size:14px; color:var(--ink); font-family:inherit; min-width:0; }
.phone-num:focus{ outline:none; }

/* pay choice */
.pay-choice{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media (max-width:560px){ .pay-choice{ grid-template-columns:1fr; } }
.pay-opt{ display:flex; align-items:flex-start; gap:10px; padding:12px 14px; border-radius:11px; border:1.5px solid var(--line); cursor:pointer; background:var(--surface); }
.pay-opt input{ position:absolute; opacity:0; }
.pay-opt.on{ border-color:var(--pri); background:color-mix(in oklab,var(--pri) 6%,var(--surface)); }
.pay-opt .ti{ font-size:13px; font-weight:600; }
.pay-opt .su{ font-size:12px; color:var(--mute); margin-top:2px; }
.stripe-badge{ display:inline-flex; align-items:center; gap:6px; font-size:11px; color:var(--mute); }
.stripe-badge strong{ color:#635BFF; }

/* ===== CONFIRMATION =============================================== */
.bkc{ background:var(--surface); color:var(--ink); }
.bkc-bar{ display:flex; justify-content:space-between; align-items:center; gap:12px; padding:20px clamp(18px,4vw,32px); border-bottom:1px solid var(--line); }
.bkc-bar .biz{ display:flex; gap:12px; align-items:center; min-width:0; }
.bkc-bar .biz .nm{ font-size:16px; font-weight:600; letter-spacing:-.01em; }
.bkc-bar .biz .sub{ font-size:12px; color:var(--mute); font-family:var(--mono); margin-top:2px; }
.bkc-bar .step-tag{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--mute); white-space:nowrap; }
.bkc-banner{ display:flex; align-items:center; gap:11px; padding:14px clamp(18px,4vw,32px); font-weight:600; font-size:14px; }
.bkc-banner.ok{ background:color-mix(in oklab,var(--green) 14%,var(--surface)); color:color-mix(in oklab,var(--green) 70%,var(--ink)); border-bottom:1px solid color-mix(in oklab,var(--green) 26%,var(--surface)); }
.bkc-banner.pending{ background:color-mix(in oklab,#d99020 16%,var(--surface)); color:color-mix(in oklab,#d99020 65%,var(--ink)); border-bottom:1px solid color-mix(in oklab,#d99020 30%,var(--surface)); }
.bkc-banner .c{ width:22px; height:22px; border-radius:50%; color:#fff; display:inline-flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; }
.bkc-banner.ok .c{ background:var(--green); }
.bkc-banner.pending .c{ background:#d99020; }
.bkc-grid{ display:grid; grid-template-columns:1fr 342px; }
@media (max-width:840px){ .bkc-grid{ grid-template-columns:1fr; } }
.bkc-card{ padding:clamp(22px,3vw,28px) clamp(20px,3vw,32px); display:flex; flex-direction:column; gap:18px; border-right:1px solid var(--line); }
@media (max-width:840px){ .bkc-card{ border-right:0; border-bottom:1px solid var(--line); } }
.bkc-when{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; border-bottom:1px solid var(--line); padding-bottom:18px; }
.bkc-when .d{ font-size:22px; font-weight:700; letter-spacing:-.02em; }
.bkc-when .t{ font-family:var(--mono); font-size:16px; color:var(--pri); font-weight:600; margin-top:5px; }
.bkc-when .code{ font-family:var(--mono); font-size:11px; letter-spacing:.05em; color:var(--mute); border:1px solid var(--line); border-radius:7px; padding:5px 9px; white-space:nowrap; }
.bkc-tot{ display:flex; justify-content:space-between; align-items:baseline; border-top:1px solid var(--line); padding-top:16px; font-size:14px; color:var(--ink-2); }
.bkc-tot b{ font-family:var(--mono); font-size:22px; color:var(--ink); }
.bkc-side{ padding:clamp(22px,3vw,28px) clamp(20px,3vw,26px); background:color-mix(in oklab,var(--pri) 4%,var(--surface)); display:flex; flex-direction:column; gap:16px; }
.bkc-side .lbl{ font-family:var(--mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--mute); margin-bottom:8px; display:block; }
.bkc-loc .t{ font-size:15px; font-weight:600; letter-spacing:-.01em; }
.bkc-loc .s{ font-size:12.5px; color:var(--mute); font-family:var(--mono); margin-top:4px; }
.bkc-pay{ display:flex; justify-content:space-between; align-items:center; border:1px solid var(--line); border-radius:12px; padding:13px 15px; background:var(--surface); font-size:13px; color:var(--ink-2); }
.bkc-pay b{ font-weight:600; color:var(--ink); }
.bkc-actions{ display:flex; flex-direction:column; gap:9px; margin-top:auto; }
.bkc-actions .btn-pri,.bkc-actions .btn-ghost{ width:100%; }
.bkc-actions .btn-ghost{ height:42px; }
.bkc-note{ font-size:12px; color:var(--mute); line-height:1.5; }

/* ===== notice (token confirm · payment cancel) ===================== */
.notice{ max-width:560px; margin:0 auto; padding:clamp(36px,6vw,56px) 24px; text-align:center; }
.notice .ic{ width:74px; height:74px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; margin-bottom:20px; }
.notice .ic.ok{ background:color-mix(in oklab,var(--green) 16%,var(--surface)); color:var(--green); }
.notice .ic.bad{ background:color-mix(in oklab,var(--red) 14%,var(--surface)); color:var(--red); }
.notice .ic.wait{ background:color-mix(in oklab,#d99020 18%,var(--surface)); color:#d99020; }
.notice h1{ font-size:clamp(22px,4vw,27px); font-weight:700; letter-spacing:-.025em; margin:0 0 10px; }
.notice .lead{ color:var(--ink-2); font-size:15px; line-height:1.5; margin:0 auto 24px; max-width:430px; }
.notice .card{ border:1px solid var(--line); border-radius:16px; padding:18px 20px; background:var(--surface); text-align:left; max-width:430px; margin:0 auto 24px; }
.notice .card .d{ font-size:17px; font-weight:700; letter-spacing:-.02em; }
.notice .card .t{ font-family:var(--mono); color:var(--pri); font-weight:600; margin-top:4px; }
.notice .card .row{ display:flex; justify-content:space-between; gap:12px; padding:9px 0; border-top:1px solid var(--line-2); font-size:13.5px; }
.notice .card .row:first-of-type{ border-top:0; }
.notice .card .row .k{ color:var(--mute); }
.notice .acts{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; max-width:430px; margin:0 auto; }
.notice .acts form{ flex:1; }
.notice .acts .btn-pri,.notice .acts .btn-ghost{ width:100%; }
.notice .help{ margin-top:22px; font-size:12.5px; color:var(--mute); }
.notice .help a{ color:var(--pri-deep); font-weight:500; }

/* ===== simple message page (NotPublished) ========================== */
.pub-msg{ min-height:100vh; display:flex; align-items:center; justify-content:center; padding:40px 24px; text-align:center; }
.pub-msg .inner{ max-width:420px; }
.pub-msg .emoji{ font-size:54px; margin-bottom:16px; }
.pub-msg h1{ font-size:24px; font-weight:700; letter-spacing:-.03em; margin:0 0 8px; }
.pub-msg p{ color:var(--mute); font-size:15px; margin:0 0 30px; }
.pub-msg .home{ display:inline-flex; align-items:center; gap:8px; padding:0 20px; height:46px; border-radius:11px; background:var(--pri); color:#fff; font-weight:600; font-size:14.5px; }
