  /* ─── Tokens ─────────────────────────────────────────────── */
  :root {
    --primary: #0F4C3A;
    --primary-700: #0a3a2c;
    --accent:  #A6E22E;
    --dark:    #0B1220;
    --light:   #FAFAF7;
    --surface: #F2F2EF;
    --success: #10B981;
    --warning: #F59E0B;
    --danger:  #DC2626;
    --ink:     #0B1220;
    --ink-70:  rgba(11, 18, 32, 0.70);
    --ink-55:  rgba(11, 18, 32, 0.55);
    --ink-40:  rgba(11, 18, 32, 0.40);
    --border:  rgba(11, 18, 32, 0.08);
    --border-strong: rgba(11, 18, 32, 0.16);
    --light-70: rgba(250, 250, 247, 0.70);
    --light-55: rgba(250, 250, 247, 0.55);
    --light-12: rgba(250, 250, 247, 0.12);

    --shadow-card:   0 1px 2px rgba(11, 18, 32, 0.04);
    --shadow-raised: 0 4px 12px rgba(11, 18, 32, 0.06);
    --shadow-modal:  0 24px 48px rgba(11, 18, 32, 0.12);

    --r-sm: 4px;
    --r-md: 8px;
    --r-lg: 12px;
    --r-xl: 16px;

    --pad-x: 96px;
    --max-w: 1440px;

    --font-display: 'Space Grotesk', system-ui, sans-serif;
    --font-body:    'Inter', system-ui, sans-serif;
    --font-mono:    'JetBrains Mono', ui-monospace, monospace;
  }
  @media (max-width: 900px) { :root { --pad-x: 24px; } }

  /* ─── Base ───────────────────────────────────────────────── */
  *, *::before, *::after { box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    margin: 0;
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.5;
    color: var(--ink);
    background: #fff;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  }
  a { color: inherit; text-decoration: none; }
  button { font-family: inherit; cursor: pointer; }
  :focus-visible { outline: 3px solid rgba(166, 226, 46, 0.4); outline-offset: 2px; border-radius: 4px; }

  .wrap {
    max-width: var(--max-w);
    margin: 0 auto;
    padding-left: var(--pad-x);
    padding-right: var(--pad-x);
  }

  /* ─── Typography ─────────────────────────────────────────── */
  .display-xl { font-family: var(--font-display); font-weight: 600; font-size: clamp(40px, 5.6vw, 64px); line-height: 1.04; letter-spacing: -0.025em; margin: 0; }
  .display-l  { font-family: var(--font-display); font-weight: 600; font-size: clamp(32px, 4vw, 48px); line-height: 1.08; letter-spacing: -0.02em; margin: 0; }
  .h1 { font-family: var(--font-display); font-weight: 600; font-size: 32px; line-height: 1.15; letter-spacing: -0.015em; margin: 0; }
  .h2 { font-family: var(--font-display); font-weight: 500; font-size: 24px; line-height: 1.25; letter-spacing: -0.01em; margin: 0; }
  .h3 { font-family: var(--font-display); font-weight: 500; font-size: 20px; line-height: 1.3; margin: 0; }
  .body-l { font-size: 17px; line-height: 1.6; }
  .body-s { font-size: 13px; line-height: 1.5; }
  .caption { font-size: 12px; font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink-55); }
  .mono { font-family: var(--font-mono); font-size: 14px; }
  .muted { color: var(--ink-70); }

  /* ─── Buttons ────────────────────────────────────────────── */
  .btn {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--font-body); font-weight: 500; font-size: 14px;
    padding: 10px 16px; border-radius: var(--r-md);
    border: 1px solid transparent;
    transition: background 150ms ease, color 150ms ease, border-color 150ms ease, transform 150ms ease;
    white-space: nowrap;
  }
  .btn-primary { background: var(--primary); color: var(--light); }
  .btn-primary:hover { background: var(--primary-700); }
  .btn-ghost { background: transparent; color: var(--ink); border-color: var(--border-strong); }
  .btn-ghost:hover { border-color: var(--ink); background: var(--surface); }
  .btn-light { background: #fff; color: var(--primary); }
  .btn-light:hover { background: var(--light); }
  .btn-lg { padding: 14px 22px; font-size: 15px; }
  .btn .arrow { transition: transform 150ms ease; }
  .btn:hover .arrow { transform: translateX(2px); }

  /* ─── Wordmark ───────────────────────────────────────────── */
  .wordmark {
    font-family: var(--font-display);
    font-size: 20px;
    letter-spacing: -0.01em;
    display: inline-flex; align-items: baseline;
    color: var(--primary);
  }
  .wordmark .m { font-weight: 600; }
  .wordmark .dot { width: 6px; height: 6px; border-radius: 999px; background: var(--accent); display: inline-block; margin: 0 3px 1px; align-self: center; }
  .wordmark .p { font-weight: 400; }
  .wordmark.dark { color: var(--light); }

  /* ─── Nav ────────────────────────────────────────────────── */
  .nav {
    position: fixed; top: 0; left: 0; right: 0; z-index: 50;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: saturate(140%) blur(8px);
    -webkit-backdrop-filter: saturate(140%) blur(8px);
    border-bottom: 0.5px solid transparent;
    transition: border-color 150ms ease, background 150ms ease;
  }
  .nav.scrolled { border-bottom-color: var(--border); background: rgba(255, 255, 255, 0.96); }
  .nav-inner {
    height: 64px; display: flex; align-items: center; justify-content: space-between;
  }
  .nav-links { display: flex; gap: 32px; }
  .nav-links a {
    font-size: 14px; font-weight: 500; color: var(--ink-70);
    transition: color 150ms ease;
  }
  .nav-links a:hover { color: var(--ink); }
  .nav-right { display: flex; align-items: center; gap: 16px; }
  .nav-login { font-size: 14px; font-weight: 500; color: var(--ink-70); }
  .nav-login:hover { color: var(--ink); }
  @media (max-width: 900px) {
    .nav-links { display: none; }
  }

  /* ─── Hero ───────────────────────────────────────────────── */
  .hero {
    position: relative;
    padding-top: 144px;
    padding-bottom: 96px;
    background: linear-gradient(180deg, var(--light) 0%, #ffffff 70%);
  }
  .hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
    gap: 64px;
    align-items: center;
  }
  .hero-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 6px 10px 6px 8px;
    background: #fff; border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 12px; font-weight: 500; color: var(--ink-70);
    margin-bottom: 24px;
  }
  .hero-eyebrow .pulse { width: 6px; height: 6px; border-radius: 999px; background: var(--accent); box-shadow: 0 0 0 0 rgba(166,226,46,0.6); animation: pulse 2.4s ease-out infinite; }
  @keyframes pulse {
    0%   { box-shadow: 0 0 0 0 rgba(166,226,46,0.5); }
    70%  { box-shadow: 0 0 0 8px rgba(166,226,46,0); }
    100% { box-shadow: 0 0 0 0 rgba(166,226,46,0); }
  }
  .hero h1 { margin-bottom: 20px; }
  .hero-sub { color: var(--ink-70); max-width: 520px; margin: 0 0 32px; }
  .hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; }
  .hero-meta {
    margin-top: 28px; display: flex; gap: 20px; align-items: center;
    font-size: 13px; color: var(--ink-55);
  }
  .hero-meta .dot { width: 4px; height: 4px; border-radius: 999px; background: var(--ink-40); }
  @media (max-width: 1100px) {
    .hero-grid { grid-template-columns: 1fr; gap: 48px; }
  }

  /* ─── Hero browser mockup ───────────────────────────────── */
  .browser {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--shadow-raised);
    overflow: hidden;
  }
  .browser-chrome {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 14px;
    border-bottom: 1px solid var(--border);
    background: var(--light);
  }
  .browser-dots { display: flex; gap: 6px; }
  .browser-dots span { width: 10px; height: 10px; border-radius: 999px; background: #E5E5E0; }
  .browser-url {
    flex: 1;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: 4px 10px;
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--ink-55);
    display: flex; align-items: center; gap: 6px;
    max-width: 320px;
    margin: 0 auto;
  }
  .browser-url .lock { color: var(--ink-40); }
  .browser-body { display: grid; grid-template-columns: 200px 1fr; min-height: 480px; }
  .b-side {
    background: var(--light);
    border-right: 1px solid var(--border);
    padding: 16px 12px;
    font-size: 13px;
  }
  .b-side .b-logo { padding: 4px 8px 16px; }
  .b-side .b-section { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-40); padding: 12px 8px 6px; }
  .b-side .b-item { display: flex; align-items: center; gap: 10px; padding: 7px 8px; border-radius: var(--r-sm); color: var(--ink-70); }
  .b-side .b-item.active { background: #fff; color: var(--ink); box-shadow: var(--shadow-card); }
  .b-side .b-item svg { width: 16px; height: 16px; stroke-width: 1.5; }
  .b-main { padding: 18px 20px; display: flex; flex-direction: column; gap: 14px; min-width: 0; }
  .b-head { display: flex; align-items: center; justify-content: space-between; }
  .b-head .b-title { font-family: var(--font-display); font-weight: 500; font-size: 16px; }
  .b-head .b-count { font-family: var(--font-mono); font-size: 11px; color: var(--ink-55); }
  .b-pills { display: flex; gap: 6px; }
  .b-pill {
    font-size: 11px; padding: 3px 8px; border-radius: 999px;
    border: 1px solid var(--border); color: var(--ink-70);
  }
  .b-pill.on { background: var(--ink); color: #fff; border-color: var(--ink); }
  .b-table { border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; }
  .b-row { display: grid; grid-template-columns: 1.6fr 1fr 0.9fr 0.9fr 0.6fr; align-items: center; padding: 10px 12px; font-size: 12px; border-top: 1px solid var(--border); }
  .b-row:first-child { border-top: 0; background: var(--surface); color: var(--ink-55); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.06em; padding: 8px 12px; }
  .b-row .cell-name { display: flex; align-items: center; gap: 10px; }
  .b-avatar { width: 24px; height: 24px; border-radius: 999px; background: var(--surface); border: 1px solid var(--border); display: inline-flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 600; color: var(--ink-70); }
  .b-row .mono { font-family: var(--font-mono); font-size: 11px; color: var(--ink-70); }
  .b-tag { font-size: 10.5px; padding: 2px 6px; border-radius: 999px; font-weight: 500; }
  .b-tag.hot { background: rgba(166,226,46,0.18); color: var(--primary); }
  .b-tag.warm { background: rgba(245,158,11,0.12); color: #8a5a04; }
  .b-tag.new { background: rgba(11,18,32,0.06); color: var(--ink-70); }

  .b-kanban { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
  .b-col { background: var(--light); border: 1px solid var(--border); border-radius: var(--r-md); padding: 10px; min-height: 110px; }
  .b-col h4 { font-family: var(--font-body); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-55); margin: 0 0 8px; display: flex; justify-content: space-between; }
  .b-card { background: #fff; border: 1px solid var(--border); border-radius: var(--r-sm); padding: 8px 10px; margin-bottom: 6px; font-size: 11.5px; }
  .b-card .b-name { font-weight: 500; }
  .b-card .b-meta { font-family: var(--font-mono); font-size: 10px; color: var(--ink-55); margin-top: 2px; }
  .b-card .b-bar { height: 3px; background: var(--surface); border-radius: 999px; margin-top: 6px; overflow: hidden; }
  .b-card .b-bar > i { display: block; height: 100%; background: var(--accent); }

  /* Float chip */
  .float-chip {
    position: absolute; right: -12px; bottom: 22px;
    background: #fff; border: 1px solid var(--border); border-radius: var(--r-md);
    box-shadow: var(--shadow-raised);
    padding: 12px 14px; display: flex; gap: 10px; align-items: center;
    font-size: 12px;
  }
  .float-chip .ico { width: 32px; height: 32px; border-radius: var(--r-sm); background: rgba(166,226,46,0.18); color: var(--primary); display: grid; place-items: center; }
  .float-chip .ico svg { width: 18px; height: 18px; stroke-width: 1.5; }
  .float-chip .label { color: var(--ink-55); font-size: 11px; }
  .float-chip .value { font-family: var(--font-mono); font-weight: 500; }

  /* ─── Sections shared ───────────────────────────────────── */
  section { scroll-margin-top: 80px; }
  .section { padding: 96px 0; }
  .section-head { max-width: 720px; margin: 0 0 56px; }
  .section-head .caption { display: block; margin-bottom: 16px; }
  .section-head p { color: var(--ink-70); margin: 16px 0 0; max-width: 600px; }
  @media (max-width: 900px) { .section { padding: 72px 0; } }

  /* ─── Social proof ──────────────────────────────────────── */
  .proof {
    padding: 48px 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    background: #fff;
  }
  .proof-head { text-align: center; font-size: 12px; color: var(--ink-55); font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: 28px; }
  .proof-row {
    display: grid; grid-template-columns: repeat(6, 1fr); gap: 32px;
    align-items: center;
  }
  @media (max-width: 900px) { .proof-row { grid-template-columns: repeat(3, 1fr); row-gap: 24px; } }
  .logo-ph {
    height: 28px; display: flex; align-items: center; justify-content: center;
    color: var(--ink-40); font-family: var(--font-display); font-weight: 600; font-size: 16px; letter-spacing: -0.01em;
    opacity: 0.75; transition: opacity 150ms ease;
  }
  .logo-ph:hover { opacity: 1; }
  .logo-ph .badge {
    display: inline-flex; align-items: center; gap: 6px;
  }
  .logo-ph .shape { width: 18px; height: 18px; border: 1.5px solid currentColor; border-radius: 4px; display: inline-block; }
  .logo-ph .shape.round { border-radius: 999px; }
  .logo-ph .shape.diamond { transform: rotate(45deg); }

  /* ─── Problem / Solution ─────────────────────────────────── */
  .ps {
    background: var(--surface);
  }
  .ps-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  }
  @media (max-width: 900px) { .ps-grid { grid-template-columns: 1fr; } }
  .ps-card {
    background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg);
    padding: 40px; box-shadow: var(--shadow-card);
  }
  .ps-card.today { background: #fff; }
  .ps-card.with { background: var(--dark); color: var(--light); border-color: transparent; }
  .ps-card .ps-label {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 12px; font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase;
    color: var(--ink-55); margin-bottom: 24px;
  }
  .ps-card.with .ps-label { color: var(--accent); }
  .ps-card .ps-label .pip { width: 6px; height: 6px; border-radius: 999px; background: currentColor; }
  .ps-card h3 { font-family: var(--font-display); font-weight: 500; font-size: 22px; line-height: 1.25; margin: 0 0 24px; }
  .ps-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 16px; }
  .ps-list li { display: flex; gap: 12px; font-size: 15px; line-height: 1.5; color: var(--ink-70); }
  .ps-card.with .ps-list li { color: var(--light-70); }
  .ps-list li .ico { flex: 0 0 22px; height: 22px; display: grid; place-items: center; border-radius: 999px; background: var(--surface); color: var(--ink-55); margin-top: 1px; }
  .ps-card.with .ps-list li .ico { background: rgba(166,226,46,0.18); color: var(--accent); }
  .ps-list li .ico svg { width: 12px; height: 12px; stroke-width: 2; }
  .ps-list li strong { color: var(--ink); font-weight: 500; }
  .ps-card.with .ps-list li strong { color: var(--light); }

  /* ─── Features ─────────────────────────────────────────── */
  .features-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
    background: var(--border);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    overflow: hidden;
  }
  @media (max-width: 900px) { .features-grid { grid-template-columns: 1fr; } }
  @media (max-width: 1100px) and (min-width: 901px) { .features-grid { grid-template-columns: repeat(2, 1fr); } }
  .f-card {
    background: #fff;
    padding: 40px 32px;
    display: flex; flex-direction: column; gap: 16px;
    transition: background 150ms ease;
  }
  .f-card:hover { background: var(--light); }
  .f-icon {
    width: 40px; height: 40px; border-radius: var(--r-md);
    background: rgba(15, 76, 58, 0.06);
    color: var(--primary);
    display: grid; place-items: center;
  }
  .f-icon svg { width: 20px; height: 20px; stroke-width: 1.5; }
  .f-card h3 { font-family: var(--font-display); font-weight: 500; font-size: 18px; margin: 0; }
  .f-card p { margin: 0; color: var(--ink-70); font-size: 14px; line-height: 1.55; }

  /* ─── How it works ─────────────────────────────────────── */
  .how { background: var(--dark); color: var(--light); }
  .how .caption { color: var(--accent); }
  .how h2 { color: var(--light); }
  .how .section-head p { color: var(--light-70); }
  .timeline {
    position: relative;
    display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px;
    counter-reset: step;
  }
  .timeline::before {
    content: ""; position: absolute; left: 0; right: 0; top: 22px;
    height: 1px; background: var(--light-12);
  }
  .step { position: relative; padding-top: 56px; }
  .step .num {
    position: absolute; top: 0; left: 0;
    width: 44px; height: 44px; border-radius: 999px;
    background: var(--dark); border: 1px solid var(--light-12);
    display: grid; place-items: center;
    font-family: var(--font-mono); font-size: 13px; color: var(--accent);
  }
  .step.active .num { background: var(--accent); color: var(--dark); border-color: var(--accent); font-weight: 500; }
  .step h3 { font-family: var(--font-display); font-weight: 500; font-size: 17px; margin: 0 0 8px; color: var(--light); }
  .step p { margin: 0; font-size: 13.5px; line-height: 1.55; color: var(--light-70); }
  @media (max-width: 900px) {
    .timeline { grid-template-columns: 1fr; gap: 16px; }
    .timeline::before { left: 22px; right: auto; top: 0; bottom: 0; width: 1px; height: auto; }
    .step { padding-top: 0; padding-left: 60px; min-height: 60px; }
  }

  /* ─── Pricing ──────────────────────────────────────────── */
  .pricing-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  }
  @media (max-width: 900px) { .pricing-grid { grid-template-columns: 1fr; } }
  .price-card {
    background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg);
    padding: 32px 28px; display: flex; flex-direction: column;
    transition: border-color 150ms ease;
  }
  .price-card:hover { border-color: var(--border-strong); }
  .price-card.featured {
    background: var(--primary); color: var(--light); border-color: var(--primary);
    box-shadow: var(--shadow-raised);
    position: relative;
  }
  .price-card.featured .badge-feat {
    position: absolute; top: -10px; right: 20px;
    background: var(--accent); color: var(--dark);
    font-size: 11px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
    padding: 4px 8px; border-radius: 999px;
  }
  .price-name { font-family: var(--font-display); font-weight: 500; font-size: 18px; margin: 0 0 6px; }
  .price-tag { font-size: 13px; color: var(--ink-55); margin-bottom: 24px; }
  .price-card.featured .price-tag { color: var(--light-70); }
  .price-amount { display: flex; align-items: baseline; gap: 6px; margin-bottom: 4px; }
  .price-amount .from { font-size: 12px; color: var(--ink-55); font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; }
  .price-card.featured .price-amount .from { color: var(--light-70); }
  .price-amount .num { font-family: var(--font-display); font-weight: 600; font-size: 44px; letter-spacing: -0.02em; line-height: 1; }
  .price-amount .unit { font-size: 14px; color: var(--ink-55); }
  .price-card.featured .price-amount .unit { color: var(--light-70); }
  .price-billed { font-size: 12px; color: var(--ink-55); margin-bottom: 28px; }
  .price-card.featured .price-billed { color: var(--light-70); }
  .price-feats { list-style: none; padding: 0; margin: 0 0 32px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
  .price-feats li { display: flex; gap: 10px; font-size: 14px; color: var(--ink-70); }
  .price-card.featured .price-feats li { color: var(--light-70); }
  .price-feats li svg { flex: 0 0 16px; width: 16px; height: 16px; stroke-width: 2; color: var(--primary); margin-top: 3px; }
  .price-card.featured .price-feats li svg { color: var(--accent); }
  .price-feats li strong { color: var(--ink); font-weight: 500; }
  .price-card.featured .price-feats li strong { color: var(--light); }
  .price-card .btn { justify-content: center; }
  .price-card.featured .btn-primary { background: var(--accent); color: var(--dark); }
  .price-card.featured .btn-primary:hover { background: #b9f04a; }

  /* ─── Testimonial ──────────────────────────────────────── */
  .testimonial {
    background: var(--surface);
  }
  .quote-card {
    max-width: 980px; margin: 0 auto;
    background: #fff; border: 1px solid var(--border); border-radius: var(--r-xl);
    padding: 64px 64px 48px;
    position: relative;
  }
  .quote-card .qmark {
    font-family: var(--font-display); font-weight: 600; font-size: 96px;
    color: var(--accent); line-height: 1;
    position: absolute; top: 28px; left: 56px;
  }
  .quote-card blockquote {
    margin: 0 0 32px;
    font-family: var(--font-display); font-weight: 500;
    font-size: clamp(22px, 2.4vw, 30px); line-height: 1.35;
    letter-spacing: -0.01em;
    color: var(--ink);
    position: relative; z-index: 1;
  }
  .quote-card cite {
    font-style: normal;
    display: flex; align-items: center; gap: 14px;
  }
  .quote-card cite .avatar {
    width: 44px; height: 44px; border-radius: 999px;
    background: var(--primary); color: var(--light);
    display: grid; place-items: center;
    font-family: var(--font-display); font-weight: 500; font-size: 14px;
  }
  .quote-card cite .who { font-weight: 500; font-size: 14px; }
  .quote-card cite .role { font-size: 13px; color: var(--ink-55); }
  @media (max-width: 700px) {
    .quote-card { padding: 48px 28px 32px; }
    .quote-card .qmark { left: 20px; top: 16px; font-size: 64px; }
  }

  /* ─── Final CTA ────────────────────────────────────────── */
  .cta-band {
    background: var(--primary);
    color: var(--light);
    padding: 96px 0;
    position: relative;
    overflow: hidden;
  }
  .cta-band::after {
    content: ""; position: absolute; right: -120px; top: -120px;
    width: 360px; height: 360px; border-radius: 999px;
    border: 1px solid rgba(166,226,46,0.18);
  }
  .cta-band::before {
    content: ""; position: absolute; right: -40px; top: -40px;
    width: 200px; height: 200px; border-radius: 999px;
    border: 1px solid rgba(166,226,46,0.12);
  }
  .cta-inner {
    display: flex; align-items: center; justify-content: space-between; gap: 40px;
    position: relative; z-index: 1;
  }
  .cta-band h2 { color: var(--light); max-width: 540px; font-size: clamp(28px, 3.4vw, 40px); line-height: 1.15; }
  .cta-band p { color: var(--light-70); margin: 12px 0 0; max-width: 480px; }
  @media (max-width: 900px) { .cta-inner { flex-direction: column; align-items: flex-start; } }

  /* ─── Footer ───────────────────────────────────────────── */
  footer {
    background: var(--dark); color: var(--light);
    padding: 80px 0 32px;
  }
  .foot-grid {
    display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: 40px;
    padding-bottom: 56px; border-bottom: 1px solid var(--light-12);
  }
  @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } .foot-brand { grid-column: 1 / -1; } }
  .foot-brand p { color: var(--light-70); font-size: 14px; max-width: 280px; margin: 16px 0 0; }
  .foot-col h4 {
    font-family: var(--font-body); font-weight: 500; font-size: 12px;
    text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--light-55); margin: 0 0 16px;
  }
  .foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
  .foot-col a { color: var(--light-70); font-size: 14px; transition: color 150ms ease; }
  .foot-col a:hover { color: var(--light); }
  .foot-bottom {
    display: flex; align-items: center; justify-content: space-between; gap: 24px;
    padding-top: 32px; font-size: 13px; color: var(--light-55);
    flex-wrap: wrap;
  }
  .foot-bottom-right { display: flex; align-items: center; gap: 16px; }
  .foot-social { display: flex; gap: 8px; }
  .foot-social a {
    width: 32px; height: 32px; border-radius: var(--r-sm);
    border: 1px solid var(--light-12);
    display: grid; place-items: center; color: var(--light-70);
    transition: border-color 150ms ease, color 150ms ease;
  }
  .foot-social a:hover { color: var(--light); border-color: var(--light-55); }
  .foot-social svg { width: 14px; height: 14px; }
  .lang-switch {
    display: inline-flex; border: 1px solid var(--light-12); border-radius: var(--r-sm); padding: 2px;
  }
  .lang-switch button {
    background: transparent; border: 0; color: var(--light-70);
    font-size: 12px; font-weight: 500; padding: 4px 10px; border-radius: 3px;
    transition: background 150ms ease, color 150ms ease;
  }
  .lang-switch button.on { background: var(--light-12); color: var(--light); }
