/* ========================================================================
   ProBroker AI — Landing Page
   Premium dark SaaS · cinematic glass · ProBroker blue · real-estate luxury
   ======================================================================== */
:root{
  --ink:#05070C;
  --bg:#0A0E16;
  --bg-2:#0C111B;
  --bg-3:#0E1521;
  --surface-1:rgba(255,255,255,0.040);
  --surface-2:rgba(255,255,255,0.070);
  --glass:rgba(14,20,32,0.55);
  --glass-strong:rgba(12,17,27,0.78);
  --border:rgba(255,255,255,0.085);
  --border-2:rgba(255,255,255,0.15);
  --hair:rgba(255,255,255,0.06);
  --text:#F4F7FB;
  --text-2:rgba(244,247,251,0.62);
  --text-3:rgba(244,247,251,0.40);
  --text-4:rgba(244,247,251,0.26);
  --accent:#2E9BFF;
  --accent-2:#5CC0FF;
  --accent-deep:#1E6FE6;
  --accent-soft:rgba(46,155,255,0.12);
  --accent-line:rgba(46,155,255,0.40);
  --cta:linear-gradient(135deg,#5CC0FF 0%,#2E84F5 52%,#2C66EF 100%);
  --glow:0 10px 40px rgba(46,155,255,0.34);
  --glow-lg:0 24px 80px rgba(46,155,255,0.30);
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue",Helvetica,system-ui,Arial,sans-serif;
  --mono:"SF Mono",ui-monospace,"JetBrains Mono",Menlo,monospace;
  --maxw:1240px;
  --r-lg:26px; --r-md:18px; --r-sm:13px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--ink);color:var(--text);font-family:var(--font);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;line-height:1.5;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;color:inherit;border:none;background:none;cursor:pointer;}
h1,h2,h3,h4,p{margin:0;}
::selection{background:rgba(46,155,255,0.34);color:#fff;}

/* ---------- shared layout ---------- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.section{position:relative;padding:130px 0;}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--accent-2);
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--accent-line);}
.eyebrow.center::after{content:"";width:22px;height:1px;background:var(--accent-line);}
.eyebrow.center{justify-content:center;}
.h-sec{font-size:clamp(34px,4.4vw,58px);font-weight:700;letter-spacing:-0.03em;line-height:1.04;text-wrap:balance;}
.lede{font-size:clamp(16px,1.6vw,19px);color:var(--text-2);line-height:1.55;text-wrap:pretty;}
.sec-head{max-width:680px;}
.sec-head.center{margin:0 auto;text-align:center;}
.sec-head .eyebrow{margin-bottom:20px;}
.sec-head .lede{margin-top:20px;}

/* faint grid + glow helpers */
.glow{position:absolute;border-radius:50%;pointer-events:none;filter:blur(40px);z-index:0;}
.grid-tex{
  position:absolute;inset:0;pointer-events:none;z-index:0;opacity:0.5;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.022) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 80% at 50% 0%,#000,transparent 72%);
          mask-image:radial-gradient(120% 80% at 50% 0%,#000,transparent 72%);
}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1);}
.reveal.in{opacity:1;transform:none;}
.reveal[data-d="1"]{transition-delay:.08s;}
.reveal[data-d="2"]{transition-delay:.16s;}
.reveal[data-d="3"]{transition-delay:.24s;}
.reveal[data-d="4"]{transition-delay:.32s;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;height:54px;
  padding:0 26px;border-radius:15px;font-size:16px;font-weight:600;letter-spacing:-0.01em;
  transition:transform .18s ease,filter .2s ease,box-shadow .3s ease,background .2s;white-space:nowrap;}
.btn svg{width:18px;height:18px;}
.btn-primary{background:var(--cta);color:#fff;box-shadow:var(--glow);position:relative;overflow:hidden;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 50px rgba(46,155,255,0.5);}
.btn-primary .sheen{position:absolute;top:0;left:-60%;width:50%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.42),transparent);transform:skewX(-18deg);}
.btn-primary:hover .sheen{animation:sheen .9s ease;}
@keyframes sheen{from{left:-60%;}to{left:140%;}}
.btn-ghost{background:var(--surface-1);border:1px solid var(--border-2);color:var(--text);backdrop-filter:blur(10px);}
.btn-ghost:hover{background:var(--surface-2);transform:translateY(-2px);border-color:rgba(255,255,255,0.28);}
.btn-sm{height:44px;padding:0 18px;font-size:14.5px;border-radius:12px;}

/* ====================================================================
   NAV
   ==================================================================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,backdrop-filter .3s,border-color .3s;
  border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(8,11,18,0.72);backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);border-bottom-color:var(--hair);}
.nav-in{display:flex;align-items:center;gap:34px;height:74px;max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.brand{display:flex;align-items:center;gap:10px;}
.brand-logo-img{height:36px;width:auto;display:block;object-fit:contain;}
.brand-svg-fallback{display:none;align-items:center;gap:10px;}
.brand .mark{width:34px;height:34px;border-radius:10px;flex:none;position:relative;
  background:linear-gradient(150deg,#2E9BFF,#1456C9);
  box-shadow:0 6px 18px rgba(46,155,255,0.42),inset 0 1px 0 rgba(255,255,255,0.45);}
.brand .mark svg{position:absolute;inset:0;margin:auto;}
.brand .name{font-size:19px;font-weight:700;letter-spacing:-0.02em;}
.brand .name b{color:var(--accent-2);font-weight:700;}
.nav-links{display:flex;align-items:center;gap:30px;margin-left:8px;}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--text-2);transition:color .2s;}
.nav-links a:hover{color:var(--text);}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px;}
.nav-signin{font-size:14.5px;font-weight:550;color:var(--text-2);transition:color .2s;}
.nav-signin:hover{color:var(--text);}
.nav-burger{display:none;width:44px;height:44px;border-radius:12px;background:var(--surface-1);
  border:1px solid var(--border);align-items:center;justify-content:center;}
.nav-burger span{display:block;width:18px;height:2px;background:var(--text);border-radius:2px;position:relative;}
.nav-burger span::before,.nav-burger span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--text);border-radius:2px;}
.nav-burger span::before{top:-6px;}.nav-burger span::after{top:6px;}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:99;background:rgba(6,9,15,0.96);backdrop-filter:blur(16px);
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:0 32px;
  opacity:0;pointer-events:none;transition:opacity .35s;}
.mobile-menu.open{opacity:1;pointer-events:auto;}
.mobile-menu a{font-size:28px;font-weight:600;letter-spacing:-0.02em;padding:12px 0;color:var(--text);
  border-bottom:1px solid var(--hair);}
.mobile-menu .btn{margin-top:24px;height:58px;}

/* ====================================================================
   HERO
   ==================================================================== */
.hero{position:relative;padding:150px 0 90px;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.hero-bg .g1{top:-180px;left:-120px;width:620px;height:520px;background:radial-gradient(closest-side,rgba(46,155,255,0.20),transparent 70%);}
.hero-bg .g2{top:120px;right:-160px;width:560px;height:560px;background:radial-gradient(closest-side,rgba(30,111,230,0.15),transparent 70%);}
.hero-grid{display:grid;grid-template-columns:1.02fr 1.18fr;gap:56px;align-items:center;position:relative;z-index:2;}

.hero-badge{display:inline-flex;align-items:center;gap:9px;height:36px;padding:0 15px 0 11px;border-radius:100px;
  background:linear-gradient(180deg,rgba(10,14,22,.62),rgba(10,14,22,.42));
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--accent-line);box-shadow:0 0 0 1px rgba(46,155,255,.05),0 4px 18px rgba(0,0,0,.32),0 0 22px rgba(46,155,255,.16);
  font-size:13px;font-weight:500;color:var(--text-2);margin-bottom:26px;white-space:nowrap;}
.hero-badge .hb-ic{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex:none;color:var(--accent-2);
  filter:drop-shadow(0 0 5px rgba(46,155,255,.55));}
.hero-badge .hb-ic svg{width:18px;height:18px;}
.hero-badge b{color:#fff;font-weight:600;}
@media (max-width:560px){.hero-badge{white-space:normal;height:auto;padding:8px 14px 8px 11px;line-height:1.35;}}
.hero h1{font-size:clamp(40px,5.4vw,72px);font-weight:700;letter-spacing:-0.035em;line-height:1.0;text-wrap:balance;}
.hero h1 .grad{background:linear-gradient(120deg,#fff 10%,#9fd0ff 60%,#2E9BFF);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero .sub{font-size:clamp(16px,1.7vw,20px);color:var(--text-2);line-height:1.55;margin-top:24px;max-width:520px;text-wrap:pretty;}
.hero-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;}
.hero-trust{display:flex;align-items:center;gap:10px;margin-top:30px;font-size:13.5px;color:var(--text-3);}
.hero-trust svg{width:17px;height:17px;color:var(--accent-2);flex:none;}
.hero-trust b{color:var(--text-2);font-weight:600;}

/* metric strip under hero */
.metrics{display:flex;gap:0;margin-top:64px;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);position:relative;z-index:2;}
.metric{flex:1;padding:26px 8px;text-align:center;border-right:1px solid var(--hair);}
.metric:last-child{border-right:none;}
.metric .n{font-size:clamp(26px,3vw,38px);font-weight:700;letter-spacing:-0.03em;}
.metric .n b{color:var(--accent-2);font-weight:700;}
.metric .l{font-size:12.5px;color:var(--text-3);margin-top:6px;letter-spacing:0.01em;}

/* hero capability strip (premium glass cards) */
.metrics.capstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;border:none;}
.metric.cap{flex:initial;display:flex;align-items:center;gap:13px;text-align:left;padding:16px 16px;
  border:1px solid var(--border-2);border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.012));
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 10px 30px rgba(0,0,0,.32);transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .3s,box-shadow .4s;}
.metric.cap:hover{transform:translateY(-4px);border-color:var(--accent-line);
  box-shadow:0 18px 44px rgba(0,0,0,.42),0 0 0 1px var(--accent-line),0 0 36px rgba(46,155,255,.14);}
.cap-ic{flex:none;width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);border:1px solid var(--accent-line);}
.cap-ic svg{width:21px;height:21px;color:var(--accent-2);}
.cap-tx{min-width:0;}
.cap-t{font-size:14.5px;font-weight:600;letter-spacing:-0.01em;color:var(--text-1);line-height:1.2;}
.cap-s{font-size:12.5px;color:var(--text-3);margin-top:3px;line-height:1.3;text-wrap:pretty;}

/* ====================================================================
   HERO — cinematic villa day/night
   ==================================================================== */
.hero-stage{position:relative;}
.villa{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border-2);
  box-shadow:0 40px 110px rgba(0,0,0,0.62),var(--glow-lg);background:#070a10;--night:0;}
.villa-media{position:relative;aspect-ratio:16/11;overflow:hidden;}
.villa-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;}
.villa-night{position:absolute;inset:0;opacity:var(--night);will-change:opacity;}
.villa-night::before{content:"";position:absolute;inset:0;
  background:radial-gradient(130% 110% at 50% -8%,rgba(14,26,64,0.62),rgba(6,9,20,0.42));mix-blend-mode:multiply;}
.night-sky{position:absolute;inset:0;mix-blend-mode:multiply;
  background:linear-gradient(180deg,rgba(8,16,44,0.82) 0%,rgba(10,18,42,0.5) 38%,rgba(6,9,20,0.18) 62%,transparent 80%);}
.night-glow{position:absolute;border-radius:50%;mix-blend-mode:screen;filter:blur(20px);pointer-events:none;}
.glow-a{top:1%;left:6%;width:48%;height:18%;background:radial-gradient(closest-side,rgba(255,196,118,0.48),transparent);}
.glow-b{top:20%;left:57%;width:24%;height:28%;background:radial-gradient(closest-side,rgba(255,206,142,0.62),transparent);}
.glow-c{top:48%;right:1%;width:20%;height:32%;background:radial-gradient(closest-side,rgba(255,190,108,0.42),transparent);}
.night-stars{position:absolute;top:0;left:0;right:0;height:44%;opacity:.55;pointer-events:none;
  background-image:radial-gradient(1.2px 1.2px at 18% 28%,rgba(255,255,255,.8),transparent),
    radial-gradient(1px 1px at 58% 16%,rgba(255,255,255,.55),transparent),
    radial-gradient(1.2px 1.2px at 82% 38%,rgba(255,255,255,.6),transparent),
    radial-gradient(1px 1px at 38% 46%,rgba(255,255,255,.4),transparent),
    radial-gradient(1px 1px at 72% 56%,rgba(255,255,255,.35),transparent);}
.villa-vignette{position:absolute;inset:0;pointer-events:none;z-index:3;
  box-shadow:inset 0 0 130px rgba(0,0,0,0.55);background:linear-gradient(180deg,transparent 52%,rgba(5,7,12,0.5));}
.villa-meta{position:absolute;top:14px;left:14px;right:14px;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.villa-tag{display:inline-flex;align-items:center;gap:7px;font-size:10.5px;font-weight:700;letter-spacing:0.14em;
  text-transform:uppercase;padding:6px 11px;border-radius:8px;background:rgba(8,11,18,0.55);backdrop-filter:blur(8px);
  border:1px solid var(--border);color:var(--text-2);}
.villa-tag::before{content:"";width:6px;height:6px;border-radius:50%;background:#46d27e;box-shadow:0 0 8px #46d27e;}
.daynight{display:inline-flex;align-items:center;gap:9px;padding:7px 13px;border-radius:100px;
  background:rgba(8,11,18,0.55);backdrop-filter:blur(8px);border:1px solid var(--border);}
.dn-ico{display:flex;}
.dn-ico svg{width:15px;height:15px;}
.dn-ico.sun{color:rgba(255,210,122,calc(1 - var(--night)*0.72));}
.dn-ico.moon{color:rgba(150,178,255,calc(0.32 + var(--night)*0.68));}
.dn-track{position:relative;width:38px;height:4px;border-radius:3px;background:rgba(255,255,255,0.16);overflow:hidden;}
.dn-fill{position:absolute;left:0;top:0;bottom:0;width:calc(var(--night)*100%);
  background:linear-gradient(90deg,#ffd27a,#9ab8ff);transition:width .12s linear;}
.dn-label{font-size:11px;font-weight:600;letter-spacing:0.02em;color:var(--text-2);min-width:50px;text-align:center;}
.villa-chips{position:absolute;left:16px;right:16px;bottom:16px;z-index:5;display:flex;gap:10px;}
.mode-chip{flex:1;display:flex;align-items:center;gap:9px;padding:11px 13px;border-radius:14px;
  background:rgba(10,14,22,0.6);backdrop-filter:blur(16px);border:1px solid var(--border);transition:.25s;}
.mode-chip .ic{width:30px;height:30px;border-radius:9px;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);border:1px solid var(--accent-line);}
.mode-chip .ic svg{width:16px;height:16px;color:var(--accent-2);}
.mode-chip .t{font-size:13px;font-weight:600;line-height:1.15;letter-spacing:-0.01em;}
.mode-chip .t small{display:block;font-size:10.5px;font-weight:500;color:var(--text-3);letter-spacing:0;}
.mode-chip:hover{border-color:var(--accent-line);background:rgba(14,28,48,0.7);box-shadow:0 8px 24px rgba(46,155,255,0.16);}
.villa-hint{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;font-size:12.5px;color:var(--text-3);}
.villa-hint svg{width:15px;height:15px;color:var(--accent-2);animation:hintbob 2.1s ease-in-out infinite;}
@keyframes hintbob{0%,100%{transform:translateY(-2px);}50%{transform:translateY(3px);}}

/* ====================================================================
   PROOF SECTION
   ==================================================================== */
.proof-wrap{margin-top:56px;}
.proof-wrap:last-of-type{margin-bottom:0;}
.proof-item-meta{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.proof-item-title{font-size:20px;font-weight:700;letter-spacing:-0.02em;color:var(--text);}
.proof-item-sub{margin-top:14px;font-size:14px;color:var(--text-3);line-height:1.55;}

/* PROOF / BIG BEFORE-AFTER */
.proof-stage{margin-top:0;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border-2);
  box-shadow:0 40px 110px rgba(0,0,0,0.55);position:relative;z-index:2;}
.proof-stage .ba{position:relative;width:100%;aspect-ratio:21/9;overflow:hidden;cursor:ew-resize;user-select:none;touch-action:none;}

.proof-pills{display:flex;gap:12px;flex-wrap:wrap;margin-top:40px;position:relative;z-index:2;}
.proof-pill{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:14px;background:var(--surface-1);
  border:1px solid var(--border);font-size:14px;color:var(--text-2);}
.proof-pill svg{width:17px;height:17px;color:var(--accent-2);}
.proof-pill b{color:var(--text);font-weight:600;}

/* BA slider */
.ba{position:relative;width:100%;height:100%;overflow:hidden;cursor:ew-resize;user-select:none;touch-action:none;}
.ba .layer{position:absolute;inset:0;}
.ba .after img,.ba .before img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.ba .before{overflow:hidden;}
.ba .before img{filter:saturate(0.45) brightness(0.7) contrast(0.92);}
.ba .before .tag,.ba .after-tag{position:absolute;top:14px;font-size:10.5px;font-weight:700;letter-spacing:0.14em;
  text-transform:uppercase;padding:6px 11px;border-radius:8px;backdrop-filter:blur(8px);z-index:3;}
.ba .before .tag{left:14px;background:rgba(8,11,18,0.62);color:var(--text-2);border:1px solid var(--border);}
.ba .after-tag{right:14px;background:var(--accent-soft);color:var(--accent-2);border:1px solid var(--accent-line);}
.ba .handle{position:absolute;top:0;bottom:0;width:2px;background:rgba(255,255,255,0.9);
  box-shadow:0 0 18px rgba(46,155,255,0.7);z-index:4;}
.ba .knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;
  background:rgba(10,14,22,0.6);backdrop-filter:blur(10px);border:1.5px solid rgba(255,255,255,0.85);
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 22px rgba(0,0,0,0.5);}
.ba .knob svg{width:22px;height:22px;color:#fff;}

/* ====================================================================
   GALLERY — premium horizontal rail
   ==================================================================== */
.gallery-sec{overflow:hidden;}
.gallery-head{max-width:none;display:flex;align-items:flex-end;justify-content:space-between;gap:30px;}
.gallery-head > div{max-width:660px;}
.rail-nav{display:flex;gap:10px;flex:none;padding-bottom:4px;}
.rail-btn{width:48px;height:48px;border-radius:14px;background:var(--surface-1);border:1px solid var(--border-2);
  display:flex;align-items:center;justify-content:center;color:var(--text);transition:.2s;}
.rail-btn:hover{background:var(--surface-2);border-color:var(--accent-line);color:var(--accent-2);transform:translateY(-2px);}
.rail-btn svg{width:20px;height:20px;}
.rail{margin-top:46px;overflow-x:auto;overflow-y:hidden;-ms-overflow-style:none;scrollbar-width:none;cursor:grab;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 3.5%,#000 96.5%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 3.5%,#000 96.5%,transparent);}
.rail::-webkit-scrollbar{display:none;}
.rail.dragging{cursor:grabbing;}
.rail.dragging .rcard{transition:none;}
.rail-track{display:flex;gap:22px;padding:8px max(32px,calc((100vw - var(--maxw))/2 + 32px)) 14px;width:max-content;}
.rcard{position:relative;flex:none;width:clamp(290px,29vw,430px);aspect-ratio:4/5;border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--border);transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s,border-color .3s;}
.rcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.06);
  transition:transform .9s cubic-bezier(.16,1,.3,1);pointer-events:none;}
.rcard:hover{transform:translateY(-10px);border-color:var(--accent-line);
  box-shadow:0 34px 74px rgba(0,0,0,0.55),0 0 56px rgba(46,155,255,0.16);}
.rcard:hover img{transform:scale(1.12);}
.rcard .ov{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,11,18,0.04) 32%,rgba(6,9,15,0.92));}
.rcard .cap{position:absolute;left:22px;right:22px;bottom:22px;z-index:2;}
.rcard .cap .k{font-family:var(--mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent-2);}
.rcard .cap h3{font-size:21px;font-weight:600;letter-spacing:-0.02em;margin-top:6px;text-wrap:balance;}
.rcard .badge{position:absolute;top:16px;left:16px;z-index:2;font-size:10px;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;padding:6px 11px;border-radius:8px;background:rgba(10,14,22,0.6);backdrop-filter:blur(8px);
  border:1px solid var(--border);color:var(--text-2);}
.rcard .badge.concept{color:var(--accent-2);border-color:var(--accent-line);background:var(--accent-soft);}
.rail-progress{margin-top:30px;height:3px;border-radius:3px;background:var(--hair);position:relative;overflow:hidden;}
.rail-bar{position:absolute;left:0;top:0;bottom:0;width:32%;border-radius:3px;background:var(--cta);transition:left .1s linear,width .1s linear;}

/* ====================================================================
   TOOLS — command center
   ==================================================================== */
.tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:60px;position:relative;z-index:2;}
.tool{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);
  background:linear-gradient(180deg,var(--surface-1),rgba(255,255,255,0.012));transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .3s,box-shadow .4s;}
.tool:hover{transform:translateY(-8px);border-color:var(--accent-line);box-shadow:0 30px 70px rgba(0,0,0,0.5),0 0 0 1px var(--accent-line),0 0 60px rgba(46,155,255,0.16);}
.tool-img{position:relative;height:212px;overflow:hidden;}
.tool-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.16,1,.3,1);}
.tool:hover .tool-img img{transform:scale(1.06);}
.tool-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,11,18,0) 40%,rgba(10,14,22,0.92));}
.tool-num{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;
  color:var(--accent-2);background:rgba(8,11,18,0.6);border:1px solid var(--accent-line);padding:4px 9px;border-radius:7px;backdrop-filter:blur(8px);}
.tool-mode{position:absolute;left:22px;bottom:16px;z-index:2;display:flex;align-items:center;gap:11px;}
.tool-mode .ic{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);border:1px solid var(--accent-line);backdrop-filter:blur(8px);}
.tool-mode .ic svg{width:20px;height:20px;color:var(--accent-2);}
.tool-mode h3{font-size:21px;font-weight:700;letter-spacing:-0.02em;}
.tool-body{padding:22px 24px 26px;}
.tool-body .purpose{font-size:14.5px;color:var(--text-2);line-height:1.5;text-wrap:pretty;}
.tool-caps{list-style:none;padding:0;margin:20px 0 0;display:flex;flex-direction:column;gap:11px;}
.tool-caps li{display:flex;align-items:flex-start;gap:11px;font-size:14px;color:var(--text-2);}
.tool-caps li svg{width:17px;height:17px;color:var(--accent-2);flex:none;margin-top:1px;}
.tool-foot{display:flex;align-items:center;gap:7px;margin-top:22px;font-size:14px;font-weight:600;color:var(--accent-2);transition:gap .25s;}
.tool:hover .tool-foot{gap:12px;}
.tool-foot svg{width:16px;height:16px;}

/* ====================================================================
   WORKFLOW — animated progress journey
   ==================================================================== */
.wf{position:relative;margin-top:68px;z-index:2;}

/* connector line + progress fill ---------------------------------- */
/* horizontal: spans between the centre of the 1st and 4th nodes (1/8 … 7/8) */
.wf-track{position:absolute;top:42px;left:12.5%;right:12.5%;height:2px;border-radius:2px;
  background:var(--border-2);overflow:hidden;z-index:0;}
.wf-fill{position:absolute;inset:0;transform-origin:left center;transform:scaleX(0);
  background:linear-gradient(90deg,var(--accent-2),#7cc4ff);
  box-shadow:0 0 14px rgba(46,155,255,.6);}
.wf.is-playing .wf-fill{transform:scaleX(1);
  transition:transform .9s cubic-bezier(.45,.05,.25,1) .2s;} /* 200ms → 1100ms */

/* grid of steps --------------------------------------------------- */
.wf-grid{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:26px;
  position:relative;z-index:1;margin:0;padding:0;}
.wf-step{text-align:center;display:flex;flex-direction:column;align-items:center;}

/* glassy floating node */
.wf-node{position:relative;width:84px;height:84px;border-radius:24px;margin-bottom:24px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.012));
  border:1px solid var(--border-2);box-shadow:0 12px 34px rgba(0,0,0,.42);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:transform .6s cubic-bezier(.16,1,.3,1),border-color .5s,box-shadow .6s,background .5s;}
.wf-glow{position:absolute;inset:-2px;border-radius:24px;pointer-events:none;opacity:0;
  background:radial-gradient(60% 60% at 50% 40%,rgba(46,155,255,.5),transparent 72%);
  transition:opacity .6s ease;}
.wf-ic{position:relative;z-index:1;width:32px;height:32px;color:var(--text-3);
  opacity:.5;transform:scale(.86);
  transition:color .5s ease,opacity .55s cubic-bezier(.16,1,.3,1),transform .55s cubic-bezier(.16,1,.3,1);}

/* number badge → check on completion */
.wf-badge{position:absolute;top:-10px;right:-10px;z-index:2;width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-3);border:1px solid var(--border-2);
  transition:background .45s ease,border-color .45s ease,box-shadow .45s ease;}
.wf-badge b{font-size:13px;font-weight:700;color:var(--text-3);transition:color .4s ease,opacity .3s ease;}
.wf-check{position:absolute;width:16px;height:16px;color:#fff;opacity:0;transform:scale(.5);
  transition:opacity .35s ease,transform .45s cubic-bezier(.16,1,.3,1);}

/* text */
.wf-text h3{font-size:19px;font-weight:600;letter-spacing:-0.02em;color:var(--text-1);
  opacity:0;transform:translateY(12px);
  transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);}
.wf-text p{font-size:14px;color:var(--text-3);margin-top:9px;line-height:1.5;text-wrap:pretty;max-width:24ch;
  opacity:0;transform:translateY(12px);
  transition:opacity .6s cubic-bezier(.16,1,.3,1) .08s,transform .6s cubic-bezier(.16,1,.3,1) .08s;}

/* ---- ON: step has been reached (completed/lit) ---- */
.wf-step.on .wf-node{border-color:var(--accent-line);
  background:linear-gradient(180deg,rgba(46,155,255,.10),rgba(46,155,255,.02));}
.wf-step.on .wf-ic{color:var(--accent-2);opacity:1;transform:scale(1);transition-delay:.12s;}
.wf-step.on .wf-text h3{opacity:1;transform:none;transition-delay:.18s;} /* text 180ms after icon */
.wf-step.on .wf-text p{opacity:1;transform:none;transition-delay:.26s;}
.wf-step.on .wf-badge{background:var(--cta);border-color:transparent;box-shadow:var(--glow);}
.wf-step.on .wf-badge b{color:#fff;opacity:0;}            /* number fades */
.wf-step.on .wf-check{opacity:1;transform:scale(1);transition-delay:.16s;} /* check reveals */

/* ---- ACTIVE: current brightest step (number badge pulse + glow) ---- */
.wf-step.is-active .wf-node{transform:translateY(-6px) scale(1.05);border-color:var(--accent-2);
  box-shadow:0 20px 50px rgba(0,0,0,.5),0 0 0 1px var(--accent-line),0 0 46px rgba(46,155,255,.34);}
.wf-step.is-active .wf-glow{opacity:1;}
.wf-step.is-active .wf-badge{animation:wfPulse .62s cubic-bezier(.16,1,.3,1);}
.wf-step.is-active .wf-badge b{opacity:1;color:#fff;}     /* active keeps its number visible */
.wf-step.is-active .wf-check{opacity:0;transform:scale(.5);}
@keyframes wfPulse{0%{transform:scale(1);}45%{transform:scale(1.22);}100%{transform:scale(1);}}

/* reduced motion: no draw / pulse — show the whole journey completed & static */
@media (prefers-reduced-motion:reduce){
  .wf.is-playing .wf-fill{transition:none;}
  .wf-fill{transform:scaleX(1);}
  .wf-step .wf-node{border-color:var(--accent-line);background:linear-gradient(180deg,rgba(46,155,255,.10),rgba(46,155,255,.02));}
  .wf-step .wf-ic{color:var(--accent-2);opacity:1;transform:none;transition:none;}
  .wf-step .wf-text h3,.wf-step .wf-text p{opacity:1;transform:none;transition:none;}
  .wf-step .wf-badge{background:var(--cta);border-color:transparent;}
  .wf-step .wf-badge b{opacity:1;}
  .wf-step.is-active .wf-badge{animation:none;}
}

/* ====================================================================
   TRUST — Architecture Lock / Integrity Scan
   ==================================================================== */
.trust{background:linear-gradient(180deg,var(--bg-2),var(--ink));}
.trust-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:stretch;margin-top:56px;}

/* ---- LEFT · scan visual ---- */
.scanviz{position:relative;}
.scanviz-frame{position:relative;width:100%;height:100%;min-height:480px;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--border-2);box-shadow:0 30px 80px rgba(0,0,0,0.5);background:#06080d;}
.scanviz-frame > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  opacity:0;transform:scale(1.05);filter:saturate(.92);
  transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1.2s cubic-bezier(.16,1,.3,1);}

/* blueprint grid overlay (subtle, masked toward edges) */
.sv-grid{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;transition:opacity 1s ease .2s;
  background-image:linear-gradient(rgba(46,155,255,.16) 1px,transparent 1px),linear-gradient(90deg,rgba(46,155,255,.16) 1px,transparent 1px);
  background-size:42px 42px;
  -webkit-mask-image:radial-gradient(120% 90% at 50% 45%,#000 35%,transparent 78%);
  mask-image:radial-gradient(120% 90% at 50% 45%,#000 35%,transparent 78%);}

/* premium blue AI glow vignette */
.sv-glow{position:absolute;inset:0;z-index:3;pointer-events:none;opacity:0;transition:opacity 1.1s ease .15s;
  background:radial-gradient(80% 60% at 50% 40%,rgba(46,155,255,.16),transparent 70%),
             inset 0 0 0 1px rgba(46,155,255,.06);
  box-shadow:inset 0 0 120px rgba(46,155,255,.14),inset 0 0 0 1px rgba(46,155,255,.08);}

/* scanning light line — single pass on reveal */
.sv-scan{position:absolute;left:0;right:0;top:0;height:160px;z-index:4;pointer-events:none;opacity:0;
  background:linear-gradient(180deg,transparent,rgba(46,155,255,.05) 40%,rgba(124,196,255,.5) 50%,rgba(46,155,255,.05) 60%,transparent);
  transform:translateY(-160px);}

/* architectural corner brackets */
.sv-corner{position:absolute;z-index:5;width:26px;height:26px;border:2px solid var(--accent-2);opacity:0;
  transition:opacity .6s ease .3s;filter:drop-shadow(0 0 6px rgba(46,155,255,.5));}
.sv-corner.tl{top:16px;left:16px;border-right:0;border-bottom:0;border-radius:6px 0 0 0;}
.sv-corner.tr{top:16px;right:16px;border-left:0;border-bottom:0;border-radius:0 6px 0 0;}
.sv-corner.bl{bottom:16px;left:16px;border-right:0;border-top:0;border-radius:0 0 0 6px;}
.sv-corner.br{bottom:16px;right:16px;border-left:0;border-top:0;border-radius:0 0 6px 0;}

/* lock pins */
.sv-pins{position:absolute;inset:0;z-index:6;}
.sv-pin{position:absolute;display:inline-flex;align-items:center;gap:9px;opacity:0;transform:translateY(6px) scale(.94);
  transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1);}
.sv-pin.lft{flex-direction:row-reverse;}
.sv-pin i{position:relative;width:11px;height:11px;border-radius:50%;flex:none;background:var(--accent-2);
  box-shadow:0 0 0 4px rgba(46,155,255,.22),0 0 12px rgba(46,155,255,.8);}
.sv-pin i::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid var(--accent-2);
  opacity:.7;animation:svPing 2.6s cubic-bezier(.16,1,.3,1) infinite;}
.sv-pin b{font-size:12px;font-weight:600;letter-spacing:.01em;color:#eaf3ff;white-space:nowrap;
  padding:6px 11px;border-radius:9px;background:rgba(8,12,20,.62);border:1px solid var(--accent-line);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 6px 18px rgba(0,0,0,.4);}
@keyframes svPing{0%{transform:scale(1);opacity:.7;}70%,100%{transform:scale(2.4);opacity:0;}}

/* status chip bottom-left */
.sv-status{position:absolute;left:18px;bottom:18px;z-index:7;display:inline-flex;align-items:center;gap:9px;
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-2);
  padding:8px 13px;border-radius:100px;background:rgba(8,12,20,.6);border:1px solid var(--accent-line);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;transition:opacity .6s ease;}
.sv-status .sv-dot{width:7px;height:7px;border-radius:50%;background:#48e08a;box-shadow:0 0 9px #48e08a;}

/* ---- RIGHT · integrity report panel ---- */
.ireport{border-radius:var(--r-lg);border:1px solid var(--border-2);overflow:hidden;
  background:linear-gradient(180deg,var(--surface-1),rgba(255,255,255,0.012));
  box-shadow:0 24px 60px rgba(0,0,0,0.4);display:flex;flex-direction:column;}
.ir-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;
  border-bottom:1px solid var(--hair);background:rgba(46,155,255,.04);}
.ir-bar-t{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);}
.ir-bar-v{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:#48e08a;}
.ir-bar-v svg{width:15px;height:15px;}
.ir-list{list-style:none;margin:0;padding:6px 22px;display:flex;flex-direction:column;flex:1;}
.ir-check{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--hair);}
.ir-check:last-child{border-bottom:none;}
.ir-ic{width:44px;height:44px;border-radius:13px;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);border:1px solid var(--accent-line);}
.ir-ic svg{width:22px;height:22px;color:var(--accent-2);}
.ir-body{min-width:0;}
.ir-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.ir-row h3{font-size:17px;font-weight:600;letter-spacing:-0.01em;color:var(--text-1);}
.ir-tag{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 9px;border-radius:7px;color:#48e08a;background:rgba(72,224,138,.1);border:1px solid rgba(72,224,138,.3);}
.ir-tag.concept{color:var(--accent-2);background:var(--accent-soft);border-color:var(--accent-line);}
.ir-body p{font-size:14px;color:var(--text-3);margin-top:6px;line-height:1.5;text-wrap:pretty;}

/* ---- reveal sequence (opt-in via .trust-ready / .trust-go) ---- */
.trust-ready .scanviz-frame > img,
.trust-ready .sv-grid,.trust-ready .sv-glow,.trust-ready .sv-corner,
.trust-ready .sv-status,.trust-ready .sv-pin,
.trust-ready .ir-bar,.trust-ready .ir-check{opacity:0;}
.trust-ready .ir-bar{transform:translateY(10px);transition:opacity .6s ease,transform .6s cubic-bezier(.16,1,.3,1);}
.trust-ready .ir-check{transform:translateX(16px);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);}

.trust-go .scanviz-frame > img{opacity:1;transform:none;}
.trust-go .sv-grid,.trust-go .sv-glow,.trust-go .sv-corner,.trust-go .sv-status{opacity:1;}
.trust-go .sv-scan{animation:svScan 1.7s cubic-bezier(.45,.05,.3,1) .35s 1 both;}
@keyframes svScan{0%{opacity:0;transform:translateY(-160px);}10%{opacity:1;}90%{opacity:1;}100%{opacity:0;transform:translateY(520px);}}
.trust-go .sv-status{transition-delay:1.5s;}
/* pins appear one by one after the scan line passes */
.trust-go .sv-pin{opacity:1;transform:none;}
.trust-go .sv-pin[data-p="1"]{transition-delay:.7s;}
.trust-go .sv-pin[data-p="2"]{transition-delay:.95s;}
.trust-go .sv-pin[data-p="3"]{transition-delay:1.2s;}
.trust-go .sv-pin[data-p="4"]{transition-delay:1.45s;}
.trust-go .sv-pin[data-p="5"]{transition-delay:1.7s;}
/* report checks reveal one by one */
.trust-go .ir-bar{opacity:1;transform:none;transition-delay:.2s;}
.trust-go .ir-check{opacity:1;transform:none;}
.trust-go .ir-check:nth-child(1){transition-delay:.45s;}
.trust-go .ir-check:nth-child(2){transition-delay:.62s;}
.trust-go .ir-check:nth-child(3){transition-delay:.79s;}
.trust-go .ir-check:nth-child(4){transition-delay:.96s;}

@media (prefers-reduced-motion:reduce){
  .trust-ready .scanviz-frame > img,.trust-ready .sv-grid,.trust-ready .sv-glow,.trust-ready .sv-corner,
  .trust-ready .sv-status,.trust-ready .sv-pin,.trust-ready .ir-bar,.trust-ready .ir-check{opacity:1 !important;transform:none !important;transition:none !important;}
  .sv-scan{display:none !important;}
  .sv-pin i::after{animation:none !important;}
}

/* ====================================================================
   PRICING
   ==================================================================== */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:58px;position:relative;z-index:2;align-items:start;max-width:1060px;margin-left:auto;margin-right:auto;}
.plan{position:relative;padding:30px 26px;border-radius:var(--r-lg);border:1px solid var(--border);
  background:linear-gradient(180deg,var(--surface-1),rgba(255,255,255,0.012));display:flex;flex-direction:column;transition:.3s;}
.plan:hover{border-color:var(--border-2);transform:translateY(-4px);}
.plan.featured{border-color:var(--accent-line);background:linear-gradient(180deg,rgba(46,155,255,0.10),rgba(46,155,255,0.02));
  box-shadow:0 30px 80px rgba(0,0,0,0.5),0 0 0 1px var(--accent-line),0 0 70px rgba(46,155,255,0.16);}
.plan-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-size:11px;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;padding:6px 14px;border-radius:100px;background:var(--cta);color:#fff;box-shadow:var(--glow);white-space:nowrap;}
.plan .pname{font-size:15px;font-weight:700;letter-spacing:0.02em;}
.plan .pfor{font-size:13px;color:var(--text-3);margin-top:5px;min-height:34px;line-height:1.35;}
.plan .pprice{display:flex;align-items:baseline;gap:4px;margin-top:18px;}
.plan .pprice .amt{font-size:42px;font-weight:700;letter-spacing:-0.04em;}
.plan .pprice .per{font-size:14px;color:var(--text-3);}
.plan .pcred{font-size:13px;color:var(--accent-2);margin-top:8px;font-weight:550;}
.plan .btn{margin-top:24px;width:100%;}
.plan-feats{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:13px;}
.plan-feats li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--text-2);line-height:1.4;}
.plan-feats li svg{width:16px;height:16px;color:var(--accent-2);flex:none;margin-top:2px;}
.price-note{text-align:center;margin-top:30px;font-size:13.5px;color:var(--text-3);position:relative;z-index:2;}

/* ====================================================================
   FAQ
   ==================================================================== */
.faq-grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:64px;margin-top:8px;align-items:start;}
.faq-list{display:flex;flex-direction:column;}
.faq-item{border-bottom:1px solid var(--hair);}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 0;text-align:left;
  font-size:17px;font-weight:550;letter-spacing:-0.01em;color:var(--text);transition:color .2s;}
.faq-q:hover{color:var(--accent-2);}
.faq-ic{width:26px;height:26px;flex:none;border-radius:50%;border:1px solid var(--border-2);position:relative;transition:.3s;}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--text-2);border-radius:2px;transition:.3s;}
.faq-ic::before{width:11px;height:1.5px;}.faq-ic::after{width:1.5px;height:11px;}
.faq-item.open .faq-ic{background:var(--accent-soft);border-color:var(--accent-line);}
.faq-item.open .faq-ic::after{transform:translate(-50%,-50%) scaleY(0);}
.faq-item.open .faq-ic::before{background:var(--accent-2);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.16,1,.3,1);}
.faq-a p{font-size:14.5px;color:var(--text-2);line-height:1.6;padding:0 40px 26px 0;text-wrap:pretty;}

/* ====================================================================
   FINAL CTA
   ==================================================================== */
.final{position:relative;overflow:hidden;padding:120px 0;}
.final-card{position:relative;border-radius:34px;overflow:hidden;border:1px solid var(--border-2);
  box-shadow:0 40px 120px rgba(0,0,0,0.6);text-align:center;padding:90px 40px;}
.final-card .bgimg{position:absolute;inset:0;z-index:0;}
.final-card .bgimg img{width:100%;height:100%;object-fit:cover;}
.final-card .bgimg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,10,16,0.78),rgba(8,11,18,0.92)),radial-gradient(80% 90% at 50% 110%,rgba(46,155,255,0.3),transparent 70%);}
.final-card .inner{position:relative;z-index:2;}
.final-card h2{font-size:clamp(34px,4.6vw,60px);font-weight:700;letter-spacing:-0.03em;line-height:1.04;text-wrap:balance;}
.final-card p{font-size:18px;color:var(--text-2);margin:20px auto 0;max-width:560px;text-wrap:pretty;}
.final-card .hero-cta{justify-content:center;margin-top:38px;}

/* ====================================================================
   FOOTER
   ==================================================================== */
.footer{border-top:1px solid var(--hair);padding:60px 0 50px;}
.footer-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.footer-brand{max-width:300px;}
.footer-brand p{font-size:14px;color:var(--text-3);margin-top:16px;line-height:1.55;}
.footer-cols{display:flex;gap:64px;flex-wrap:wrap;}
.footer-col h4{font-size:12px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-4);margin-bottom:16px;}
.footer-col a{display:block;font-size:14px;color:var(--text-2);margin-bottom:11px;transition:color .2s;}
.footer-col a:hover{color:var(--text);}
.footer-bot{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-top:50px;padding-top:28px;border-top:1px solid var(--hair);font-size:13px;color:var(--text-4);}

/* ====================================================================
   RESPONSIVE
   ==================================================================== */
@media (max-width:1080px){
  .tools-grid{grid-template-columns:1fr;}
  .tool{display:grid;grid-template-columns:1fr 1.2fr;}
  .tool-img{height:100%;min-height:240px;}
  .tool-img::after{background:linear-gradient(90deg,rgba(8,11,18,0) 50%,rgba(10,14,22,0.6));}
  .tool-mode{position:static;padding:0;}
  .tool-num{display:none;}
}
@media (max-width:920px){
  .nav-links,.nav-signin{display:none;}
  .nav-burger{display:flex;}
  .hero-grid{grid-template-columns:1fr;gap:42px;}
  .hero{padding:120px 0 70px;}
  .trust-grid,.faq-grid{grid-template-columns:1fr;gap:42px;}
  .price-grid{grid-template-columns:repeat(2,1fr);max-width:none;}
  .scanviz-frame{min-height:420px;}
}
@media (max-width:680px){
  .wrap{padding:0 20px;}
  .section{padding:88px 0;}
  .nav-in{padding:0 20px;height:64px;}
  .hero{padding:104px 0 60px;}
  .tool{grid-template-columns:1fr;}
  .tool-img{min-height:200px;}
  .tool-img::after{background:linear-gradient(180deg,rgba(8,11,18,0) 40%,rgba(10,14,22,0.92));}
  /* Trust scan → simplify to 3 pins, smaller frame */
  .scanviz-frame{min-height:340px;}
  .sv-pin.pin-opt{display:none;}
  .sv-pin b{font-size:11px;padding:5px 9px;}
  .sv-grid{background-size:34px 34px;}
  /* Workflow → vertical timeline, progress line top→bottom */
  .wf{margin-top:48px;padding-left:6px;}
  .wf-grid{grid-template-columns:1fr;gap:30px;}
  .wf-step{flex-direction:row;align-items:flex-start;text-align:left;gap:20px;}
  .wf-node{width:64px;height:64px;border-radius:20px;margin-bottom:0;flex:none;}
  .wf-ic{width:26px;height:26px;}
  .wf-text{padding-top:6px;}
  .wf-text p{max-width:none;}
  .wf-track{top:8px;bottom:8px;left:32px;right:auto;width:2px;height:auto;}
  .wf-fill{transform:scaleY(0);transform-origin:top center;}
  .wf.is-playing .wf-fill{transform:scaleY(1);}
  .metrics{flex-wrap:wrap;}
  .metric{flex:1 1 50%;border-right:none;padding:20px 8px;}
  .metric:nth-child(odd){border-right:1px solid var(--hair);}
  .metrics.capstrip{grid-template-columns:1fr 1fr;gap:10px;}
  .metric.cap{flex:initial;border:1px solid var(--border-2);padding:14px 14px;}
  .metric.cap:nth-child(odd){border-right:1px solid var(--border-2);}
  .price-grid{grid-template-columns:1fr;}
  .plan.featured{order:-1;}
  .villa-chips{gap:7px;left:12px;right:12px;bottom:12px;}
  .villa-chips .mode-chip{padding:9px 10px;}
  .villa-chips .mode-chip .t small{display:none;}
  .proof-stage .ba{aspect-ratio:4/3;}
  .final-card{padding:60px 24px;}
  .footer-top{flex-direction:column;}
  .gallery-head{flex-direction:column;align-items:flex-start;gap:22px;}
  .rail{margin-top:34px;-webkit-mask-image:none;mask-image:none;}
  .rail-track{padding:8px 20px 14px;gap:16px;}
  .rcard{width:78vw;aspect-ratio:3/4;}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important;}
  .reveal{opacity:1;transform:none;}
}

/* ====================================================================
   PRODUCTION COMPATIBILITY — ll- class hooks required by test suite
   ==================================================================== */

/* Hero section (ll-hero) - section tag carries class, no extra CSS needed */

/* Hero copy panel */
.ll-hero-glass {
  position:relative;
  z-index:2;
}

/* Bento grid (tools-grid) */
.ll-bento {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:60px;
}

/* Bento panel base */
.ll-bp {
  position:relative;
  overflow:hidden;
  border-radius:var(--r-lg);
}

/* Proof section */
.ll-proof {
  padding:130px 0;
}

/* Proof item container */
.ll-proof-item {
  margin-bottom:56px;
}
.ll-proof-item:last-of-type {
  margin-bottom:0;
}

/* Large BA slider */
.ll-ba-large {
  position:relative;
  aspect-ratio:21 / 9;
  border-radius:var(--r-lg);
  box-shadow:0 40px 110px rgba(0,0,0,0.55);
  overflow:hidden;
  border:1px solid var(--border-2);
}

/* Proof mode badges */
.ll-proof-badge {
  display:inline-flex;
  align-items:center;
  font-size:10.5px;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:6px 12px;
  border-radius:8px;
}
.ll-proof-badge-creative {
  background:var(--accent-soft);
  border:1px solid var(--accent-line);
  color:var(--accent-2);
}
.ll-proof-badge-interior {
  background:rgba(53,216,242,0.12);
  border:1px solid rgba(53,216,242,0.38);
  color:#35D8F2;
}

/* Trust section */
.ll-trust {
  background:linear-gradient(180deg,var(--bg-2),var(--ink));
}

/* Desktop hero split layout — required by test (min-width: 900px + 1fr 1fr) */
@media (min-width:900px) {
  .hero-grid {
    grid-template-columns:1fr 1fr;
  }
  .villa-photo {
    object-position:center 28%;
  }
}

/* Mobile BA large responsive override */
@media (max-width:900px) {
  .ll-ba-large {
    aspect-ratio:4 / 3;
  }
  .proof-stage .ba {
    aspect-ratio:4 / 3;
  }
}

/* Hero veil directional gradient (to right) — required by test */
.hero-bg::after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to right,rgba(5,7,12,0.72) 0%,transparent 60%);
  pointer-events:none;
  z-index:1;
}

/* ====================================================================
   HERO CINEMATIC — full-bleed day/night with click toggle
   ==================================================================== */

/* Override .hero padding; cinematic hero fills full viewport */
.hero-cinematic {
  padding:0;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  align-items:stretch;
}

/* Background image stack */
.hero-bg-wrap {
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-bg-img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 58%;
  display:block;
}
.hero-bg-day  { z-index:1; }
.hero-bg-night {
  z-index:2;
  opacity:0;
  will-change:opacity;
  transition:opacity 1.2s cubic-bezier(0.16,1,0.3,1);
}

/* Night mode: fade in the night image */
.hero-cinematic[data-hero="night"] .hero-bg-night { opacity:1; }

/* Cinematic directional overlay — dark-left for copy, opens to right */
.hero-overlay {
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:
    linear-gradient(to right,
      rgba(5,7,12,0.94) 0%,
      rgba(5,7,12,0.82) 24%,
      rgba(5,7,12,0.44) 52%,
      rgba(5,7,12,0.10) 72%,
      transparent 88%),
    linear-gradient(to top,
      rgba(5,7,12,0.58) 0%,
      transparent 30%);
}

/* Main content sits above the overlay stack */
.hero-cinematic > .wrap {
  position:relative;
  z-index:4;
  display:flex;
  flex-direction:column;
  min-height:100dvh;
  padding-top:128px;
  padding-bottom:0;
}

/* Copy block: vertically centered in available height above metrics */
.hero-cinematic .hero-copy {
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
  max-width:640px;
  padding-bottom:48px;
}

/* Day / Night toggle: large premium widget, right-center of hero */
.hero-dn-toggle {
  position:absolute;
  right:56px;
  top:50%;
  transform:translateY(-50%);
  z-index:6;
  display:flex;
  flex-direction:column;
  gap:8px;
  background:rgba(6,9,15,0.70);
  backdrop-filter:blur(28px) saturate(180%) brightness(0.95);
  -webkit-backdrop-filter:blur(28px) saturate(180%) brightness(0.95);
  border:1px solid rgba(255,255,255,0.18);
  border-radius:24px;
  padding:10px;
  min-width:190px;
  box-shadow:
    0 40px 100px rgba(0,0,0,0.62),
    0 0 0 1px rgba(255,255,255,0.05),
    inset 0 1px 0 rgba(255,255,255,0.12);
}

/* Label above buttons */
.hero-dn-toggle::before {
  content:"View in";
  display:block;
  font-size:10.5px;
  font-weight:700;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--text-4);
  text-align:center;
  padding:4px 8px 2px;
}

.dn-btn {
  display:flex;
  align-items:center;
  gap:12px;
  padding:18px 26px;
  border-radius:16px;
  font-size:17px;
  font-weight:600;
  letter-spacing:-0.02em;
  color:rgba(244,247,251,0.40);
  background:transparent;
  border:none;
  cursor:pointer;
  transition:color .22s,background .22s,box-shadow .22s,transform .15s;
  white-space:nowrap;
  width:100%;
  justify-content:flex-start;
}
.dn-btn svg { width:20px;height:20px;flex:none; }
.dn-btn:hover {
  color:var(--text-2);
  background:rgba(255,255,255,0.06);
}
.dn-btn:active { transform:scale(0.97); }

/* Active: Day = warm gold fill */
.dn-btn-day.active {
  background:rgba(255,196,50,0.16);
  color:rgba(255,220,80,1.0);
  box-shadow:
    0 6px 28px rgba(255,180,30,0.24),
    inset 0 1px 0 rgba(255,230,120,0.14);
}

/* Active: Night = ProBroker blue fill */
.dn-btn-night.active {
  background:rgba(46,155,255,0.18);
  color:var(--accent-2);
  box-shadow:
    0 6px 28px rgba(46,155,255,0.30),
    inset 0 1px 0 rgba(92,192,255,0.14);
}

/* Mobile: horizontal, bottom-center */
@media (max-width:920px) {
  .hero-dn-toggle {
    right:auto;
    left:50%;
    top:auto;
    bottom:110px;
    transform:translateX(-50%);
    flex-direction:row;
    border-radius:18px;
    padding:7px;
    min-width:0;
  }
  .hero-dn-toggle::before { display:none; }
  .dn-btn { padding:13px 22px;font-size:15px;justify-content:center;width:auto; }
}
@media (max-width:680px) {
  .hero-dn-toggle { bottom:88px; }
  .dn-btn { padding:11px 18px;font-size:14px;gap:9px; }
}

/* Reduced motion: instant toggle */
@media (prefers-reduced-motion:reduce) {
  .hero-bg-night { transition:none !important; }
}

/* HERO DAY/NIGHT MANUAL POLISH */
.hero-bg-wrap {
  background: #050911;
}

.hero-bg-wrap::before {
  content: "";
  position: absolute;
  inset: -24px;
  background-image: url("/assets/landing/hero-day-night/villa-day.jpg");
  background-size: cover;
  background-position: center center;
  filter: blur(26px);
  transform: scale(1.05);
  opacity: 0.35;
  z-index: 0;
}

.hero-bg-img {
  object-fit: cover !important;
  object-position: center center !important;
  z-index: 1;
}

.hero-bg-night {
  z-index: 2;
}

.hero-overlay {
  z-index: 3;
}

.hero-cinematic > .wrap,
.hero-dn-toggle {
  z-index: 4;
}

.hero-dn-toggle {
  right: clamp(28px, 6vw, 110px) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 190px !important;
  padding: 12px !important;
  border-radius: 26px !important;
  background: rgba(5, 8, 14, 0.72) !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  box-shadow:
    0 24px 80px rgba(0, 0, 0, 0.45),
    0 0 40px rgba(0, 136, 204, 0.22) !important;
  backdrop-filter: blur(22px) saturate(1.35) !important;
  -webkit-backdrop-filter: blur(22px) saturate(1.35) !important;
}

.dn-btn {
  min-height: 54px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em !important;
  border-radius: 18px !important;
}

.dn-btn.active {
  transform: scale(1.02);
}

.dn-btn-day.active {
  background: linear-gradient(135deg, rgba(232, 194, 90, 0.95), rgba(150, 108, 28, 0.88)) !important;
  color: #171104 !important;
}

.dn-btn-night.active {
  background: linear-gradient(135deg, rgba(0, 178, 255, 0.96), rgba(20, 92, 255, 0.88)) !important;
  color: #ffffff !important;
}

@media (max-width: 900px) {
  .hero-bg-img {
    object-fit: cover !important;
    object-position: center center !important;
  }

  .hero-dn-toggle {
    width: min(360px, calc(100vw - 32px)) !important;
    right: 50% !important;
    top: auto !important;
    bottom: 28px !important;
    transform: translateX(50%) !important;
    flex-direction: row !important;
  }

  .dn-btn {
    flex: 1;
  }
}

/* HERO DAY/NIGHT MANUAL POLISH */
.hero-bg-wrap {
  background: #050911;
}

.hero-bg-wrap::before {
  content: "";
  position: absolute;
  inset: -24px;
  background-image: url("/assets/landing/hero-day-night/villa-day.jpg");
  background-size: cover;
  background-position: center center;
  filter: blur(26px);
  transform: scale(1.05);
  opacity: 0.35;
  z-index: 0;
}

.hero-bg-img {
  object-fit: cover !important;
  object-position: center center !important;
  z-index: 1;
}

.hero-bg-night {
  z-index: 2;
}

.hero-overlay {
  z-index: 3;
}

.hero-cinematic > .wrap,
.hero-dn-toggle {
  z-index: 4;
}

.hero-dn-toggle {
  right: clamp(28px, 6vw, 110px) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 190px !important;
  padding: 12px !important;
  border-radius: 26px !important;
  background: rgba(5, 8, 14, 0.72) !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  box-shadow:
    0 24px 80px rgba(0, 0, 0, 0.45),
    0 0 40px rgba(0, 136, 204, 0.22) !important;
  backdrop-filter: blur(22px) saturate(1.35) !important;
  -webkit-backdrop-filter: blur(22px) saturate(1.35) !important;
}

.dn-btn {
  min-height: 54px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em !important;
  border-radius: 18px !important;
}

.dn-btn.active {
  transform: scale(1.02);
}

.dn-btn-day.active {
  background: linear-gradient(135deg, rgba(232, 194, 90, 0.95), rgba(150, 108, 28, 0.88)) !important;
  color: #171104 !important;
}

.dn-btn-night.active {
  background: linear-gradient(135deg, rgba(0, 178, 255, 0.96), rgba(20, 92, 255, 0.88)) !important;
  color: #ffffff !important;
}

@media (max-width: 900px) {
  .hero-bg-img {
    object-fit: cover !important;
    object-position: center center !important;
  }

  .hero-dn-toggle {
    width: min(360px, calc(100vw - 32px)) !important;
    right: 50% !important;
    top: auto !important;
    bottom: 28px !important;
    transform: translateX(50%) !important;
    flex-direction: row !important;
  }

  .dn-btn {
    flex: 1;
  }
}

/* NAVBAR + HERO ALIGNMENT POLISH */
@media (min-width: 980px) {
  .nav {
    background: linear-gradient(
      to bottom,
      rgba(3, 7, 13, 0.72),
      rgba(3, 7, 13, 0.38),
      rgba(3, 7, 13, 0)
    ) !important;
    backdrop-filter: blur(18px) saturate(1.25) !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.25) !important;
  }

  .nav-in {
    width: min(1440px, calc(100vw - 96px)) !important;
    max-width: none !important;
    height: 82px !important;
    padding: 0 !important;
    display: grid !important;
    grid-template-columns: minmax(240px, 1fr) auto minmax(240px, 1fr) !important;
    align-items: center !important;
    gap: 42px !important;
  }

  .brand {
    justify-self: start !important;
  }

  .nav-links {
    justify-self: center !important;
    margin-left: 0 !important;
    gap: 38px !important;
  }

  .nav-right {
    justify-self: end !important;
    margin-left: 0 !important;
    gap: 20px !important;
  }

  .hero-cinematic > .wrap,
  .hero > .wrap {
    width: min(1440px, calc(100vw - 96px)) !important;
    max-width: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .hero-copy {
    max-width: 620px !important;
  }

  .hero-cta {
    align-items: center !important;
  }

  .hero-dn-toggle {
    right: max(64px, calc((100vw - 1440px) / 2 + 32px)) !important;
  }

  .metrics {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

@media (max-width: 979px) {
  .nav-in {
    width: calc(100vw - 32px) !important;
    padding: 0 !important;
  }
}

/* HERO DAY/NIGHT CLICK FIX */
.hero-bg-wrap,
.hero-bg-img,
.hero-overlay {
  pointer-events: none !important;
}

.hero-dn-toggle,
.hero-dn-toggle * {
  pointer-events: auto !important;
}

.hero-dn-toggle {
  cursor: pointer !important;
}

/* FORCE HERO DAY/NIGHT STATE */
#top[data-hero="night"] .hero-bg-night,
#top[data-state="night"] .hero-bg-night,
.hero[data-hero="night"] .hero-bg-night,
.hero[data-state="night"] .hero-bg-night,
.ll-hero[data-hero="night"] .hero-bg-night,
.ll-hero[data-state="night"] .hero-bg-night {
  opacity: 1 !important;
}

#top[data-hero="day"] .hero-bg-night,
#top[data-state="day"] .hero-bg-night,
.hero[data-hero="day"] .hero-bg-night,
.hero[data-state="day"] .hero-bg-night,
.ll-hero[data-hero="day"] .hero-bg-night,
.ll-hero[data-state="day"] .hero-bg-night {
  opacity: 0 !important;
}

/* HARD HERO DAY/NIGHT TOGGLE FIX */
#top,
.hero,
.ll-hero,
.hero-cinematic {
  position: relative !important;
  isolation: isolate !important;
}

.hero-bg-wrap,
.hero-bg-img,
.hero-overlay,
.villa,
.villa-media,
.villa-night,
.hero-bg-night,
.pb-force-night-layer {
  pointer-events: none !important;
}

.hero-bg-night,
.villa-night,
.pb-force-night-layer {
  opacity: 0;
  transition: opacity 900ms cubic-bezier(0.16, 1, 0.3, 1) !important;
  will-change: opacity;
}

.hero-dn-toggle {
  z-index: 999 !important;
  pointer-events: auto !important;
}

.hero-dn-toggle *,
.dn-btn {
  pointer-events: auto !important;
}

/* EXACT VIDEO-STYLE HERO SKY TOGGLE */
.hero-sky-toggle-wrap {
  position: absolute;
  right: max(64px, calc((100vw - 1440px) / 2 + 32px));
  top: 50%;
  transform: translateY(-50%);
  z-index: 1000;
  pointer-events: auto;
}

.sky-toggle {
  appearance: none;
  -webkit-appearance: none;
  border: 0;
  margin: 0;
  padding: 0;
  cursor: pointer;
  display: block;
  position: relative;
  width: 132px;
  height: 68px;
  border-radius: 999px;
  background: transparent;
  -webkit-tap-highlight-color: transparent;
  outline: none;
  will-change: transform;
  filter: drop-shadow(0 18px 28px rgba(0, 0, 0, 0.36));
}

.sky-toggle:active {
  transform: scale(.975);
}

.sky-toggle:focus-visible {
  box-shadow: 0 0 0 4px rgba(80, 178, 255, .65);
  border-radius: 999px;
}

.st-track {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  overflow: hidden;
  box-shadow:
    0 14px 34px rgba(58, 160, 236, .34),
    0 4px 10px rgba(20, 30, 60, .34),
    inset 0 1px 2px rgba(255, 255, 255, .45);
  transition: box-shadow .65s cubic-bezier(.4, 0, .2, 1);
}

.sky-toggle.is-night .st-track {
  box-shadow:
    0 16px 38px rgba(18, 18, 52, .65),
    0 4px 12px rgba(8, 10, 28, .5),
    inset 0 1px 2px rgba(190, 196, 255, .2);
}

.st-sky {
  position: absolute;
  inset: 0;
  transition: opacity .6s cubic-bezier(.4, 0, .2, 1);
}

.st-day {
  opacity: 1;
  background: linear-gradient(165deg, #d8efff 0%, #8ecff4 44%, #22a9f4 100%);
}

.st-night {
  opacity: 0;
  background: linear-gradient(165deg, #3c4180 0%, #222650 50%, #0e1030 100%);
}

.sky-toggle.is-night .st-day {
  opacity: 0;
}

.sky-toggle.is-night .st-night {
  opacity: 1;
}

.st-clouds {
  position: absolute;
  inset: 0;
  opacity: 1;
  transition: opacity .5s ease;
}

.sky-toggle.is-night .st-clouds {
  opacity: 0;
}

.st-clouds i {
  position: absolute;
  border-radius: 50%;
  background: #fff;
  filter: drop-shadow(0 1px 1px rgba(40, 90, 140, .18));
}

.st-clouds .c1 {
  left: 20px;
  top: 17px;
  width: 9px;
  height: 9px;
  box-shadow: 7px 2px 0 -1px #fff, 14px 3px 0 -2px #fff;
}

.st-clouds .c2 {
  left: 16px;
  top: 38px;
  width: 10px;
  height: 10px;
  box-shadow: 8px 1px 0 0 #fff, 16px 3px 0 -1px #fff, 24px 4px 0 -3px #fff;
}

.st-stars {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .55s ease;
}

.sky-toggle.is-night .st-stars {
  opacity: 1;
}

.st-stars i {
  position: absolute;
  width: 2px;
  height: 2px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 4px rgba(255, 255, 255, .9);
}

.st-stars i:nth-child(1) { right: 20px; top: 18px; }
.st-stars i:nth-child(2) { right: 38px; top: 31px; width: 1.5px; height: 1.5px; }
.st-stars i:nth-child(3) { right: 16px; top: 43px; }
.st-stars i:nth-child(4) { right: 52px; top: 20px; width: 1.5px; height: 1.5px; }
.st-stars i:nth-child(5) { right: 32px; top: 48px; width: 1.5px; height: 1.5px; }
.st-stars i:nth-child(6) { right: 58px; top: 40px; }

.st-thumb {
  position: absolute;
  left: 7px;
  top: 7px;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  transform: translateX(64px);
  transition: transform .62s cubic-bezier(.34, 1.4, .5, 1);
  will-change: transform;
}

.sky-toggle.is-night .st-thumb {
  transform: translateX(0);
}

.st-sun,
.st-moon {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  transition: opacity .45s ease;
}

.st-sun {
  opacity: 1;
  background: radial-gradient(circle at 40% 36%, #ffffff 0%, #fffaf0 58%, #ffeecb 100%);
  box-shadow:
    0 0 18px 4px rgba(255, 255, 255, .92),
    0 0 34px 10px rgba(150, 215, 255, .56),
    0 4px 10px rgba(20, 60, 100, .26);
}

.st-moon {
  opacity: 0;
  background: radial-gradient(circle at 38% 34%, #fdfbf6 0%, #ece7f6 58%, #d6cfec 100%);
  box-shadow:
    0 0 16px 4px rgba(255, 206, 224, .56),
    0 0 30px 10px rgba(120, 108, 205, .44),
    0 4px 10px rgba(10, 12, 40, .32);
}

.sky-toggle.is-night .st-sun {
  opacity: 0;
}

.sky-toggle.is-night .st-moon {
  opacity: 1;
}

.st-moon .cr {
  position: absolute;
  border-radius: 50%;
  background: rgba(176, 168, 206, .6);
  box-shadow: inset 1px 1px 2px rgba(120, 112, 165, .55);
}

.st-moon .cr1 { width: 12px; height: 12px; left: 10px; bottom: 9px; }
.st-moon .cr2 { width: 8px; height: 8px; left: 27px; top: 11px; }
.st-moon .cr3 { width: 6px; height: 6px; left: 30px; bottom: 15px; }

@media (max-width: 900px) {
  .hero-sky-toggle-wrap {
    right: 24px;
    top: auto;
    bottom: 34px;
    transform: none;
  }

  .sky-toggle {
    width: 118px;
    height: 62px;
  }

  .st-thumb {
    width: 50px;
    height: 50px;
    transform: translateX(56px);
  }

  .sky-toggle.is-night .st-thumb {
    transform: translateX(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .st-track,
  .st-sky,
  .st-clouds,
  .st-stars,
  .st-thumb,
  .st-sun,
  .st-moon {
    transition: none !important;
  }
}

/* HERO SKY TOGGLE POSITION FINAL */
.hero-sky-toggle-wrap {
  right: max(92px, calc((100vw - 1440px) / 2 + 150px)) !important;
  top: 31% !important;
  bottom: auto !important;
  transform: translateY(-50%) !important;
}

/* HERO SKY TOGGLE FINAL ALIGNMENT */
.hero-sky-toggle-wrap {
  top: 24% !important;
  right: max(72px, calc((100vw - 1440px) / 2 + 70px)) !important;
  bottom: auto !important;
  transform: translateY(-50%) !important;
}

/* ====================================================================
   PREMIUM UPLIFT — 2026 refresh
   Hero entrance · centered gallery · before/after cards · motion polish
   ==================================================================== */

/* Gradient text accent for headings */
.tx-grad{
  background:linear-gradient(115deg,#fff 8%,#9fd0ff 54%,#2E9BFF 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---- refined reveal variants (transform + opacity only) ---- */
.reveal[data-d="5"]{transition-delay:.40s;}
.reveal[data-d="6"]{transition-delay:.48s;}
.reveal-blur{opacity:0;transform:translateY(30px);filter:blur(6px);
  transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1),filter 1s cubic-bezier(.16,1,.3,1);}
.reveal-blur.in{opacity:1;transform:none;filter:none;}

/* ====================================================================
   HERO — premium staggered entrance (transform + opacity only)
   Opt-in: hidden ONLY when JS adds body.pb-anim, so a JS failure
   still shows everything. Animates once body.pb-loaded is set.
   ==================================================================== */
.hero-copy.ll-hero-glass{opacity:1;transform:none;} /* neutralise base .reveal on the panel */
body.pb-anim .hero-anim > *{opacity:0;transform:translateY(26px);}
body.pb-anim .hero-anim > h1{opacity:1;transform:none;} /* h1 box stays; its lines animate */
body.pb-loaded .hero-anim > *:not(h1){
  animation:heroIn 1.05s cubic-bezier(.16,1,.3,1) forwards;
}
body.pb-loaded .hero-anim > *:nth-child(1){animation-delay:.10s;}
body.pb-loaded .hero-anim > *:nth-child(3){animation-delay:.30s;}
body.pb-loaded .hero-anim > *:nth-child(4){animation-delay:.44s;}
body.pb-loaded .hero-anim > *:nth-child(5){animation-delay:.56s;}
@keyframes heroIn{from{opacity:0;transform:translateY(26px);}to{opacity:1;transform:none;}}

/* h1 line-by-line reveal */
.hero h1 .ln{display:block;overflow:hidden;}
.hero h1 .ln > span{display:inline-block;will-change:transform;}
body.pb-anim .hero h1 .ln > span{transform:translateY(106%);opacity:0;
  transition:transform 1s cubic-bezier(.16,1,.3,1),opacity 1s cubic-bezier(.16,1,.3,1);}
body.pb-loaded .hero h1 .ln > span{transform:none;opacity:1;}
body.pb-loaded .hero h1 .ln:nth-child(1) > span{transition-delay:.22s;}
body.pb-loaded .hero h1 .ln:nth-child(2) > span{transition-delay:.36s;}

/* metrics: staggered rise */
.metrics.reveal{transition-delay:.62s;}
body.pb-anim .metric{opacity:0;}
body.pb-loaded .metric{animation:metricIn .8s cubic-bezier(.16,1,.3,1) forwards;}
body.pb-loaded .metric:nth-child(1){animation-delay:.70s;}
body.pb-loaded .metric:nth-child(2){animation-delay:.78s;}
body.pb-loaded .metric:nth-child(3){animation-delay:.86s;}
body.pb-loaded .metric:nth-child(4){animation-delay:.94s;}
@keyframes metricIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

/* subtle ambient drift on hero background (very slow, GPU-cheap) */
@media (min-width:900px){
  .hero-bg-img{animation:heroDrift 26s ease-in-out infinite alternate;}
}
@keyframes heroDrift{from{transform:scale(1.04) translate3d(0,0,0);}to{transform:scale(1.08) translate3d(-1.4%,-1.2%,0);}}

/* ====================================================================
   RESULT GALLERY — centered head + before/after cards
   ==================================================================== */
.gallery-sec{overflow:visible;}
.gallery-sec .gallery-head{
  max-width:760px !important;display:block !important;margin:0 auto !important;text-align:center !important;
}
.gallery-hint{
  display:inline-flex;align-items:center;gap:10px;margin-top:26px;
  font-family:var(--mono);font-size:12px;letter-spacing:0.04em;color:var(--text-3);
  padding:9px 16px;border-radius:100px;background:var(--surface-1);border:1px solid var(--border);
}
.gallery-hint svg{width:16px;height:16px;color:var(--accent-2);animation:hintScrub 2.6s ease-in-out infinite;}
@keyframes hintScrub{0%,100%{transform:translateX(-2px);}50%{transform:translateX(2px);}}

.ba-card{display:none;} /* legacy grid card — superseded by .cine carousel */

/* the comparison viewport (shared by carousel slides) */
.ba-view{
  position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;cursor:ew-resize;
  user-select:none;touch-action:pan-y;background:#070a10;
}

/* ====================================================================
   RESULT GALLERY — cinematic featured carousel (video-referenced)
   large active stage · numbered thumbnail rail · active expands
   ==================================================================== */
.cine{margin-top:56px;position:relative;z-index:2;}

/* ---- featured stage ---- */
.cine-stage{
  position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--r-lg);
  overflow:hidden;border:1px solid var(--border);background:#06080d;
  box-shadow:0 40px 110px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.02);
}
.cine-slide{
  position:absolute;inset:0;opacity:0;transform:scale(1.045);
  transition:opacity .8s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1);
  pointer-events:none;will-change:opacity,transform;
}
.cine-slide.is-active{opacity:1;transform:scale(1);pointer-events:auto;z-index:2;}
.cine-slide .ba-view{position:absolute;inset:0;width:100%;height:100%;aspect-ratio:auto;border-radius:0;}

/* caption overlay — bottom-left, big title (video reference) */
.cine-grad{position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(0deg,rgba(4,6,11,.92) 0%,rgba(4,6,11,.55) 26%,rgba(4,6,11,0) 52%);}
.cine-cap{position:absolute;left:clamp(22px,3.4vw,52px);bottom:clamp(22px,3.4vw,46px);z-index:4;
  max-width:70%;pointer-events:none;}
.cine-cap .cine-badge{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;padding:7px 12px;border-radius:8px;margin-bottom:14px;
  background:rgba(8,11,18,.55);border:1px solid var(--border);color:var(--text-2);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}
.cine-cap .cine-badge.concept{color:var(--accent-2);border-color:var(--accent-line);background:var(--accent-soft);}
.cine-cap .cine-k{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-3);margin-bottom:8px;}
.cine-title{font-size:clamp(30px,4.4vw,62px);font-weight:700;letter-spacing:-.03em;line-height:1.02;
  text-wrap:balance;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.55);}
/* caption rises in with the active slide */
.cine-slide .cine-cap > *{opacity:0;transform:translateY(22px);}
.cine-slide.is-active .cine-cap > *{opacity:1;transform:none;
  transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);}
.cine-slide.is-active .cine-cap .cine-badge{transition-delay:.16s;}
.cine-slide.is-active .cine-cap .cine-k{transition-delay:.24s;}
.cine-slide.is-active .cine-cap .cine-title{transition-delay:.32s;}
/* CTA link inside .cine-cap — pointer-events:auto overrides parent none */
.cine-cta{display:inline-flex;align-items:center;gap:7px;margin-top:18px;font-size:13.5px;font-weight:600;
  color:var(--accent-2);pointer-events:auto;text-decoration:none;
  transition:gap .2s ease,color .2s ease,opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.cine-cta:hover{gap:12px;color:var(--text);}
.cine-slide.is-active .cine-cap .cine-cta{transition-delay:.40s;}

/* keep the before/after handle clear of the caption */
.cine-slide .ba-tag{top:18px;}

/* prev / next arrows */
.cine-arrow{position:absolute;top:calc(50% - 40px);z-index:6;width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  background:rgba(8,11,18,.5);border:1px solid var(--border);color:#fff;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:background .25s,border-color .25s,transform .25s,opacity .25s;opacity:0;transform:translateY(-50%) scale(.9);}
.cine:hover .cine-arrow{opacity:1;transform:translateY(-50%) scale(1);}
.cine-arrow:hover{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent-2);}
.cine-arrow svg{width:24px;height:24px;}
.cine-prev{left:18px;}
.cine-next{right:18px;}

/* ---- thumbnail rail ---- */
.cine-rail{display:flex;gap:14px;margin-top:18px;align-items:stretch;}
.cine-thumb{position:relative;flex:1 1 0;flex-basis:0%;min-width:0;height:96px;border-radius:14px;overflow:hidden;
  cursor:pointer;border:1px solid var(--border);background:#06080d;padding:0;
  opacity:.46;filter:saturate(.7);transition:opacity .45s,filter .45s,flex-basis .55s cubic-bezier(.16,1,.3,1),border-color .35s,box-shadow .45s;
  will-change:flex-basis;}
.cine-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.cine-thumb-ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(4,6,11,.78),rgba(4,6,11,.05) 70%);}
.cine-thumb-num{position:absolute;left:12px;bottom:10px;z-index:2;font-family:var(--mono);font-size:13px;
  font-weight:600;color:#fff;letter-spacing:.04em;text-shadow:0 1px 8px rgba(0,0,0,.6);}
.cine-thumb-label{position:absolute;left:38px;right:12px;bottom:10px;z-index:2;font-size:13px;font-weight:600;
  color:#fff;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  opacity:0;transform:translateX(-6px);transition:opacity .4s,transform .4s;text-shadow:0 1px 10px rgba(0,0,0,.7);}
.cine-thumb:hover{opacity:.82;filter:saturate(1);}
.cine-thumb.is-active{opacity:1;filter:saturate(1);flex-basis:22%;border-color:var(--accent-line);
  box-shadow:0 0 0 1px var(--accent-line),0 14px 36px rgba(0,0,0,.5),0 0 34px rgba(46,155,255,.16);}
.cine-thumb.is-active .cine-thumb-label{opacity:1;transform:none;}
.cine-thumb.is-active .cine-thumb-ov{background:linear-gradient(0deg,rgba(4,6,11,.82),rgba(46,155,255,.12) 60%,rgba(4,6,11,.05));}

@media (max-width:880px){
  .cine-stage{aspect-ratio:4/3;}
  .cine-rail{gap:10px;}
  .cine-thumb{height:74px;}
  .cine-thumb-label{display:none;}
  .cine-thumb.is-active{flex-basis:12%;}
}
@media (max-width:560px){
  .cine{margin-top:38px;}
  .cine-stage{aspect-ratio:3/4;}
  .cine-rail{overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
  .cine-rail::-webkit-scrollbar{display:none;}
  .cine-thumb{flex:0 0 64px;height:64px;}
  .cine-thumb.is-active{flex:0 0 110px;}
  .cine-arrow{opacity:1;transform:translateY(-50%) scale(1);width:44px;height:44px;}
}

/* ====================================================================
   THREE MODES — cinematic hover dominance (active brightens, rest dim)
   ==================================================================== */
.cine-modes{transition:none;}
.cine-modes .tool{transition:transform .55s cubic-bezier(.16,1,.3,1),opacity .45s ease,filter .45s ease,box-shadow .55s,border-color .35s;}
.cine-modes .tool .tool-img img{transition:transform 1.1s cubic-bezier(.16,1,.3,1),filter .5s ease;}
/* when the grid is hovered, non-hovered siblings dim & desaturate */
@media (hover:hover) and (pointer:fine){
  .cine-modes:hover .tool{opacity:.5;filter:saturate(.72) brightness(.82);}
  .cine-modes:hover .tool:hover{opacity:1;filter:none;transform:translateY(-8px);
    box-shadow:0 32px 80px rgba(0,0,0,.55),0 0 0 1px var(--accent-line),0 0 60px rgba(46,155,255,.16);}
  .cine-modes .tool:hover .tool-img img{transform:scale(1.07);}
}

/* ====================================================================
   THREE MODES — "brought online" reveal sequence (left → right)
   Opt-in: hidden only when JS adds .mode-ready (so no-JS shows cards).
   Per-card layers reveal after JS adds .mode-in (staggered by index).
   ==================================================================== */
.mode-card{position:relative;}

/* image scan bar + sharpen */
.mode-scan{position:absolute;inset:0;z-index:3;pointer-events:none;opacity:0;
  background:linear-gradient(105deg,transparent 38%,rgba(46,155,255,.10) 47%,rgba(170,214,255,.85) 50%,rgba(46,155,255,.10) 53%,transparent 62%);
  transform:translateX(-110%);mix-blend-mode:screen;}
.mode-ready .mode-card .tool-img img{filter:blur(9px) saturate(.7) brightness(.72);transform:scale(1.07);}

/* card pre-reveal state */
.mode-ready .mode-card{opacity:0;transform:translateY(28px) scale(.96);
  transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1),border-color .4s,box-shadow .5s;}

/* content layers pre-reveal */
.mode-ready .mode-card .tool-num,
.mode-ready .mode-card .tool-mode,
.mode-ready .mode-card .purpose,
.mode-ready .mode-card .tool-caps li,
.mode-ready .mode-card .tool-foot{opacity:0;transform:translateY(14px);
  transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);}

/* ---- ON: card brought online ---- */
.mode-card.mode-in{opacity:1;transform:none;}
.mode-card.mode-in .tool-img img{filter:none;transform:none;
  transition:filter 1s cubic-bezier(.16,1,.3,1) .12s,transform 1.1s cubic-bezier(.16,1,.3,1) .12s;}
/* light sweep travels across the image once */
.mode-card.mode-in .mode-scan{animation:modeScan 1s cubic-bezier(.4,.05,.2,1) .15s 1 both;}
@keyframes modeScan{0%{opacity:0;transform:translateX(-110%);}12%{opacity:1;}88%{opacity:1;}100%{opacity:0;transform:translateX(110%);}}
/* brief accent border "power-on" pulse */
.mode-card.mode-in{animation:modeOnline 1.1s ease .1s 1 both;}
@keyframes modeOnline{0%{box-shadow:0 0 0 1px rgba(46,155,255,0),0 20px 50px rgba(0,0,0,.35);}
  30%{box-shadow:0 0 0 1px var(--accent-line),0 0 40px rgba(46,155,255,.32),0 20px 50px rgba(0,0,0,.4);}
  100%{box-shadow:0 0 0 1px rgba(46,155,255,0),0 20px 50px rgba(0,0,0,.35);}}

/* layered content reveal (badge → icon+title → paragraph → bullets → CTA) */
.mode-card.mode-in .tool-num{opacity:1;transform:none;transition-delay:.20s;}
.mode-card.mode-in .tool-mode{opacity:1;transform:none;transition-delay:.30s;}
.mode-card.mode-in .purpose{opacity:1;transform:none;transition-delay:.42s;}
.mode-card.mode-in .tool-caps li{opacity:1;transform:none;}
.mode-card.mode-in .tool-caps li:nth-child(1){transition-delay:.52s;}
.mode-card.mode-in .tool-caps li:nth-child(2){transition-delay:.60s;}
.mode-card.mode-in .tool-caps li:nth-child(3){transition-delay:.68s;}
.mode-card.mode-in .tool-foot{opacity:1;transform:none;transition-delay:.78s;}

/* hover: CTA brightens (lift / glow / image zoom handled by .cine-modes dominance) */
@media (hover:hover) and (pointer:fine){
  .cine-modes .tool:hover .tool-foot{color:#7cc4ff;}
}

@media (prefers-reduced-motion:reduce){
  .mode-ready .mode-card,
  .mode-ready .mode-card .tool-num,
  .mode-ready .mode-card .tool-mode,
  .mode-ready .mode-card .purpose,
  .mode-ready .mode-card .tool-caps li,
  .mode-ready .mode-card .tool-foot{opacity:1 !important;transform:none !important;transition:none !important;}
  .mode-ready .mode-card .tool-img img{filter:none !important;transform:none !important;}
  .mode-card.mode-in{animation:none !important;}
  .mode-scan{display:none !important;}
}
.ba-layer{position:absolute;inset:0;}
.ba-layer img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;pointer-events:none;}
.ba-after img{transform:scale(1.02);transition:transform 1s cubic-bezier(.16,1,.3,1);}
.ba-card:hover .ba-after img{transform:scale(1.06);}
/* before layer is clipped by JS via clip-path inset from the right */
.ba-before{clip-path:inset(0 50% 0 0);will-change:clip-path;}
.ba-before::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(46,155,255,0.05));}
/* enhancement card: simulate a flat raw capture on the BEFORE only */
.ba-view--enhance .ba-before img{filter:saturate(.62) brightness(.82) contrast(.92) hue-rotate(-4deg);}

/* before / after tags */
.ba-tag{
  position:absolute;top:14px;z-index:5;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  padding:6px 11px;border-radius:8px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:opacity .3s;
}
.ba-tag-before{left:14px;background:rgba(8,11,18,0.6);color:var(--text-2);border:1px solid var(--border);}
.ba-tag-after{right:14px;background:var(--accent-soft);color:var(--accent-2);border:1px solid var(--accent-line);}

/* drag handle */
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;z-index:6;
  background:linear-gradient(180deg,rgba(255,255,255,.35),rgba(255,255,255,.95),rgba(255,255,255,.35));
  box-shadow:0 0 18px rgba(46,155,255,0.7);transform:translateX(-1px);}
.ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;
  background:rgba(10,14,22,0.55);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1.5px solid rgba(255,255,255,0.9);display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 22px rgba(0,0,0,0.5);transition:transform .25s,box-shadow .25s;}
.ba-knob svg{width:20px;height:20px;color:#fff;}
.ba-card:hover .ba-knob{box-shadow:0 8px 28px rgba(46,155,255,0.5),0 0 0 6px rgba(46,155,255,0.12);}
.ba-view:active .ba-knob{transform:translate(-50%,-50%) scale(.92);}

/* intro wipe when the card reveals */
.ba-card.reveal .ba-before{clip-path:inset(0 100% 0 0);}
.ba-card.reveal.in .ba-before{clip-path:inset(0 50% 0 0);transition:clip-path 1.1s cubic-bezier(.16,1,.3,1) .15s;}

/* meta row under the comparison */
.ba-meta{display:flex;align-items:center;gap:14px;padding:18px 20px 20px;}
.ba-badge{flex:none;font-size:10px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  padding:7px 11px;border-radius:8px;background:rgba(10,14,22,0.6);border:1px solid var(--border);color:var(--text-2);}
.ba-badge.concept{color:var(--accent-2);border-color:var(--accent-line);background:var(--accent-soft);}
.ba-text{min-width:0;}
.ba-text .ba-k{font-family:var(--mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent-2);}
.ba-text h3{font-size:18px;font-weight:600;letter-spacing:-0.02em;margin-top:4px;line-height:1.2;text-wrap:balance;}

@media (max-width:1080px){
  .ba-grid{grid-template-columns:repeat(2,1fr);gap:20px;}
}
@media (max-width:680px){
  .ba-grid{grid-template-columns:1fr;gap:18px;margin-top:42px;}
  .ba-view{aspect-ratio:4/3;}
  .ba-text h3{font-size:17px;}
}

/* reduced motion: no auto-wipe / drift, instant comparison at midpoint */
@media (prefers-reduced-motion:reduce){
  .hero-anim > *,.hero h1 .ln > span,.metric{animation:none !important;opacity:1 !important;transform:none !important;}
  .hero h1 .ln > span{transform:none !important;}
  .hero-bg-img{animation:none !important;}
  .ba-card.reveal .ba-before,.ba-card.reveal.in .ba-before{clip-path:inset(0 50% 0 0) !important;transition:none !important;}
}

/* PHONE LANDING REBUILD - manual */
@media (max-width: 680px) {
  html,
  body {
    overflow-x: hidden;
  }

  .hero-cinematic {
    min-height: auto !important;
  }

  .hero-cinematic > .wrap {
    min-height: auto !important;
    padding-top: 96px !important;
    padding-bottom: 52px !important;
  }

  .hero-copy {
    max-width: 100% !important;
  }

  .hero h1 {
    font-size: clamp(30px, 8.6vw, 42px) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.055em !important;
    max-width: 11.2em;
  }

  .hero .lede {
    font-size: clamp(16px, 4.4vw, 19px) !important;
    line-height: 1.45 !important;
    max-width: 94vw !important;
  }

  .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
    align-items: stretch !important;
  }

  .hero-actions .btn {
    min-height: 58px !important;
    padding: 0 16px !important;
    justify-content: center !important;
    white-space: nowrap !important;
  }

  .metrics.capstrip {
    display: none !important;
  }

  .hero-sky-toggle-wrap {
    display: flex !important;
    position: relative !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    transform: none !important;
    justify-content: center !important;
    width: 100% !important;
    margin: 18px auto 0 !important;
    z-index: 5 !important;
    pointer-events: auto !important;
  }

  .sky-toggle {
    transform: scale(0.86) !important;
    transform-origin: center !important;
  }

  #tools .tools-grid,
  #cineModes.tools-grid,
  #cineModes.tools-grid.ll-bento,
  #cineModes.tools-grid.ll-bento.cine-modes {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    gap: 18px !important;
    margin-top: 34px !important;
    overflow: visible !important;
  }

  #cineModes .tool,
  #cineModes .tool.mode-card,
  #cineModes .tool.ll-bp {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    grid-template-columns: none !important;
    overflow: hidden !important;
  }

  #cineModes .tool-img {
    height: 218px !important;
    min-height: 218px !important;
  }

  #cineModes .tool-img::after {
    background: linear-gradient(180deg, rgba(8,11,18,0) 38%, rgba(10,14,22,0.94)) !important;
  }

  #cineModes .tool-mode {
    position: absolute !important;
    left: 20px !important;
    right: 20px !important;
    bottom: 18px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
  }

  #cineModes .tool-mode h3 {
    font-size: 24px !important;
    line-height: 1.05 !important;
    white-space: normal !important;
  }

  #cineModes .tool-body {
    padding: 20px 22px 24px !important;
  }

  #cineModes .tool-body .purpose {
    font-size: 16px !important;
    line-height: 1.48 !important;
  }

  #cineModes .tool-caps {
    gap: 12px !important;
    margin-top: 18px !important;
  }

  #cineModes .tool-caps li {
    font-size: 15.5px !important;
    line-height: 1.4 !important;
    gap: 10px !important;
  }

  .ir-list {
    padding: 8px 14px !important;
  }

  .ir-list li {
    display: grid !important;
    grid-template-columns: 56px 1fr !important;
    gap: 14px !important;
    align-items: flex-start !important;
  }

  .ir-row {
    display: flex !important;
    align-items: flex-start !important;
    flex-direction: column !important;
    gap: 8px !important;
  }

  .ir-row h3 {
    font-size: 18px !important;
    line-height: 1.22 !important;
  }

  .ir-check {
    font-size: 15.5px !important;
    line-height: 1.45 !important;
  }
}

@media (max-width: 560px) {
  .cine-stage {
    aspect-ratio: 4 / 3 !important;
  }

  .ba-view {
    background: #06080d !important;
  }

  .ba-layer img {
    object-fit: contain !important;
  }
}

@media (max-width: 420px) {
  .hero-actions {
    grid-template-columns: 1fr !important;
  }

  .hero-actions .btn {
    width: 100% !important;
  }
}

/* PHONE HERO TOGGLE POSITION FIX */
@media (max-width: 680px) {
  .hero-sky-toggle-wrap {
    margin: 92px auto 30px !important;
  }
}

@media (max-width: 420px) {
  .hero-sky-toggle-wrap {
    margin: 78px auto 26px !important;
  }
}
