/* ============================================================
   Providr — NDIS care platform
   Light lavender canvas · violet accent · Plus Jakarta Sans
   Tokens lifted from the Providr brand guidelines
   ============================================================ */
:root{
  /* brand palette */
  --bg:#f3f2fb;            /* lavender canvas */
  --bg-soft:#fbfaff;
  --surface:#ffffff;
  --ink:#211f54;           /* headlines & logo */
  --ink-2:#3c3a63;
  --ink-soft:#6c6a88;      /* body copy */
  --ink-faint:#9a98b6;
  --line:#e8e6f7;
  --line-2:#ddd9f2;

  --primary:#5e3bee;       /* violet */
  --primary-2:#7c5cff;
  --primary-dk:#4a2bd0;
  --primary-soft:#ece9ff;
  --coral:#ff7a59;
  --good:#2bb673;

  --font:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;

  --r:18px;
  --r-card:22px;
  --r-sec:40px;
  --ease:cubic-bezier(.16,1,.3,1);
  --sh-1:0 18px 44px -22px rgba(45,40,90,.16);
  --sh-2:0 24px 60px -30px rgba(94,59,238,.24);
  --sh-pri:0 16px 34px -12px rgba(94,59,238,.5);

  --pad:clamp(20px,5vw,80px);
  --maxw:1240px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;border:0 solid}
html{scroll-behavior:smooth;background:var(--bg);font-size:16px;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink-soft);
  font-family:var(--font);
  font-weight:400;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:clip;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{color:var(--ink);font-weight:800;letter-spacing:-.02em;line-height:1.05}

/* ───────── shared bits ───────── */
/* eyebrow = brand "chip" bubble (ref: brand-guide .traits pill) */
.eyebrow{font-family:var(--font);font-size:.72rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:.55em;line-height:1;
  background:var(--primary-soft);color:var(--primary-dk);padding:7px 13px;border-radius:50rem}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--primary)}
/* on dark / photo / violet grounds: solid white bubble so it stands out */
.eyebrow.light{background:#fff;color:var(--primary-dk);
  box-shadow:0 8px 24px -10px rgba(0,0,0,.5)}
.eyebrow.light::before{background:var(--primary)}
.eyebrow.center{justify-content:center}
.arr{display:inline-block;transition:transform .35s var(--ease)}
.btn:hover .arr,.nav-cta:hover .arr,.ps-cta:hover .arr{transform:translateX(4px)}

/* ───────── buttons ───────── */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:700;font-size:.94rem;letter-spacing:-.01em;
  padding:.85em 1.55em;border-radius:50rem;
  transition:transform .4s var(--ease),background .3s var(--ease),box-shadow .4s var(--ease),color .3s;
  white-space:nowrap;cursor:pointer;
}
.btn:hover{transform:translateY(-2px)}
.btn-pri{background:var(--primary);color:#fff;box-shadow:var(--sh-pri)}
.btn-pri:hover{background:var(--primary-dk);box-shadow:0 22px 44px -14px rgba(94,59,238,.6)}
.btn-light{background:#fff;color:var(--ink);box-shadow:var(--sh-2)}
.btn-light:hover{box-shadow:0 26px 56px -20px rgba(0,0,0,.4)}
.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--line-2)}
.btn-outline:hover{border-color:var(--primary);background:var(--primary-soft);box-shadow:none}
.btn-ghost-light{background:rgba(255,255,255,.08);color:#fff;
  border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(6px)}
.btn-ghost-light:hover{background:rgba(255,255,255,.16)}

/* ───────── nav ───────── */
.nav{position:fixed;inset:0 0 auto;z-index:60;transform:translateZ(0)}
.nav-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:18px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{font-weight:800;font-size:1.5rem;letter-spacing:-.03em;color:#fff;line-height:1;
  transition:color .3s var(--ease)}
.brand span{color:var(--primary-2);transition:color .3s var(--ease)}
.nav.scrolled .brand{color:var(--ink)}
.nav.scrolled .brand span{color:var(--primary)}
/* floating frosted pill — dark frost over the hero, light frost once the sheet rises over it */
.nav-pill{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  display:flex;align-items:center;gap:10px;padding:6px 6px 6px 14px;border-radius:999px;
  background:rgba(18,13,42,.32);border:1px solid rgba(255,255,255,.16);
  -webkit-backdrop-filter:blur(16px) saturate(150%);backdrop-filter:blur(16px) saturate(150%);
  box-shadow:0 12px 36px -22px rgba(10,8,30,.7);
  transition:background .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease)}
.nav.scrolled .nav-pill{background:rgba(255,255,255,.88);border-color:rgba(20,15,50,.09);
  box-shadow:0 16px 40px -16px rgba(45,40,90,.5)}
.nav-links{display:flex;gap:2px;font-size:.92rem;font-weight:500}
.nav-links a{color:rgba(255,255,255,.86);padding:.5em .9em;border-radius:999px;
  transition:color .25s,background .25s}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.12)}
.nav.scrolled .nav-links a{color:var(--ink-soft)}
.nav.scrolled .nav-links a:hover{color:var(--primary);background:rgba(94,59,238,.08)}
.nav-cta{font-size:.85rem;padding:.64em 1.15em}
.nav-toggle{display:none;background:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.nav-toggle span{width:22px;height:2px;background:#fff;display:block;transition:.3s var(--ease)}
.nav.scrolled .nav-toggle span{background:var(--ink)}

/* ───────── mobile menu — full-screen violet takeover ───────── */
.mobile-menu{position:fixed;inset:0;z-index:50;display:flex;flex-direction:column;justify-content:center;
  gap:clamp(22px,4vh,40px);padding:max(92px,13vh) clamp(28px,8vw,72px) clamp(40px,7vh,72px);
  background:linear-gradient(165deg,#2a2560 0%,#171336 100%);overflow:hidden;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .45s var(--ease),visibility .45s var(--ease)}
body.menu-open .mobile-menu{opacity:1;visibility:visible;pointer-events:auto}
.mm-glow{position:absolute;top:-12%;right:-18%;width:75%;height:62%;border-radius:50%;pointer-events:none;
  background:radial-gradient(ellipse,rgba(124,92,255,.5),transparent 66%);filter:blur(44px)}
.mm-links{position:relative;display:flex;flex-direction:column;gap:clamp(4px,1.2vh,12px)}
.mm-links a{display:inline-block;width:max-content;color:#fff;font-weight:800;letter-spacing:-.03em;line-height:1.06;
  font-size:clamp(2.4rem,11vw,3.6rem);
  opacity:0;transform:translateY(26px);
  transition:opacity .5s var(--ease),transform .5s var(--ease),color .25s}
.mm-links a span{position:relative}
.mm-links a span::after{content:"";position:absolute;left:0;bottom:.06em;height:2px;width:0;
  background:var(--primary-2);transition:width .35s var(--ease)}
.mm-links a:hover{color:var(--primary-2)}
.mm-links a:hover span::after{width:100%}
.mm-cta{position:relative;align-self:flex-start;margin-top:clamp(10px,2vh,22px);
  opacity:0;transform:translateY(26px);transition:opacity .5s var(--ease) .34s,transform .5s var(--ease) .34s,box-shadow .4s}
.mm-foot{position:absolute;left:clamp(28px,8vw,72px);bottom:clamp(26px,5vh,48px);
  display:flex;align-items:center;gap:9px;color:rgba(255,255,255,.55);font-size:.82rem}
.mm-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;background:linear-gradient(150deg,#7c5cff,#4a2bd0)}
/* staggered reveal on open */
body.menu-open .mm-links a,body.menu-open .mm-cta{opacity:1;transform:none}
body.menu-open .mm-links a:nth-child(1){transition-delay:.12s}
body.menu-open .mm-links a:nth-child(2){transition-delay:.19s}
body.menu-open .mm-links a:nth-child(3){transition-delay:.26s}
@media(min-width:901px){.mobile-menu{display:none}}

/* open state: lock scroll, morph burger → X, keep nav bar white over the menu */
body.menu-open{overflow:hidden}
body.menu-open .nav{background:transparent!important;backdrop-filter:none!important;
  box-shadow:none!important;border-bottom-color:transparent!important}
body.menu-open .nav .brand{color:#fff}
body.menu-open .nav .brand span{color:var(--primary-2)}
body.menu-open .nav .nav-toggle span{background:#fff}
body.menu-open .nav-toggle span:first-child{transform:translateY(3.5px) rotate(45deg)}
body.menu-open .nav-toggle span:last-child{transform:translateY(-3.5px) rotate(-45deg)}

/* ───────── hero ───────── */
/* main holds its own stacking context (below the nav) so the sticky hero can
   never composite above the fixed nav */
#top{position:relative;z-index:1}
/* hero PINS (sticky) and the white sheet scrolls up over it — see .sheet z-index */
.hero{position:sticky;top:0;min-height:100svh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  padding:140px var(--pad) clamp(70px,12vh,130px);
  overflow:hidden;isolation:isolate}
.hero-media{position:absolute;inset:0;z-index:-1;background:#000;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 30%}
@keyframes slowZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;
  /* ONE even tint across the whole hero — no gradient, no banding, no two-tone.
     Brand violet-black so white copy stays legible on any video frame. */
  background:rgba(16,11,44,.52);}
.hero-content{max-width:820px}
.hero-title{font-weight:800;letter-spacing:-.035em;line-height:1;
  font-size:clamp(3rem,8vw,6rem);color:#fff;margin-top:1rem;
  text-shadow:0 4px 50px rgba(0,0,0,.35)}
.hero-title span{display:block}
.hero-sub{margin:1.5rem auto 2.3rem;max-width:48ch;font-size:clamp(1.02rem,1.4vw,1.2rem);
  color:rgba(255,255,255,.86);font-weight:400;line-height:1.7}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%)}
.hero-scroll span{display:block;width:1px;height:46px;background:linear-gradient(#fff,transparent);
  animation:scrollPulse 2.4s var(--ease) infinite}
@keyframes scrollPulse{0%{opacity:0;transform:scaleY(.3) translateY(-10px)}40%{opacity:.9}100%{opacity:0;transform:scaleY(1) translateY(14px)}}

/* hero load cascade */
.reveal-line{opacity:0;transform:translateY(26px);filter:blur(6px);
  animation:rise 1s var(--ease) forwards}
.hero-content .reveal-line:nth-child(1){animation-delay:.1s}
.hero-title .reveal-line:nth-child(1){animation-delay:.22s}
.hero-title .reveal-line:nth-child(2){animation-delay:.36s}
.hero-sub.reveal-line{animation-delay:.55s}
.hero-actions.reveal-line{animation-delay:.72s}
@keyframes rise{to{opacity:1;transform:translateY(0);filter:blur(0)}}

/* ───────── sheet ───────── */
.sheet{background:var(--surface);position:relative;z-index:2;margin-top:-1px;
  border-radius:var(--r-sec) var(--r-sec) 0 0;padding:clamp(70px,11vw,150px) var(--pad);
  box-shadow:0 -30px 80px -60px rgba(45,40,90,.3);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.02'/%3E%3C/svg%3E");}
.sheet > section{max-width:var(--maxw);margin-inline:auto}
.sheet > section + section{margin-top:clamp(48px,6vw,96px)}

.display{font-weight:800;letter-spacing:-.03em;line-height:1.02;
  font-size:clamp(2.4rem,5.4vw,4.2rem);color:var(--ink)}
.display.light{color:#fff}

/* ===== device — light Providr UI (shared by scrolly + gallery) ===== */
.phone{position:relative;z-index:1;width:clamp(256px,30vw,310px);aspect-ratio:310/640;
  background:linear-gradient(160deg,#2a2550,#171336);border-radius:44px;padding:11px;
  box-shadow:0 60px 100px -45px rgba(45,30,110,.55),0 8px 26px -10px rgba(45,30,110,.4),
    inset 0 0 0 1.5px rgba(255,255,255,.1)}
.phone-notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:3;
  width:100px;height:24px;background:#171336;border-radius:0 0 16px 16px}
.phone-glow{position:absolute;top:50%;left:50%;width:min(620px,86vw);height:560px;
  transform:translate(-50%,-50%);z-index:-1;
  background:radial-gradient(ellipse at center,rgba(124,92,255,.34),rgba(94,59,238,.12) 45%,transparent 70%);
  filter:blur(46px);border-radius:50%}
.phone-screen{position:relative;width:100%;height:100%;overflow:hidden;border-radius:34px;
  background:linear-gradient(180deg,#fbfaff,#f1eefb);color:var(--ink);font-size:.78rem}
.screen{position:absolute;inset:0;padding:40px 16px 16px;display:flex;flex-direction:column;
  opacity:0;transform:translateY(10px) scale(.99);
  transition:opacity .55s var(--ease),transform .55s var(--ease)}
.screen.is-active{opacity:1;transform:none}
.ps-top{display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;color:var(--ink-faint);font-size:.72rem;font-weight:600}
.ps-dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 10px rgba(43,182,115,.7)}
.ps-label{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-faint);margin:2px 0 8px}
.ps-row{display:flex;align-items:center;gap:10px;padding:9px 8px;border-radius:12px;
  background:#fff;border:1px solid var(--line);margin-bottom:7px;box-shadow:var(--sh-1)}
.ps-av{width:26px;height:26px;border-radius:8px;flex:0 0 auto;display:grid;place-items:center;
  color:#fff;font-weight:700;font-size:.72rem}
.ps-av.a1{background:linear-gradient(150deg,#7c5cff,#4a2bd0)}
.ps-av.a2{background:linear-gradient(150deg,#ff9f85,#ff7a59)}
.ps-av.a3{background:linear-gradient(150deg,#3ecf8e,#2bb673)}
.ps-name{display:flex;flex-direction:column;font-weight:700;color:var(--ink);font-size:.78rem;line-height:1.2}
.ps-name em{font-style:normal;font-weight:500;color:var(--ink-faint);font-size:.66rem;margin-top:2px}
.ps-claim{font-weight:700;color:var(--ink);font-size:.76rem}
.ps-tag{margin-left:auto;font-size:.58rem;font-weight:700;letter-spacing:.04em;border-radius:50rem;padding:3px 9px}
.ps-tag.ok{background:var(--primary-soft);color:var(--primary-dk)}
.ps-tag.ready{background:rgba(43,182,115,.16);color:#1c8a55}
.ps-tag.flag{background:rgba(255,122,89,.16);color:#d8542f}
.ps-week{display:flex;justify-content:space-between;margin:2px 0 10px}
.ps-week b{width:24px;height:24px;display:grid;place-items:center;border-radius:8px;font-size:.64rem;
  font-weight:700;color:var(--ink-faint);background:#fff;border:1px solid var(--line)}
.ps-week b.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.ps-stats{display:flex;flex-direction:column;gap:8px;margin-top:2px}
.ps-stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 14px;box-shadow:var(--sh-1)}
.ps-stat b{display:block;font-size:1.5rem;font-weight:800;color:var(--primary-dk);letter-spacing:-.02em;line-height:1.1}
.ps-stat span{font-size:.64rem;color:var(--ink-faint);font-weight:600}
.ps-cta{margin-top:auto;display:flex;align-items:center;justify-content:center;gap:.5em;
  background:var(--primary);color:#fff;font-weight:700;font-size:.78rem;
  padding:12px;border-radius:14px;box-shadow:var(--sh-pri)}

/* ===== pinned-phone scrollytelling ===== */
/* base (no-JS / mobile): stacked & readable */
.scrolly{position:relative}
.scrolly-stage{display:flex;flex-direction:column;align-items:center;gap:48px}
.scrolly-phone{position:relative;display:flex;align-items:center;justify-content:center}
.scrolly-copy{width:100%;max-width:var(--maxw);margin:0 auto;display:flex;flex-direction:column;gap:80px}
.step{display:flex}
.step-inner{width:100%;max-width:46ch}
.step .eyebrow{margin-bottom:1rem}
.step-title{font-weight:800;letter-spacing:-.025em;line-height:1.05;
  font-size:clamp(2rem,4.4vw,3.4rem);color:var(--ink)}
.step-body{margin-top:1.1rem;font-size:1.05rem;color:var(--ink-soft);line-height:1.6;max-width:42ch}
.scrolly-rail{display:none}

/* pinned (desktop, JS-enabled) */
.scrolly.is-pinned{height:440vh}
.scrolly.is-pinned .scrolly-stage{position:sticky;top:0;height:100svh;overflow:hidden;
  display:block;gap:0}
.scrolly.is-pinned .scrolly-phone{position:absolute;inset:0;z-index:2}
.scrolly.is-pinned .scrolly-copy{position:absolute;inset:0;z-index:3;max-width:var(--maxw);
  display:block;pointer-events:none}
.scrolly.is-pinned .step{position:absolute;inset:0;align-items:center;padding:0 clamp(24px,4vw,64px);
  opacity:0;transform:translateY(26px);filter:blur(4px);
  transition:opacity .6s var(--ease),transform .6s var(--ease),filter .6s var(--ease)}
.scrolly.is-pinned .step.left{justify-content:flex-start}
.scrolly.is-pinned .step.right{justify-content:flex-end}
.scrolly.is-pinned .step.right .step-inner{text-align:right}
.scrolly.is-pinned .step.right .eyebrow{flex-direction:row-reverse}
.scrolly.is-pinned .scrolly-phone .phone{width:clamp(238px,22vw,290px)}
.scrolly.is-pinned .step-inner{width:min(30%,320px);max-width:320px}
.scrolly.is-pinned .step.is-active{opacity:1;transform:none;filter:none}
.scrolly.is-pinned .scrolly-rail{display:flex;position:absolute;left:50%;bottom:clamp(20px,4vh,46px);
  transform:translateX(-50%);z-index:4;gap:8px}
.scrolly-rail span{width:24px;height:3px;border-radius:2px;background:var(--line-2);transition:.45s var(--ease)}
.scrolly-rail span.is-active{background:var(--primary);width:36px}

/* ===== horizontal card gallery ===== */
/* base (no-JS / mobile): native horizontal swipe */
.gallery{position:relative}
.gallery-stage{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scrollbar-width:none}
.gallery-stage::-webkit-scrollbar{display:none}
.gallery-track{display:flex;gap:clamp(16px,2vw,26px);padding:0 var(--pad);align-items:stretch}
.gallery-head{flex:0 0 clamp(240px,24vw,340px);display:flex;flex-direction:column;
  justify-content:center;scroll-snap-align:start}
.gallery-head .eyebrow{margin-bottom:1rem}
.gallery-title{font-weight:800;letter-spacing:-.025em;line-height:1.05;
  font-size:clamp(1.9rem,3.6vw,2.9rem);color:var(--ink)}
.gallery-hint{margin-top:1.2rem;font-family:var(--mono);font-size:.78rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-faint);display:flex;align-items:center;gap:.5em}
.gallery-hint .arr{animation:nudge 1.6s var(--ease) infinite}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(5px)}}
.gcard{flex:0 0 clamp(280px,30vw,400px);height:clamp(420px,78vh,660px);scroll-snap-align:start;
  border-radius:var(--r-card);overflow:hidden;position:relative;display:flex;flex-direction:column;
  box-shadow:var(--sh-2)}
.gcard .eyebrow{margin-bottom:.8rem}
.gcard h3{font-weight:800;letter-spacing:-.02em;font-size:clamp(1.35rem,2.2vw,1.7rem);
  margin-bottom:.55rem;color:inherit}
.gcard p{font-size:.98rem;font-weight:400;line-height:1.55}
.gcard-photo{justify-content:flex-end;color:#fff}
.gcard-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 32%}
.gcard-photo.no-img{background:linear-gradient(150deg,#7c5cff,#4a2bd0)}
.gcard-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(36,22,90,.04) 25%,rgba(24,15,60,.85))}
.gcard-photo .gcard-body{position:relative;padding:clamp(22px,2.4vw,32px)}
.gcard-photo p{color:rgba(255,255,255,.88)}
.gcard-light{background:linear-gradient(165deg,var(--primary-soft),#fff);color:var(--ink);
  border:1px solid var(--line);padding:clamp(24px,2.6vw,34px);gap:16px;justify-content:flex-start}
.gcard-light p{color:var(--ink-soft)}
.gcard-violet{background:linear-gradient(160deg,var(--primary-2),var(--primary-dk));color:#fff;
  padding:clamp(24px,2.6vw,34px);gap:16px;justify-content:flex-start}
.gcard-violet p{color:rgba(255,255,255,.85)}
.gcard-ui{flex:1;display:flex;align-items:flex-end;justify-content:center;min-height:140px;overflow:hidden}
.gcard-week{margin-top:auto;display:flex;justify-content:space-between;gap:6px}
.gcard-week b{flex:1;aspect-ratio:1;display:grid;place-items:center;border-radius:10px;
  font-size:.8rem;font-weight:700;color:rgba(255,255,255,.7);background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18)}
.gcard-week b.on{background:#fff;color:var(--primary-dk);border-color:#fff}
.gstats{width:100%;display:flex;flex-direction:column;gap:8px}
.gstat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;
  display:flex;align-items:baseline;gap:10px;box-shadow:var(--sh-1)}
.gstat b{font-size:1.5rem;font-weight:800;color:var(--primary-dk);letter-spacing:-.02em}
.gstat span{font-size:.78rem;color:var(--ink-faint);font-weight:600}

/* shared mini-phone (used in gallery) */
.mini-phone{width:min(96%,300px);background:#fff;border-radius:18px 18px 0 0;
  padding:18px 16px 22px;border:1px solid var(--line);border-bottom:0;
  box-shadow:0 -14px 50px -22px rgba(94,59,238,.32);transform:translateY(8px)}
.mp-h{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-faint);margin-bottom:10px}
.mp-row{display:flex;align-items:center;gap:10px;padding:9px 0;color:var(--ink);
  font-size:.82rem;font-weight:600;border-bottom:1px solid var(--line)}
.mp-id{flex:1}
.mp-row em{font-style:normal;font-size:.6rem;font-weight:700;letter-spacing:.03em;border-radius:50rem;padding:3px 9px}
.mp-row em.ready{background:rgba(43,182,115,.16);color:#1c8a55}
.mp-row em.flag{background:rgba(255,122,89,.16);color:#d8542f}
.mp-row.flagged{color:var(--ink-2)}
.mp-total{margin-top:12px;font-size:.78rem;font-weight:700;color:var(--primary-dk)}

/* pinned (desktop, JS-enabled): vertical scroll drives horizontal track */
.gallery.is-pinned .gallery-stage{position:sticky;top:0;height:100svh;overflow:hidden;
  display:flex;align-items:center;scroll-snap-type:none}
.gallery.is-pinned .gallery-track{will-change:transform}
.gallery.is-pinned .gcard,.gallery.is-pinned .gallery-head{scroll-snap-align:none}

/* ===== real app screenshots ===== */
/* phone scrollytelling: real mobile screens fill the device */
.screen{padding:0}
.screen img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}

/* gallery: real desktop screenshot cards */
.gcard-shot{flex:0 0 clamp(330px,52vw,640px);height:clamp(400px,64vh,560px);
  background:#fff;border:1px solid var(--line);box-shadow:var(--sh-2);overflow:hidden;color:var(--ink)}
.gcard-shot .shot{flex:1;min-height:0;overflow:hidden;background:#f3f1fb;border-bottom:1px solid var(--line)}
.gcard-shot .shot img{width:100%;height:100%;object-fit:cover;object-position:top left;display:block}
.gcard-shot .gcard-body{padding:clamp(20px,2vw,30px)}
.gcard-shot .eyebrow{color:var(--primary);margin-bottom:.55rem}
.gcard-shot h3{color:var(--ink)}
.gcard-shot p{color:var(--ink-soft)}

/* ===== why providr / one platform ===== */
.platform-grid{display:grid;grid-template-columns:1.05fr 1.1fr;gap:clamp(32px,5vw,72px);align-items:center}
.platform-copy .eyebrow{margin-bottom:1rem}
.platform-copy h3{font-weight:800;letter-spacing:-.025em;line-height:1.05;
  font-size:clamp(2rem,4.2vw,3.2rem);color:var(--ink)}
.platform-lead{margin-top:1.1rem;font-size:1.06rem;color:var(--ink-soft);line-height:1.7;max-width:54ch}
.platform-points{list-style:none;margin:1.7rem 0 2rem;display:flex;flex-direction:column;gap:15px}
.platform-points li{display:flex;gap:13px;font-size:1rem;color:var(--ink-soft);line-height:1.5}
.platform-points b{color:var(--ink);font-weight:700}
.pp-ico{flex:0 0 auto;width:26px;height:26px;border-radius:8px;display:grid;place-items:center;margin-top:1px;
  background:var(--primary-soft);color:var(--primary)}
.pp-ico svg{width:15px;height:15px}
.shot-frame{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#fff;
  box-shadow:0 50px 90px -50px rgba(45,30,110,.5),0 12px 30px -16px rgba(45,30,110,.28)}
.sf-bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:#f4f2fb;border-bottom:1px solid var(--line)}
.sf-bar i{width:10px;height:10px;border-radius:50%;background:var(--line-2);flex:0 0 auto}
.shot-frame img{width:100%;height:auto;display:block}
@media(max-width:860px){.platform-grid{grid-template-columns:1fr;gap:34px}}

/* ===== pricing ===== */
.pricing{text-align:center}
.pricing .eyebrow{margin-bottom:1rem}
.pricing-title{font-weight:800;letter-spacing:-.025em;font-size:clamp(2rem,4.2vw,3.2rem);color:var(--ink)}
.pricing-sub{margin:1rem auto 0;max-width:52ch;color:var(--ink-soft);font-weight:400}
.bill-toggle{display:inline-flex;align-items:center;gap:13px;margin-top:1.8rem;flex-wrap:wrap;justify-content:center}
.bt-label{font-weight:700;color:var(--ink);font-size:.98rem}
.bt-switch{width:54px;height:30px;border-radius:50rem;background:var(--line-2);position:relative;cursor:pointer;
  transition:background .3s var(--ease);flex:0 0 auto}
.pricing.is-yearly .bt-switch{background:var(--primary)}
.bt-knob{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;
  box-shadow:0 2px 6px rgba(45,30,110,.3);transition:transform .3s var(--ease)}
.pricing.is-yearly .bt-knob{transform:translateX(24px)}
.bt-badge{font-family:var(--font);font-size:.72rem;font-weight:700;letter-spacing:.01em;
  background:rgba(43,182,115,.14);color:#1c8a55;padding:6px 11px;border-radius:50rem}
.pricing-setup{margin-top:1rem;font-size:.9rem;color:var(--ink-faint)}
.tier-grid{margin-top:clamp(40px,5vw,60px);display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,1.8vw,22px);text-align:left;align-items:start}
.tier{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:clamp(26px,2.4vw,34px);display:flex;flex-direction:column;box-shadow:var(--sh-1);position:relative}
/* most-popular card: inverted (violet) so it stands out */
.tier-pop{background:linear-gradient(165deg,var(--primary-2),var(--primary-dk));border:none;color:#fff;
  box-shadow:0 44px 92px -36px rgba(94,59,238,.62)}
.tier-pop .tier-top h3{color:#fff}
.tier-pop .tier-for{color:rgba(255,255,255,.72)}
.tier-pop .tier-amt b{color:#fff}
.tier-pop .tier-amt i{color:rgba(255,255,255,.72)}
.tier-pop .tier-was{color:rgba(255,255,255,.55)}
.tier-pop .tier-note{color:rgba(255,255,255,.8)}
.tier-pop .tier-save{color:#9bf3c6}
.tier-pop .tier-feats li{color:rgba(255,255,255,.9)}
.tier-pop .tier-feats li::before{background:rgba(255,255,255,.2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/11px no-repeat}
.tier-pop .tier-cta{background:#fff;color:var(--primary-dk);box-shadow:0 16px 34px -12px rgba(0,0,0,.3)}
.tier-pop .tier-cta:hover{background:#fff;color:var(--primary);box-shadow:0 22px 46px -14px rgba(0,0,0,.42)}
.tier-flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:#fff;color:var(--primary-dk);font-family:var(--font);font-size:.66rem;font-weight:700;
  letter-spacing:.03em;text-transform:uppercase;padding:6px 14px;border-radius:50rem;white-space:nowrap;
  box-shadow:0 14px 30px -10px rgba(0,0,0,.4)}
.tier-top h3{font-size:1.4rem;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.tier-for{color:var(--ink-faint);font-size:.9rem;margin-top:2px}
.tier-price{margin:1.3rem 0 1.5rem;min-height:98px}
.tier-amt{display:flex;align-items:baseline;gap:7px;flex-wrap:wrap}
.tier-was{text-decoration:line-through;color:var(--ink-faint);font-weight:700;font-size:1.35rem;display:none}
.pricing.is-yearly .tier-was{display:inline}
.tier-amt b{font-size:clamp(2.4rem,3.6vw,3rem);font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1}
.tier-amt i{font-style:normal;color:var(--ink-faint);font-weight:600;font-size:1rem}
.tier-note{color:var(--ink-soft);font-size:.9rem;margin-top:.45rem}
.tier-save{display:none;color:var(--good);font-weight:700;font-size:.86rem;margin-top:.35rem}
.pricing.is-yearly .tier-save{display:block}
.tier-cta{justify-content:center;margin-bottom:1.4rem}
.tier-feats{list-style:none;display:flex;flex-direction:column;gap:11px}
.tier-feats li{display:flex;gap:10px;align-items:flex-start;color:var(--ink-soft);font-size:.95rem;line-height:1.4}
.tier-feats li::before{content:"";flex:0 0 auto;width:18px;height:18px;margin-top:1px;border-radius:50%;
  background:var(--primary-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235e3bee' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/11px no-repeat}
@media(max-width:820px){.tier-grid{grid-template-columns:1fr;max-width:420px;margin-inline:auto}}

/* ===== sub pages (contact): nav forced to light/ink (no hero behind it) ===== */
body.page-sub .nav .brand{color:var(--ink)}
body.page-sub .nav .brand span{color:var(--primary)}
body.page-sub .nav-pill{background:rgba(255,255,255,.9);border-color:rgba(20,15,50,.09);
  box-shadow:0 16px 40px -18px rgba(45,40,90,.4)}
body.page-sub .nav-links a{color:var(--ink-soft)}
body.page-sub .nav-links a:hover{color:var(--primary);background:rgba(94,59,238,.08)}
body.page-sub .nav-toggle span{background:var(--ink)}

/* ===== contact page ===== */
.contact-main{max-width:var(--maxw);margin:0 auto;padding:clamp(112px,16vh,168px) var(--pad) clamp(56px,8vw,100px)}
.contact-head{text-align:center;max-width:620px;margin:0 auto clamp(38px,5vw,58px)}
.contact-head .eyebrow{margin-bottom:1rem}
.contact-title{font-weight:800;letter-spacing:-.03em;line-height:1.02;font-size:clamp(2.6rem,6vw,4rem);color:var(--ink)}
.contact-sub{margin-top:1rem;color:var(--ink-soft);font-size:1.08rem}
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(20px,2.4vw,32px);align-items:start}
.contact-info{background:linear-gradient(165deg,#2a2560,#171336);color:#fff;border-radius:var(--r-card);
  padding:clamp(28px,3vw,44px);position:relative;overflow:hidden}
.ci-ico{width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.1);display:grid;
  place-items:center;color:#fff;margin-bottom:1.4rem}
.ci-ico svg{width:24px;height:24px}
.contact-info h2{color:#fff;font-size:clamp(1.5rem,2.4vw,2rem);font-weight:800;letter-spacing:-.02em}
.contact-info > p{color:rgba(255,255,255,.72);margin:.8rem 0 1.6rem;line-height:1.6;font-weight:400}
.contact-info .btn-outline{color:#fff;border-color:rgba(255,255,255,.4)}
.contact-info .btn-outline:hover{background:rgba(255,255,255,.12);border-color:#fff}
.ci-meta{margin-top:2.2rem;display:flex;flex-direction:column;gap:18px}
.ci-meta p{display:flex;flex-direction:column;gap:2px}
.ci-meta b{color:#fff;font-weight:700}
.ci-meta span{color:rgba(255,255,255,.6);font-size:.9rem}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:clamp(24px,3vw,40px);box-shadow:var(--sh-1)}
.plan-note{display:none;background:var(--primary-soft);color:var(--primary-dk);
  border-radius:12px;padding:12px 16px;margin-bottom:1.4rem;font-size:.92rem;line-height:1.55}
.plan-note b{font-weight:700}
.plan-note b{font-weight:700}
.contact-form{display:flex;flex-direction:column;gap:16px}
/* anti-spam honeypot: pushed off-screen (not display:none, so bots still fill it) and hidden from assistive tech */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden}
.cf-captcha{margin-top:.2rem}
.cf-err{display:none;color:#c0392b;font-size:.9rem;margin:-.4rem 0 0;font-weight:600}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cf-field{display:flex;flex-direction:column;gap:7px}
.cf-field > span{font-size:.82rem;font-weight:700;color:var(--ink)}
.cf-field input,.cf-field textarea{font-family:var(--font);font-size:.98rem;color:var(--ink);width:100%;
  background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:13px 15px;
  transition:border-color .25s,box-shadow .25s;resize:vertical}
.cf-field input::placeholder,.cf-field textarea::placeholder{color:var(--ink-faint)}
.cf-field input:focus,.cf-field textarea:focus{outline:none;border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(94,59,238,.12)}
.cf-submit{justify-content:center;margin-top:.4rem}
.form-done{display:none;text-align:center;padding:clamp(20px,3vw,40px) 0}
.fd-ico{width:60px;height:60px;margin:0 auto 1.2rem;border-radius:50%;display:grid;place-items:center;
  background:rgba(43,182,115,.14);color:var(--good)}
.fd-ico svg{width:30px;height:30px}
.form-done h3{font-size:1.5rem;color:var(--ink)}
.form-done p{margin:.6rem auto 1.4rem;color:var(--ink-soft);max-width:38ch}
.social-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,22px);margin-top:clamp(20px,2.4vw,32px)}
.soc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:clamp(22px,2.4vw,30px);box-shadow:var(--sh-1)}
.soc-ico{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:var(--primary-soft);color:var(--primary);margin-bottom:1.1rem}
.soc-ico svg{width:22px;height:22px}
.soc-card h3{font-size:1.1rem;color:var(--ink);margin-bottom:.4rem}
.soc-card p{color:var(--ink-soft);font-size:.92rem;margin-bottom:1.2rem;line-height:1.5;font-weight:400}
@media(max-width:820px){
  .contact-grid{grid-template-columns:1fr}
  .social-cards{grid-template-columns:1fr}
  .cf-row{grid-template-columns:1fr}
}

/* ===== stats / confidence strip ===== */
.stats{text-align:center}
.stats > .eyebrow{margin-bottom:clamp(28px,3vw,40px)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,24px)}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:clamp(22px,2.4vw,32px);box-shadow:var(--sh-1);text-align:left}
.stat b{display:block;font-size:clamp(1.9rem,3.2vw,2.7rem);font-weight:800;color:var(--primary-dk);
  letter-spacing:-.02em;line-height:1;margin-bottom:.7rem}
.stat span{color:var(--ink-soft);font-size:.95rem;line-height:1.5;font-weight:400}
@media(max-width:820px){.stats-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.stats-grid{grid-template-columns:1fr}}

/* ===== how it works ===== */
.howto{text-align:center}
.howto .eyebrow{margin-bottom:1rem}
.howto-title{font-weight:800;letter-spacing:-.025em;font-size:clamp(2rem,4.2vw,3.2rem);color:var(--ink)}
.howto-sub{margin:1rem auto 0;max-width:52ch;color:var(--ink-soft);font-weight:400}
.howto-steps{margin-top:clamp(40px,5vw,60px);display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(18px,2.2vw,28px);text-align:left}
.step-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:clamp(26px,2.6vw,36px);box-shadow:var(--sh-1)}
.step-num{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:13px;
  background:linear-gradient(150deg,var(--primary-2),var(--primary-dk));color:#fff;font-weight:800;
  font-size:1.1rem;box-shadow:var(--sh-pri);margin-bottom:1.1rem}
.step-card h3{font-size:1.25rem;color:var(--ink);margin-bottom:.5rem}
.step-card p{color:var(--ink-soft);line-height:1.55;font-weight:400}
@media(max-width:760px){.howto-steps{grid-template-columns:1fr}}

/* ===== doc / legal / about pages ===== */
.doc-main{max-width:860px;margin:0 auto;padding:clamp(112px,16vh,168px) var(--pad) clamp(56px,8vw,100px)}
.doc-head{margin-bottom:clamp(34px,5vw,52px)}
.doc-head .eyebrow{margin-bottom:1rem}
.doc-title{font-weight:800;letter-spacing:-.03em;line-height:1.04;font-size:clamp(2.4rem,5.4vw,3.6rem);color:var(--ink)}
.doc-meta{margin-top:1rem;color:var(--ink-faint);font-size:.92rem}
.doc-lead{margin-top:1.1rem;color:var(--ink-soft);font-size:1.15rem;line-height:1.6}
.prose{color:var(--ink-soft);font-size:1.05rem;line-height:1.75}
.prose h2{color:var(--ink);font-size:clamp(1.35rem,2.4vw,1.75rem);margin:2.4rem 0 .8rem;
  letter-spacing:-.02em;font-weight:800}
.prose p{margin-bottom:1rem}
.prose ul{margin:0 0 1.1rem 1.15rem;display:flex;flex-direction:column;gap:.55rem}
.prose li{padding-left:.25rem}
.prose a{color:var(--primary);font-weight:600}
.prose a:hover{text-decoration:underline}
.prose b,.prose strong{color:var(--ink);font-weight:700}
.doc-note{background:var(--primary-soft);border:1px solid var(--line);border-radius:14px;
  padding:16px 20px;margin:2.4rem 0 0;color:var(--ink-soft);font-size:.95rem;line-height:1.6}

/* about page */
.about-main .doc-head{text-align:center}
.about-story{max-width:720px;margin:0 auto}
.about-values{margin:clamp(40px,5vw,64px) auto 0;max-width:920px;display:grid;
  grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,22px)}
.av-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:clamp(24px,2.6vw,32px);box-shadow:var(--sh-1)}
.av-card h3{font-size:1.2rem;color:var(--ink);margin-bottom:.5rem}
.av-card p{color:var(--ink-soft);line-height:1.6;font-weight:400}
.about-cta{text-align:center;margin-top:clamp(44px,6vw,72px)}
.about-cta h2{font-weight:800;letter-spacing:-.025em;font-size:clamp(1.8rem,3.6vw,2.6rem);
  color:var(--ink);margin-bottom:1.4rem}
.about-cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
@media(max-width:680px){.about-values{grid-template-columns:1fr}}

/* privacy */
.privacy-inner{background:linear-gradient(155deg,#2a2560,#1a1640);color:#fff;
  border-radius:var(--r-sec);padding:clamp(40px,6vw,82px);position:relative;overflow:hidden;
  box-shadow:0 50px 100px -55px rgba(45,30,110,.7)}
.privacy-inner::before{content:"";position:absolute;top:-40%;left:-10%;width:60%;height:120%;
  background:radial-gradient(ellipse,rgba(124,92,255,.4),transparent 65%);filter:blur(30px)}
.privacy-copy{position:relative;z-index:2;max-width:520px}
.privacy-copy .eyebrow{margin-bottom:1rem}
.privacy-copy h3{font-weight:800;letter-spacing:-.025em;font-size:clamp(2rem,4.2vw,3.2rem);
  margin-bottom:1.1rem;color:#fff}
.privacy-copy p{font-size:1.06rem;font-weight:400;color:rgba(255,255,255,.78);line-height:1.7;max-width:46ch}
.privacy-lock{position:absolute;right:clamp(-30px,-2vw,10px);bottom:-12%;width:clamp(230px,32vw,430px);
  color:rgba(255,255,255,.08);z-index:1}
.privacy-lock svg{width:100%;height:auto}

/* testimonials */
.quotes{text-align:center}
.quotes .eyebrow{margin-bottom:1rem}
.quotes-title{font-weight:800;letter-spacing:-.025em;font-size:clamp(2rem,4.2vw,3.2rem);color:var(--ink)}
.quotes-sub{margin:1rem auto 0;max-width:48ch;color:var(--ink-soft);font-weight:400}
.quotes-grid{margin-top:clamp(40px,6vw,72px);display:grid;
  grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);text-align:left}
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:clamp(24px,2.6vw,34px);display:flex;flex-direction:column;gap:16px;box-shadow:var(--sh-1)}
.stars{color:var(--coral);font-size:.95rem;letter-spacing:.12em}
.quote blockquote{font-size:1.06rem;font-weight:500;line-height:1.55;color:var(--ink);flex:1;letter-spacing:-.01em}
.quote figcaption{font-size:.78rem;letter-spacing:.03em;color:var(--ink-faint);font-weight:500;
  display:flex;align-items:center;gap:8px}
.quote figcaption::before{content:"";width:18px;height:1px;background:var(--line-2)}
/* review marquee — auto-scrolling wall of testimonials (like the reference review section) */
.quotes-marquee{position:relative;width:100vw;margin-left:calc(50% - 50vw);
  margin-top:clamp(40px,6vw,72px);overflow:hidden;text-align:left;
  -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.qm-track{display:flex;width:max-content;gap:clamp(16px,2vw,24px);
  padding:16px clamp(12px,1.5vw,22px);animation:qmScroll 46s linear infinite;will-change:transform}
.quotes-marquee:hover .qm-track{animation-play-state:paused}
.qm-card{flex:0 0 clamp(290px,28vw,360px);margin:0}
@keyframes qmScroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}

/* faq */
.faq{max-width:880px;text-align:center}
.faq .eyebrow{margin-bottom:1rem}
.faq-title{font-weight:800;letter-spacing:-.025em;font-size:clamp(2rem,4.2vw,3.2rem);
  color:var(--ink);margin-bottom:clamp(34px,5vw,56px)}
.faq-list{text-align:left}
.faq-item{border-top:1px solid var(--line-2)}
.faq-item:last-child{border-bottom:1px solid var(--line-2)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 8px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  font-size:clamp(1rem,1.7vw,1.2rem);font-weight:700;color:var(--ink);transition:color .25s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--primary)}
.faq-i{position:relative;flex:0 0 auto;width:15px;height:15px}
.faq-i::before,.faq-i::after{content:"";position:absolute;background:var(--primary);transition:.35s var(--ease)}
.faq-i::before{top:7px;left:0;width:15px;height:2px}
.faq-i::after{left:7px;top:0;height:15px;width:2px}
.faq-item[open] .faq-i::after{transform:rotate(90deg);opacity:0}
.faq-a{overflow:hidden;display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s var(--ease)}
.faq-item[open] .faq-a{grid-template-rows:1fr}
.faq-a > p{overflow:hidden;min-height:0;padding:0 8px;color:var(--ink-soft);
  font-weight:400;font-size:1.02rem;line-height:1.7;max-width:64ch;
  opacity:0;transition:opacity .4s ease .1s,padding .35s var(--ease)}
.faq-item[open] .faq-a > p{opacity:1;padding:0 8px 26px}

/* ───────── final cta ───────── */
/* solid backing so the CTA's rounded corners reveal lavender (the section above),
   never the dark pinned hero peeking through behind it */
.cta-wrap{position:relative;z-index:2;background:var(--surface);margin-top:-1px}
.cta{position:relative;z-index:2;text-align:center;overflow:hidden;isolation:isolate;
  padding:clamp(90px,16vw,180px) var(--pad);
  border-radius:var(--r-sec) var(--r-sec) 0 0;background:#3a25a8}
.cta-media{position:absolute;inset:0;overflow:hidden;border-radius:var(--r-sec) var(--r-sec) 0 0}
.cta-media img{width:100%;height:100%;object-fit:cover;object-position:50% 45%;transform:scale(1.16);will-change:transform}
.cta-overlay{position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(30,18,75,.62) 0%,rgba(36,22,90,.42) 42%,rgba(26,16,66,.78) 100%),
    radial-gradient(120% 100% at 50% 48%,transparent 30%,rgba(20,12,52,.55) 100%)}
.cta-content{position:relative;z-index:1;max-width:680px;margin-inline:auto}
.cta-content .eyebrow{margin-bottom:1rem}
.cta-sub{margin:1.2rem auto 2.2rem;color:rgba(255,255,255,.85);font-weight:400;font-size:1.12rem;max-width:46ch}

/* ───────── footer ───────── */
.footer{background:var(--ink);color:#fff;padding:clamp(56px,8vw,90px) var(--pad) 40px}
.footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:1.7fr repeat(3,1fr) 1.2fr;gap:40px 30px;
  padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand .brand{font-size:1.8rem;color:#fff}
.footer-brand .brand span{color:var(--primary-2)}
.footer-brand p{margin-top:14px;color:rgba(255,255,255,.55);font-weight:400;font-size:.94rem;max-width:30ch}
.footer-col h5{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.5);font-weight:700;margin-bottom:16px;font-family:var(--mono)}
.footer-col a{display:block;color:rgba(255,255,255,.8);font-weight:400;font-size:.95rem;
  padding:5px 0;transition:color .25s}
.footer-col a:hover{color:var(--primary-2)}
.footer-flag{display:flex;gap:10px;align-items:flex-start;color:rgba(255,255,255,.7);font-size:.86rem;line-height:1.5}
.flag-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto;margin-top:5px;
  background:linear-gradient(150deg,#7c5cff,#4a2bd0)}
.footer-base{max-width:var(--maxw);margin:24px auto 0;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:rgba(255,255,255,.5)}
.footer-base a:hover{color:#fff}

/* ───────── scroll reveal ───────── */
.reveal{opacity:0;transform:translateY(34px);filter:blur(8px);
  transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease)}
.reveal.in{opacity:1;transform:none;filter:none}

/* ───────── responsive ───────── */
@media(max-width:900px){
  .nav-pill{display:none}
  .nav-toggle{display:flex}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand,.footer-flag{grid-column:1/-1}
}
@media(max-width:720px){
  :root{--r-sec:30px}
  .quotes-grid{grid-template-columns:1fr}
  .privacy-lock{opacity:.55}
  .hero-actions{flex-direction:column;align-items:center;gap:12px}
  .hero-actions .btn{width:100%;max-width:330px;justify-content:center}
  .scrolly-copy{gap:64px}
  .gcard{flex-basis:78vw}
}
@media(max-width:460px){
  .footer-grid{grid-template-columns:1fr}
}

/* gallery "Built for the day-to-day" → vertical stack below the pin breakpoint,
   so every card is reachable by normal page scroll on phones / narrow windows
   (the horizontal swipe needs touch or a scrollbar, which a resized desktop lacks) */
@media(max-width:819px){
  .gallery-stage{overflow:visible;scroll-snap-type:none}
  .gallery-track{flex-direction:column;align-items:stretch;gap:clamp(14px,3vw,20px);padding:0 var(--pad)}
  .gallery-head{flex:none;width:auto;justify-content:flex-start;scroll-snap-align:none;margin-bottom:2px}
  .gallery-hint{display:none}
  .gcard{flex:none;width:100%;height:auto;min-height:clamp(360px,52vh,430px);scroll-snap-align:none}
}

/* ───────── reduced motion ───────── */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal,.reveal-line{opacity:1!important;transform:none!important;filter:none!important}
  .hero-img{animation:none;transform:none}
  /* keep the review marquee gliding even under reduced-motion (gentle, user-requested) */
  .qm-track{animation-duration:46s!important;animation-iteration-count:infinite!important}
}
