/* ============================================================ PRODUCT MOCKUP (built from design system) */
.mock{ --mh:520px; display:grid; grid-template-columns:200px 1fr; background:var(--bg); font-family:var(--font); color:var(--text-mid); }
.mock--rail{ grid-template-columns:200px 1fr 232px; }
@media (max-width:720px){ .mock{ grid-template-columns:1fr; } .mock--rail{ grid-template-columns:1fr; } .mock__side, .mock__rail{ display:none; } }

.mock__side{ background:var(--bg-soft); border-right:1px solid var(--border); padding:16px 12px; display:flex; flex-direction:column; gap:3px; }
.mock__brand{ display:flex; align-items:center; gap:9px; padding:4px 6px 16px; }
.mock__brand .bm{ width:30px; height:30px; border-radius:9px; display:grid; place-items:center; color:#fff; background:linear-gradient(150deg,var(--accent-bright),var(--accent) 55%,var(--accent-deep)); }
.mock__brand .bm svg{ width:15px; height:15px; }
.mock__brand .bn{ font-family:var(--display); font-weight:700; font-size:13.5px; color:var(--text-hi); }
.mock__seg{ display:grid; grid-template-columns:1fr 1fr; gap:3px; padding:3px; border-radius:11px; background:var(--surface); border:1px solid var(--border); margin-bottom:14px; }
.mock__seg b{ text-align:center; padding:6px 0; border-radius:8px; font-size:11px; font-weight:600; color:var(--text-lo); }
.mock__seg b.on{ background:var(--surface-3); color:var(--text-hi); }
.mock__nsec{ font-family:var(--mono); font-size:8.5px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-dim); padding:12px 8px 5px; }
.mock__ni{ display:flex; align-items:center; gap:9px; padding:7px 8px; border-radius:8px; font-size:12px; font-weight:500; color:var(--text-mid); }
.mock__ni svg{ width:14px; height:14px; color:var(--text-lo); flex:none; }
.mock__ni.on{ color:var(--text-hi); background:linear-gradient(90deg, var(--accent-soft), transparent); position:relative; }
.mock__ni.on::before{ content:""; position:absolute; left:-12px; top:4px; bottom:4px; width:3px; border-radius:2px; background:var(--accent); }
.mock__ni.on svg{ color:var(--accent-bright); }

.mock__main{ padding:18px 20px; min-width:0; overflow:hidden; }
.mock__top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.mock__h{ font-family:var(--display); font-weight:600; font-size:18px; color:var(--text-hi); }
.mock__hsub{ font-size:11px; color:var(--text-lo); margin-top:2px; }
.mock__chip{ display:inline-flex; align-items:center; gap:6px; padding:7px 13px; border-radius:999px; font-size:11.5px; font-weight:600; color:#fff; background:linear-gradient(180deg, color-mix(in oklab,var(--accent),white 10%), var(--accent)); box-shadow:0 6px 16px -8px var(--accent-glow); }
.mock__chip svg{ width:13px; height:13px; }

.mock__stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:11px; margin-bottom:14px; }
.mstat{ padding:13px 14px; border-radius:13px; background:var(--surface); border:1px solid var(--border); }
.mstat__l{ font-size:10.5px; color:var(--text-lo); }
.mstat__v{ font-family:var(--display); font-weight:600; font-size:23px; letter-spacing:-0.02em; color:var(--text-hi); margin-top:8px; line-height:1; }
.mstat__spark{ height:24px; margin-top:9px; display:block; width:100%; }

.mock__chart{ padding:16px; border-radius:14px; background:var(--surface); border:1px solid var(--border); }
.mock__chart-h{ display:flex; align-items:center; justify-content:space-between; margin-bottom:13px; }
.mock__chart-t{ font-family:var(--mono); font-size:9.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-lo); }
.mock__chart-v{ font-family:var(--display); font-weight:600; font-size:21px; color:var(--text-hi); margin-top:5px; }
.mbars{ display:flex; align-items:flex-end; gap:9px; height:120px; }
.mbars .bar{ flex:1; border-radius:4px 4px 1px 1px; background:linear-gradient(180deg, var(--surface-3), color-mix(in oklab,var(--surface-3),transparent 35%)); position:relative; transition:height .8s cubic-bezier(.2,.7,.2,1); }
.mbars .bar.hot{ background:linear-gradient(180deg, var(--accent-bright), var(--accent)); box-shadow:0 0 22px -4px var(--accent-glow); }
.mbars .bar.hot::after{ content:attr(data-v); position:absolute; top:-22px; left:50%; transform:translateX(-50%); font-family:var(--mono); font-size:9px; font-weight:700; color:var(--text-hi); background:var(--surface-3); padding:2px 6px; border-radius:5px; white-space:nowrap; }

.mock__rail{ background:var(--bg-soft); border-left:1px solid var(--border); padding:16px 14px; display:flex; flex-direction:column; gap:12px; }
.rcard{ padding:13px; border-radius:13px; background:var(--surface); border:1px solid var(--border); }
.rcard__t{ font-family:var(--mono); font-size:9px; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-dim); margin-bottom:10px; }
.racc{ display:flex; align-items:center; gap:10px; }
.racc__av{ width:32px; height:32px; border-radius:9px; display:grid; place-items:center; font-weight:700; font-size:12px; color:#fff; background:linear-gradient(140deg,var(--accent-hot),var(--accent-deep)); }
.racc__n{ font-size:12.5px; font-weight:700; color:var(--text-hi); }
.racc__s{ font-size:10.5px; color:var(--text-lo); }
.rsend{ width:28px; height:28px; border-radius:8px; display:grid; place-items:center; color:#fff; background:linear-gradient(150deg,var(--accent),var(--accent-deep)); margin-left:auto; }
.rsend svg{ width:14px; height:14px; }
.rline{ display:flex; align-items:center; justify-content:space-between; font-size:11px; margin-top:11px; }
.rline .k{ color:var(--text-lo); } .rline .v{ color:var(--text-hi); font-weight:600; font-family:var(--mono); }
.rbar{ height:6px; border-radius:999px; background:var(--surface-3); margin-top:6px; overflow:hidden; }
.rbar i{ display:block; height:100%; border-radius:999px; background:linear-gradient(90deg,var(--accent),var(--accent-bright)); }
.rchan{ display:flex; align-items:center; gap:8px; font-size:11.5px; margin-top:9px; }
.rchan .cd{ width:8px; height:8px; border-radius:50%; flex:none; }
.rchan .cn{ color:var(--text-mid); } .rchan .cv{ margin-left:auto; font-family:var(--mono); font-weight:600; color:var(--text-hi); }

/* ============================================================ INTERFACE SHOWCASE */
.showcase{ display:grid; grid-template-columns:1.5fr 1fr; gap:var(--s4); }
@media (max-width:860px){ .showcase{ grid-template-columns:1fr; } }
.shot{ position:relative; overflow:hidden; border-radius:var(--r-xl); border:1px solid var(--border-2); background:var(--bg-soft); box-shadow:var(--shadow-card); transition:transform .35s cubic-bezier(.2,.7,.2,1), border-color .35s; }
.shot:hover{ transform:translateY(-4px); border-color:var(--accent-line); }
.shot__cap{ position:absolute; left:0; right:0; bottom:0; padding:var(--s7) var(--s6) var(--s5); background:linear-gradient(0deg, color-mix(in oklab,var(--bg),transparent 5%) 8%, transparent); z-index:6; }
.shot__t{ font-family:var(--display); font-weight:600; font-size:18px; color:var(--text-hi); }
.shot__d{ font-size:13px; color:var(--text-lo); margin-top:5px; max-width:34ch; }
.shot__col{ display:grid; gap:var(--s4); }

/* ============================================================ INTERFACE CAROUSEL */
.carow{ display:flex; align-items:center; gap:var(--s4); }
.carow__arrow{ flex:none; width:52px; height:52px; border-radius:50%; display:grid; place-items:center; background:var(--surface); border:1px solid var(--border-2); color:var(--text-mid); box-shadow:var(--shadow-card); transition:all .2s ease; }
.carow__arrow:hover{ color:var(--text-hi); border-color:var(--accent-line); background:var(--surface-2); transform:scale(1.06); }
.carow__arrow:active{ transform:scale(.96); }
.carow__arrow svg{ width:22px; height:22px; }
@media (max-width:760px){ .carow__arrow{ display:none; } }

.carow__stage{ flex:1; min-width:0; position:relative; }
.carow__glow{ position:absolute; left:50%; top:-6%; transform:translateX(-50%); width:62%; height:120px; background:var(--accent); filter:blur(95px); opacity:calc(.26 * var(--glow-strength)); border-radius:50%; z-index:-1; }
.carow__frame{ position:relative; border-radius:var(--r-2xl); border:1px solid var(--border-2); background:var(--bg-soft); box-shadow:var(--shadow-pop); overflow:hidden; }
/* hover caption — bottom darken + label */
.carow__hovercap{ position:absolute; left:0; right:0; bottom:0; z-index:7; padding:var(--s8) var(--s6) var(--s5); pointer-events:none;
  background:linear-gradient(0deg, color-mix(in oklab,var(--bg),transparent 8%) 12%, color-mix(in oklab,var(--bg),transparent 45%) 55%, transparent);
  opacity:0; transition:opacity .6s ease; }
.carow__frame:hover .carow__hovercap{ opacity:1; }
.carow__hovercap-kick, .carow__hovercap-t, .carow__hovercap-d{ opacity:0; transform:translateY(14px); transition:opacity .5s ease, transform .6s cubic-bezier(.2,.7,.2,1); }
.carow__frame:hover .carow__hovercap-kick{ opacity:1; transform:none; transition-delay:.06s; }
.carow__frame:hover .carow__hovercap-t{ opacity:1; transform:none; transition-delay:.14s; }
.carow__frame:hover .carow__hovercap-d{ opacity:1; transform:none; transition-delay:.22s; }
.carow__hovercap-kick{ font-family:var(--mono); font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent-bright); }
.carow__hovercap-t{ font-family:var(--display); font-weight:600; font-size:20px; color:var(--text-hi); letter-spacing:-0.015em; margin-top:7px; }
.carow__hovercap-d{ font-size:13.5px; color:var(--text-lo); margin-top:6px; max-width:52ch; line-height:1.5; }
@media (max-width:720px){ .carow__hovercap{ display:none; } }
/* fake browser/app top bar */
.carow__bar{ display:flex; align-items:center; gap:8px; padding:12px var(--s5); border-bottom:1px solid var(--border); background:var(--bg-soft); }
.carow__dots{ display:flex; gap:7px; }
.carow__dots i{ width:11px; height:11px; border-radius:50%; }
.carow__dots i:nth-child(1){ background:#ED6A5E; }
.carow__dots i:nth-child(2){ background:#F4BF4F; }
.carow__dots i:nth-child(3){ background:#61C554; }
.carow__url{ margin-left:10px; display:inline-flex; align-items:center; gap:7px; padding:5px 13px; border-radius:var(--r-pill); background:var(--surface); border:1px solid var(--border); font-family:var(--mono); font-size:11px; color:var(--text-lo); }
.carow__url svg{ width:12px; height:12px; }
.carow__live{ margin-left:auto; display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:10px; font-weight:700; letter-spacing:0.1em; color:var(--accent-bright); }
.carow__live .dot{ width:6px; height:6px; border-radius:50%; background:var(--accent); box-shadow:0 0 8px 1px var(--accent-glow); }
.carow__screens{ position:relative; height:520px; }
.carow__screen{ position:absolute; inset:0; opacity:0; transition:opacity .5s ease; pointer-events:none; overflow:hidden; }
.carow__screen.on{ opacity:1; pointer-events:auto; z-index:1; animation:carScreenIn .55s cubic-bezier(.2,.7,.2,1); }
.carow__screen > div{ height:100%; }
@keyframes carScreenIn{ from{ transform:translateY(8px) scale(.99); } to{ transform:none; } }

.carow__meta{ display:flex; align-items:flex-end; justify-content:space-between; gap:var(--s5); margin-top:var(--s6); }
.carow__info{ min-width:0; }
.carow__kick{ font-family:var(--mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent-bright); }
.carow__t{ font-family:var(--display); font-weight:600; font-size:clamp(20px,2.4vw,26px); letter-spacing:-0.015em; color:var(--text-hi); margin-top:8px; }
.carow__d{ font-size:14px; color:var(--text-lo); margin-top:8px; max-width:54ch; line-height:1.6; }
.carow__count{ font-family:var(--mono); font-size:12px; color:var(--text-dim); white-space:nowrap; }
.carow__count b{ color:var(--accent-bright); font-weight:700; }

.carow__rail{ display:flex; align-items:center; gap:10px; margin-top:var(--s6); flex-wrap:wrap; }
.carow__chip{ display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border-radius:var(--r-pill); font-size:12.5px; font-weight:600; color:var(--text-lo); background:var(--surface); border:1px solid var(--border); transition:all .2s ease; }
.carow__chip svg{ width:15px; height:15px; }
.carow__chip:hover{ color:var(--text-hi); border-color:var(--border-2); }
.carow__chip.on{ background:var(--accent-soft); color:var(--accent-bright); border-color:var(--accent-line); }
.carow__mobnav{ display:none; gap:10px; margin-top:var(--s5); }
@media (max-width:760px){ .carow__mobnav{ display:flex; } .carow__mobnav .carow__arrow{ display:grid; width:46px; height:46px; } }

/* ============================================================ PRICING */
.price__head{ display:flex; flex-direction:column; align-items:center; gap:var(--s5); }
.price__toggle{ display:inline-flex; gap:3px; padding:4px; border-radius:var(--r-pill); background:var(--surface); border:1px solid var(--border); }
.price__toggle button{ padding:9px 20px; border-radius:var(--r-pill); font-size:13px; font-weight:600; color:var(--text-lo); position:relative; }
.price__toggle button.on{ background:var(--surface-3); color:var(--text-hi); box-shadow:0 1px 0 rgba(255,255,255,0.06) inset; }
.price__toggle .save{ font-family:var(--mono); font-size:9.5px; padding:2px 7px; border-radius:var(--r-pill); background:var(--ok-soft); color:var(--ok); margin-left:7px; }

.price__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s5); margin-top:var(--s8); align-items:stretch; }
@media (max-width:920px){ .price__grid{ grid-template-columns:1fr; max-width:440px; margin-left:auto; margin-right:auto; } }
.tier{ display:flex; flex-direction:column; padding:var(--s7); border-radius:var(--r-xl); background:var(--surface); border:1px solid var(--border); box-shadow:var(--shadow-card); position:relative; }
.tier--hot{ border-color:var(--accent-line); background:radial-gradient(130% 80% at 50% 0%, var(--accent-soft), transparent 60%), var(--surface); box-shadow:var(--shadow-hover); transform:scale(1.02); }
@media (max-width:920px){ .tier--hot{ transform:none; } }
.tier__badge{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); padding:5px 14px; border-radius:var(--r-pill); font-size:11px; font-weight:700; color:#fff; background:linear-gradient(180deg, color-mix(in oklab,var(--accent),white 10%), var(--accent)); box-shadow:0 8px 20px -8px var(--accent-glow); white-space:nowrap; }
.tier__name{ font-family:var(--display); font-weight:600; font-size:20px; color:var(--text-hi); }
.tier__d{ font-size:13px; color:var(--text-lo); margin-top:8px; min-height:38px; }
.tier__price{ display:flex; align-items:baseline; gap:7px; margin:var(--s5) 0 var(--s2); }
.tier__amt{ font-family:var(--display); font-weight:700; font-size:42px; letter-spacing:-0.03em; color:var(--text-hi); line-height:1; font-variant-numeric:tabular-nums; }
.tier__cur{ font-size:18px; color:var(--text-mid); font-weight:600; }
.tier__per{ font-size:13px; color:var(--text-lo); }
.tier__btn{ width:100%; margin:var(--s5) 0; }
.tier__feats{ display:flex; flex-direction:column; gap:12px; margin-top:var(--s2); }
.tier__feat{ display:flex; align-items:flex-start; gap:10px; font-size:13.5px; color:var(--text-mid); }
.tier__feat svg{ width:17px; height:17px; flex:none; color:var(--accent-bright); margin-top:1px; }
.tier--hot .tier__feat svg{ color:var(--accent-hot); }

/* ============================================================ WHY US */
.why__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s4); }
@media (max-width:860px){ .why__grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .why__grid{ grid-template-columns:1fr; } }
.why{ padding:var(--s6); border-radius:var(--r-lg); background:var(--surface); border:1px solid var(--border); transition:transform .3s cubic-bezier(.2,.7,.2,1), border-color .3s; }
.why:hover{ transform:translateY(-3px); border-color:var(--border-2); }
.why__ico{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; color:var(--accent-bright); background:var(--accent-soft); border:1px solid var(--accent-line); margin-bottom:var(--s5); }
.why__ico svg{ width:20px; height:20px; }
.why__t{ font-family:var(--display); font-weight:600; font-size:16.5px; color:var(--text-hi); letter-spacing:-0.01em; }
.why__d{ font-size:13.5px; color:var(--text-lo); margin-top:10px; line-height:1.6; }

/* ============================================================ TESTIMONIALS (marquee) */
.marq{ position:relative; display:flex; flex-direction:column; gap:var(--s4); overflow:hidden; -webkit-mask:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); mask:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); }
.marq__track{ display:flex; gap:var(--s4); width:max-content; animation:marquee var(--dur,52s) linear infinite; }
.marq__track.rev{ animation-direction:reverse; }
.marq:hover .marq__track{ animation-play-state:paused; }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .marq__track{ animation:none; } }
.tcard{ width:380px; flex:none; padding:var(--s6); border-radius:var(--r-lg); background:var(--surface); border:1px solid var(--border); box-shadow:var(--shadow-card); }
.tcard__q{ font-size:14px; color:var(--text-mid); line-height:1.65; }
.tcard__who{ display:flex; align-items:center; gap:12px; margin-top:var(--s5); }
.tcard__av{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center; font-weight:700; font-size:14px; color:#fff; flex:none; }
.tcard__n{ font-size:13.5px; font-weight:700; color:var(--text-hi); }
.tcard__r{ font-size:11.5px; color:var(--text-lo); }
.tcard__stars{ display:flex; gap:2px; margin-bottom:14px; color:var(--accent); }
.tcard__stars svg{ width:14px; height:14px; }

/* ============================================================ STORIES */
.stories{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s4); }
@media (max-width:860px){ .stories{ grid-template-columns:1fr; max-width:460px; margin:0 auto; } }
.story{ display:flex; flex-direction:column; padding:var(--s6); border-radius:var(--r-xl); background:var(--surface); border:1px solid var(--border); box-shadow:var(--shadow-card); transition:transform .32s cubic-bezier(.2,.7,.2,1), border-color .32s, box-shadow .32s; position:relative; overflow:hidden; }
.story::before{ content:""; position:absolute; inset:0 0 auto 0; height:3px; background:linear-gradient(90deg, var(--accent), transparent); opacity:0; transition:opacity .3s; }
.story:hover{ transform:translateY(-4px); border-color:var(--accent-line); box-shadow:var(--shadow-hover); }
.story:hover::before{ opacity:1; }

.story__head{ display:flex; align-items:center; gap:11px; }
.story__av{ width:42px; height:42px; border-radius:12px; flex:none; display:grid; place-items:center; color:#fff; font-family:var(--display); font-weight:700; font-size:17px; box-shadow:0 6px 16px -8px rgba(0,0,0,.5); }
.story__id{ min-width:0; flex:1; }
.story__name{ font-family:var(--display); font-weight:600; font-size:15.5px; color:var(--text-hi); letter-spacing:-0.01em; }
.story__role{ font-size:12px; color:var(--text-lo); margin-top:2px; line-height:1.3; }
.story__days{ flex:none; font-size:10.5px; font-family:var(--mono); font-weight:600; padding:4px 10px; border-radius:var(--r-pill); background:var(--surface-3); color:var(--text-mid); white-space:nowrap; }

.story__hero{ display:flex; align-items:flex-end; justify-content:space-between; gap:10px; margin-top:var(--s6); }
.story__lbl{ font-size:9.5px; font-family:var(--mono); font-weight:600; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-dim); }
.story__after{ display:flex; align-items:baseline; gap:4px; margin-top:6px; white-space:nowrap; }
.story__amt{ font-family:var(--display); font-weight:700; font-size:clamp(28px,3vw,34px); letter-spacing:-0.03em; color:var(--text-hi); line-height:1; font-variant-numeric:tabular-nums; }
.story__after .u{ font-family:var(--display); font-weight:700; font-size:20px; color:var(--accent); }
.story__mult{ display:inline-flex; align-items:center; gap:4px; flex:none; font-family:var(--mono); font-size:13px; font-weight:700; padding:6px 11px; border-radius:var(--r-pill); background:var(--ok-soft); color:var(--ok); border:1px solid color-mix(in oklab,var(--ok),transparent 76%); }
.story__mult svg{ width:14px; height:14px; }
.story__mult.is-new{ background:var(--accent-soft); color:var(--accent-bright); border-color:var(--accent-line); }

.story__bars{ display:flex; align-items:flex-end; gap:6px; height:46px; margin-top:var(--s5); }
.story__bars span{ flex:1; height:var(--h); min-height:5px; border-radius:4px 4px 2px 2px; background:var(--surface-3); transition:height .7s cubic-bezier(.2,.7,.2,1); }
.story__bars span.hot{ background:linear-gradient(180deg, var(--accent-bright), var(--accent-deep)); box-shadow:0 0 18px -3px var(--accent-glow); }
.reveal:not(.in) .story__bars span{ height:6px; }

.story__before-row{ display:flex; align-items:center; gap:8px; margin-top:var(--s5); padding-top:var(--s4); border-top:1px solid var(--border); }
.story__before{ font-family:var(--mono); font-size:13px; color:var(--text-lo); text-decoration:line-through; text-decoration-color:var(--text-dim); margin-left:auto; font-variant-numeric:tabular-nums; }
.story__t{ font-size:13.5px; color:var(--text-lo); line-height:1.6; margin:var(--s5) 0 0; flex:1; }
.story__metric{ display:inline-flex; align-items:center; gap:8px; margin-top:var(--s5); padding:9px 13px; border-radius:var(--r-md); background:var(--accent-softer); border:1px solid var(--accent-line); font-size:12.5px; font-weight:600; color:var(--accent-bright); }
.story__metric svg{ width:15px; height:15px; flex:none; }

/* ============================================================ FAQ */
.faq{ max-width:780px; margin:0 auto; display:flex; flex-direction:column; gap:11px; }
.qa{ border-radius:var(--r-md); background:var(--surface); border:1px solid var(--border); overflow:hidden; transition:border-color .25s, background .25s, box-shadow .35s; }
.qa:hover{ border-color:var(--border-2); }
.qa.open{ border-color:var(--accent-line); background:radial-gradient(120% 140% at 0% 0%, var(--accent-softer), transparent 60%), var(--surface); box-shadow:var(--shadow-card); }
.qa__q{ display:flex; align-items:center; gap:var(--s4); width:100%; padding:var(--s5) var(--s6); text-align:left; font-size:15.5px; font-weight:600; color:var(--text-hi); }
.qa__q .ico{ margin-left:auto; width:30px; height:30px; border-radius:9px; display:grid; place-items:center; background:var(--surface-2); border:1px solid var(--border); color:var(--text-mid); flex:none; transition:transform .35s cubic-bezier(.2,.7,.2,1), background .25s, color .25s; }
.qa__q .ico svg{ width:16px; height:16px; }
.qa.open .qa__q .ico{ transform:rotate(180deg); background:var(--accent); border-color:var(--accent); color:#fff; box-shadow:0 6px 16px -8px var(--accent-glow); }
.qa__a{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .42s cubic-bezier(.2,.7,.2,1); }
.qa.open .qa__a{ grid-template-rows:1fr; }
.qa__a-wrap{ overflow:hidden; }
.qa__a-in{ padding:0 var(--s6) var(--s6); font-size:14px; color:var(--text-lo); line-height:1.65; opacity:0; transform:translateY(-8px); transition:opacity .35s ease .06s, transform .4s cubic-bezier(.2,.7,.2,1) .06s; }
.qa.open .qa__a-in{ opacity:1; transform:none; }

/* ============================================================ FINAL CTA */
.finalcta{ position:relative; overflow:hidden; border-radius:var(--r-2xl); padding:var(--s11) var(--s8); text-align:center; border:1px solid var(--accent-line);
  background:radial-gradient(120% 140% at 50% -10%, var(--accent-soft), transparent 60%), var(--surface); box-shadow:var(--shadow-pop); }
.finalcta::before{ content:""; position:absolute; left:50%; top:-40%; transform:translateX(-50%); width:70%; height:300px; background:var(--accent); filter:blur(120px); opacity:calc(.22 * var(--glow-strength)); border-radius:50%; z-index:0; }
.finalcta__grid{ position:absolute; inset:0; z-index:0; opacity:.4; -webkit-mask:radial-gradient(60% 60% at 50% 40%, #000, transparent 75%); mask:radial-gradient(60% 60% at 50% 40%, #000, transparent 75%);
  background-image:linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px); background-size:48px 48px; }
.finalcta > *{ position:relative; z-index:1; }
.finalcta__t{ font-family:var(--display); font-weight:700; font-size:clamp(30px,4.5vw,52px); line-height:1.05; letter-spacing:-0.025em; color:var(--text-hi); text-wrap:balance; max-width:16ch; margin:0 auto; }
.finalcta__s{ font-size:16px; color:var(--text-lo); margin:var(--s5) auto 0; max-width:46ch; }
.finalcta__cta{ display:flex; gap:var(--s3); justify-content:center; margin-top:var(--s7); flex-wrap:wrap; }
.finalcta__badge{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:0.16em; text-transform:uppercase; color:var(--accent-bright); background:var(--accent-soft); border:1px solid var(--accent-line); padding:6px 14px; border-radius:var(--r-pill); }
.finalcta__perks{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--s4); margin:var(--s8) auto 0; max-width:980px; text-align:left; }
@media (max-width:860px){ .finalcta__perks{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .finalcta__perks{ grid-template-columns:1fr; } }
.cperk{ padding:var(--s5); border-radius:var(--r-lg); background:color-mix(in oklab,var(--surface),transparent 18%); border:1px solid var(--border); backdrop-filter:blur(8px); transition:transform .28s cubic-bezier(.2,.7,.2,1), border-color .28s; }
.cperk:hover{ transform:translateY(-4px); border-color:var(--accent-line); }
.cperk__ico{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center; color:var(--accent-bright); background:var(--accent-soft); border:1px solid var(--accent-line); margin-bottom:var(--s4); }
.cperk__ico svg{ width:19px; height:19px; }
.cperk__t{ font-family:var(--display); font-weight:600; font-size:15.5px; color:var(--text-hi); letter-spacing:-0.01em; }
.cperk__d{ font-size:12.5px; color:var(--text-lo); margin-top:7px; line-height:1.5; }
.finalcta__notes{ display:flex; gap:var(--s6); justify-content:center; flex-wrap:wrap; margin-top:var(--s6); }
.finalcta__note{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:500; color:var(--text-mid); }
.finalcta__note svg{ width:15px; height:15px; color:var(--ok); }

/* ============================================================ FOOTER */
.footer{ border-top:1px solid var(--border); padding:var(--s10) 0 var(--s7); margin-top:var(--s10); }
.footer__top{ display:grid; grid-template-columns:1.2fr 2fr; gap:var(--s9); align-items:start; }
@media (max-width:760px){ .footer__top{ grid-template-columns:1fr; gap:var(--s8); } }
.footer__about{ max-width:340px; }
.footer__desc{ font-size:13.5px; color:var(--text-lo); line-height:1.65; margin-top:var(--s4); }
.footer__soc{ display:flex; gap:10px; margin-top:var(--s5); }
.footer__ico{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center; color:var(--accent-bright); background:var(--accent-soft); border:1px solid var(--accent-line); transition:transform .2s, background .2s, color .2s, box-shadow .2s; }
.footer__ico svg{ width:19px; height:19px; }
.footer__ico:hover{ color:#fff; background:linear-gradient(150deg,var(--accent-bright),var(--accent) 60%,var(--accent-deep)); border-color:transparent; transform:translateY(-2px); box-shadow:0 10px 22px -10px var(--accent-glow); }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s7); }
@media (max-width:560px){ .footer__cols{ grid-template-columns:1fr 1fr; gap:var(--s6); } }
.footer__col-t{ font-size:12px; font-weight:700; color:var(--text-hi); letter-spacing:0.02em; margin-bottom:var(--s4); }
.footer__lnk{ display:block; font-size:13.5px; color:var(--text-lo); padding:6px 0; transition:color .2s, transform .2s; }
.footer__lnk:hover{ color:var(--accent-bright); transform:translateX(2px); }
.footer__lnk--ico{ display:flex; align-items:center; gap:9px; }
.footer__lico{ width:20px; height:20px; flex:none; display:grid; place-items:center; }
.footer__lico svg{ width:18px; height:18px; }
.footer__lico--tg{ color:#2AABEE; }
.footer__lico--yt{ color:#FF3B3B; }
.footer__lnk--ico:hover{ transform:translateX(2px); color:var(--text-hi); }
.footer__bottom{ display:flex; align-items:center; justify-content:center; gap:var(--s4); margin-top:var(--s9); padding-top:var(--s6); border-top:1px solid var(--border); flex-wrap:wrap; }
.footer__copy{ font-size:12.5px; color:var(--text-dim); }

/* ============================================================ TWEAKS PANEL */
.tweaks{ position:fixed; right:20px; bottom:20px; z-index:400; width:300px; border-radius:var(--r-xl); background:color-mix(in oklab,var(--surface-2),transparent 6%); backdrop-filter:blur(26px) saturate(150%); border:1px solid var(--border-2); box-shadow:var(--shadow-pop); overflow:hidden; font-family:var(--font); }
.tweaks__head{ display:flex; align-items:center; gap:10px; padding:14px 16px; border-bottom:1px solid var(--border); }
.tweaks__title{ font-family:var(--display); font-weight:600; font-size:14px; color:var(--text-hi); }
.tweaks__close{ margin-left:auto; width:28px; height:28px; border-radius:8px; display:grid; place-items:center; color:var(--text-lo); background:var(--surface-2); border:1px solid var(--border); }
.tweaks__close:hover{ color:var(--text-hi); }
.tweaks__close svg{ width:15px; height:15px; }
.tweaks__body{ padding:16px; display:flex; flex-direction:column; gap:18px; max-height:70vh; overflow-y:auto; }
.tw-sec__lbl{ font-family:var(--mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-dim); margin-bottom:10px; }
.tw-seg{ display:flex; gap:4px; padding:4px; border-radius:var(--r-md); background:var(--surface); border:1px solid var(--border); }
.tw-seg button{ flex:1; padding:8px 0; border-radius:9px; font-size:12px; font-weight:600; color:var(--text-lo); }
.tw-seg button.on{ background:var(--surface-3); color:var(--text-hi); box-shadow:0 1px 0 rgba(255,255,255,0.06) inset; }
.tw-dots{ display:flex; gap:10px; align-items:center; }
.tw-dot{ width:26px; height:26px; border-radius:50%; background:var(--dot); border:2px solid transparent; cursor:pointer; transition:transform .15s, border-color .15s; }
.tw-dot:hover{ transform:scale(1.12); }
.tw-dot.on{ border-color:var(--text-hi); transform:scale(1.1); box-shadow:0 0 0 2px var(--dot); }
.tweaks__fab{ position:fixed; right:20px; bottom:20px; z-index:399; width:52px; height:52px; border-radius:50%; display:grid; place-items:center; color:#fff; background:linear-gradient(150deg,var(--accent-hot),var(--accent) 55%,var(--accent-deep)); box-shadow:0 14px 34px -10px var(--accent-glow), 0 1px 0 rgba(255,255,255,0.25) inset; border:1px solid rgba(255,255,255,0.18); }
.tweaks__fab:hover{ transform:translateY(-3px) scale(1.05); }
.tweaks__fab svg{ width:22px; height:22px; }
