/* ============================================================================
   Public Leaders Advisory — Bootstrap 5 dark theme layer (executive / refined).
   Loaded AFTER Bootstrap. Midnight navy base, ocean-teal light, warm gold.
   ============================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,800;1,400;1,600&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --ink-deepest: #050B18;
  --ink-base:    #081021;
  --ink-surface: #0d1830;
  --ink-raised:  #122039;
  --ink-line:    rgba(51, 197, 255, 0.13);
  --ink-line-2:  rgba(212, 175, 55, 0.20);

  --text-bright: #F5F7FA;
  --text-body:   #c3d0e0;
  --text-muted:  #8497ad;

  --accent:        #33C5FF;
  --accent-bright: #6fd9ff;
  --accent-deep:   #007BFF;
  --accent-glow:   rgba(51, 197, 255, 0.24);
  --gold:        #D4AF37;
  --gold-deep:   #A07A1E;
  --gold-soft:   #F5DC8B;
  --gold-glow:   rgba(212, 175, 55, 0.22);

  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;

  --bs-body-bg: var(--ink-base);
  --bs-body-color: var(--text-body);
  --bs-body-font-family: var(--font-body);
  --bs-body-font-weight: 300;
  --bs-emphasis-color: var(--text-bright);
  --bs-secondary-color: var(--text-muted);
  --bs-border-color: var(--ink-line);
  --bs-primary: #33C5FF;
  --bs-primary-rgb: 51, 197, 255;
  --bs-link-color: var(--accent);
  --bs-link-color-rgb: 51, 197, 255;
  --bs-link-hover-color: var(--accent-bright);
}

body { background: var(--ink-base); color: var(--text-body); -webkit-font-smoothing: antialiased; min-height: 100vh; }
body::before {
  content: ''; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(1000px 680px at 82% -12%, rgba(63,182,201,0.07), transparent 60%),
    radial-gradient(760px 560px at -12% 112%, rgba(212,180,106,0.06), transparent 55%);
}
/* Fine grain overlay for depth */
body::after {
  content: ''; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: 0.035;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1,h2,h3,h4,h5 { font-family: var(--font-display); font-weight: 600; color: var(--text-bright); letter-spacing: -0.015em; }
.display-1,.display-2,.display-3,.display-4,.display-5 { font-family: var(--font-display); }
a { text-decoration: none; }
.text-muted, .text-secondary { color: var(--text-muted) !important; }
.mono { font-family: var(--font-mono); }
.fraunces { font-family: var(--font-display); }
.glyph { color: var(--accent); font-size: 0.7em; margin: 0 0.4em; vertical-align: middle; }
.text-gold { color: var(--gold) !important; }
.lead { font-weight: 300; }

/* Navbar */
.navbar { background: rgba(8,13,21,0.82) !important; backdrop-filter: blur(18px); border-bottom: 1px solid var(--ink-line); }
.navbar .nav-link { color: var(--text-body) !important; font-weight: 400; letter-spacing: 0.01em; }
.navbar .nav-link:hover, .navbar .nav-link.active { color: var(--text-bright) !important; }
.navbar .dropdown-menu { background: var(--ink-surface); border: 1px solid var(--ink-line); border-radius: 12px; box-shadow: 0 24px 60px rgba(0,0,0,0.5); }
.navbar .dropdown-item { color: var(--text-body); border-radius: 8px; padding: 0.5rem 0.8rem; }
.navbar .dropdown-item:hover { background: var(--ink-raised); color: var(--text-bright); }
.navbar .dropdown-header { color: var(--text-muted); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; }
.navbar-toggler { border-color: var(--ink-line); }
.navbar-toggler-icon { filter: invert(0.8); }

.brand-mark { width: 40px; height: 40px; border-radius: 11px; display: inline-grid; place-items: center; background: linear-gradient(135deg, var(--gold-soft), var(--gold), var(--gold-deep)); color: #06101f; font-family: var(--font-display); font-weight: 700; font-size: 0.85rem; box-shadow: 0 4px 22px var(--gold-glow); flex-shrink: 0; }
.brand-mark.gold { background: linear-gradient(135deg, var(--gold-deep), var(--gold)); box-shadow: 0 4px 22px var(--gold-glow); }
.brand-name { font-family: var(--font-display); font-weight: 600; color: var(--text-bright); font-size: 1.0rem; line-height: 1.1; }
.brand-tag { font-size: 0.64rem; color: var(--text-muted); letter-spacing: 0.07em; text-transform: uppercase; }

.credit-chip { display: inline-flex; align-items: center; gap: 0.45rem; background: var(--ink-surface); border: 1px solid var(--ink-line); border-radius: 999px; padding: 0.3rem 0.85rem; font-size: 0.85rem; color: var(--text-body); }
.credit-chip .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px var(--accent); }
.credit-chip strong { color: var(--text-bright); font-family: var(--font-mono); }

/* Cards */
.card { background: var(--ink-surface); border: 1px solid var(--ink-line); border-radius: 16px; color: var(--text-body); }
.card-header { background: transparent; border-bottom: 1px solid var(--ink-line); font-family: var(--font-display); color: var(--text-bright); font-weight: 500; }
.card.glow { background: linear-gradient(165deg, var(--ink-surface), var(--ink-base)); border-color: rgba(63,182,201,0.28); box-shadow: 0 30px 80px -30px rgba(63,182,201,0.25); }

/* Buttons */
.btn { font-weight: 500; border-radius: 10px; letter-spacing: 0.01em; }
.btn-primary { background: linear-gradient(135deg, var(--gold-soft), var(--gold), var(--gold-deep)); border: none; color: #06101f; font-weight: 600; box-shadow: 0 8px 26px var(--gold-glow); }
.btn-primary:hover, .btn-primary:focus { color: var(--ink-deepest); transform: translateY(-1px); filter: brightness(1.05); }
.btn-warning { background: linear-gradient(135deg, var(--gold), var(--gold-deep)); border: none; color: var(--ink-deepest); font-weight: 600; box-shadow: 0 8px 26px var(--gold-glow); }
.btn-warning:hover { color: var(--ink-deepest); }
.btn-outline-light { border-color: var(--ink-line); color: var(--text-body); }
.btn-outline-light:hover { background: rgba(255,255,255,0.04); border-color: var(--accent); color: var(--text-bright); }
.btn-secondary { background: var(--ink-raised); border-color: var(--ink-line); color: var(--text-bright); }
.btn-secondary:hover { background: var(--ink-line); border-color: var(--accent); color: var(--text-bright); }
.btn-outline-gold { color: var(--gold); border: 1px solid rgba(212,180,106,0.4); }
.btn-outline-gold:hover { background: rgba(212,180,106,0.1); color: var(--gold); border-color: var(--gold); }
.btn-outline-danger { color: #e08585; border-color: rgba(213,106,106,0.4); }
.btn-outline-danger:hover { background: rgba(213,106,106,0.12); color: #e08585; border-color: rgba(213,106,106,0.5); }
.btn-lg { padding: 0.7rem 1.6rem; }

/* Forms */
.form-control, .form-select { background: var(--ink-base); border: 1px solid var(--ink-line); color: var(--text-bright); border-radius: 10px; font-weight: 300; }
.form-control:focus, .form-select:focus { background: var(--ink-base); border-color: var(--accent); color: var(--text-bright); box-shadow: 0 0 0 3px var(--accent-glow); }
.form-control::placeholder { color: #56697a; }
.form-label { color: var(--text-muted); font-size: 0.85rem; margin-bottom: 0.3rem; }
.form-control:disabled, .form-select:disabled { background: var(--ink-deepest); color: var(--text-muted); }
.form-check-input { background-color: var(--ink-base); border-color: var(--ink-line); }
.form-check-input:checked { background-color: var(--accent); border-color: var(--accent); }
.form-text { color: #56697a; }
.input-group-text { background: var(--ink-raised); border-color: var(--ink-line); color: var(--text-muted); }

/* Tabs */
.nav-tabs { border-bottom: 1px solid var(--ink-line); }
.nav-tabs .nav-link { color: var(--text-muted); border: none; border-bottom: 2px solid transparent; font-weight: 400; }
.nav-tabs .nav-link:hover { color: var(--text-bright); border-color: transparent; }
.nav-tabs .nav-link.active { color: var(--accent-bright); background: transparent; border-bottom: 2px solid var(--accent); }

/* Tables */
.table { color: var(--text-body); --bs-table-bg: transparent; --bs-table-color: var(--text-body); border-color: var(--ink-line); }
.table > :not(caption) > * > * { background: transparent; color: var(--text-body); border-bottom-color: var(--ink-line); }
.table thead th { color: var(--text-muted); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 500; }
.table-hover > tbody > tr:hover > * { background: rgba(63,182,201,0.04); color: var(--text-bright); }

/* List groups */
.list-group-item { background: transparent; border-color: var(--ink-line); color: var(--text-body); }
.list-group-item-action:hover { background: var(--ink-raised); color: var(--text-bright); }

/* Badges */
.badge.text-bg-success { background-color: rgba(92,184,138,0.16) !important; color: #6fcf9c !important; }
.badge.text-bg-warning { background-color: rgba(212,180,106,0.18) !important; color: var(--gold) !important; }
.badge.text-bg-secondary { background-color: rgba(120,140,156,0.16) !important; color: var(--text-muted) !important; }
.badge.text-bg-info { background-color: rgba(63,182,201,0.16) !important; color: var(--accent-bright) !important; }
.badge.text-bg-danger { background-color: rgba(213,106,106,0.16) !important; color: #e08585 !important; }

/* Alerts */
.alert { border-radius: 11px; border: 1px solid transparent; }
.alert-success { background: rgba(92,184,138,0.1); border-color: rgba(92,184,138,0.3); color: #6fcf9c; }
.alert-danger { background: rgba(213,106,106,0.1); border-color: rgba(213,106,106,0.3); color: #e08585; }
.alert-warning { background: rgba(212,180,106,0.1); border-color: rgba(212,180,106,0.3); color: var(--gold); }
.alert-info { background: rgba(63,182,201,0.1); border-color: rgba(63,182,201,0.3); color: var(--accent-bright); }

/* Avatars */
.avatar { width: 40px; height: 40px; border-radius: 11px; display: grid; place-items: center; color: var(--ink-deepest); font-weight: 600; font-family: var(--font-display); flex-shrink: 0; }
.avatar-lg { width: 68px; height: 68px; font-size: 1.7rem; border-radius: 18px; }

/* AI output */
.ai-block { background: var(--ink-base); border-left: 3px solid var(--accent); border-radius: 0 11px 11px 0; padding: 1.1rem 1.3rem; white-space: pre-wrap; line-height: 1.75; color: var(--text-body); }
.ai-block.gold { border-left-color: var(--gold); }

/* Stat tiles */
.stat-tile { background: var(--ink-surface); border: 1px solid var(--ink-line); border-radius: 16px; padding: 1.2rem; display: block; height: 100%; transition: border-color .2s, transform .2s; }
a.stat-tile:hover { border-color: var(--accent); transform: translateY(-2px); }
.stat-label { font-size: 0.78rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.stat-value { font-family: var(--font-display); font-size: 1.9rem; font-weight: 600; color: var(--text-bright); }

/* ============================ LANDING / EXECUTIVE ========================== */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; }
#hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; display: block; }
.hero-overlay { position: absolute; inset: 0; z-index: 1; background:
  linear-gradient(180deg, rgba(4,7,12,0.30) 0%, rgba(4,7,12,0.55) 55%, var(--ink-base) 100%);
}
.hero-content { position: relative; z-index: 2; }
.hero-title { font-family: var(--font-display); font-weight: 500; font-size: clamp(2.6rem, 6.4vw, 5rem); line-height: 1.02; letter-spacing: -0.02em; color: var(--text-bright); }
.hero-title em { font-style: italic; font-weight: 500;
  background: linear-gradient(100deg, var(--accent-bright), var(--gold));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

.pill { display: inline-flex; align-items: center; gap: 0.55rem; padding: 0.4rem 0.95rem; border: 1px solid var(--ink-line-2); border-radius: 999px; background: rgba(212,180,106,0.06); color: var(--gold); font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 500; }
.pill .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 10px var(--gold); }

.eyebrow { color: var(--accent-bright); letter-spacing: 0.18em; text-transform: uppercase; font-size: 0.8rem; font-weight: 500; }
.section-label { color: var(--gold); font-size: 0.78rem; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 600; }
.hairline { height: 1px; width: 100%; background: linear-gradient(90deg, transparent, var(--ink-line-2), transparent); }

/* Trust / credibility strip */
.trust-strip { border-top: 1px solid var(--ink-line); border-bottom: 1px solid var(--ink-line); }
.trust-strip .label { color: var(--text-muted); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; }
.trust-item { font-family: var(--font-display); color: var(--text-body); font-size: 1.05rem; letter-spacing: 0.01em; opacity: 0.85; }

/* Feature cards */
.feature-card { position: relative; background: linear-gradient(180deg, var(--ink-surface), var(--ink-base)); border: 1px solid var(--ink-line); border-radius: 18px; padding: 2rem 1.8rem; height: 100%; transition: transform 0.25s, border-color 0.25s; overflow: hidden; }
.feature-card::after { content: ''; position: absolute; inset: 0 0 auto 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0.5; }
.feature-card:hover { transform: translateY(-4px); border-color: rgba(63,182,201,0.32); }
.feature-num { font-family: var(--font-mono); font-size: 0.74rem; color: var(--gold); letter-spacing: 0.14em; }
.feature-ic { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: rgba(63,182,201,0.1); border: 1px solid var(--ink-line); margin-bottom: 1rem; }
.feature-ic svg { width: 22px; height: 22px; stroke: var(--accent-bright); fill: none; stroke-width: 1.5; }

/* How it works */
.step { position: relative; padding: 1.6rem; border-radius: 16px; border: 1px solid var(--ink-line); background: var(--ink-surface); height: 100%; }
.step-no { font-family: var(--font-display); font-size: 2.4rem; font-weight: 600; line-height: 1;
  background: linear-gradient(135deg, var(--accent-bright), var(--gold)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* Editorial quote band */
.quote-band { position: relative; border-radius: 22px; overflow: hidden; border: 1px solid var(--ink-line-2);
  background: radial-gradient(120% 140% at 0% 0%, rgba(63,182,201,0.10), transparent 55%),
              radial-gradient(120% 140% at 100% 100%, rgba(212,180,106,0.10), transparent 55%),
              var(--ink-surface); padding: clamp(2.2rem, 5vw, 4rem); }
.quote-band .mark { font-family: var(--font-display); font-size: 4rem; color: var(--gold); line-height: 0.6; opacity: 0.6; }
.quote-text { font-family: var(--font-display); font-style: italic; font-weight: 400; font-size: clamp(1.4rem, 3vw, 2.1rem); line-height: 1.35; color: var(--text-bright); }

/* Pricing */
.price-amount { font-family: var(--font-display); font-size: 3.4rem; font-weight: 600; color: var(--text-bright); line-height: 1; }
.price-list { list-style: none; padding: 0; margin: 0; }
.price-list li { padding: 0.55rem 0 0.55rem 1.8rem; position: relative; border-bottom: 1px solid var(--ink-line); color: var(--text-body); }
.price-list li::before { content: '\25C6'; position: absolute; left: 0; color: var(--accent); font-size: 0.7rem; top: 0.8rem; }

/* CTA band */
.cta-band { border-radius: 22px; border: 1px solid var(--ink-line-2); overflow: hidden;
  background: radial-gradient(130% 200% at 50% -40%, rgba(63,182,201,0.16), transparent 60%), var(--ink-surface);
  padding: clamp(2.4rem, 5vw, 4rem); text-align: center; }

/* Auth */
.auth-wrap { min-height: 100vh; display: grid; place-items: center; padding: 2rem 1rem; position: relative; }
.auth-card { width: 100%; max-width: 440px; position: relative; z-index: 2; }

/* Setup */
.setup-steps { display: flex; gap: 0.5rem; }
.setup-step { flex: 1; height: 4px; border-radius: 2px; background: var(--ink-raised); }
.setup-step.done { background: var(--accent); }
.setup-step.current { background: var(--accent-bright); }

/* Footer */
.site-foot { border-top: 1px solid var(--ink-line); padding: 2.8rem 0; margin-top: 3.5rem; }
.foot-disclaimer { color: #56697a; font-style: italic; font-size: 0.82rem; }

/* Utilities */
.divider { height: 1px; background: var(--ink-line); margin: 1.25rem 0; }
.section { padding: clamp(3.5rem, 8vw, 6.5rem) 0; }
.reveal { opacity: 0; transform: translateY(22px); animation: reveal 0.8s cubic-bezier(.2,.7,.2,1) forwards; }
@keyframes reveal { to { opacity: 1; transform: translateY(0); } }
.d1{animation-delay:.1s}.d2{animation-delay:.28s}.d3{animation-delay:.46s}.d4{animation-delay:.64s}
.confidence-bar { height: 5px; background: var(--ink-raised); border-radius: 3px; overflow: hidden; }
.confidence-bar > span { display: block; height: 100%; background: var(--accent); }

/* ===================== MERGED MAIN PAGE ADDITIONS ===================== */
html { scroll-behavior: smooth; }
section[id] { scroll-margin-top: 88px; }

/* Scroll cue */
.scroll-cue { width: 26px; height: 42px; border: 1px solid var(--ink-line-2); border-radius: 14px; position: relative; opacity: 0.7; }
.scroll-cue::after { content: ''; position: absolute; left: 50%; top: 8px; width: 4px; height: 8px; border-radius: 3px; background: var(--gold); transform: translateX(-50%); animation: cue 1.8s ease-in-out infinite; }
@keyframes cue { 0%,100% { opacity: 0; transform: translate(-50%, 0); } 50% { opacity: 1; transform: translate(-50%, 10px); } }

/* Membership plan card */
.plan-card { position: relative; border-radius: 22px; overflow: hidden; border: 1px solid var(--ink-line-2);
  background: radial-gradient(130% 120% at 0% 0%, rgba(63,182,201,0.12), transparent 55%),
              radial-gradient(120% 120% at 100% 100%, rgba(212,180,106,0.10), transparent 55%),
              linear-gradient(180deg, var(--ink-surface), var(--ink-base));
  box-shadow: 0 40px 100px -40px rgba(63,182,201,0.30); }
.plan-ribbon { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.35rem 0.85rem; border-radius: 999px; background: rgba(212,180,106,0.12); border: 1px solid var(--ink-line-2); color: var(--gold); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; }
.price-mega { font-family: var(--font-display); font-weight: 600; font-size: clamp(3.4rem, 8vw, 5rem); line-height: 0.95; color: var(--text-bright); }
.price-mega .cur { font-size: 1.6rem; color: var(--text-muted); vertical-align: top; margin-right: 0.15rem; }
.price-per { color: var(--text-muted); font-size: 1rem; }

/* Check list */
.check-list { list-style: none; padding: 0; margin: 0; }
.check-list li { display: flex; gap: 0.7rem; align-items: flex-start; padding: 0.55rem 0; color: var(--text-body); }
.check-list li svg { flex-shrink: 0; width: 20px; height: 20px; margin-top: 2px; stroke: var(--accent-bright); fill: none; stroke-width: 2; }
.check-list li b { color: var(--text-bright); font-weight: 600; }

/* Add-on chips */
.addon { display: flex; justify-content: space-between; align-items: center; padding: 0.7rem 1rem; border: 1px solid var(--ink-line); border-radius: 12px; background: var(--ink-base); }
.addon .amt { font-family: var(--font-mono); color: var(--text-bright); }

/* FAQ accordion */
.accordion { --bs-accordion-bg: transparent; --bs-accordion-color: var(--text-body); --bs-accordion-border-color: var(--ink-line); --bs-accordion-active-bg: transparent; }
.accordion-item { background: transparent; border: 1px solid var(--ink-line); border-radius: 14px !important; margin-bottom: 0.75rem; overflow: hidden; }
.accordion-button { background: var(--ink-surface); color: var(--text-bright); font-family: var(--font-display); font-weight: 500; }
.accordion-button:not(.collapsed) { background: var(--ink-surface); color: var(--accent-bright); box-shadow: none; }
.accordion-button:focus { box-shadow: none; border-color: var(--ink-line); }
.accordion-button::after { filter: invert(0.7) sepia(1) saturate(3) hue-rotate(150deg); }
.accordion-body { background: var(--ink-surface); color: var(--text-body); }

/* ===================== LANDING SECTION POLISH ===================== */
.section-head h2 { font-size: clamp(1.9rem, 4vw, 2.9rem); }

/* Principles strip */
.principle { text-align: center; padding: 1.2rem 1rem; }
.principle-ic { width: 54px; height: 54px; border-radius: 15px; display: grid; place-items: center; margin: 0 auto 1rem; background: rgba(63,182,201,0.08); border: 1px solid var(--ink-line); }
.principle-ic svg { width: 24px; height: 24px; stroke: var(--accent-bright); fill: none; stroke-width: 1.5; }
.principle h4 { font-size: 1.1rem; margin-bottom: 0.4rem; }

/* Feature cards — elevated */
.feature-card .feature-ic { width: 52px; height: 52px; }
.feature-card h3 { font-size: 1.32rem; }

/* Product preview card */
.preview-wrap { position: relative; }
.preview-glow { position: absolute; inset: -18% -8% auto -8%; height: 70%; background: radial-gradient(60% 100% at 50% 0, rgba(63,182,201,0.20), transparent 70%); filter: blur(24px); z-index: 0; pointer-events: none; }
.preview-card { position: relative; z-index: 1; border: 1px solid var(--ink-line); border-radius: 20px; background: linear-gradient(180deg, var(--ink-surface), var(--ink-base)); box-shadow: 0 50px 120px -55px rgba(0,0,0,0.85); overflow: hidden; }
.pv-bar-top { display: flex; gap: 7px; padding: 14px 16px; border-bottom: 1px solid var(--ink-line); }
.pv-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--ink-raised); }
.pv-body { padding: 1.5rem; }
.pv-person { display: flex; align-items: center; gap: 0.9rem; margin-bottom: 1.2rem; }
.pv-tabs { display: flex; gap: 1.3rem; border-bottom: 1px solid var(--ink-line); margin-bottom: 1.2rem; }
.pv-tabs span { padding-bottom: 0.6rem; color: var(--text-muted); font-size: 0.86rem; }
.pv-tabs span.on { color: var(--accent-bright); border-bottom: 2px solid var(--accent); }
.pv-label { font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 0.6rem; }
.trait-chip { display: inline-block; padding: 0.32rem 0.72rem; border: 1px solid var(--ink-line); border-radius: 999px; font-size: 0.78rem; color: var(--text-body); margin: 0 0.4rem 0.5rem 0; background: var(--ink-base); }
.pv-row { display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin-bottom: 0.7rem; font-size: 0.86rem; color: var(--text-body); }
.pv-track { height: 6px; border-radius: 3px; background: var(--ink-raised); width: 44%; overflow: hidden; flex-shrink: 0; }
.pv-track > i { display: block; height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-bright)); }
.pv-note { margin-top: 1.1rem; padding: 0.85rem 1rem; border-left: 3px solid var(--gold); background: var(--ink-base); border-radius: 0 10px 10px 0; font-size: 0.88rem; color: var(--text-body); }

/* How it works — rail with badges */
.steps-rail { position: relative; }
@media (min-width: 768px) { .steps-rail::before { content: ''; position: absolute; top: 28px; left: 16%; right: 16%; height: 1px; background: linear-gradient(90deg, transparent, var(--ink-line-2), transparent); } }
.step-badge { width: 56px; height: 56px; border-radius: 50%; display: grid; place-items: center; margin: 0 auto 1.1rem; font-family: var(--font-display); font-size: 1.5rem; font-weight: 600; color: var(--ink-deepest); background: linear-gradient(135deg, var(--accent-bright), var(--gold)); position: relative; z-index: 1; box-shadow: 0 8px 26px var(--accent-glow); }
.step-clean { text-align: center; padding: 0 0.6rem; }
.step-clean h3 { font-size: 1.2rem; margin-bottom: 0.5rem; }

/* ===================== HERO MARKETING WORD LAYER ===================== */
.hero-words { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.hero-words span {
  position: absolute; font-family: var(--font-display); font-style: italic; font-weight: 600;
  white-space: nowrap; opacity: 0; transform: translateY(10px);
  transition: opacity 1.2s ease, transform 1.4s ease;
  text-shadow: 0 0 26px rgba(51, 197, 255, 0.25); will-change: opacity, transform; letter-spacing: 0.01em;
}
.hero-words span.show { opacity: var(--o, 0.22); transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .hero-words span { transition: opacity 0.6s ease; transform: none; } }
