    :root {
      --navy:        #0F1031;
      --navy-2:      #1A1D44;
      --navy-3:      #2A2E5C;
      --blue:        #6699CC;
      --blue-bright: #85B0D9;
      --blue-soft:   #EAF1F8;
      --ink:         #333333;
      --muted:       #6B6F7A;
      --line:        #D6D8DE;
      --bg:          #FFFFFF;
      --bg-alt:      #F7F7F8;
      --bg-dark:     #0F1031;
      --accent:      #6699CC;
      --radius:      14px;
      --radius-sm:   10px;
      --shadow-sm:   0 1px 2px rgba(15,16,49,.06), 0 2px 6px rgba(15,16,49,.05);
      --shadow-md:   0 4px 12px rgba(15,16,49,.08), 0 16px 32px rgba(15,16,49,.08);
      --shadow-lg:   0 10px 30px rgba(15,16,49,.10), 0 30px 60px rgba(15,16,49,.12);
      --maxw:        1180px;
    }

    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body {
      margin: 0;
      font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
      font-size: 16px;
      line-height: 1.6;
      color: var(--ink);
      background: var(--bg);
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
    }

    a { color: var(--blue); text-decoration: none; }
    a:hover { color: var(--navy); }

    img { max-width: 100%; display: block; }

    .container {
      max-width: var(--maxw);
      margin: 0 auto;
      padding: 0 24px;
    }

    /* ------------ Header ------------ */
    header.site {
      position: sticky;
      top: 0;
      z-index: 100;
      background: rgba(255,255,255,.92);
      backdrop-filter: saturate(160%) blur(10px);
      -webkit-backdrop-filter: saturate(160%) blur(10px);
      border-bottom: 1px solid var(--line);
    }
    .nav {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding-top: 16px;
      padding-bottom: 16px;
    }
    .brand {
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .brand img { height: 28px; width: auto; }
    .nav-links {
      display: flex;
      gap: 28px;
      align-items: center;
    }
    .nav-links a {
      color: var(--ink);
      font-weight: 500;
      font-size: 14.5px;
    }
    .nav-links a:hover { color: var(--blue); }
    .nav-links a[aria-current="page"] { color: var(--navy); font-weight: 700; }
    .nav-cta {
      background: var(--navy);
      color: #fff !important;
      padding: 9px 16px;
      border-radius: 999px;
      font-weight: 600;
      font-size: 14px;
      transition: background .15s ease, transform .15s ease;
    }
    .nav-cta:hover { background: var(--navy-3); transform: translateY(-1px); }

    .mobile-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 6px; }

    /* ------------ Hero ------------ */
    .hero {
      position: relative;
      padding: 88px 0 72px;
      overflow: hidden;
      background:
        radial-gradient(1200px 500px at 80% -10%, rgba(102,153,204,.20), transparent 60%),
        radial-gradient(800px 400px at -5% 20%, rgba(15,16,49,.06), transparent 60%),
        linear-gradient(180deg, #FFFFFF 0%, #F7F7F8 100%);
    }
    .hero-grid {
      display: grid;
      grid-template-columns: 1.05fr .95fr;
      gap: 56px;
      align-items: center;
    }
    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: #fff;
      border: 1px solid var(--line);
      color: var(--navy-3);
      padding: 6px 12px;
      border-radius: 999px;
      font-size: 12.5px;
      font-weight: 600;
      letter-spacing: .02em;
      box-shadow: var(--shadow-sm);
    }
    .eyebrow .dot {
      width: 7px; height: 7px;
      background: var(--accent);
      border-radius: 50%;
      box-shadow: 0 0 0 4px rgba(102,153,204,.22);
    }
    h1 {
      font-size: clamp(36px, 4.8vw, 56px);
      line-height: 1.08;
      font-weight: 800;
      letter-spacing: -0.02em;
      margin: 18px 0 18px;
      color: var(--navy);
    }
    h1 .grad {
      color: var(--blue-bright);
    }
    .lede {
      font-size: 18px;
      color: var(--muted);
      max-width: 560px;
      margin: 0 0 28px;
    }
    .cta-row {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
    }
    .btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 13px 22px;
      border-radius: 999px;
      font-weight: 600;
      font-size: 15px;
      border: 1px solid transparent;
      cursor: pointer;
      transition: transform .15s ease, background .15s ease, border-color .15s ease, color .15s ease;
    }
    .btn-primary {
      background: var(--navy);
      color: #fff;
    }
    .btn-primary:hover { background: var(--navy-3); color: #fff; transform: translateY(-1px); }
    .btn-ghost {
      background: #fff;
      color: var(--navy);
      border-color: var(--line);
    }
    .btn-ghost:hover { border-color: var(--blue); color: var(--blue); }

    .hero-badges {
      display: flex;
      gap: 24px;
      margin-top: 36px;
      flex-wrap: wrap;
      color: var(--muted);
      font-size: 13.5px;
      font-weight: 500;
    }
    .hero-badges span { display: inline-flex; align-items: center; gap: 8px; }
    .hero-badges .tick { color: var(--accent); font-weight: 700; }

    /* Hero visual — tier catalog card */
    .hero-visual { position: relative; }
    .frame {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow-lg);
      overflow: hidden;
    }
    .frame .bar {
      display: flex;
      align-items: center;
      gap: 6px;
      padding: 10px 14px;
      background: #F4F4F5;
      border-bottom: 1px solid var(--line);
    }
    .frame .bar .d { width: 10px; height: 10px; border-radius: 50%; background: #D6D8DE; }
    .frame .bar .d:nth-child(1) { background: #FF6159; }
    .frame .bar .d:nth-child(2) { background: #FFBD2E; }
    .frame .bar .d:nth-child(3) { background: #28C840; }
    .frame .bar .url {
      margin-left: 12px;
      font-family: 'JetBrains Mono', monospace;
      color: #7A8498;
      font-size: 12px;
    }

    .tier-catalog {
      padding: 22px;
      background: linear-gradient(180deg, #FFFFFF 0%, #F7F9FC 100%);
    }
    .tier-catalog h6 {
      font-size: 11px;
      letter-spacing: .12em;
      color: var(--muted);
      text-transform: uppercase;
      margin: 0 0 14px;
      font-weight: 700;
    }
    .tier-row {
      display: grid;
      grid-template-columns: 48px 1fr auto;
      gap: 14px;
      align-items: center;
      padding: 14px;
      border: 1px solid var(--line);
      border-radius: var(--radius-sm);
      background: #fff;
      margin-bottom: 10px;
    }
    .tier-row:last-child { margin-bottom: 0; }
    .tier-badge {
      width: 48px; height: 48px;
      border-radius: 12px;
      display: grid; place-items: center;
      color: #fff;
      font-weight: 800;
      font-family: 'JetBrains Mono', monospace;
      font-size: 13px;
      letter-spacing: .02em;
    }
    .tier-badge.spark { background: var(--blue); }
    .tier-badge.build { background: var(--navy-3); }
    .tier-badge.scale { background: var(--navy); }
    .tier-body strong { display: block; color: var(--navy); font-size: 15px; }
    .tier-body small { color: var(--muted); font-size: 13px; }
    .tier-dur {
      font-family: 'JetBrains Mono', monospace;
      color: var(--navy-3);
      font-size: 12px;
      font-weight: 700;
      background: var(--blue-soft);
      padding: 4px 10px;
      border-radius: 999px;
      white-space: nowrap;
    }

    /* Hero wireframe — generic custom app */
    .wf {
      padding: 0;
      background: linear-gradient(180deg, #FFFFFF 0%, #F7F9FC 100%);
      display: grid;
      grid-template-columns: 140px 1fr;
      min-height: 320px;
    }
    .wf-side {
      background: var(--navy);
      padding: 16px 12px;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }
    .wf-logo {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 6px;
    }
    .wf-logo-mark {
      width: 22px; height: 22px;
      border-radius: 6px;
      background: linear-gradient(135deg, var(--blue) 0%, var(--blue-bright) 100%);
    }
    .wf-logo-bar { height: 8px; width: 60px; border-radius: 4px; background: rgba(255,255,255,.35); }
    .wf-nav-item {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 7px 8px;
      border-radius: 6px;
    }
    .wf-nav-item.active { background: rgba(255,255,255,.08); }
    .wf-nav-dot { width: 10px; height: 10px; border-radius: 3px; background: rgba(255,255,255,.25); flex: 0 0 10px; }
    .wf-nav-item.active .wf-nav-dot { background: var(--blue-bright); }
    .wf-nav-bar { height: 6px; border-radius: 3px; background: rgba(255,255,255,.18); flex: 1; }
    .wf-nav-item.active .wf-nav-bar { background: rgba(255,255,255,.45); }

    .wf-main { padding: 16px; display: flex; flex-direction: column; gap: 14px; }
    .wf-topbar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
    }
    .wf-title-bar { height: 10px; width: 110px; border-radius: 5px; background: var(--navy); opacity: .82; }
    .wf-search {
      flex: 1;
      max-width: 150px;
      height: 22px;
      border-radius: 6px;
      background: #EEF1F6;
      border: 1px solid var(--line);
    }
    .wf-avatar {
      width: 22px; height: 22px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--blue) 0%, var(--navy-3) 100%);
      flex: 0 0 22px;
    }

    .wf-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
    .wf-stat {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius-sm);
      padding: 10px;
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
    .wf-stat-label { height: 6px; width: 50%; border-radius: 3px; background: #D6DBE5; }
    .wf-stat-value { height: 12px; width: 70%; border-radius: 4px; background: var(--navy); opacity: .85; }
    .wf-stat:nth-child(2) .wf-stat-value { background: var(--blue); opacity: 1; }

    .wf-chart {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius-sm);
      padding: 12px;
      position: relative;
      min-height: 90px;
      overflow: hidden;
    }
    .wf-chart-label { height: 6px; width: 40%; border-radius: 3px; background: #D6DBE5; margin-bottom: 10px; }
    .wf-chart-svg { width: 100%; height: 60px; display: block; }

    .wf-table {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius-sm);
      overflow: hidden;
    }
    .wf-tr {
      display: grid;
      grid-template-columns: 18px 1.2fr 1fr 70px;
      gap: 10px;
      align-items: center;
      padding: 9px 12px;
      border-bottom: 1px solid var(--line);
    }
    .wf-tr:last-child { border-bottom: 0; }
    .wf-tr.header { background: #F7F9FC; }
    .wf-check {
      width: 12px; height: 12px;
      border-radius: 3px;
      border: 1px solid var(--line);
      background: #fff;
    }
    .wf-tr.header .wf-check { visibility: hidden; }
    .wf-cell { height: 7px; border-radius: 3px; background: #E3E7EE; }
    .wf-tr.header .wf-cell { background: #CDD4DE; height: 6px; }
    .wf-cell.wide { width: 90%; }
    .wf-cell.mid { width: 70%; }
    .wf-cell.short { width: 55%; }
    .wf-pill {
      height: 16px;
      border-radius: 999px;
      background: var(--blue-soft);
      border: 1px solid rgba(102,153,204,.35);
      width: 54px;
      justify-self: end;
    }
    .wf-pill.gray { background: #EEF1F6; border-color: var(--line); }
    .wf-pill.green { background: rgba(40,200,130,.15); border-color: rgba(40,200,130,.35); }

    /* Floating stat card over hero */
    .stat-float {
      position: absolute;
      right: -14px;
      bottom: -24px;
      background: #fff;
      border: 1px solid var(--line);
      box-shadow: var(--shadow-md);
      padding: 14px 16px;
      border-radius: 12px;
      display: flex;
      align-items: center;
      gap: 12px;
      max-width: 280px;
    }
    .stat-float .mark {
      width: 36px; height: 36px;
      border-radius: 10px;
      background: linear-gradient(135deg, var(--blue), var(--navy-3));
      display: grid; place-items: center;
      color: #fff;
      font-weight: 800;
    }
    .stat-float small { color: var(--muted); font-size: 12px; display: block; }
    .stat-float strong { font-size: 14.5px; color: var(--navy); }

    /* ------------ Section base ------------ */
    section { padding: 88px 0; }
    .section-head {
      text-align: center;
      max-width: 720px;
      margin: 0 auto 48px;
    }
    .section-head .eyebrow { margin-bottom: 14px; }
    h2 {
      font-size: clamp(28px, 3.2vw, 40px);
      line-height: 1.15;
      font-weight: 800;
      letter-spacing: -0.02em;
      margin: 0 0 14px;
      color: var(--navy);
    }
    h3 {
      font-size: 20px;
      font-weight: 700;
      color: var(--navy);
      margin: 0 0 8px;
    }
    .section-head p {
      color: var(--muted);
      font-size: 17px;
      margin: 0;
    }

    /* ------------ About / Who ------------ */
    .who { background: var(--bg-alt); }
    .who .eyebrow { margin-bottom: 14px; }
    .who-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 48px;
      align-items: center;
    }
    .who p {
      color: var(--muted);
      font-size: 17px;
      margin: 0 0 16px;
    }
    .who .pillars {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      margin-top: 24px;
    }
    .pillar {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius-sm);
      padding: 18px;
    }
    .pillar .ico {
      width: 36px; height: 36px;
      border-radius: 10px;
      background: linear-gradient(135deg, var(--blue), var(--blue-bright));
      color: #fff;
      display: grid;
      place-items: center;
      font-weight: 700;
      margin-bottom: 10px;
    }
    .pillar h4 { margin: 0 0 4px; font-size: 15px; color: var(--navy); }
    .pillar p { font-size: 14px; margin: 0; color: var(--muted); }

    /* ------------ Build intro ------------ */
    .build-intro .hero-grid { gap: 64px; }
    .feature-list {
      list-style: none;
      padding: 0;
      margin: 24px 0 0;
      display: grid;
      gap: 14px;
    }
    /* See note in flow.css — chained with .wp-block-list so our 0,2,1 beats
       Gutenberg's editor-only `.wp-block-list li { display: list-item }` (0,1,1).
       Without this the bullet renders as a full-width elongated oval. */
    .wp-block-list.feature-list li,
    .feature-list li {
      display: flex;
      gap: 12px;
      align-items: flex-start;
      color: var(--ink);
      font-size: 15.5px;
    }
    .feature-list .check {
      flex: 0 0 22px;
      width: 22px;          /* defensive: keeps the bullet a circle even if a
                               future rule breaks the parent's flex layout. */
      height: 22px;
      border-radius: 50%;
      background: rgba(102,153,204,.15);
      color: var(--accent);
      display: grid;
      place-items: center;
      font-size: 13px;
      font-weight: 800;
      margin-top: 2px;
    }

    /* ------------ Tier cards ------------ */
    .caps { background: var(--bg); }
    .cap-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
    .cap {
      position: relative;
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 28px 26px;
      transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    }
    .cap:hover {
      transform: translateY(-3px);
      box-shadow: var(--shadow-md);
      border-color: #D6D8DE;
    }
    .cap .num {
      width: 44px; height: 44px;
      border-radius: 12px;
      display: grid;
      place-items: center;
      color: #fff;
      font-weight: 800;
      margin-bottom: 16px;
      font-size: 15px;
      font-family: 'JetBrains Mono', monospace;
      letter-spacing: .02em;
    }
    .cap:nth-child(1) .num { background: var(--blue); }
    .cap:nth-child(2) .num { background: var(--navy-3); }
    .cap:nth-child(3) .num { background: var(--navy); }
    .cap h3 { font-size: 22px; margin-bottom: 6px; }
    .cap .sub { color: var(--muted); font-size: 14px; margin: 0 0 8px; }
    .cap .dur {
      display: inline-block;
      font-family: 'JetBrains Mono', monospace;
      color: var(--navy-3);
      font-size: 12px;
      font-weight: 700;
      background: var(--blue-soft);
      padding: 5px 10px;
      border-radius: 999px;
      margin: 0 0 16px;
    }
    .cap ul {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 10px;
    }
    .cap ul li {
      display: flex;
      gap: 10px;
      align-items: flex-start;
      font-size: 14.5px;
    }
    .cap ul li::before {
      content: "";
      flex: 0 0 16px;
      height: 16px;
      margin-top: 4px;
      background: rgba(102,153,204,.15);
      border-radius: 50%;
      position: relative;
      background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'><path d='M4 8.5l2.5 2.5L12 5.5' stroke='%234C7FBA' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
      background-repeat: no-repeat;
      background-position: center;
    }

    /* ------------ Flow <-> Build patterns (deep) ------------ */
    .deep { background: var(--bg-alt); }
    .deep-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 56px;
      align-items: center;
      margin-bottom: 88px;
    }
    .deep-row:last-child { margin-bottom: 0; }
    .deep-row.reverse { direction: rtl; }
    .deep-row.reverse > * { direction: ltr; }
    .deep .tag {
      display: inline-block;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--blue);
      background: var(--blue-soft);
      padding: 5px 10px;
      border-radius: 6px;
      margin-bottom: 12px;
    }
    .deep h3 {
      font-size: 28px;
      line-height: 1.2;
      margin-bottom: 12px;
    }
    .deep p {
      color: var(--muted);
      font-size: 16px;
      margin: 0 0 14px;
    }
    .mini-list {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 10px;
    }
    .mini-list li {
      display: flex;
      gap: 10px;
      align-items: flex-start;
      color: var(--ink);
      font-size: 14.5px;
    }
    .mini-list li::before {
      content: "→";
      color: var(--accent);
      font-weight: 800;
      margin-top: 1px;
    }

    /* Pattern diagram card (replaces screenshots in Flow-Build section) */
    .pattern-card {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow-md);
      padding: 28px;
    }
    .pattern-card h6 {
      font-size: 11px;
      letter-spacing: .12em;
      color: var(--muted);
      text-transform: uppercase;
      margin: 0 0 16px;
      font-weight: 700;
    }
    .pattern-grid {
      display: grid;
      gap: 10px;
    }
    .pattern-pill {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 12px 14px;
      border: 1px solid var(--line);
      border-radius: 10px;
      background: var(--bg-alt);
      font-size: 14px;
      color: var(--ink);
    }
    .pattern-pill.highlight {
      background: var(--blue-soft);
      border-color: var(--blue);
      color: var(--navy);
      font-weight: 700;
    }
    .pattern-pill .label {
      font-family: 'JetBrains Mono', monospace;
      font-size: 11px;
      font-weight: 700;
      color: var(--navy-3);
      background: #fff;
      border: 1px solid var(--line);
      padding: 3px 8px;
      border-radius: 999px;
      margin-right: 4px;
    }
    .pattern-pill.highlight .label {
      background: var(--navy);
      color: #fff;
      border-color: var(--navy);
    }
    .pattern-arrow {
      text-align: center;
      color: var(--blue);
      font-size: 14px;
      margin: 2px 0;
    }

    /* ------------ How it works ------------ */
    .how {
      background: var(--navy);
      color: #E8EEF8;
      position: relative;
      overflow: hidden;
    }
    .how::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(700px 280px at 10% 10%, rgba(102,153,204,.28), transparent 70%),
        radial-gradient(600px 280px at 90% 90%, rgba(102,153,204,.14), transparent 70%);
      pointer-events: none;
    }
    .how .section-head h2 { color: #fff; }
    .how .section-head p { color: #B9C3D6; }
    .how .eyebrow { background: rgba(255,255,255,.06); color: #E8EEF8; border-color: rgba(255,255,255,.15); }
    .steps {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
      position: relative;
      z-index: 1;
    }
    .step {
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.10);
      border-radius: var(--radius);
      padding: 24px;
      position: relative;
    }
    .step .n {
      font-family: 'JetBrains Mono', monospace;
      font-size: 12px;
      color: var(--blue-bright);
      letter-spacing: .1em;
    }
    .step h4 {
      color: #fff;
      margin: 8px 0 8px;
      font-size: 17px;
    }
    .step p {
      color: #B9C3D6;
      font-size: 14px;
      margin: 0;
    }

    /* ------------ Not Build (what it isn't) ------------ */
    .not-build { background: var(--bg); }
    .not-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 16px;
      max-width: 900px;
      margin: 0 auto;
    }
    .not-card {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius-sm);
      padding: 20px 22px;
      display: flex;
      gap: 14px;
      align-items: flex-start;
    }
    .not-card .x {
      flex: 0 0 28px;
      height: 28px;
      border-radius: 50%;
      background: #FCEEEF;
      color: #C94A52;
      display: grid;
      place-items: center;
      font-weight: 800;
      margin-top: 2px;
    }
    .not-card strong { display: block; color: var(--navy); font-size: 15px; margin-bottom: 4px; }
    .not-card p { margin: 0; color: var(--muted); font-size: 14px; }

    /* ------------ Why Veloscint ------------ */
    .why .cap-grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }
    .why-card {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 26px;
    }
    .why-card .ico {
      width: 44px; height: 44px;
      border-radius: 12px;
      display: grid; place-items: center;
      background: var(--blue-soft);
      color: var(--blue);
      margin-bottom: 14px;
    }
    .why-card h3 { font-size: 17px; margin-bottom: 6px; }
    .why-card p { color: var(--muted); font-size: 14.5px; margin: 0; }

    /* ------------ CTA ------------ */
    .cta {
      background: linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 70%, var(--blue) 100%);
      color: #fff;
      border-radius: 24px;
      padding: 56px 48px;
      margin: 0 24px;
      text-align: center;
      position: relative;
      overflow: hidden;
    }
    .cta-wrap { padding: 40px 0 80px; max-width: var(--maxw); margin: 0 auto; }
    .cta h2 { color: #fff; margin-bottom: 10px; }
    .cta p { color: #C7D2E6; max-width: 560px; margin: 0 auto 28px; font-size: 17px; }
    .cta .btn-primary {
      background: #fff;
      color: var(--navy);
    }
    .cta .btn-primary:hover { background: var(--blue-soft); color: var(--navy); }
    .cta .btn-ghost {
      background: transparent;
      border-color: rgba(255,255,255,.25);
      color: #fff;
    }
    .cta .btn-ghost:hover { border-color: #fff; color: #fff; }

    /* ------------ Footer ------------ */
    footer.site {
      background: #080924;
      color: #9AA6BE;
      padding: 48px 0 28px;
    }
    .foot {
      display: grid;
      grid-template-columns: 1.4fr 1fr 1fr 1fr;
      gap: 40px;
      margin-bottom: 36px;
    }
    .foot .brand img { height: 26px; opacity: .95; }
    .foot h5 {
      font-size: 13px;
      text-transform: uppercase;
      letter-spacing: .1em;
      color: #E8EEF8;
      margin: 0 0 14px;
    }
    .foot ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
    .foot a { color: #9AA6BE; font-size: 14px; }
    .foot a:hover { color: #fff; }
    .foot p { margin: 10px 0 0; font-size: 14px; color: #9AA6BE; max-width: 320px; }
    .foot-bottom {
      display: flex;
      justify-content: space-between;
      padding-top: 24px;
      border-top: 1px solid rgba(255,255,255,.08);
      font-size: 13px;
      color: #6B778F;
    }

    /* ------------ Responsive ------------ */
    @media (max-width: 980px) {
      .hero-grid,
      .who-grid,
      .deep-row,
      .deep-row.reverse { grid-template-columns: 1fr; direction: ltr; gap: 32px; }
      .deep-row { margin-bottom: 56px; }
      .cap-grid,
      .why .cap-grid { grid-template-columns: 1fr 1fr; }
      .steps { grid-template-columns: 1fr 1fr; }
      .not-grid { grid-template-columns: 1fr; }
      .foot { grid-template-columns: 1fr 1fr; }
      .nav-links { display: none; }
      .mobile-toggle { display: inline-flex; }
      .nav-links.open {
        display: flex;
        position: absolute;
        top: 100%;
        left: 0; right: 0;
        background: #fff;
        flex-direction: column;
        padding: 16px 24px;
        gap: 14px;
        border-bottom: 1px solid var(--line);
        box-shadow: var(--shadow-sm);
      }
      .cta { padding: 40px 24px; }
      section { padding: 64px 0; }
      .hero { padding: 64px 0 56px; }
    }

    @media (max-width: 620px) {
      .cap-grid,
      .why .cap-grid,
      .steps,
      .foot,
      .who .pillars { grid-template-columns: 1fr; }
      .foot-bottom { flex-direction: column; gap: 8px; }
      .wf { grid-template-columns: 96px 1fr; }
      .wf-stats { grid-template-columns: repeat(3, 1fr); gap: 8px; }
    }

    /* reveal on scroll */
    .reveal {
      opacity: 0;
      transform: translateY(16px);
      transition: opacity .7s ease, transform .7s ease;
    }
    .reveal.in {
      opacity: 1;
      transform: none;
    }
