
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: 'DM Sans', sans-serif;
      background: #f7f6f3;
      color: #1a0f3c;
      overflow-x: hidden;
      -webkit-font-smoothing: antialiased;
    }

    /* ── TOKENS ── */
    :root {
      --navy: #1a0f3c;
      --pink: #e63975;
      --gold: #c9a84c;
      --gold-light: #f5e6c0;
      --gold-mid: #e8c96a;
      --gold-dark: #a07830;
      --teal: #17474a;
      --cream: #f7f6f3;
      --white: #ffffff;
      --muted: #5a5080;
      --border: rgba(0,0,0,0.07);
    }

    /* ── NAV ── */
    .site-nav {
      position: fixed; top: 0; left: 0; right: 0; z-index: 500;
      height: 72px; display: flex; align-items: center; justify-content: space-between;
      padding: 0 48px; background: var(--navy);
      border-bottom: 1px solid rgba(255,255,255,0.07);
      transition: box-shadow 0.3s;
    }

    .nav-back { font-size: 0.875rem; font-weight: 600; color: rgba(255,255,255,0.6); text-decoration: none; display: flex; align-items: center; gap: 6px; transition: color 0.2s; }
    .nav-back:hover { color: #fff; }
    .nav-pill { background: var(--gold); color: var(--navy); font-size: 0.875rem; font-weight: 700; padding: 10px 24px; border-radius: 50px; text-decoration: none; transition: all 0.25s; }
    .nav-pill:hover { background: var(--gold-mid); transform: translateY(-2px); }

    /* ── HERO ── */
    .hero {
      min-height: 100vh; padding-top: 72px;
      background: var(--navy);
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      position: relative; overflow: hidden; text-align: center;
    }
    /* Canvas replaces the static bg-grid */
    #hero-canvas {
      position: absolute; inset: 0; width: 100%; height: 100%;
      display: block; z-index: 1; pointer-events: none;
    }
    .hero-bg-glow {
      position: absolute; inset: 0; z-index: 2;
      background: radial-gradient(ellipse 80% 60% at 50% 40%, rgba(201,168,76,0.13) 0%, transparent 70%);
    }
    .hero-content {
      position: relative; z-index: 10; padding: 0 24px; max-width: 900px;
      display: flex; flex-direction: column; align-items: center;
    }
    .hero-badge {
      display: inline-flex; align-items: center; gap: 8px;
      background: rgba(201,168,76,0.12); border: 1px solid rgba(201,168,76,0.3);
      color: var(--gold-mid); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.1em;
      text-transform: uppercase; padding: 8px 18px; border-radius: 50px; margin-bottom: 32px;
    }
    .hero-badge-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold-mid); animation: pulse 2s infinite; }
    @keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.5;transform:scale(1.4)} }
    .hero-h1 {
      font-family: 'DM Sans', sans-serif;
      font-size: clamp(3rem, 7vw, 6rem);
      font-weight: 800;
      line-height: 1.0; letter-spacing: -0.05em; color: #fff; margin-bottom: 16px;
    }
    .hero-h1 em { font-style: normal; color: var(--gold-mid); }
    .hero-sub {
      font-size: clamp(1rem, 2vw, 1.25rem); color: rgba(255,255,255,0.78);
      line-height: 1.7; max-width: 620px; margin: 0 auto 44px;
    }
    .hero-ctas { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; }
    .btn-gold {
      background: var(--gold); color: var(--navy);
      font-size: 1rem; font-weight: 700; padding: 16px 40px; border-radius: 50px;
      text-decoration: none; transition: all 0.3s; box-shadow: 0 8px 32px rgba(201,168,76,0.35);
    }
    .btn-gold:hover { background: var(--gold-mid); transform: translateY(-3px); box-shadow: 0 14px 40px rgba(201,168,76,0.4); }
    .btn-ghost {
      background: transparent; color: rgba(255,255,255,0.75); font-size: 1rem; font-weight: 600;
      padding: 15px 36px; border-radius: 50px; text-decoration: none;
      border: 1.5px solid rgba(255,255,255,0.2); transition: all 0.3s;
    }
    .btn-ghost:hover { border-color: rgba(255,255,255,0.6); color: #fff; }
    .hero-trust { margin-top: 60px; font-size: 0.8rem; color: rgba(255,255,255,0.35); letter-spacing: 0.08em; text-transform: uppercase; }

    /* ── STATS BAR ── */
    .stats-bar { background: var(--gold); padding: 56px 0; }
    .stats-inner { max-width: 1700px; margin: 0 auto; padding: 0 40px; display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
    .stat-item { text-align: center; }
    .stat-num { font-size: 1.8rem; font-weight: 800; color: var(--navy); line-height: 1; }
    .stat-lbl { font-size: 0.78rem; font-weight: 600; color: rgba(26,15,60,0.65); margin-top: 4px; letter-spacing: 0.04em; }
    .stat-divider { width: 1px; height: 40px; background: rgba(26,15,60,0.15); }

    /* ── SECTION SHARED ── */
    .container { max-width: 1700px; margin: 0 auto; padding: 0 40px; }
    .section-white { background: #fff; padding: 140px 0; }
    .section-cream { background: var(--cream); padding: 140px 0; }
    .section-navy { background: var(--navy); padding: 140px 0; }
    /* eyebrow — from index.html: 0.9rem, 0.15em, margin-bottom 24px */
    .eyebrow { font-size: 0.9rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold); margin-bottom: 24px; }
    .eyebrow-pink { color: var(--pink); }
    /* section-h2 — from index.html: DM Sans 800, clamp(2.5rem,5vw,4.2rem), line-height 1.05, letter-spacing -0.03em */
    .section-h2 {
      font-family: 'DM Sans', sans-serif;
      font-size: clamp(2.5rem, 5vw, 4.2rem);
      font-weight: 800;
      line-height: 1.05; letter-spacing: -0.03em; color: var(--navy); margin-bottom: 24px;
    }
    .section-h2 em { font-weight: 800; font-style: normal; color: var(--pink); }
    .section-h2.light { color: #fff; }
    .section-h2.light em { color: var(--gold-mid); }
    /* section-body — from index.html: 1.2rem, line-height 1.6, max-width 600px, weight 500 */
    .section-body { font-size: 1.2rem; color: var(--muted); line-height: 1.6; max-width: 600px; font-weight: 500; }
    .section-body.light { color: rgba(255,255,255,0.8); }
    .text-center { text-align: center; }
    .mx-auto { margin-left: auto; margin-right: auto; }

    /* ── REVEAL ── */
    .reveal { opacity:0; transform:translateY(28px); transition:opacity .55s cubic-bezier(.22,1,.36,1), transform .55s cubic-bezier(.22,1,.36,1); }
    .reveal.in { opacity:1; transform:none; }

    /* ── WHO IS THIS FOR ── */
    .personas-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 60px; }
    .persona-card {
      background: var(--cream); border: 1px solid var(--border); border-radius: 20px;
      padding: 32px 28px; transition: all 0.35s cubic-bezier(.22,1,.36,1); position: relative; overflow: hidden;
    }
    .persona-card::before {
      content: ''; position: absolute; inset: 0; border-radius: inherit; opacity: 0;
      background: linear-gradient(145deg, rgba(201,168,76,0.07) 0%, rgba(26,15,60,0.03) 100%);
      transition: opacity 0.35s;
    }
    .persona-card:hover { transform: translateY(-6px); box-shadow: 0 20px 50px rgba(26,15,60,0.1); border-color: var(--gold); }
    .persona-card:hover::before { opacity: 1; }
    .pc-icon { width: 52px; height: 52px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; margin-bottom: 20px; background: linear-gradient(135deg, var(--gold-light), var(--gold-mid)); }
    .pc-title { font-size: 1.35rem; font-weight: 700; color: var(--navy); margin-bottom: 8px; }
    .pc-body { font-size: 1rem; color: var(--muted); line-height: 1.6; margin-bottom: 16px; }
    .pc-earn { font-size: 0.78rem; font-weight: 700; color: var(--gold-dark); background: var(--gold-light); padding: 6px 12px; border-radius: 20px; display: inline-block; }

    /* ── HOW IT WORKS ── */
    .steps-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 60px; position: relative; }
    .steps-row::before { content: ''; position: absolute; top: 36px; left: calc(33.33% + 0px); right: calc(33.33% + 0px); height: 1px; background: linear-gradient(90deg, var(--gold-mid), var(--gold)); z-index: 0; }
    .step { text-align: center; padding: 0 32px; position: relative; z-index: 1; }
    .step-num {
      width: 72px; height: 72px; border-radius: 50%; background: var(--navy);
      border: 3px solid var(--gold); color: var(--gold); font-size: 1.4rem; font-weight: 800;
      display: flex; align-items: center; justify-content: center; margin: 0 auto 24px;
    }
    .step-title { font-size: 1.3rem; font-weight: 700; color: var(--navy); margin-bottom: 10px; }
    .step-body { font-size: 1rem; color: var(--muted); line-height: 1.6; }

    /* ── TIERS ── */
    .tiers-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 60px; }
    .tier-card {
      border-radius: 24px; padding: 40px 32px; position: relative; overflow: hidden;
      border: 1px solid var(--border); background: #fff;
      transition: transform 0.3s, box-shadow 0.3s;
    }
    .tier-card:hover { transform: translateY(-6px); box-shadow: 0 24px 60px rgba(26,15,60,0.1); }
    .tier-card.featured {
      background: var(--navy); border-color: var(--gold);
      box-shadow: 0 0 0 2px var(--gold), 0 20px 60px rgba(201,168,76,0.2);
    }
    .tier-featured-badge {
      position: absolute; top: 20px; right: 20px;
      background: var(--gold); color: var(--navy); font-size: 0.68rem; font-weight: 800;
      letter-spacing: 0.08em; text-transform: uppercase; padding: 4px 12px; border-radius: 20px;
    }
    .tier-name { font-size: 0.9rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold); margin-bottom: 10px; }
    .tier-title { font-family: 'DM Sans', sans-serif; font-size: 1.6rem; font-weight: 800; color: var(--navy); margin-bottom: 8px; letter-spacing: -0.02em; }
    .tier-card.featured .tier-title { color: #fff; }
    .tier-desc { font-size: 1rem; color: var(--muted); line-height: 1.6; margin-bottom: 28px; }
    .tier-card.featured .tier-desc { color: rgba(255,255,255,0.6); }
    .tier-earn-label { font-size: 0.9rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
    .tier-card.featured .tier-earn-label { color: rgba(255,255,255,0.45); }
    .tier-earn-amount { font-size: 2.4rem; font-weight: 800; color: var(--navy); line-height: 1; margin-bottom: 4px; }
    .tier-card.featured .tier-earn-amount { color: var(--gold-mid); }
    .tier-earn-note { font-size: 0.8rem; color: var(--muted); margin-bottom: 28px; }
    .tier-card.featured .tier-earn-note { color: rgba(255,255,255,0.45); }
    .tier-perks { list-style: none; display: flex; flex-direction: column; gap: 10px; }
    .tier-perk { display: flex; align-items: flex-start; gap: 10px; font-size: 1rem; color: var(--navy); line-height: 1.5; }
    .tier-card.featured .tier-perk { color: rgba(255,255,255,0.85); }
    .tier-check { color: var(--gold); font-weight: 700; flex-shrink: 0; margin-top: 1px; }
    .tier-who { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--border); font-size: 0.88rem; color: var(--muted); }
    .tier-card.featured .tier-who { border-top-color: rgba(255,255,255,0.1); color: rgba(255,255,255,0.4); }

    /* ── CASE STUDIES ── */
    .cases-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin-top: 60px; }
    .case-card {
      border-radius: 24px; padding: 40px; background: #fff; border: 1px solid var(--border);
      position: relative; overflow: hidden; transition: transform 0.3s, box-shadow 0.3s;
    }
    .case-card:hover { transform: translateY(-5px); box-shadow: 0 20px 50px rgba(26,15,60,0.09); }
    .case-card::after {
      content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 4px;
      background: linear-gradient(90deg, var(--gold), var(--gold-mid));
    }
    .case-logo-area { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
    .case-brand-name { font-size: 1.5rem; font-weight: 800; color: var(--navy); letter-spacing: -0.02em; }
    .case-category { font-size: 0.75rem; font-weight: 600; color: var(--muted); background: var(--cream); padding: 4px 12px; border-radius: 20px; }
    .case-market { font-size: 0.78rem; font-weight: 700; color: var(--gold-dark); background: var(--gold-light); padding: 5px 12px; border-radius: 20px; margin-bottom: 20px; display: inline-block; }
    .case-result-num { font-size: 3.5rem; font-weight: 900; color: var(--navy); line-height: 1; letter-spacing: -0.04em; margin-bottom: 4px; }
    .case-result-label { font-size: 1rem; color: var(--muted); line-height: 1.5; margin-bottom: 24px; }
    .case-detail { font-size: 1rem; color: var(--muted); line-height: 1.7; border-top: 1px solid var(--border); padding-top: 20px; }
    .case-detail strong { color: var(--navy); font-weight: 600; }

    /* ── PARTNER TYPES DEEP ── */
    .partner-types-row { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; margin-top: 60px; }
    .pt-list { display: flex; flex-direction: column; gap: 14px; }
    .pt-item {
      background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08);
      border-radius: 14px; padding: 20px 22px; display: flex; gap: 16px; align-items: flex-start;
      transition: all 0.25s; cursor: default;
    }
    .pt-item:hover { background: rgba(201,168,76,0.08); border-color: rgba(201,168,76,0.25); }
    .pt-icon { width: 40px; height: 40px; border-radius: 10px; background: rgba(201,168,76,0.15); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; }
    .pt-text h4 { font-size: 1.1rem; font-weight: 700; color: #fff; margin-bottom: 4px; }
    .pt-text p { font-size: 0.9rem; color: rgba(255,255,255,0.5); line-height: 1.65; }
    .pt-ideal-brands { background: rgba(201,168,76,0.06); border: 1px solid rgba(201,168,76,0.15); border-radius: 20px; padding: 40px; }
    .pt-ideal-brands h3 { font-family: 'DM Sans', sans-serif; font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 800; letter-spacing: -0.02em; color: #fff; margin-bottom: 12px; }
    .pt-ideal-brands p { font-size: 0.875rem; color: rgba(255,255,255,0.55); line-height: 1.65; margin-bottom: 24px; }
    .ideal-tag { display: inline-flex; align-items: center; gap: 6px; background: rgba(201,168,76,0.12); border: 1px solid rgba(201,168,76,0.2); color: var(--gold-mid); font-size: 0.78rem; font-weight: 600; padding: 7px 14px; border-radius: 20px; margin: 4px; }
    .ideal-tags { margin-bottom: 28px; }

    /* ── FAQ ── */
    .faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 56px; }
    .faq-item { background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 32px; }
    .faq-q { font-size: 1.05rem; font-weight: 700; color: var(--navy); margin-bottom: 12px; }
    .faq-a { font-size: 1rem; color: var(--muted); line-height: 1.75; }
    .faq-a strong { color: var(--navy); }

    /* ── CTA SECTION ── */
    .cta-section {
      background: var(--navy); padding: 120px 0;
      position: relative; overflow: hidden;
    }
    .cta-bg {
      position: absolute; inset: 0;
      background: radial-gradient(ellipse 70% 80% at 50% 50%, rgba(201,168,76,0.1) 0%, transparent 70%);
    }
    .cta-inner { position: relative; z-index: 1; text-align: center; max-width: 700px; margin: 0 auto; padding: 0 24px; }
    .cta-h2 { font-family: 'DM Sans', sans-serif; font-size: clamp(2.5rem, 5vw, 4.2rem); font-weight: 800; color: #fff; line-height: 1.05; letter-spacing: -0.03em; margin-bottom: 20px; }
    .cta-h2 em { font-weight: 800; font-style: normal; color: var(--gold-mid); }
    .cta-body { font-size: 1.2rem; color: rgba(255,255,255,0.78); line-height: 1.6; margin-bottom: 48px; font-weight: 500; }
    .cta-form { background: rgba(255,255,255,0.05); border: 1px solid rgba(201,168,76,0.2); border-radius: 20px; padding: 40px; max-width: 560px; margin: 0 auto; }
    .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
    .form-group { display: flex; flex-direction: column; gap: 6px; }
    .form-group label { font-size: 0.75rem; font-weight: 600; color: rgba(255,255,255,0.5); letter-spacing: 0.05em; text-transform: uppercase; }
    .form-group input, .form-group select {
      background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12);
      border-radius: 10px; padding: 12px 16px; color: #fff; font-size: 0.9rem; font-family: 'DM Sans', sans-serif;
      transition: border-color 0.2s; outline: none;
    }
    .form-group input::placeholder { color: rgba(255,255,255,0.25); }
    .form-group input:focus, .form-group select:focus { border-color: var(--gold); }
    .form-group select option { background: var(--navy); color: #fff; }
    .form-full { grid-column: 1 / -1; }
    .btn-submit {
      width: 100%; padding: 16px; background: var(--gold); color: var(--navy);
      font-size: 1rem; font-weight: 800; border: none; border-radius: 50px; cursor: pointer;
      transition: all 0.3s; margin-top: 6px; font-family: 'DM Sans', sans-serif;
      box-shadow: 0 8px 28px rgba(201,168,76,0.35);
    }
    .btn-submit:hover { background: var(--gold-mid); transform: translateY(-2px); box-shadow: 0 12px 36px rgba(201,168,76,0.45); }
    .form-note { font-size: 0.78rem; color: rgba(255,255,255,0.3); margin-top: 14px; text-align: center; }

    /* ── FOOTER ── */
    .mini-footer { background: #0f0822; padding: 32px 0; text-align: center; font-size: 0.8rem; color: rgba(255,255,255,0.25); }
    .mini-footer a { color: rgba(255,255,255,0.4); text-decoration: none; margin: 0 10px; }
    .mini-footer a:hover { color: var(--gold); }

    /* ── RESPONSIVE ── */
    @media (max-width: 900px) {
      .personas-grid { grid-template-columns: 1fr 1fr; }
      .tiers-grid { grid-template-columns: 1fr; }
      .cases-grid { grid-template-columns: 1fr; }
      .faq-grid { grid-template-columns: 1fr; }
      .partner-types-row { grid-template-columns: 1fr; }
      .steps-row { grid-template-columns: 1fr; gap: 40px; }
      .steps-row::before { display: none; }
      .form-row { grid-template-columns: 1fr; }
      .site-nav { padding: 0 24px; }
    }
    @media (max-width: 600px) {
      .personas-grid { grid-template-columns: 1fr; }
      .container { padding: 0 20px; }
      .stats-inner { justify-content: center; gap: 30px; }
      .stat-divider { display: none; }
    }
    /* ── HERO PAGE SWITCH ── */
    .hero-page-switch {
        display: inline-flex;
        align-items: center;
        align-self: flex-start;
        background: rgba(201, 168, 76, 0.08);
        border: 1px solid rgba(201, 168, 76, 0.2);
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
        border-radius: 999px;
        padding: 4px;
        margin-bottom: 150px;
        gap: 0;
    }
    .hps-tab {
        display: inline-flex;
        align-items: center;
        padding: 9px 24px;
        border-radius: 999px;
        font-size: 0.75rem;
        font-weight: 700;
        letter-spacing: 0.1em;
        text-transform: uppercase;
        text-decoration: none;
        color: rgba(255, 255, 255, 0.38);
        transition: color 0.3s ease;
        white-space: nowrap;
    }
    .hps-tab:not(.active):hover { color: rgba(255, 255, 255, 0.7); }
    .hps-tab.active {
        color: var(--navy);
        background: linear-gradient(135deg, var(--gold-mid) 0%, var(--gold) 100%);
        box-shadow:
            0 0 18px rgba(201, 168, 76, 0.55),
            0 4px 12px rgba(201, 168, 76, 0.3),
            inset 0 1px 0 rgba(255, 255, 255, 0.25);
        animation: hps-pulse 2.8s ease-in-out infinite;
    }
    @keyframes hps-pulse {
        0%, 100% {
            box-shadow:
                0 0 18px rgba(201, 168, 76, 0.55),
                0 4px 12px rgba(201, 168, 76, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.25);
        }
        50% {
            box-shadow:
                0 0 32px rgba(201, 168, 76, 0.8),
                0 0 60px rgba(201, 168, 76, 0.2),
                0 4px 12px rgba(201, 168, 76, 0.35),
                inset 0 1px 0 rgba(255, 255, 255, 0.25);
        }
    }
  
    @media (max-width: 480px) {
      .site-nav { padding: 0 16px; }
      .nav-back { display: none; }
      .nav-logo { font-size: 1.2rem; }
    }
  
        /* ── PARTNERS: Responsive section padding ── */
        @media (max-width: 1024px) {
          .hero                                          { padding-top: 100px; }
          .section-white, .section-cream, .section-navy { padding: 100px 0; }
          .cta-section                                   { padding: 96px 0; }
          .container                                     { padding: 0 32px; }
        }
        @media (max-width: 768px) {
          .hero                                          { padding-top: 80px; }
          .section-white, .section-cream, .section-navy { padding: 72px 0; }
          .cta-section                                   { padding: 72px 0; }
          .container                                     { padding: 0 20px; }
        }
        @media (max-width: 480px) {
          .hero                                          { padding-top: 64px; }
          .section-white, .section-cream, .section-navy { padding: 56px 0; }
          .cta-section                                   { padding: 56px 0; }
          .container                                     { padding: 0 16px; }
        }
    
        /* ── STATS BAR — responsive scale matching index.html stats-strip ── */
        @media (max-width: 1024px) {
          .stats-bar { padding: 48px 0; }
        }
        @media (max-width: 768px) {
          .stats-bar { padding: 40px 0; }
        }
        @media (max-width: 480px) {
          .stats-bar { padding: 32px 0; }
        }
        