/* ═══════════════════════════════════════════════════════
   MEMORA — styles
   Design tokens, icon system, layout, animations.
═══════════════════════════════════════════════════════ */

:root {
  --bg:      #F6F4EF;
  --bg2:     #EDEBE4;
  --bg3:     #E8E5DD;
  --surface: #FFFFFF;
  --ink:     #12100C;           /* deeper, richer ink */
  --ink2:    #3F3C37;
  --ink3:    #6B6860;
  --ink4:    #9E9A94;
  --border:  #E2DED7;
  --border2: #D8D3CA;
  --green:   #059669;
  --green-bg:#D1FAE5;
  --green-dk:#065F46;
  --green-lt:#6EE7B7;
  --sage:    #4F6B5E;           /* softer secondary green */
  --lime:    #84CC16;           /* vibrant interactive highlight */
  --amber:   #F59E0B;
  --white:   #FAFAF8;
  --shadow-xs:0 1px 2px rgba(18,16,12,.06);
  --shadow:  0 4px 24px rgba(18,16,12,.09), 0 1px 4px rgba(18,16,12,.05);
  --shadow-md:0 8px 36px rgba(18,16,12,.10), 0 2px 8px rgba(18,16,12,.06);
  --shadow-lg:0 16px 56px rgba(18,16,12,.14);
  --shadow-xl:0 32px 80px rgba(18,16,12,.20), 0 8px 24px rgba(18,16,12,.10);
  --shadow-inset:inset 0 1px 0 rgba(255,255,255,.5);
  --ease:    cubic-bezier(0.22,1,0.36,1);
  --spring:  cubic-bezier(0.34,1.56,0.64,1);
  --settle:  cubic-bezier(0.16,0.8,0.24,1.04);  /* overshoot-and-settle */
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--bg);color:var(--ink);
  overflow-x:hidden;line-height:1.55;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1000;
  opacity:.35;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.05 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
/* Pages use opacity+transform transitions rather than display toggling
   so we get a smooth cross-fade instead of a hard cut */
.page{
  opacity:0;
  visibility:hidden;
  transform:translateY(12px) scale(.995);
  transition:opacity .5s var(--ease),transform .5s var(--ease),visibility 0s linear .5s;
  pointer-events:none;
  position:absolute;top:0;left:0;right:0;
  width:100%;
}
.page.active{
  opacity:1;
  visibility:visible;
  transform:translateY(0) scale(1);
  pointer-events:auto;
  position:relative;
  transition:opacity .55s var(--ease) .05s,transform .55s var(--ease) .05s,visibility 0s linear 0s;
}
::selection{background:var(--green-dk);color:var(--white);}
:focus-visible{outline:2.5px solid var(--green);outline-offset:3px;border-radius:3px;}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;}
  html{scroll-behavior:auto;}
}

/* ─── ICONS ─── */
.icon{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;flex-shrink:0;line-height:0;}
.icon svg{width:100%;height:100%;display:block;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.tile{
  display:inline-grid;place-items:center;
  width:54px;height:54px;border-radius:14px;
  background:var(--bg2);color:var(--ink2);
  box-shadow:inset 0 0 0 1px rgba(26,24,20,.04);
  transition:background .3s,color .3s,transform .4s var(--spring);
  font-size:26px;
}
.tile.accent{background:var(--green-bg);color:var(--green-dk);}
.tile.dark{background:var(--ink);color:var(--green-lt);box-shadow:inset 0 0 0 1px rgba(250,250,248,.06);}
.tile-sm{width:36px;height:36px;border-radius:10px;font-size:18px;}
.tile-xs{width:28px;height:28px;border-radius:8px;font-size:14px;}

/* ─── PROGRESS BAR ─── */
#progress{
  position:fixed;top:0;left:0;height:1.5px;
  background:linear-gradient(90deg,var(--green),var(--green-lt),var(--lime));
  width:0%;z-index:999;transition:width .12s linear;
  box-shadow:0 0 12px rgba(5,150,105,.6),0 0 4px rgba(110,231,183,.8);
}

/* ─── NAV ─── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:72px;display:flex;align-items:center;background:rgba(246,244,239,.72);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border-bottom:1px solid transparent;transition:border-color .4s,box-shadow .4s,height .4s,background .4s,backdrop-filter .4s;}
.nav.scrolled{border-color:var(--border);box-shadow:0 1px 16px rgba(18,16,12,.08);height:60px;background:rgba(246,244,239,.85);backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%);}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 28px;width:100%;display:flex;align-items:center;justify-content:space-between;}
.nav-logo{font-family:'Instrument Serif',serif;font-size:24px;letter-spacing:-.02em;text-decoration:none;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:opacity .2s;}
.nav-logo:hover{opacity:.7;}
.nav-logo-mark{
  width:32px;height:32px;border-radius:9px;
  background:var(--ink);
  display:grid;place-items:center;
  box-shadow:0 0 0 3px var(--green-bg),0 2px 6px rgba(18,16,12,.12);
  overflow:hidden;
  transition:transform .35s var(--spring),box-shadow .35s;
}
.nav-logo-mark img{
  width:20px;height:20px;
  object-fit:contain;
  /* invert image so the dark strokes become the green accent */
  filter:brightness(0) saturate(100%) invert(92%) sepia(19%) saturate(563%) hue-rotate(90deg) brightness(98%) contrast(92%);
  transition:filter .35s;
}
.nav-logo:hover .nav-logo-mark{transform:rotate(-4deg) scale(1.05);box-shadow:0 0 0 3px var(--green-bg),0 4px 12px rgba(18,16,12,.18);}
.nav-logo:focus-visible{outline:3px solid var(--green);outline-offset:4px;border-radius:4px;}
.nav-links{display:flex;align-items:center;gap:40px;}
.nav-links a{font-size:14px;font-weight:500;color:var(--ink3);text-decoration:none;cursor:pointer;transition:color .15s;position:relative;}
.nav-links a:not(.nav-cta)::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--ink);transform:scaleX(0);transform-origin:right center;transition:transform .35s var(--ease);}
.nav-links a:not(.nav-cta):hover{color:var(--ink);}
.nav-links a:not(.nav-cta):hover::after{transform:scaleX(1);transform-origin:left center;}
.nav-links a:focus-visible{outline:3px solid var(--green);outline-offset:3px;border-radius:2px;}
.nav-cta{background:var(--ink);color:var(--white)!important;padding:11px 22px;border-radius:100px;font-weight:600!important;font-size:13px!important;transition:transform .25s var(--spring),box-shadow .25s;display:inline-flex;align-items:center;gap:8px;}
.nav-cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);}
.nav-cta .icon{font-size:14px;}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;padding:12px;border-radius:8px;cursor:pointer;}
.nav-toggle span{display:block;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .15s;}
.nav-toggle[aria-expanded=true] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-nav{display:none;position:fixed;top:58px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);padding:16px 24px 24px;z-index:99;flex-direction:column;gap:4px;}
.mobile-nav.open{display:flex;animation:slideDown .3s var(--ease);}
.mobile-nav a{font-size:18px;font-weight:500;color:var(--ink);padding:12px 0;text-decoration:none;border-bottom:1px solid var(--border);cursor:pointer;}
.mobile-nav a:last-child{border-bottom:none;color:var(--green-dk);font-weight:600;}

/* ─── LAYOUT ─── */
.wrap{max-width:1200px;margin:0 auto;padding:0 28px;}
section{padding:112px 0;}
/* Tighter between thematically continuous sections */
.scenarios{padding-top:88px;}
.compare{padding-bottom:96px;}
/* Wider breathing room before identity-anchoring sections */
.features-section{padding-top:140px;}
.faq-section{padding:128px 0;}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;border-radius:100px;font-size:16px;font-weight:600;text-decoration:none;cursor:pointer;min-height:54px;white-space:nowrap;transition:transform .3s var(--spring),box-shadow .3s,background .2s;position:relative;overflow:hidden;letter-spacing:-.005em;}
.btn:focus-visible{outline:3px solid var(--green);outline-offset:3px;}
.btn::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--rx,50%) var(--ry,50%),rgba(255,255,255,.3) 0%,transparent 60%);opacity:0;transition:opacity .3s;pointer-events:none;}
.btn:active::after{opacity:1;}
.btn-primary{background:var(--ink);color:var(--white);box-shadow:var(--shadow-md);}
.btn-primary:hover{transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow-xl);}
.btn-primary:active{transform:scale(.98);}
.btn .icon{font-size:18px;}

/* ─── LABELS & HEADINGS ─── */
.label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink4);margin-bottom:18px;display:inline-flex;align-items:center;gap:10px;}
.label::before{content:'';width:18px;height:1px;background:var(--ink4);}
h2.section-title{font-family:'Instrument Serif',serif;font-size:clamp(34px,4.5vw,58px);line-height:1.04;letter-spacing:-.025em;margin-bottom:18px;}
.accent{font-style:italic;color:var(--green-dk);}

/* ─── REVEAL ─── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s var(--ease),transform .75s var(--ease);}
.reveal.in{opacity:1;transform:none;}
/* Bento cards scale up from 0.94 instead of sliding — different rhythm */
.bcard.reveal{opacity:0;transform:scale(.94) translateY(12px);transition:opacity .8s var(--ease),transform .8s var(--settle);}
.bcard.reveal.in{opacity:1;transform:scale(1) translateY(0);}
/* Steps slide in from the left one by one — reinforces the sequential "01 → 02 → 03" mental model */
.step.reveal{opacity:0;transform:translateX(-32px);transition:opacity .65s var(--ease),transform .65s var(--settle);}
.step.reveal.in{opacity:1;transform:none;}
.steps-wrap.in .step:nth-child(1){transition-delay:.05s;}
.steps-wrap.in .step:nth-child(2){transition-delay:.18s;}
.steps-wrap.in .step:nth-child(3){transition-delay:.31s;}
.steps-wrap.in .step:nth-child(4){transition-delay:.44s;}
/* Scenarios cards scale + lift — slightly different again */
.scenario.reveal{opacity:0;transform:translateY(24px) scale(.97);transition:opacity .7s var(--ease),transform .7s var(--settle);}
.scenario.reveal.in{opacity:1;transform:none;}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.40s}.d6{transition-delay:.48s}

/* ─── HERO ─── */
.hero{min-height:100vh;padding-top:68px;display:grid;grid-template-columns:1.05fr 1fr;align-items:center;gap:40px;max-width:1200px;margin:0 auto;padding-left:28px;padding-right:28px;position:relative;}
.hero::before{content:'';position:absolute;top:20%;right:-10%;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(5,150,105,.10) 0%,transparent 65%);pointer-events:none;z-index:0;animation:ambientFloat 14s ease-in-out infinite;}
.hero::after{content:'';position:absolute;bottom:5%;left:-10%;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(245,158,11,.06) 0%,transparent 65%);pointer-events:none;z-index:0;animation:ambientFloat 18s ease-in-out infinite reverse;}
@keyframes ambientFloat{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(-30px,20px) scale(1.1);}}
.hero-left{padding-right:32px;position:relative;z-index:1;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--green-bg);color:var(--green-dk);padding:7px 16px;border-radius:100px;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:28px;animation:slideDown .5s var(--spring) both;border:1px solid rgba(5,150,105,.15);position:relative;overflow:hidden;}
.hero-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;}
.hero-badge::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.6) 50%,transparent 70%);
  background-size:250% 100%;background-position:200% 0;
  animation:badgeShimmer 5.5s ease-in-out 2.5s infinite;
  pointer-events:none;
}
@keyframes badgeShimmer{
  0%,12%{background-position:200% 0;}
  28%{background-position:-100% 0;}
  100%{background-position:-100% 0;}
}
@keyframes slideDown{from{opacity:0;transform:translateY(-14px);}to{opacity:1;transform:none;}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(1.5);}}
.hero-title{font-family:'Instrument Serif',serif;font-size:clamp(44px,6.2vw,82px);line-height:1.0;letter-spacing:-.04em;margin-bottom:26px;}
.hero-title .word{display:inline-block;opacity:0;transform:translateY(28px) scale(.94);animation:wordSettle 1.1s var(--settle) forwards;will-change:transform,opacity;}
.hero-title .word.no-anim{opacity:1;transform:none;animation:none;will-change:auto;}
.hero-title .word:nth-child(1){animation-delay:.15s;}
.hero-title .word:nth-child(2){animation-delay:.27s;}
.hero-title .word:nth-child(3){animation-delay:.39s;}
.hero-title .word:nth-child(4){animation-delay:.51s;}
.hero-title .word:nth-child(5){animation-delay:.63s;}
.hero-title .accent{font-style:italic;color:var(--green-dk);position:relative;display:inline-block;}
.hero-title .accent::after{content:'';position:absolute;left:-2%;right:-2%;bottom:.08em;height:.18em;background:linear-gradient(90deg,var(--green-lt) 0%,var(--lime) 60%,var(--green-lt) 100%);opacity:.4;z-index:-1;transform-origin:left;transform:scaleX(0) skewX(-4deg);animation:underline 1.1s var(--ease) 1.1s forwards;border-radius:4px;}
@keyframes wordSettle{0%{opacity:0;transform:translateY(28px) scale(.94);}60%{opacity:1;transform:translateY(-2px) scale(1.01);}100%{opacity:1;transform:translateY(0) scale(1);}}
@keyframes underline{to{transform:scaleX(1) skewX(-4deg);}}
.hero-sub{font-size:20px;line-height:1.6;color:var(--ink3);max-width:460px;margin-bottom:40px;animation:slideUp .75s var(--ease) .7s both;}
@keyframes slideUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:none;}}
.hero-actions{display:flex;flex-direction:column;gap:16px;align-items:flex-start;animation:slideUp .75s var(--ease) .82s both;}
.hero-actions-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.cta-sub{font-family:'DM Mono',monospace;font-size:12px;color:var(--ink4);letter-spacing:.04em;display:inline-flex;align-items:center;gap:8px;}
.cta-sub .icon{color:var(--green);font-size:14px;}
.hero-stats{display:flex;gap:0;margin-top:48px;padding-top:32px;border-top:1px solid var(--border);animation:slideUp .75s var(--ease) .95s both;}
.hero-stat{
  min-width:0;
  padding:0 28px;
  border-left:1px solid var(--border);
  opacity:0;
  animation:statSettle .7s var(--ease) forwards;
}
.hero-stat:first-child{padding-left:0;border-left:none;}
.hero-stat:nth-child(1){animation-delay:1.05s;}
.hero-stat:nth-child(2){animation-delay:1.17s;}
.hero-stat:nth-child(3){animation-delay:1.29s;}
@keyframes statSettle{
  from{opacity:0;transform:translateY(10px);}
  to{opacity:1;transform:translateY(0);}
}
.hero-stat-num{font-family:'Instrument Serif',serif;font-size:44px;line-height:1;color:var(--ink);letter-spacing:-.025em;margin-bottom:6px;}
.hero-stat-unit{font-size:.48em;color:var(--ink3);margin-left:2px;font-style:italic;}
.hero-stat-num.counted{animation:statGlow .7s ease-out;}
@keyframes statGlow{
  0%{text-shadow:0 0 0 rgba(5,150,105,0);}
  40%{text-shadow:0 0 18px rgba(5,150,105,.55),0 0 4px rgba(110,231,183,.8);}
  100%{text-shadow:0 0 0 rgba(5,150,105,0);}
}
.hero-stat-zero{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:6px;
  font-family:'Instrument Serif',serif;font-size:44px;line-height:1;
  color:var(--ink);letter-spacing:-.025em;
}
.hero-stat-zero-mark{
  width:32px;height:32px;border-radius:50%;
  background:var(--green);color:var(--white);
  display:inline-grid;place-items:center;font-size:17px;
  box-shadow:0 3px 10px rgba(5,150,105,.4);
  animation:zeroCheckIn .6s var(--spring) 1.15s both;
}
@keyframes zeroCheckIn{
  from{opacity:0;transform:scale(.3) rotate(-20deg);}
  60%{opacity:1;transform:scale(1.18) rotate(6deg);}
  to{opacity:1;transform:scale(1) rotate(0);}
}
.hero-stat-zero-label{font-style:italic;color:var(--green-dk);}
.hero-stat-label{font-family:'DM Mono',monospace;font-size:11px;color:var(--ink4);letter-spacing:.14em;text-transform:uppercase;}

.hero-right{display:flex;justify-content:center;align-items:center;position:relative;height:680px;z-index:1;animation:slideUp .9s var(--ease) .35s both;}
.hero-right::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    radial-gradient(2px 2px at 8% 20%,var(--green-lt) 50%,transparent 51%),
    radial-gradient(1.5px 1.5px at 82% 12%,var(--sage) 50%,transparent 51%),
    radial-gradient(1px 1px at 70% 85%,var(--green) 50%,transparent 51%),
    radial-gradient(2px 2px at 18% 90%,var(--green-lt) 50%,transparent 51%),
    radial-gradient(1.5px 1.5px at 45% 8%,var(--sage) 50%,transparent 51%),
    radial-gradient(1px 1px at 92% 55%,var(--green) 50%,transparent 51%),
    radial-gradient(1.5px 1.5px at 5% 58%,var(--green-lt) 50%,transparent 51%);
  opacity:.45;
  animation:particleDrift 22s ease-in-out infinite;
}
@keyframes particleDrift{
  0%,100%{transform:translate(0,0) rotate(0);opacity:.45;}
  25%{transform:translate(8px,-12px) rotate(.5deg);opacity:.55;}
  50%{transform:translate(-6px,-6px) rotate(-.3deg);opacity:.4;}
  75%{transform:translate(4px,10px) rotate(.4deg);opacity:.5;}
}
.phone-stack{position:relative;width:380px;height:640px;}
.phone-stack::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:540px;height:540px;border-radius:50%;
  background:radial-gradient(circle,rgba(5,150,105,.18) 0%,rgba(132,204,22,.08) 40%,transparent 70%);
  filter:blur(24px);
  pointer-events:none;z-index:0;
  animation:phoneHalo 10s ease-in-out infinite;
}
@keyframes phoneHalo{
  0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.9;}
  50%{transform:translate(-50%,-50%) scale(1.08);opacity:1;}
}
.phone{
  position:absolute;width:290px;height:600px;border-radius:48px;
  background:var(--ink);padding:9px;
  box-shadow:
    0 48px 120px rgba(18,16,12,.28),
    0 20px 50px rgba(18,16,12,.18),
    0 0 0 1.5px rgba(18,16,12,.14),
    inset 0 1px 0 rgba(255,255,255,.05);
  transition:transform .5s var(--spring),box-shadow .4s;
  overflow:hidden;
  z-index:1;
}
.phone-inner{width:100%;height:100%;border-radius:36px;overflow:hidden;background:var(--bg);position:relative;}
/* Dynamic Island / notch */
.phone-inner .phone-notch{
  position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:86px;height:22px;border-radius:100px;
  background:var(--ink);z-index:4;
  box-shadow:0 1px 2px rgba(0,0,0,.15);
}
.phone-inner .phone-notch::before{
  content:'';position:absolute;right:10px;top:50%;transform:translateY(-50%);
  width:6px;height:6px;border-radius:50%;
  background:#1f1f1f;box-shadow:inset 0 0 0 1px rgba(255,255,255,.15);
}
/* Status bar overlay */
.phone-status{
  position:absolute;top:0;left:0;right:0;height:34px;
  padding:10px 20px 0;z-index:3;
  display:flex;align-items:center;justify-content:space-between;
  font-family:'DM Sans',sans-serif;font-size:11.5px;font-weight:600;
  color:var(--ink);letter-spacing:-.01em;pointer-events:none;
  line-height:1;
  opacity:0;
  animation:phoneWake .5s var(--ease) .95s forwards;
}
@keyframes phoneWake{
  from{opacity:0;transform:translateY(-4px);}
  to{opacity:1;transform:translateY(0);}
}
.phone-status .time{font-variant-numeric:tabular-nums;}
.phone-status .icons{display:inline-flex;align-items:center;gap:5px;}
/* signal dots */
.phone-status .signal{display:inline-flex;align-items:flex-end;gap:1.5px;height:9px;}
.phone-status .signal i{width:2px;background:var(--ink);border-radius:1px;opacity:0;animation:signalIn .35s var(--ease) forwards;}
.phone-status .signal i:nth-child(1){height:3px;animation-delay:1.1s;}
.phone-status .signal i:nth-child(2){height:5px;animation-delay:1.18s;}
.phone-status .signal i:nth-child(3){height:7px;animation-delay:1.26s;}
.phone-status .signal i:nth-child(4){height:9px;animation-delay:1.34s;}
@keyframes signalIn{from{opacity:0;transform:translateY(2px);}to{opacity:1;transform:translateY(0);}}
/* wifi arc */
.phone-status .wifi{
  width:11px;height:8px;
  border:1.5px solid var(--ink);
  border-radius:50% 50% 0 0/100% 100% 0 0;
  border-bottom:none;position:relative;
}
.phone-status .wifi::before{
  content:'';position:absolute;bottom:-1px;left:50%;
  width:2px;height:2px;border-radius:50%;background:var(--ink);
  transform:translateX(-50%);
}
/* battery pill */
.phone-status .battery{
  width:22px;height:11px;border:1.2px solid var(--ink);border-radius:3px;
  position:relative;padding:1px;display:inline-flex;
}
.phone-status .battery::after{
  content:'';position:absolute;right:-2.5px;top:3px;
  width:1.5px;height:4px;background:var(--ink);border-radius:0 1px 1px 0;
}
.phone-status .battery i{display:block;background:var(--ink);width:0;border-radius:1px;animation:batteryFill 1s var(--ease) 1.1s forwards;}
@keyframes batteryFill{to{width:82%;}}
/* Dynamic Island subtle breathing so it feels alive */
.phone-inner .phone-notch{animation:islandPulse 4.5s ease-in-out 1.7s infinite;}
@keyframes islandPulse{
  0%,100%{box-shadow:0 1px 2px rgba(0,0,0,.15);}
  50%{box-shadow:0 1px 2px rgba(0,0,0,.15),0 0 0 2px rgba(18,16,12,.08);}
}
/* Dark variant if image makes top dark — currently our app screens are light, so default ink is fine */

/* Skeleton screen behind the image — visible only if the img fails to paint */
.phone-inner::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:
    linear-gradient(180deg,var(--bg) 0%,#FAFAF8 30%,#EDEBE4 100%);
}
.phone-inner::after{
  content:'';position:absolute;top:54px;left:16px;right:16px;z-index:0;
  height:160px;
  background:
    linear-gradient(var(--bg2) 0 10px,transparent 0) 0 0/60% 10px no-repeat,
    linear-gradient(var(--bg2) 0 6px,transparent 0) 0 22px/40% 6px no-repeat,
    linear-gradient(var(--surface) 0 42px,transparent 0) 0 44px/100% 42px no-repeat,
    linear-gradient(var(--surface) 0 42px,transparent 0) 0 92px/100% 42px no-repeat,
    linear-gradient(var(--surface) 0 42px,transparent 0) 0 140px/100% 42px no-repeat;
  border-radius:6px;
  opacity:.6;
}
.phone-inner img{width:100%;height:calc(100% - 34px);object-fit:cover;object-position:top;display:block;position:absolute;top:34px;left:0;z-index:1;}
.phone-a{left:0;top:24px;--px:0px;--py:0px;transform:rotate(-7deg);z-index:1;animation:pa 1s var(--spring) .45s both,floatA 6s ease-in-out 1.6s infinite;}
.phone-b{right:0;top:0;--px:0px;--py:0px;transform:rotate(5deg);z-index:2;animation:pb 1s var(--spring) .6s both,floatB 7s ease-in-out 1.8s infinite;}
@keyframes pa{from{opacity:0;transform:rotate(-12deg) translateY(80px);}to{transform:rotate(-7deg) translate(var(--px,0),calc(24px + var(--py,0)));opacity:1;}}
@keyframes pb{from{opacity:0;transform:rotate(9deg) translateY(80px);}to{transform:rotate(5deg) translate(var(--px,0),var(--py,0));opacity:1;}}
@keyframes floatA{0%,100%{transform:rotate(-7deg) translate(var(--px,0),calc(24px + var(--py,0)));}50%{transform:rotate(-6deg) translate(var(--px,0),calc(16px + var(--py,0)));}}
@keyframes floatB{0%,100%{transform:rotate(5deg) translate(var(--px,0),var(--py,0));}50%{transform:rotate(6deg) translate(var(--px,0),calc(-8px + var(--py,0)));}}
.phone-a:hover{transform:rotate(-2deg) translateY(8px) scale(1.03);z-index:10;animation-play-state:paused;}
.phone-b:hover{transform:rotate(1deg) translateY(-10px) scale(1.03);z-index:10;animation-play-state:paused;}

.chip{position:absolute;--px:0px;--py:0px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:10px 14px;font-size:12px;font-weight:500;color:var(--ink);box-shadow:var(--shadow-md);white-space:nowrap;z-index:20;display:inline-flex;align-items:center;gap:10px;animation:chipIn .6s var(--spring) 1.4s both,floatY 5s ease-in-out 2s infinite;transition:--px .25s ease-out,--py .25s ease-out;}
.chip-b{bottom:68px;left:-36px;}
.chip-c{top:80px;right:-32px;animation-delay:1.6s,2.2s;}
.chip-d{top:44%;right:-50px;animation-delay:1.8s,2.4s;background:var(--ink);color:var(--white);border-color:var(--ink);}
.chip-d .icon{color:var(--green-lt);}
@keyframes chipIn{from{opacity:0;transform:scale(.6);}to{opacity:1;transform:scale(1);}}
@keyframes floatY{0%,100%{transform:translate(var(--px,0),calc(0px + var(--py,0)));}50%{transform:translate(var(--px,0),calc(-10px + var(--py,0)));}}
.chip .icon{font-size:14px;color:var(--ink2);}
.chip-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;flex-shrink:0;}

/* ─── HOOK ─── */
.hook{background:var(--ink);padding:88px 24px;text-align:center;position:relative;overflow:hidden;}
.hook::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(5,150,105,.12) 0%,transparent 55%),radial-gradient(circle at 70% 50%,rgba(132,204,22,.06) 0%,transparent 55%);pointer-events:none;animation:hookShift 14s ease-in-out infinite;}
@keyframes hookShift{0%,100%{opacity:1;}50%{opacity:.7;}}
.hook-clock{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:380px;height:380px;opacity:.05;pointer-events:none;stroke:var(--white);stroke-width:.8;fill:none;stroke-linecap:round;}
.hook-clock .hand{transform-origin:180px 180px;animation:tick 90s linear infinite;}
.hook-clock .hand-m{animation-duration:1080s;}
@keyframes tick{from{transform:rotate(0);}to{transform:rotate(360deg);}}
.hook p{font-family:'Instrument Serif',serif;font-style:italic;font-size:clamp(24px,3vw,36px);color:rgba(250,250,248,.78);max-width:780px;margin:0 auto;line-height:1.5;letter-spacing:-.015em;position:relative;}
.hook strong{color:var(--white);font-style:normal;font-weight:400;}
.hook-accent{color:var(--green-lt)!important;font-style:normal;font-weight:600;display:inline-block;padding:0 2px;}
.hook-count{font-family:'Instrument Serif',serif;font-style:normal;font-weight:400;color:var(--green-lt);display:inline-block;min-width:1.2em;}
.hook-cta{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:32px;
  padding:10px 20px;border-radius:100px;
  background:rgba(250,250,248,.06);color:var(--green-lt);
  border:1px solid rgba(110,231,183,.25);
  font-family:'DM Mono',monospace;font-size:12px;font-weight:500;
  text-transform:uppercase;letter-spacing:.1em;text-decoration:none;
  position:relative;z-index:1;
  transition:background .25s,transform .3s var(--spring),border-color .25s;
}
.hook-cta:hover{background:rgba(110,231,183,.12);border-color:rgba(110,231,183,.45);transform:translateY(-1px);}
.hook-cta .icon{font-size:14px;transition:transform .25s;}
.hook-cta:hover .icon{transform:translateX(3px);}

/* ─── MARQUEE ─── */
.marquee{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:26px 0;overflow:hidden;position:relative;}
.marquee::before,.marquee::after{content:'';position:absolute;top:0;bottom:0;width:140px;z-index:2;pointer-events:none;}
.marquee::before{left:0;background:linear-gradient(90deg,var(--bg2),transparent);}
.marquee::after{right:0;background:linear-gradient(270deg,var(--bg2),transparent);}
.marquee-track{display:flex;gap:44px;width:max-content;animation:marquee 50s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-item{font-family:'Instrument Serif',serif;font-style:italic;font-size:24px;color:var(--ink3);display:inline-flex;align-items:center;gap:14px;white-space:nowrap;animation:marqueeBob 3.6s ease-in-out infinite;}
.marquee-item:nth-child(odd){animation-delay:-1.8s;}
@keyframes marqueeBob{0%,100%{transform:translateY(0);}50%{transform:translateY(-4px);}}
.marquee-item .tile{font-size:22px;}
.marquee-sep{color:var(--ink4);font-size:8px;opacity:.35;align-self:center;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ─── DEMO ─── */
.demo-section{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;overflow:hidden;}
.demo-section::before{content:'';position:absolute;top:-100px;left:50%;transform:translateX(-50%);width:800px;height:400px;border-radius:50%;background:radial-gradient(ellipse,rgba(5,150,105,.06) 0%,transparent 70%);pointer-events:none;}
.demo-card{max-width:600px;margin:0 auto;background:var(--bg);border:1px solid var(--border);border-radius:28px;padding:40px;box-shadow:var(--shadow-md);position:relative;overflow:hidden;}
.demo-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent 0%,transparent 35%,var(--green-lt) 50%,transparent 65%,transparent 100%);
  background-size:200% 100%;background-position:100% 0;
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.demo-card.active::before{opacity:1;animation:shimmer 1.8s linear infinite;}
@keyframes shimmer{from{background-position:100% 0;}to{background-position:-100% 0;}}
.demo-label{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:14px;display:inline-flex;align-items:center;gap:8px;}
.demo-label::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;}
.demo-input-row{display:flex;gap:10px;margin-bottom:22px;}
.demo-input{flex:1;padding:15px 20px;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;font-family:'DM Sans',sans-serif;font-size:15px;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;}
.demo-input::placeholder{color:var(--ink4);}
.demo-input:focus{border-color:var(--ink);box-shadow:0 0 0 4px rgba(26,24,20,.07);}
.demo-btn{padding:15px 26px;background:var(--ink);color:var(--white);border:none;border-radius:14px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:transform .25s var(--spring),box-shadow .25s;display:inline-flex;align-items:center;gap:8px;}
.demo-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow);}
.demo-btn:active{transform:scale(.97);}
.demo-btn .icon{font-size:15px;}
.demo-result{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 20px;min-height:84px;display:flex;align-items:center;gap:18px;transition:all .4s var(--ease);position:relative;overflow:hidden;}
.demo-result.empty .result-tile{opacity:.45;}
.demo-result.found{border-color:var(--green-lt);background:#F0FDF4;}
.demo-result.found .result-tile{background:var(--green-bg);color:var(--green-dk);}
.demo-result.found::after{content:'';position:absolute;inset:0;border-radius:14px;background:radial-gradient(circle at 50% 50%,rgba(5,150,105,.1) 0%,transparent 70%);animation:resultFlash .8s var(--ease);pointer-events:none;}
.demo-result.found::before{
  content:'';position:absolute;top:0;left:-40%;width:40%;bottom:0;
  background:linear-gradient(90deg,transparent 0%,rgba(110,231,183,.4) 50%,transparent 100%);
  animation:scanSweep 1.1s var(--ease) forwards;
  pointer-events:none;z-index:1;
}
/* Particle burst container — absolutely positioned anchor around the result tile */
.demo-burst{
  position:absolute;left:32px;top:50%;width:0;height:0;
  pointer-events:none;z-index:5;
}
.demo-burst .p{
  position:absolute;left:0;top:0;
  width:6px;height:6px;border-radius:50%;
  background:var(--green-lt);
  opacity:0;
  transform:translate(0,0) scale(0);
}
.demo-burst.fire .p{animation:burst .9s cubic-bezier(0.22,1,0.36,1) forwards;}
@keyframes burst{
  0%{opacity:0;transform:translate(0,0) scale(.3);}
  20%{opacity:1;}
  100%{opacity:0;transform:translate(var(--tx,0),var(--ty,0)) scale(1);}
}
@keyframes scanSweep{from{left:-40%;}to{left:100%;}}
@keyframes resultFlash{from{opacity:1;}to{opacity:0;}}
.result-tile{width:44px;height:44px;border-radius:12px;background:var(--bg2);display:grid;place-items:center;font-size:22px;flex-shrink:0;transition:transform .4s var(--spring),background .3s,color .3s;color:var(--ink2);position:relative;z-index:2;}
.demo-result.found .result-tile{animation:iconPop .55s var(--spring);}
@keyframes iconPop{0%{transform:scale(.5) rotate(-15deg);}60%{transform:scale(1.2) rotate(4deg);}100%{transform:scale(1) rotate(0);}}
.result-text{position:relative;z-index:2;}
.result-text .result-name{font-size:17px;font-weight:600;color:var(--ink);margin-bottom:5px;letter-spacing:-.01em;}
.result-text .result-detail{font-size:13px;color:var(--ink3);line-height:1.5;}
.result-text .result-detail .place{
  color:var(--green);font-weight:600;position:relative;
  display:inline-block;
}
.result-text .result-detail .place.typing::after{
  content:'';display:inline-block;width:1px;height:1em;
  background:var(--green);margin-left:2px;vertical-align:-2px;
  animation:caret .7s steps(2) infinite;
}
@keyframes caret{50%{opacity:0;}}
.result-placeholder{font-size:14px;color:var(--ink4);}
.demo-chips{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap;}
.demo-chip{padding:8px 14px;background:var(--bg);border:1px solid var(--border);border-radius:100px;font-size:13px;font-weight:500;color:var(--ink2);cursor:pointer;transition:background .2s,border-color .2s,transform .25s var(--spring);display:inline-flex;align-items:center;gap:8px;}
.demo-chip:hover{background:var(--surface);border-color:var(--ink3);transform:translateY(-1px);}
.demo-chip:active{transform:scale(.96);}
.demo-chip .icon{font-size:14px;color:var(--ink3);}
.demo-note{font-size:12px;color:var(--ink4);text-align:center;margin-top:18px;font-family:'DM Mono',monospace;letter-spacing:.04em;}

/* ─── HOW IT WORKS ─── */
.steps-wrap{position:relative;margin-top:64px;}
/* Single continuous dashed connector across all steps */
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:36px;
  position:relative;
  padding-top:28px;
}
.steps::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:repeating-linear-gradient(90deg,var(--border) 0 6px,transparent 6px 12px);
  z-index:0;
}
/* Progress overlay — fills in green from left as section enters view */
.steps::after{
  content:'';position:absolute;top:0;left:0;height:2px;width:0;
  background:repeating-linear-gradient(90deg,var(--green) 0 6px,transparent 6px 12px);
  z-index:1;transition:width 1.8s var(--ease);
}
.steps-wrap.in .steps::after{width:100%;}
.step{padding:0;position:relative;z-index:1;transition:transform .4s var(--spring);background:transparent;}
/* Small node indicator on the connector above each step */
.step::before{
  content:'';position:absolute;top:-4px;left:0;
  width:10px;height:10px;border-radius:50%;
  background:var(--bg);border:2px solid var(--border);
  transition:border-color .3s,background .3s,transform .3s var(--spring);
  z-index:2;
}
.step:hover{transform:translateY(-4px);}
.step:hover::before{border-color:var(--green);background:var(--green-bg);transform:scale(1.3);}
.step.final::before{border-color:var(--green);background:var(--green-bg);}
.step-num{font-family:'Instrument Serif',serif;font-size:56px;line-height:1;color:var(--border);margin:24px 0 18px;transition:color .3s,transform .4s var(--spring);display:inline-block;}
.step:hover .step-num{color:var(--green-dk);transform:scale(1.12) translateX(4px);}
.step-tile{margin-bottom:18px;transition:transform .4s var(--spring);}
.step:hover .step-tile{transform:rotate(-6deg) scale(1.08);background:var(--green-bg);color:var(--green-dk);}
.step-title{font-size:18px;font-weight:600;margin-bottom:10px;letter-spacing:-.015em;}
.step-desc{font-size:14.5px;line-height:1.7;color:var(--ink3);}
.step.final .step-num{color:var(--green-dk);font-style:italic;}
.step.final .step-tile{background:var(--green-bg);color:var(--green-dk);animation:breathe 3.5s ease-in-out infinite;}
@keyframes breathe{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(5,150,105,.2);}50%{transform:scale(1.04);box-shadow:0 0 0 8px rgba(5,150,105,0);}}

/* ─── COMPARISON ─── */
.compare{background:var(--bg2);padding:112px 0;position:relative;overflow:hidden;}
.compare::before{content:'';position:absolute;top:-200px;right:-200px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(5,150,105,.06) 0%,transparent 70%);pointer-events:none;}
.compare-wrap{max-width:1000px;margin:0 auto;padding:0 28px;position:relative;}
.compare-header{text-align:center;margin-bottom:56px;}
.compare-grid{
  width:100%;
  background:var(--surface);border-radius:20px;overflow:hidden;
  box-shadow:var(--shadow-md);border:1px solid var(--border);
  border-collapse:collapse;
  table-layout:fixed;
}
.compare-grid thead th,
.compare-grid tbody th,
.compare-grid tbody td{padding:18px 20px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle;text-align:left;transition:background .25s;}
.compare-grid th{font-weight:inherit;}
.compare-grid tbody tr:last-child th,
.compare-grid tbody tr:last-child td{border-bottom:none;}
.compare-grid thead th{
  background:var(--bg);padding:22px 20px;
  font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink3);font-weight:500;
  border-bottom:1px solid var(--border2);
}
.compare-grid thead th.memora{
  color:var(--green-dk);
  background:linear-gradient(180deg,var(--green-bg) 0%,#BBF7D0 100%);
  font-weight:700;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5);
  position:relative;
}
.compare-grid thead th.memora::after{
  content:'';position:absolute;bottom:0;left:10%;right:10%;height:2px;
  background:var(--green);border-radius:2px;
}
.compare-grid tbody tr:hover th:not(.memora),
.compare-grid tbody tr:hover td:not(.memora){background:var(--bg);}
.compare-grid tbody tr:hover th.memora,
.compare-grid tbody tr:hover td.memora{background:rgba(134,239,172,.45);}
.compare-grid .memora{
  background:linear-gradient(180deg,rgba(187,247,208,.45) 0%,rgba(209,250,229,.35) 100%);
  font-weight:600;color:var(--ink);
  position:relative;
  box-shadow:inset 1px 0 0 rgba(5,150,105,.08),inset -1px 0 0 rgba(5,150,105,.08);
}
.compare-grid tbody tr:last-child td.memora,
.compare-grid tbody tr:last-child th.memora{
  box-shadow:inset 1px 0 0 rgba(5,150,105,.08),inset -1px 0 0 rgba(5,150,105,.08),inset 0 -1px 0 rgba(5,150,105,.08);
}
.compare-grid .compare-feature{font-weight:600;color:var(--ink);width:38%;}
/* First column (feature name) narrower on larger screens */
.compare-grid col.c-feature{width:38%;}
.compare-check{width:22px;height:22px;border-radius:50%;background:var(--green);color:var(--white);display:inline-grid;place-items:center;font-size:12px;flex-shrink:0;box-shadow:0 2px 6px rgba(5,150,105,.3);vertical-align:middle;margin-right:10px;}
.compare-check .icon svg{stroke-dasharray:22;stroke-dashoffset:22;}
.compare-grid.in .compare-check .icon svg{animation:drawCheck .6s var(--ease) forwards;}
/* Stagger check-draw by row */
.compare-grid.in tbody tr:nth-child(1) .compare-check .icon svg{animation-delay:.05s;}
.compare-grid.in tbody tr:nth-child(2) .compare-check .icon svg{animation-delay:.15s;}
.compare-grid.in tbody tr:nth-child(3) .compare-check .icon svg{animation-delay:.25s;}
.compare-grid.in tbody tr:nth-child(4) .compare-check .icon svg{animation-delay:.35s;}
.compare-grid.in tbody tr:nth-child(5) .compare-check .icon svg{animation-delay:.45s;}
.compare-grid.in tbody tr:nth-child(6) .compare-check .icon svg{animation-delay:.55s;}
@keyframes drawCheck{to{stroke-dashoffset:0;}}
.compare-x{width:22px;height:22px;border-radius:50%;background:var(--bg2);color:var(--ink4);display:inline-grid;place-items:center;font-size:12px;flex-shrink:0;vertical-align:middle;margin-right:10px;}
.compare-small{font-size:12px;color:var(--ink3);font-weight:500;margin-left:4px;}
.compare-note{font-size:16px;color:var(--ink3);text-align:center;margin-top:32px;font-style:italic;font-family:'Instrument Serif',serif;}
/* Visually-hidden utility for the empty first-col header */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* ─── FEATURES / BENTO ─── */
.features-section{background:var(--bg);position:relative;overflow:hidden;}
.features-section::before{content:'';position:absolute;top:10%;left:-10%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(5,150,105,.05) 0%,transparent 70%);pointer-events:none;animation:ambientFloat 20s ease-in-out infinite;}
.features-header{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;margin-bottom:64px;align-items:end;}
.features-header h2{margin-bottom:0;}
.features-header-desc{font-size:17px;line-height:1.65;color:var(--ink3);max-width:420px;padding-bottom:8px;}
.bento{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(180px,auto);gap:16px;}
.bcard{background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:32px;position:relative;overflow:hidden;transition:transform .4s var(--spring),border-color .3s,box-shadow .4s;display:flex;flex-direction:column;}
.bcard:hover{transform:translateY(-4px);border-color:var(--border2);box-shadow:var(--shadow-md);}
.bcard-tile{margin-bottom:auto;}
.bcard h3{font-size:19px;font-weight:600;letter-spacing:-.015em;margin-top:24px;margin-bottom:8px;}
.bcard p{font-size:14.5px;line-height:1.6;color:var(--ink3);}
.b1{grid-column:span 3;grid-row:span 2;background:var(--ink);color:var(--white);border-color:var(--ink);}
.b1 p{color:rgba(250,250,248,.65);}
.b1 .bcard-tile{background:rgba(250,250,248,.08);color:var(--green-lt);box-shadow:inset 0 0 0 1px rgba(250,250,248,.05);}
.b1 .bcard-demo{margin-top:18px;flex:1;min-height:140px;background:rgba(250,250,248,.04);border-radius:14px;padding:18px;font-family:'DM Mono',monospace;font-size:11px;color:rgba(250,250,248,.75);letter-spacing:.04em;display:flex;flex-direction:column;gap:14px;border:1px solid rgba(250,250,248,.06);position:relative;overflow:hidden;}
.bcard-demo-row{display:flex;align-items:center;gap:12px;}
.bcard-demo-row .dot{width:8px;height:8px;border-radius:50%;background:var(--green-lt);flex-shrink:0;}
.bcard-demo-row:nth-child(2) .dot{background:#FBBF24;}
.bcard-demo-row:nth-child(3) .dot{background:rgba(250,250,248,.4);}
.bcard-demo-row .label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bcard-demo-row .bar{
  flex:1;height:4px;border-radius:2px;background:rgba(250,250,248,.08);
  overflow:hidden;position:relative;
}
.bcard-demo-row .bar::after{
  content:'';position:absolute;inset:0 auto 0 0;width:0;
  background:linear-gradient(90deg,var(--green-lt),var(--lime));
  border-radius:2px;transition:width 1.4s var(--ease) .3s;
}
.bcard-demo-row:nth-child(2) .bar::after{background:linear-gradient(90deg,#FBBF24,#F59E0B);transition-delay:.5s;}
.bcard-demo-row:nth-child(3) .bar::after{background:rgba(250,250,248,.4);transition-delay:.7s;}
.b1.in .bcard-demo-row:nth-child(1) .bar::after{width:92%;}
.b1.in .bcard-demo-row:nth-child(2) .bar::after{width:81%;}
.b1.in .bcard-demo-row:nth-child(3) .bar::after{width:67%;}
.bcard-demo-row .pct{color:rgba(250,250,248,.55);min-width:30px;text-align:right;}

.b2{grid-column:span 3;background:var(--green-bg);border-color:rgba(5,150,105,.15);color:var(--green-dk);}
.b2 p{color:#047857;}
.b2 .bcard-tile{background:rgba(5,150,105,.12);color:var(--green-dk);}
.b2-map{position:absolute;right:-20px;bottom:-30px;opacity:.22;width:240px;height:180px;pointer-events:none;}
.b2-map .route{stroke-dasharray:240;stroke-dashoffset:240;}
.b2.in .b2-map .route{animation:drawRoute 2.4s var(--ease) forwards;}
@keyframes drawRoute{to{stroke-dashoffset:0;}}
.b2-map .endpoint{transform-origin:150px 50px;animation:endpointPulse 2.2s ease-in-out 2.2s infinite;}
@keyframes endpointPulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.35);opacity:.75;}}
.b2-pulse{position:absolute;top:28px;right:28px;width:10px;height:10px;border-radius:50%;background:var(--green-dk);}
.b2-pulse::before,.b2-pulse::after{content:'';position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--green-dk);animation:pulseRing 2.4s ease-out infinite;}
.b2-pulse::after{animation-delay:1.2s;}
@keyframes pulseRing{0%{transform:scale(1);opacity:.8;}100%{transform:scale(3.5);opacity:0;}}

.b3{grid-column:span 3;position:relative;}
.b4{grid-column:span 2;}
.b5{grid-column:span 2;}
.b6{grid-column:span 2;}
.b7{
  grid-column:span 3;
  background:linear-gradient(135deg,var(--ink) 0%,#1c1a15 100%);
  border-color:rgba(255,255,255,.06);
  color:var(--white);
}
.b7 h3{color:var(--white);}
.b7 p{color:rgba(250,250,248,.65);}
.b7 .bcard-tile{background:rgba(255,255,255,.06);color:var(--green-lt);box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);}
.b7 .bcard-visual{margin-top:18px;display:flex;align-items:center;justify-content:center;flex:1;min-height:80px;position:relative;}
.b7::after{
  content:'';position:absolute;inset:-20%;
  background:radial-gradient(circle at 85% 50%,rgba(110,231,183,.12) 0%,transparent 50%);
  pointer-events:none;
}
.b7 > *{position:relative;z-index:1;}
.b7 .lock-ring{
  width:88px;height:88px;border-radius:50%;
  background:conic-gradient(from 0deg,var(--green-dk) 0deg,var(--green-lt) 90deg,var(--sage) 180deg,var(--green-dk) 270deg,var(--green-dk) 360deg);
  padding:2px;
  display:grid;place-items:center;position:relative;
  animation:spin 12s linear infinite;
  box-shadow:0 12px 32px rgba(5,150,105,.35),inset 0 0 0 1px rgba(255,255,255,.15),0 0 24px rgba(110,231,183,.25);
}
.b7 .lock-ring::before{
  content:'';position:absolute;inset:2px;border-radius:50%;
  background:#1c1a15;
}
.b7 .lock-ring::after{content:'';position:absolute;inset:-22px;border-radius:50%;border:1px dashed rgba(110,231,183,.3);opacity:.8;animation:spin 24s linear infinite reverse;}
.b7 .lock-tile{background:var(--green-dk);color:var(--green-lt);font-size:22px;position:relative;z-index:1;animation:spin 12s linear infinite reverse;box-shadow:0 4px 12px rgba(5,150,105,.4),inset 0 1px 0 rgba(255,255,255,.15);}
@keyframes spin{to{transform:rotate(360deg);}}

.bt-wave{position:absolute;top:28px;right:28px;display:flex;gap:4px;align-items:flex-end;height:20px;}
.bt-wave i{width:3px;border-radius:2px;background:var(--green);opacity:.3;animation:bwave 1.4s ease-in-out infinite;}
.bt-wave i:nth-child(1){height:6px;animation-delay:0s;}
.bt-wave i:nth-child(2){height:12px;animation-delay:.15s;}
.bt-wave i:nth-child(3){height:18px;animation-delay:.3s;}
.bt-wave i:nth-child(4){height:12px;animation-delay:.45s;}
.bt-wave i:nth-child(5){height:6px;animation-delay:.6s;}
@keyframes bwave{0%,100%{opacity:.25;transform:scaleY(.7);}50%{opacity:1;transform:scaleY(1.1);}}

/* ─── FAQ ─── */
.faq-section{background:var(--bg2);}
.faq-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start;}
.faq-heading h2{margin-bottom:20px;}
.faq-heading p{font-size:16px;color:var(--ink3);line-height:1.6;max-width:340px;}
.faq-email{color:var(--green-dk);font-weight:600;text-decoration:none;border-bottom:1px solid rgba(5,150,105,.3);transition:border-color .2s,color .2s;}
.faq-email:hover{color:var(--green);border-bottom-color:var(--green);}
.faq-list{display:flex;flex-direction:column;gap:4px;}
.faq-item{border-top:1px solid var(--border2);transition:background .25s;}
.faq-item:last-child{border-bottom:1px solid var(--border2);}
.faq-item.open{background:linear-gradient(180deg,rgba(209,250,229,.25) 0%,transparent 100%);}
.faq-q{width:100%;text-align:left;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:24px;font-size:17px;font-weight:500;color:var(--ink);letter-spacing:-.01em;cursor:pointer;transition:color .25s,font-weight .25s;}
.faq-q:hover{color:var(--green-dk);}
.faq-item.open .faq-q{color:var(--green-dk);font-weight:600;}
.faq-q-icon{width:32px;height:32px;border-radius:50%;background:var(--surface);display:grid;place-items:center;flex-shrink:0;transition:background .25s,transform .4s var(--spring),color .25s;color:var(--ink2);border:1px solid var(--border);}
.faq-item.open .faq-q-icon{background:var(--ink);color:var(--green-lt);border-color:var(--ink);transform:rotate(45deg);}
.faq-q-icon .icon{font-size:14px;}
/* Smooth expand using grid-template-rows trick */
.faq-a{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows .45s var(--ease);
}
.faq-a-inner{overflow:hidden;}
.faq-item.open .faq-a{grid-template-rows:1fr;}
.faq-a p{font-size:15px;line-height:1.75;color:var(--ink3);padding:0 56px 24px 0;}

/* ─── SCENARIOS / USE CASES ─── */
.scenarios{background:var(--bg);position:relative;overflow:hidden;}
.scenarios::before{
  content:'';position:absolute;top:20%;right:-10%;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(5,150,105,.06) 0%,transparent 65%);
  pointer-events:none;animation:ambientFloat 18s ease-in-out infinite;
}
.scenarios-header{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:72px;align-items:end;
}
.scenarios-header h2{margin-bottom:0;}
.scenarios-desc{font-size:17px;line-height:1.65;color:var(--ink3);max-width:440px;padding-bottom:8px;}
.scenarios-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;position:relative;z-index:1;}
.scenario{
  background:var(--surface);border:1px solid var(--border);
  border-radius:22px;padding:36px 36px 32px;
  position:relative;overflow:hidden;
  transition:transform .5s var(--spring),border-color .35s,box-shadow .4s;
}
.scenario:hover{transform:translateY(-4px);border-color:var(--border2);box-shadow:var(--shadow-md);}
.scenario::before{
  content:'';position:absolute;top:0;left:0;width:0;height:3px;
  background:linear-gradient(90deg,var(--green),var(--green-lt));
  transition:width .6s var(--ease);
}
.scenario:hover::before{width:100%;}
.scenario-num{
  font-family:'DM Mono',monospace;font-size:11px;color:var(--ink4);
  letter-spacing:.14em;
  display:block;margin-bottom:16px;
  transition:color .3s;
}
.scenario:hover .scenario-num{color:var(--green-dk);}
.scenario h3{font-size:20px;font-weight:600;letter-spacing:-.02em;margin-bottom:12px;line-height:1.25;}
.scenario p{font-size:15px;line-height:1.7;color:var(--ink3);}
@media(max-width:900px){
  .scenarios-header{grid-template-columns:1fr;gap:24px;}
  .scenarios-grid{grid-template-columns:1fr;gap:20px;}
  .scenario{padding:28px 28px 26px;}
}

/* ─── PRIVACY BLOCK ─── */
.privacy-block{
  background:linear-gradient(135deg,var(--green-bg) 0%,#E6FBF1 50%,#DCFCE7 100%);
  background-size:200% 200%;
  animation:privShift 18s ease-in-out infinite,privBreathe 6s ease-in-out infinite;
  border-radius:28px;padding:76px 80px;margin:0 28px;display:grid;grid-template-columns:auto 1fr;gap:56px;align-items:center;position:relative;overflow:hidden;border:1px solid rgba(5,150,105,.1);
}
@keyframes privShift{0%,100%{background-position:0% 50%;}50%{background-position:100% 50%;}}
@keyframes privBreathe{
  0%,100%{box-shadow:0 0 0 0 rgba(5,150,105,0);}
  50%{box-shadow:0 0 42px 4px rgba(5,150,105,.12),0 0 0 1px rgba(5,150,105,.08);}
}
.privacy-block::before{content:'';position:absolute;top:-50px;right:-50px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(5,150,105,.18) 0%,transparent 70%);pointer-events:none;animation:ambientFloat 14s ease-in-out infinite;}
.privacy-block::after{content:'';position:absolute;right:-40px;bottom:-40px;width:240px;height:240px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23065F46' stroke-width='1.2' stroke-linecap='round' stroke-linejoin='round' opacity='0.06'><rect x='5' y='11' width='14' height='10' rx='2'/><path d='M8 11V7a4 4 0 0 1 8 0v4'/><circle cx='12' cy='16' r='1.4'/></svg>");background-size:contain;background-repeat:no-repeat;pointer-events:none;animation:privRock 5s ease-in-out infinite;}
@keyframes privRock{0%,100%{transform:rotate(-6deg);}50%{transform:rotate(6deg);}}
.privacy-tile{
  width:104px;height:104px;border-radius:26px;
  background:linear-gradient(135deg,var(--green-dk) 0%,#047857 100%);
  color:var(--green-lt);
  display:grid;place-items:center;font-size:48px;
  box-shadow:0 16px 40px rgba(5,150,105,.25),inset 0 1px 0 rgba(255,255,255,.12);
  animation:rock 4s ease-in-out infinite,lockBreathe 5s ease-in-out infinite;
}
@keyframes rock{0%,100%{transform:rotate(-4deg);}50%{transform:rotate(4deg);}}
@keyframes lockBreathe{0%,100%{box-shadow:0 16px 40px rgba(5,150,105,.25),inset 0 1px 0 rgba(255,255,255,.12),0 0 0 0 rgba(5,150,105,.25);}50%{box-shadow:0 16px 40px rgba(5,150,105,.35),inset 0 1px 0 rgba(255,255,255,.12),0 0 0 14px rgba(5,150,105,0);}}
.privacy-block h2{font-family:'Instrument Serif',serif;font-size:clamp(28px,3.4vw,44px);letter-spacing:-.025em;color:var(--green-dk);margin-bottom:14px;line-height:1.1;}
.privacy-block p{font-size:17px;line-height:1.65;color:#047857;margin-bottom:18px;max-width:540px;}
.privacy-tagline{font-size:22px;font-weight:700;color:var(--green-dk);margin-bottom:18px!important;font-family:'Instrument Serif',serif;font-style:italic;}
.privacy-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--green-dk);padding:10px 20px;background:rgba(255,255,255,.55);border-radius:100px;cursor:pointer;transition:background .2s,transform .25s var(--spring);text-decoration:none;border:1px solid rgba(5,150,105,.2);position:relative;z-index:1;}
.privacy-link:hover{background:var(--white);transform:translateY(-1px);}
.privacy-link .arrow{transition:transform .2s;}
.privacy-link:hover .arrow{transform:translateX(3px);}
.privacy-link:focus-visible{outline:3px solid var(--green);outline-offset:4px;}

/* ─── CTA — dark landing that creates visual rhythm before the footer ─── */
.cta-section{
  text-align:center;position:relative;padding:150px 0;overflow:hidden;
  background:var(--ink);color:var(--white);
}
.cta-section::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:780px;height:780px;border-radius:50%;
  background:radial-gradient(circle,rgba(5,150,105,.22) 0%,rgba(132,204,22,.08) 40%,transparent 70%);
  pointer-events:none;animation:ambientFloat 9s ease-in-out infinite;
}
.cta-section::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120' fill='none' stroke='%236EE7B7' stroke-width='1' stroke-linecap='round' stroke-linejoin='round' opacity='0.08'><circle cx='20' cy='20' r='4'/><path d='M23 17l5-5'/><rect x='60' y='60' width='14' height='10' rx='1.5'/><path d='M62 60v-3a2 2 0 0 1 4 0v3'/><path d='M90 20l5 5'/><circle cx='93' cy='90' r='3'/></svg>");
  background-size:180px 180px;
  mask-image:radial-gradient(ellipse at center,rgba(0,0,0,.9) 0%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at center,rgba(0,0,0,.9) 0%,transparent 70%);
}
.cta-section > *{position:relative;z-index:1;}
.cta-section .label{color:var(--green-lt);}
.cta-section .label::before{background:var(--green-lt);}
.cta-section h2{font-family:'Instrument Serif',serif;font-size:clamp(42px,5.8vw,82px);letter-spacing:-.04em;margin-bottom:20px;line-height:1.0;color:var(--white);}
.cta-section h2 em{font-style:italic;color:var(--green-lt);}
.cta-section .cta-desc{font-size:20px;color:rgba(250,250,248,.65);max-width:480px;margin:0 auto 44px;line-height:1.5;}
/* CTA button on dark: invert to white background */
.cta-section .btn-primary{background:var(--white);color:var(--ink);}
.cta-section .btn-primary:hover{background:var(--green-bg);color:var(--green-dk);}
.cta-sub2{font-family:'DM Mono',monospace;font-size:12px;color:rgba(250,250,248,.55);margin-top:22px;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;}
.cta-sub2 span{display:inline-flex;align-items:center;gap:6px;}
.cta-sub2 span .icon{color:var(--green-lt);font-size:14px;}
.cta-glow{position:relative;display:inline-block;}
.cta-glow::after{
  content:'';position:absolute;inset:-14px;border-radius:100px;
  background:radial-gradient(circle,rgba(110,231,183,.45) 0%,rgba(132,204,22,.2) 60%,transparent 100%);
  filter:blur(28px);
  opacity:.4;
  transition:opacity .5s;pointer-events:none;z-index:-1;
  animation:ctaBreathe 3.2s ease-in-out infinite;
}
.cta-glow:hover::after{opacity:1;animation-play-state:paused;}
@keyframes ctaBreathe{0%,100%{opacity:.3;transform:scale(.96);}50%{opacity:.7;transform:scale(1.04);}}

/* ─── FOOTER ─── */
.footer{border-top:1px solid var(--border);padding:56px 0 40px;background:var(--bg);position:relative;}
.footer-inner{max-width:1200px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;}
.footer-logo{font-family:'Instrument Serif',serif;font-size:22px;color:var(--ink);text-decoration:none;cursor:pointer;display:inline-flex;align-items:center;gap:10px;}
.footer-links{display:flex;gap:32px;}
.footer-links a{font-size:13px;color:var(--ink4);text-decoration:none;cursor:pointer;transition:color .15s;}
.footer-links a:hover{color:var(--ink);}
.footer-copy{font-size:13px;color:var(--ink4);font-family:'DM Mono',monospace;letter-spacing:.02em;}
.footer-updated{color:var(--ink4);opacity:.7;margin-left:6px;}

/* ─── PRIVACY PAGE ─── */
.pp-page{background:var(--bg);}
.pp-hero{background:var(--ink);padding:120px 28px 80px;text-align:center;position:relative;overflow:hidden;}
.pp-hero::before{content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(5,150,105,.2) 0%,transparent 70%);pointer-events:none;animation:ambientFloat 12s ease-in-out infinite;}
.pp-hero::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 30%,rgba(110,231,183,.06) 0%,transparent 40%),radial-gradient(circle at 80% 70%,rgba(245,158,11,.04) 0%,transparent 40%);pointer-events:none;}
.pp-hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(5,150,105,.18);color:#6EE7B7;padding:7px 16px;border-radius:100px;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:28px;border:1px solid rgba(110,231,183,.25);position:relative;z-index:1;}
.pp-hero-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:#6EE7B7;animation:pulse 2s infinite;}
.pp-hero h1{font-family:'Instrument Serif',serif;font-size:clamp(40px,5.5vw,68px);line-height:1.04;letter-spacing:-.03em;color:var(--white);margin-bottom:24px;position:relative;z-index:1;}
.pp-hero-sub{font-size:20px;line-height:1.6;color:rgba(250,250,248,.65);max-width:500px;margin:0 auto 36px;position:relative;z-index:1;}
.pp-hero-hook{display:inline-block;background:rgba(5,150,105,.22);border:1px solid rgba(110,231,183,.35);border-radius:12px;padding:14px 24px;font-family:'DM Mono',monospace;font-size:13px;font-weight:500;color:#6EE7B7;letter-spacing:.04em;position:relative;z-index:1;}
.pp-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;border-bottom:1px solid var(--border);background:var(--border);}
.pp-sum-card{background:var(--surface);padding:36px 32px;text-align:center;transition:background .25s;position:relative;overflow:hidden;}
.pp-sum-card::after{content:'';position:absolute;bottom:-30px;right:-30px;width:80px;height:80px;border-radius:50%;background:var(--green-bg);opacity:0;transform:scale(0);transition:opacity .3s,transform .5s var(--spring);}
.pp-sum-card:hover{background:#FDFCFA;}
.pp-sum-card:hover::after{opacity:1;transform:scale(1);}
.pp-sum-tile{margin:0 auto 16px;}
.pp-sum-card:hover .pp-sum-tile{transform:scale(1.1) rotate(-5deg);background:var(--green-bg);color:var(--green-dk);}
.pp-sum-title{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:8px;letter-spacing:-.01em;position:relative;}
.pp-sum-desc{font-size:13.5px;line-height:1.6;color:var(--ink3);position:relative;}
.pp{max-width:760px;margin:0 auto;padding:80px 28px 104px;}
.pp-back{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--ink3);cursor:pointer;margin-bottom:56px;transition:color .2s,gap .25s var(--spring),background .2s;text-decoration:none;padding:8px 14px;margin-left:-14px;border-radius:8px;}
.pp-back::before{content:'←';font-size:16px;}
.pp-back:hover{color:var(--ink);gap:12px;background:var(--bg2);}
.pp-back:focus-visible{outline:3px solid var(--green);outline-offset:4px;border-radius:8px;}
.pp-sec{margin-bottom:56px;}
.pp-num{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:8px;display:inline-flex;align-items:center;gap:10px;}
.pp-num::before{content:'';width:14px;height:1px;background:var(--green);}
.pp-sec h2{font-family:'Instrument Serif',serif;font-size:28px;font-weight:400;letter-spacing:-.02em;margin-bottom:18px;color:var(--ink);line-height:1.15;}
.pp-sec h2 em{font-style:italic;color:var(--ink3);}
.pp-body{font-size:16px;line-height:1.8;color:var(--ink3);}
.pp-body p{margin-bottom:16px;}
.pp-body p:last-child{margin-bottom:0;}
.pp-body ul{margin:16px 0;display:flex;flex-direction:column;gap:14px;}
.pp-body li{display:flex;gap:14px;align-items:flex-start;}
.pp-body li::before{
  content:'';flex-shrink:0;margin-top:10px;
  width:6px;height:6px;border-radius:50%;
  background:var(--green);
}
.pp-body strong{color:var(--ink);font-weight:600;}
.pp-sub{font-size:15px;font-weight:700;color:var(--ink);margin:28px 0 12px;font-family:'DM Sans',sans-serif;}
.pp-callout{background:var(--green-bg);border-left:3px solid var(--green);border-radius:0 14px 14px 0;padding:18px 22px;margin:20px 0;font-size:14.5px;color:#047857;line-height:1.7;}
.pp-callout strong{color:var(--green-dk);}
.pp-hr{border:none;border-top:1px solid var(--border);margin:56px 0;}
.pp-cta{background:linear-gradient(135deg,var(--green-bg) 0%,#E6FBF1 100%);border-radius:24px;padding:56px 48px;text-align:center;margin-top:64px;position:relative;overflow:hidden;border:1px solid rgba(5,150,105,.12);}
.pp-cta::before{content:'';position:absolute;top:-50px;right:-50px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(5,150,105,.18) 0%,transparent 70%);}
.pp-cta h3{font-family:'Instrument Serif',serif;font-size:clamp(24px,3vw,36px);letter-spacing:-.02em;color:var(--green-dk);margin-bottom:12px;position:relative;}
.pp-cta p{font-size:16px;color:#047857;margin-bottom:28px;line-height:1.6;position:relative;}
.pp-cta .btn{background:var(--green-dk);color:var(--white);position:relative;}
.pp-cta .btn:hover{opacity:.9;}

/* ─── RESPONSIVE ─── */
@media(max-width:1080px){
  .hero{gap:20px;}.hero-left{padding-right:16px;}.chip-d{right:-20px;}
  .bento{grid-template-columns:repeat(4,1fr);}
  .b1,.b2,.b3,.b7{grid-column:span 4;}
  .b1{grid-row:span 2;}
  .b4,.b5,.b6{grid-column:span 2;}
  .features-header{grid-template-columns:1fr;gap:24px;}
  .steps{grid-template-columns:repeat(2,1fr);gap:40px;}
  .steps-line{display:none;}
}
@media(max-width:992px){
  .nav-links{display:none;}.nav-toggle{display:flex;}
  .privacy-block{grid-template-columns:1fr;text-align:center;padding:56px 40px;margin:0 20px;gap:32px;}
  .privacy-tile{margin:0 auto;}
  .faq-grid{grid-template-columns:1fr;gap:40px;}
  .compare-grid thead th,.compare-grid tbody th,.compare-grid tbody td{padding:14px 14px;font-size:13px;}
  .hero-stats{gap:20px;}
}
@media(max-width:768px){
  .steps{grid-template-columns:1fr;gap:0;position:relative;padding-left:44px;}
  /* Vertical timeline bar on the left */
  .steps::before{
    content:'';position:absolute;top:10px;bottom:10px;left:18px;width:2px;
    background:repeating-linear-gradient(180deg,var(--border) 0 6px,transparent 6px 12px);
    z-index:0;
  }
  .step{border-top:none;padding-top:0;padding-bottom:36px;position:relative;}
  .step:last-child{padding-bottom:0;}
  /* Small node dot on the timeline, aligned with the step number */
  .step::before{
    content:'';position:absolute;left:-32px;top:18px;
    width:14px;height:14px;border-radius:50%;
    background:var(--bg);border:2px solid var(--border);
    transition:border-color .3s,background .3s,transform .3s var(--spring);
  }
  .step:hover::before,
  .step.final::before{border-color:var(--green);background:var(--green-bg);transform:scale(1.15);}
  .step.final::before{animation:breathe 3.5s ease-in-out infinite;}
  .step-num{font-size:48px;margin-bottom:12px;}
  .hero{grid-template-columns:1fr;padding-top:96px;min-height:auto;padding-bottom:56px;text-align:center;}
  .hero-left{padding-right:0;}
  .hero-sub,.hero-actions{max-width:100%;}
  .hero-actions{align-items:center;}
  .hero-stats{justify-content:center;flex-wrap:wrap;}
  .hero-right{height:480px;}
  .phone-stack{width:300px;height:460px;}
  .phone{width:230px;height:460px;}
  .bento{grid-template-columns:1fr;}
  .b1,.b2,.b3,.b4,.b5,.b6,.b7{grid-column:span 1;grid-row:auto;}
  section{padding:80px 0;}
  .compare-grid thead th,.compare-grid tbody th,.compare-grid tbody td{padding:12px 10px;font-size:12.5px;}
  .compare-grid thead th{font-size:10px;padding:14px 10px;}
  .demo-card{padding:28px;}
  .marquee-item{font-size:20px;}
  .marquee-item .tile{font-size:20px;}
  .privacy-block{padding:44px 28px;}
  .cta-section{padding:100px 0;}
  .pp-summary{grid-template-columns:1fr;}
  .pp-hero{padding:100px 24px 56px;}
  .pp-cta{padding:40px 28px;}
}
@media(max-width:480px){
  .chip-c,.chip-d{display:none;}
  .hero-actions-row{flex-direction:column;align-items:center;width:100%;}
  .hero-actions-row .btn,.hero-actions-row .cta-glow{width:100%;}
  .hero-actions-row .btn{justify-content:center;}
  .footer-inner{flex-direction:column;text-align:center;}
  .footer-links{flex-wrap:wrap;justify-content:center;gap:20px;}
  .privacy-block{padding:36px 24px;}
  .cta-sub2{flex-direction:column;gap:8px;}
  .hero-stats{gap:0;padding-top:24px;margin-top:32px;}
  .hero-stat{padding:0 18px;}
  .hero-stat-num,.hero-stat-zero{font-size:30px;}
  .hero-stat-zero-mark{width:24px;height:24px;font-size:13px;}
}
