/* ─── RESET ─── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* ─── DESIGN TOKENS ─── */
:root{
  --blue:#2540f5;
  --blue-soft:#4d63f8;
  --blue-pale:#e8ecff;
  --blue-wash:#dde2f8;
  --teal:#10c6a0;
  --teal-soft:#3dd4b5;
  --teal-pale:#e4fbf4;

  --ink:#111827;
  --ink-2:#1f2937;
  --ink-3:#374151;
  --ink-4:#6b7280;
  --ink-5:#b8bcc8;
  --ink-6:#d0d4de;

  --glass:rgba(255,255,255,0.4);
  --glass-strong:rgba(255,255,255,0.6);
  --glass-border:rgba(255,255,255,0.6);
  --glass-hover:rgba(255,255,255,0.62);
  --glass-shadow:0 8px 32px rgba(0,0,0,0.08);

  --bg:#d8dce5;
  --font:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  --max-w:1080px;
  --nav-h:60px;
  --radius:16px;
  --radius-sm:10px;
  --tr:0.25s cubic-bezier(0.4,0,0.2,1);
}

/* ─── HEADLINE FONT ─── */
@font-face{
  font-family:'Headline';
  src:url('fonts/PlusJakartaSans-ExtraBoldItalic.woff2') format('woff2');
  font-weight:normal;font-style:normal;font-display:swap;
}

/* ─── ITALIC FONT (variable, declared as style:normal so it can be used via font-family without font-style:italic) ─── */
@font-face{
  font-family:'Jakarta Italic';
  src:url('fonts/PlusJakartaSans-Italic-VariableFont_wght.ttf') format('truetype-variations');
  font-weight:100 900;font-style:normal;font-display:swap;
}

input::placeholder,
textarea::placeholder{
  font-family:'Jakarta Italic',var(--font);
}

/* ─── ICON FONT ─── */
@font-face{
  font-family:'icons';
  src:url('fonts/icons.woff2') format('woff2'),url('fonts/icons.woff') format('woff');
  font-weight:normal;font-style:normal;font-display:swap;
}
[class^="i-"]::before,[class*=" i-"]::before{
  font-family:'icons';font-style:normal;font-weight:normal;
  display:inline-block;text-decoration:inherit;
  width:1em;line-height:1em;text-align:center;
  -webkit-font-smoothing:antialiased;
}
.i-flash::before{content:'\e825'}
.i-shield::before{content:'\f132'}
.i-globe::before{content:'\e821'}
.i-link::before{content:'\e813'}
.i-heart::before{content:'\e82b'}
.i-stats::before{content:'\e810'}
.i-ok::before{content:'\e81a'}
.i-tag::before{content:'\e827'}
.i-eye::before{content:'\e817'}
.i-cog::before{content:'\e82a'}
.i-bell::before{content:'\f0f3'}
.i-truck::before{content:'\e828'}
.i-leaf::before{content:'\e822'}
.i-recycle::before{content:'\f1b8'}
.i-building::before{content:'\e829'}
.i-key::before{content:'\e811'}
.i-certificate::before{content:'\e82e'}
.i-communication::before{content:'\e81e'}
.i-menu::before{content:'\f0c9'}

/* ─── TYPE TOKENS ─── */
:root{
  --text-xs:  0.75rem;   /* 11.25px — eyebrows, trust badges, TOC labels */
  --text-sm:  0.85rem;   /* 12.75px — form labels, meta, captions */
  --text-base:1rem;      /* 15px    — body copy, form inputs, cards, options */
  --text-md:  1.1rem;    /* 16.5px  — card titles, small section headings */
  --text-lg:  1.25rem;   /* 18.75px — section intros, H3 on content pages */
  --text-xl:  1.5rem;    /* 22.5px  — H3 / small H2 */
}

/* ─── BASE ─── */
html{
  font-size:15px;
  scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 16px);
  scrollbar-gutter:stable;
  scrollbar-width:thin;
  scrollbar-color:rgba(0,0,0,0.2) transparent;
}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{
  background:rgba(0,0,0,0.2);border-radius:4px;
}
::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,0.35)}
body{
  font-family:var(--font);
  background:
    radial-gradient(circle 180px at 10% 15%,rgba(16,198,160,0.1) 0%,transparent 100%),
    radial-gradient(circle 250px at 90% 10%,rgba(20,180,140,0.08) 0%,transparent 100%),
    radial-gradient(circle 200px at 45% 35%,rgba(16,198,160,0.07) 0%,transparent 100%),
    radial-gradient(circle 300px at 15% 55%,rgba(14,210,150,0.1) 0%,transparent 100%),
    radial-gradient(circle 220px at 80% 50%,rgba(16,198,160,0.08) 0%,transparent 100%),
    radial-gradient(circle 280px at 55% 75%,rgba(20,190,145,0.07) 0%,transparent 100%),
    radial-gradient(circle 180px at 25% 90%,rgba(16,198,160,0.08) 0%,transparent 100%),
    radial-gradient(circle 240px at 70% 85%,rgba(14,210,150,0.06) 0%,transparent 100%),
    radial-gradient(circle 150px at 50% 15%,rgba(16,198,160,0.05) 0%,transparent 100%),
    radial-gradient(circle 200px at 30% 70%,rgba(20,180,140,0.04) 0%,transparent 100%),
    linear-gradient(175deg,#d6e0f5 0%,#e0e8f8 50%,#f0f3f9 100%);
  background-attachment:fixed;
  color:var(--ink-3);
  font-size:var(--text-base);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ─── BACKGROUND SHAPES ─── */
.bg-shapes{
  position:fixed;top:0;left:-5%;
  width:110%;height:100vh;height:100lvh;
  z-index:-1;overflow:hidden;pointer-events:none;
}
.bg-shapes svg{
  position:absolute;
  width:100%;height:100%;
  will-change:transform;
}
.bg-shapes svg:nth-child(1){animation:drift1 16s ease-in-out infinite}
.bg-shapes svg:nth-child(2){animation:drift2 20s ease-in-out infinite}
.bg-shapes svg:nth-child(3){animation:drift3 14s ease-in-out infinite}
.bg-shapes svg:nth-child(4){animation:drift4 18s ease-in-out infinite}
.bg-shapes svg:nth-child(5){animation:drift5 23s ease-in-out infinite}

@keyframes drift1{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(20px,-20px) scale(1.03)}
}
@keyframes drift2{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-20px,-15px) scale(1.02)}
}
@keyframes drift3{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(15px,-25px) scale(1.04)}
}
@keyframes drift4{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-15px,-10px) scale(1.02)}
}
@keyframes drift5{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(20px,-18px) scale(1.03)}
}

/* ─── REVEAL ANIMATION ─── */
.rv{opacity:0;transform:translateY(20px);transition:opacity 0.6s var(--tr),transform 0.6s var(--tr)}
.rv.v{opacity:1;transform:none}
.rv.d1{transition-delay:0.08s}
.rv.d2{transition-delay:0.16s}
.rv.d3{transition-delay:0.24s}
.rv.d4{transition-delay:0.32s}
.rv.d5{transition-delay:0.4s}

/* ─── NAV ─── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);display:flex;align-items:center;
  background:transparent;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  border-bottom:1px solid transparent;
  transition:background 0.4s,backdrop-filter 0.4s,border-color 0.4s,box-shadow 0.4s;
}
.nav.scrolled{
  background:rgba(216,220,229,0.55);
  backdrop-filter:blur(20px) saturate(1.3);
  -webkit-backdrop-filter:blur(20px) saturate(1.3);
  border-bottom-color:rgba(255,255,255,0.6);
  box-shadow:0 1px 8px rgba(0,0,0,0.04);
}
.nav.nav-dark{
  background:rgba(17,24,39,0.7);
  backdrop-filter:blur(20px) saturate(1.3);
  -webkit-backdrop-filter:blur(20px) saturate(1.3);
  border-bottom-color:rgba(255,255,255,0.08);
}
.nav.nav-dark .nav-links a{color:rgba(255,255,255,0.6)}
.nav.nav-dark .nav-links a:hover{color:#fff;background:rgba(255,255,255,0.08)}
.nav.nav-dark .btn-ghost{color:rgba(255,255,255,0.7);border-color:rgba(255,255,255,0.2)}
.nav.nav-dark .btn-ghost:hover{color:#fff;border-color:rgba(255,255,255,0.4)}
.nav.nav-dark .nav-toggle{color:#fff}
.nav-inner{
  width:100%;max-width:var(--max-w);margin:0 auto;
  padding:0 24px;display:flex;align-items:center;justify-content:space-between;
  position:relative;z-index:1;
}
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{height:22px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links a{
  font-size:var(--text-base);font-weight:500;color:var(--ink-3);
  text-decoration:none;padding:7px 14px;border-radius:8px;transition:var(--tr);
}
.nav-links a:hover{color:var(--blue);background:var(--blue-pale)}
.nav-cta{display:flex;gap:8px;align-items:center}
.mobile-cta{display:none;list-style:none}

/* ─── BUTTONS ─── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-family:var(--font);font-size:var(--text-sm);font-weight:700;line-height:1.2;
  padding:9px 20px;border-radius:8px;border:none;cursor:pointer;
  text-decoration:none;transition:var(--tr);
}
.btn-fill{background:var(--blue);color:#fff}
.btn-fill:hover{background:var(--blue-soft);transform:translateY(-1px);box-shadow:0 4px 16px rgba(37,64,245,0.25)}
.btn-ghost{background:transparent;color:var(--ink-3);border:1px solid var(--ink-6)}
.btn-ghost:hover{border-color:var(--ink-5);color:var(--ink)}
.btn-lg{font-size:var(--text-base);padding:14px 32px;border-radius:var(--radius-sm)}
.btn-teal{background:var(--teal);color:#fff}
.btn-teal:hover{background:var(--teal-soft);transform:translateY(-1px);box-shadow:0 4px 16px rgba(16,198,160,0.3)}
.btn-white{background:#fff;color:var(--ink)}
.btn-white:hover{background:var(--ink-6);transform:translateY(-1px)}

.nav-toggle{
  display:none;align-items:center;justify-content:center;
  background:none;border:none;cursor:pointer;
  padding:8px;font-size:1.4rem;color:var(--blue);
  transition:color 0.2s ease;
  outline:none;-webkit-tap-highlight-color:transparent;
}
.nav-toggle:focus,.nav-toggle:focus-visible{outline:none}
.nav-toggle::before{
  font-family:'icons';content:'\f0c9';
  display:inline-block;line-height:1;
}

/* ─── SECTIONS ─── */
section{padding:80px 24px;position:relative;overflow:hidden}
.container{max-width:var(--max-w);margin:0 auto;position:relative;z-index:1}
.section-head{text-align:center;margin-bottom:40px}
.section-label{
  font-size:0.7rem;font-weight:700;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--blue);margin-bottom:12px;
}
.section-title{
  font-size:clamp(1.6rem,3.2vw,2.2rem);
  font-weight:800;color:var(--ink);letter-spacing:-0.025em;
  line-height:1.15;margin-bottom:14px;
}
.section-desc{font-size:var(--text-base);color:var(--ink-3);max-width:500px;margin:0 auto;line-height:1.7}

/* ─── FROSTED SECTION ─── */
.frosted{
  background:rgba(255,255,255,0.35);
  backdrop-filter:blur(40px) saturate(1.2);
  -webkit-backdrop-filter:blur(40px) saturate(1.2);
  border-top:1px solid rgba(255,255,255,0.5);
  border-bottom:1px solid rgba(255,255,255,0.5);
}
.frosted .glass{
  background:#fff;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  border-color:#e8eaef;
  box-shadow:0 2px 8px rgba(0,0,0,0.04);
}

/* ─── GLASS CARD ─── */
.glass{
  background:var(--glass);
  backdrop-filter:blur(20px) saturate(1.3);
  -webkit-backdrop-filter:blur(20px) saturate(1.3);
  border:1px solid rgba(255,255,255,0.45);
  border-top-color:rgba(255,255,255,0.6);
  border-left-color:rgba(255,255,255,0.5);
  border-radius:var(--radius);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.3),
    inset 0 0 0 1px rgba(255,255,255,0.05),
    0 4px 16px rgba(0,0,0,0.04);
  transition:var(--tr);
  transform:translateZ(0);
}
@media(max-width:768px){
  .glass{
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    background:rgba(255,255,255,0.55);
  }
}

/* ─── DARK SECTION ─── */
.dark{
  background:var(--ink);
  color:rgba(255,255,255,0.6);
  position:relative;overflow:hidden;
}
.dark::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 25% 40%,rgba(37,64,245,0.12) 0%,transparent 50%),
    radial-gradient(ellipse at 75% 60%,rgba(16,198,160,0.08) 0%,transparent 50%);
  background-attachment:fixed;
  pointer-events:none;
}
.dark *{position:relative}
.dark .glass{
  background:rgba(255,255,255,0.06);
  border-color:rgba(255,255,255,0.10);
  border-top-color:rgba(255,255,255,0.15);
  border-left-color:rgba(255,255,255,0.12);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 0 0 1px rgba(255,255,255,0.03),
    0 4px 16px rgba(0,0,0,0.2);
}
.dark .glass h3{color:#fff}
.dark .glass p{color:rgba(255,255,255,0.55)}
.dark .section-label{color:var(--teal)}
.dark .section-title{color:#fff}
.dark .section-desc{color:rgba(255,255,255,0.5)}
.dark h2{color:#fff}
.dark p{color:rgba(255,255,255,0.55)}

/* ─── SPLIT SECTION ─── */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
}
.split-text h2{
  font-size:clamp(1.5rem,3vw,2rem);font-weight:800;color:var(--ink);
  letter-spacing:-0.02em;line-height:1.2;margin-bottom:16px;
}
.split-text p{font-size:var(--text-base);color:var(--ink-3);line-height:1.7;margin-bottom:24px}
.split-list{list-style:none;display:flex;flex-direction:column;gap:12px}
.split-list li{
  font-size:var(--text-base);color:var(--ink-2);display:flex;align-items:center;gap:10px;
}
.split-list li::before{
  content:'';width:7px;height:7px;background:var(--teal);border-radius:50%;flex-shrink:0;
}
.split-visual{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat-card{padding:24px 20px}
.stat-val{font-size:1.5rem;font-weight:800;color:var(--ink);letter-spacing:-0.02em;margin-bottom:4px}
.stat-label{font-size:0.74rem;color:var(--ink-4);font-weight:500;line-height:1.4}
.stat-card:nth-child(2) .stat-val{color:var(--blue)}
.stat-card:nth-child(3) .stat-val{color:var(--teal)}

.dark .split-text h2{color:#fff}
.dark .split-text p{color:rgba(255,255,255,0.55)}
.dark .split-list li{color:rgba(255,255,255,0.7)}
.dark .split-list li::before{background:var(--teal)}
.dark .stat-card{
  background:rgba(255,255,255,0.06);
  border-color:rgba(255,255,255,0.1);
  backdrop-filter:blur(12px);
}
.dark .stat-val{color:#fff}
.dark .stat-card:nth-child(2) .stat-val{color:var(--blue-soft)}
.dark .stat-card:nth-child(3) .stat-val{color:var(--teal)}
.dark .stat-label{color:rgba(255,255,255,0.4)}

/* ─── FEATURES ─── */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.feature{padding:24px}
.feature h3{
  font-size:var(--text-base);font-weight:700;color:var(--ink);margin-bottom:8px;
  display:flex;align-items:center;gap:8px;
}
.feature h3 [class^="i-"]{font-size:1.1rem;color:var(--ink-3)}
.feature p{font-size:var(--text-base);color:var(--ink-3);line-height:1.6}

/* ─── STEPS ─── */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
.steps::before{
  content:'';position:absolute;top:28px;left:12.5%;right:12.5%;height:1px;
  background:linear-gradient(90deg,transparent,var(--ink-6) 15%,var(--ink-6) 85%,transparent);z-index:0;
}
.step{text-align:center;position:relative;z-index:1}
.step-num{
  width:44px;height:44px;margin:0 auto 14px;border-radius:50%;
  background:var(--glass-strong);border:2px solid var(--glass-border);
  backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;
  font-size:0.85rem;font-weight:800;color:var(--blue);
  transition:var(--tr);
}
.step h3{font-size:var(--text-base);font-weight:700;color:var(--ink);margin-bottom:6px}
.step p{font-size:var(--text-base);color:var(--ink-4);line-height:1.55}

/* ─── TIMELINE ─── */
.timeline{display:flex;gap:16px}
.timeline-item{padding:28px 24px;flex:1;display:flex;gap:16px;align-items:flex-start}
.timeline-year{
  font-size:1.8rem;font-weight:800;color:var(--blue);
  letter-spacing:-0.03em;line-height:1;flex-shrink:0;
}
.timeline-text strong{font-size:var(--text-base);color:var(--ink);display:block;margin-bottom:4px}
.timeline-text p{font-size:var(--text-base);color:var(--ink-3);line-height:1.55;margin:0}
@media(max-width:768px){.timeline{flex-direction:column}}

/* ─── TAGS ─── */
.tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
a.tag{
  font-size:var(--text-base);font-weight:500;color:var(--ink-3);
  padding:9px 20px;border-radius:100px;text-decoration:none;
  background:var(--glass);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.4);transition:var(--tr);
}
a.tag:hover{border-color:var(--blue);color:var(--blue);background:rgba(232,236,255,0.5)}

/* ─── PRICING ─── */
.pricing-single{max-width:520px;margin:0 auto}
.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:780px;margin:0 auto}
.price-card{padding:40px 32px;display:flex;flex-direction:column}
.price-card.featured{
  border-color:rgba(37,64,245,0.12);
  background:rgba(240,243,255,0.55);
  backdrop-filter:blur(20px);
}
.dark .price-card{
  background:rgba(255,255,255,0.06);
  border-color:rgba(255,255,255,0.1);
  backdrop-filter:blur(12px);
}
.dark .price-card.featured{
  background:rgba(255,255,255,0.08);
  border-color:rgba(37,64,245,0.3);
}
.dark .price-name{color:#fff}
.dark .price-desc{color:rgba(255,255,255,0.5)}
.dark .price-amount{color:#fff}
.dark .price-old{color:rgba(255,255,255,0.35)}
.dark .price-note{color:rgba(255,255,255,0.4)}
.dark .price-list li{color:rgba(255,255,255,0.7)}
.dark .price-badge{background:var(--teal)}
.price-badge{
  font-size:0.65rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  color:#fff;background:var(--blue);padding:3px 10px;border-radius:4px;
  width:fit-content;margin-bottom:20px;
}
.price-name{font-size:1.3rem;font-weight:700;color:var(--ink);margin-bottom:6px}
.price-desc{font-size:var(--text-base);color:var(--ink-4);margin-bottom:20px;line-height:1.55}
.price-amount{font-size:2.2rem;font-weight:800;color:var(--ink);line-height:1;letter-spacing:-0.03em}
.price-old{color:var(--ink-4);font-size:1.3rem;font-weight:500;text-decoration:line-through;margin-right:8px}
.price-note{font-size:0.75rem;color:var(--ink-4);margin-top:6px;margin-bottom:28px}
.price-features{display:grid;grid-template-columns:1fr 1fr;gap:0 24px;margin-bottom:32px}
.price-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:32px;flex:1}
.price-list li{font-size:var(--text-base);color:var(--ink-2);display:flex;align-items:flex-start;gap:10px;line-height:1.4}
.price-check{
  width:16px;height:16px;flex-shrink:0;border-radius:50%;
  background:var(--teal-pale);position:relative;margin-top:2px;
}
.price-check::after{
  content:'';position:absolute;width:4px;height:7px;
  border:solid var(--teal);border-width:0 1.5px 1.5px 0;
  transform:rotate(45deg);top:3px;left:5.5px;
}

.price-more{font-size:0.78rem;color:var(--ink-4);margin-top:14px;text-align:center}
.price-more a{color:var(--teal);text-decoration:none;font-weight:600;transition:var(--tr)}
.price-more a:hover{color:var(--blue)}

/* ─── CTA ─── */
.cta{
  padding:100px 24px;text-align:center;
  background:var(--ink);position:relative;overflow:hidden;
}
.cta::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 25% 50%,rgba(37,64,245,0.15) 0%,transparent 50%),
    radial-gradient(ellipse at 75% 50%,rgba(16,198,160,0.1) 0%,transparent 50%);
  pointer-events:none;
}
.cta-box{
  max-width:var(--max-w);margin:0 auto;position:relative;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--radius);
  padding:48px;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.cta-box h2{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;color:#fff;letter-spacing:-0.02em;margin-bottom:14px}
.cta-box p{font-size:var(--text-base);color:rgba(255,255,255,0.6);margin-bottom:32px;max-width:460px;margin-left:auto;margin-right:auto;line-height:1.6}

.pricing-cta{
  text-align:center;font-size:1rem;
  color:rgba(255,255,255,0.5);
  margin-top:48px;margin-bottom:20px;
  max-width:460px;margin-left:auto;margin-right:auto;
}

/* ─── FOOTER ─── */
.footer{
  padding:56px 24px 0;
  border-top:1px solid rgba(255,255,255,0.3);
  background:transparent;
  backdrop-filter:none;
  -webkit-backdrop-filter:blur(40px) saturate(1.2);
}
.footer-inner{
  max-width:var(--max-w);margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:40px;
}
.footer-brand{display:flex;align-items:center;margin-bottom:12px}
.footer-brand img{height:18px;width:auto;display:block}
.footer-desc{font-size:var(--text-base);color:var(--ink-3);line-height:1.6;max-width:280px}
.footer-col h4{font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.footer-col a{display:block;font-size:var(--text-base);color:var(--ink-2);text-decoration:none;padding:3px 0;transition:var(--tr)}
.footer-col a:hover{color:var(--blue)}
.footer-bottom{
  max-width:var(--max-w);margin:0 auto;
  padding:20px 0;border-top:1px solid rgba(0,0,0,0.08);
  display:flex;justify-content:space-between;align-items:center;
  font-size:0.78rem;color:var(--ink-3);
}
.footer-links{display:flex;gap:20px}
.footer-links a{color:var(--ink-3);text-decoration:none;transition:var(--tr)}
.footer-links a:hover{color:var(--blue)}

/* ─── PAGE HEADER (subpages) ─── */
.page-header{
  padding:calc(var(--nav-h) + 60px) 24px 48px;
  text-align:center;position:relative;overflow:hidden;
}
.page-header h1{
  font-size:clamp(1.8rem,4vw,2.6rem);
  font-weight:800;color:var(--ink);
  line-height:1.15;letter-spacing:-0.03em;margin-bottom:14px;
}
.page-header .section-desc{margin-bottom:0}

/* ─── CONTENT CARD (white surface) ─── */
.content-card{
  background:#fff;
  border-radius:var(--radius);
  padding:48px;
  box-shadow:0 1px 4px rgba(0,0,0,0.04);
  border:1px solid rgba(0,0,0,0.04);
}

/* ─── RESPONSIVE ─── */
@media(max-width:768px){
  .features{grid-template-columns:1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
  .steps::before{display:none}
  .split{grid-template-columns:1fr;gap:32px}
  .split-visual{grid-template-columns:1fr 1fr}
  .pricing{grid-template-columns:1fr;max-width:400px}
  .footer-inner{grid-template-columns:1fr 1fr;gap:24px}
  .nav-links{
    display:none;flex-direction:column;gap:0;
    position:fixed;top:calc(var(--nav-h) - 1px);left:0;right:0;
    background:linear-gradient(180deg,var(--blue) 0%,#6b7dfa 100%);
    padding:8px 0 16px;
    z-index:1000;
  }
  .nav-links.open{display:flex}
  .nav-links li{list-style:none}
  .nav-links a{
    font-size:var(--text-base);font-weight:500;
    color:rgba(255,255,255,0.85);
    padding:10px 20px;display:block;width:100%;
    transition:var(--tr);
  }
  .nav-links a:hover{color:#fff;background:rgba(255,255,255,0.1)}
  .nav-links .mobile-cta{
    display:flex;gap:8px;padding:14px 20px;
    margin-top:4px;border-top:1px solid rgba(255,255,255,0.15);
  }
  .nav-links .mobile-cta .btn{color:#fff;border-color:rgba(255,255,255,0.4)}
  .nav-links .mobile-cta .btn-fill{background:#fff;color:var(--blue);border-color:#fff}
  .nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav::before{
    content:'';position:absolute;inset:0;
    background:var(--blue);
    border-radius:0;
    opacity:0;
    transition:opacity 0.2s ease;
    z-index:0;
  }
  .nav.menu-open::before{opacity:1}
  .nav.menu-open{border-bottom-color:transparent;box-shadow:none}
  .nav.menu-open .logo img{filter:brightness(0) invert(1)}
  .nav.menu-open .nav-toggle{color:#fff}
  .content-card{padding:28px 20px}
  .page-header{padding:calc(var(--nav-h) + 40px) 24px 32px}
  section{padding:48px 24px}
  .cta{padding:48px 24px}
}
@media(max-width:480px){
  .steps{grid-template-columns:1fr}
  .split-visual{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .price-amount{font-size:1.7rem}
  .price-old{font-size:1rem;margin-right:6px}
}
@media(max-width:360px){
  .footer-inner{grid-template-columns:1fr}
}

/* ─── TomSelect — match form input style ─── */
.ts-wrapper{width:100%;position:relative;box-sizing:border-box}
.ts-wrapper .ts-control,
.ts-wrapper.single .ts-control,
.ts-wrapper.single.input-active .ts-control{
  font-family:var(--font);font-size:var(--text-base);line-height:1.4;
  padding:0 40px 0 14px;min-height:42px;height:42px;
  width:100%;box-sizing:border-box;
  border-radius:8px;
  border:1px solid var(--ink-6);
  background-color:rgba(255,255,255,0.7);
  background-image:none !important;
  color:var(--ink);
  box-shadow:none;
  transition:border-color 0.15s ease,box-shadow 0.15s ease;
  display:flex;align-items:center;
}
.ts-wrapper.focus .ts-control,
.ts-wrapper.dropdown-active .ts-control{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(37,64,245,0.1);
  outline:none;
}
.ts-wrapper .ts-control > input{
  font-family:var(--font);font-size:var(--text-base);color:var(--ink);
  background:transparent;
}
.ts-wrapper .ts-control > input::placeholder{
  font-family:'Jakarta Italic',var(--font);color:var(--ink-4);
}
.ts-wrapper .ts-control > .item{
  color:var(--ink);font-size:var(--text-base);
}
/* With controlInput:null there's no search input — selected
   item stays visible in the control at all times. */
/* Chevron — pure CSS triangle via clip-path */
.ts-wrapper.single .ts-control::after{
  content:'';
  position:absolute;right:14px;top:50%;margin-top:-3px;
  width:10px;height:6px;
  background-color:var(--ink-4);
  clip-path:polygon(0 0, 100% 0, 50% 100%);
  pointer-events:none;transition:transform 0.15s ease;
}
.ts-wrapper.single.dropdown-active .ts-control::after{
  transform:rotate(180deg);
}
/* Active control connects to dropdown: flat bottom, blue all around */
.ts-wrapper.dropdown-active .ts-control,
.ts-wrapper.single.dropdown-active .ts-control{
  border-radius:8px 8px 0 0 !important;
  border-color:var(--blue);
  border-bottom-color:transparent;
}
section.dark .ts-wrapper.dropdown-active .ts-control,
section.dark .ts-wrapper.single.dropdown-active .ts-control{
  background-color:#1f2937;
  border-color:var(--blue-soft);
  border-bottom-color:transparent;
}
.ts-dropdown{
  background:#fff;
  border:1px solid var(--blue);
  border-top:none;
  border-radius:0 0 var(--radius-sm) var(--radius-sm);
  box-shadow:0 10px 24px rgba(0,0,0,0.1);
  position:absolute !important;
  top:100% !important;left:0 !important;right:0 !important;
  width:auto !important;
  margin:-1px 0 0 0 !important;
  font-family:var(--font);font-size:var(--text-base);
  overflow:hidden;
  z-index:100;
}
.ts-dropdown .ts-dropdown-content{border-radius:0 0 var(--radius-sm) var(--radius-sm)}
.ts-dropdown .ts-dropdown-content{
  max-height:240px;overflow-y:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(0,0,0,0.2) transparent;
}
.ts-dropdown .ts-dropdown-content::-webkit-scrollbar{width:6px}
.ts-dropdown .ts-dropdown-content::-webkit-scrollbar-track{background:transparent}
.ts-dropdown .ts-dropdown-content::-webkit-scrollbar-thumb{
  background:rgba(0,0,0,0.2);border-radius:3px;
}
.ts-dropdown .option{
  padding:10px 14px;color:var(--ink-2);cursor:pointer;
  font-size:var(--text-base);
}
.ts-dropdown .option.active{
  background:var(--blue-pale);color:var(--blue);
}
.ts-dropdown .option.selected{
  background:var(--blue);color:#fff;
}

/* Dark-section overrides for TomSelect */
section.dark .ts-wrapper .ts-control,
section.dark .ts-wrapper.single .ts-control,
section.dark .ts-wrapper.single.input-active .ts-control{
  background-color:rgba(255,255,255,0.06);
  border-color:rgba(255,255,255,0.15);
  color:#fff;
}
section.dark .ts-wrapper .ts-control > .item{color:#fff}
section.dark .ts-wrapper .ts-control > input{color:#fff}
section.dark .ts-wrapper .ts-control > input::placeholder{color:rgba(255,255,255,0.35)}
section.dark .ts-wrapper.focus .ts-control,
section.dark .ts-wrapper.dropdown-active .ts-control{
  border-color:var(--blue-soft);
  box-shadow:0 0 0 3px rgba(77,99,248,0.2);
}
section.dark .ts-wrapper.single .ts-control::after{
  border-color:rgba(255,255,255,0.5);
}
section.dark .ts-dropdown{
  background:#1f2937;
  border-color:rgba(255,255,255,0.15);
  box-shadow:0 10px 24px rgba(0,0,0,0.4);
}
section.dark .ts-dropdown .option{color:rgba(255,255,255,0.78)}
section.dark .ts-dropdown .option.active{
  background:rgba(77,99,248,0.2);color:#fff;
}
section.dark .ts-dropdown .option.selected{
  background:var(--blue);color:#fff;
}
section.dark .ts-dropdown .ts-dropdown-content{
  scrollbar-color:rgba(255,255,255,0.2) transparent;
}
section.dark .ts-dropdown .ts-dropdown-content::-webkit-scrollbar-thumb{
  background:rgba(255,255,255,0.2);
}

/* Menu-open backdrop — body-level to escape the nav stacking context */
body::before{
  content:'';position:fixed;inset:0;
  background:rgba(0,0,0,0.35);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  z-index:50;
  opacity:0;pointer-events:none;
  transition:opacity 0.2s ease;
}
body:has(.nav.menu-open)::before{
  opacity:1;pointer-events:auto;
}
html:has(.nav.menu-open),
body:has(.nav.menu-open){
  overflow:hidden;
}
