/* ============================================================
   SimplyBarbers — Design System
   Heritage luxury × sci-fi futurism. Near-black / gold / ivory.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,opsz,wght@0,6..96,400;0,6..96,500;0,6..96,600;0,6..96,700;0,6..96,800;1,6..96,500&family=Hanken+Grotesk:wght@300;400;500;600;700;800&family=Space+Mono:wght@400;700&display=swap');

:root{
  /* palette */
  --bg:        #121319;
  --bg-1:      #181a21;
  --bg-2:      #20242d;
  --bg-3:      #2a2e39;
  --line:      rgba(255,255,255,.08);
  --line-2:    rgba(255,255,255,.15);
  --ivory:     #ffffff;
  --ivory-dim: rgba(255,255,255,.74);
  --muted:     rgba(255,255,255,.52);
  --muted-2:   rgba(255,255,255,.34);
  /* accent = electric blue. legacy gold-* aliases now resolve to blue */
  --blue:      #5e9eff;
  --blue-1:    #8fc0ff;
  --blue-2:    #3f7de0;
  --violet:    #7a5fff;
  --pink:      #d946ef;
  --gold:      #5e9eff;
  --gold-1:    #8fc0ff;
  --gold-2:    #3f7de0;
  --gold-ink:  #04060c;
  --gold-real: #cda45e;
  --good:      #6fbf8e;
  --warn:      #d9a441;
  --bad:       #ef5a4a;

  --glow: rgba(94,158,255,.22);

  /* type — modern grotesque system (old serif retired) */
  --serif: 'Hanken Grotesk', system-ui, sans-serif; /* legacy alias → now sans */
  --sans:  'Hanken Grotesk', system-ui, sans-serif;
  --mono:  'Space Mono', ui-monospace, monospace;

  /* geometry */
  --r-sm: 10px;
  --r:    16px;
  --r-lg: 22px;
  --r-xl: 30px;
  --maxw: 1280px;
  --pad:  clamp(20px, 5vw, 64px);

  --shadow: 0 30px 80px -30px rgba(0,0,0,.7);
  --shadow-gold: 0 20px 60px -20px rgba(94,158,255,.40);

  --ease: cubic-bezier(.2,.7,.2,1);
  --motion: 1; /* tweakable 0..1 */

  color-scheme: dark;
}

/* light mode (tweak) */
:root[data-theme="light"]{
  --bg:        #f3efe7;
  --bg-1:      #ece7dc;
  --bg-2:      #ffffff;
  --bg-3:      #f7f3ea;
  --line:      rgba(20,16,10,.12);
  --line-2:    rgba(20,16,10,.18);
  --ivory:     #1a1813;
  --ivory-dim: #3a352c;
  --muted:     #6c665a;
  --muted-2:   #948e80;
  --glow:      rgba(168,132,47,.18);
  --shadow: 0 30px 70px -34px rgba(40,30,10,.30);
  color-scheme: light;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--ivory);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  letter-spacing:.005em;
  overflow-x:hidden;
}

/* ambient field rendered behind everything */
.sb-field{
  position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden;
  background:
    radial-gradient(60vw 50vh at 78% -8%, var(--glow), transparent 60%),
    radial-gradient(50vw 40vh at 8% 12%, rgba(94,158,255,.07), transparent 60%),
    radial-gradient(70vw 60vh at 50% 120%, rgba(94,158,255,.06), transparent 60%);
  opacity:calc(.9 * var(--motion) + .1);
}
.sb-field::before, .sb-field::after{ content:""; position:absolute; border-radius:50%; filter:blur(72px); opacity:calc(.55*var(--motion)); }
.sb-field::before{ width:46vw; height:46vw; left:52%; top:-14%; background:radial-gradient(circle, rgba(94,158,255,.22), transparent 65%); animation:aur1 26s ease-in-out infinite; }
.sb-field::after{ width:42vw; height:42vw; left:-12%; top:42%; background:radial-gradient(circle, rgba(122,95,255,.15), transparent 65%); animation:aur2 32s ease-in-out infinite; }
@keyframes aur1{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(-8%,10%) scale(1.18);} }
@keyframes aur2{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(12%,-8%) scale(1.22);} }
@media (prefers-reduced-motion: reduce){ .sb-field::before,.sb-field::after{ animation:none; } }
.sb-particles{ position:fixed; inset:0; z-index:0; pointer-events:none; }
.sb-grid{ position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(94,158,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(94,158,255,.07) 1px, transparent 1px);
  background-size:48px 48px;
  -webkit-mask-image:radial-gradient(130% 100% at 72% 6%, #000 0%, rgba(0,0,0,.6) 38%, transparent 66%);
  mask-image:radial-gradient(130% 100% at 72% 6%, #000 0%, rgba(0,0,0,.6) 38%, transparent 66%);
  opacity:calc(.55*var(--motion)+.18);
  animation:gridmove 26s linear infinite;
}
@keyframes gridmove{ to{ background-position:48px 48px, 48px 48px; } }
@media (prefers-reduced-motion: reduce){ .sb-grid{ animation:none; } }
.sb-top{ position:fixed; left:18px; bottom:18px; z-index:88; width:46px; height:46px; border-radius:50%;
  background:color-mix(in srgb,var(--bg-2) 90%, transparent); border:1px solid var(--line-2); color:var(--ivory); cursor:pointer;
  font-size:19px; display:grid; place-items:center; opacity:0; transform:translateY(12px); pointer-events:none;
  transition:.4s var(--ease); box-shadow:var(--shadow); backdrop-filter:blur(10px); }
.sb-top.show{ opacity:1; transform:none; pointer-events:auto; }
.sb-top:hover{ border-color:var(--blue); color:var(--blue-1); transform:translateY(-2px); }
.sb-grain{
  position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
.sb-shell{ position:relative; z-index:1; }

/* ---------- typography ---------- */
h1,h2,h3,h4{ font-family:var(--sans); font-weight:700; line-height:1.0; margin:0; letter-spacing:-.025em; }
.display{ font-size:clamp(48px, 8.5vw, 132px); font-weight:800; line-height:.9; letter-spacing:-.035em; }
.h1{ font-size:clamp(40px,6vw,82px); font-weight:800; letter-spacing:-.03em; }
.h2{ font-size:clamp(32px,4.4vw,60px); font-weight:800; letter-spacing:-.03em; }
.h3{ font-size:clamp(24px,3vw,38px); font-weight:700; }
.serif-it{ font-style:normal; font-weight:800; }
p{ margin:0; }

.kicker{
  font-family:var(--mono); font-size:12px; letter-spacing:.34em; text-transform:uppercase;
  color:var(--gold-1); display:inline-flex; align-items:center; gap:10px;
}
.kicker::before{ content:""; width:26px; height:1px; background:linear-gradient(90deg,var(--gold),transparent); }
.kicker.center::after{ content:""; width:26px; height:1px; background:linear-gradient(270deg,var(--gold),transparent); }

.lede{ font-size:clamp(17px,1.5vw,20px); color:var(--ivory-dim); line-height:1.65; max-width:60ch; }
.muted{ color:var(--muted); }
.mono{ font-family:var(--mono); }
.gold{ color:var(--gold-1); }
.amp{ font-family:var(--serif); font-style:italic; color:var(--gold-1); font-weight:500; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(80px,11vw,160px); position:relative; }
.section.tight{ padding-block:clamp(56px,7vw,96px); }
.grid{ display:grid; gap:24px; }
.between{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.eyebrow-row{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:clamp(36px,5vw,64px); }
.stack-sm{ display:flex; flex-direction:column; gap:8px; }
.divider{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- buttons ---------- */
.btn{
  font-family:var(--sans); font-weight:600; font-size:15px; letter-spacing:.01em;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 26px; border-radius:100px; border:1px solid transparent;
  background:linear-gradient(100deg, var(--blue-2), var(--blue)); color:#fff; cursor:pointer; text-decoration:none;
  transition:transform .5s var(--ease), background .3s, box-shadow .5s, color .3s, border-color .3s, filter .3s;
  will-change:transform; position:relative; isolation:isolate; white-space:nowrap;
}
.btn:hover{ box-shadow:var(--shadow-gold); filter:brightness(1.06); }
.btn.primary{ background:linear-gradient(100deg, var(--blue-2) 0%, var(--blue) 65%, var(--blue-1) 130%); color:#fff; }
.btn.ghost{ background:transparent; color:var(--ivory); border-color:var(--line-2); }
.btn.ghost:hover{ border-color:var(--gold); color:var(--gold-1); box-shadow:none; background:rgba(94,158,255,.06); }
.btn.dark{ background:var(--bg-3); color:var(--ivory); border:1px solid var(--line-2); }
.btn.dark:hover{ border-color:var(--gold); box-shadow:none; }
.btn.sm{ padding:11px 18px; font-size:13.5px; }
.btn.lg{ padding:18px 32px; font-size:16px; }
.btn .ar{ transition:transform .5s var(--ease); }
.btn:hover .ar{ transform:translateX(4px); }
.btn-row{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

.link-arrow{ font-family:var(--mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold-1); text-decoration:none; display:inline-flex; gap:8px; align-items:center; }
.link-arrow .ar{ transition:transform .4s var(--ease); }
.link-arrow:hover .ar{ transform:translateX(5px); }

/* ---------- cards / surfaces ---------- */
.card{
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--line); border-radius:var(--r-lg); position:relative; overflow:hidden;
}
.glass{
  background:linear-gradient(180deg, rgba(244,239,230,.06), rgba(244,239,230,.02));
  border:1px solid var(--line-2); border-radius:var(--r-lg);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
}
.hairline-top{ box-shadow:inset 0 1px 0 rgba(244,239,230,.08); }
.gold-edge{ border:1px solid rgba(94,158,255,.32); }
.pad{ padding:clamp(22px,3vw,34px); }

.tag{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--gold-1); border:1px solid rgba(94,158,255,.3); border-radius:100px; padding:6px 12px;
  display:inline-flex; align-items:center; gap:7px; background:rgba(94,158,255,.05);
}
.chip{
  font-size:13px; color:var(--ivory-dim); border:1px solid var(--line-2); border-radius:100px;
  padding:8px 15px; display:inline-flex; gap:8px; align-items:center; background:var(--bg-2);
  cursor:pointer; transition:.25s var(--ease); user-select:none; white-space:nowrap;
}
.chip:hover{ border-color:var(--gold); color:var(--ivory); }
.chip.on{ background:var(--gold); color:var(--gold-ink); border-color:var(--gold); font-weight:600; }

.pill-stat{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; color:var(--muted); }

/* star rating */
.stars{ color:var(--gold-1); letter-spacing:2px; font-size:13px; }

/* avatar / image slot framing */
.framed{ border:1px solid var(--line-2); box-shadow:var(--shadow); }
image-slot{ display:block; background:
   repeating-linear-gradient(135deg, var(--bg-2), var(--bg-2) 11px, var(--bg-3) 11px, var(--bg-3) 22px);
   color:var(--muted); }

/* ---------- nav ---------- */
.sb-nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  transition:background .4s, border-color .4s, backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.sb-nav.scrolled{
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.sb-nav .bar{ display:flex; align-items:center; justify-content:space-between; height:74px; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--ivory); }
.brand .mark{
  width:34px; height:34px; border-radius:9px; display:grid; place-items:center;
  background:linear-gradient(180deg,var(--gold-1),var(--gold)); color:var(--gold-ink);
  font-family:var(--serif); font-weight:700; font-size:20px; box-shadow:var(--shadow-gold);
}
.brand .wordmark{ font-family:var(--serif); font-weight:600; font-size:19px; letter-spacing:.02em; }
.brand .wordmark b{ color:var(--gold-1); font-weight:600; }
.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  color:var(--ivory-dim); text-decoration:none; font-size:14px; font-weight:500;
  padding:9px 14px; border-radius:100px; transition:.25s var(--ease); position:relative;
}
.nav-links a:hover{ color:var(--ivory); background:rgba(244,239,230,.05); }
.nav-links a.active{ color:var(--gold-1); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-burger{ display:none; background:none; border:1px solid var(--line-2); border-radius:10px; width:42px; height:42px; color:var(--ivory); cursor:pointer; }
.nav-drawer{ display:none; }

@media (max-width:1024px){
  .nav-links, .nav-cta .btn.desktop{ display:none; }
  .nav-burger{ display:grid; place-items:center; }
  .nav-drawer{
    display:block; position:fixed; inset:0; z-index:59; background:color-mix(in srgb,var(--bg) 96%, transparent);
    backdrop-filter:blur(20px); padding:96px var(--pad) 40px; opacity:0; pointer-events:none; transition:.4s var(--ease);
    transform:translateY(-8px);
  }
  .nav-drawer.open{ opacity:1; pointer-events:auto; transform:none; }
  .nav-drawer a{ display:block; font-family:var(--serif); font-size:30px; color:var(--ivory); text-decoration:none; padding:14px 0; border-bottom:1px solid var(--line); }
  .nav-drawer a.active{ color:var(--gold-1); }
}

/* ---------- footer ---------- */
.sb-footer{ border-top:1px solid var(--line); background:var(--bg-1); position:relative; z-index:1; }
.sb-footer .top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-block:72px; }
.sb-footer h5{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:0 0 18px; }
.sb-footer a{ display:block; color:var(--ivory-dim); text-decoration:none; font-size:14px; padding:6px 0; transition:.2s; }
.sb-footer a:hover{ color:var(--gold-1); }
.sb-footer .bottom{ border-top:1px solid var(--line); padding-block:26px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:13px; color:var(--muted); }
@media (max-width:820px){ .sb-footer .top{ grid-template-columns:1fr 1fr; gap:32px; } }

/* ---------- reveal motion ---------- */
[data-reveal]{ opacity:0; transform:translateY(calc(26px * var(--motion))); transition:opacity .9s var(--ease), transform 1s var(--ease); transition-delay:var(--d,0ms); }
[data-reveal].in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ [data-reveal]{ opacity:1 !important; transform:none !important; } }

/* float loop */
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(calc(-12px * var(--motion))); } }
.float{ animation:floaty 7s var(--ease) infinite; }
.float.slow{ animation-duration:10s; }
@media (prefers-reduced-motion: reduce){ .float{ animation:none; } }

/* shimmering gold text */
.shimmer{
  background:linear-gradient(100deg, var(--gold-2) 20%, var(--gold-1) 42%, #fff6df 50%, var(--gold-1) 58%, var(--gold-2) 80%);
  background-size:200% 100%; -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:shim 6s linear infinite;
}
@keyframes shim{ to{ background-position:-200% 0; } }
@media (prefers-reduced-motion: reduce){ .shimmer{ animation:none; } }

/* ---------- forms ---------- */
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.input, .select, textarea.input{
  width:100%; background:var(--bg-2); border:1px solid var(--line-2); border-radius:var(--r-sm);
  color:var(--ivory); font-family:var(--sans); font-size:15px; padding:14px 16px; transition:.25s var(--ease);
}
.input:focus, .select:focus, textarea.input:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 4px rgba(94,158,255,.12); }
.input::placeholder{ color:var(--muted-2); }

/* segmented */
.seg{ display:inline-flex; background:var(--bg-2); border:1px solid var(--line-2); border-radius:100px; padding:4px; gap:4px; }
.seg button{ font-family:var(--sans); font-size:13px; font-weight:600; color:var(--muted); background:none; border:0; border-radius:100px; padding:9px 16px; cursor:pointer; transition:.25s var(--ease); }
.seg button.on{ background:var(--gold); color:var(--gold-ink); }

/* progress steps */
.steps{ display:flex; align-items:center; gap:0; }
.steps .st{ display:flex; align-items:center; gap:12px; color:var(--muted); font-size:13px; }
.steps .st .dot{ width:30px; height:30px; border-radius:50%; display:grid; place-items:center; border:1px solid var(--line-2); font-family:var(--mono); font-size:12px; background:var(--bg-2); }
.steps .st.done .dot{ background:var(--gold); color:var(--gold-ink); border-color:var(--gold); }
.steps .st.now .dot{ border-color:var(--gold); color:var(--gold-1); box-shadow:0 0 0 4px rgba(94,158,255,.12); }
.steps .st.now{ color:var(--ivory); }
.steps .bar{ width:clamp(20px,5vw,70px); height:1px; background:var(--line-2); margin:0 6px; }

/* dashboard shell */
.app{ display:grid; grid-template-columns:260px 1fr; min-height:100vh; }
.side{ border-right:1px solid var(--line); background:var(--bg-1); padding:22px 18px; position:sticky; top:0; height:100vh; overflow:auto; }
.side .nav-item{ display:flex; align-items:center; gap:12px; color:var(--ivory-dim); text-decoration:none; padding:11px 13px; border-radius:11px; font-size:14px; font-weight:500; transition:.2s; }
.side .nav-item:hover{ background:rgba(244,239,230,.05); color:var(--ivory); }
.side .nav-item.active{ background:rgba(94,158,255,.12); color:var(--gold-1); }
.side .grp{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted-2); padding:18px 13px 8px; }
.main{ padding:clamp(20px,3vw,38px); min-width:0; }
.kpis{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.kpi{ padding:22px; }
.kpi .v{ font-family:var(--serif); font-size:38px; font-weight:600; letter-spacing:-.02em; }
.kpi .l{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.kpi .delta{ font-size:12px; font-weight:600; }
.kpi .delta.up{ color:var(--good); } .kpi .delta.down{ color:var(--bad); }
@media (max-width:1100px){ .kpis{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:860px){ .app{ grid-template-columns:1fr; } .side{ display:none; } }

/* tiny bar chart */
.bars{ display:flex; align-items:flex-end; gap:8px; height:140px; }
.bars .b{ flex:1; background:linear-gradient(180deg,var(--gold-1),var(--gold-2)); border-radius:6px 6px 2px 2px; opacity:.85; transition:height 1s var(--ease); }
.bars .b.ghost{ background:var(--bg-3); }

table.tbl{ width:100%; border-collapse:collapse; font-size:14px; }
table.tbl th{ text-align:left; font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); padding:12px 14px; border-bottom:1px solid var(--line); }
table.tbl td{ padding:14px; border-bottom:1px solid var(--line); color:var(--ivory-dim); }
table.tbl tr:hover td{ background:rgba(244,239,230,.03); }
.badge{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; padding:5px 10px; border-radius:100px; display:inline-block; }
.badge.ok{ color:var(--good); background:rgba(111,191,142,.12); }
.badge.pend{ color:var(--warn); background:rgba(217,164,65,.12); }
.badge.no{ color:var(--bad); background:rgba(212,121,107,.12); }

/* ---------- accordion ---------- */
.acc-item{ border-bottom:1px solid var(--line); }
.acc-q{ width:100%; background:none; border:0; color:var(--ivory); text-align:left; cursor:pointer;
  font-family:var(--serif); font-size:clamp(20px,2.4vw,27px); font-weight:500; padding:26px 0; display:flex; justify-content:space-between; align-items:center; gap:20px; }
.acc-q .pm{ font-family:var(--sans); font-size:26px; color:var(--gold-1); transition:transform .4s var(--ease); flex:none; }
.acc-item.open .acc-q .pm{ transform:rotate(45deg); }
.acc-a{ max-height:0; overflow:hidden; transition:max-height .5s var(--ease); }
.acc-a .inner{ padding:0 0 26px; color:var(--ivory-dim); max-width:70ch; font-size:16px; }

/* ---------- tweaks panel ---------- */
.sb-tweaks{ position:fixed; right:18px; bottom:18px; z-index:90; width:260px;
  background:color-mix(in srgb,var(--bg-2) 92%, transparent); border:1px solid var(--line-2); border-radius:18px;
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); box-shadow:var(--shadow); padding:16px; }
.sb-tweaks[hidden]{ display:none; }
.tw-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.tw-head .mono{ font-size:11px; letter-spacing:.24em; color:var(--gold-1); }
.tw-x{ background:none; border:0; color:var(--muted); cursor:pointer; font-size:14px; }
.tw-sec{ margin-bottom:16px; }
.tw-sec>label{ display:flex; justify-content:space-between; font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:9px; }
.tw-swatches{ display:flex; gap:9px; }
.tw-sw{ width:30px; height:30px; border-radius:9px; border:2px solid transparent; cursor:pointer; box-shadow:inset 0 0 0 1px rgba(0,0,0,.2); transition:.2s; }
.tw-sw.on{ border-color:var(--ivory); transform:scale(1.05); }
.tw-range{ width:100%; accent-color:var(--gold); }
.sb-tweaks .seg{ width:100%; } .sb-tweaks .seg button{ flex:1; }
.tw-foot{ font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted-2); text-align:center; margin-top:4px; }
.sb-tw-fab{ position:fixed; right:18px; bottom:18px; z-index:89; width:46px; height:46px; border-radius:50%;
  background:linear-gradient(180deg,var(--gold-1),var(--gold)); color:var(--gold-ink); border:0; cursor:pointer; font-size:18px;
  box-shadow:var(--shadow-gold); transition:transform .3s var(--ease); }
.sb-tw-fab:hover{ transform:scale(1.08) rotate(90deg); }
.sb-tweaks:not([hidden]) ~ .sb-tw-fab{ display:none; }

/* ---------- portrait media ---------- */
.media{ position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line-2); }
.media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(12,12,14,.5)); pointer-events:none; }
.media image-slot{ width:100%; height:100%; }
.ring{ border:1px solid rgba(94,158,255,.4); border-radius:50%; padding:5px; display:inline-block; }

/* price */
.price{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; }
.price .cur{ font-size:.6em; vertical-align:super; color:var(--gold-1); }

/* feature tick list */
.ticks{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px; }
.ticks li{ display:flex; gap:12px; align-items:flex-start; color:var(--ivory-dim); font-size:15px; }
.ticks li::before{ content:"✓"; color:var(--gold-1); font-weight:700; flex:none; }

/* utility */
.center{ text-align:center; }
.mt-s{ margin-top:14px; } .mt{ margin-top:24px; } .mt-l{ margin-top:44px; }
.rel{ position:relative; } .z{ position:relative; z-index:2; }
.hide-mob{ } @media (max-width:680px){ .hide-mob{ display:none !important; } }
.full{ width:100%; }

/* ---------- dashboard chrome (shared) ---------- */
.topbar{ display:flex; align-items:center; justify-content:space-between; gap:18px; margin-bottom:28px; flex-wrap:wrap; }
.topbar .greet{ font-family:var(--serif); font-size:clamp(24px,3vw,34px); font-weight:600; letter-spacing:-.01em; }
.topbar .sub{ color:var(--muted); font-size:14px; margin-top:2px; }
.searchbox{ display:flex; align-items:center; gap:10px; background:var(--bg-2); border:1px solid var(--line-2); border-radius:100px; padding:10px 16px; color:var(--muted); font-size:14px; min-width:200px; }
.searchbox input{ background:none; border:0; color:var(--ivory); outline:none; font-family:var(--sans); font-size:14px; width:100%; }
.iconbtn{ width:42px; height:42px; border-radius:12px; border:1px solid var(--line-2); background:var(--bg-2); color:var(--ivory); cursor:pointer; position:relative; display:grid; place-items:center; }
.iconbtn .ndot{ position:absolute; top:9px; right:9px; width:7px; height:7px; border-radius:50%; background:var(--gold-1); }
.side-brand{ display:flex; align-items:center; gap:10px; padding:6px 10px 22px; text-decoration:none; color:var(--ivory); }
.side-foot{ margin-top:24px; padding-top:18px; }
.side-user{ display:flex; align-items:center; gap:10px; padding:10px; border-radius:12px; background:var(--bg-2); border:1px solid var(--line); }
.role-switch{ display:flex; gap:6px; background:var(--bg-2); border:1px solid var(--line); border-radius:100px; padding:4px; margin:0 6px 14px; }
.role-switch a{ flex:1; text-align:center; font-size:12px; font-weight:600; color:var(--muted); text-decoration:none; padding:8px; border-radius:100px; }
.role-switch a.on{ background:var(--gold); color:var(--gold-ink); }
.view-title{ font-family:var(--serif); font-size:clamp(26px,3.4vw,40px); font-weight:600; letter-spacing:-.01em; margin-bottom:6px; }
.section-head{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin:36px 0 18px; flex-wrap:wrap; }
.section-head h3{ font-family:var(--serif); font-size:22px; }
.dgrid{ display:grid; gap:18px; }
.cols-2{ grid-template-columns:1fr 1fr; } .cols-3{ grid-template-columns:repeat(3,1fr); } .cols-12{ grid-template-columns:2fr 1fr; }
@media (max-width:1100px){ .cols-3{ grid-template-columns:1fr 1fr; } .cols-12{ grid-template-columns:1fr; } }
@media (max-width:700px){ .cols-2,.cols-3{ grid-template-columns:1fr; } }
.list-row{ display:flex; align-items:center; gap:14px; padding:16px; border:1px solid var(--line); border-radius:var(--r); background:var(--bg-2); transition:.25s var(--ease); }
.list-row:hover{ border-color:var(--line-2); }
.list-row .ra{ margin-left:auto; display:flex; align-items:center; gap:12px; }
.thumb{ width:54px; height:54px; border-radius:12px; overflow:hidden; flex:none; border:1px solid var(--line-2); }
.thumb image-slot{ width:100%; height:100%; }
.dot-line{ width:8px; height:8px; border-radius:50%; background:var(--good); flex:none; }
.progress{ height:7px; border-radius:100px; background:var(--bg-3); overflow:hidden; }
.progress i{ display:block; height:100%; background:linear-gradient(90deg,var(--gold-2),var(--gold-1)); border-radius:100px; }
.ring-stat{ --p:70; width:96px; height:96px; border-radius:50%; display:grid; place-items:center;
  background:conic-gradient(var(--gold-1) calc(var(--p)*1%), var(--bg-3) 0); position:relative; }
.ring-stat::before{ content:""; position:absolute; inset:9px; border-radius:50%; background:var(--bg-1); }
.ring-stat span{ position:relative; font-family:var(--serif); font-size:22px; }
.msg-thread{ display:flex; flex-direction:column; gap:12px; }
.bubble{ max-width:74%; padding:12px 16px; border-radius:16px; font-size:14px; line-height:1.5; }
.bubble.them{ background:var(--bg-3); border:1px solid var(--line); align-self:flex-start; border-bottom-left-radius:4px; }
.bubble.me{ background:linear-gradient(180deg,var(--gold-1),var(--gold)); color:var(--gold-ink); align-self:flex-end; border-bottom-right-radius:4px; }
.toggle{ width:44px; height:26px; border-radius:100px; background:var(--bg-3); border:1px solid var(--line-2); position:relative; cursor:pointer; flex:none; transition:.25s; }
.toggle::after{ content:""; position:absolute; top:2px; left:2px; width:20px; height:20px; border-radius:50%; background:var(--ivory); transition:.25s var(--ease); }
.toggle.on{ background:var(--gold); } .toggle.on::after{ left:20px; background:var(--gold-ink); }
.set-row{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:16px 0; border-bottom:1px solid var(--line); }
.set-row:last-child{ border-bottom:0; }
.mobile-only{ display:none; } @media (max-width:860px){ .mobile-only{ display:block; } }
.dash-mobnav{ display:none; }
@media (max-width:860px){
  .dash-mobnav{ display:flex; gap:8px; overflow-x:auto; padding:10px 0 14px; margin-bottom:6px;
    position:sticky; top:0; z-index:20; background:linear-gradient(180deg,var(--bg) 72%, transparent);
    -webkit-overflow-scrolling:touch; scrollbar-width:none; }
  .dash-mobnav::-webkit-scrollbar{ display:none; }
  .dmn{ flex:none; white-space:nowrap; font-family:var(--sans); font-size:13px; font-weight:600; color:var(--muted);
    background:var(--bg-2); border:1px solid var(--line-2); border-radius:100px; padding:9px 15px; cursor:pointer; transition:.2s; }
  .dmn.on{ background:var(--blue); color:#06101f; border-color:var(--blue); }
}

/* ============================================================
   Cinematic hero (full-bleed scene + glass console)
   ============================================================ */
.cine{ position:relative; min-height:100svh; display:flex; flex-direction:column; justify-content:center;
  overflow:hidden; padding-top:96px; padding-bottom:40px; }
.cine-bg{ position:absolute; inset:0; z-index:0;
  background:url("media/hero-stage.png") center right/cover no-repeat; }
.cine-bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, var(--bg) 3%, rgba(6,8,14,.55) 34%, transparent 64%),
            linear-gradient(0deg, var(--bg) 1%, transparent 26%); }
.cine-glow{ position:absolute; z-index:1; pointer-events:none; inset:0;
  background:radial-gradient(38vw 38vw at 64% 42%, rgba(94,158,255,.16), transparent 60%); opacity:calc(.4+.6*var(--motion)); }
.cine-inner{ position:relative; z-index:2; width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad);
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,500px); gap:40px; align-items:center; }
.cine-copy{ max-width:620px; }
.mega{ font-family:var(--sans); font-weight:800; line-height:.94; letter-spacing:-.03em;
  font-size:clamp(50px,8.2vw,112px); margin:0; }
.grad-blue{ background:linear-gradient(100deg, var(--blue) 0%, #8f7bff 28%, #56d2e6 52%, var(--blue-1) 76%, var(--blue) 100%);
  background-size:220% 100%; -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:gradshift 7s linear infinite; }
@keyframes gradshift{ to{ background-position:-220% 0; } }
@media (prefers-reduced-motion:reduce){ .grad-blue{ animation:none; } }
.cine .lede{ color:#c9d3e4; }
.cine-stats{ display:flex; gap:clamp(18px,3vw,38px); margin-top:36px; align-items:center; }
.cine-stats .v{ font-family:var(--sans); font-weight:800; font-size:clamp(22px,2.6vw,32px); letter-spacing:-.02em; }
.cine-stats .l{ font-size:12px; color:var(--muted); margin-top:2px; }
.cine-stats .sep{ width:1px; height:38px; background:var(--line-2); }
.activity{ display:inline-flex; align-items:center; gap:12px; margin-top:28px; padding:9px 16px 9px 9px;
  border-radius:100px; background:rgba(10,14,22,.6); border:1px solid var(--line-2); backdrop-filter:blur(12px); }
.activity .av{ width:34px; height:34px; border-radius:50%; overflow:hidden; border:1px solid var(--line-2); flex:none; }
.activity .av image-slot{ width:100%; height:100%; }
.activity .txt{ font-size:13px; color:var(--ivory-dim); }
.activity .txt b{ color:var(--ivory); font-weight:600; }
.activity .ago{ font-family:var(--mono); font-size:11px; color:var(--muted); }
.activity .live{ width:8px; height:8px; border-radius:50%; background:var(--blue); box-shadow:0 0 0 0 rgba(94,158,255,.6); animation:livepulse 1.8s infinite; }
.console{ position:relative; display:flex; flex-direction:column; gap:14px; }
.gcard{ background:linear-gradient(180deg, rgba(20,26,38,.74), rgba(10,14,22,.64));
  border:1px solid rgba(255,255,255,.10); border-radius:18px; backdrop-filter:blur(22px); -webkit-backdrop-filter:blur(22px);
  box-shadow:0 24px 60px -24px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.06); padding:16px 18px; }
.gcard .gh{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:12px; }
.gcard .gt{ font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--blue-1); }
.gcard .gx{ color:var(--muted); font-size:13px; cursor:pointer; }
.g-ai{ display:flex; gap:14px; align-items:center; }
.g-orb{ width:56px; height:56px; border-radius:14px; flex:none; position:relative; overflow:hidden;
  background:radial-gradient(circle at 40% 35%, rgba(143,192,255,.9), rgba(94,158,255,.5) 45%, rgba(20,30,60,.9) 80%);
  box-shadow:0 0 22px rgba(94,158,255,.4), inset 0 0 18px rgba(255,255,255,.25); animation:floaty 6s var(--ease) infinite; }
.g-match{ font-family:var(--sans); font-weight:800; font-size:22px; }
.g-svc{ display:flex; align-items:center; gap:12px; padding:9px 0; border-top:1px solid var(--line); }
.g-svc:first-of-type{ border-top:0; }
.g-svc .ic{ width:34px; height:34px; border-radius:9px; overflow:hidden; border:1px solid var(--line-2); flex:none; }
.g-svc .ic image-slot{ width:100%; height:100%; }
.g-svc .nm{ font-size:14px; } .g-svc .du{ font-size:11px; color:var(--muted); }
.g-svc .pr{ margin-left:auto; font-family:var(--sans); font-weight:700; color:var(--blue-1); }
.g-cal{ display:grid; grid-template-columns:repeat(7,1fr); gap:5px; }
.g-cal span{ text-align:center; font-size:11px; padding:7px 0; border-radius:8px; color:var(--ivory-dim); cursor:pointer; }
.g-cal span.h{ color:var(--muted); font-family:var(--mono); font-size:9px; cursor:default; }
.g-cal span.on{ background:var(--blue); color:#06101f; font-weight:700; }
.g-times{ display:grid; grid-template-columns:repeat(4,1fr); gap:7px; margin-top:10px; }
.g-times button{ font-family:var(--sans); font-size:12px; color:var(--ivory-dim); background:rgba(255,255,255,.04);
  border:1px solid var(--line-2); border-radius:9px; padding:9px 0; cursor:pointer; transition:.2s; }
.g-times button.on{ background:var(--blue); color:#06101f; border-color:var(--blue); font-weight:700; }
.g-times button:hover{ border-color:var(--blue); }
.g-confirm{ margin-top:12px; width:100%; display:flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--sans); font-weight:700; font-size:14px; padding:13px; border-radius:100px; cursor:pointer; border:0;
  background:linear-gradient(100deg, var(--blue-2), var(--blue) 60%, var(--gold)); color:#06101f;
  box-shadow:0 14px 30px -12px rgba(94,158,255,.6); }
.cine-logos{ position:relative; z-index:2; max-width:var(--maxw); margin:46px auto 0; padding-inline:var(--pad); }
.cine-logos .cap{ text-align:center; font-family:var(--mono); font-size:11px; letter-spacing:.26em; color:var(--muted-2); }
.cine-logos .row{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:clamp(20px,5vw,58px); margin-top:18px; opacity:.6; }
.cine-logos .row span{ font-family:var(--serif); font-weight:600; font-size:clamp(15px,1.6vw,20px); color:var(--ivory-dim); letter-spacing:.02em; }
@media (max-width:980px){
  .cine-inner{ grid-template-columns:1fr; }
  .console{ max-width:440px; }
  .cine-bg{ background-position:72% center; }
  .cine-bg::after{ background:linear-gradient(0deg, var(--bg) 14%, rgba(6,8,14,.5) 52%, rgba(6,8,14,.4)); }
}
@media (max-width:560px){ .cine-stats{ flex-wrap:wrap; gap:16px; } .cine-stats .sep{ display:none; } .activity{ flex-wrap:wrap; } }

/* ============================================================
   Smart click router — toast component
   ============================================================ */
.sb-toast-host{ position:fixed; left:50%; bottom:28px; transform:translateX(-50%); z-index:9999; display:flex; flex-direction:column; gap:8px; pointer-events:none; }
.sb-toast{
  display:flex; align-items:center; gap:10px;
  padding:12px 18px; min-width:220px; max-width:480px;
  background:linear-gradient(180deg, rgba(33,36,45,0.96), rgba(26,28,35,0.96));
  border:1px solid rgba(255,255,255,0.10);
  border-radius:14px;
  color:#fff; font-family:'Hanken Grotesk', system-ui, sans-serif; font-size:14px; font-weight:500;
  box-shadow:0 18px 50px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.02) inset;
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  opacity:0; transform:translateY(10px);
  transition: opacity 0.22s ease, transform 0.22s cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events:auto;
}
.sb-toast.in{ opacity:1; transform:translateY(0); }
.sb-toast-dot{ width:8px; height:8px; border-radius:50%; flex-shrink:0; background:#5e9eff; box-shadow:0 0 10px rgba(94,158,255,0.80); }
.sb-toast.ok .sb-toast-dot{ background:#56d2e6; box-shadow:0 0 10px rgba(86,210,230,0.80); }
.sb-toast.warn .sb-toast-dot{ background:#f59e0b; box-shadow:0 0 10px rgba(245,158,11,0.80); }
.sb-toast.err  .sb-toast-dot{ background:#ef5a4a; box-shadow:0 0 10px rgba(239,90,74,0.80); }
.sb-toast-msg{ color:#fff; letter-spacing:-0.005em; line-height:1.35; }
@media (prefers-reduced-motion: reduce){
  .sb-toast{ transition:none; }
}
