/* ============================================================
   OneBenefits — Static site stylesheet (revamp)
   Brand: Outfit (headings) / DM Sans (body) · UI Kit colors
   Fresh look: aurora hero, glass cards, scroll-reveal motion
   ============================================================ */
:root{
  --navy:#121C30; --cyan:#00B8DB; --blue:#2B7FFF; --coral:#EF6262;
  --light:#F4F7FB; --pale:#EAF3FF; --pale2:#D2E4FF; --palered:#FBEAEB;
  --grey:#566074; --ink:#1B2436; --line:#E5EBF4; --white:#fff;
  --grad:linear-gradient(120deg,#2B7FFF 0%,#00B8DB 100%);
  --grad-soft:linear-gradient(135deg,#EAF3FF 0%,#FBEAEB 100%);
  --shadow:0 10px 30px rgba(18,28,48,.08);
  --shadow-lg:0 30px 70px rgba(18,28,48,.16);
  --radius:18px; --radius-sm:12px; --maxw:1180px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; font-family:'DM Sans',system-ui,Arial,sans-serif; color:var(--ink); background:var(--white); line-height:1.6; font-size:17px; -webkit-font-smoothing:antialiased; overflow-x:hidden}
h1,h2,h3,h4,h5{font-family:'Outfit',system-ui,Arial,sans-serif; color:var(--navy); line-height:1.1; margin:0 0 .5em; font-weight:700; letter-spacing:-.015em}
h1{font-size:clamp(2.3rem,5.2vw,3.8rem); font-weight:800}
h2{font-size:clamp(1.8rem,3.8vw,2.7rem)}
h3{font-size:clamp(1.2rem,2vw,1.55rem)}
p{margin:0 0 1rem}
a{color:var(--blue); text-decoration:none}
img{max-width:100%; height:auto; display:block}
.container{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px}
section{padding:90px 0; position:relative}

/* Utilities (no inline styles allowed) */
.bg-light{background:var(--light)}
.sec-tight{padding:54px 0}
.sec-flush-top{padding-top:0}
.muted{color:var(--grey)}
.center{justify-content:center}
.is-hidden{display:none!important}
.gtm-noscript{display:none; visibility:hidden}

/* Accessibility */
.skip-link{position:absolute; left:-9999px; top:0; background:var(--navy); color:#fff; padding:12px 18px; border-radius:0 0 8px 0; z-index:3000}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--blue); outline-offset:3px; border-radius:5px}

/* Scroll-reveal */
.reveal{opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1; transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important; transition-duration:.001ms!important; scroll-behavior:auto!important}
  .reveal{opacity:1; transform:none}
}

/* Eyebrow / headings */
.kicker{display:inline-flex; align-items:center; gap:8px; font-family:'Outfit'; font-weight:600; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin-bottom:14px; padding:6px 14px; background:var(--pale); border-radius:50px}
.section-head{max-width:720px; margin:0 auto 56px; text-align:center}
.section-head p{color:var(--grey); font-size:1.1rem}
.text-grad{background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent}

/* Buttons */
.btn{position:relative; display:inline-flex; align-items:center; gap:8px; font-family:'Outfit'; font-weight:600; font-size:1rem; padding:14px 28px; border-radius:50px; border:2px solid transparent; cursor:pointer; transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s; text-align:center; overflow:hidden}
.btn-primary{background:var(--grad); color:#fff; background-size:160% 160%; box-shadow:0 10px 26px rgba(0,184,219,.35)}
.btn-primary:hover{transform:translateY(-3px); box-shadow:0 18px 36px rgba(0,184,219,.5); background-position:100% 50%}
.btn-ghost{background:#fff; color:var(--navy); border-color:var(--line)}
.btn-ghost:hover{border-color:var(--blue); color:var(--blue); transform:translateY(-3px)}
.btn-white{background:#fff; color:var(--navy)}
.btn-white:hover{transform:translateY(-3px); box-shadow:var(--shadow-lg)}
.btn-outline-white{background:transparent; color:#fff; border-color:rgba(255,255,255,.45)}
.btn-outline-white:hover{background:rgba(255,255,255,.14); transform:translateY(-3px)}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Header ---------- */
.site-header{position:sticky; top:0; z-index:1000; background:rgba(255,255,255,.8); backdrop-filter:blur(14px); border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s}
.site-header.scrolled{border-bottom-color:var(--line); box-shadow:0 4px 24px rgba(18,28,48,.05)}
.nav{display:flex; align-items:center; justify-content:space-between; height:76px}
.nav .logo img{height:34px}
.nav-links{display:flex; align-items:center; gap:30px; list-style:none; margin:0; padding:0}
.nav-links a{position:relative; color:var(--navy); font-family:'Outfit'; font-weight:500; font-size:.98rem; padding:4px 0}
.nav-links a::after{content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:var(--grad); transition:width .3s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex; align-items:center; gap:14px}
.nav-actions .login{color:var(--navy); font-family:'Outfit'; font-weight:500}
.nav-actions .login:hover{color:var(--blue)}
.menu-toggle{display:none; background:none; border:0; width:44px; height:44px; cursor:pointer}
.menu-toggle span{display:block; width:24px; height:2px; background:var(--navy); margin:5px auto; transition:.3s}
.nav.open .menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .menu-toggle span:nth-child(2){opacity:0}
.nav.open .menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero w/ aurora ---------- */
.hero{position:relative; overflow:hidden; background:#fff}
.hero .aurora{position:absolute; inset:0; z-index:0; overflow:hidden}
.hero .blob{position:absolute; border-radius:50%; filter:blur(70px); opacity:.55; animation:float 16s var(--ease) infinite}
.hero .blob.b1{width:480px; height:480px; background:radial-gradient(circle,#2B7FFF,transparent 70%); top:-160px; left:-120px}
.hero .blob.b2{width:420px; height:420px; background:radial-gradient(circle,#00B8DB,transparent 70%); top:-80px; right:-100px; animation-delay:-5s}
.hero .blob.b3{width:360px; height:360px; background:radial-gradient(circle,#EF6262,transparent 70%); bottom:-160px; left:30%; opacity:.32; animation-delay:-9s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,40px) scale(1.08)}66%{transform:translate(-25px,20px) scale(.95)}}
.hero-inner{position:relative; z-index:2; display:grid; grid-template-columns:1.05fr .95fr; gap:50px; align-items:center; padding:74px 0 84px}
.hero h1 span{display:inline; background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent}
.hero p.lead{font-size:1.2rem; color:var(--grey); max-width:540px; margin-bottom:28px}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:26px}
.hero-trust{display:flex; gap:22px; flex-wrap:wrap; color:var(--grey); font-size:.9rem}
.hero-trust span{display:inline-flex; align-items:center; gap:7px}
.hero-trust span::before{content:""; width:8px; height:8px; border-radius:50%; background:var(--grad)}
.hero-visual{position:relative; perspective:1200px}
.hero-visual img{border-radius:var(--radius); box-shadow:var(--shadow-lg); border:1px solid var(--line); background:#fff; transform:rotateY(-6deg) rotateX(2deg); transition:transform .5s var(--ease)}
.hero-visual:hover img{transform:rotateY(0) rotateX(0)}
.hero-visual .chip{position:absolute; background:#fff; border:1px solid var(--line); border-radius:14px; padding:12px 16px; box-shadow:var(--shadow); display:flex; align-items:center; gap:10px; font-family:'Outfit'; font-weight:600; font-size:.85rem; animation:bob 5s var(--ease) infinite}
.hero-visual .chip .dot{width:30px;height:30px;border-radius:9px;background:var(--grad); display:grid; place-items:center; color:#fff}
.hero-visual .chip.c1{top:-18px; left:-26px}
.hero-visual .chip.c2{bottom:24px; right:-30px; animation-delay:-2.5s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- Hero slider (two-column, blended) ---------- */
.hero{padding:0; position:relative; overflow:hidden; background:radial-gradient(1100px 520px at 86% -4%, #E3F1FF 0%, rgba(227,241,255,0) 60%), linear-gradient(180deg,#FAFCFF 0%,#fff 70%)}
.hero-slider{position:relative}
.hero-slide{display:none}
.hero-slide.active{display:block; animation:slideFade .6s var(--ease)}
@keyframes slideFade{from{opacity:0; transform:translateY(14px)}to{opacity:1; transform:none}}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; padding:40px 0 24px}
.hero-copy{max-width:600px}
.hero-slide h1,.hero-slide h2{font-size:clamp(2.1rem,4.4vw,3.4rem); font-weight:800; line-height:1.1; margin:0 0 .45em; letter-spacing:-.015em}
.hero .accent{display:inline; background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent}
.hero-art{position:relative; display:flex; justify-content:center}
.hero-art img{width:100%; height:auto; max-height:480px; object-fit:contain}
.hero-art .badge{position:absolute; bottom:18px; left:2%; background:#fff; border-radius:14px; padding:11px 16px; box-shadow:var(--shadow-lg); display:flex; align-items:center; gap:10px; font-family:'Outfit'; font-weight:600; font-size:.84rem; color:var(--navy); animation:bob 5.5s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.hero-art .badge .bi{width:26px; height:26px; border-radius:8px; background:var(--grad); display:grid; place-items:center; color:#fff}
.hero-art .badge .bi svg{width:15px; height:15px}
.hero-controls{display:flex; align-items:center; gap:16px; justify-content:flex-start; margin-top:30px}
.hero-arrow{width:46px; height:46px; border-radius:50%; border:1px solid var(--line); background:#fff; color:var(--navy); font-size:1.4rem; line-height:1; cursor:pointer; display:grid; place-items:center; transition:transform .25s var(--ease),background .25s,color .25s; box-shadow:var(--shadow)}
.hero-arrow:hover{background:var(--grad); color:#fff; transform:translateY(-2px); border-color:transparent}
.hero-dots{display:flex; gap:10px}
.hero-dot{width:11px; height:11px; border-radius:50%; border:0; background:var(--pale2); cursor:pointer; padding:0; transition:width .3s var(--ease),background .3s}
.hero-dot.active{width:30px; border-radius:6px; background:var(--grad)}

/* Pillars */
.pillars{position:relative; z-index:3; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:46px}
.pillar{background:transparent; border-radius:14px; padding:22px 18px; transition:transform .3s var(--ease)}
.pillar:hover{transform:translateY(-4px)}
.pillar .pi{width:48px; height:48px; border-radius:14px; background:var(--pale); display:grid; place-items:center; margin-bottom:14px; color:var(--blue)}
.pillar .pi svg{width:24px; height:24px}
.pillar h4{font-size:1.02rem; margin:0 0 4px}
.pillar p{font-size:.9rem; color:var(--grey); margin:0}

/* Icon helper */
.ico{stroke:currentColor; stroke-width:1.8; fill:none; stroke-linecap:round; stroke-linejoin:round}

/* ---------- Proof strip (under hero) ---------- */
.proof{padding:8px 0 70px}
.proof-eyebrow{text-align:center; font-family:'Outfit'; font-weight:600; font-size:.76rem; letter-spacing:.18em; text-transform:uppercase; color:var(--grey); margin:0 0 30px}
.proof-bar{display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.proof-item{display:flex; gap:15px; align-items:center; padding:26px 30px}
.proof-item + .proof-item{border-left:1px solid var(--line)}
.proof-item .hi{flex:0 0 auto; width:46px; height:46px; border-radius:13px; background:var(--pale); color:var(--blue); display:grid; place-items:center}
.proof-item .hi svg{width:23px; height:23px}
.proof-item h4{font-family:'Outfit'; font-size:1.06rem; margin:0 0 3px}
.proof-item p{font-size:.85rem; color:var(--grey); margin:0; line-height:1.4}

/* ---------- Platform strip ---------- */
.platform{position:relative; background:var(--navy); color:#fff; border-radius:26px; padding:60px 40px; text-align:center; overflow:hidden}
.platform::before{content:""; position:absolute; width:420px;height:420px; top:-200px; right:-120px; background:radial-gradient(circle,rgba(0,184,219,.5),transparent 70%); filter:blur(40px)}
.platform>*{position:relative}
.platform h2{color:#fff}
.platform .channels{display:flex; justify-content:center; gap:42px; flex-wrap:wrap; margin:34px 0}
.platform .channel{display:flex; flex-direction:column; align-items:center; gap:12px; font-family:'Outfit'; font-weight:600; transition:transform .3s var(--ease)}
.platform .channel:hover{transform:translateY(-6px)}
.platform .channel img{width:56px; height:56px; background:#fff; border-radius:15px; padding:9px}
.platform .lead-line{max-width:760px; margin:0 auto 26px; color:#C7D2E2; font-size:1.12rem}
.platform .lead-line strong{color:#fff}

/* ---------- Video section ---------- */
.video-wrap{max-width:920px; margin:0 auto; position:relative; border-radius:22px; overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--line); aspect-ratio:16/9; background:var(--navy)}
.video-wrap iframe{position:absolute; inset:0; width:100%; height:100%; border:0}
.video-facade{position:absolute; inset:0; cursor:pointer; display:grid; place-items:center; background:var(--grad)}
.video-facade::after{content:""; position:absolute; inset:0; background:radial-gradient(circle at 70% 30%,rgba(255,255,255,.25),transparent 55%)}
.video-facade .play{position:relative; width:84px; height:84px; border-radius:50%; background:rgba(255,255,255,.95); display:grid; place-items:center; transition:transform .3s var(--ease); box-shadow:0 12px 30px rgba(0,0,0,.25)}
.video-facade:hover .play{transform:scale(1.08)}
.video-facade .play span{width:0; height:0; border-left:22px solid var(--blue); border-top:14px solid transparent; border-bottom:14px solid transparent; margin-left:6px}
.video-facade .vtext{position:absolute; bottom:22px; left:24px; color:#fff; font-family:'Outfit'; font-weight:600; font-size:1.05rem}

/* ---------- Feature cards grid ---------- */
.feature-cards{display:grid; grid-template-columns:repeat(4,1fr); gap:20px}
.fcard{position:relative; background:#fff; border-radius:16px; padding:26px 22px; box-shadow:0 6px 20px rgba(18,28,48,.05); transition:transform .3s var(--ease),box-shadow .3s; overflow:hidden}
.fcard::before{content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--grad); transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease)}
.fcard:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg)}
.fcard:hover::before{transform:scaleX(1)}
.fcard .fi{width:48px; height:48px; border-radius:13px; background:var(--pale); color:var(--blue); display:grid; place-items:center; margin-bottom:16px}
.fcard .fi svg{width:25px; height:25px}
.fcard h4{font-size:1.06rem; margin:0 0 7px}
.fcard p{font-size:.9rem; color:var(--grey); margin:0; line-height:1.5}

/* ---------- Product tour carousel ---------- */
.tour{margin-top:56px}
.tour-head{text-align:center; margin-bottom:26px}
.tour-head h3{margin:0 0 6px}
.tour-head p{color:var(--grey); margin:0}
.tour-stage{position:relative; max-width:880px; margin:0 auto; background:linear-gradient(140deg,#EAF3FF,#FBEAEB); border:1px solid #fff; border-radius:var(--radius); box-shadow:var(--shadow-lg); padding:26px; overflow:hidden}
.tour-track{position:relative; aspect-ratio:16/10}
.tour-slide{position:absolute; inset:0; opacity:0; transform:scale(1.015); transition:opacity .5s var(--ease),transform .5s var(--ease); display:grid; place-items:center}
.tour-slide.active{opacity:1; transform:none}
.tour-slide img{max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; border-radius:10px; box-shadow:0 14px 34px rgba(18,28,48,.16)}
.tour-controls{display:flex; align-items:center; justify-content:center; gap:16px; margin-top:22px}
.tour-dots{display:flex; gap:9px; flex-wrap:wrap; justify-content:center; max-width:340px}
.tour-dot{width:10px; height:10px; border-radius:50%; border:0; background:var(--pale2); cursor:pointer; padding:0; transition:width .3s var(--ease),background .3s}
.tour-dot.active{width:26px; border-radius:5px; background:var(--grad)}

/* ---------- How it works ---------- */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:26px}
.step{position:relative; background:transparent; border-radius:var(--radius); padding:34px 24px 26px; transition:transform .3s var(--ease)}
.step:hover{transform:translateY(-5px)}
.step .num{width:42px; height:42px; border-radius:12px; background:var(--grad); color:#fff; font-family:'Outfit'; font-weight:800; display:grid; place-items:center; box-shadow:0 8px 18px rgba(0,184,219,.4); margin-bottom:8px}
.step img{width:58px; height:58px; margin:8px 0 16px}
.step h3{margin-bottom:8px}
.step p{color:var(--grey); margin:0; font-size:.98rem}
.step-connector{display:none}

/* ---------- Features ---------- */
.features-grid{display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center}
.feature-list{display:grid; grid-template-columns:1fr 1fr; gap:14px; list-style:none; padding:0; margin:24px 0 0}
.feature-list li{display:flex; align-items:center; gap:10px; background:#fff; border:1px solid var(--line); border-radius:11px; padding:14px 16px; font-family:'Outfit'; font-weight:500; font-size:.96rem; transition:transform .25s var(--ease),border-color .25s}
.feature-list li:hover{transform:translateX(4px); border-color:var(--cyan)}
.feature-list li .tick{flex:0 0 auto; width:22px; height:22px; border-radius:50%; background:var(--grad); display:grid; place-items:center; color:#fff}
.feature-gallery{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.feature-gallery img{border-radius:14px; box-shadow:var(--shadow); border:1px solid var(--line); transition:transform .35s var(--ease)}
.feature-gallery img:hover{transform:scale(1.03)}
.feature-gallery img:first-child{grid-column:1/-1}

/* ---------- Benefit cards ---------- */
.benefit-cards{display:grid; grid-template-columns:repeat(4,1fr); gap:34px}
.bcard{position:relative; text-align:center; padding:8px; transition:transform .3s var(--ease)}
.bcard:hover{transform:translateY(-5px)}
.bcard img{width:66px; height:66px; margin:0 auto 16px}
.bcard h4{margin:0 0 6px}
.bcard p{color:var(--grey); font-size:.92rem; margin:0}

/* ---------- Audience ---------- */
.audience{display:grid; grid-template-columns:1fr 1fr; gap:30px}
.aud-card{position:relative; background:#fff; border-radius:var(--radius); padding:42px 36px; overflow:hidden; transition:transform .3s var(--ease),box-shadow .3s}
.aud-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-lg)}
.aud-card.blue{background:linear-gradient(160deg,#EAF3FF 0%,#D2E4FF 100%)}
.aud-card.red{background:linear-gradient(160deg,#FBEAEB 0%,#D2E4FF 100%)}
.checklist{list-style:none; padding:0; margin:18px 0 0}
.checklist li{display:flex; gap:12px; align-items:flex-start; margin-bottom:14px; font-size:1rem}
.checklist li img{width:22px; height:22px; margin-top:2px; flex:0 0 auto}

/* ---------- Contact ---------- */
.contact{background:var(--navy); color:#fff}
.contact h1,.contact h2{color:#fff}
.contact .kicker{background:rgba(255,255,255,.1); color:#9FE9F7}
.contact-grid{display:grid; grid-template-columns:1fr 1.1fr; gap:48px; align-items:start}
.contact-info p{color:#C7D2E2}
.contact-info .checklist li{font-size:1.02rem; color:#E6ECF5}
.contact-info .checklist li img{filter:brightness(0) saturate(100%) invert(70%) sepia(60%) saturate(600%) hue-rotate(150deg)}
.contact-form{background:#fff; border-radius:var(--radius); padding:36px; box-shadow:var(--shadow-lg); color:var(--ink)}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.field{margin-bottom:16px}
.field label{display:block; font-family:'Outfit'; font-weight:500; font-size:.9rem; margin-bottom:6px; color:var(--navy)}
.req{color:var(--coral); margin-left:2px}
.muted-light{color:#C7D2E2; font-size:.95rem; margin-top:20px}
.muted-light a{color:var(--cyan)}
.field input,.field select,.field textarea{width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:11px; font-family:'DM Sans'; font-size:1rem; background:#fff; color:var(--ink); transition:border .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--blue); box-shadow:0 0 0 4px rgba(43,127,255,.14)}
.field textarea{resize:vertical; min-height:110px}
.consent{display:flex; gap:10px; align-items:flex-start; font-size:.88rem; color:var(--grey); margin-bottom:18px}
.consent input{width:18px; height:18px; margin-top:3px; flex:0 0 auto}
.contact-form .btn{width:100%; justify-content:center}

/* ---------- Final CTA ---------- */
.final-cta{position:relative; background:var(--grad); color:#fff; text-align:center; border-radius:26px; padding:70px 40px; overflow:hidden}
.final-cta::after{content:""; position:absolute; inset:0; background:radial-gradient(circle at 80% 20%,rgba(255,255,255,.25),transparent 50%)}
.final-cta>*{position:relative}
.final-cta img.logo{width:56px; margin:0 auto 20px}
.final-cta h2{color:#fff}
.final-cta p{color:rgba(255,255,255,.92); max-width:560px; margin:0 auto 28px}
.final-cta .btn-row{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}
.final-cta .small{display:block; margin-top:18px; color:rgba(255,255,255,.8); font-size:.85rem}

/* ---------- Pricing ---------- */
.page-hero{position:relative; overflow:hidden; background:radial-gradient(1100px 480px at 84% -10%, #E3F1FF 0%, rgba(227,241,255,0) 60%), linear-gradient(180deg,#FAFCFF,#fff); text-align:center; padding:64px 0 36px}
.page-hero .kicker{margin-bottom:16px}
.page-hero h1{font-size:clamp(2.2rem,4.6vw,3.4rem); margin:0 0 .35em}
.page-hero p.lead{color:var(--grey); font-size:1.15rem; max-width:620px; margin:0 auto}
.price-toggle{display:inline-flex; background:var(--light); border:1px solid var(--line); border-radius:50px; padding:5px; margin:30px auto 0; gap:4px}
.price-toggle button{font-family:'Outfit'; font-weight:600; font-size:.96rem; color:var(--grey); background:transparent; border:0; border-radius:50px; padding:11px 26px; cursor:pointer; transition:color .25s}
.price-toggle button.active{color:#fff; background:var(--grad); box-shadow:0 8px 20px rgba(0,184,219,.32)}
.price-note{display:block; margin-top:12px; color:var(--grey); font-size:.9rem}
.pricing-sec{padding:48px 0 90px}
.price-view{display:none}
.price-view.active{display:block; animation:slideFade .5s var(--ease)}
.price-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:22px; align-items:start}
.price-card{position:relative; background:#fff; border:1px solid var(--line); border-radius:18px; padding:30px 26px; display:flex; flex-direction:column; transition:transform .3s var(--ease),box-shadow .3s}
.price-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg)}
.price-card.popular{border-color:transparent; box-shadow:var(--shadow-lg); background:linear-gradient(#fff,#fff) padding-box, var(--grad) border-box; border:2px solid transparent}
.price-badge{position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--grad); color:#fff; font-family:'Outfit'; font-weight:700; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; padding:6px 16px; border-radius:50px; white-space:nowrap}
.price-card .tier{font-family:'Outfit'; font-weight:600; font-size:1.05rem; color:var(--navy); margin:0 0 6px}
.price-card .amt{font-family:'Outfit'; font-weight:800; font-size:2.3rem; color:var(--navy); line-height:1}
.price-card .amt .per{font-size:.95rem; font-weight:500; color:var(--grey)}
.price-card .range{color:var(--grey); font-size:.9rem; margin:6px 0 20px}
.price-card .btn{width:100%; justify-content:center; margin-bottom:22px}
.price-card .plus{font-family:'Outfit'; font-weight:600; font-size:.82rem; color:var(--navy); margin:0 0 12px}
.price-feats{list-style:none; padding:0; margin:0; display:grid; gap:11px}
.price-feats li{display:flex; gap:10px; align-items:flex-start; font-size:.92rem; color:var(--ink)}
.price-feats li .tick{flex:0 0 auto; width:19px; height:19px; border-radius:50%; background:var(--pale); color:var(--blue); display:grid; place-items:center; margin-top:2px}
.price-feats li .tick svg{width:12px; height:12px}
.bundle{display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; text-align:center; background:var(--navy); color:#fff; border-radius:18px; padding:26px 34px; margin-top:34px}
.bundle .tag{font-family:'Outfit'; font-weight:700; background:var(--grad); color:#fff; padding:6px 14px; border-radius:50px; font-size:.82rem}
.bundle p{margin:0; color:#C7D2E2; font-size:1.02rem}
.bundle strong{color:#fff}

/* page hero accent + reassurance */
.page-hero .accent{font-style:italic}
.page-hero .hero-cta{justify-content:center; margin-top:30px}
.reassure{display:block; margin-top:18px; color:var(--grey); font-size:.9rem}
.reassure b{color:var(--navy); font-weight:600}

/* tier card dual CTAs + tagline */
.price-card .tagline{color:var(--grey); font-size:.9rem; margin:0 0 16px; min-height:38px}
.price-card .btns{display:grid; gap:9px; margin-bottom:22px}
.price-card .btns .btn{width:100%; justify-content:center; margin:0}
.price-card .btn-text{background:transparent; border:0; color:var(--blue); font-family:'Outfit'; font-weight:600; padding:6px; cursor:pointer}
.price-card .btn-text:hover{text-decoration:underline}

/* ---------- Bundle savings calculator ---------- */
.calc{background:linear-gradient(160deg,#EAF3FF,#FBEAEB); border-radius:22px; padding:40px; margin-top:14px}
.calc-grid{display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:center}
.calc h3{margin:0 0 6px}
.calc .sub{color:var(--grey); margin:0 0 22px}
.calc .picker{display:grid; gap:16px}
.calc label{display:block; font-family:'Outfit'; font-weight:600; font-size:.9rem; margin-bottom:6px; color:var(--navy)}
.calc select{width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:11px; font-family:'DM Sans'; font-size:1rem; background:#fff; color:var(--ink)}
.calc select:focus{outline:none; border-color:var(--blue); box-shadow:0 0 0 4px rgba(43,127,255,.14)}
.calc-result{background:#fff; border-radius:18px; padding:30px; box-shadow:var(--shadow-lg); text-align:center}
.calc-result .label{font-family:'Outfit'; font-weight:600; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--grey)}
.calc-result .big{font-family:'Outfit'; font-weight:800; font-size:3rem; line-height:1; background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; margin:8px 0}
.calc-result .rows{display:grid; gap:8px; margin-top:18px; text-align:left}
.calc-result .rows div{display:flex; justify-content:space-between; font-size:.95rem; color:var(--ink); padding:9px 0; border-bottom:1px solid var(--line)}
.calc-result .rows div:last-child{border-bottom:0; font-family:'Outfit'; font-weight:700; color:var(--navy)}
.calc-result .rows .strike{color:var(--grey); text-decoration:line-through}
.calc-note{font-size:.82rem; color:var(--grey); margin:14px 0 0}

/* ---------- Comparison table ---------- */
.compare{margin-top:60px}
.compare h3{text-align:center; margin:0 0 28px}
.compare h3 .accent{font-style:italic}
.cmp-scroll{overflow-x:auto; border:1px solid var(--line); border-radius:16px}
table.cmp{width:100%; border-collapse:collapse; min-width:620px; font-size:.93rem}
table.cmp th,table.cmp td{padding:15px 18px; text-align:left; border-bottom:1px solid var(--line)}
table.cmp thead th{background:var(--navy); color:#fff; font-family:'Outfit'; font-weight:600; position:sticky; top:0}
table.cmp thead th:first-child{border-top-left-radius:16px}
table.cmp thead th:last-child{border-top-right-radius:16px}
table.cmp thead .pop{color:#9FE9F7}
table.cmp td:not(:first-child),table.cmp th:not(:first-child){text-align:center; width:20%}
table.cmp .grp td{background:var(--light); font-family:'Outfit'; font-weight:700; color:var(--navy); font-size:.82rem; letter-spacing:.06em; text-transform:uppercase}
table.cmp .yes{color:var(--blue); font-weight:700}
table.cmp .no{color:#C2CBD8}
table.cmp tbody tr:hover td{background:#FAFCFF}
table.cmp .grp:hover td{background:var(--light)}

/* ---------- Enterprise block ---------- */
.enterprise{display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center; background:var(--navy); color:#fff; border-radius:24px; padding:50px; overflow:hidden; position:relative}
.enterprise::before{content:""; position:absolute; width:360px; height:360px; top:-160px; right:-100px; background:radial-gradient(circle,rgba(0,184,219,.45),transparent 70%)}
.enterprise>*{position:relative}
.enterprise h2{color:#fff; margin:0 0 12px}
.enterprise h2 .accent{font-style:italic; -webkit-text-fill-color:transparent; background:linear-gradient(120deg,#7FD4FF,#9FE9F7); -webkit-background-clip:text; background-clip:text}
.enterprise p{color:#C7D2E2; margin:0 0 22px}
.enterprise .btn-row{display:flex; gap:14px; flex-wrap:wrap}
.ent-card{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:16px; padding:24px}
.ent-card .q{color:#fff; font-weight:600; margin:0 0 12px}
.ent-card .a{color:#9FE9F7; margin:0; font-size:.95rem}
.ent-card .tagm{display:inline-block; margin-bottom:14px; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:#8FA0B8; font-family:'Outfit'; font-weight:600}

/* ---------- Pricing FAQ ---------- */
.pfaq{max-width:780px; margin:0 auto}
.pfaq h2{text-align:center; margin-bottom:30px}
.pfaq details{background:#fff; border:1px solid var(--line); border-radius:13px; padding:0 22px; margin-bottom:12px; transition:box-shadow .25s}
.pfaq details[open]{box-shadow:var(--shadow)}
.pfaq summary{list-style:none; cursor:pointer; font-family:'Outfit'; font-weight:600; color:var(--navy); padding:18px 0; display:flex; justify-content:space-between; align-items:center; gap:16px}
.pfaq summary::-webkit-details-marker{display:none}
.pfaq summary::after{content:"+"; font-size:1.4rem; color:var(--blue); flex:0 0 auto; transition:transform .25s}
.pfaq details[open] summary::after{transform:rotate(45deg)}
.pfaq .ans{color:var(--grey); padding:0 0 20px; margin:0; line-height:1.6}

/* ---------- Article (blog post) ---------- */
.article-hero{background:radial-gradient(1000px 460px at 80% -10%, #E3F1FF 0%, rgba(227,241,255,0) 60%), linear-gradient(180deg,#FAFCFF,#fff); padding:32px 0 8px}
.crumbs{font-size:.85rem; color:var(--grey); margin-bottom:22px}
.crumbs a{color:var(--grey)} .crumbs a:hover{color:var(--blue)}
.article-head{max-width:780px; margin:0 auto; text-align:center}
.article-head h1{font-size:clamp(2rem,4.2vw,3rem); margin:.2em 0 .4em}
.article-meta{display:flex; gap:18px; justify-content:center; flex-wrap:wrap; color:var(--grey); font-size:.92rem; margin-bottom:8px}
.article-meta span{display:inline-flex; align-items:center; gap:6px}
.article-feat{max-width:980px; margin:34px auto 0; border-radius:20px; overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--line)}
.article-feat img{width:100%; display:block}
.article-layout{display:grid; grid-template-columns:240px 1fr; gap:48px; max-width:1040px; margin:0 auto; align-items:start}
.toc{position:sticky; top:100px; font-size:.9rem}
.toc h4{font-family:'Outfit'; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--grey); margin:0 0 14px}
.toc ul{list-style:none; margin:0; padding:0; display:grid; gap:9px; border-left:2px solid var(--line); padding-left:16px}
.toc a{color:var(--grey); line-height:1.4}
.toc a:hover{color:var(--blue)}
.prose{max-width:720px}
.prose h2{font-size:1.6rem; margin:42px 0 14px; scroll-margin-top:100px}
.prose h3{font-size:1.2rem; margin:28px 0 10px; scroll-margin-top:100px}
.prose p,.prose li{font-size:1.05rem; line-height:1.8; color:var(--ink)}
.prose ul{padding-left:22px; margin:0 0 20px}
.prose li{margin-bottom:10px}
.prose strong{color:var(--navy)}
.prose hr{border:0; border-top:1px solid var(--line); margin:40px 0}
.prose .lead-p{font-size:1.18rem; color:var(--grey); line-height:1.7}
.prose .tldr{background:var(--pale); border-left:4px solid var(--blue); border-radius:10px; padding:18px 22px; margin:26px 0}
.prose .tldr p{margin:0; font-size:1rem}
.prose .tldr .lbl{display:block; font-family:'Outfit'; font-weight:700; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); margin-bottom:6px}
.callout{background:linear-gradient(140deg,#EAF3FF,#FBEAEB); border-radius:16px; padding:28px 30px; margin:28px 0; text-align:center}
.callout .big{font-family:'Outfit'; font-weight:800; font-size:2.8rem; line-height:1; background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent}
.callout p{margin:10px 0 0; color:var(--ink); font-size:.98rem}
.ptable{width:100%; border-collapse:collapse; margin:22px 0; font-size:.95rem; border:1px solid var(--line); border-radius:14px; overflow:hidden}
.ptable th,.ptable td{padding:13px 16px; text-align:left; border-bottom:1px solid var(--line); vertical-align:top}
.ptable thead th{background:var(--navy); color:#fff; font-family:'Outfit'; font-weight:600}
.ptable tbody tr:nth-child(even){background:var(--light)}
.ptable td:first-child{font-family:'Outfit'; font-weight:600; color:var(--navy); white-space:nowrap}
.post-cta-form{background:#fff; border:1px solid var(--line); border-radius:16px; padding:28px; box-shadow:var(--shadow); margin:28px 0}
.post-cta-form h3{margin:0 0 6px}
.post-cta-form p{color:var(--grey); margin:0 0 18px; font-size:.95rem}
@media (max-width:900px){
  .article-layout{grid-template-columns:1fr; gap:24px}
  .toc{position:static; border:1px solid var(--line); border-radius:12px; padding:18px; background:var(--light)}
  .toc ul{border-left:0; padding-left:0}
  .prose{max-width:100%}
}

/* ---------- Legal pages ---------- */
.legal{max-width:820px; margin:0 auto}
.legal .updated{color:var(--grey); font-size:.9rem; margin:0 0 30px}
.legal h2{font-size:1.45rem; margin:38px 0 12px}
.legal h3{font-size:1.1rem; margin:24px 0 8px; color:var(--navy)}
.legal p,.legal li{color:var(--ink); line-height:1.75}
.legal ul{padding-left:20px; margin:0 0 18px}
.legal li{margin-bottom:8px}
.legal a{color:var(--blue)}
.legal .note{background:var(--pale); border-radius:12px; padding:16px 20px; font-size:.92rem; color:var(--grey); margin:0 0 28px}

/* ---------- Insights (blog) ---------- */
.blog-search{max-width:480px; margin:0 auto 44px; position:relative}
.blog-search svg{position:absolute; left:18px; top:50%; transform:translateY(-50%); width:20px; height:20px; color:var(--grey); pointer-events:none}
.blog-search input{width:100%; padding:14px 18px 14px 48px; border:1px solid var(--line); border-radius:50px; font-family:'DM Sans'; font-size:1rem; background:#fff; color:var(--ink); box-shadow:var(--shadow)}
.blog-search input:focus{outline:none; border-color:var(--blue); box-shadow:0 0 0 4px rgba(43,127,255,.14)}
.no-results{display:none; text-align:center; color:var(--grey); padding:24px}
.no-results.show{display:block}
.post-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px}
.post-card{display:flex; flex-direction:column; background:#fff; border-radius:18px; overflow:hidden; box-shadow:0 6px 20px rgba(18,28,48,.05); transition:transform .3s var(--ease),box-shadow .3s}
.post-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg)}
.post-card .pimg{display:block; aspect-ratio:16/10; overflow:hidden; background:var(--light)}
.post-card .pimg img{width:100%; height:100%; object-fit:cover; transition:transform .45s var(--ease)}
.post-card:hover .pimg img{transform:scale(1.05)}
.post-body{padding:24px; display:flex; flex-direction:column; flex:1}
.post-tag{align-self:flex-start; font-family:'Outfit'; font-weight:600; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--blue); background:var(--pale); padding:5px 12px; border-radius:50px; margin-bottom:14px}
.post-date{color:var(--grey); font-size:.85rem; margin:0 0 8px}
.post-card h3{font-size:1.18rem; margin:0 0 10px; line-height:1.25}
.post-card h3 a{color:var(--navy)}
.post-card h3 a:hover{color:var(--blue)}
.post-excerpt{color:var(--grey); font-size:.94rem; margin:0 0 18px; flex:1}
.post-more{font-family:'Outfit'; font-weight:600; color:var(--blue); display:inline-flex; align-items:center; gap:6px}
.post-more svg{width:16px; height:16px; transition:transform .25s var(--ease)}
.post-card:hover .post-more svg{transform:translateX(3px)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy); color:#C7D2E2; padding:64px 0 28px}
.footer-top{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand img{height:34px; margin-bottom:16px}
.footer-brand p{font-size:.94rem; max-width:320px}
.footer-col h5{color:#fff; font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:16px}
.footer-col ul{list-style:none; padding:0; margin:0}
.footer-col li{margin-bottom:11px}
.footer-col a{color:#C7D2E2; font-size:.95rem; transition:color .2s}
.footer-col a:hover{color:var(--cyan)}
.footer-bottom{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; padding-top:24px; font-size:.88rem}
.footer-bottom a{color:#C7D2E2}
.social{display:flex; gap:12px}
.social a{width:38px; height:38px; border-radius:50%; background:rgba(255,255,255,.08); display:grid; place-items:center; transition:background .25s,transform .25s}
.social a:hover{background:var(--cyan); transform:translateY(-3px)}
.social svg{width:18px; height:18px; fill:#fff}

/* ---------- Mobile ---------- */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr; gap:24px; padding:34px 0 18px}
  .hero-art{order:-1; max-width:420px; margin:0 auto; width:100%}
  .hero-copy{max-width:100%}
  .features-grid,.audience,.contact-grid{grid-template-columns:1fr; gap:36px}
  .feature-cards{grid-template-columns:1fr 1fr}
  .benefit-cards{grid-template-columns:1fr 1fr}
  .price-grid{grid-template-columns:1fr 1fr}
  .post-grid{grid-template-columns:1fr 1fr}
  .calc-grid{grid-template-columns:1fr; gap:26px}
  .enterprise{grid-template-columns:1fr; gap:28px; padding:38px}
  .proof-bar{grid-template-columns:1fr 1fr}
  .proof-item:nth-child(3){border-left:0}
  .proof-item:nth-child(n+3){border-top:1px solid var(--line)}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  section{padding:64px 0}
  .nav-links,.nav-actions .login{display:none}
  .menu-toggle{display:block}
  .nav.open .nav-links{display:flex; position:absolute; top:76px; left:0; right:0; flex-direction:column; align-items:flex-start; background:#fff; padding:20px 24px; gap:16px; border-bottom:1px solid var(--line); box-shadow:var(--shadow)}
  .nav.open .nav-actions .login{display:block}
  .steps,.feature-list{grid-template-columns:1fr}
  .platform{padding:42px 22px}
  .platform .channels{gap:26px}
  .final-cta{padding:52px 24px}
}
@media (max-width:460px){
  .benefit-cards,.feature-cards,.footer-top,.price-grid,.post-grid{grid-template-columns:1fr}
  .proof-bar{grid-template-columns:1fr}
  .proof-item + .proof-item{border-left:0; border-top:1px solid var(--line)}
  body{font-size:16px}
}

/* Decorative overlays must never intercept clicks */
.final-cta::after,.final-cta::before,.platform::before,.enterprise::before,.hero-art::before,.video-facade::after,.hero .blob{pointer-events:none}
