*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Primary brand — matches Sprint28 app exactly */
  --primary:#1E5EF0;--primary-dark:#0D47A1;--primary-hover:#184CD6;
  /* Legacy aliases used throughout CSS (kept for compatibility) */
  --indigo:#1E5EF0;--indigo-light:#184CC8;--indigo-subtle:#E7F1FF;
  /* Dark surfaces */
  --navy:#0F172A;--navy-light:#1e293b;
  /* Additional blue shades */
  --blue-mid:#2563eb;--blue-deep:#1d4ed8;
  /* Surfaces */
  --white:#ffffff;--off-white:#F6FAFF;--gray-50:#f9fafb;
  --gray-100:#f3f4f6;--gray-200:#E2E8F0;--gray-300:#d1d5db;--gray-400:#9ca3af;
  --gray-500:#64748B;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;
  /* Semantic colors — match app tokens */
  --green:#16A34A;--green-light:#d1fae5;--purple:#8b5cf6;--purple-light:#ede9fe;
  --blue:#1E5EF0;--blue-light:#E7F1FF;
  --warning:#F59E0B;--destructive:#DC2626;--border:#E2E8F0;
  /* Typography */
  --font-heading:'Plus Jakarta Sans',sans-serif;--font-body:'Inter',sans-serif;
  /* Shadows */
  --shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);
  --shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);
  --shadow-2xl:0 25px 50px -12px rgba(0,0,0,.25);
  --radius:12px;--radius-lg:16px;--radius-xl:24px;
  /* Reusable blue gradient */
  --blue-gradient:radial-gradient(circle at center,rgba(191,216,248,.12) 0%,rgba(191,216,248,0) 60%),linear-gradient(180deg,rgb(18,60,160) 0%,rgb(24,76,200) 55%,rgb(30,94,240) 100%);
  /* Subtle light blue */
  --subtle-blue:linear-gradient(180deg,#F0F5FF 0%,#F6FAFF 100%);
}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-body);color:var(--navy);line-height:1.6;background:var(--white);overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.2;font-weight:800}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ═══ REVEAL ANIMATIONS ═══ */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}

/* ═══ NAVBAR ═══ */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 0;transition:all .35s cubic-bezier(.16,1,.3,1)}
.navbar .container{display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:var(--font-heading);font-weight:800;font-size:22px;display:flex;align-items:center;gap:8px}
.nav-logo img{height:32px;width:auto}
.nav-logo-dark{display:none}

/* Navbar default state (on hero dark bg) */
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-size:14px;font-weight:500;color:rgba(255,255,255,.8);transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-cta{background:var(--white)!important;color:var(--primary)!important;padding:10px 22px;border-radius:10px;font-weight:700!important;font-size:14px;transition:all .25s;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.2)}
.lang-switch{font-size:12px!important;font-weight:700!important;letter-spacing:.5px;padding:6px 10px;border:1.5px solid rgba(255,255,255,.3);border-radius:6px;transition:all .2s}
.lang-switch:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.5)}
.navbar.scrolled .lang-switch{border-color:var(--gray-200);color:var(--gray-500)!important}
.navbar.scrolled .lang-switch:hover{border-color:var(--primary);color:var(--primary)!important;background:rgba(30,94,240,.05)}
.nav-mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-mobile-toggle span{display:block;width:22px;height:2px;background:#fff;margin:5px 0;transition:all .3s;border-radius:2px}

/* Navbar scrolled state (white bg) */
.navbar.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 3px rgba(0,0,0,.08);padding:10px 0}
.navbar.scrolled .nav-logo-light{display:none}
.navbar.scrolled .nav-logo-dark{display:block}
.navbar.scrolled .nav-links a{color:var(--gray-600)}
.navbar.scrolled .nav-links a:hover{color:var(--navy)}
.navbar.scrolled .nav-cta{background:linear-gradient(to bottom right,#1E5EF0,#0D47A1)!important;color:#fff!important;box-shadow:0 2px 8px rgba(30,94,240,.25)}
.navbar.scrolled .nav-cta:hover{box-shadow:0 6px 20px rgba(30,94,240,.35)}
.navbar.scrolled .nav-mobile-toggle span{background:var(--navy)}

/* Mobile nav — full-screen overlay */
@media(max-width:768px){
  .nav-links{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100vh;background:var(--white);flex-direction:column;justify-content:center;align-items:center;gap:0;opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:999}
  .nav-links.open{opacity:1;pointer-events:auto}
  .nav-links a{font-size:20px;font-weight:600;color:var(--navy)!important;padding:16px 0;transition:color .2s}
  .nav-links a:hover{color:var(--primary)!important}
  .nav-cta.nav-cta{background:linear-gradient(to bottom right,#1E5EF0,#0D47A1)!important;color:#fff!important;padding:14px 36px;margin-top:16px;font-size:16px;border-radius:12px}
  .lang-switch.lang-switch{font-size:15px!important;padding:10px 20px;margin-top:24px;border-color:var(--gray-200);color:var(--gray-500)!important}
  .nav-mobile-toggle{display:block;z-index:1001}
  .nav-mobile-toggle.open span{background:var(--navy)}
  .nav-mobile-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  .nav-mobile-toggle.open span:nth-child(2){opacity:0}
  .nav-mobile-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
}

/* ═══ HERO (Dark Blue Gradient) ═══ */
.hero{padding:140px 0 80px;position:relative;overflow:hidden;background:var(--blue-gradient)}
.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-content{max-width:560px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.9);padding:6px 16px;border-radius:100px;font-size:13px;font-weight:600;margin-bottom:24px;border:1px solid rgba(255,255,255,.15)}
.hero h1{font-size:clamp(36px,5vw,56px);font-weight:800;color:#fff;margin-bottom:20px;letter-spacing:-.03em;line-height:1.08}
.hero p{font-size:18px;color:rgba(255,255,255,.7);margin-bottom:32px;line-height:1.7;max-width:480px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--white);color:var(--primary);padding:14px 30px;border-radius:10px;font-family:var(--font-heading);font-weight:700;font-size:15px;border:none;cursor:pointer;transition:all .25s;box-shadow:0 4px 14px rgba(0,0,0,.15)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;padding:14px 30px;border-radius:10px;font-family:var(--font-heading);font-weight:700;font-size:15px;border:1.5px solid rgba(255,255,255,.3);cursor:pointer;transition:all .25s}
.btn-secondary:hover{border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.08);transform:translateY(-2px)}

/* Phone Mockup */
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center;min-height:520px}
.phone-frame{width:280px;height:560px;background:#fff;border-radius:40px;padding:12px;position:relative;box-shadow:var(--shadow-2xl),inset 0 0 0 2px rgba(255,255,255,.2);transform:perspective(800px) rotateY(-5deg) rotateX(2deg);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.phone-frame:hover{transform:perspective(800px) rotateY(0deg) rotateX(0deg)}
.phone-notch{position:absolute;top:12px;left:50%;transform:translateX(-50%);width:100px;height:28px;background:#fff;border-radius:0 0 16px 16px;z-index:10}
.phone-screenshot{width:100%;height:100%;object-fit:contain;object-position:top;border-radius:30px;display:block;background:#F6FAFF}

/* Floating Badges */
.float-badge{position:absolute;background:rgba(255,255,255,.95);padding:10px 16px;border-radius:12px;box-shadow:var(--shadow-lg);font-size:13px;font-weight:600;color:var(--navy);white-space:nowrap;animation:float-gentle 3s ease-in-out infinite;border:1px solid rgba(255,255,255,.2)}
.float-badge .badge-val{font-size:18px;font-weight:800;font-family:var(--font-heading);display:block}
.float-badge .badge-lbl{font-size:11px;color:var(--gray-500);font-weight:500}
.float-badge.b1{top:40px;right:0;animation-delay:0s}
.float-badge.b2{bottom:120px;left:-20px;animation-delay:1s}
.float-badge.b3{bottom:40px;right:-10px;animation-delay:2s}
@keyframes float-gentle{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

@media(max-width:900px){
  .hero .container{grid-template-columns:1fr;text-align:center;gap:40px}
  .hero-content{max-width:100%;margin:0 auto}
  .hero p{margin-left:auto;margin-right:auto}
  .hero-ctas{justify-content:center}
  .hero-visual{min-height:auto}
  .phone-frame{transform:none}
  .phone-frame:hover{transform:none}
  .float-badge.b1{top:-10px;right:10%}
  .float-badge.b2{bottom:80px;left:5%}
  .float-badge.b3{bottom:-10px;right:10%}
}

/* ═══ SECTION HEADER (shared) ═══ */
.section-header{text-align:center;margin-bottom:60px}
.section-header h2{font-size:clamp(28px,4vw,42px);color:var(--navy);margin-bottom:16px;letter-spacing:-.02em;font-weight:800}
.section-header p{font-size:17px;color:var(--gray-500);max-width:560px;margin:0 auto}

/* ═══ WHY WORKPLACE WELLBEING MATTERS (white bg) ═══ */
.problem-stats{padding:100px 0;background:var(--white)}
.problem-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.problem-card{background:var(--off-white);border-radius:var(--radius-lg);padding:40px 32px;border:1px solid var(--gray-100);text-align:center;transition:all .3s cubic-bezier(.16,1,.3,1)}
.problem-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.problem-stat{font-size:clamp(40px,5vw,56px);font-weight:800;font-family:var(--font-heading);margin-bottom:12px;line-height:1;color:var(--primary)}
.problem-context{font-size:15px;color:var(--gray-600);line-height:1.6;margin-bottom:12px}
.problem-context strong{color:var(--navy)}
.problem-source{font-size:12px;color:var(--gray-400)}
.problem-source a{color:var(--gray-500);text-decoration:underline}
.problem-impact{font-size:14px;font-weight:600;color:var(--navy);margin-top:16px;padding-top:16px;border-top:1px solid var(--gray-200);line-height:1.6}
.problem-sources{display:flex;flex-wrap:wrap;gap:4px 16px;justify-content:center;margin-top:12px}
.problem-sources span{font-size:12px;color:var(--gray-400)}
.problem-sources a{color:var(--gray-500);text-decoration:underline}
.problem-callout{text-align:center;font-size:16px;color:var(--gray-600);margin-top:48px;line-height:1.7;max-width:600px;margin-left:auto;margin-right:auto}
.problem-callout strong{color:var(--primary)}
@media(max-width:768px){.problem-stats-grid{grid-template-columns:1fr}}

/* ═══ HOW SPRINT28 WORKS (subtle light blue bg) ═══ */
.how-it-works{padding:100px 0;position:relative;background:var(--white)}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;position:relative}
.steps-grid::before{content:'';position:absolute;top:44px;left:calc(16.67% + 20px);right:calc(16.67% + 20px);height:2px;background:linear-gradient(90deg,#0D47A1,#1E5EF0);opacity:.15;z-index:0}
.step-card{text-align:center;position:relative;z-index:1}
.step-number{width:64px;height:64px;border-radius:50%;background:linear-gradient(to bottom right,#1E5EF0,#0D47A1);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:24px;font-weight:800;margin:0 auto 24px;box-shadow:0 4px 14px rgba(30,94,240,.3)}
.step-card h3{font-size:19px;margin-bottom:10px;color:var(--navy)}
.step-card p{font-size:14px;color:var(--gray-500);line-height:1.7;max-width:300px;margin:0 auto}
@media(max-width:768px){.steps-grid{grid-template-columns:1fr;gap:48px}.steps-grid::before{display:none}}

/* How it works — benefits row */
.hiw-benefits{display:flex;justify-content:center;flex-wrap:wrap;gap:12px 32px;margin-top:56px;padding-top:40px;border-top:1px solid var(--gray-200)}
.hiw-benefit{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--navy)}
.hiw-benefit svg{color:var(--primary);flex-shrink:0}

/* ═══ SPRINT THEMES (white bg) ═══ */
.themes{padding:100px 0;background:var(--subtle-blue)}
.themes-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:32px}
.themes-tab{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:100px;border:1px solid var(--gray-200);background:var(--off-white);color:var(--gray-500);font-family:var(--font-heading);font-weight:600;font-size:14px;cursor:pointer;transition:all .25s}
.themes-tab:hover{background:var(--gray-100);color:var(--navy)}
.themes-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.themes-panels{max-width:720px;margin:0 auto;position:relative}
.theme-panel{display:none;animation:panelFade .25s ease}
.theme-panel.active{display:block}
@keyframes panelFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.theme-card{background:var(--white);border-radius:var(--radius-lg);padding:36px 32px;border:1px solid var(--gray-100)}
.theme-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;background:var(--indigo-subtle);color:var(--primary)}
.theme-card h3{font-size:20px;margin-bottom:8px;color:var(--navy)}
.theme-card .theme-desc{font-size:14px;color:var(--gray-500);margin-bottom:20px;line-height:1.6}

/* Weekly progression */
.theme-weeks{display:grid;grid-template-columns:1fr 1fr;gap:16px 32px}
.theme-week{border-top:1px solid var(--gray-200);padding-top:12px}
.theme-week:nth-child(-n+2){border-top:none;padding-top:0}
.week-label{font-size:12px;font-weight:700;font-family:var(--font-heading);color:var(--navy);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.unlock-tag{font-size:10px;font-weight:600;color:var(--primary);background:var(--indigo-subtle);padding:2px 8px;border-radius:100px;margin-left:6px;text-transform:none;letter-spacing:0}
.week-actions{list-style:none;display:flex;flex-direction:column;gap:4px}
.week-actions li{font-size:13px;color:var(--gray-600);padding:4px 0;display:flex;align-items:center;gap:8px}
.week-actions li::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0}
.primary-action::before{background:var(--primary)}
.bonus-action{font-style:italic;color:var(--gray-400)!important}
.bonus-action::before{background:var(--warning)!important}

.themes-legend{display:flex;justify-content:center;gap:24px;margin-top:32px}
.themes-legend-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--gray-500);font-weight:500}
.legend-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.legend-dot--primary{background:var(--primary)}
.legend-dot--bonus{background:var(--warning)}
.themes-note{text-align:center;font-size:15px;color:var(--gray-500);margin-top:16px;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.7}
@media(max-width:600px){.themes-tabs{gap:6px}.themes-tab{padding:10px 16px;font-size:13px;gap:6px}.themes-tab svg{width:16px;height:16px}.theme-card{padding:28px 24px}.theme-weeks{gap:12px 20px}}

/* ═══ THE IMPACT ON YOUR TEAM (subtle light blue bg) ═══ */
.impact{padding:100px 0;background:var(--subtle-blue)}
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.impact-card{background:var(--white);border-radius:var(--radius-lg);padding:36px 28px;border:1px solid var(--gray-100);text-align:center;transition:all .3s cubic-bezier(.16,1,.3,1)}
.impact-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.impact-stat{font-size:clamp(32px,4vw,44px);font-weight:800;font-family:var(--font-heading);color:var(--primary);line-height:1;margin-bottom:8px}
.impact-label{font-size:14px;font-weight:700;font-family:var(--font-heading);color:var(--navy);margin-bottom:12px}
.impact-desc{font-size:14px;color:var(--gray-500);line-height:1.6;margin-bottom:16px}
.impact-source{font-size:12px;color:var(--gray-400)}
.impact-source a{color:var(--gray-500);text-decoration:underline}
@media(max-width:900px){.impact-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.impact-grid{grid-template-columns:1fr}}

/* ═══ APP SHOWCASE (blue gradient bg) ═══ */
.showcase{padding:100px 0;position:relative;overflow:hidden;background:var(--blue-gradient)}
.showcase .section-header h2{color:#fff}
.showcase .section-header p{color:rgba(255,255,255,.5)}
.showcase-phones{display:flex;justify-content:center;gap:32px;flex-wrap:wrap;position:relative;z-index:1}
.showcase-item{display:flex;flex-direction:column;align-items:center;gap:8px}
.showcase-item .screen-label{color:#fff;font-size:15px;font-weight:700;font-family:var(--font-heading);margin-top:12px}
.showcase-item .screen-desc{color:rgba(255,255,255,.5);font-size:13px}

/* Mini Phone Frame */
.mini-phone{width:240px;height:440px;background:#fff;border-radius:32px;padding:10px;box-shadow:var(--shadow-2xl),0 0 60px rgba(30,94,240,.15);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.showcase-item:first-child .mini-phone{transform:perspective(800px) rotateY(5deg) rotateX(2deg)}
.showcase-item:nth-child(2) .mini-phone{transform:perspective(800px) rotateY(0deg) rotateX(3deg)}
.showcase-item:last-child .mini-phone{transform:perspective(800px) rotateY(-5deg) rotateX(2deg)}
.showcase-item:first-child .mini-phone:hover{transform:perspective(800px) rotateY(0deg) rotateX(0deg) translateY(-8px)}
.showcase-item:nth-child(2) .mini-phone:hover{transform:perspective(800px) rotateY(0deg) rotateX(0deg) translateY(-8px)}
.showcase-item:last-child .mini-phone:hover{transform:perspective(800px) rotateY(0deg) rotateX(0deg) translateY(-8px)}
.mp-screenshot{width:100%;height:100%;object-fit:contain;object-position:top;border-radius:24px;display:block;background:#F6FAFF}

@media(max-width:768px){.showcase-phones{gap:24px}.mini-phone{width:200px;height:380px}.showcase-item .mini-phone{transform:none}.showcase-item .mini-phone:hover{transform:translateY(-8px)}}

/* ═══ QUOTES ═══ */
.quotes{padding:80px 0;background:var(--white)}
.quotes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.quote-card{text-align:center;padding:32px 24px}
.quote-photo{width:72px;height:72px;border-radius:50%;overflow:hidden;margin:0 auto 20px;background:var(--gray-100)}
.quote-photo img{width:100%;height:100%;object-fit:cover}
.quote-card blockquote{font-size:15px;color:var(--gray-600);line-height:1.7;font-style:italic;margin-bottom:20px}
.quote-author{font-size:15px;font-weight:700;font-family:var(--font-heading);color:var(--navy)}
.quote-title{font-size:13px;color:var(--gray-400);margin-top:2px}
.quote-source{display:inline-block;font-size:12px;color:var(--gray-400);margin-top:10px;text-decoration:underline;transition:color .2s}
.quote-source:hover{color:var(--primary)}
@media(max-width:768px){.quotes-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}

/* ═══ MISSION ═══ */
.mission{padding:80px 0;background:var(--white);text-align:center}
.mission-origin{font-size:clamp(16px,2vw,18px);color:var(--gray-400);line-height:1.7;max-width:600px;margin:0 auto 12px;font-style:italic}
.mission-goal{font-size:clamp(20px,3vw,26px);font-family:var(--font-heading);font-weight:800;color:var(--navy);line-height:1.4;max-width:600px;margin:0 auto;letter-spacing:-.02em}

/* ═══ PARTNER WITH SPRINT28 (white bg) ═══ */
.partner{padding:100px 0;background:var(--white)}
.partner-card{background:var(--off-white);border-radius:var(--radius-xl);padding:60px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;border:1px solid var(--gray-100)}
.partner-left h2{font-size:clamp(28px,3.5vw,36px);color:var(--navy);margin-bottom:16px;letter-spacing:-.02em}
.partner-left p{font-size:16px;color:var(--gray-600);line-height:1.7;margin-bottom:28px}
.partner-right{display:flex;flex-direction:column;gap:16px}
.partner-perk-card{background:var(--white);border-radius:var(--radius);padding:20px 24px;display:flex;align-items:center;gap:16px;border:1px solid var(--gray-100);transition:all .25s}
.partner-perk-card:hover{box-shadow:var(--shadow-md);border-color:transparent}
.perk-icon{width:44px;height:44px;border-radius:12px;background:var(--indigo-subtle);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.perk-label{font-size:14px;font-weight:600;color:var(--navy);line-height:1.4}
.btn-partner{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(to bottom right,#1E5EF0,#0D47A1);color:#fff;padding:14px 30px;border-radius:10px;font-family:var(--font-heading);font-weight:700;font-size:15px;border:none;cursor:pointer;transition:all .25s;box-shadow:0 4px 14px rgba(30,94,240,.25)}
.btn-partner:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(30,94,240,.35)}
.partner-note{font-size:13px;color:var(--gray-500);margin-top:16px}
@media(max-width:768px){.partner-card{grid-template-columns:1fr;padding:36px 28px;text-align:center}.partner-left p{margin-left:auto;margin-right:auto}}

/* ═══ PRICING (subtle light blue bg) ═══ */
.pricing{padding:100px 0;background:var(--subtle-blue)}
.pricing-calculator{max-width:560px;margin:0 auto;background:var(--white);border-radius:var(--radius-xl);padding:36px 48px;border:1px solid var(--gray-100);text-align:center;display:flex;align-items:center;gap:32px}
.pricing-label{display:block;font-size:15px;font-weight:600;color:var(--navy);margin-bottom:10px}
.pricing-input-side{flex:1}
.pricing-input{width:100%;padding:14px 20px;border-radius:10px;border:2px solid var(--gray-200);font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--navy);text-align:center;outline:none;transition:all .2s}
.pricing-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,94,240,.1)}
.pricing-input::placeholder{color:var(--gray-300);font-weight:500;font-size:16px}
.pricing-result{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}
.pricing-price{font-size:clamp(28px,4vw,38px);font-weight:800;font-family:var(--font-heading);color:var(--primary);line-height:1;white-space:nowrap;transition:color .2s, transform .25s cubic-bezier(.16,1,.3,1)}
.pricing-price--empty{color:var(--gray-300)}
.pricing-period{font-size:13px;color:var(--gray-400);font-weight:500;margin-top:6px}
.pricing-cta{text-align:center;margin-top:40px}
.price-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;text-align:center;padding:16px 40px;border-radius:10px;font-family:var(--font-heading);font-weight:700;font-size:16px;cursor:pointer;transition:all .25s;border:none}
.price-btn.primary{background:linear-gradient(to bottom right,#1E5EF0,#0D47A1);color:#fff;box-shadow:0 4px 14px rgba(30,94,240,.25)}
.price-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(30,94,240,.35)}
.pricing-note{font-size:14px;color:var(--gray-500);margin-top:16px}
@media(max-width:600px){.pricing-calculator{flex-direction:column;gap:24px;padding:32px 24px}}


/* ═══ FAQ (white bg) ═══ */
.faq{padding:100px 0;background:var(--white)}
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--gray-200)}
.faq-question{width:100%;background:none;border:none;padding:20px 0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-family:var(--font-heading);font-size:16px;font-weight:600;color:var(--navy);text-align:left;transition:color .2s}
.faq-question:hover{color:var(--indigo)}
.faq-icon{width:28px;height:28px;border-radius:8px;background:var(--gray-100);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--gray-400);transition:all .3s;flex-shrink:0}
.faq-item.open .faq-icon{background:var(--indigo-subtle);color:var(--indigo);transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.16,1,.3,1)}
.faq-answer p{padding:0 0 20px;font-size:15px;color:var(--gray-500);line-height:1.7}

/* ═══ FINAL CTA / CONTACT FORM (blue gradient bg) ═══ */
.final-cta{padding:100px 0;position:relative;overflow:hidden;background:var(--blue-gradient)}
.final-cta .container{text-align:center;position:relative;z-index:1}
.final-cta h2{font-size:clamp(28px,4vw,42px);color:#fff;margin-bottom:16px;letter-spacing:-.02em}
.final-cta p{font-size:17px;color:rgba(255,255,255,.7);max-width:520px;margin:0 auto 40px}

/* Contact form */
.contact-form{max-width:520px;margin:0 auto;text-align:left}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form .form-group{margin-bottom:16px}
.contact-form label{display:block;font-size:13px;font-weight:600;color:rgba(255,255,255,.8);margin-bottom:6px}
.contact-form input,
.contact-form textarea{width:100%;padding:12px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.15);font-family:var(--font-body);font-size:16px;background:rgba(255,255,255,.1);color:#fff;outline:none;transition:all .2s;resize:vertical}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:rgba(255,255,255,.35)}
.contact-form input:focus,
.contact-form textarea:focus{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.4);box-shadow:0 0 0 3px rgba(255,255,255,.1)}
.contact-submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;margin-top:8px;background:var(--white);color:var(--primary);border:none;border-radius:10px;font-family:var(--font-heading);font-weight:700;font-size:15px;cursor:pointer;transition:all .25s;box-shadow:0 4px 14px rgba(0,0,0,.15)}
.contact-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.contact-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}
.form-success{text-align:center;padding:24px;background:rgba(255,255,255,.15);border-radius:10px;margin-top:12px}
.form-success p{color:var(--white);font-size:17px;font-weight:600;margin:0}
@media(max-width:500px){.contact-form .form-row{grid-template-columns:1fr}}

/* ═══ FOOTER ═══ */
.footer{padding:48px 0;background:var(--white);border-top:1px solid var(--gray-100)}
.footer .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px}
.footer-brand{display:flex;align-items:center;gap:10px;color:var(--gray-500);font-size:13px}
.footer-brand img{height:24px;width:auto}
.footer-links{display:flex;gap:28px}
.footer-links a{font-size:13px;color:var(--gray-400);transition:color .2s}
.footer-links a:hover{color:var(--navy)}
.footer-social{display:flex;gap:12px}
.footer-social a{width:34px;height:34px;border-radius:8px;background:var(--gray-100);display:flex;align-items:center;justify-content:center;color:var(--gray-400);font-size:14px;transition:all .2s}
.footer-social a:hover{background:var(--gray-200);color:var(--navy)}
@media(max-width:600px){.footer .container{flex-direction:column;text-align:center}.footer-links{flex-wrap:wrap;justify-content:center}}

/* ═══ LEGAL PAGES ═══ */
.legal-page{padding:140px 0 80px;background:var(--white);min-height:60vh}
.legal-page h1{font-size:clamp(28px,4vw,42px);color:var(--navy);margin-bottom:8px;letter-spacing:-.02em}
.legal-updated{font-size:14px;color:var(--gray-400);margin-bottom:40px}
.legal-page h2{font-size:20px;color:var(--navy);margin-top:36px;margin-bottom:12px}
.legal-page h3{font-size:16px;color:var(--navy);margin-top:24px;margin-bottom:8px}
.legal-page p{font-size:15px;color:var(--gray-600);line-height:1.7;margin-bottom:12px;max-width:720px}
.legal-page ul{margin:0 0 16px 24px;max-width:720px}
.legal-page li{font-size:15px;color:var(--gray-600);line-height:1.7;margin-bottom:4px}
.legal-page a{color:var(--primary);text-decoration:underline}

/* ═══ COOKIE CONSENT BANNER ═══ */
.cookie-overlay{position:fixed;inset:0;z-index:9998;background:rgba(0,0,0,.5);backdrop-filter:blur(2px);animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--white);border-top:1px solid var(--border);box-shadow:0 -4px 24px rgba(0,0,0,.12);padding:32px 24px;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.cookie-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.cookie-content p{margin:0;font-size:15px;color:var(--gray-500);line-height:1.6}
.cookie-content a{color:var(--primary);text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-btn{padding:12px 24px;border-radius:8px;font-family:var(--font-heading);font-weight:600;font-size:14px;cursor:pointer;border:none;transition:all .2s}
.cookie-btn.primary{background:var(--primary);color:#fff}
.cookie-btn.primary:hover{background:var(--primary-hover)}
.cookie-btn.secondary{background:var(--gray-100);color:var(--navy)}
.cookie-btn.secondary:hover{background:var(--gray-200)}
@media(max-width:600px){.cookie-content{flex-direction:column;text-align:center}.cookie-actions{width:100%}.cookie-btn{flex:1}}
