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

      :root {
        --bg: #FAF8F5;
        --bg-alt: #F3F0EB;
        --surface: #FFFFFF;
        --text: #1C1917;
        --text-2: #57534E;
        --text-3: #78716C;
        --border: #E7E2DC;
        --border-h: #D6D0C8;

        /* Branded pastel palette (matches 3D icon style) */
        --p-blue: #7BA7C9;
        --p-blue-bg: rgba(123, 167, 201, 0.10);
        --p-green: #7DB87C;
        --p-green-bg: rgba(125, 184, 124, 0.10);
        --p-amber: #D4A843;
        --p-amber-bg: rgba(212, 168, 67, 0.10);
        --p-coral: #CF7B63;
        --p-coral-bg: rgba(207, 123, 99, 0.10);
        --p-violet: #9B8FE8;
        --p-violet-bg: rgba(155, 143, 232, 0.08);
        --p-gray: #B5AFA8;

        --font: "Satoshi", "Inter", system-ui, sans-serif;
        --font-serif: "Instrument Serif", serif;
        --radius: 14px;
        --radius-lg: 20px;
        --shadow-sm: 0 1px 3px rgba(0,0,0,0.04);
        --shadow-md: 0 4px 20px rgba(0,0,0,0.06);
        --shadow-lg: 0 12px 40px rgba(0,0,0,0.07);
        --spring: cubic-bezier(0.175, 0.885, 0.32, 1);
      }

      html { scroll-behavior: smooth; overflow-x: hidden; }
      body { font-family: var(--font); color: var(--text); background: var(--bg); line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
      .container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

      /* ---- VE: GROOVE SEPARATORS ---- */
      .ve-groove-t { border-top: none; position: relative; }
      .ve-groove-t::before {
        content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
        background: linear-gradient(to bottom, var(--border) 0px, var(--border) 1px, rgba(255,255,255,0.7) 1px, rgba(255,255,255,0.7) 2px);
      }
      .ve-groove-b { border-bottom: none; position: relative; }
      .ve-groove-b::after {
        content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
        background: linear-gradient(to bottom, var(--border) 0px, var(--border) 1px, rgba(255,255,255,0.7) 1px, rgba(255,255,255,0.7) 2px);
      }

      /* ---- NAV ---- */
      header { position: fixed; top: 0; left: 0; right: 0; z-index: 100; display: flex; justify-content: center; pointer-events: none; }
      .header-pill {
        pointer-events: auto; display: flex; align-items: center; justify-content: space-between;
        max-width: 900px; width: calc(100% - 32px); margin: 16px auto;
        padding: 0 8px 0 20px; height: 56px; border-radius: 999px;
        background: rgba(250,248,245,0.65); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
        border: 1px solid rgba(231,226,220,0.6);
        transition: background 0.3s, box-shadow 0.3s, border-color 0.3s;
        box-shadow: 0 1px 3px rgba(0,0,0,0.02), inset 0 1px 0 rgba(255,255,255,0.5);
      }
      header.scrolled .header-pill {
        background: rgba(250,248,245,0.97); border-color: var(--border);
        box-shadow:
          0 2px 8px rgba(0,0,0,0.05),
          0 8px 32px rgba(0,0,0,0.06),
          0 1px 2px rgba(0,0,0,0.03),
          inset 0 1px 0 rgba(255,255,255,0.8);
      }
      header.scrolled .header-pill nav {
        background: rgba(243,240,235,0.6);
        border-color: rgba(231,226,220,0.35);
      }
      .logo { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--text); flex-shrink: 0; }
      .logo img {
        width: 28px; height: 28px; border-radius: 7px;
        box-shadow: 0 2px 6px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04), inset 0 -1px 0 rgba(0,0,0,0.05), inset 0 1px 0 rgba(255,255,255,0.4);
      }
      .logo span { font-family: var(--font-serif); font-weight: 400; font-size: 18px; letter-spacing: -0.3px; }
      /* Recessed nav well */
      nav {
        display: flex; align-items: center; gap: 2px; margin: 0 auto;
        background: var(--bg-alt);
        border-radius: 999px; padding: 3px 4px;
        box-shadow: inset 0 1px 3px rgba(0,0,0,0.04), inset 0 0 1px rgba(0,0,0,0.03);
        border: 1px solid rgba(231,226,220,0.5);
      }
      nav a {
        text-decoration: none; color: var(--text-3); font-size: 13px; font-weight: 500;
        padding: 5px 14px; border-radius: 999px; position: relative;
        transition: color 0.25s var(--spring), background 0.25s var(--spring), box-shadow 0.25s var(--spring);
      }
      nav a:hover {
        color: var(--text); background: var(--surface);
        box-shadow: 0 1px 4px rgba(0,0,0,0.05), inset 0 1px 0 rgba(255,255,255,0.7);
      }
      nav a.active {
        color: var(--text); background: var(--surface); font-weight: 600;
        box-shadow: 0 2px 6px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04), inset 0 1px 0 rgba(255,255,255,0.8);
      }
      .header-actions { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
      .header-login { text-decoration: none; color: var(--text-2); font-size: 14px; font-weight: 500; transition: color 0.2s; }
      .header-login:hover { color: var(--text); }
      .btn-pill {
        background: var(--text); color: #fff; padding: 8px 20px; border-radius: 999px;
        font-size: 13px; font-weight: 600; text-decoration: none;
        transition: background 0.2s, box-shadow 0.2s, transform 0.25s var(--spring);
        border: none; cursor: pointer; font-family: var(--font);
        box-shadow: 0 2px 8px rgba(28,25,23,0.15), 0 0 0 1px rgba(155,143,232,0.08);
      }
      .btn-pill:hover { background: #3a3632; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(28,25,23,0.2), 0 1px 3px rgba(28,25,23,0.1), 0 0 12px rgba(155,143,232,0.1); }
      .hamburger { display: none; background: none; border: none; cursor: pointer; padding: 4px; color: var(--text); }
      .hamburger svg { width: 24px; height: 24px; }
      .nav-mobile-actions { display: none; }

      .btn {
        display: inline-flex; align-items: center; justify-content: center; gap: 8px;
        padding: 14px 28px; border-radius: 12px; font-family: var(--font); font-size: 15px;
        font-weight: 600; cursor: pointer; border: none; text-decoration: none;
        transition: all 0.25s var(--spring);
      }
      .btn:hover { transform: translateY(-2px); }
      .btn svg { width: 16px; height: 16px; }
      .btn-dark { background: var(--text); color: #fff; box-shadow: 0 2px 8px rgba(28,25,23,0.15), inset 0 1px 0 rgba(255,255,255,0.1); }
      .btn-dark:hover { box-shadow: 0 8px 24px rgba(28,25,23,0.2), 0 2px 6px rgba(28,25,23,0.1), inset 0 1px 0 rgba(255,255,255,0.1); transform: translateY(-2px); }
      .btn-outline { background: transparent; color: var(--text); border: 1.5px solid var(--border); }
      .btn-outline:hover { border-color: var(--border-h); background: var(--surface); }

      /* ---- 3D ICON STYLE ---- */
      .icon-3d {
        width: 72px; height: 72px; border-radius: 18px;
        display: flex; align-items: center; justify-content: center;
        position: relative; flex-shrink: 0;
        box-shadow: 0 6px 16px rgba(0,0,0,0.06), 0 2px 4px rgba(0,0,0,0.04), inset 0 -3px 0 rgba(0,0,0,0.06), inset 0 1px 0 rgba(255,255,255,0.5);
      }
      .icon-3d svg { width: 32px; height: 32px; stroke-width: 1.8; }
      .icon-3d-sm { width: 56px; height: 56px; border-radius: 14px; }
      .icon-3d-sm svg { width: 26px; height: 26px; }
      .ic-blue { background: linear-gradient(145deg, #9BC2DB 0%, #6A99B8 100%); color: #fff; }
      .ic-green { background: linear-gradient(145deg, #9BD09A 0%, #6DAE6C 100%); color: #fff; }
      .ic-amber { background: linear-gradient(145deg, #E4BF63 0%, #C49A33 100%); color: #fff; }
      .ic-coral { background: linear-gradient(145deg, #E09880 0%, #BF6D53 100%); color: #fff; }
      .ic-violet { background: linear-gradient(145deg, #B5A8F0 0%, #8A7DD8 100%); color: #fff; }
      .ic-gray { background: linear-gradient(145deg, #C8C2BC 0%, #A8A29E 100%); color: #fff; }

      /* ---- HERO ---- */
      .hero {
        padding: 160px 0 100px; position: relative; min-height: 100vh;
        display: flex; align-items: center; overflow: hidden;
        background: #FFFFFF;
      }
      /* Background depth: radial glow + geometry */
      .hero::before {
        content: ''; position: absolute; top: -10%; left: 0; right: 0; height: 120%;
        background:
          radial-gradient(ellipse 65% 55% at 25% 35%, rgba(155,143,232,0.12) 0%, transparent 65%),
          radial-gradient(ellipse 50% 45% at 80% 50%, rgba(125,184,124,0.09) 0%, transparent 60%),
          radial-gradient(ellipse 40% 35% at 55% 70%, rgba(207,123,99,0.07) 0%, transparent 60%);
        pointer-events: none; z-index: 0;
      }
      .hero::after {
        content: ''; position: absolute; top: 50%; right: -5%; width: 500px; height: 500px;
        transform: translateY(-55%);
        background: url('./assets/hero-geometry.svg') no-repeat center / contain;
        opacity: 0.35; pointer-events: none; z-index: 0;
      }
      .hero > .container { position: relative; z-index: 1; }
      .hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
      .hero-content { max-width: 540px; }
      .hero h1 {
        font-size: clamp(46px, 6.5vw, 76px); font-weight: 700;
        line-height: 1.05; letter-spacing: -2.5px; margin-bottom: 24px;
      }
      .hero h1 em {
        font-family: var(--font-serif); font-style: italic; font-weight: 400;
        background: linear-gradient(135deg, var(--p-violet) 0%, var(--p-blue) 100%);
        -webkit-background-clip: text; -webkit-text-fill-color: transparent;
        background-clip: text; padding-right: 4px; /* Fix for italic descenders */
      }
      .hero-sub { font-size: 19px; color: var(--text); line-height: 1.65; margin-bottom: 30px; max-width: 480px; opacity: 0.75; }
      
      .hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 28px; }
      /* Proof pills */
      .hero-proof { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
      .hero-proof-item {
        display: inline-flex; align-items: center; gap: 8px;
        font-size: 13px; font-weight: 600; color: var(--text-2);
        padding: 8px 16px; border-radius: 999px;
        background: var(--bg-alt);
        box-shadow: inset 0 1px 3px rgba(0,0,0,0.05), inset 0 0 1px rgba(0,0,0,0.03);
        border: 1px solid rgba(231,226,220,0.8);
      }
      .hero-proof-item svg { width: 15px; height: 15px; }
      .proof-green { background: var(--p-green-bg); border-color: rgba(125,184,124,0.18); }
      .proof-green svg { color: var(--p-green); }
      .proof-blue { background: var(--p-blue-bg); border-color: rgba(123,167,201,0.18); }
      .proof-blue svg { color: var(--p-blue); }
      .proof-coral { background: var(--p-coral-bg); border-color: rgba(207,123,99,0.18); }
      .proof-coral svg { color: var(--p-coral); }
      .proof-violet { background: var(--p-violet-bg); border-color: rgba(155,143,232,0.18); }
      .proof-violet svg { color: var(--p-violet); }

      /* Nav ambient glow — contained within header bounds */
      .header-pill::before {
        content: ''; position: absolute; top: -20px; left: -20%; right: -20%; height: 100px;
        background: radial-gradient(ellipse at center, rgba(155,143,232,0.06) 0%, transparent 70%);
        pointer-events: none; z-index: -1;
      }

      /* Product frame + carousel */
      .hero-visual { position: relative; animation: float-hero 8s ease-in-out infinite; }
      @keyframes float-hero { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
      .hero-glass-glow {
        position: absolute; top: 50%; left: 50%; width: 600px; height: 600px;
        transform: translate(-50%, -50%);
        background: radial-gradient(circle at center, var(--p-violet) 0%, var(--p-blue) 60%, transparent 70%);
        border-radius: 50%;
        filter: blur(80px); opacity: 0.15; z-index: -1; pointer-events: none;
      }

      /* Floating Orbiting Badges */
      .hb {
        position: absolute; display: inline-flex; align-items: center; gap: 6px;
        padding: 8px 14px; font-size: 12px; font-weight: 600; color: var(--text-2);
        background: rgba(255,255,255,0.85); backdrop-filter: blur(8px);
        border: 1px solid rgba(231,226,220,0.8); border-radius: 99px;
        box-shadow: 0 8px 24px rgba(0,0,0,0.06), inset 0 1px 0 rgba(255,255,255,0.7); z-index: 10;
        animation: float-badge 6s ease-in-out infinite alternate; pointer-events: none;
      }
      .hb svg { width: 14px; height: 14px; }
      .hb-1 { top: -20px; right: -15px; animation-delay: 0s; }
      .hb-1 svg { color: var(--p-violet); }
      .hb-2 { bottom: -15px; left: -25px; animation-delay: -3s; }
      .hb-2 svg { color: var(--p-blue); }
      @keyframes float-badge { 0% { transform: translateY(0); } 100% { transform: translateY(-12px); } }
      .slide-badge { opacity: 0; visibility: hidden; transition: opacity 0.4s ease, visibility 0.4s; }
      .slide-badge.active { opacity: 1; visibility: visible; }      .pf {
        background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
        overflow: hidden;
        box-shadow: 0 16px 48px rgba(0,0,0,0.08), 0 4px 12px rgba(0,0,0,0.04), inset 0 1px 0 rgba(255,255,255,0.9);
      }
      .pf-bar { 
        display: flex; align-items: center; justify-content: center; 
        padding: 14px 20px; background: var(--bg);
        border-bottom: 2px solid transparent; 
        border-image: linear-gradient(to right, transparent, var(--border), transparent) 1;
      }
      .pf-title { font-size: 12px; color: var(--text-3); font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; }
      .pf-body { padding: 24px; height: 400px; position: relative; overflow: hidden; }

      /* Slides — stacked via absolute positioning to prevent layout jumps */
      .demo-slide {
        position: absolute; top: 24px; left: 24px; right: 24px; bottom: 24px;
        display: flex; flex-direction: column; gap: 14px;
        opacity: 0; pointer-events: none; transition: opacity 0.5s ease;
      }
      .demo-slide.active { opacity: 1; pointer-events: auto; }
      .demo-dots { display: flex; justify-content: center; gap: 8px; padding: 16px 0 20px; }
      .demo-dot {
        width: 8px; height: 8px; border-radius: 4px; background: rgba(231,226,220,0.6);
        border: none; cursor: pointer; transition: all 0.3s var(--spring); padding: 0;
        position: relative; overflow: hidden;
      }
      .demo-dot.active { width: 32px; transform: scale(1); background: rgba(231,226,220,0.4); }
      .demo-dot.active::after {
        content: ''; position: absolute; inset: 0;
        background: var(--p-violet);
        animation: dot-progress var(--slide-dur, 7s) linear forwards;
      }
      @keyframes dot-progress { from { width: 0%; } to { width: 100%; } }

      /* Slide 1: Chat */
      .cr { display: flex; gap: 10px; align-items: flex-start; opacity: 0; transform: translateY(10px); }
      .cr.show { opacity: 1; transform: translateY(0); transition: opacity 0.5s ease, transform 0.5s var(--spring); }
      .cr-av { width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: #fff; }
      .cr-bub { padding: 11px 15px; border-radius: 14px; font-size: 13.5px; line-height: 1.55; max-width: 88%; }
      .bub-ai { 
        background: var(--p-violet-bg); border: 1px solid rgba(155,143,232,0.2);
        box-shadow: 0 2px 6px rgba(155,143,232,0.1), inset 0 1px 0 rgba(255,255,255,0.5);
      }
      .bub-you { 
        background: var(--bg-alt); border: 1px solid rgba(231,226,220,0.8);
        box-shadow: 0 2px 6px rgba(0,0,0,0.03), inset 0 1px 0 rgba(255,255,255,0.7);
      }
      .cr-meta { font-size: 11px; color: var(--text-3); padding-left: 40px; margin-top: -6px; opacity: 0; transform: translateY(10px); }
      .cr-meta.show { opacity: 1; transform: translateY(0); transition: opacity 0.5s ease, transform 0.5s var(--spring); }
      .cx { opacity: 0; transform: translateY(10px); }
      .cx.show { opacity: 1; transform: translateY(0); transition: opacity 0.5s ease, transform 0.5s var(--spring); }

      /* Slide 2: Site editor */
      .site-mock { display: flex; flex-direction: column; gap: 0; font-size: 13px; }
      .site-topbar { background: var(--bg-alt); padding: 8px 14px; border-radius: 8px 8px 0 0; display: flex; align-items: center; gap: 8px; border: 1px solid var(--border); border-bottom: none; }
      .site-topbar-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--text-3); opacity: 0.4; }
      .site-topbar-url { flex: 1; text-align: center; font-size: 11px; color: var(--text-3); }
      .site-body { border: 1px solid var(--border); border-radius: 0 0 8px 8px; padding: 16px; background: #fff; }
      .site-hero-block { text-align: center; margin-bottom: 14px; }
      .site-hero-block h4 { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
      .site-hero-block p { font-size: 11px; color: var(--text-3); }
      .site-pricing-row { display: flex; gap: 8px; }
      .site-price-card {
        flex: 1; padding: 10px; border: 1px solid var(--border); border-radius: 8px;
        text-align: center; font-size: 11px; transition: all 0.4s var(--spring);
      }
      .site-price-card strong { display: block; font-size: 16px; margin: 4px 0 2px; }
      .site-price-card small { color: var(--text-3); }
      .site-price-card.editing {
        border-color: var(--p-violet); box-shadow: 0 0 0 2px rgba(155,143,232,0.2);
      }
      .site-cursor {
        display: inline-flex; align-items: center; gap: 4px;
        font-size: 10px; color: var(--p-violet); font-weight: 600;
        opacity: 0; transition: opacity 0.4s;
      }
      .site-cursor.show { opacity: 1; }
      .site-cursor svg { width: 12px; height: 12px; }
      .site-new-section {
        margin-top: 10px; padding: 10px; border: 2px dashed var(--p-green);
        border-radius: 8px; text-align: center; font-size: 11px; color: var(--p-green);
        font-weight: 600; opacity: 0; transform: translateY(8px);
        transition: opacity 0.5s, transform 0.5s var(--spring);
      }
      .site-new-section.show { opacity: 1; transform: translateY(0); }
      .site-status {
        margin-top: 10px; display: flex; align-items: center; gap: 6px;
        font-size: 11px; font-weight: 600; color: var(--p-green);
        opacity: 0; transition: opacity 0.4s;
      }
      .site-status.show { opacity: 1; }
      .site-status svg { width: 14px; height: 14px; }

      /* Slide 3: Contract review */
      .contract-doc { font-size: 12px; line-height: 1.7; }
      .contract-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
      .contract-header h4 { font-size: 14px; font-weight: 700; }
      .contract-badge {
        font-size: 10px; font-weight: 600; padding: 3px 10px;
        border-radius: 999px; background: var(--p-amber-bg);
        color: #B8942A; border: 1px solid rgba(212,168,67,0.2);
      }
      .contract-line { padding: 6px 0; border-bottom: 1px solid var(--border); color: var(--text-2); }
      .contract-line:last-child { border-bottom: none; }
      .redline {
        background: rgba(207,123,99,0); text-decoration: none;
        color: inherit; padding: 0 3px; border-radius: 3px;
        transition: background 0.4s, color 0.4s, text-decoration-color 0.4s;
      }
      .redline.struck {
        background: rgba(207,123,99,0.1); text-decoration: line-through;
        color: var(--p-coral);
      }
      .greenline {
        background: rgba(125,184,124,0); color: inherit;
        padding: 0 3px; border-radius: 3px; font-weight: 600;
        opacity: 0; transition: opacity 0.4s, background 0.3s, color 0.3s;
      }
      .greenline.revealed {
        background: rgba(125,184,124,0.1); color: #5A9A59; opacity: 1;
      }
      .contract-comment {
        margin-top: 10px; padding: 10px 14px; background: var(--p-violet-bg);
        border: 1px solid rgba(155,143,232,0.15); border-radius: 10px;
        font-size: 12px; line-height: 1.5;
      }
      .contract-comment strong { color: var(--text); }
      .contract-comment .typed-text { display: inline; }
      .contract-comment .typing-cursor {
        display: inline-block; width: 2px; height: 13px; background: var(--p-violet);
        margin-left: 1px; vertical-align: text-bottom;
        animation: blink-cursor 0.6s steps(1) infinite;
      }
      @keyframes blink-cursor { 0%,100% { opacity: 1; } 50% { opacity: 0; } }

      /* Slide 4: Patient intake */
      .intake-scene { display: flex; flex-direction: column; gap: 12px; }
      .intake-upload {
        display: flex; align-items: center; gap: 10px; padding: 10px 14px;
        background: var(--surface); border: 1px solid var(--border); border-radius: 10px;
        font-size: 12px; color: var(--text-2);
      }
      .intake-upload svg { width: 16px; height: 16px; flex-shrink: 0; color: var(--p-blue); }
      .intake-upload-name { flex: 1; }
      .intake-upload-name .blur-text { filter: blur(3px); user-select: none; display: inline; }
      .intake-progress {
        width: 100%; height: 3px; background: var(--border); border-radius: 2px;
        margin-top: 4px; overflow: hidden;
      }
      .intake-progress-bar {
        height: 100%; width: 0%; background: var(--p-blue); border-radius: 2px;
        transition: width 1.2s ease-out;
      }
      .intake-progress-bar.done { width: 100%; }
      .intake-form {
        background: var(--surface); border: 1px solid var(--border); border-radius: 10px;
        padding: 14px 16px; font-size: 12px;
      }
      .intake-form-header {
        display: flex; align-items: center; justify-content: space-between;
        margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--border);
      }
      .intake-form-header h4 { font-size: 12px; font-weight: 700; }
      .intake-form-badge {
        font-size: 9px; font-weight: 600; padding: 2px 8px; border-radius: 999px;
        background: var(--p-blue-bg); color: var(--p-blue); border: 1px solid rgba(123,167,201,0.2);
      }
      .intake-row {
        display: grid; grid-template-columns: 90px 1fr; gap: 4px; padding: 4px 0;
        align-items: center; font-size: 11px;
      }
      .intake-label { font-weight: 600; color: var(--text-3); text-transform: uppercase; font-size: 9px; letter-spacing: 0.5px; }
      .intake-val { color: var(--text-2); filter: blur(4px); user-select: none; }
      .intake-check-overlay {
        position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
        background: rgba(250,248,245,0.7); opacity: 0; transition: opacity 0.5s;
        pointer-events: none; z-index: 2;
      }
      .intake-check-overlay.show { opacity: 1; }
      .intake-check-circle {
        width: 56px; height: 56px; border-radius: 50%;
        background: linear-gradient(135deg, var(--p-green), #6DAE6C);
        display: flex; align-items: center; justify-content: center;
        transform: scale(0); transition: transform 0.5s var(--spring);
        box-shadow: 0 4px 16px rgba(125,184,124,0.3);
      }
      .intake-check-overlay.show .intake-check-circle { transform: scale(1); }
      .intake-check-circle svg { width: 28px; height: 28px; color: #fff; }
      .intake-badges {
        display: flex; justify-content: center; gap: 6px; opacity: 0; transition: opacity 0.5s;
      }
      .intake-badges.show { opacity: 1; }
      .intake-badge {
        display: inline-flex; align-items: center; gap: 4px;
        font-size: 9px; font-weight: 700; letter-spacing: 0.3px;
        padding: 4px 10px; border-radius: 999px;
        transform: translateY(6px); transition: transform 0.4s var(--spring);
      }
      .intake-badges.show .intake-badge { transform: translateY(0); }
      .intake-badge svg { width: 11px; height: 11px; }
      .ib-shield {
        background: var(--p-green-bg); color: var(--p-green);
        border: 1px solid rgba(125,184,124,0.2);
      }
      .intake-badge:nth-child(2) { transition-delay: 0.1s; }
      .intake-badge:nth-child(3) { transition-delay: 0.2s; }

      /* Shared success overlay for all slides */
      .slide-success {
        position: absolute; inset: 0; z-index: 5;
        display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px;
        background: rgba(250,248,245,0.98); backdrop-filter: blur(12px);
        opacity: 0; pointer-events: none; transition: opacity 0.4s;
      }
      .slide-success.show { opacity: 1; pointer-events: auto; }
      .slide-success .ss-icon {
        width: 52px; height: 52px; border-radius: 50%;
        display: flex; align-items: center; justify-content: center;
        transform: scale(0); transition: transform 0.5s var(--spring);
      }
      .slide-success.show .ss-icon { transform: scale(1); }
      .slide-success .ss-icon svg { width: 26px; height: 26px; color: #fff; }
      .ss-icon-green { background: linear-gradient(135deg, var(--p-green), #6DAE6C); box-shadow: 0 4px 16px rgba(125,184,124,0.3); }
      .ss-icon-violet { background: linear-gradient(135deg, var(--p-violet), #7B6FD0); box-shadow: 0 4px 16px rgba(155,143,232,0.3); }
      .slide-success h4 {
        font-size: 15px; font-weight: 700; color: var(--text);
        opacity: 0; transform: translateY(8px);
        transition: opacity 0.4s 0.2s, transform 0.4s 0.2s var(--spring);
      }
      .slide-success.show h4 { opacity: 1; transform: translateY(0); }
      .slide-success p {
        font-size: 12px; color: var(--text-2); max-width: 240px; text-align: center; line-height: 1.5;
        opacity: 0; transform: translateY(8px);
        transition: opacity 0.4s 0.35s, transform 0.4s 0.35s var(--spring);
      }
      .slide-success.show p { opacity: 1; transform: translateY(0); }
      /* Confetti dots */
      .ss-confetti {
        position: absolute; inset: 0; pointer-events: none; overflow: hidden;
      }
      .ss-confetti i {
        position: absolute; width: 5px; height: 5px; border-radius: 50%;
        opacity: 0; animation: confetti-pop 1s ease-out forwards;
      }
      @keyframes confetti-pop {
        0% { opacity: 1; transform: translate(0,0) scale(1); }
        100% { opacity: 0; transform: translate(var(--cx), var(--cy)) scale(0.5); }
      }
      .contract-btn-approve.clicked { background: var(--p-green); color: #fff; transform: scale(0.95); transition: all 0.15s; }
      .contract-actions {
        margin-top: 12px; display: flex; gap: 8px;
      }
      .contract-btn {
        padding: 6px 14px; border-radius: 8px; font-size: 11px;
        font-weight: 600; border: none; cursor: pointer; font-family: var(--font);
      }
      .contract-btn-approve { background: var(--p-green); color: #fff; }
      .contract-btn-comment { background: var(--bg-alt); color: var(--text-2); border: 1px solid var(--border); }

      /* ---- SECTION SHARED ---- */
      .section-head { text-align: center; margin-bottom: 56px; }
      .section-head h2 { font-size: clamp(28px, 3.8vw, 42px); font-weight: 700; letter-spacing: -1.5px; line-height: 1.15; margin-bottom: 14px; }
      .section-head h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; }
      .section-head p { font-size: 17px; color: var(--text-2); max-width: 520px; margin: 0 auto; line-height: 1.6; }
      .section-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: var(--text-3); margin-bottom: 12px; }

      /* ---- ALTERNATING FEATURES ---- */
      .features { padding: 60px 0 40px; }
      .features .section-head { margin-bottom: 64px; }
      .feature-row {
        display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
        align-items: center; padding: 60px 0;
        border-bottom: 1px solid var(--border);
      }
      .feature-row:last-child { border-bottom: none; }
      .feature-row.reverse .feature-visual { order: -1; }
      .feature-text h3 { font-size: 26px; font-weight: 700; letter-spacing: -0.5px; margin-bottom: 12px; line-height: 1.2; }
      .feature-text h3 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; }
      .feature-text > p { font-size: 15px; color: var(--text-2); line-height: 1.7; margin-bottom: 24px; }
      .feature-bullets { list-style: none; display: flex; flex-direction: column; gap: 12px; }
      .feature-bullets li {
        display: flex; align-items: flex-start; gap: 10px;
        font-size: 14px; line-height: 1.55; color: var(--text);
      }
      .feature-bullets svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; }
      .feature-visual {
        background: var(--surface); border: 1px solid var(--border);
        border-radius: var(--radius-lg); padding: 36px;
        display: flex; flex-direction: column; align-items: center;
        justify-content: center; min-height: 320px; text-align: center;
        position: relative; overflow: hidden;
      }
      /* Placeholder for 3D illustration -- replace with real renders */
      .feature-illust {
        width: 180px; height: 180px; margin-bottom: 20px;
        border-radius: 24px; display: flex; align-items: center; justify-content: center;
        position: relative;
      }
      .feature-illust svg { width: 72px; height: 72px; stroke-width: 1.5; }
      .fi-blue { background: linear-gradient(145deg, #E8F1F7 0%, #D0E3F0 100%); color: var(--p-blue); }
      .fi-green { background: linear-gradient(145deg, #E8F5E8 0%, #D0EAD0 100%); color: var(--p-green); }
      .fi-amber { background: linear-gradient(145deg, #F7F0E0 0%, #EDE2C8 100%); color: var(--p-amber); }
      .fi-coral { background: linear-gradient(145deg, #F7ECE8 0%, #EDD8D0 100%); color: var(--p-coral); }
      .fi-violet { background: linear-gradient(145deg, #EFECFB 0%, #DDD8F5 100%); color: var(--p-violet); }
      .feature-visual-label { font-size: 13px; color: var(--text-3); font-weight: 500; }

      /* ---- FEATURE PROCESS FLOWS ---- */
      .fv-flow { width: 100%; display: flex; flex-direction: column; align-items: center; gap: 12px; }
      .fv-flow > * { opacity: 0; transform: translateY(10px); transition: opacity 0.5s ease, transform 0.5s var(--spring); }
      .feature-row.visible .fv-flow > :nth-child(1) { opacity: 1; transform: translateY(0); transition-delay: 0.3s; }
      .feature-row.visible .fv-flow > :nth-child(2) { opacity: 1; transform: translateY(0); transition-delay: 0.65s; }
      .feature-row.visible .fv-flow > :nth-child(3) { opacity: 1; transform: translateY(0); transition-delay: 1.0s; }
      .feature-row.visible .fv-flow > :nth-child(4) { opacity: 1; transform: translateY(0); transition-delay: 1.35s; }
      .feature-row.visible .fv-flow > :nth-child(5) { opacity: 1; transform: translateY(0); transition-delay: 1.7s; }
      .feature-row.visible .fv-flow > :nth-child(6) { opacity: 1; transform: translateY(0); transition-delay: 2.05s; }
      .feature-row.visible .fv-flow > :nth-child(7) { opacity: 1; transform: translateY(0); transition-delay: 2.4s; }
      .fv-flow.compact { gap: 6px; }
      .fv-pills { display: flex; gap: 6px; flex-wrap: wrap; justify-content: center; }
      .fv-pill { display: inline-flex; align-items: center; gap: 5px; padding: 5px 10px; border-radius: 16px; font-size: 11px; font-weight: 600; }
      .fv-pill svg { width: 12px; height: 12px; }
      .fv-arrow { color: var(--text-3); margin-top: 4px; }
      .fv-arrow svg { width: 16px; height: 16px; }
      .fv-label { font-size: 11px; color: var(--text-3); font-weight: 500; }
      /* Security */
      .fv-sec-pill { background: var(--p-green-bg); color: var(--p-green); border: 1px solid rgba(125,184,124,0.15); }
      .fv-sec-box { display: flex; align-items: center; gap: 12px; padding: 14px 24px; border-radius: 14px; background: linear-gradient(145deg, #E8F5E8, #D0EAD0); border: 1px solid rgba(125,184,124,0.25); }
      .fv-sec-box svg { width: 28px; height: 28px; color: var(--p-green); stroke-width: 1.5; }
      .fv-sec-box span { font-size: 12px; font-weight: 700; color: var(--p-green); }
      /* Tools */
      .fv-tool-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; width: 100%; max-width: 280px; }
      .fv-tool-card { display: flex; align-items: center; gap: 8px; padding: 10px 12px; border-radius: 10px; background: var(--surface); border: 1px solid var(--border); opacity: 0; transform: scale(0.92); transition: opacity 0.4s ease, transform 0.4s var(--spring); }
      .feature-row.visible .fv-tool-card { opacity: 1; transform: scale(1); }
      .feature-row.visible .fv-tool-card:nth-child(1) { transition-delay: 0.4s; }
      .feature-row.visible .fv-tool-card:nth-child(2) { transition-delay: 0.7s; }
      .feature-row.visible .fv-tool-card:nth-child(3) { transition-delay: 1.0s; }
      .feature-row.visible .fv-tool-card:nth-child(4) { transition-delay: 1.3s; }
      .fv-tool-ic { width: 28px; height: 28px; border-radius: 6px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
      .fv-tool-ic svg { width: 14px; height: 14px; stroke-width: 1.5; }
      .fv-tool-ic.bl { background: linear-gradient(135deg, #E8F1F7, #D0E3F0); color: var(--p-blue); }
      .fv-tool-ic.am { background: linear-gradient(135deg, #F7F0E0, #EDE2C8); color: var(--p-amber); }
      .fv-tool-ic.co { background: linear-gradient(135deg, #F7ECE8, #EDD8D0); color: var(--p-coral); }
      .fv-tool-ic.vi { background: linear-gradient(135deg, #EFECFB, #DDD8F5); color: var(--p-violet); }
      .fv-tool-name { font-size: 11px; font-weight: 700; color: var(--text); }
      .fv-tool-sub { font-size: 10px; color: var(--text-3); }
      .fv-tool-status { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-2); font-weight: 600; }
      .fv-tool-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--p-green); }
      .feature-row.visible .fv-tool-dot { animation: fv-pulse 1.5s ease infinite 2s; }
      @keyframes fv-pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }
      /* Memory */
      .fv-flow > .fv-mem-row { transform: translateX(-8px); }
      .feature-row.visible .fv-flow > .fv-mem-row { transform: translateX(0); }
      .fv-mem-row { width: 100%; max-width: 260px; display: flex; align-items: center; gap: 7px; padding: 6px 10px; border-radius: 7px; background: var(--p-violet-bg); font-size: 10px; color: var(--text-2); }
      .fv-mem-row svg { width: 11px; height: 11px; color: var(--p-violet); flex-shrink: 0; stroke-width: 1.5; }
      .fv-mem-row span { flex: 1; }
      .fv-mem-row small { font-size: 9px; color: var(--text-3); white-space: nowrap; }
      .fv-mem-search { width: 100%; max-width: 260px; display: flex; align-items: center; gap: 7px; padding: 7px 11px; border-radius: 8px; background: var(--surface); border: 1px solid var(--border); font-size: 11px; color: var(--text); }
      .fv-mem-search svg { width: 13px; height: 13px; color: var(--text-3); flex-shrink: 0; stroke-width: 1.5; }
      .fv-mem-result { width: 100%; max-width: 260px; display: flex; align-items: center; gap: 7px; padding: 8px 11px; border-radius: 8px; background: linear-gradient(145deg, #EFECFB, #DDD8F5); border: 1px solid rgba(155,143,232,0.2); font-size: 11px; color: var(--text); font-weight: 600; }
      .fv-mem-result svg { width: 14px; height: 14px; color: var(--p-green); flex-shrink: 0; }

      /* ---- WORKFLOW VISUAL ---- */
      .fv-wf-flow { gap: 0; align-items: stretch; max-width: 300px; margin: 0 auto; }
      .fv-wf-flow > * { opacity: 0; transform: translateY(8px); transition: opacity 0.45s ease, transform 0.45s var(--spring); }
      .feature-row.visible .fv-wf-flow > :nth-child(1) { opacity: 1; transform: translateY(0); transition-delay: 0.25s; }
      .feature-row.visible .fv-wf-flow > :nth-child(2) { opacity: 1; transform: translateY(0); transition-delay: 0.5s; }
      .feature-row.visible .fv-wf-flow > :nth-child(3) { opacity: 1; transform: translateY(0); transition-delay: 0.75s; }
      .feature-row.visible .fv-wf-flow > :nth-child(4) { opacity: 1; transform: translateY(0); transition-delay: 1.0s; }
      .feature-row.visible .fv-wf-flow > :nth-child(5) { opacity: 1; transform: translateY(0); transition-delay: 1.25s; }
      .feature-row.visible .fv-wf-flow > :nth-child(6) { opacity: 1; transform: translateY(0); transition-delay: 1.5s; }
      .feature-row.visible .fv-wf-flow > :nth-child(7) { opacity: 1; transform: translateY(0); transition-delay: 1.75s; }
      .fv-wf-trigger {
        display: flex; align-items: center; gap: 10px;
        padding: 10px 12px; border-radius: 10px;
        background: var(--bg-alt); border: 1px solid var(--border);
        width: 100%;
      }
      .fv-wf-trigger-ic {
        width: 30px; height: 30px; border-radius: 8px; flex-shrink: 0;
        background: linear-gradient(135deg, #E8F5E8, #D0EAD0);
        color: var(--p-green); display: flex; align-items: center; justify-content: center;
      }
      .fv-wf-trigger-ic svg { width: 15px; height: 15px; }
      .fv-wf-label-sm { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-3); margin-bottom: 1px; }
      .fv-wf-name { font-size: 12px; font-weight: 600; color: var(--text); }
      .fv-wf-connector {
        width: 1px; height: 14px; background: var(--border);
        flex-shrink: 0; align-self: flex-start;
        margin-left: 26px; /* align with center of 30px icon */
      }
      .fv-wf-step {
        display: flex; align-items: center; gap: 9px;
        padding: 9px 11px; border-radius: 10px;
        background: var(--surface); border: 1px solid var(--border);
        width: 100%;
      }
      .fv-wf-done { border-color: rgba(125,184,124,0.25); background: linear-gradient(145deg, #FAFFF9, #F4FBF4); }
      .fv-wf-pending { border-color: rgba(155,143,232,0.25); background: linear-gradient(145deg, #FAFBFF, #F5F3FC); }
      .fv-wf-step-ic {
        width: 28px; height: 28px; border-radius: 7px; flex-shrink: 0;
        display: flex; align-items: center; justify-content: center;
      }
      .fv-wf-step-ic svg { width: 13px; height: 13px; }
      .fv-wf-ic-blue { background: linear-gradient(135deg, #E8F1F7, #D0E3F0); color: var(--p-blue); }
      .fv-wf-ic-amber { background: linear-gradient(135deg, #F7F0E0, #EDE2C8); color: var(--p-amber); }
      .fv-wf-ic-violet { background: linear-gradient(135deg, #EFECFB, #DDD8F5); color: var(--p-violet); }
      .fv-wf-step-body { flex: 1; min-width: 0; }
      .fv-wf-step-agent { font-size: 11px; font-weight: 700; color: var(--text); }
      .fv-wf-step-desc { font-size: 10px; color: var(--text-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
      .fv-wf-check {
        width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0;
        background: var(--p-green); display: flex; align-items: center; justify-content: center;
      }
      .fv-wf-check svg { width: 10px; height: 10px; color: #fff; }
      .fv-wf-pending-badge {
        font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px;
        color: var(--p-violet); background: var(--p-violet-bg);
        border: 1px solid rgba(155,143,232,0.2);
        padding: 2px 7px; border-radius: 20px; white-space: nowrap; flex-shrink: 0;
      }
      .fv-wf-footer {
        display: flex; align-items: center; justify-content: space-between;
        padding: 8px 4px 0;
      }
      .fv-wf-run { display: flex; align-items: center; gap: 5px; font-size: 10px; font-weight: 600; color: var(--text-2); }
      .fv-wf-last { font-size: 10px; color: var(--text-3); }

      /* ---- WORKFLOW DEMO ANIMATION ---- */
      .wf-demo {
        display: flex; flex-direction: column; gap: 10px;
        max-width: 320px; margin: 0 auto;
        background: var(--surface); border: 1px solid var(--border);
        border-radius: 16px; padding: 20px;
        box-shadow: 0 4px 24px rgba(0,0,0,0.06);
      }
      .wfd-hidden { opacity: 0; transform: translateY(6px); pointer-events: none; }
      .wfd-visible { opacity: 1 !important; transform: translateY(0) !important; transition: opacity 0.4s ease, transform 0.4s var(--spring); }

      .wfd-prompt { display: flex; align-items: flex-start; gap: 9px; }
      .wfd-prompt-av {
        width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
        background: var(--text); display: flex; align-items: center; justify-content: center;
      }
      .wfd-prompt-av svg { width: 14px; height: 14px; stroke: #fff; }
      .wfd-prompt-bubble {
        background: var(--bg-alt); border: 1px solid var(--border);
        border-radius: 0 10px 10px 10px;
        padding: 8px 12px; font-size: 13px; font-weight: 600; color: var(--text-1);
        min-height: 36px; display: block; flex: 1; line-height: 1.5;
      }
      .wfd-cursor {
        display: inline-block; width: 1px; height: 13px;
        background: var(--text-2); margin-left: 1px; vertical-align: middle;
        animation: wfd-blink 0.8s step-end infinite;
      }
      .wfd-cursor.hidden { opacity: 0; }
      @keyframes wfd-blink { 0%,100% { opacity: 1; } 50% { opacity: 0; } }

      .wfd-thinking {
        display: flex; align-items: center; gap: 8px;
        padding: 6px 4px; transition: opacity 0.3s ease, transform 0.3s ease;
      }
      .wfd-think-dots { display: flex; gap: 4px; }
      .wfd-think-dots span {
        width: 5px; height: 5px; border-radius: 50%; background: var(--text-3);
        animation: wfd-bounce 1.2s ease-in-out infinite;
      }
      .wfd-think-dots span:nth-child(2) { animation-delay: 0.2s; }
      .wfd-think-dots span:nth-child(3) { animation-delay: 0.4s; }
      @keyframes wfd-bounce { 0%,80%,100% { transform: translateY(0); } 40% { transform: translateY(-4px); } }
      .wfd-think-label { font-size: 11px; color: var(--text-3); font-weight: 500; }

      .wfd-steps { display: flex; flex-direction: column; gap: 7px; }
      .wfd-step {
        display: flex; align-items: center; justify-content: space-between;
        padding: 9px 11px; border-radius: 10px;
        background: var(--bg); border: 1px solid var(--border);
        transition: opacity 0.4s ease, transform 0.4s var(--spring), border-color 0.3s ease, background 0.3s ease;
      }
      .wfd-step.wfd-step-running {
        border-color: rgba(123,167,201,0.35); background: linear-gradient(145deg, #FAFCFF, #F3F8FC);
      }
      .wfd-step.wfd-step-done {
        border-color: rgba(125,184,124,0.3); background: linear-gradient(145deg, #FAFFF9, #F3FAF3);
      }
      .wfd-step-left { display: flex; align-items: center; gap: 9px; flex: 1; min-width: 0; }
      .wfd-step-ic {
        width: 28px; height: 28px; border-radius: 7px; flex-shrink: 0;
        display: flex; align-items: center; justify-content: center;
      }
      .wfd-step-ic svg { width: 13px; height: 13px; }
      .wfd-ic-blue   { background: linear-gradient(135deg, #E8F1F8, #D5E6F3); color: var(--p-blue); }
      .wfd-ic-amber  { background: linear-gradient(135deg, #FEF3D8, #FAE7B0); color: var(--p-amber); }
      .wfd-ic-violet { background: linear-gradient(135deg, #EEF0FB, #E0E4F7); color: var(--p-violet); }
      .wfd-step-body { min-width: 0; }
      .wfd-step-task { font-size: 11px; font-weight: 600; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
      .wfd-step-agent { font-size: 10px; color: var(--text-3); margin-top: 1px; }

      .wfd-status { flex-shrink: 0; width: 20px; height: 20px; position: relative; }
      .wfd-st-idle, .wfd-st-run, .wfd-st-done {
        position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
        transition: opacity 0.3s ease;
      }
      .wfd-st-idle svg { width: 16px; height: 16px; stroke: var(--border-h); }
      .wfd-st-done svg { width: 16px; height: 16px; stroke: var(--p-green); }
      .wfd-spin {
        width: 14px; height: 14px; border-radius: 50%;
        border: 2px solid rgba(123,167,201,0.25); border-top-color: var(--p-blue);
        animation: wfd-spin 0.7s linear infinite;
      }
      @keyframes wfd-spin { to { transform: rotate(360deg); } }

      .wfd-footer {
        display: flex; align-items: center; gap: 7px;
        padding: 4px 2px 0; font-size: 10px; font-weight: 600; color: var(--p-green);
        transition: opacity 0.4s ease, transform 0.4s ease;
      }
      .wfd-footer-dot {
        width: 6px; height: 6px; border-radius: 50%; background: var(--p-green);
        box-shadow: 0 0 0 2px rgba(125,184,124,0.25);
      }

      /* ---- REMINDERS VISUAL ---- */
      .fv-rem-flow { gap: 10px; align-items: stretch; max-width: 300px; margin: 0 auto; }
      .fv-rem-flow > * { opacity: 0; transform: translateY(8px); transition: opacity 0.45s ease, transform 0.45s var(--spring); }
      .feature-row.visible .fv-rem-flow > :nth-child(1) { opacity: 1; transform: none; transition-delay: 0.2s; }
      .feature-row.visible .fv-rem-flow > :nth-child(2) { opacity: 1; transform: none; transition-delay: 0.45s; }
      .feature-row.visible .fv-rem-flow > :nth-child(3) { opacity: 1; transform: none; transition-delay: 0.65s; }
      .feature-row.visible .fv-rem-flow > :nth-child(4) { opacity: 1; transform: none; transition-delay: 0.85s; }

      .fv-rem-header {
        display: flex; align-items: center; gap: 10px;
        padding: 10px 12px; border-radius: 10px;
        background: var(--bg-alt); border: 1px solid var(--border);
      }
      .fv-rem-header-ic {
        width: 30px; height: 30px; border-radius: 8px; flex-shrink: 0;
        background: linear-gradient(135deg, #EEF0FB, #E0E4F7);
        color: var(--p-violet);
        display: flex; align-items: center; justify-content: center;
      }
      .fv-rem-header-ic svg { width: 15px; height: 15px; }
      .fv-rem-header-label { font-size: 10px; color: var(--text-3); font-weight: 500; }
      .fv-rem-header-count { font-size: 12px; font-weight: 600; color: var(--text-1); }

      .fv-rem-card {
        display: flex; align-items: center; gap: 9px;
        padding: 10px 11px; border-radius: 10px;
        background: var(--surface); border: 1px solid var(--border); width: 100%;
      }
      .fv-rem-urgent { border-color: rgba(212,168,67,0.25); background: linear-gradient(145deg, #FFFDF5, #FBF7E8); }
      .fv-rem-active { border-color: var(--border); }

      .fv-rem-card-ic {
        width: 28px; height: 28px; border-radius: 7px; flex-shrink: 0;
        display: flex; align-items: center; justify-content: center;
      }
      .fv-rem-card-ic svg { width: 13px; height: 13px; }
      .fv-rem-ic-amber { background: linear-gradient(135deg, #FEF3D8, #FAE7B0); color: var(--p-amber); }
      .fv-rem-ic-coral { background: linear-gradient(135deg, #FAEAE5, #F5D6CE); color: var(--p-coral); }
      .fv-rem-ic-blue  { background: linear-gradient(135deg, #E8F1F8, #D5E6F3); color: var(--p-blue); }

      .fv-rem-card-body { flex: 1; min-width: 0; }
      .fv-rem-card-title { font-size: 11px; font-weight: 600; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
      .fv-rem-card-sub { font-size: 10px; color: var(--text-3); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

      .fv-rem-tag {
        font-size: 9px; font-weight: 600; padding: 2px 7px; border-radius: 20px;
        white-space: nowrap; flex-shrink: 0; letter-spacing: 0.02em;
      }
      .fv-rem-tag-amber { color: var(--p-amber); background: rgba(212,168,67,0.12); }
      .fv-rem-tag-coral { color: var(--p-coral); background: rgba(207,123,99,0.12); }
      .fv-rem-tag-blue  { color: var(--p-blue);  background: rgba(123,167,201,0.12); }

      /* ---- REMINDERS DEMO ANIMATION ---- */
      .rm-demo {
        display: flex; flex-direction: column; gap: 9px;
        max-width: 320px; margin: 0 auto;
        background: var(--surface); border: 1px solid var(--border);
        border-radius: 16px; padding: 18px 18px 16px;
        box-shadow: 0 4px 24px rgba(0,0,0,0.06);
      }
      .rmd-chidden { display: none !important; }

      .rmd-header {
        display: flex; align-items: center; gap: 9px;
        padding: 8px 11px; border-radius: 10px;
        background: var(--bg-alt); border: 1px solid var(--border);
      }
      .rmd-loop-ic {
        width: 28px; height: 28px; border-radius: 7px; flex-shrink: 0;
        background: linear-gradient(135deg, #EEF0FB, #E0E4F7); color: var(--p-violet);
        display: flex; align-items: center; justify-content: center;
      }
      .rmd-loop-ic svg { width: 13px; height: 13px; animation: wfd-spin 3s linear infinite; }
      .rmd-header-text { flex: 1; }
      .rmd-header-label { font-size: 11px; font-weight: 600; color: var(--text-1); }
      .rmd-header-sub { font-size: 10px; color: var(--text-3); }
      .rmd-loop-badge {
        font-size: 9px; font-weight: 700; letter-spacing: 0.05em;
        color: var(--p-violet); background: rgba(155,143,232,0.12);
        padding: 2px 7px; border-radius: 20px;
      }

      .rmd-conditions { display: flex; flex-direction: column; gap: 7px; }
      .rmd-cond {
        display: flex; align-items: center; gap: 9px;
        padding: 9px 10px; border-radius: 10px;
        background: var(--bg); border: 1px solid var(--border);
        transition: border-color 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
      }
      .rmd-cond.rmd-cond-fired {
        border-color: rgba(212,168,67,0.4); background: linear-gradient(145deg, #FFFDF5, #FBF7EA);
        box-shadow: 0 2px 12px rgba(212,168,67,0.12);
      }
      .rmd-cond-ic {
        width: 28px; height: 28px; border-radius: 7px; flex-shrink: 0;
        display: flex; align-items: center; justify-content: center;
      }
      .rmd-cond-ic svg { width: 13px; height: 13px; }
      .rmd-ic-amber { background: linear-gradient(135deg, #FEF3D8, #FAE7B0); color: var(--p-amber); }
      .rmd-ic-coral { background: linear-gradient(135deg, #FAEAE5, #F5D6CE); color: var(--p-coral); }
      .rmd-ic-blue  { background: linear-gradient(135deg, #E8F1F8, #D5E6F3); color: var(--p-blue); }
      .rmd-cond-body { flex: 1; min-width: 0; }
      .rmd-cond-name { font-size: 11px; font-weight: 600; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
      .rmd-cond-sub  { font-size: 10px; color: var(--text-3); margin-top: 1px; }
      .rmd-cond-right { flex-shrink: 0; width: 22px; height: 18px; position: relative; }
      .rmd-scan, .rmd-fired { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
      .rmd-scan { gap: 2px; }
      .rmd-scan span {
        width: 3px; height: 3px; border-radius: 50%; background: var(--border-h);
        animation: wfd-bounce 1.4s ease-in-out infinite;
      }
      .rmd-scan span:nth-child(2) { animation-delay: 0.2s; }
      .rmd-scan span:nth-child(3) { animation-delay: 0.4s; }
      .rmd-fired { color: var(--p-amber); }
      .rmd-fired svg { width: 16px; height: 16px; animation: rmd-bell 0.5s ease-in-out 2; }
      @keyframes rmd-bell {
        0%,100% { transform: rotate(0); }
        25% { transform: rotate(-15deg); }
        75% { transform: rotate(15deg); }
      }

      .rmd-action {
        display: flex; align-items: center; gap: 9px;
        padding: 10px 11px; border-radius: 10px;
        border: 1px solid var(--border);
        background: var(--bg-alt);
        transition: background 0.4s ease, border-color 0.4s ease;
        height: 44px; /* fixed -- prevents resize between idle and active */
        overflow: hidden;
      }
      .rmd-action.rmd-action-idle .rmd-action-label { color: var(--text-3); }
      .rmd-action.rmd-action-idle .rmd-action-text  { color: var(--text-3); }
      .rmd-action.rmd-action-idle .rmd-action-tag   { visibility: hidden; }
      .rmd-action.rmd-action-live {
        background: linear-gradient(145deg, #FFF8F5, #FDF0EB);
        border-color: rgba(207,123,99,0.25);
      }
      .rmd-action.rmd-action-live .rmd-action-label { color: var(--p-coral); }
      .rmd-action.rmd-action-live .rmd-action-text  { color: var(--text-1); }
      .rmd-action.rmd-action-live .rmd-action-tag   { visibility: visible; }
      .rmd-action-ic { flex-shrink: 0; }
      .rmd-spin {
        width: 14px; height: 14px; border-radius: 50%;
        border: 2px solid var(--border); border-top-color: var(--text-3);
        animation: wfd-spin 1.2s linear infinite;
        transition: border-color 0.4s ease, border-top-color 0.4s ease;
      }
      .rmd-action.rmd-action-live .rmd-spin {
        border-color: rgba(207,123,99,0.2); border-top-color: var(--p-coral);
      }
      .rmd-action-body { flex: 1; min-width: 0; }
      .rmd-action-label {
        font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em;
        margin-bottom: 2px; transition: color 0.4s ease;
      }
      .rmd-action-text { font-size: 11px; font-weight: 500; line-height: 1.45; transition: color 0.4s ease; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
      .rmd-action-tag {
        flex-shrink: 0; font-size: 9px; font-weight: 700; padding: 2px 0; border-radius: 20px;
        color: var(--p-coral); background: rgba(207,123,99,0.12);
        width: 68px; text-align: center; /* fixed width -- largest tag is "Reply ready" */
        transition: visibility 0s;
      }

      /* ---- ORG CHART ---- */
      .org-chart { display: flex; flex-direction: column; align-items: center; gap: 0; width: 100%; }
      .org-you, .org-hub { display: flex; justify-content: center; }

      /* Animation states */
      .org-node { transition: box-shadow 0.4s ease, border-color 0.4s ease; }
      .org-node-you.org-active  { box-shadow: 0 0 0 3px rgba(28,25,23,0.12), 0 4px 16px rgba(0,0,0,0.1); }
      .org-node-hub.org-active  { box-shadow: 0 0 0 4px rgba(155,143,232,0.3), 0 6px 24px rgba(155,143,232,0.18); border-color: rgba(155,143,232,0.5) !important; }
      .org-node-agent.org-active { border-color: rgba(155,143,232,0.3); box-shadow: 0 0 0 3px rgba(155,143,232,0.1), 0 4px 16px rgba(0,0,0,0.06); }
      .org-node-agent.org-working .org-title { color: var(--p-violet); font-style: italic; }
      .org-node-agent .org-title { transition: color 0.3s ease; }

      /* Flowing signal dot on connector */
      .org-connector { position: relative; overflow: visible; }
      .org-signal {
        position: absolute; left: 50%; transform: translateX(-50%);
        width: 8px; height: 8px; border-radius: 50%;
        background: var(--p-violet);
        box-shadow: 0 0 6px rgba(155,143,232,0.6);
        pointer-events: none;
        animation: org-flow 0.55s cubic-bezier(0.4,0,0.2,1) forwards;
      }
      @keyframes org-flow {
        0%   { top: 0;    opacity: 0; }
        15%  { opacity: 1; }
        85%  { opacity: 1; }
        100% { top: 100%; opacity: 0; }
      }

      /* Branch reveal */
      .org-branches { transition: opacity 0.4s ease; }

      .org-node {
        display: flex; align-items: center; gap: 10px;
        padding: 12px 20px; border-radius: 12px;
        background: var(--bg); border: 1px solid var(--border);
        transition: box-shadow 0.3s var(--spring);
      }
      .org-node:hover { box-shadow: var(--shadow-md); }
      .org-node-you { border-color: var(--border-h); }
      .org-node-hub { border-color: rgba(155,143,232,0.3); background: var(--p-violet-bg); }
      .org-av {
        width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
        display: flex; align-items: center; justify-content: center;
        font-size: 11px; font-weight: 700;
      }
      .org-info { min-width: 0; }
      .org-name { font-size: 13px; font-weight: 600; color: var(--text); white-space: nowrap; }
      .org-title { font-size: 11px; color: var(--text-3); white-space: nowrap; }
      .org-connector {
        width: 2px; height: 32px; background: var(--border-h); margin: 0 auto; border-radius: 999px;
      }
      .org-branches {
        position: relative; width: 75%; height: 28px; margin: 28px auto 0;
      }
      .org-branches::before {
        content: ''; position: absolute; top: 0; left: 0; right: 0;
        height: 2px; background: var(--border-h); border-radius: 999px;
      }
      .org-branches::after {
        content: ''; position: absolute; bottom: 100%; left: 50%;
        width: 2px; height: 28px; background: var(--border-h); transform: translateX(-50%); border-radius: 999px;
      }
      .org-agents {
        display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; width: 100%;
      }
      .org-node-add { border-style: dashed; border-color: var(--border-h); background: transparent; }
      .org-node-agent {
        flex-direction: column; text-align: center; gap: 10px;
        padding: 16px 10px 14px; position: relative;
      }
      .org-node-agent::before {
        content: ''; position: absolute; top: -28px; left: 50%;
        width: 2px; height: 28px; background: var(--border-h); transform: translateX(-50%); border-radius: 999px;
      }
      .org-node-agent::after {
        content: ''; position: absolute; top: -31px; left: 50%;
        width: 7px; height: 7px; border-radius: 50%;
        background: var(--bg); border: 2px solid var(--border-h);
        transform: translateX(-50%);
      }
      .org-node-agent .org-av { margin: 0 auto; }
      .org-node-agent .org-name { font-size: 12px; }
      .org-node-agent .org-title { font-size: 10px; white-space: normal; line-height: 1.3; }
      @media (max-width: 768px) {
        .org-agents { grid-template-columns: 1fr; gap: 16px; max-width: 280px; margin: 0 auto; }
        .org-branches { width: 2px; height: 16px; margin: 0 auto; background: var(--border-h); border-radius: 999px; }
        .org-branches::before, .org-branches::after { display: none; }
        .org-node-agent::before { height: 16px; top: -16px; }
        .org-node-agent::after { display: none; }
        .org-connector { height: 16px; }
      }

      /* ---- FOUNDATION SECTION ---- */
      .foundation { background: var(--bg-alt); padding: 80px 0; }
      .foundation-grid {
        display: grid; grid-template-columns: repeat(3, 1fr);
        gap: 24px; margin-top: 0;
      }
      .found-card {
        background: var(--surface); border: 1px solid var(--border);
        border-radius: 20px; padding: 28px 28px 24px;
        transition: transform 0.3s var(--spring), box-shadow 0.3s ease;
      }
      .found-card:hover { transform: translateY(-3px); box-shadow: 0 8px 32px rgba(0,0,0,0.08); }
      .found-ic {
        width: 48px; height: 48px; border-radius: 14px;
        display: flex; align-items: center; justify-content: center;
        margin-bottom: 18px; flex-shrink: 0;
      }
      .found-ic svg { width: 22px; height: 22px; }
      .found-ic-shield { background: linear-gradient(135deg, #E8F5E8, #C8E6C8); color: var(--p-green); }
      .found-ic-brain  { background: linear-gradient(135deg, #EEF0FB, #DDE2F5); color: var(--p-violet); }
      .found-ic-tools  { background: linear-gradient(135deg, #FEF3D8, #FAE7B0); color: var(--p-amber); }
      .found-title { font-size: 18px; font-weight: 700; color: var(--text-1); margin-bottom: 10px; letter-spacing: -0.3px; }
      .found-body { font-size: 14px; color: var(--text-2); line-height: 1.65; margin-bottom: 18px; }
      .found-bullets { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 9px; }
      .found-bullets li { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; color: var(--text-2); line-height: 1.5; }
      .found-bullets li svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 2px; }

      /* ---- SKILLS STRIP ---- */
      .skills-strip {
        padding: 80px 0;
        background: var(--bg-alt);
        position: relative;
      }
      .skills-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
      .skill-card {
        background: var(--surface); border: 1px solid var(--border);
        border-radius: var(--radius); padding: 24px 22px;
        transition: all 0.3s var(--spring);
      }
      .skill-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
      .skill-top { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
      .skill-card h4 { font-size: 15px; font-weight: 700; }
      .skill-card p { font-size: 13px; color: var(--text-2); line-height: 1.6; }
      .skill-example {
        margin-top: 12px; padding: 10px 14px;
        background: var(--bg); border-radius: 8px;
        font-size: 12px; color: var(--text-2); line-height: 1.5;
        border-left: 3px solid var(--border-h);
        font-style: italic;
      }

      /* ---- COMPARISON ---- */
      .comparison { padding: 100px 0; }
      .comp-wrap {
        max-width: 960px; margin: 0 auto;
        background: var(--surface); border: 1px solid var(--border);
        border-radius: var(--radius-lg); overflow: hidden;
      }
      .comp-row { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; border-bottom: 1px solid var(--border); font-size: 14px; }
      .comp-row:last-child { border-bottom: none; }
      .comp-head { background: var(--bg-alt); font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-3); }
      .comp-cell { padding: 14px 18px; display: flex; align-items: center; }
      .comp-cell:not(:first-child) { justify-content: center; }
      .comp-cell svg { width: 18px; height: 18px; }
      .cc-yes { color: var(--p-green); }
      .cc-no { color: var(--text-3); opacity: 0.35; }
      .cc-part { color: var(--p-amber); }
      .comp-hl { background: rgba(155,143,232,0.03); }
      .comp-col-title { font-weight: 700; font-size: 13px; flex-direction: column; gap: 2px; text-align: center; }
      .comp-col-sub { font-size: 11px; font-weight: 500; color: var(--text-3); }
      .comp-orb-wrap { display: flex; align-items: center; justify-content: center; gap: 6px; }
      .comp-orb-wrap canvas { width: 20px; height: 20px; border-radius: 50%; flex-shrink: 0; }

      /* ---- SCENARIOS ---- */
      .scenarios { padding: 100px 0; background: var(--bg-alt); position: relative; }
      .scenario-tabs { display: flex; gap: 8px; justify-content: center; margin-bottom: 48px; flex-wrap: wrap; }
      .scenario-tab {
        padding: 10px 20px; border-radius: 999px; font-size: 14px; font-weight: 600;
        background: var(--surface); border: 1px solid var(--border); color: var(--text-2);
        cursor: pointer; transition: all 0.2s; font-family: var(--font);
      }
      .scenario-tab:hover { border-color: var(--border-h); color: var(--text); }
      .scenario-tab.active { background: #44403C; color: #fff; border-color: #44403C; }
      .scenario-panel { display: none; }
      .scenario-panel.active { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
      .scenario-content h3 { font-size: 22px; font-weight: 700; margin-bottom: 12px; letter-spacing: -0.3px; }
      .scenario-content > p { font-size: 15px; color: var(--text-2); line-height: 1.65; margin-bottom: 20px; }
      .sc-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
      .sc-list li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; line-height: 1.5; }
      .sc-list svg { width: 17px; height: 17px; flex-shrink: 0; margin-top: 2px; color: var(--p-green); }
      .sc-visual {
        background: var(--surface); border: 1px solid var(--border);
        border-radius: var(--radius); padding: 28px;
      }
      .sc-visual-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-3); margin-bottom: 16px; }
      .timeline { display: flex; flex-direction: column; gap: 14px; }
      .tl-event { display: flex; gap: 12px; align-items: flex-start; font-size: 13px; }
      .tl-time { font-weight: 700; color: var(--p-blue); white-space: nowrap; min-width: 52px; font-size: 12px; }
      .tl-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--p-blue); flex-shrink: 0; margin-top: 6px; }
      .tl-desc { color: var(--text-2); line-height: 1.5; }
      .tl-desc strong { color: var(--text); font-weight: 600; }

      /* ---- HOW (DUAL FLYWHEEL) ---- */
      .how { padding: 100px 0; }
      .flywheel-wrap { max-width: 760px; margin: 56px auto 0; }
      .flywheel { position: relative; width: 100%; padding-bottom: 57.1%; }
      .flywheel-svg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
      .fw-pulse { fill: none; }
      .fw-pulse-l {
        stroke-dasharray: 236 706;
        animation: fw-spin 6s linear infinite;
      }
      .fw-pulse-r {
        stroke-dasharray: 236 706;
        animation: fw-spin 6s linear infinite;
        animation-direction: reverse;
      }
      @keyframes fw-spin { to { stroke-dashoffset: -942; } }
      .fw-node {
        position: absolute; transform: translate(-50%, -50%);
        text-align: center; cursor: default; z-index: 2;
        animation: fw-node-glow 6s ease-in-out infinite; opacity: 0.55;
      }
      .fw-node:hover { opacity: 1 !important; }
      .fw-n1 { left: 31%; top: 12.5%; animation-delay: 0s; }
      .fw-n2 { left: 10%; top: 50%; animation-delay: 1s; }
      .fw-n3 { left: 31%; top: 87.5%; animation-delay: 2s; }
      .fw-n4 { left: 69%; top: 12.5%; animation-delay: 3s; }
      .fw-n5 { left: 90%; top: 50%; animation-delay: 4s; }
      .fw-n6 { left: 69%; top: 87.5%; animation-delay: 5s; }
      @keyframes fw-node-glow {
        0%, 5% { opacity: 0.55; }
        10% { opacity: 1; }
        20% { opacity: 1; }
        28%, 100% { opacity: 0.55; }
      }
      .fw-dot {
        width: 42px; height: 42px; border-radius: 50%;
        background: var(--surface); border: 2px solid var(--border);
        display: flex; align-items: center; justify-content: center;
        margin: 0 auto 6px; box-shadow: var(--shadow-sm);
        transition: border-color 0.3s, box-shadow 0.3s;
      }
      .fw-dot svg {
        width: 18px; height: 18px; stroke: var(--text-2); fill: none;
        stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
      }
      .fw-node:hover .fw-dot { border-color: var(--p-blue); box-shadow: 0 0 14px rgba(123,167,201,0.3); }
      .fw-node.fw-r:hover .fw-dot { border-color: var(--p-violet); box-shadow: 0 0 14px rgba(155,143,232,0.3); }
      .fw-name {
        font-size: 12px; font-weight: 700; color: var(--text); margin-bottom: 1px;
        background: var(--bg); padding: 1px 8px; border-radius: 4px;
      }
      .fw-desc {
        font-size: 10px; color: var(--text-3); line-height: 1.3; max-width: 110px; margin: 0 auto;
        background: var(--bg); padding: 2px 8px; border-radius: 4px;
        opacity: 0;
        animation: fw-desc-show 6s ease-in-out infinite;
        animation-delay: inherit;
      }
      @keyframes fw-desc-show {
        0%, 3% { opacity: 0.15; }
        8% { opacity: 1; }
        28% { opacity: 1; }
        38%, 100% { opacity: 0.15; }
      }
      @keyframes fw-desc-dim {
        0%, 3% { opacity: 0.4; }
        8% { opacity: 1; }
        28% { opacity: 1; }
        38%, 100% { opacity: 0.4; }
      }
      .fw-node:hover .fw-desc { animation: none; opacity: 1; }
      .fw-hub {
        position: absolute; transform: translate(-50%, -50%);
        font-size: 10px; font-weight: 700; text-transform: uppercase;
        letter-spacing: 1.5px; pointer-events: none; z-index: 1;
      }
      .fw-hub-l { left: 31%; top: 50%; color: var(--p-blue); opacity: 0.35; }
      .fw-hub-r { left: 69%; top: 50%; color: var(--p-violet); opacity: 0.35; }
      .fw-center {
        position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
        background: var(--surface); border: 1px solid var(--border);
        border-radius: 20px; padding: 5px 14px;
        font-size: 9px; font-weight: 600; color: var(--text-2);
        text-transform: uppercase; letter-spacing: 1px;
        white-space: nowrap; box-shadow: var(--shadow-sm); z-index: 3;
      }
      .fw-mobile { display: none; }
      .fw-svg-m { display: none; }
      .fw-pulse-lm {
        stroke-dasharray: 204 613;
        animation: fw-spin-m 6s linear infinite;
      }
      .fw-pulse-rm {
        stroke-dasharray: 204 613;
        animation: fw-spin-m 6s linear infinite;
        animation-direction: reverse;
      }
      @keyframes fw-spin-m { to { stroke-dashoffset: -817; } }

      /* ---- TESTIMONIALS ---- */
      .testi { padding: 100px 0; background: var(--bg-alt); position: relative; }
      .testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
      .testi-card {
        background: var(--surface); border: 1px solid var(--border);
        border-radius: var(--radius); padding: 28px;
        transition: transform 0.3s var(--spring), box-shadow 0.3s;
      }
      .testi-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
      .testi-stars { display: flex; gap: 2px; margin-bottom: 14px; }
      .testi-stars svg { width: 14px; height: 14px; color: var(--p-amber); fill: var(--p-amber); }
      .testi-q { font-size: 14px; line-height: 1.7; margin-bottom: 18px; }
      .testi-who { display: flex; align-items: center; gap: 10px; }
      .testi-av { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; }
      .testi-name { font-size: 13px; font-weight: 600; }
      .testi-role { font-size: 11px; color: var(--text-3); }

      /* ---- FINAL CTA ---- */
      .cta-final {
        padding: 160px 0 120px; text-align: center; position: relative; overflow: visible;
        background: linear-gradient(170deg, rgba(125,184,124,0.08) 0%, rgba(240,244,248,0.95) 30%, rgba(240,244,248,0.95) 70%, rgba(123,167,201,0.08) 100%);
      }
      .cta-final::before {
        content: ''; position: absolute; top: 45%; left: 50%;
        transform: translate(-50%, -50%); width: 800px; height: 800px;
        background: radial-gradient(circle, rgba(168,140,196,0.08) 0%, rgba(123,167,201,0.04) 40%, transparent 65%);
        pointer-events: none;
      }
      .cta-final::after {
        content: ''; position: absolute; inset: 0;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'%3E%3Cellipse cx='20' cy='18' rx='9' ry='4' transform='rotate(-35,20,18)' fill='%237DB87C'/%3E%3Cellipse cx='60' cy='58' rx='9' ry='4' transform='rotate(-35,60,58)' fill='%237DB87C'/%3E%3Cellipse cx='58' cy='20' rx='9' ry='4' transform='rotate(35,58,20)' fill='%237DB87C'/%3E%3Cellipse cx='18' cy='60' rx='9' ry='4' transform='rotate(35,18,60)' fill='%237DB87C'/%3E%3Cellipse cx='40' cy='40' rx='7' ry='3.5' transform='rotate(-20,40,40)' fill='%237DB87C'/%3E%3C/svg%3E");
        background-size: 80px 80px;
        opacity: 0.05; pointer-events: none;
      }
      .cta-final h2 { font-size: clamp(30px, 4vw, 46px); font-weight: 700; letter-spacing: -1.5px; margin-bottom: 20px; line-height: 1.12; position: relative; z-index: 1; }
      .cta-final h2 em { font-family: var(--font-serif); font-style: italic; font-weight: 400; }
      .cta-final > .container > p { font-size: 17px; color: var(--text-2); max-width: 440px; margin: 0 auto 40px; line-height: 1.65; position: relative; z-index: 1; }
      .cta-final .btn { position: relative; z-index: 1; margin-bottom: 28px; }
      .cta-note { margin-top: 0; font-size: 14px; font-weight: 500; color: var(--text-2); position: relative; z-index: 1; }
      .cta-guarantee {
        display: inline-flex; align-items: center; gap: 8px;
        background: var(--surface); border: 1px solid rgba(125,184,124,0.25);
        border-radius: 999px; padding: 10px 22px;
        position: absolute; top: 0; left: 50%; transform: translate(-50%, -50%);
        z-index: 10;
        box-shadow: 0 4px 16px rgba(125,184,124,0.12), 0 1px 3px rgba(0,0,0,0.04);
      }
      .cta-guarantee svg { width: 16px; height: 16px; color: var(--p-green); flex-shrink: 0; }
      .cta-guarantee span { font-size: 12px; font-weight: 600; color: var(--p-green); letter-spacing: 0.3px; }

      /* ---- FOOTER ---- */
      footer { padding: 64px 0 40px; position: relative; }
      footer::before {
        content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
        background: linear-gradient(to bottom, var(--border) 0px, var(--border) 1px, rgba(255,255,255,0.7) 1px, rgba(255,255,255,0.7) 2px);
      }
      .footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
      .footer-brand .logo { margin-bottom: 12px; }
      .footer-brand p { font-size: 14px; color: var(--text-2); line-height: 1.6; }
      .footer-col h4 { font-size: 12px; font-weight: 700; margin-bottom: 14px; text-transform: uppercase; letter-spacing: 0.8px; }
      .footer-col a { display: block; font-size: 14px; color: var(--text-2); text-decoration: none; margin-bottom: 8px; transition: color 0.2s; }
      .footer-col a:hover { color: var(--text); }
      .footer-bottom {
        display: flex; align-items: center; justify-content: space-between;
        padding-top: 24px; position: relative; border-top: none;
      }
      .footer-bottom::before {
        content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
        background: linear-gradient(to bottom, var(--border) 0px, var(--border) 1px, rgba(255,255,255,0.7) 1px, rgba(255,255,255,0.7) 2px);
      }
      .footer-bottom p { font-size: 13px; color: var(--text-3); }
      .footer-social { display: flex; gap: 16px; }
      .footer-social a { color: var(--text-3); transition: color 0.2s; }
      .footer-social a:hover { color: var(--text); }
      .footer-social svg { width: 20px; height: 20px; }

      .reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease, transform 0.6s var(--spring); }
      .reveal.visible { opacity: 1; transform: translateY(0); }

      @media (max-width: 1024px) {
        .hero { min-height: 100svh; }
        .hero-grid { grid-template-columns: 1fr; gap: 36px; }
        .hero-visual { order: -1; max-width: 500px; margin: 0 auto; width: 100%; }
        .hero-content { max-width: 100%; text-align: center; margin: 0 auto; }
        .hero-sub { margin-left: auto; margin-right: auto; }
        .hero-ctas { justify-content: center; }
        .hero-proof { justify-content: center; }
        .feature-row { grid-template-columns: 1fr; gap: 32px; }
        .feature-row.reverse .feature-visual { order: 0; }
        .foundation-grid { grid-template-columns: 1fr; }
        .skills-grid { grid-template-columns: 1fr 1fr; }
        .scenario-panel.active { grid-template-columns: 1fr; gap: 28px; }
        .flow-wrap { max-width: 600px; }
        .testi-grid { grid-template-columns: 1fr 1fr; }
        .comp-row { grid-template-columns: 1.5fr 1fr 1fr 1fr; }
        .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
      }
      @media (max-width: 768px) {
        nav { display: none; }
        /* Dark neumorphic mobile menu */
        nav.open {
          display: flex; flex-direction: column; position: fixed;
          top: 80px; left: 16px; right: 16px;
          background: #1C1917;
          border: 1px solid rgba(255,255,255,0.1);
          border-radius: var(--radius-lg); padding: 8px; gap: 0;
          box-shadow:
            0 24px 80px rgba(0,0,0,0.55),
            0 8px 20px rgba(0,0,0,0.3),
            inset 0 1px 0 rgba(255,255,255,0.07);
          z-index: 200; margin: 0; overflow: hidden;
          -webkit-backdrop-filter: none; backdrop-filter: none;
          will-change: transform;
        }
        nav.open a {
          font-size: 15px; font-weight: 500; display: block;
          color: rgba(255,255,255,0.5); letter-spacing: -0.2px;
          background: transparent; border: none; border-radius: 12px;
          box-shadow: none; padding: 14px 16px; text-align: left;
          transition: color 0.2s, background 0.2s, box-shadow 0.2s;
          transform: none; margin: 0; position: relative;
        }
        nav.open a + a::before { display: none; }
        nav.open a:hover {
          color: rgba(255,255,255,0.85);
          background: rgba(255,255,255,0.05);
          box-shadow: 0 2px 8px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.04);
        }
        .header-actions { display: none; }
        /* Actions with neumorphic CTAs */
        nav.open .nav-mobile-actions {
          display: flex; flex-direction: column; gap: 8px;
          padding: 8px 0 0; margin-top: 4px;
          border-top: none; position: relative;
        }
        nav.open .nav-mobile-actions::before {
          content: ''; position: absolute; top: 0; left: 8px; right: 8px; height: 1px;
          background: rgba(255,255,255,0.06);
        }
        nav.open .nav-mobile-actions .mob-login {
          display: block; width: auto; margin: 0; padding: 13px 16px;
          font-size: 15px; font-weight: 500;
          color: rgba(255,255,255,0.5); text-decoration: none; text-align: center;
          border: 1px solid rgba(255,255,255,0.08); border-radius: 12px;
          background: rgba(255,255,255,0.03);
          box-shadow: inset 0 1px 3px rgba(0,0,0,0.15);
          transition: color 0.2s, background 0.2s, box-shadow 0.2s, border-color 0.2s;
        }
        nav.open .nav-mobile-actions .mob-login:hover {
          color: rgba(255,255,255,0.85); border-color: rgba(255,255,255,0.15);
          background: rgba(255,255,255,0.06);
          box-shadow: 0 2px 8px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.04);
        }
        nav.open .nav-mobile-actions .mob-cta {
          display: block; width: auto; margin: 0; padding: 14px 16px;
          border-radius: 12px; text-align: center;
          background: #fff; color: #1C1917; font-size: 15px; font-weight: 600;
          text-decoration: none;
          box-shadow: 0 4px 16px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.9);
        }
        .hamburger { display: block; }
        .hero { padding: 100px 0 40px; min-height: 100svh; }
        .hero::after { display: none; }
        .pf-body { height: 360px; padding: 16px; }
        .demo-slide { top: 16px; left: 16px; right: 16px; bottom: 16px; }
        .skills-grid, .testi-grid { grid-template-columns: 1fr; }
        .comp-wrap { overflow-x: auto; }
        .comp-row { min-width: 600px; }
        .flywheel-wrap { max-width: 340px; margin-left: auto; margin-right: auto; }
        .flywheel { padding-bottom: 150%; }
        .fw-svg-d { display: none; }
        .fw-svg-m { display: block; }
        .fw-desc { animation-name: fw-desc-dim; }
        .fw-n1 { left: 50%; top: 9.2%; }
        .fw-n2 { left: 15%; top: 30.8%; }
        .fw-n3 { left: 85%; top: 30.8%; }
        .fw-n4 { left: 15%; top: 69.2%; }
        .fw-n5 { left: 85%; top: 69.2%; }
        .fw-n6 { left: 50%; top: 90.8%; }
        .fw-hub-l { left: 50%; top: 30.8%; }
        .fw-hub-r { left: 50%; top: 69.2%; }
        .footer-grid { grid-template-columns: 1fr; gap: 24px; text-align: center; }
        .footer-brand { padding-bottom: 8px; }
        .footer-brand .logo { justify-content: center; }
        .footer-col { display: flex; flex-direction: column; align-items: center; }
        .footer-col h4 { margin-bottom: 10px; }
        .footer-col a { margin-bottom: 6px; }
        .footer-bottom { flex-direction: column; gap: 16px; text-align: center; }
        .footer-social { justify-content: center; }
      }
      @media (max-width: 480px) {
        .hero-ctas { flex-direction: column; }
        .hero-ctas .btn { width: 100%; }
        .hero-proof { flex-wrap: wrap; gap: 8px; justify-content: center; }
        .scenario-tabs { flex-direction: column; align-items: stretch; }
      }
