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

    /* Tokens loaded from brand-tokens.css (StayFull Brand Kit) */

    html {
      scroll-behavior: smooth;
    }

    @media (prefers-reduced-motion: reduce) {
      html {
        scroll-behavior: auto;
      }

      .ticker-track {
        animation: none;
      }

      .hero-outer .dashboard {
        animation: none;
      }
    }

    body {
      font-family: var(--ff-body);
      font-size: 18px;
      background: var(--bg);
      color: var(--fg);
      line-height: 1.65;
      overflow-x: hidden;
    }

    /* ── NAV ─────────────────────────────── */
    nav {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 100;
      height: 60px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 40px;
      background: rgba(255, 255, 255, 0.92);
      backdrop-filter: blur(20px) saturate(180%);
      border-bottom: 1px solid var(--border);
      transition: background 0.3s;
    }

    nav.scrolled {
      background: rgba(255, 255, 255, 0.98);
    }

    .nav-logo {
      display: flex;
      align-items: center;
      text-decoration: none;
    }

    .nav-logo.lockup {
      gap: 8px;
    }

    .nav-logo .lockup-wm {
      font-family: var(--ff-head);
      font-size: 1.47rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      line-height: 1;
      color: var(--fg-3);
    }

    .nav-logo .lockup-wm .full {
      font-weight: 900;
      color: var(--primary);
    }

    .nav-links {
      display: flex;
      gap: 32px;
    }

    .nav-links a {
      font-size: 15px;
      font-weight: 500;
      letter-spacing: 0.01em;
      color: var(--fg-3);
      text-decoration: none;
      transition: color 0.15s;
    }

    .nav-links a:hover {
      color: var(--fg);
    }

    .nav-right {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .nav-signin {
      font-size: 15px;
      font-weight: 500;
      color: var(--fg-3);
      text-decoration: none;
      padding: 7px 14px;
      transition: color 0.15s;
    }

    .nav-signin:hover {
      color: var(--fg);
    }

    .nav-trial {
      font-size: 15px;
      font-weight: 600;
      color: #fff;
      background: var(--primary);
      text-decoration: none;
      padding: 8px 18px;
      border-radius: var(--radius-sm);
      transition: background 0.15s;
    }

    .nav-trial:hover {
      background: var(--primary-dark);
    }

    /* Focus visible — accessibility */
    a:focus-visible,
    button:focus-visible {
      outline: 2px solid var(--primary);
      outline-offset: 2px;
    }

    /* Skip link */
    .skip-link {
      position: absolute;
      left: 12px;
      top: -52px;
      z-index: 101;
      background: var(--fg);
      color: var(--surface);
      padding: 10px 16px;
      border-radius: var(--radius-sm);
      text-decoration: none;
      font-weight: 600;
      font-size: 14px;
      transition: top 0.15s;
    }

    .skip-link:focus-visible {
      top: 12px;
    }

    /* Mobile nav: hamburger + drawer */
    .nav-toggle {
      display: none;
      align-items: center;
      justify-content: center;
      width: 44px;
      height: 44px;
      padding: 0;
      border: 0;
      background: transparent;
      color: var(--fg);
      cursor: pointer;
      border-radius: var(--radius-sm);
    }

    .nav-toggle:hover {
      background: rgba(0, 0, 0, 0.06);
    }

    .nav-toggle-icon {
      display: block;
    }

    .nav-toggle-icon-close {
      display: none;
    }

    nav.menu-open .nav-toggle-icon {
      display: none;
    }

    nav.menu-open .nav-toggle-icon-close {
      display: block;
    }

    .nav-drawer {
      display: none;
      position: fixed;
      top: 60px;
      left: 0;
      right: 0;
      bottom: 0;
      z-index: 99;
      background: var(--bg);
      padding: 24px;
      overflow-y: auto;
      border-top: 1px solid var(--border);
    }

    .nav-drawer a {
      display: block;
      padding: 14px 0;
      font-size: 18px;
      font-weight: 500;
      color: var(--fg);
      text-decoration: none;
      border-bottom: 1px solid var(--border);
    }

    .nav-drawer a:hover {
      color: var(--primary);
    }

    .nav-drawer .nav-trial {
      border: none;
      text-align: center;
      margin-top: 16px;
      border-radius: var(--radius-md);
    }

    /* ── HERO ────────────────────────────── */
    .hero-outer {
      padding-top: 60px;
      min-height: 100vh;
      display: flex;
      flex-direction: column;
      position: relative;
    }

    /* Subtle noise texture */
    .hero-outer::before {
      content: '';
      position: absolute;
      inset: 0;
      z-index: 0;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
      opacity: 0.4;
      pointer-events: none;
    }

    .hero-glow {
      position: absolute;
      z-index: 0;
      pointer-events: none;
      top: 0;
      left: 0;
      right: 0;
      height: 70vh;
      background: radial-gradient(ellipse 70% 60% at 30% 0%, rgba(59, 130, 246, 0.08), transparent 65%),
        radial-gradient(ellipse 40% 40% at 75% 20%, rgba(37, 99, 235, 0.04), transparent 60%);
    }

    .hero-grid-line {
      position: absolute;
      inset: 0;
      z-index: 0;
      pointer-events: none;
      background-image:
        linear-gradient(var(--border) 1px, transparent 1px),
        linear-gradient(90deg, var(--border) 1px, transparent 1px);
      background-size: 80px 80px;
      mask-image: radial-gradient(ellipse 90% 60% at 30% 10%, rgba(0, 0, 0, 0.6) 0%, transparent 70%);
    }

    .hero-inner {
      position: relative;
      z-index: 1;
      max-width: 1200px;
      margin: 0 auto;
      width: 100%;
      padding: 80px 48px 60px;
      display: grid;
      grid-template-columns: 1fr 480px;
      gap: 64px;
      align-items: center;
      flex: 1;
    }

    .hero-kicker {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-family: var(--ff-mono);
      font-size: 11px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: var(--primary);
      margin-bottom: 28px;
    }

    .kicker-line {
      width: 24px;
      height: 1px;
      background: var(--primary);
    }

    .hero-h1 {
      font-family: var(--ff-head);
      font-size: clamp(40px, 5vw, 68px);
      font-weight: 800;
      line-height: 1.04;
      letter-spacing: -0.035em;
      color: var(--fg);
      margin-bottom: 10px;
    }

    .hero-h1-serif {
      font-family: var(--ff-display);
      font-style: italic;
      font-size: clamp(44px, 5.5vw, 74px);
      font-weight: 400;
      line-height: 1.04;
      letter-spacing: -0.01em;
      color: var(--primary);
      display: block;
      margin-bottom: 28px;
    }

    .hero-sub {
      font-size: 21px;
      font-weight: 300;
      line-height: 1.75;
      color: var(--fg-2);
      max-width: 540px;
      margin-bottom: 40px;
    }

    .hero-sub strong {
      color: var(--fg);
      font-weight: 600;
    }

    .hero-social-proof {
      font-size: 15px;
      color: var(--fg-3);
      margin-bottom: 20px;
      letter-spacing: 0.02em;
    }

    .hero-ctas {
      display: flex;
      align-items: center;
      gap: 14px;
      margin-bottom: 52px;
      flex-wrap: wrap;
    }

    .cta-primary {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      font-size: 17px;
      font-weight: 700;
      color: #fff;
      background: var(--primary);
      text-decoration: none;
      padding: 14px 26px;
      border-radius: var(--radius-sm);
      box-shadow: 0 0 32px rgba(59, 130, 246, 0.25), 0 4px 12px rgba(0, 0, 0, 0.08);
      transition: all 0.2s;
    }

    .cta-primary:hover {
      background: var(--primary-dark);
      transform: translateY(-1px);
      box-shadow: 0 0 44px rgba(59, 130, 246, 0.35), 0 6px 18px rgba(0, 0, 0, 0.1);
    }

    .cta-secondary {
      font-size: 16px;
      font-weight: 600;
      color: var(--fg-2);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      transition: color 0.15s;
    }

    .cta-secondary:hover {
      color: var(--fg);
    }

    .cta-secondary::after {
      content: '→';
      transition: transform 0.15s;
    }

    .cta-secondary:hover::after {
      transform: translateX(3px);
    }

    .hero-proof-row {
      display: flex;
      gap: 0;
      border-top: 1px solid var(--border);
      padding-top: 24px;
    }

    .proof-item {
      padding-right: 28px;
      margin-right: 28px;
      border-right: 1px solid var(--border);
    }

    .proof-item:last-child {
      border-right: none;
      padding-right: 0;
      margin-right: 0;
    }

    .proof-num {
      font-family: var(--ff-head);
      font-size: 30px;
      font-weight: 800;
      color: var(--fg);
      letter-spacing: -0.03em;
      line-height: 1;
      margin-bottom: 4px;
    }

    .proof-num span {
      color: var(--primary);
    }

    .proof-label {
      font-size: 12px;
      color: var(--fg-3);
      line-height: 1.4;
      text-transform: uppercase;
      letter-spacing: 0.06em;
    }

    /* Dashboard */
    .dashboard {
      background: var(--surface);
      border: 1px solid var(--border-mid);
      border-radius: var(--radius-lg);
      overflow: hidden;
      box-shadow: 0 24px 48px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
      animation: riseIn 0.9s 0.2s cubic-bezier(0.16, 1, 0.3, 1) both;
    }

    @keyframes riseIn {
      from {
        opacity: 0;
        transform: translateY(40px) scale(0.97);
      }

      to {
        opacity: 1;
        transform: none;
      }
    }

    .dash-bar {
      background: rgba(0, 0, 0, 0.03);
      border-bottom: 1px solid var(--border);
      padding: 10px 14px;
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .db {
      width: 10px;
      height: 10px;
      border-radius: 50%;
    }

    .db-r {
      background: #ff5f57;
    }

    .db-y {
      background: #febc2e;
    }

    .db-g {
      background: #28c840;
    }

    .dash-bar-title {
      font-family: var(--ff-mono);
      font-size: 10px;
      color: var(--fg-3);
      margin-left: 6px;
    }

    .dash-bar-tag {
      margin-left: auto;
      font-family: var(--ff-mono);
      font-size: 9px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--success);
      background: rgba(22, 163, 74, 0.1);
      border: 1px solid rgba(22, 163, 74, 0.2);
      padding: 2px 8px;
      border-radius: 3px;
    }

    .dash-body {
      padding: 16px;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .dash-metrics {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      gap: 8px;
    }

    .dm {
      background: rgba(0, 0, 0, 0.02);
      border: 1px solid var(--border);
      border-radius: 8px;
      padding: 10px;
    }

    .dm-l {
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.06em;
      color: var(--fg-3);
      margin-bottom: 5px;
    }

    .dm-v {
      font-family: var(--ff-body);
      font-size: 20px;
      font-weight: 800;
      color: var(--fg);
      letter-spacing: -0.02em;
    }

    .dm-d {
      font-size: 9px;
      color: var(--success);
      margin-top: 2px;
    }

    .dash-action {
      background: rgba(37, 99, 235, 0.08);
      border: 1px solid rgba(37, 99, 235, 0.2);
      border-radius: 8px;
      padding: 10px 12px;
      display: flex;
      gap: 8px;
      align-items: flex-start;
    }

    .da-badge {
      font-family: var(--ff-mono);
      font-size: 8px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--primary);
      white-space: nowrap;
      padding-top: 1px;
    }

    .da-text {
      font-size: 11px;
      color: var(--fg-2);
      line-height: 1.5;
    }

    .da-text strong {
      color: var(--fg);
    }

    .dash-log {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .dl-item {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 12px;
      color: var(--fg-2);
      padding: 6px 8px;
      border-radius: 6px;
      background: rgba(0, 0, 0, 0.02);
    }

    .dl-dot {
      width: 5px;
      height: 5px;
      border-radius: 50%;
      flex-shrink: 0;
    }

    .dl-dot.g {
      background: var(--success);
      box-shadow: 0 0 5px rgba(22, 163, 74, 0.5);
    }

    .dl-dot.b {
      background: var(--primary);
      box-shadow: 0 0 5px rgba(37, 99, 235, 0.4);
    }

    .dl-dot.o {
      background: var(--primary);
      box-shadow: 0 0 5px rgba(59, 130, 246, 0.5);
    }

    .dl-time {
      margin-left: auto;
      font-family: var(--ff-mono);
      font-size: 9px;
      color: var(--fg-3);
      flex-shrink: 0;
    }

    /* ── TICKER ──────────────────────────── */
    .ticker-outer {
      background: var(--bg-1);
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      overflow: hidden;
      position: relative;
    }

    .ticker-outer::before,
    .ticker-outer::after {
      content: '';
      position: absolute;
      top: 0;
      bottom: 0;
      width: 80px;
      z-index: 2;
    }

    .ticker-outer::before {
      left: 0;
      background: linear-gradient(90deg, var(--bg-1), transparent);
    }

    .ticker-outer::after {
      right: 0;
      background: linear-gradient(-90deg, var(--bg-1), transparent);
    }

    .ticker-track {
      display: flex;
      animation: scroll 28s linear infinite;
      white-space: nowrap;
    }

    .ticker-track:hover {
      animation-play-state: paused;
    }

    @keyframes scroll {
      to {
        transform: translateX(-50%);
      }
    }

    .ti {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 14px 36px;
      font-size: 14px;
      color: var(--fg-3);
      border-right: 1px solid var(--border);
    }

    .ti b {
      color: var(--fg-2);
      font-weight: 600;
    }

    .ti-sep {
      color: var(--primary);
      font-size: 16px;
      line-height: 1;
    }

    /* ── SHARED ──────────────────────────── */
    .wrap {
      max-width: 1160px;
      margin: 0 auto;
      padding: 0 48px;
    }

    .sec {
      padding: var(--section-padding) 0;
    }

    .section-rule {
      height: 1px;
      background: var(--border);
      margin: 0;
      width: 100%;
      max-width: 1160px;
      margin-left: auto;
      margin-right: auto;
    }

    .section-rule--space-before {
      margin-top: 52px;
    }

    .section-rule--space-after {
      margin-bottom: 52px;
    }

    .lede {
      font-family: var(--ff-body);
      font-size: 0.68rem;
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.18em;
      color: var(--fg-3);
      margin-bottom: 16px;
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .lede::before {
      content: '';
      width: 18px;
      height: 1.5px;
      background: var(--primary);
      flex-shrink: 0;
    }

    .big-h {
      font-family: var(--ff-body);
      font-size: clamp(30px, 3.6vw, 50px);
      font-weight: 800;
      letter-spacing: -0.025em;
      color: var(--fg);
      line-height: 1.1;
      margin-bottom: 16px;
    }

    .big-h-serif {
      font-family: var(--ff-display);
      font-style: italic;
      font-weight: 400;
      font-size: clamp(32px, 3.8vw, 52px);
      letter-spacing: -0.01em;
      color: var(--fg);
      line-height: 1.1;
      margin-bottom: 16px;
    }

    .body-lead {
      font-size: 20px;
      font-weight: 300;
      color: var(--fg-2);
      line-height: 1.75;
      max-width: 580px;
      margin-bottom: 48px;
    }

    /* Reveal */
    .rv {
      opacity: 0;
      transform: translateY(24px);
      transition: opacity 0.55s ease, transform 0.55s ease;
    }

    .rv.on {
      opacity: 1;
      transform: none;
    }

    /* ── PROBLEM ─────────────────────────── */
    .problem-sec {
      background: var(--bg-1);
    }

    .problem-layout {
      display: grid;
      grid-template-columns: 1fr 380px;
      gap: 80px;
      align-items: start;
      margin-top: 48px;
    }

    /* Bill-of-tools */
    .bill {
      border: 1px solid var(--border);
      border-radius: 2px;
      overflow: hidden;
    }

    .bill-head {
      background: rgba(0, 0, 0, 0.02);
      padding: 14px 20px;
      display: flex;
      justify-content: space-between;
      border-bottom: 1px solid var(--border);
      font-family: var(--ff-mono);
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: var(--fg-3);
    }

    .bill-row {
      padding: 16px 20px;
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: flex-start;
      gap: 16px;
      transition: background 0.15s;
    }

    .bill-row:hover {
      background: rgba(0, 0, 0, 0.02);
    }

    .bill-row:last-child {
      border-bottom: none;
    }

    .bill-n {
      font-family: var(--ff-mono);
      font-size: 10px;
      color: var(--fg-3);
      padding-top: 2px;
      width: 18px;
      flex-shrink: 0;
    }

    .bill-name {
      font-size: 17px;
      font-weight: 600;
      color: var(--fg-2);
      margin-bottom: 3px;
    }

    .bill-desc {
      font-size: 15px;
      color: var(--fg-3);
      line-height: 1.55;
    }

    .bill-cost {
      font-family: var(--ff-mono);
      font-size: 13px;
      font-weight: 600;
      color: #dc2626;
      margin-left: auto;
      flex-shrink: 0;
    }

    .bill-foot {
      background: rgba(220, 38, 38, 0.06);
      border-top: 1px solid rgba(220, 38, 38, 0.15);
      padding: 14px 20px;
      display: flex;
      justify-content: space-between;
      align-items: center;
    }

    .bill-foot-label {
      font-size: 16px;
      font-weight: 600;
      color: var(--fg-2);
    }

    .bill-foot-total {
      font-family: var(--ff-mono);
      font-size: 18px;
      font-weight: 700;
      color: #dc2626;
    }

    /* Replace panel */
    .replace-panel {
      position: sticky;
      top: 80px;
    }

    .replace-label {
      font-family: var(--ff-mono);
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: var(--fg-3);
      margin-bottom: 20px;
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .replace-label::before {
      content: '';
      flex: 1;
      height: 1px;
      background: var(--border);
    }

    .replace-label::after {
      content: '';
      flex: 1;
      height: 1px;
      background: var(--border);
    }

    .replace-price {
      text-align: center;
      margin-bottom: 24px;
    }

    .replace-from {
      font-family: var(--ff-mono);
      font-size: 12px;
      color: var(--fg-3);
      text-decoration: line-through;
      margin-bottom: 4px;
    }

    .replace-amt {
      font-family: var(--ff-body);
      font-size: 56px;
      font-weight: 800;
      color: var(--fg);
      letter-spacing: -0.04em;
      line-height: 1;
    }

    .replace-per {
      font-size: 13px;
      color: var(--fg-3);
      margin-top: 4px;
    }

    .replace-everything {
      font-size: 13px;
      color: var(--fg-2);
      text-align: center;
      margin-bottom: 24px;
      line-height: 1.6;
    }

    .replace-list {
      list-style: none;
      display: flex;
      flex-direction: column;
      border-top: 1px solid var(--border);
      margin-bottom: 24px;
    }

    .replace-list li {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 15px;
      color: var(--fg-2);
      padding: 10px 0;
      border-bottom: 1px solid var(--border);
    }

    .replace-list li::before {
      content: '↗';
      color: var(--primary);
      font-size: 11px;
      flex-shrink: 0;
    }

    .replace-cta {
      display: block;
      text-align: center;
      font-size: 16px;
      font-weight: 700;
      color: #fff;
      background: var(--primary);
      text-decoration: none;
      padding: 14px;
      border-radius: 6px;
      transition: background 0.15s;
    }

    .replace-cta:hover {
      background: var(--primary-dark);
    }

    .replace-fine {
      text-align: center;
      font-size: 11px;
      color: var(--fg-3);
      margin-top: 10px;
    }

    /* ── FEATURES ────────────────────────── */
    .features-sec {
      background: var(--bg);
    }

    /* Feature blocks — alternating text left/right, mock or placeholder */
    .feat-blocks {
      margin-top: 40px;
    }

    .feat-block {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0;
      align-items: center;
      min-height: 280px;
      border: 1px solid var(--border);
      border-bottom: none;
      transition: background 0.15s;
    }

    .feat-block:last-child {
      border-bottom: 1px solid var(--border);
    }

    .feat-block:hover {
      background: rgba(255, 255, 255, 0.02);
    }

    .feat-block--text-right .feat-block-text {
      order: 2;
    }

    .feat-block--text-right .feat-block-mock {
      order: 1;
    }

    .feat-block-text {
      padding: 40px 44px;
      border-right: 1px solid var(--border);
    }

    .feat-block--text-right .feat-block-text {
      border-right: none;
      border-left: 1px solid var(--border);
    }

    .feat-block-num {
      font-family: var(--ff-mono);
      font-size: 11px;
      color: var(--fg-3);
      letter-spacing: 0.1em;
      margin-bottom: 12px;
    }

    .feat-block-text h3 {
      font-size: 24px;
      font-weight: 700;
      color: var(--fg);
      letter-spacing: -0.02em;
      margin-bottom: 6px;
    }

    .feat-block-text .ft {
      font-family: var(--ff-mono);
      font-size: 13px;
      color: var(--primary);
      letter-spacing: 0.05em;
      margin-bottom: 12px;
      display: block;
    }

    .feat-block-text p {
      font-size: 17px;
      color: var(--fg-2);
      line-height: 1.65;
      margin-bottom: 12px;
    }

    .feat-block-text .feat-proof {
      margin-top: 8px;
      margin-bottom: 0;
    }

    .feat-block-mock {
      padding: 32px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: rgba(0, 0, 0, 0.02);
    }

    .feat-block-mock--padded {
      padding: 40px;
    }

    .feat-mock-inner {
      width: 100%;
      max-width: 100%;
    }

    .feat-mock-placeholder {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 12px;
      width: 100%;
      min-height: 200px;
      background: rgba(0, 0, 0, 0.03);
      border: 1px dashed var(--border);
      border-radius: var(--radius-md);
      color: var(--fg-3);
    }

    .feat-mock-icon {
      font-size: 36px;
      opacity: 0.7;
    }

    .feat-mock-label {
      font-family: var(--ff-mono);
      font-size: 11px;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }

    .feat-block--included .feat-block-num {
      color: var(--fg-3);
    }

    .mock-card {
      background: rgba(0, 0, 0, 0.02);
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      padding: 14px 16px;
    }

    .mock-caption {
      font-family: var(--ff-mono);
      font-size: 9px;
      color: var(--fg-3);
      text-transform: uppercase;
      letter-spacing: 0.08em;
      margin-bottom: 10px;
    }

    .mock-card-body {
      font-size: 12px;
      color: var(--fg-2);
      line-height: 1.7;
    }

    .mock-fg {
      color: var(--fg);
    }

    .mock-success {
      color: var(--success);
    }

    .mock-mono-blue {
      font-family: var(--ff-mono);
      color: var(--primary);
    }

    .mock-badge {
      border-radius: var(--radius-md);
      padding: 12px 16px;
      font-size: 12px;
    }

    .mock-badge--success {
      background: rgba(22, 163, 74, 0.08);
      border: 1px solid rgba(22, 163, 74, 0.2);
      color: var(--success);
    }

    .mock-progress {
      height: 6px;
      background: var(--border);
      border-radius: 3px;
      overflow: hidden;
    }

    .mock-progress-fill {
      height: 100%;
      background: linear-gradient(90deg, var(--grad-end), var(--grad-start));
      border-radius: 3px;
      transition: width 0.4s ease;
    }

    .mock-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
    }

    .mock-pill {
      font-family: var(--ff-mono);
      font-size: 10px;
      color: var(--fg-3);
      background: rgba(0, 0, 0, 0.04);
      padding: 4px 8px;
      border-radius: 4px;
    }

    .mock-sequence {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .mock-seq-step {
      font-size: 12px;
      color: var(--fg-2);
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .mock-seq-step--done {
      color: var(--fg-3);
    }

    .mock-seq-day {
      font-family: var(--ff-mono);
      font-size: 10px;
      color: var(--fg-3);
      min-width: 36px;
    }

    .mock-channels {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .mock-channel {
      font-size: 12px;
      color: var(--fg-2);
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .mock-channel::before {
      content: '';
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--border-mid);
    }

    .mock-channel--ok::before {
      background: var(--success);
    }

    .mock-channel--warn::before {
      background: #ca8a04;
    }

    /* Big feature — editorial layout (legacy, kept for rate-bar/chat reuse) */
    .feat-editorial {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0;
      border: 1px solid var(--border);
      border-radius: 2px;
      overflow: hidden;
      margin-bottom: 24px;
    }

    .feat-editorial-left {
      padding: 52px 48px;
      border-right: 1px solid var(--border);
    }

    .feat-editorial-right {
      padding: 40px;
      display: flex;
      flex-direction: column;
      gap: 8px;
      justify-content: center;
      background: rgba(0, 0, 0, 0.01);
    }

    .feat-num-big {
      font-family: var(--ff-mono);
      font-size: 80px;
      font-weight: 600;
      color: var(--border-mid);
      line-height: 1;
      margin-bottom: 16px;
      letter-spacing: -0.04em;
    }

    .feat-editorial-left h3 {
      font-family: var(--ff-body);
      font-size: 28px;
      font-weight: 800;
      color: var(--fg);
      letter-spacing: -0.025em;
      margin-bottom: 6px;
    }

    .feat-tag {
      font-family: var(--ff-mono);
      font-size: 10px;
      color: var(--primary);
      letter-spacing: 0.06em;
      margin-bottom: 16px;
      display: block;
    }

    .feat-editorial-left p {
      font-size: 17px;
      color: var(--fg-2);
      line-height: 1.75;
      margin-bottom: 20px;
    }

    .feat-proof {
      font-size: 14px;
      color: var(--fg-3);
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .feat-proof strong {
      color: var(--success);
    }

    /* Rate bars */
    .rate-bar {
      margin-bottom: 8px;
    }

    .rb-head {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      margin-bottom: 6px;
    }

    .rb-label {
      font-size: 11px;
      color: var(--fg-3);
    }

    .rb-val {
      font-family: var(--ff-mono);
      font-size: 12px;
      font-weight: 600;
    }

    .rb-val.up {
      color: var(--success);
    }

    .rb-val.hold {
      color: var(--fg-3);
    }

    .rb-track {
      height: 4px;
      background: var(--border);
      border-radius: 2px;
      overflow: hidden;
    }

    .rb-fill {
      height: 100%;
      border-radius: 2px;
    }

    .rb-fill.up {
      background: linear-gradient(90deg, #1d4ed8, #3b82f6);
    }

    .rb-fill.hold {
      background: var(--border-mid);
    }

    .rb-note {
      font-size: 10px;
      color: var(--fg-3);
      font-style: italic;
      margin-top: 12px;
      line-height: 1.5;
    }

    /* Feature row list */
    .feat-rows {
      border-top: 1px solid var(--border);
      margin-top: 24px;
    }

    .feat-row {
      display: grid;
      grid-template-columns: 48px 1fr 1fr;
      gap: 0;
      border-bottom: 1px solid var(--border);
      transition: background 0.15s;
    }

    .feat-row:hover {
      background: rgba(0, 0, 0, 0.02);
    }

    .feat-row-num {
      font-family: var(--ff-mono);
      font-size: 10px;
      color: var(--fg-3);
      padding: 24px 0 24px 0;
      border-right: 1px solid var(--border);
      display: flex;
      align-items: flex-start;
      justify-content: center;
      padding-top: 28px;
    }

    .feat-row-left {
      padding: 24px 32px 24px 28px;
      border-right: 1px solid var(--border);
    }

    .feat-row-right {
      padding: 24px 28px;
      display: flex;
      align-items: center;
    }

    .feat-row-icon {
      font-size: 20px;
      margin-bottom: 10px;
    }

    .feat-row-left h3 {
      font-size: 17px;
      font-weight: 700;
      color: var(--fg);
      margin-bottom: 4px;
      letter-spacing: -0.01em;
    }

    .feat-row-left .ft {
      font-family: var(--ff-mono);
      font-size: 11px;
      color: var(--primary);
      letter-spacing: 0.05em;
      margin-bottom: 10px;
      display: block;
    }

    .feat-row-left p {
      font-size: 15px;
      color: var(--fg-2);
      line-height: 1.65;
    }

    /* Chat demo */
    .chat-demo {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .bubble {
      border-radius: 10px;
      padding: 10px 13px;
      font-size: 12px;
      line-height: 1.5;
      max-width: 88%;
    }

    .bubble-from {
      font-family: var(--ff-mono);
      font-size: 8px;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      margin-bottom: 4px;
    }

    .bubble.guest {
      background: rgba(255, 255, 255, 0.05);
      border: 1px solid var(--border);
      color: var(--fg-2);
    }

    .bubble.guest .bubble-from {
      color: var(--fg-3);
    }

    .bubble.ai {
      background: rgba(37, 99, 235, 0.08);
      border: 1px solid rgba(37, 99, 235, 0.2);
      color: var(--fg);
      margin-left: auto;
    }

    .bubble.ai .bubble-from {
      color: var(--primary);
    }

    /* Feature grid — uniform cards after spotlight blocks */
    .feat-grid-lede {
      font-family: var(--ff-mono);
      font-size: 11px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--fg-3);
      margin: 40px 0 16px;
      padding-top: 32px;
      border-top: 1px solid var(--border);
    }

    .feat-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      overflow: hidden;
      margin-bottom: 24px;
    }

    .feat-grid:last-child {
      margin-bottom: 0;
    }

    .feat-grid-first,
    .feat-grid-3 {
      grid-template-columns: repeat(3, 1fr);
    }

    .feat-grid-first .feat-mini:nth-child(3n),
    .feat-grid-3 .feat-mini:nth-child(3n) {
      border-right: none;
    }

    .feat-grid-first .feat-mini:nth-last-child(-n+3),
    .feat-grid-3 .feat-mini:nth-last-child(-n+3) {
      border-bottom: none;
    }

    .feat-grid-2 {
      grid-template-columns: repeat(2, 1fr);
    }

    .feat-grid-2 .feat-mini:nth-child(2n) {
      border-right: none;
    }

    .feat-grid-2 .feat-mini:nth-last-child(-n+2) {
      border-bottom: none;
    }

    .feat-mini {
      padding: 28px 24px;
      border-right: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      transition: background 0.15s;
    }

    .feat-grid .feat-mini:nth-child(4n) {
      border-right: none;
    }

    .feat-grid .feat-mini:nth-last-child(-n+4) {
      border-bottom: none;
    }

    .feat-mini:hover {
      background: rgba(0, 0, 0, 0.02);
    }

    .feat-mini-included .feat-mini-num {
      color: var(--fg-3);
    }

    .feat-mini-icon {
      font-size: 22px;
      margin-bottom: 14px;
    }

    .feat-mini-num {
      font-family: var(--ff-mono);
      font-size: 9px;
      color: var(--fg-3);
      letter-spacing: 0.1em;
      margin-bottom: 10px;
    }

    .feat-mini h3 {
      font-size: 16px;
      font-weight: 700;
      color: var(--fg);
      margin-bottom: 4px;
      letter-spacing: -0.01em;
    }

    .feat-mini .ft {
      font-family: var(--ff-mono);
      font-size: 11px;
      color: var(--primary);
      letter-spacing: 0.05em;
      margin-bottom: 10px;
      display: block;
    }

    .feat-mini p {
      font-size: 15px;
      color: var(--fg-2);
      line-height: 1.65;
    }

    /* ── FOUNDER ─────────────────────────── */
    .founder-sec {
      background: var(--bg-1);
    }

    .founder-layout {
      display: grid;
      grid-template-columns: 1fr 400px;
      gap: 80px;
      align-items: start;
      margin-top: 48px;
    }

    .founder-quote {
      font-family: var(--ff-display);
      font-style: italic;
      font-size: clamp(22px, 2.8vw, 32px);
      font-weight: 400;
      line-height: 1.45;
      color: var(--fg);
      letter-spacing: -0.01em;
      margin-bottom: 32px;
      padding-left: 28px;
      border-left: 2px solid var(--primary);
    }

    .founder-quote em {
      font-style: normal;
      color: var(--primary);
    }

    .founder-body {
      font-size: 17px;
      font-weight: 300;
      color: var(--fg-2);
      line-height: 1.78;
      margin-bottom: 32px;
    }

    .founder-body+.founder-body {
      margin-top: -16px;
    }

    .section-label {
      font-family: var(--ff-body);
      font-size: 0.68rem;
      font-weight: 500;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--fg-3);
      margin-top: 48px;
      margin-bottom: 24px;
    }

    .belief-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0;
    }

    .belief {
      padding: 28px 0;
      border-top: 1.5px solid var(--border);
    }

    .belief:nth-child(odd) {
      padding-right: 40px;
      border-right: 1px solid var(--border);
    }

    .belief:nth-child(even) {
      padding-left: 40px;
    }

    .belief-num {
      font-family: var(--ff-head);
      font-size: 0.65rem;
      font-weight: 700;
      letter-spacing: 0.14em;
      color: var(--primary);
      text-transform: uppercase;
      margin-bottom: 12px;
    }

    .belief-title {
      font-family: var(--ff-head);
      font-size: 0.92rem;
      font-weight: 700;
      color: var(--fg);
      line-height: 1.35;
      margin-bottom: 10px;
      letter-spacing: -0.01em;
    }

    .belief-list {
      list-style: none;
      margin-top: 10px;
      display: flex;
      flex-direction: column;
      gap: 5px;
    }

    .belief-list li {
      font-size: 0.83rem;
      line-height: 1.6;
      color: var(--fg-2);
      font-weight: 300;
      display: flex;
      align-items: baseline;
      gap: 8px;
    }

    .belief-list li::before {
      content: "—";
      color: var(--primary);
      font-weight: 400;
      flex-shrink: 0;
    }

    .belief-text {
      font-size: 0.83rem;
      line-height: 1.78;
      color: var(--fg-2);
      font-weight: 300;
    }

    .our-why-bullets {
      list-style: none;
      margin-top: 32px;
      margin-bottom: 0;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px 32px;
    }

    .our-why-bullets li {
      font-size: 0.9rem;
      line-height: 1.5;
      color: var(--fg-2);
      font-weight: 300;
      display: flex;
      align-items: baseline;
      gap: 10px;
    }

    .our-why-bullets li::before {
      content: "—";
      color: var(--primary);
      font-weight: 500;
      flex-shrink: 0;
    }

    @media (max-width: 640px) {
      .our-why-bullets {
        grid-template-columns: 1fr;
      }

      .pricing-cards {
        grid-template-columns: 1fr;
      }
    }

    .founder-sig {
      display: flex;
      align-items: center;
      gap: 14px;
      margin-top: 40px;
    }

    .our-why-sec .founder-sig {
      margin-top: 24px;
    }

    .our-why-manifesto-link {
      margin-top: 40px;
      margin-bottom: 0;
      font-size: 0.9rem;
      font-weight: 500;
      color: var(--fg-2);
    }

    .our-why-sec .founder-sig+.our-why-manifesto-link {
      margin-top: 14px;
    }

    .our-why-sec .our-why-manifesto-link {
      margin-top: 28px;
    }

    .our-why-manifesto-link a {
      color: var(--primary);
      text-decoration: none;
      letter-spacing: 0.02em;
    }

    .our-why-manifesto-link a:hover {
      text-decoration: underline;
    }

    .f-avatar {
      width: 48px;
      height: 48px;
      border-radius: 50%;
      flex-shrink: 0;
      object-fit: cover;
      display: block;
    }

    .f-name {
      font-size: 14px;
      font-weight: 700;
      color: var(--fg);
    }

    .f-title {
      font-size: 12px;
      color: var(--fg-3);
    }

    .founder-closing {
      margin-top: 48px;
      width: 100%;
      background: var(--fg);
      padding: 44px 48px;
      position: relative;
      overflow: hidden;
      display: flex;
      align-items: flex-start;
      gap: 24px;
    }

    .our-why-sec .founder-closing {
      margin-top: 32px;
      padding: 14px 24px;
      display: block;
    }

    .founder-closing-sig {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .founder-closing-avatar {
      width: 56px;
      height: 56px;
      border-radius: 50%;
      object-fit: cover;
      flex-shrink: 0;
    }

    .our-why-sec .founder-closing-avatar {
      width: 40px;
      height: 40px;
    }

    .founder-closing-name {
      font-size: 14px;
      font-weight: 700;
      color: #f9fafb;
    }

    .founder-closing-title {
      font-size: 11px;
      color: #9ca3af;
      display: block;
      margin-top: 1px;
    }

    .founder-closing-body {
      flex: 1;
      min-width: 0;
    }

    .founder-closing::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      height: 3px;
      background: linear-gradient(90deg, var(--primary-dark), var(--primary-light));
    }

    .founder-closing-quote {
      font-family: var(--ff-display);
      font-style: italic;
      font-size: clamp(1rem, 2.2vw, 1.28rem);
      font-weight: 400;
      line-height: 1.7;
      color: #f9fafb;
      margin-bottom: 20px;
      max-width: 540px;
    }

    .founder-closing-body .founder-closing-quote {
      margin-top: 0;
    }

    .founder-closing-quote strong {
      font-style: normal;
      font-weight: 700;
      color: var(--primary-light);
      font-family: var(--ff-head);
    }

    .founder-closing-attr {
      font-family: var(--ff-body);
      font-size: 0.7rem;
      font-weight: 500;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: #9ca3af;
    }

    .founder-stats {
      position: sticky;
      top: 80px;
      display: flex;
      flex-direction: column;
      gap: 2px;
    }

    .f-stat {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: 2px;
      padding: 20px 24px;
      display: flex;
      justify-content: space-between;
      align-items: flex-end;
    }

    .f-stat-label {
      font-size: 12px;
      color: var(--fg-3);
      line-height: 1.4;
      max-width: 160px;
    }

    .f-stat-val {
      font-family: var(--ff-body);
      font-size: 28px;
      font-weight: 800;
      color: var(--fg);
      letter-spacing: -0.03em;
      line-height: 1;
    }

    .f-stat-val span {
      color: var(--primary);
    }

    .f-properties {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: 2px;
      padding: 20px 24px;
      margin-top: 2px;
    }

    .f-prop-label {
      font-family: var(--ff-mono);
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: var(--fg-3);
      margin-bottom: 14px;
    }

    .f-prop {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 10px 0;
      border-bottom: 1px solid var(--border);
    }

    .f-prop:last-child {
      border-bottom: none;
      padding-bottom: 0;
    }

    .f-prop-name {
      font-size: 13px;
      font-weight: 600;
      color: var(--fg-2);
    }

    .f-prop-loc {
      font-size: 11px;
      color: var(--fg-3);
      margin-top: 1px;
    }

    .f-prop-live {
      font-family: var(--ff-mono);
      font-size: 9px;
      color: var(--success);
      letter-spacing: 0.06em;
      display: flex;
      align-items: center;
      gap: 4px;
    }

    .f-prop-live::before {
      content: '';
      width: 5px;
      height: 5px;
      border-radius: 50%;
      background: var(--success);
      box-shadow: 0 0 5px rgba(22, 163, 74, 0.5);
    }

    /* ── HOW IT WORKS ────────────────────── */
    .how-sec {
      background: var(--bg);
    }

    .how-layout {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 64px;
      align-items: start;
      margin-top: 48px;
    }

    .how-steps {
      display: flex;
      flex-direction: column;
      gap: 0;
    }

    .how-step {
      display: flex;
      gap: 20px;
      padding: 20px 0;
      border-bottom: 1px solid var(--border);
      cursor: pointer;
    }

    .how-step:first-child {
      border-top: 1px solid var(--border);
    }

    .how-n {
      font-family: var(--ff-mono);
      font-size: 11px;
      font-weight: 600;
      color: var(--fg-3);
      padding-top: 3px;
      flex-shrink: 0;
      width: 20px;
      transition: color 0.2s;
    }

    .how-step.active .how-n {
      color: var(--primary);
    }

    .how-step h3 {
      font-size: 19px;
      font-weight: 700;
      color: var(--fg-3);
      margin-bottom: 5px;
      letter-spacing: -0.01em;
      transition: color 0.2s;
    }

    .how-step.active h3 {
      color: var(--fg);
    }

    .how-step p {
      font-size: 17px;
      color: var(--fg-3);
      line-height: 1.65;
      transition: color 0.2s;
    }

    .how-step.active p {
      color: var(--fg-2);
    }

    .how-t {
      font-family: var(--ff-mono);
      font-size: 10px;
      color: var(--primary);
      margin-top: 6px;
      opacity: 0;
      transition: opacity 0.2s;
    }

    .how-step.active .how-t {
      opacity: 1;
    }

    .how-screen {
      background: var(--surface);
      border: 1px solid var(--border-mid);
      border-radius: 8px;
      padding: 28px;
      min-height: 300px;
      display: flex;
      flex-direction: column;
    }

    .how-screen-label {
      font-family: var(--ff-mono);
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: var(--fg-3);
      margin-bottom: 20px;
    }

    .how-bubbles {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    /* ── PRICING ── */
    .pricing-sec {
      background: var(--bg-1);
    }

    .pricing-intro-head {
      font-family: var(--ff-body);
      font-size: clamp(28px, 3.4vw, 46px);
      font-weight: 800;
      letter-spacing: -0.025em;
      color: var(--fg);
      line-height: 1.1;
      margin-bottom: 12px;
    }

    /* Revenue band cards on top */
    .pricing-subline {
      font-size: 1.05rem;
      font-weight: 600;
      color: var(--fg);
      margin-top: 12px;
      margin-bottom: 0;
      max-width: 540px;
    }

    .pricing-band-head {
      font-family: var(--ff-body);
      font-size: 0.9rem;
      font-weight: 600;
      color: var(--fg-2);
      margin-top: 48px;
      margin-bottom: 8px;
    }

    .pricing-all-included {
      font-size: 0.9rem;
      font-weight: 500;
      color: var(--fg-2);
      margin: 0 0 20px 0;
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .pricing-all-included-icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 18px;
      height: 18px;
      border-radius: 50%;
      background: rgba(22, 163, 74, 0.12);
      color: var(--success);
      font-size: 10px;
      font-weight: 700;
      flex-shrink: 0;
    }

    .pricing-full-platform {
      font-size: 0.85rem;
      color: var(--fg-3);
      text-align: center;
      margin: 20px 0 0 0;
      padding: 0;
    }

    .pricing-cards {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
    }

    .pricing-card {
      border: 1.5px solid var(--border);
      border-radius: 8px;
      padding: 24px;
      cursor: pointer;
      transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
      background: var(--bg);
    }

    .pricing-card:hover {
      border-color: var(--primary-light);
      background: rgba(37, 99, 235, 0.02);
    }

    .pricing-card.sel {
      border-color: var(--primary);
      background: rgba(37, 99, 235, 0.06);
      box-shadow: 0 0 0 1px var(--primary);
    }

    .pricing-card-label {
      font-size: 0.75rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--primary);
      margin-bottom: 8px;
    }

    .pricing-card-band {
      font-size: 0.95rem;
      color: var(--fg-2);
      line-height: 1.4;
      margin-bottom: 16px;
    }

    .pricing-card-price {
      font-family: var(--ff-body);
      font-size: 2rem;
      font-weight: 800;
      color: var(--fg);
      letter-spacing: -0.02em;
      margin-bottom: 4px;
    }

    .pricing-card-mo {
      font-size: 0.9rem;
      font-weight: 400;
      color: var(--fg-3);
    }

    .pricing-card-txn {
      font-family: var(--ff-mono);
      font-size: 0.7rem;
      color: var(--primary);
    }

    .pricing-cta-wrap {
      margin-top: 40px;
      text-align: center;
    }

    .pricing-confidence {
      font-size: 1.05rem;
      font-weight: 500;
      color: var(--fg-2);
      margin: 0 0 20px 0;
    }

    .pricing-trust {
      list-style: none;
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 24px 32px;
      margin: 0 0 24px 0;
      padding: 0;
      font-size: 1rem;
      font-weight: 500;
      color: var(--fg-2);
    }

    .pricing-trust li {
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .pricing-trust-icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 20px;
      height: 20px;
      border-radius: 50%;
      background: rgba(22, 163, 74, 0.12);
      color: var(--success);
      font-size: 11px;
      font-weight: 700;
      line-height: 1;
    }

    .pricing-cta {
      display: inline-block;
      font-size: 17px;
      font-weight: 700;
      color: #fff;
      background: var(--primary);
      text-decoration: none;
      padding: 14px 32px;
      border-radius: 6px;
      transition: background 0.15s;
    }

    .pricing-cta:hover {
      background: var(--primary-dark);
    }

    .pricing-cta-note {
      font-size: 12px;
      color: var(--fg-3);
      margin-top: 14px;
      line-height: 1.5;
    }

    .pricing-cta-note a {
      color: var(--primary);
      text-decoration: none;
    }

    /* What's included — single feature list below */
    .pricing-included {
      margin-top: 56px;
      padding-top: 48px;
      border-top: 1px solid var(--border);
    }

    .pricing-included-title {
      font-family: var(--ff-head);
      font-size: 1.1rem;
      font-weight: 700;
      color: var(--fg);
      margin-bottom: 6px;
    }

    .pricing-included-sub {
      font-size: 0.9rem;
      color: var(--fg-3);
      margin-bottom: 24px;
    }

    .af-features {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
    }

    .af-feature {
      padding: 16px 20px;
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: flex-start;
      gap: 12px;
      border-right: 1px solid var(--border);
    }

    .af-feature:nth-child(even) {
      border-right: none;
    }

    .af-feature-icon {
      font-size: 16px;
      flex-shrink: 0;
      margin-top: 1px;
    }

    .af-feature-name {
      font-size: 13px;
      font-weight: 600;
      color: var(--fg);
      margin-bottom: 2px;
    }

    .af-feature-desc {
      font-size: 11px;
      color: var(--fg-3);
      line-height: 1.4;
    }

    /* ── COMPARE ─────────────────────────── */
    /* ── Billing toggle ── */
    .billing-toggle {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 12px;
      margin-bottom: 32px;
      position: relative;
    }

    .toggle-label {
      font-size: 14px;
      font-weight: 600;
      line-height: 1;
      color: var(--fg-3);
      cursor: pointer;
      transition: color 0.2s;
    }

    .toggle-label.active {
      color: var(--fg);
    }

    .toggle-track {
      width: 46px;
      height: 26px;
      background: var(--border-mid);
      border-radius: 100px;
      position: relative;
      cursor: pointer;
      transition: background 0.25s;
    }

    .toggle-track.annual {
      background: var(--primary);
    }

    .toggle-thumb {
      width: 20px;
      height: 20px;
      background: #fff;
      border-radius: 50%;
      position: absolute;
      top: 3px;
      left: 3px;
      box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
      transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .toggle-track.annual .toggle-thumb {
      transform: translateX(20px);
    }

    .save-badge {
      font-family: var(--ff-mono);
      font-size: 11px;
      font-weight: 600;
      line-height: 1;
      color: var(--success);
      background: rgba(22, 163, 74, 0.08);
      border: 1px solid rgba(22, 163, 74, 0.2);
      padding: 4px 10px 3px 10px;
      border-radius: 100px;
      position: absolute;
      left: 50%;
      transform: translateX(95px);
    }

    /* ── Slider Card ── */
    .pricing-slider-card {
      max-width: 600px;
      margin: 0 auto;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: 16px;
      padding: 32px;
      box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03);
    }

    .slider-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 24px;
    }

    .slider-rooms-label {
      font-size: 16px;
      font-weight: 600;
      color: var(--fg);
    }

    .slider-rooms-value {
      font-family: var(--ff-body);
      font-size: 24px;
      font-weight: 800;
      color: var(--primary);
      background: rgba(37, 99, 235, 0.08);
      padding: 6px 16px;
      border-radius: 100px;
    }

    .slider-container {
      margin-bottom: 32px;
    }

    .room-slider {
      -webkit-appearance: none;
      width: 100%;
      height: 6px;
      border-radius: 6px;
      background: var(--border-mid);
      outline: none;
      margin: 16px 0;
    }

    .room-slider::-webkit-slider-thumb {
      -webkit-appearance: none;
      appearance: none;
      width: 28px;
      height: 28px;
      border-radius: 50%;
      background: #fff;
      border: 2px solid var(--primary);
      cursor: pointer;
      box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
      transition: transform 0.1s;
    }

    .room-slider::-webkit-slider-thumb:hover {
      transform: scale(1.1);
    }

    .slider-marks {
      display: flex;
      justify-content: space-between;
      font-family: var(--ff-mono);
      font-size: 12px;
      color: var(--fg-3);
    }

    .slider-result {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      padding: 24px 32px;
      background: var(--bg-1);
      border-radius: 12px;
      border: 1px solid var(--border);
      margin-bottom: 24px;
    }

    .slider-room-band {
      font-size: 20px;
      font-weight: 700;
      color: var(--fg);
    }

    .slider-price-info {
      text-align: right;
    }

    .slider-price-was {
      font-family: var(--ff-mono);
      font-size: 13px;
      color: var(--fg-3);
      text-decoration: line-through;
      margin-bottom: 2px;
    }

    .slider-price-now {
      font-family: var(--ff-body);
      font-size: 36px;
      font-weight: 800;
      color: var(--fg);
      line-height: 1;
      letter-spacing: -0.03em;
    }

    .slider-price-note {
      font-family: var(--ff-mono);
      font-size: 11px;
      color: var(--success);
      margin-top: 6px;
      min-height: 14px;
    }

    .slider-cta-area {
      text-align: center;
    }

    @media (max-width: 640px) {
      .pricing-slider-card {
        padding: 24px 20px;
      }

      .slider-result {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
      }

      .slider-price-info {
        text-align: left;
      }
    }


    /* ── COMPARE ─────────────────────────── */
    .compare-sec {
      background: var(--bg);
    }

    .ctable {
      width: 100%;
      border-collapse: collapse;
      margin-top: 48px;
    }

    .ctable th,
    .ctable td {
      padding: 14px 20px;
      font-size: 15px;
      text-align: center;
      border-bottom: 1px solid var(--border);
    }

    .ctable th {
      font-size: 15px;
      font-weight: 700;
      color: var(--fg);
      background: var(--surface);
      padding: 16px 20px;
    }

    .ctable th:first-child,
    .ctable td:first-child {
      text-align: left;
      color: var(--fg-2);
    }

    .ctable th.sf {
      background: rgba(37, 99, 235, 0.1);
      color: var(--primary);
      border-left: 1px solid rgba(37, 99, 235, 0.2);
      border-right: 1px solid rgba(37, 99, 235, 0.2);
    }

    .ctable td.sf {
      background: rgba(37, 99, 235, 0.04);
      border-left: 1px solid rgba(37, 99, 235, 0.12);
      border-right: 1px solid rgba(37, 99, 235, 0.12);
    }

    .ck {
      color: var(--success);
      font-weight: 700;
    }

    .cx {
      color: #dc2626;
    }

    .cp {
      color: var(--primary-dark);
      font-size: 11px;
    }

    /* ── CTA ─────────────────────────────── */
    .cta-sec {
      background: var(--bg-1);
      padding: var(--section-padding) 0;
    }

    .cta-box {
      max-width: 760px;
      margin: 0 auto;
      padding: 0 48px;
      text-align: center;
    }

    .cta-h {
      font-family: var(--ff-display);
      font-style: italic;
      font-size: clamp(32px, 5vw, 52px);
      font-weight: 400;
      color: var(--fg);
      line-height: 1.2;
      letter-spacing: -0.01em;
      margin-bottom: 16px;
    }

    .cta-sub {
      font-size: 20px;
      color: var(--fg-2);
      margin-bottom: 36px;
      line-height: 1.7;
    }

    .cta-acts {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      flex-wrap: wrap;
    }

    .cta-fine {
      font-size: 12px;
      color: var(--fg-3);
      margin-top: 16px;
    }

    .cta-fine a {
      color: var(--primary);
      text-decoration: none;
    }

    /* ── FOOTER ──────────────────────────── */
    footer {
      background: var(--bg);
      border-top: 1px solid var(--border);
      padding: 56px 48px 36px;
    }

    .foot-inner {
      max-width: 1160px;
      margin: 0 auto;
    }

    .foot-top {
      display: grid;
      grid-template-columns: 2fr 1fr 1fr 1fr;
      gap: 48px;
      margin-bottom: 48px;
    }

    .foot-brand .lockup {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      color: inherit;
      flex-shrink: 0;
    }

    .lockup-footer .lockup-wm {
      font-family: var(--ff-head);
      font-size: 1.1rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      line-height: 1;
      color: var(--fg-3);
    }

    .lockup-footer .lockup-wm .full {
      font-weight: 900;
      color: var(--primary);
    }

    .foot-brand p {
      font-size: 14px;
      color: var(--fg-3);
      margin-top: 14px;
      line-height: 1.65;
      max-width: 260px;
    }

    .foot-col h4 {
      font-family: var(--ff-mono);
      font-size: 10px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: var(--fg-3);
      margin-bottom: 14px;
    }

    .foot-col ul {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 9px;
    }

    .foot-col ul li a {
      font-size: 14px;
      color: var(--fg-3);
      text-decoration: none;
      transition: color 0.15s;
    }

    .foot-col ul li a:hover {
      color: var(--fg);
    }

    .foot-bottom {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding-top: 28px;
      border-top: 1px solid var(--border);
      font-size: 12px;
      color: var(--fg-3);
    }

    .foot-bottom a {
      color: var(--fg-3);
      text-decoration: none;
      transition: color 0.15s;
    }

    .foot-bottom a:hover {
      color: var(--fg);
    }

    /* ── RESPONSIVE ──────────────────────── */
    @media (max-width: 1024px) {
      .hero-inner {
        grid-template-columns: 1fr;
        text-align: center;
        padding: 60px 32px;
      }

      .hero-sub {
        margin: 0 auto 40px;
      }

      .hero-ctas {
        justify-content: center;
      }

      .hero-proof-row {
        justify-content: center;
      }

      .dashboard {
        max-width: 480px;
        margin: 0 auto;
      }

      .problem-layout {
        grid-template-columns: 1fr;
      }

      .replace-panel {
        position: static;
      }

      .founder-layout {
        grid-template-columns: 1fr;
      }

      .founder-stats {
        position: static;
      }

      .how-layout {
        grid-template-columns: 1fr;
      }

      .af-features {
        grid-template-columns: 1fr;
      }

      .af-feature:nth-child(even) {
        border-right: 1px solid var(--border);
      }

      .feat-editorial {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 640px) {
      .pricing-table-head {
        display: none;
      }

      .pricing-table-row {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto;
        gap: 0;
        padding: 18px 20px;
        min-height: auto;
      }

      .row-rooms {
        padding: 0;
        grid-column: 1;
        grid-row: 1;
      }

      .row-price {
        padding: 0;
        grid-column: 2;
        grid-row: 1;
      }

      .row-saving {
        padding: 6px 0 0;
        grid-column: 1;
        grid-row: 2;
        justify-content: flex-start;
      }

      .row-cta {
        padding: 6px 0 0;
        grid-column: 2;
        grid-row: 2;
      }

      .row-cta-btn {
        opacity: 1;
        transform: none;
        pointer-events: auto;
        font-size: 12px;
        padding: 7px 14px;
      }

      .feat-editorial-left {
        border-right: none;
        border-bottom: 1px solid var(--border);
      }

      .feat-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    .feat-grid .feat-mini:nth-child(4n) {
      border-right: 1px solid var(--border);
    }

    .feat-grid .feat-mini:nth-child(2n) {
      border-right: none;
    }

    .feat-grid .feat-mini:nth-last-child(-n+4) {
      border-bottom: 1px solid var(--border);
    }

    .feat-grid .feat-mini:nth-last-child(-n+2) {
      border-bottom: none;
    }

    .foot-top {
      grid-template-columns: 1fr 1fr;
    }

    @media (max-width: 768px) {
      nav {
        padding: 0 20px;
      }

      .nav-links {
        display: none;
      }

      .nav-right .nav-signin {
        display: none;
      }

      .nav-right .nav-trial {
        display: none;
      }

      .nav-toggle {
        display: flex;
      }

      .nav-drawer.is-open {
        display: block;
      }

      .wrap {
        padding: 0 24px;
      }

      .feat-grid {
        grid-template-columns: 1fr;
      }

      .feat-grid .feat-mini:nth-child(4n),
      .feat-grid .feat-mini:nth-child(2n) {
        border-right: none;
      }

      .feat-grid .feat-mini {
        border-right: none;
        border-bottom: 1px solid var(--border);
      }

      .feat-grid .feat-mini:last-child {
        border-bottom: none;
      }

      .feat-rows .feat-row {
        grid-template-columns: 1fr;
      }

      .feat-row-num {
        display: none;
      }

      .feat-block {
        grid-template-columns: 1fr;
        min-height: 0;
      }

      .feat-block-text,
      .feat-block--text-right .feat-block-text {
        order: 1;
        border-right: none;
        border-left: none;
        border-bottom: 1px solid var(--border);
        padding: 28px 24px;
      }

      .feat-block-mock,
      .feat-block--text-right .feat-block-mock {
        order: 2;
        padding: 24px;
      }

      .feat-mock-placeholder {
        min-height: 160px;
      }

      .belief-grid {
        grid-template-columns: 1fr;
      }

      .belief:nth-child(odd) {
        padding-right: 0;
        border-right: none;
      }

      .belief:nth-child(even) {
        padding-left: 0;
      }
    }

    /* ── WAITLIST MODAL ─────────────────────────────────── */
    .waitlist-modal {
      position: fixed;
      inset: 0;
      z-index: 200;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
      opacity: 0;
      visibility: hidden;
      transition: opacity 0.2s ease, visibility 0.2s ease;
    }

    .waitlist-modal.is-open {
      opacity: 1;
      visibility: visible;
    }

    .waitlist-modal-backdrop {
      position: absolute;
      inset: 0;
      background: rgba(2, 8, 23, 0.5);
      backdrop-filter: blur(4px);
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .waitlist-modal-panel {
      position: relative;
      width: 100%;
      max-width: 440px;
      max-height: min(92dvh, calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 24px));
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
      background: var(--bg);
      border-radius: var(--radius-lg);
      box-shadow: 0 24px 48px rgba(0, 0, 0, 0.15), 0 0 0 1px var(--border);
      padding: 36px 32px;
      cursor: default;
    }

    /* Honeypot field — must be invisible */
    .waitlist-modal-panel input[name="_honeypot"] {
      position: absolute;
      width: 0;
      height: 0;
      overflow: hidden;
      opacity: 0;
      pointer-events: none;
    }

    .waitlist-modal-close {
      position: absolute;
      top: 12px;
      right: 12px;
      width: 36px;
      height: 36px;
      padding: 0;
      border: 0;
      background: transparent;
      color: var(--fg-3);
      font-size: 24px;
      line-height: 1;
      cursor: pointer;
      border-radius: var(--radius-sm);
      transition: color 0.15s, background 0.15s;
    }

    .waitlist-modal-close:hover {
      color: var(--fg);
      background: var(--bg-2);
    }

    @media (max-width: 640px) {
      .waitlist-modal {
        align-items: flex-start;
        padding: max(56px, env(safe-area-inset-top)) 16px 24px;
      }

      .waitlist-modal-panel {
        margin-top: 0;
        padding: 28px 20px 24px;
        max-height: calc(100dvh - max(56px, env(safe-area-inset-top)) - 32px);
      }

      .waitlist-modal-title {
        font-size: 1.35rem;
        padding-right: 40px;
      }

      .waitlist-modal-sub {
        font-size: 0.95rem;
      }

      .waitlist-input {
        font-size: 16px;
      }

      .waitlist-modal-close {
        top: 8px;
        right: 8px;
        width: 44px;
        height: 44px;
        display: flex;
        align-items: center;
        justify-content: center;
      }
    }

    .waitlist-modal-title {
      font-family: var(--ff-head);
      font-size: 1.5rem;
      font-weight: 700;
      color: var(--fg);
      margin-bottom: 6px;
    }

    .waitlist-modal-sub {
      font-size: 1rem;
      color: var(--fg-3);
      margin-bottom: 20px;
    }

    .waitlist-label {
      display: block;
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--fg-2);
      margin-bottom: 6px;
    }

    .waitlist-input {
      width: 100%;
      padding: 12px 14px;
      font-size: 1rem;
      font-family: var(--ff-body);
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      margin-bottom: 16px;
      transition: border-color 0.15s;
      background: var(--bg);
      color: var(--fg);
    }

    .waitlist-input:focus {
      outline: none;
      border-color: var(--primary);
      box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
    }

    .waitlist-interest {
      border: none;
      padding: 0;
      margin: 0 0 18px 0;
    }

    .waitlist-interest legend {
      margin-bottom: 10px;
    }

    .waitlist-radio {
      display: flex;
      align-items: flex-start;
      gap: 10px;
      padding: 10px 14px;
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      margin-bottom: 8px;
      cursor: pointer;
      transition: border-color 0.15s, background 0.15s;
      font-size: 0.9rem;
      color: var(--fg-2);
      line-height: 1.4;
    }

    .waitlist-radio:last-child {
      margin-bottom: 0;
    }

    .waitlist-radio:hover {
      border-color: var(--primary-light);
      background: rgba(37, 99, 235, 0.03);
    }

    .waitlist-radio:has(input:checked) {
      border-color: var(--primary);
      background: rgba(37, 99, 235, 0.06);
      color: var(--fg);
    }

    .waitlist-radio strong {
      color: var(--fg);
      font-weight: 600;
      display: block;
      margin-bottom: 2px;
    }

    .waitlist-radio input[type="radio"] {
      margin: 3px 0 0 0;
      accent-color: var(--primary);
      flex-shrink: 0;
    }

    .waitlist-error {
      font-size: 0.85rem;
      color: #dc2626;
      margin-bottom: 10px;
    }

    .waitlist-submit {
      width: 100%;
      padding: 14px 20px;
      font-size: 1.05rem;
      font-weight: 700;
      font-family: var(--ff-body);
      color: #fff;
      background: var(--primary);
      border: 0;
      border-radius: var(--radius-md);
      cursor: pointer;
      transition: background 0.15s;
      box-shadow: 0 0 20px rgba(59, 130, 246, 0.2);
    }

    .waitlist-submit:hover {
      background: var(--primary-dark);
    }

    @media (max-width: 640px) {
      .waitlist-modal {
        padding: 16px;
      }

      .waitlist-modal-panel {
        padding: 24px 20px;
        max-height: calc(100vh - 32px);
      }

      .waitlist-modal-title {
        font-size: 1.35rem;
        margin-bottom: 4px;
      }

      .waitlist-modal-sub {
        font-size: 0.95rem;
        margin-bottom: 16px;
      }

      .waitlist-input {
        padding: 10px 12px;
        margin-bottom: 12px;
      }

      .waitlist-radio {
        padding: 8px 12px;
      }

      .waitlist-submit {
        padding: 12px 16px;
      }
    }