/* ============================================================
   TuGymPR — site v2 · matches the real product brand
   cream · ink · teal (app accent #19B8B8) · gold logo · Archivo + Familjen Grotesk
   bold / vibrant / momentum sales page (not tidy sections)
   ============================================================ */
:root{
  --cream:#E9E6DF;
  --cream-2:#E3DFD5;
  --card:#FBFAF6;
  --white:#FFFFFF;
  --ink:#0B0F12;
  --ink-2:#2A2823;
  --muted:#6E6A5F;
  --faint:#9A9486;
  --line:rgba(11,15,18,0.12);
  --line-soft:rgba(11,15,18,0.07);
  /* brand accent = app teal #19B8B8. var names kept as --orange* to avoid churn. */
  --orange:#19B8B8;
  --orange-2:#0F9E9E;
  --orange-wash:#D9F1F1;
  --purple:#6B5BD2;
  --teal:#15B8A6;
  --gold:#E8A23D;
  --keep:#1E7A52;

  --fd:"Archivo","Arial Black",system-ui,sans-serif;
  --fb:"Familjen Grotesk",system-ui,sans-serif;
  --fm:"JetBrains Mono",ui-monospace,Menlo,monospace;

  --maxw:1280px;
  --ease:cubic-bezier(0.2,0.8,0.2,1);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:84px;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{font-family:var(--fb);background:var(--cream);color:var(--ink);font-size:18px;line-height:1.5;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:clip;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;}
input,select,textarea{font:inherit;color:inherit;}
svg{display:block;}
img{max-width:100%;display:block;}
::selection{background:var(--orange);color:#fff;}

.fd{font-family:var(--fd);font-weight:800;line-height:0.92;letter-spacing:-0.025em;}
h1,h2,h3{font-family:var(--fd);font-weight:800;letter-spacing:-0.025em;line-height:0.94;}
.mono{font-family:var(--fm);font-variant-numeric:tabular-nums;}
.o{color:var(--orange);}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}

/* labels */
.kick{font-family:var(--fm);font-size:12px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--orange);}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:58px;padding:0 30px;border-radius:999px;
  font-family:var(--fb);font-weight:700;font-size:17px;white-space:nowrap;border:2px solid transparent;
  transition:transform .2s var(--ease),background .2s,color .2s,box-shadow .2s,border-color .2s;}
.btn svg{width:19px;height:19px;}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 10px 30px -10px rgba(25,184,184,0.6);}
.btn-orange:hover{background:var(--orange-2);transform:translateY(-3px);box-shadow:0 18px 40px -10px rgba(25,184,184,0.7);}
.btn-ink{background:var(--ink);color:var(--cream);}
.btn-ink:hover{transform:translateY(-3px);box-shadow:0 16px 36px -14px rgba(11,15,18,0.6);}
.btn-line{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-line:hover{background:var(--ink);color:var(--cream);transform:translateY(-3px);}
.on-dark .btn-line{color:#fff;border-color:rgba(255,255,255,0.4);}
.on-dark .btn-line:hover{background:#fff;color:var(--ink);border-color:#fff;}
.btn-sm{height:48px;padding:0 22px;font-size:15px;}
.btn-lg{height:64px;padding:0 38px;font-size:19px;}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:76px;display:flex;align-items:center;
  background:rgba(233,230,223,0.8);backdrop-filter:blur(16px) saturate(150%);-webkit-backdrop-filter:blur(16px) saturate(150%);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(233,230,223,0.92);}
.nav .wrap{display:flex;align-items:center;gap:24px;width:100%;}
.brand{font-family:var(--fd);font-weight:900;font-size:25px;letter-spacing:-0.03em;display:inline-flex;align-items:center;gap:0;}
.brand-mark{height:34px;width:auto;margin-right:10px;}
.brand .pr{color:var(--gold);}
.brand i{width:30px;height:30px;border-radius:9px;background:var(--orange);display:grid;place-items:center;font-style:normal;color:#fff;box-shadow:0 6px 16px -6px rgba(25,184,184,0.7);margin-right:10px;}
.brand i svg{width:17px;height:17px;}
.nav-links{display:flex;gap:2px;margin-left:18px;}
.nav-links a{font-family:var(--fb);font-weight:600;font-size:15px;color:var(--ink-2);padding:9px 14px;border-radius:999px;transition:background .2s,color .2s;}
.nav-links a:hover{background:rgba(11,15,18,0.05);}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px;}
.lang{display:inline-flex;border:2px solid var(--line);border-radius:999px;padding:2px;font-family:var(--fm);font-size:12px;font-weight:600;}
.lang button{padding:6px 11px;border-radius:999px;color:var(--muted);transition:.2s;}
.lang button.active{background:var(--ink);color:var(--cream);}

.progress{position:fixed;top:0;left:0;height:3px;background:var(--orange);z-index:1001;width:0;transition:width .1s linear;}

/* ============ HERO ============ */
.hero{padding:120px 0 70px;position:relative;overflow:hidden;}
.hero-blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:0.5;pointer-events:none;z-index:0;}
.hero-blob.a{width:560px;height:560px;background:rgba(25,184,184,0.32);top:-120px;right:-120px;}
.hero-blob.b{width:420px;height:420px;background:rgba(107,91,210,0.22);bottom:-160px;left:-120px;}
.hero .wrap{position:relative;z-index:1;}
.hero-top{max-width:1000px;}
.hero-badge{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:var(--cream);font-family:var(--fm);font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;padding:9px 16px;border-radius:999px;margin-bottom:28px;}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--orange);animation:pulse 2.2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(25,184,184,.6);}70%{box-shadow:0 0 0 7px rgba(25,184,184,0);}100%{box-shadow:0 0 0 0 rgba(25,184,184,0);}}
.hero h1{font-family:var(--fd);font-weight:900;font-size:clamp(52px,9vw,124px);line-height:0.9;letter-spacing:-0.035em;}
.hero h1 em{font-style:normal;color:var(--orange);}
.hero-sub{font-size:clamp(20px,2vw,25px);color:var(--ink-2);max-width:680px;margin-top:30px;line-height:1.45;text-wrap:pretty;}
.hero-sub b{font-weight:700;}
.hero-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;align-items:center;}
.hero-cta .note{font-family:var(--fm);font-size:13px;color:var(--muted);}

/* video player frame */
.video-wrap{margin-top:64px;position:relative;border-radius:24px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 2px 4px rgba(11,15,18,0.05),0 50px 100px -40px rgba(11,15,18,0.5);background:var(--ink);aspect-ratio:16/9;}
.video-wrap video,.video-wrap .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.video-wrap .poster{filter:saturate(1.05);}
.video-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,15,18,0.05),rgba(11,15,18,0.35));display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;}
.play-btn{width:96px;height:96px;border-radius:50%;background:var(--orange);display:grid;place-items:center;box-shadow:0 16px 50px -8px rgba(25,184,184,0.8);transition:transform .25s var(--ease),background .2s;animation:pulse-play 2.6s infinite;}
.play-btn:hover{transform:scale(1.08);background:var(--orange-2);}
.play-btn svg{width:34px;height:34px;color:#fff;margin-left:5px;}
@keyframes pulse-play{0%{box-shadow:0 16px 50px -8px rgba(25,184,184,0.8),0 0 0 0 rgba(25,184,184,.5);}70%{box-shadow:0 16px 50px -8px rgba(25,184,184,0.8),0 0 0 22px rgba(25,184,184,0);}100%{box-shadow:0 16px 50px -8px rgba(25,184,184,0.8),0 0 0 0 rgba(25,184,184,0);}}
.video-cap{font-family:var(--fm);font-size:13px;letter-spacing:0.1em;text-transform:uppercase;color:#fff;text-shadow:0 1px 12px rgba(0,0,0,0.4);}
.video-tag{position:absolute;top:18px;left:18px;font-family:var(--fm);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:rgba(255,255,255,0.8);background:rgba(11,15,18,0.5);backdrop-filter:blur(6px);padding:7px 13px;border-radius:999px;}

/* ============ MARQUEE ============ */
.marquee{background:var(--ink);color:var(--cream);overflow:hidden;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:22px 0;}
.marquee-track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:scroll 32s linear infinite;}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;}}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-item{display:inline-flex;align-items:center;gap:16px;padding:0 34px;font-family:var(--fd);font-weight:800;font-size:26px;letter-spacing:-0.01em;}
.marquee-item .o{color:var(--orange);}
.marquee-item .star{color:var(--orange);font-size:18px;}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ============ SECTION scaffolds (loose, not boxed) ============ */
.section{padding:130px 0;position:relative;}
.section.sm{padding:90px 0;}

/* big statement */
.statement{max-width:1100px;}
.statement .kick{margin-bottom:24px;display:inline-block;}
.statement h2{font-family:var(--fd);font-weight:900;font-size:clamp(40px,6.5vw,96px);line-height:0.92;letter-spacing:-0.03em;text-wrap:balance;}
.statement h2 em{font-style:normal;color:var(--orange);}
.statement p{font-size:clamp(20px,2vw,26px);color:var(--ink-2);max-width:760px;margin-top:30px;line-height:1.45;text-wrap:pretty;}
.statement p b{font-weight:700;}

/* ============ SHOWCASE (text + bleeding screenshot) ============ */
.showcase{display:grid;grid-template-columns:0.9fr 1.1fr;gap:60px;align-items:center;}
.showcase.flip{grid-template-columns:1.1fr 0.9fr;}
.showcase.flip .sc-copy{order:2;}
.sc-copy .kick{margin-bottom:20px;display:inline-block;}
.sc-copy h2{font-family:var(--fd);font-weight:900;font-size:clamp(34px,4.6vw,62px);line-height:0.94;letter-spacing:-0.03em;}
.sc-copy h2 em{font-style:normal;color:var(--orange);}
.sc-copy p{font-size:19px;color:var(--ink-2);margin-top:22px;line-height:1.5;max-width:480px;text-wrap:pretty;}
.sc-copy p b{font-weight:700;color:var(--ink);}
.sc-list{margin-top:26px;display:flex;flex-direction:column;gap:14px;}
.sc-list .li{display:flex;gap:13px;align-items:flex-start;font-size:17px;color:var(--ink-2);}
.sc-list .li svg{width:22px;height:22px;color:var(--orange);flex-shrink:0;margin-top:1px;}
.sc-list .li b{color:var(--ink);font-weight:700;}
.sc-cta{margin-top:32px;}

/* shot frames */
.shot{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 2px 4px rgba(11,15,18,0.05),0 40px 90px -40px rgba(11,15,18,0.45);background:#fff;}
.shot.browser{padding-top:38px;}
.shot.browser::before{content:"";position:absolute;top:0;left:0;right:0;height:38px;background:var(--cream-2);border-bottom:1px solid var(--line);}
.shot.browser::after{content:"";position:absolute;top:15px;left:16px;width:9px;height:9px;border-radius:50%;background:#E0584B;box-shadow:16px 0 0 #E8A23D,32px 0 0 #5FB87A;}
.shot img{width:100%;display:block;}
.shot.bleed-r{margin-right:-120px;}
.shot.bleed-l{margin-left:-120px;}
.shot-tag{position:absolute;z-index:3;background:var(--ink);color:#fff;font-family:var(--fm);font-size:12px;font-weight:600;letter-spacing:0.04em;padding:10px 15px;border-radius:999px;box-shadow:0 14px 30px -10px rgba(11,15,18,0.5);}
.shot-tag.tl{top:-16px;left:-16px;background:var(--orange);}
.shot-tag.br{bottom:-16px;right:-16px;}

/* ============ CALCULATOR ============ */
.calc-section{background:var(--ink);color:var(--cream);}
.calc-head h2{color:#fff;font-family:var(--fd);font-weight:900;font-size:clamp(34px,5vw,68px);line-height:0.94;letter-spacing:-0.03em;}
.calc-head h2 em{font-style:normal;color:var(--orange);}
.calc-head p{color:rgba(233,230,223,0.7);font-size:20px;margin-top:20px;max-width:560px;line-height:1.45;}
.calc{display:grid;grid-template-columns:1fr 1fr;gap:50px;margin-top:56px;align-items:center;}
.cf{margin-bottom:32px;}
.cf:last-child{margin-bottom:0;}
.cf .top{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px;}
.cf .top label{font-family:var(--fm);font-size:13px;letter-spacing:0.04em;text-transform:uppercase;color:rgba(233,230,223,0.7);}
.cf .top .v{font-family:var(--fd);font-weight:800;font-size:30px;color:var(--orange);}
.cf .hint{font-family:var(--fm);font-size:11.5px;color:rgba(233,230,223,0.45);margin-top:10px;line-height:1.5;}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:rgba(233,230,223,0.18);outline:none;cursor:pointer;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:var(--orange);border:3px solid var(--ink);cursor:pointer;margin-top:-9px;box-shadow:0 0 0 1px var(--orange);transition:transform .15s;}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.14);}
input[type=range]::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--orange);border:3px solid var(--ink);cursor:pointer;}
.calc-result{background:var(--orange);border-radius:24px;padding:46px;color:#fff;position:relative;overflow:hidden;box-shadow:0 40px 90px -30px rgba(25,184,184,0.6);}
.calc-result .rl{font-family:var(--fm);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.85);}
.calc-result .big{font-family:var(--fd);font-weight:900;font-size:clamp(60px,9vw,108px);line-height:0.84;margin:12px 0 6px;letter-spacing:-0.03em;font-variant-numeric:tabular-nums;}
.calc-result .unit{font-family:var(--fm);font-size:13px;color:rgba(255,255,255,0.8);}
.calc-result .div{height:1px;background:rgba(255,255,255,0.25);margin:28px 0;}
.calc-result .line{font-size:19px;line-height:1.5;color:#fff;}
.calc-result .line b{font-weight:800;}
.calc-result .sec{font-family:var(--fm);font-size:14px;color:rgba(255,255,255,0.9);margin-top:14px;}
.calc-result .disc{font-family:var(--fm);font-size:11.5px;color:rgba(255,255,255,0.7);margin-top:26px;line-height:1.55;}
.calc-cta{margin-top:34px;}

/* ============ members app (dark, floating phones) ============ */
.appshow{background:var(--ink);color:var(--cream);position:relative;overflow:hidden;}
.appshow .glow{position:absolute;width:600px;height:600px;border-radius:50%;background:rgba(107,91,210,0.25);filter:blur(90px);top:-100px;left:-100px;pointer-events:none;}
.appshow .glow.b{background:rgba(21,184,166,0.18);right:-100px;left:auto;top:auto;bottom:-160px;}
.appshow .wrap{position:relative;z-index:1;}
.appshow h2{color:#fff;font-family:var(--fd);font-weight:900;font-size:clamp(36px,5.5vw,80px);line-height:0.92;letter-spacing:-0.03em;text-wrap:balance;}
.appshow h2 em{font-style:normal;color:var(--orange);}
.appshow .lead{font-size:21px;color:rgba(233,230,223,0.72);max-width:600px;margin-top:24px;line-height:1.45;}
.phones{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:64px;}
.phone{border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,0.1);background:#000;box-shadow:0 40px 80px -36px rgba(0,0,0,0.8);}
.phone img{width:100%;display:block;}
.phone-cap{margin-top:18px;}
.phone-cap .pt{font-family:var(--fd);font-weight:800;font-size:21px;color:#fff;}
.phone-cap .pd{font-size:15px;color:rgba(233,230,223,0.6);margin-top:5px;line-height:1.4;}
.appfeat{display:flex;flex-wrap:wrap;gap:12px;margin-top:56px;}
.appfeat .af{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,0.16);border-radius:999px;padding:11px 18px;font-size:15px;color:var(--cream);}
.appfeat .af svg{width:17px;height:17px;color:var(--orange);}

/* ============ how it works ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px;}
.step{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:36px 30px 38px;transition:transform .3s var(--ease),box-shadow .3s;}
.step:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(11,15,18,0.35);}
.step .sn{width:54px;height:54px;border-radius:50%;background:var(--orange);color:#fff;font-family:var(--fd);font-weight:800;font-size:24px;display:grid;place-items:center;margin-bottom:24px;}
.step h3{font-family:var(--fd);font-weight:800;font-size:24px;line-height:1.05;}
.step p{font-size:16.5px;color:var(--ink-2);margin-top:12px;line-height:1.5;text-wrap:pretty;}

/* ============ big orange band ============ */
.bigband{background:var(--orange);color:#fff;text-align:center;}
.bigband h2{color:#fff;font-family:var(--fd);font-weight:900;font-size:clamp(44px,8vw,118px);line-height:0.88;letter-spacing:-0.03em;text-wrap:balance;}
.bigband p{font-size:22px;color:rgba(255,255,255,0.9);max-width:620px;margin:28px auto 0;line-height:1.45;}
.bigband .btn-row{display:flex;justify-content:center;gap:14px;margin-top:40px;flex-wrap:wrap;}
.bigband .btn-ink{background:#fff;color:var(--orange);}
.bigband .btn-ink:hover{background:var(--ink);color:#fff;}
.bigband .btn-line{color:#fff;border-color:rgba(255,255,255,0.5);}
.bigband .btn-line:hover{background:#fff;color:var(--orange);border-color:#fff;}

/* ============ why (3 bold cards) ============ */
.why{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px;}
.wc{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:36px 32px;transition:transform .3s var(--ease),box-shadow .3s;}
.wc:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(11,15,18,0.35);}
.wc .wi{width:52px;height:52px;border-radius:14px;background:var(--orange-wash);display:grid;place-items:center;color:var(--orange);margin-bottom:22px;}
.wc .wi svg{width:25px;height:25px;}
.wc h3{font-family:var(--fd);font-weight:800;font-size:25px;line-height:1.04;}
.wc p{font-size:16.5px;color:var(--ink-2);margin-top:13px;line-height:1.5;text-wrap:pretty;}

/* ============ FAQ ============ */
.faq{max-width:880px;margin:56px auto 0;}
.fq{border:1px solid var(--line);border-radius:16px;background:var(--card);margin-bottom:14px;overflow:hidden;transition:border-color .25s;}
.fq.open{border-color:var(--orange);}
.fq-q{width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 26px;
  font-family:var(--fd);font-weight:800;font-size:clamp(19px,2.2vw,24px);line-height:1.12;}
.fq-q .pm{width:22px;height:22px;position:relative;flex-shrink:0;}
.fq-q .pm::before,.fq-q .pm::after{content:"";position:absolute;background:var(--orange);border-radius:2px;}
.fq-q .pm::before{top:10px;left:0;right:0;height:2.5px;}
.fq-q .pm::after{left:10px;top:0;bottom:0;width:2.5px;transition:transform .3s var(--ease);}
.fq.open .pm::after{transform:scaleY(0);}
.fq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease);}
.fq-a-in{padding:0 26px 26px;font-size:17px;color:var(--ink-2);line-height:1.55;text-wrap:pretty;}
.fq-a-in a{color:var(--orange);text-decoration:underline;text-underline-offset:3px;}

/* ============ final ============ */
.final{background:var(--ink);color:var(--cream);text-align:center;position:relative;overflow:hidden;}
.final .glow{position:absolute;width:700px;height:500px;border-radius:50%;background:rgba(25,184,184,0.3);filter:blur(90px);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;}
.final .wrap{position:relative;z-index:1;}
.final h2{color:#fff;font-family:var(--fd);font-weight:900;font-size:clamp(48px,8.5vw,128px);line-height:0.88;letter-spacing:-0.03em;}
.final h2 em{font-style:normal;color:var(--orange);}
.final p{font-size:21px;color:rgba(233,230,223,0.72);max-width:520px;margin:26px auto 0;line-height:1.45;}
.final .btn-row{display:flex;justify-content:center;gap:14px;margin-top:42px;flex-wrap:wrap;}
.final .ftrust{margin-top:30px;font-family:var(--fm);font-size:12px;letter-spacing:0.06em;text-transform:uppercase;color:rgba(233,230,223,0.4);}

/* ============ footer ============ */
.footer{background:var(--cream);padding:72px 0 40px;}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px;}
.foot-tag{font-size:16px;color:var(--ink-2);max-width:280px;margin-top:16px;line-height:1.5;}
.foot-col h4{font-family:var(--fm);font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;}
.foot-col a{display:block;font-size:16px;color:var(--ink-2);padding:7px 0;transition:color .2s;}
.foot-col a:hover{color:var(--orange);}
.foot-bottom{margin-top:56px;padding-top:28px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.foot-bottom span{font-family:var(--fm);font-size:12px;color:var(--muted);}

/* ============ modal ============ */
.scrim{position:fixed;inset:0;z-index:2000;background:rgba(11,15,18,0.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:grid;place-items:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .3s;}
.scrim.open{opacity:1;pointer-events:auto;}
.modal{background:var(--card);border-radius:24px;width:100%;max-width:560px;padding:42px;max-height:92vh;overflow-y:auto;
  transform:translateY(16px) scale(0.98);transition:transform .35s var(--ease);box-shadow:0 50px 110px -30px rgba(11,15,18,0.7);}
.scrim.open .modal{transform:none;}
.modal-h{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;}
.modal-h h3{font-family:var(--fd);font-weight:900;font-size:34px;line-height:0.95;}
.modal-h p{font-family:var(--fm);font-size:12px;color:var(--muted);margin-top:10px;text-transform:uppercase;letter-spacing:0.04em;}
.modal-x{width:42px;height:42px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;flex-shrink:0;transition:background .2s,color .2s;}
.modal-x:hover{background:var(--orange);color:#fff;}
.modal-x svg{width:18px;height:18px;}
.ff{margin-bottom:18px;}
.ff label{font-family:var(--fm);font-size:11.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px;}
.ff label .req{color:var(--orange);}
.fi{width:100%;height:50px;padding:0 16px;background:var(--white);border:2px solid var(--line);border-radius:12px;font-size:16px;color:var(--ink);transition:border-color .2s,box-shadow .2s;}
textarea.fi{height:auto;min-height:84px;padding:13px 16px;resize:vertical;line-height:1.5;}
.fi:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-wash);}
.fi::placeholder{color:var(--faint);}
select.fi{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236E6A5F' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:38px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.fnote{font-family:var(--fm);font-size:11.5px;color:var(--muted);text-align:center;margin-top:16px;line-height:1.6;}
.fnote a{color:var(--orange);text-decoration:underline;}
.fsuccess{display:none;text-align:center;padding:30px 8px;}
.fsuccess.show{display:block;}
.fsuccess .chk{width:64px;height:64px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;margin:0 auto 22px;}
.fsuccess .chk svg{width:30px;height:30px;}
.fsuccess h3{font-family:var(--fd);font-weight:900;font-size:34px;margin-bottom:12px;}
.fsuccess p{font-size:16px;color:var(--ink-2);}

/* ============ reveal ============ */
.rv{opacity:1;transform:none;}
html.js .rv{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
html.js .rv.in{opacity:1;transform:none;}
html.js .rv.d1{transition-delay:.09s;}html.js .rv.d2{transition-delay:.18s;}html.js .rv.d3{transition-delay:.27s;}html.js .rv.d4{transition-delay:.36s;}
@media (prefers-reduced-motion:reduce){html.js .rv{opacity:1!important;transform:none!important;}}

/* ============ responsive ============ */
@media (max-width:1000px){
  .showcase,.showcase.flip{grid-template-columns:1fr;gap:40px;}
  .showcase.flip .sc-copy{order:0;}
  .shot.bleed-r,.shot.bleed-l{margin-right:0;margin-left:0;}
  .calc{grid-template-columns:1fr;gap:36px;}
  .phones{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto;}
  .steps{grid-template-columns:1fr;}
  .why{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .nav-links{display:none;}
}
@media (max-width:640px){
  .section{padding:90px 0;}
  .wrap{padding:0 20px;}
  .hero{padding:104px 0 50px;}
  .frow{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;}
  .marquee-item{font-size:21px;}
}

/* ============ LANG toggle ============ */
.lang{display:inline-flex;border:2px solid var(--line);border-radius:999px;padding:2px;font-family:var(--fm);font-size:12px;font-weight:600;}
.lang button{padding:6px 11px;border-radius:999px;color:var(--muted);transition:.2s;letter-spacing:0.04em;}
.lang button.active{background:var(--ink);color:var(--cream);}

/* ============ LEGAL / PROSE pages ============ */
.legal-spacer{height:76px;}
.legal{max-width:820px;margin:0 auto;padding:64px 32px 120px;}
.back-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--fm);font-size:12px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);margin-bottom:30px;transition:color .2s;}
.back-link:hover{color:var(--orange);}
.back-link svg{width:15px;height:15px;}
.legal-head{margin-bottom:48px;padding-bottom:34px;border-bottom:1px solid var(--line);}
.legal-head .kick{margin-bottom:18px;display:inline-block;}
.legal-head h1{font-family:var(--fd);font-weight:900;font-size:clamp(40px,6vw,68px);line-height:0.92;letter-spacing:-0.03em;}
.legal-head .updated{margin-top:18px;font-family:var(--fm);font-size:13px;color:var(--muted);}
.legal-toc{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:26px 30px;margin-bottom:52px;}
.legal-toc h2{font-family:var(--fm);font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:600;}
.legal-toc ol{list-style:none;counter-reset:toc;columns:2;column-gap:36px;}
.legal-toc li{counter-increment:toc;padding:6px 0;font-size:14.5px;break-inside:avoid;}
.legal-toc a{color:var(--ink-2);transition:color .2s;}
.legal-toc a::before{content:counter(toc) ". ";color:var(--orange);font-family:var(--fm);font-size:12px;}
.legal-toc a:hover{color:var(--orange);}
.legal section{margin-bottom:44px;scroll-margin-top:96px;}
.legal section h2{font-family:var(--fd);font-weight:800;font-size:27px;letter-spacing:-0.02em;margin-bottom:18px;line-height:1.08;display:flex;gap:14px;align-items:baseline;}
.legal section h2 .sn{font-family:var(--fm);font-size:15px;color:var(--orange);flex-shrink:0;font-weight:600;}
.legal section h3{font-family:var(--fd);font-weight:700;font-size:18px;margin:26px 0 8px;color:var(--ink);}
.legal p,.legal li{font-size:16px;color:var(--ink-2);line-height:1.7;margin-bottom:14px;text-wrap:pretty;}
.legal ul{padding-left:22px;margin-bottom:14px;}
.legal ul li{margin-bottom:7px;}
.legal strong{color:var(--ink);font-weight:700;}
.legal a.inline{color:var(--orange);text-decoration:underline;text-underline-offset:3px;}
.legal code,.legal .ph{font-family:var(--fm);font-size:13.5px;background:var(--orange-wash);color:var(--orange-2);border:1px solid rgba(25,184,184,0.3);padding:2px 8px;border-radius:6px;}
.legal .placeholder{display:block;margin:12px 0;background:var(--orange-wash);border-left:3px solid var(--orange);border-radius:0 8px 8px 0;padding:12px 16px;font-family:var(--fm);font-size:13.5px;color:var(--orange-2);line-height:1.5;}
.legal table{width:100%;border-collapse:collapse;margin:16px 0 22px;font-size:14px;}
.legal table th,.legal table td{text-align:left;padding:11px 14px;border:1px solid var(--line);vertical-align:top;}
.legal table th{background:var(--card);color:var(--ink);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:0.05em;font-family:var(--fm);}
.legal table td{color:var(--ink-2);}
.legal table tr:nth-child(even) td{background:rgba(11,15,18,0.02);}
