@import url('https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(128,128,128,.15);border-radius:3px}
::selection{background:rgba(212,165,116,.28);color:#0A0A0B}
html,body{height:100%}
body{font-family:'Inter Tight','Inter',system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:'ss01','cv11';letter-spacing:-.005em;transition:background .35s ease,color .35s ease}

/* ═══ THEME VARIABLES ═══
   Refined palette — near-black ground, copper accent, restrained
   contrast. Glow variables intentionally near-zero to drop the
   "AI-template" feel. Light theme mirrors with cream + warm copper. */
:root,body.dark{
  --bg:#0A0A0B;--bg-card:rgba(255,255,255,.025);--bg-card-hover:rgba(255,255,255,.045);--bg-surface:#111113;
  --bg-nav:rgba(10,10,11,.78);--border:rgba(255,255,255,.07);--border-hover:rgba(255,255,255,.14);
  --text:#EDEDED;--text-secondary:#8A8A92;--text-muted:#56565E;
  --accent:#D4A574;--accent-dim:rgba(212,165,116,.09);--accent-glow:rgba(212,165,116,.0);
  --sidebar:#08080A;--green:#7BBA8F;--red:#D88080;--amber:#D4A574;
  --grid-line:rgba(255,255,255,.04);--chart-bar-muted:rgba(212,165,116,.18);--glow1:rgba(0,0,0,0);
  --accent-bg:#D4A574;--accent-text:#0A0A0B;
  --results-bg:rgba(255,255,255,.02);
  --badge-new-bg:rgba(255,255,255,.06);--badge-new-c:#C8C8CE;
  --badge-contacted-bg:rgba(212,165,116,.12);--badge-contacted-c:#D4A574;
  --badge-qualified-bg:rgba(123,186,143,.12);--badge-qualified-c:#9BD0AB;
  --badge-booked-bg:rgba(212,165,116,.18);--badge-booked-c:#E4BA88;
  --badge-closed-bg:rgba(123,186,143,.14);--badge-closed-c:#A8D6B6;
  --badge-confirmed-bg:rgba(123,186,143,.12);--badge-confirmed-c:#9BD0AB;
  --badge-pending-bg:rgba(212,165,116,.12);--badge-pending-c:#D4A574;
  --badge-succeeded-bg:rgba(123,186,143,.12);--badge-succeeded-c:#9BD0AB;
  --badge-refunded-bg:rgba(216,128,128,.12);--badge-refunded-c:#E29797;
  --popular-border:rgba(212,165,116,.32);--popular-bg:rgba(212,165,116,.07);--popular-c:#D4A574;
  --best-bg:rgba(123,186,143,.07);
  --particle-color:212,165,116;
  --icon-border:rgba(212,165,116,.14);
  --connect-avatar-bg:rgba(212,165,116,.09);--connect-avatar-c:#D4A574;
  --glow-orb1:rgba(0,0,0,0);--glow-orb2:rgba(0,0,0,0);
  --metric-accent:rgba(123,186,143,.3);--metric-accent2:rgba(216,128,128,.3);
  /* Aliases — multi-page component system */
  --card-bg:#111113;--hover-bg:rgba(255,255,255,.035);
}
body.light{
  --bg:#F6F4EF;--bg-card:#FFFFFF;--bg-card-hover:#EFEDE7;--bg-surface:#FFFFFF;
  --bg-nav:rgba(246,244,239,.88);--border:rgba(15,15,15,.09);--border-hover:rgba(15,15,15,.16);
  --text:#1A1A1A;--text-secondary:#6B6B70;--text-muted:#A8A8AE;
  --accent:#A06B3A;--accent-dim:rgba(160,107,58,.07);--accent-glow:rgba(0,0,0,0);
  --sidebar:#1A1A1A;--green:#4F8A65;--red:#B85454;--amber:#A06B3A;
  --grid-line:rgba(0,0,0,.05);--chart-bar-muted:rgba(160,107,58,.18);--glow1:rgba(0,0,0,0);
  --accent-bg:#A06B3A;--accent-text:#FFFFFF;
  --results-bg:rgba(160,107,58,.03);
  --badge-new-bg:#EFEDE7;--badge-new-c:#3A3A3A;
  --badge-contacted-bg:#F1E5D2;--badge-contacted-c:#6B4820;
  --badge-qualified-bg:#E0EBE3;--badge-qualified-c:#2E5B3F;
  --badge-booked-bg:#F1E5D2;--badge-booked-c:#6B4820;
  --badge-closed-bg:#E0EBE3;--badge-closed-c:#2E5B3F;
  --badge-confirmed-bg:#E0EBE3;--badge-confirmed-c:#2E5B3F;
  --badge-pending-bg:#F1E5D2;--badge-pending-c:#6B4820;
  --badge-succeeded-bg:#E0EBE3;--badge-succeeded-c:#2E5B3F;
  --badge-refunded-bg:#F1E0E0;--badge-refunded-c:#7A2E2E;
  --popular-border:rgba(160,107,58,.35);--popular-bg:rgba(160,107,58,.06);--popular-c:#A06B3A;
  --best-bg:rgba(79,138,101,.06);
  --particle-color:160,107,58;
  --icon-border:rgba(160,107,58,.14);
  --connect-avatar-bg:rgba(160,107,58,.07);--connect-avatar-c:#A06B3A;
  --glow-orb1:rgba(0,0,0,0);--glow-orb2:rgba(0,0,0,0);
  --metric-accent:rgba(79,138,101,.3);--metric-accent2:rgba(184,84,84,.3);
  /* Aliases — multi-page component system */
  --card-bg:#FFFFFF;--hover-bg:#EFEDE7;
}
/* Body theme — paint bg/text */
body.dark{background:var(--bg);color:var(--text)}
body.light{background:var(--bg);color:var(--text)}

/* ═══ ANIMATIONS ═══ */
@keyframes scanline{0%,100%{top:-2px;opacity:0}50%{top:100%;opacity:1}}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes borderGlow{0%,100%{border-color:rgba(212,165,116,.1)}50%{border-color:rgba(212,165,116,.3)}}
@keyframes slideUp{from{opacity:0;transform:translateY(60px)}to{opacity:1;transform:none}}
@keyframes slideLeft{from{opacity:0;transform:translateX(80px)}to{opacity:1;transform:none}}
@keyframes slideRight{from{opacity:0;transform:translateX(-80px)}to{opacity:1;transform:none}}
@keyframes scaleIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:none}}
@keyframes countUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 20px rgba(212,165,116,.1)}50%{box-shadow:0 0 40px rgba(212,165,116,.25),0 0 80px rgba(212,165,116,.1)}}
@keyframes rotateBorder{0%{--angle:0deg}100%{--angle:360deg}}
@keyframes typewriter{from{width:0}to{width:100%}}
@keyframes blink{50%{border-color:transparent}}
@keyframes morphBg{0%,100%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}50%{border-radius:30% 60% 70% 40%/50% 60% 30% 60%}}
@keyframes revealLine{from{width:0}to{width:100%}}
@keyframes ripple{0%{transform:scale(1);opacity:1}100%{transform:scale(1.5);opacity:0}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes dashDraw{to{stroke-dashoffset:0}}
@keyframes numberRoll{0%{transform:translateY(100%);opacity:0}100%{transform:translateY(0);opacity:1}}
@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.95)}100%{opacity:1;transform:none}}
@keyframes swoopIn{0%{opacity:0;transform:translateY(40px) rotate(-3deg)}100%{opacity:1;transform:none}}

/* Editorial: solid accent on display text — no animated gradient text */
.gradient-text-dark{color:var(--accent)!important;background:none!important;-webkit-text-fill-color:var(--accent)!important;animation:none!important}
.gradient-text-light{color:var(--accent)!important;background:none!important;-webkit-text-fill-color:var(--accent)!important;animation:none!important}

/* Scroll-triggered entrance — restrained motion (8-12px travel, .35s) */
.fade-in{opacity:0;transform:translateY(8px);transition:opacity .35s ease,transform .35s ease}
.fade-in.visible{opacity:1;transform:none}
.slide-up{opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease}
.slide-up.visible{opacity:1;transform:none}
.slide-left{opacity:0;transform:translateX(12px);transition:opacity .4s ease,transform .4s ease}
.slide-left.visible{opacity:1;transform:none}
.slide-right{opacity:0;transform:translateX(-12px);transition:opacity .4s ease,transform .4s ease}
.slide-right.visible{opacity:1;transform:none}
.scale-in{opacity:0;transform:scale(.98);transition:opacity .35s ease,transform .35s ease}
.scale-in.visible{opacity:1;transform:none}
.blur-in{opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .4s ease}
.blur-in.visible{opacity:1;transform:none}
.bounce-in{opacity:0;transform:scale(.96);transition:opacity .35s ease,transform .35s ease}
.bounce-in.visible{opacity:1;transform:none}
.swoop-in{opacity:0;transform:translateY(10px);transition:opacity .4s ease,transform .4s ease}
.swoop-in.visible{opacity:1;transform:none}

.float-arrow{display:inline-flex}
.pulse-dot{opacity:.85}

/* Shimmer/glow/morph — killed (decorative noise) */
.shimmer-btn{position:relative;overflow:hidden}
.shimmer-btn::after{display:none}
.glow-pulse{box-shadow:none}
.morph-blob{display:none}

/* Counter animation wrapper */
.counter-animate{display:inline-block;animation:countUp .6s cubic-bezier(.16,1,.3,1) both}

/* Reveal line */
.reveal-line{height:2px;background:var(--accent);animation:revealLine 1.5s cubic-bezier(.16,1,.3,1) both}

/* Ripple button effect */
.ripple-btn{position:relative;overflow:hidden}
.ripple-btn::before{content:'';position:absolute;width:100%;height:100%;background:rgba(255,255,255,.1);border-radius:50%;transform:scale(0);transition:transform .6s ease}
.ripple-btn:hover::before{transform:scale(2.5)}

/* Proof section — dashboard mockup */
.proof-dashboard{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden;position:relative}
body.light .proof-dashboard{box-shadow:0 8px 32px rgba(0,0,0,.08)}
body.dark .proof-dashboard{box-shadow:0 8px 32px rgba(0,0,0,.3)}
.proof-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.proof-dot{width:8px;height:8px;border-radius:50%}
.proof-body{padding:28px;display:grid;grid-template-columns:1fr 1fr;gap:20px}
.proof-metric{padding:22px;border-radius:14px;background:var(--bg);border:1px solid var(--border);transition:all .25s}
.proof-metric:hover{transform:translateY(-2px);border-color:var(--border-hover)}
.proof-metric .pm-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-weight:600;margin-bottom:10px}
.proof-metric .pm-value{font-size:32px;font-weight:800;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--text);line-height:1.1}
.proof-metric .pm-change{font-size:12px;color:var(--green);font-weight:600;margin-top:8px}
.proof-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.proof-row:last-child{border-bottom:none}
.proof-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--accent);font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}
.proof-badge{padding:3px 10px;border-radius:12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.proof-badge.booked{background:rgba(167,139,250,.12);color:#A78BFA}
.proof-badge.qualified{background:rgba(52,211,153,.12);color:#34D399}

/* Objection section */
.objection-card{position:relative;padding-left:20px;border-left:3px solid var(--accent)}
.objection-card h4{font-size:16px;font-weight:700;margin:0 0 8px;color:var(--text)}
.objection-card p{font-size:14px;line-height:1.65;color:var(--text-secondary);margin:0}

/* Marquee / social proof bar */
.marquee-wrap{overflow:hidden;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);white-space:nowrap}
.marquee-track{display:inline-flex;gap:48px;flex-wrap:wrap;justify-content:center}
.marquee-track span{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;display:flex;align-items:center;gap:10px}

/* Proprietary system badge */
.system-badge{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--accent-dim),rgba(212,165,116,.02));border:1px solid var(--icon-border);padding:8px 18px;border-radius:24px;font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.03em;text-transform:uppercase}
.system-badge .sys-icon{width:20px;height:20px;border-radius:6px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--accent-text);font-weight:800}

/* Application form styles */
.app-form-disqualifier{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;background:var(--accent-dim);border:1px solid var(--icon-border);font-size:13px;color:var(--text-secondary)}
.app-form-disqualifier .dq-icon{color:var(--accent);font-weight:700;font-size:16px}

/* Trust bar */
.trust-bar{display:flex;align-items:center;justify-content:center;gap:32px;padding:20px 32px;flex-wrap:wrap}
.trust-bar-item{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text-secondary)}
.trust-bar-item .tb-icon{font-size:16px;color:var(--accent)}

/* Partner logo bar */
.partner-bar{display:flex;align-items:center;justify-content:center;gap:36px;padding:28px 32px;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.partner-logo{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;letter-spacing:-.02em;opacity:.35;transition:opacity .3s}
.partner-logo:hover{opacity:.7}
.partner-logo .pl-dot{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff}

/* Comparison table */
.compare-table{width:100%;border-collapse:collapse;font-size:14px}
.compare-table th{padding:16px 20px;text-align:left;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);border-bottom:2px solid var(--border)}
.compare-table th.highlight{color:var(--accent);background:var(--accent-dim)}
.compare-table td{padding:14px 20px;border-bottom:1px solid var(--border);color:var(--text)}
.compare-table td.highlight{background:var(--accent-dim);font-weight:600}
.compare-table tr:last-child td{border-bottom:none}
.compare-table .check-cell{color:var(--green);font-weight:700}
.compare-table .x-cell{color:var(--red);font-weight:600}
.compare-table .meh-cell{color:var(--amber)}

/* For you / Not for you */
.qualify-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:800px;margin:0 auto}
.qualify-col h3{font-size:16px;font-weight:700;margin:0 0 20px;display:flex;align-items:center;gap:8px}
.qualify-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;font-size:14px;line-height:1.5;color:var(--text-secondary)}
.qualify-item .qi-icon{font-size:16px;flex-shrink:0;margin-top:1px}

/* Founder section */
.founder-card{display:flex;align-items:center;gap:24px;max-width:600px;margin:0 auto}
.founder-avatar{width:80px;height:80px;border-radius:20px;background:linear-gradient(135deg,var(--accent-dim),var(--accent-glow));border:2px solid var(--icon-border);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:var(--accent);font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;flex-shrink:0}
.founder-info{text-align:left}
.founder-name{font-size:18px;font-weight:700;color:var(--text);margin:0 0 4px}
.founder-role{font-size:13px;color:var(--text-secondary);margin:0 0 8px}
.founder-bio{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0}

/* ROI calculator */
.roi-calc{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:32px;max-width:560px;margin:0 auto}
body.light .roi-calc{box-shadow:0 4px 16px rgba(0,0,0,.06)}
.roi-input-group{margin-bottom:20px}
.roi-input-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.roi-input-group input[type=range]{width:100%;margin-bottom:4px}

/* ════════════════════════════════════════════════════════════
   CUSTOM RANGE SLIDER — replaces the chunky native browser default.
   Track: thin dark capsule with an accent-gradient fill that follows
   the thumb. Thumb: solid accent circle with a soft glow on hover.
   Cross-browser: Webkit (Chrome/Safari/Edge) + Firefox pseudo-elements.
   Sets via the --pct CSS variable that the inline JS updates on input. */
input[type=range]{
  -webkit-appearance:none;appearance:none;
  width:100%;height:32px;background:transparent;cursor:pointer;
  font-family:inherit;
  --pct:50%;
}
/* Track */
input[type=range]::-webkit-slider-runnable-track{
  height:6px;border-radius:999px;
  background:linear-gradient(to right,
    var(--accent) 0%, var(--accent) var(--pct),
    rgba(255,255,255,.08) var(--pct), rgba(255,255,255,.08) 100%);
  border:1px solid rgba(255,255,255,.04);
}
input[type=range]::-moz-range-track{
  height:6px;border-radius:999px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.04);
}
input[type=range]::-moz-range-progress{
  height:6px;border-radius:999px;background:var(--accent);
}
/* Thumb */
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:20px;height:20px;border-radius:50%;
  background:#fff;border:none;
  margin-top:-7px;cursor:grab;
  box-shadow:0 0 0 4px var(--accent),0 4px 14px rgba(212,165,116,.45);
  transition:transform .15s ease,box-shadow .15s ease;
}
input[type=range]::-moz-range-thumb{
  width:20px;height:20px;border-radius:50%;
  background:#fff;border:none;cursor:grab;
  box-shadow:0 0 0 4px var(--accent),0 4px 14px rgba(212,165,116,.45);
  transition:transform .15s ease,box-shadow .15s ease;
}
input[type=range]:hover::-webkit-slider-thumb,
input[type=range]:focus::-webkit-slider-thumb{
  transform:scale(1.12);
  box-shadow:0 0 0 4px var(--accent),0 0 24px rgba(212,165,116,.6),0 6px 20px rgba(212,165,116,.55);
}
input[type=range]:hover::-moz-range-thumb,
input[type=range]:focus::-moz-range-thumb{
  transform:scale(1.12);
  box-shadow:0 0 0 4px var(--accent),0 0 24px rgba(212,165,116,.6),0 6px 20px rgba(212,165,116,.55);
}
input[type=range]:active::-webkit-slider-thumb{cursor:grabbing;transform:scale(1.06)}
input[type=range]:active::-moz-range-thumb{cursor:grabbing;transform:scale(1.06)}
input[type=range]:focus-visible{outline:none}

/* Light-theme tweak */
body.light input[type=range]::-webkit-slider-runnable-track{
  background:linear-gradient(to right,
    var(--accent) 0%, var(--accent) var(--pct),
    rgba(0,0,0,.08) var(--pct), rgba(0,0,0,.08) 100%);
}
body.light input[type=range]::-moz-range-track{background:rgba(0,0,0,.08)}
.roi-input-group .roi-value{font-size:24px;font-weight:800;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--accent)}
.roi-result{background:var(--accent-dim);border:1px solid var(--icon-border);border-radius:12px;padding:20px;text-align:center;margin-top:24px}
.roi-result .roi-big{font-size:36px;font-weight:800;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--accent)}
.roi-result .roi-label{font-size:13px;color:var(--text-secondary);margin-top:4px}

/* Annual toggle */
.pricing-toggle{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:32px}
.pricing-toggle span{font-size:14px;font-weight:500;color:var(--text-secondary);transition:color .3s}
.pricing-toggle span.active{color:var(--text);font-weight:600}
.pricing-toggle .toggle-track{width:48px;height:26px;border-radius:13px;background:var(--border);cursor:pointer;position:relative;transition:background .3s}
.pricing-toggle .toggle-track.on{background:var(--accent)}
.pricing-toggle .toggle-knob{width:20px;height:20px;border-radius:50%;background:#fff;position:absolute;top:3px;left:3px;transition:left .3s cubic-bezier(.34,1.56,.64,1)}
.pricing-toggle .toggle-track.on .toggle-knob{left:25px}
.pricing-save{background:rgba(52,211,153,.1);color:var(--green);padding:3px 10px;border-radius:10px;font-size:11px;font-weight:700;margin-left:4px}

/* Sticky CTA */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:90;padding:12px 32px;background:var(--bg-nav);backdrop-filter:blur(16px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:center;gap:16px;transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.sticky-cta.visible{transform:none}
.sticky-cta p{font-size:14px;font-weight:500;color:var(--text);margin:0}
.sticky-cta .sticky-btn{background:var(--accent-bg);color:var(--accent-text);border:none;padding:10px 24px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Inter Tight',sans-serif;white-space:nowrap}

/* Exit intent popup */
.exit-popup{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}
.exit-popup.visible{opacity:1;pointer-events:auto}
.exit-popup-inner{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;padding:40px;max-width:480px;width:100%;text-align:center;transform:translateY(20px) scale(.95);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.exit-popup.visible .exit-popup-inner{transform:none}
body.light .exit-popup-inner{box-shadow:0 24px 64px rgba(0,0,0,.15)}
body.dark .exit-popup-inner{box-shadow:0 24px 64px rgba(0,0,0,.5)}
.exit-popup-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer}

/* Industry cards */
.industry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.industry-card{padding:20px;border-radius:12px;background:var(--bg-card);border:1px solid var(--border);text-align:center;transition:transform .3s,border-color .3s}
body.light .industry-card{box-shadow:0 1px 3px rgba(0,0,0,.04)}
.industry-card:hover{transform:translateY(-3px);border-color:var(--accent)}
.industry-card .ic-icon{font-size:28px;margin-bottom:10px}
.industry-card .ic-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}
.industry-card .ic-result{font-size:12px;color:var(--text-secondary)}

/* Guarantee shield */
.guarantee-shield{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,rgba(52,211,153,.15),rgba(52,211,153,.05));border:2px solid rgba(52,211,153,.3);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 20px}

/* ═══ GLOW CARDS ═══ */
.glow-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;position:relative;overflow:hidden;transition:border-color .3s ease,transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s ease}
body.light .glow-card{box-shadow:0 1px 3px rgba(0,0,0,.04)}
.glow-card:hover{border-color:var(--border-hover);transform:translateY(-3px);box-shadow:0 12px 40px var(--glow1)}
.glow-card.no-hover:hover{transform:none;box-shadow:none}
body.light .glow-card.no-hover:hover{box-shadow:0 1px 3px rgba(0,0,0,.04)}

/* ═══ STATUS BADGES ═══ */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.badge .dot{width:5px;height:5px;border-radius:50%}
.badge-new{background:var(--badge-new-bg);color:var(--badge-new-c)}.badge-new .dot{background:var(--badge-new-c)}
.badge-contacted{background:var(--badge-contacted-bg);color:var(--badge-contacted-c)}.badge-contacted .dot{background:var(--badge-contacted-c)}
.badge-qualified{background:var(--badge-qualified-bg);color:var(--badge-qualified-c)}.badge-qualified .dot{background:var(--badge-qualified-c)}
.badge-booked{background:var(--badge-booked-bg);color:var(--badge-booked-c)}.badge-booked .dot{background:var(--badge-booked-c)}
.badge-closed{background:var(--badge-closed-bg);color:var(--badge-closed-c)}.badge-closed .dot{background:var(--badge-closed-c)}
.badge-confirmed{background:var(--badge-confirmed-bg);color:var(--badge-confirmed-c)}.badge-confirmed .dot{background:var(--badge-confirmed-c)}
.badge-pending{background:var(--badge-pending-bg);color:var(--badge-pending-c)}.badge-pending .dot{background:var(--badge-pending-c)}
.badge-succeeded{background:var(--badge-succeeded-bg);color:var(--badge-succeeded-c)}.badge-succeeded .dot{background:var(--badge-succeeded-c)}
.badge-refunded{background:var(--badge-refunded-bg);color:var(--badge-refunded-c)}.badge-refunded .dot{background:var(--badge-refunded-c)}

/* ═══ METRIC CARDS ═══ */
.metric-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:22px;position:relative;overflow:hidden;transition:all .3s ease;flex:1;min-width:0}
body.light .metric-card{box-shadow:0 1px 3px rgba(0,0,0,.04)}
.metric-card .glow{position:absolute;top:-10px;right:-10px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow),transparent);pointer-events:none}
.metric-label{font-size:11px;color:var(--text-secondary);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}
.metric-value{font-size:30px;font-weight:700;color:var(--text);letter-spacing:-.03em;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}
.metric-change{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;padding:2px 8px;border-radius:10px}
.metric-change.up{color:var(--green);background:rgba(52,211,153,.1)}
.metric-change.down{color:var(--red);background:rgba(248,113,113,.1)}

/* ═══ THEME TOGGLE ═══ */
.theme-toggle{width:48px;height:26px;border-radius:13px;border:none;cursor:pointer;position:relative;transition:background .4s ease}
body.dark .theme-toggle{background:rgba(212,165,116,.15)}
body.light .theme-toggle{background:rgba(160,107,58,.12)}
.theme-toggle .knob{width:20px;height:20px;border-radius:50%;position:absolute;top:3px;transition:left .4s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;font-size:11px}
body.dark .theme-toggle .knob{left:25px;background:#D4A574}
body.light .theme-toggle .knob{left:3px;background:#A06B3A;color:#fff}

/* ═══ LAYOUT ═══ */
.landing-page{color:var(--text);background:var(--bg);min-height:100vh;transition:background .5s ease,color .5s ease}
.nav{position:sticky;top:0;z-index:100;background:var(--bg-nav);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);padding:0 32px;transition:all .5s ease}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px}
/* Setorra mark — full-color SVG renders the blue gradient natively. The
   inner <span>S</span> is hidden but kept for accessibility/no-CSS fallback. */
.logo-mark{width:32px;height:32px;border-radius:8px;background:url('/assets/setorra-mark.png') center/contain no-repeat;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.logo-mark span{display:none}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500}
.mobile-menu-btn{display:none;background:none;border:none;color:var(--text);font-size:24px;cursor:pointer;padding:4px}
.nav-mobile-actions{display:none;align-items:center;gap:8px}
.mobile-portal-btn{display:none;padding:8px 16px!important;font-size:13px!important;border-radius:8px!important}
.desktop-portal-btn{display:inline-flex}

/* Mobile bottom nav for app */
.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--bg-nav);backdrop-filter:blur(16px);border-top:1px solid var(--border);padding:6px 8px calc(6px + env(safe-area-inset-bottom));justify-content:space-around;align-items:center}
.mobile-bottom-nav button{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:6px 12px;border-radius:8px;font-family:inherit;transition:color .2s}
.mobile-bottom-nav button.active{color:var(--accent)}
.mobile-nav-label{font-size:10px;font-weight:600;letter-spacing:.02em}
.btn-primary{background:var(--accent-bg);color:var(--accent-text);border:1px solid rgba(0,0,0,.12);padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;letter-spacing:-.005em;cursor:pointer;font-family:'Inter Tight',sans-serif;transition:transform .15s ease,filter .15s ease}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn-primary:active{transform:translateY(0)}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border);padding:14px 28px;border-radius:8px;font-size:15px;font-weight:500;letter-spacing:-.005em;cursor:pointer;font-family:'Inter Tight',sans-serif;transition:border-color .18s ease,color .18s ease}
.btn-outline:hover{border-color:var(--text);color:var(--text)}
/* Ghost / secondary button — replaces the default-styled white box that
   was rendering on dark cards. Used on Apply for Role, Pipeline action
   bar, blog back-links, and similar utility CTAs. */
.btn-secondary{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.03);
  color:var(--text);
  border:1px solid var(--border);
  padding:9px 16px;border-radius:8px;
  font-family:'Inter Tight',sans-serif;font-size:13px;font-weight:500;letter-spacing:-.005em;
  cursor:pointer;
  transition:border-color .18s ease,background .18s ease,color .18s ease,transform .12s ease;
}
.btn-secondary:hover{
  border-color:var(--accent);
  background:var(--accent-dim);
  color:var(--accent);
  transform:translateY(-1px);
}
.btn-secondary:active{transform:translateY(0)}
.btn-secondary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
body.light .btn-secondary{background:rgba(0,0,0,.02)}
.section{max-width:1200px;margin:0 auto;padding:80px 32px}
/* Section eyebrow — editorial style: "§ 01 / HOW WE WORK"
   The "§ 01" prefix auto-numbers via a CSS counter scoped at .landing-page.
   Followed by a hairline to anchor the title block. */
.landing-page{counter-reset:setorra-sec}
.section{counter-increment:setorra-sec;position:relative}
.section-tag{display:inline-flex;align-items:baseline;gap:14px;background:transparent;padding:0;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;margin-bottom:22px;color:var(--accent)}
.section-tag::before{content:"§ " counter(setorra-sec, decimal-leading-zero);color:var(--accent);font-variant-numeric:tabular-nums;font-weight:500;letter-spacing:.04em}
.section-tag::after{content:"";display:inline-block;width:40px;height:1px;background:var(--accent);opacity:.5;align-self:center}
/* Editorial section divider — hairline rule above titles, spans full content width */
.section > .section-tag:first-child{position:relative}
.section > .section-tag:first-child::before{position:relative}
.section-title{font-size:clamp(28px,3.6vw,44px);font-weight:600;letter-spacing:-.025em;line-height:1.05;margin:0 0 48px;color:var(--text)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.hero-section{max-width:1200px;margin:0 auto;padding:100px 32px 80px;position:relative;overflow:hidden}
.hero-title{font-size:clamp(36px,6.4vw,80px);font-weight:600;line-height:1.02;letter-spacing:-.035em;margin:0 0 24px;max-width:880px;position:relative;z-index:1;color:var(--text)}
.hero-sub{font-size:17px;line-height:1.55;color:var(--text-secondary);max-width:560px;margin:0 0 40px;font-weight:400;letter-spacing:-.005em}
.stat-value{font-size:36px;font-weight:800;letter-spacing:-.03em;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--accent)}
.stat-label{font-size:13px;color:var(--text-secondary);margin-top:6px;font-weight:500}
.step-number{position:absolute;top:16px;right:18px;font-size:56px;font-weight:800;color:var(--text-muted);opacity:.25;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}
.step-icon{width:52px;height:52px;border-radius:14px;background:var(--accent-dim);border:1px solid var(--icon-border);display:flex;align-items:center;justify-content:center;margin-bottom:24px;font-size:22px}
.testimonial-metric{font-size:52px;font-weight:800;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;margin-bottom:16px;line-height:1;color:var(--accent)}
/* Glow orbs killed — they were the loudest "AI-template" tell */
.glow-orb,.glow-orb-1,.glow-orb-2{display:none!important}

/* ═══ PARTICLE CANVAS — hidden, particles read as decorative noise ═══ */
#particle-canvas{display:none!important}

/* ═══ PRICING ═══ */
.setup-fee-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:32px;margin-bottom:40px;text-align:center}
body.light .setup-fee-card{box-shadow:0 1px 4px rgba(0,0,0,.06)}
.setup-fee-card h3{font-size:22px;font-weight:700;margin:0 0 8px;color:var(--text)}
.setup-fee-card .price{font-size:36px;font-weight:800;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--accent);margin:16px 0 8px}
.setup-fee-includes{display:flex;justify-content:center;gap:24px;margin-top:20px;flex-wrap:wrap}
.setup-fee-includes span{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}
.setup-fee-includes .check{color:var(--green);font-weight:700}

.plan-card{display:flex;flex-direction:column;padding:0!important;overflow:hidden;transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s ease,border-color .3s}
.plan-card.recommended{border:2px solid var(--popular-border);transform:scale(1.03)}
body.light .plan-card{box-shadow:0 1px 4px rgba(0,0,0,.06)}
.plan-card.recommended:hover{transform:scale(1.05)}
.plan-recommended-tag{background:var(--popular-bg);padding:10px;text-align:center;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--popular-c)}
.plan-best-tag{background:var(--best-bg);padding:8px;text-align:center;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--green)}
.plan-body{padding:28px 28px 0;flex:1;display:flex;flex-direction:column}
.plan-price{font-size:44px;font-weight:800;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:-.04em;color:var(--text)}
.plan-price.sub{font-size:48px}
.plan-period{font-size:16px;font-weight:500;color:var(--text-secondary)}
.plan-features{border-top:1px solid var(--border);padding-top:20px;margin-bottom:24px;flex:1}
.plan-feature{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;font-size:13px;color:var(--text)}
.plan-feature .check{color:var(--green);font-size:14px;flex-shrink:0;margin-top:1px}
.plan-cta{padding:0 28px 28px}
.plan-cta button{width:100%;padding:14px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;font-family:'Inter Tight',sans-serif;transition:all .2s ease}
.plan-cta .primary{background:var(--accent-bg);color:var(--accent-text);border:none}
body.dark .plan-cta .primary{box-shadow:0 1px 2px rgba(0,0,0,.4)}
body.light .plan-cta .primary{box-shadow:0 4px 16px rgba(160,107,58,.15)}
.plan-cta .outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}
.pricing-note{text-align:center;margin-top:40px;padding:24px;border-radius:16px;background:var(--bg-card);border:1px solid var(--border)}
body.light .pricing-note{box-shadow:0 1px 3px rgba(0,0,0,.04)}
.pricing-note p{font-size:15px;color:var(--text-secondary);margin:0;line-height:1.6}

/* ═══ CTA SECTION ═══ */
.cta-section{max-width:1200px;margin:0 auto;padding:100px 32px;text-align:center}
.cta-title{font-size:clamp(32px,4.2vw,52px);font-weight:600;letter-spacing:-.03em;line-height:1.05;margin:0 0 20px;color:var(--text)}
.cta-sub{font-size:17px;line-height:1.55;color:var(--text-secondary);margin:0 auto 36px;max-width:520px}
.cta-btn{background:var(--accent-bg);color:var(--accent-text);border:1px solid rgba(0,0,0,.14);padding:16px 36px;border-radius:10px;font-size:16px;font-weight:600;letter-spacing:-.005em;cursor:pointer;font-family:'Inter Tight',sans-serif;display:inline-flex;align-items:center;gap:10px;transition:transform .15s ease,filter .15s ease}
.cta-btn:hover{transform:translateY(-1px);filter:brightness(1.04)}
body.dark .cta-btn{box-shadow:0 1px 0 rgba(255,255,255,.12) inset,0 2px 8px rgba(0,0,0,.4)}
body.light .cta-btn{box-shadow:0 4px 24px rgba(160,107,58,.2)}

/* ═══ APP SHELL ═══ */
.app-shell{display:flex;height:100vh;background:var(--bg);color:var(--text);overflow:hidden;transition:background .5s ease,color .5s ease;font-family:'Inter Tight',sans-serif}
.sidebar{background:var(--sidebar);color:#fff;display:flex;flex-direction:column;flex-shrink:0;transition:width .3s cubic-bezier(.16,1,.3,1);overflow:hidden}
.sidebar.expanded{width:230px}
.sidebar.collapsed{width:64px}
.sidebar-header{padding:20px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.05)}
/* Sidebar mark — same real-color PNG as the public nav so the brand stays
   consistent inside the authenticated portal. The inner <span>S</span> stays
   as a no-CSS fallback but is hidden visually. */
.sidebar-logo{width:32px;height:32px;border-radius:8px;background:url('/assets/setorra-mark.png') center/contain no-repeat;flex-shrink:0;overflow:hidden}
.sidebar-logo span{display:none}
.sidebar-brand{font-size:18px;font-weight:700;letter-spacing:-.02em;white-space:nowrap}
.sidebar-nav{padding:16px 10px;flex:1}
.sidebar-nav button{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;color:rgba(255,255,255,.4);border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:500;margin-bottom:4px;text-align:left;white-space:nowrap;font-family:'Inter Tight',sans-serif;transition:all .25s ease;position:relative}
.sidebar-nav button:hover{background:rgba(255,255,255,.04);color:rgba(255,255,255,.85)}
.sidebar-nav button.active{background:rgba(212,165,116,.08);color:#D4A574}
.sidebar-nav button.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:2px;height:18px;border-radius:0 2px 2px 0;background:#D4A574}
.sidebar-nav button .icon{font-size:16px;width:20px;text-align:center}
.sidebar-footer{padding:16px 10px;border-top:1px solid rgba(255,255,255,.05)}
.sidebar-footer button{width:100%;background:transparent;border:none;color:rgba(255,255,255,.3);cursor:pointer;padding:8px;font-size:14px;font-family:'Inter Tight',sans-serif}
.topbar{padding:14px 32px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:var(--bg-nav);backdrop-filter:blur(16px);position:sticky;top:0;z-index:10}
.topbar-back{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:13px;font-family:'Inter Tight',sans-serif}
.topbar-right{display:flex;align-items:center;gap:16px}
.user-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}
body.dark .user-avatar{background:rgba(212,165,116,.08);border:1px solid rgba(212,165,116,.15);color:#D4A574}
body.light .user-avatar{background:rgba(160,107,58,.06);border:1px solid rgba(160,107,58,.12);color:#A06B3A}
.page-content{padding:32px}
.page-title{font-size:26px;font-weight:600;letter-spacing:-.025em;line-height:1.15;margin:0 0 4px;color:var(--text)}
.page-subtitle{color:var(--text-secondary);font-size:14px;letter-spacing:-.005em;margin:0}

/* ═══ TABLES ═══ */
.data-table{width:100%;border-collapse:collapse;font-size:14px}
.data-table th{text-align:left;padding:14px 20px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}
.data-table td{padding:14px 20px;border-bottom:1px solid var(--border)}
.data-table tbody tr{transition:background .2s;cursor:pointer}
.data-table tbody tr:hover{background:var(--bg-card-hover)}
.avatar-sm{width:32px;height:32px;border-radius:50%;background:var(--connect-avatar-bg);color:var(--connect-avatar-c);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}
.avatar-md{width:36px;height:36px;border-radius:50%;background:var(--connect-avatar-bg);color:var(--connect-avatar-c);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}
.score-bar{width:48px;height:4px;border-radius:2px;background:var(--grid-line);overflow:hidden}
.score-fill{height:100%;border-radius:2px;transition:width 1s cubic-bezier(.16,1,.3,1)}
.mono{font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}

/* ═══ FILTERS ═══ */
.filter-bar{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.filter-btn{padding:7px 18px;border-radius:20px;border:1px solid var(--border);font-size:12px;font-weight:600;cursor:pointer;text-transform:capitalize;background:transparent;color:var(--text-secondary);font-family:'Inter Tight',sans-serif;transition:all .25s}
.filter-btn.active{background:var(--accent-bg);color:var(--accent-text);border-color:var(--accent-bg)}

/* ═══ CONNECT PANEL ═══ */
.connect-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px;margin-bottom:24px}
.connect-input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-size:14px;outline:none;background:var(--bg-surface);color:var(--text);font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;min-width:0}
.connect-tags button{padding:8px 16px;border-radius:10px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;font-family:'Inter Tight',sans-serif;transition:all .2s}

/* ═══ CALENDAR ═══ */
.calendar-grid{display:grid;grid-template-columns:60px repeat(7,1fr)}
.calendar-header{padding:14px 8px;text-align:center;font-size:12px;font-weight:600;color:var(--text-secondary)}
.calendar-header.today{color:var(--accent);background:var(--accent-dim);border-bottom:2px solid var(--accent)}
.calendar-hour{padding:8px;font-size:11px;color:var(--text-muted);text-align:right;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}
.calendar-cell{padding:4px;border-left:1px solid var(--grid-line)}
.calendar-cell.today-col{background:var(--accent-dim)}
.appt-block{border-radius:8px;padding:6px 8px;font-size:11px;border-left:3px solid}
.appt-block.confirmed{border-left-color:var(--green)}
body.dark .appt-block.confirmed{background:rgba(52,211,153,.1)}
body.light .appt-block.confirmed{background:#E1F5EE}
.appt-block.pending{border-left-color:var(--amber)}
body.dark .appt-block.pending{background:rgba(251,191,36,.1)}
body.light .appt-block.pending{background:#FAEEDA}
.appt-name{font-weight:600;color:var(--text)}
.appt-type{color:var(--text-secondary);margin-top:2px}
.list-row{display:flex;align-items:center;gap:16px;padding:18px 24px;border-bottom:1px solid var(--border);transition:background .2s}
.list-row:hover{background:var(--bg-card-hover)}
.status-bar{width:4px;height:44px;border-radius:2px}
.status-bar.confirmed{background:var(--green)}
.status-bar.pending{background:var(--amber)}

/* ═══ REVENUE ═══ */
.chart-container{display:flex;align-items:flex-end;gap:16px;height:220px;padding:0 8px}
.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px}
.chart-label{font-size:12px;font-weight:600;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--text)}
.chart-bar{width:100%;max-width:56px;border-radius:8px 8px 4px 4px;position:relative;overflow:hidden;transition:height 1s cubic-bezier(.16,1,.3,1)}
.chart-bar.muted{background:var(--chart-bar-muted)}
body.dark .chart-bar.current{background:linear-gradient(180deg,#D4A574,#A06B3A)}
body.light .chart-bar.current{background:linear-gradient(180deg,#A06B3A,#1A3FCC)}
.chart-month{font-size:12px;color:var(--text-secondary);font-weight:500}
.scanline{display:none}
.scanline::after{display:none}

/* ═══ STRIPE CONNECT ═══ */
.stripe-panel{background:var(--bg-card);border:1.5px solid rgba(99,91,255,.25);border-radius:16px;padding:24px;margin-bottom:24px}
.stripe-icon{width:44px;height:44px;background:rgba(99,91,255,.1);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#635BFF;font-size:20px;font-weight:700}
.stripe-btn{background:#635BFF;color:#fff;border:none;padding:10px 24px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Inter Tight',sans-serif}
.stripe-connect-btn{background:rgba(99,91,255,.1);color:#635BFF;border:1px solid rgba(99,91,255,.2);padding:10px 20px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Inter Tight',sans-serif;display:flex;align-items:center;gap:8px;transition:all .2s}

/* ═══ SETTINGS ═══ */
.integration-card{padding:20px 24px!important;display:flex;align-items:center;justify-content:space-between}
.integration-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}
.integration-btn{padding:8px 22px;border-radius:10px;border:1px solid;font-size:12px;font-weight:600;cursor:pointer;font-family:'Inter Tight',sans-serif;transition:all .2s}
.integration-btn.connected{color:var(--green);border-color:var(--green)}
body.dark .integration-btn.connected{background:rgba(52,211,153,.1);border-color:rgba(52,211,153,.3)}
body.light .integration-btn.connected{background:#E1F5EE;border-color:#5DCAA5}
.integration-btn.disconnected{background:transparent;color:var(--text-secondary);border-color:var(--border)}

/* ═══ CONTACT MODAL ═══ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:8vh 20px 20px;overflow-y:auto;opacity:0;transition:opacity .3s ease}
.modal-overlay.visible{opacity:1}
.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;padding:36px;max-width:440px;width:100%;position:relative;transform:translateY(20px);transition:transform .3s cubic-bezier(.16,1,.3,1)}
.modal-overlay.visible .modal{transform:none}
body.light .modal{box-shadow:0 20px 60px rgba(0,0,0,.12)}
body.dark .modal{box-shadow:0 20px 60px rgba(0,0,0,.4)}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .2s}
.modal-close:hover{color:var(--text)}
.modal h2{font-size:22px;font-weight:700;margin:0 0 6px;color:var(--text)}
.modal p{font-size:14px;color:var(--text-secondary);margin:0 0 24px;line-height:1.5}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.form-group input,.form-group select{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-size:14px;background:var(--bg);color:var(--text);font-family:'Inter Tight',sans-serif;outline:none;transition:border-color .2s}
.form-group input:focus,.form-group select:focus{border-color:var(--accent)}
.form-group select{appearance:none;cursor:pointer}
.form-submit{width:100%;padding:14px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;font-family:'Inter Tight',sans-serif;background:var(--accent-bg);color:var(--accent-text);border:none;margin-top:8px;transition:transform .2s}
.form-submit:hover{transform:scale(1.02)}
.form-success{text-align:center;padding:20px 0}
.form-success .check-circle{width:56px;height:56px;border-radius:50%;background:rgba(52,211,153,.1);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px}

/* ═══ FAQ ═══ */
.faq-answer{transition:margin .3s ease,max-height .3s ease}
.faq-answer.hidden{display:none;margin-top:0!important}

/* ═══ SPLASH SCREEN — editorial / restrained ═══
   The splash is the first impression. Refined: dot grid texture, a
   single accent mark, a quiet wordmark, monospace metadata strips
   at top-left + top-right (registration marks), and a tiny "Enter"
   link instead of a glowy button. */
.splash{position:fixed;inset:0;background:#0A0A0B;color:#EDEDED;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;overflow:hidden}
.splash-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
/* Subtle dot grid — feels like printer registration, not "tech glow" */
.splash-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.045) 1px,transparent 1px);background-size:32px 32px;background-position:0 0;opacity:.85}
/* Orbs neutralized (replaced by a single faint warm wash from top-right) */
.splash-orb,.splash-orb-1,.splash-orb-2,.splash-orb-3{display:none!important}
/* Top metadata bar — left: edition, right: location/date. Pure registration. */
.splash-bg::before{
  content:"SETORRA — VOL. 01 / B2B OUTBOUND";
  position:absolute;top:24px;left:32px;
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10px;letter-spacing:.18em;color:rgba(255,255,255,.34);
  opacity:0;animation:splashFadeIn .6s ease .15s forwards;
}
.splash-bg::after{
  content:"SANFORD, FL — EST. 2026";
  position:absolute;top:24px;right:32px;
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10px;letter-spacing:.18em;color:rgba(255,255,255,.34);
  opacity:0;animation:splashFadeIn .6s ease .25s forwards;
}
/* Bottom-left run marks: page count + ISSN-style code */
.splash::before{
  content:"§01 / LEAD GENERATION / 2026";
  position:absolute;bottom:24px;left:32px;
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10px;letter-spacing:.18em;color:rgba(255,255,255,.24);
  opacity:0;animation:splashFadeIn .6s ease .5s forwards;
  z-index:3;
}
.splash::after{
  content:"PRESS ENTER →";
  position:absolute;bottom:24px;right:32px;
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10px;letter-spacing:.18em;color:rgba(255,255,255,.42);
  opacity:0;animation:splashFadeIn .6s ease .8s forwards;
  z-index:3;
}
@keyframes splashFadeIn{from{opacity:0}to{opacity:1}}

.splash-content{position:relative;z-index:2;text-align:center;max-width:800px;padding:0 32px;display:flex;flex-direction:column;align-items:center}
/* Mark: smaller, refined, no glow */
.splash-logo{width:64px;height:64px;background:url('/assets/setorra-mark.png') center/contain no-repeat;margin:0 0 32px;opacity:0;animation:splashFadeIn .5s ease .2s forwards;filter:none}
/* Wordmark: SETORRA in solid accent, tight kerning */
.splash-title{font-size:clamp(56px,9vw,108px);font-weight:600;letter-spacing:-.04em;line-height:.92;margin:0 0 18px;color:#EDEDED;opacity:0;animation:splashFadeIn .5s ease .35s forwards}
.splash-title span{display:block;background:none;-webkit-text-fill-color:#D4A574;color:#D4A574;animation:none}
/* Subtitle: thin hairline + small caps, one line */
.splash-sub{position:relative;font-size:11px;color:rgba(255,255,255,.55);font-weight:500;letter-spacing:.24em;text-transform:uppercase;margin:0 0 48px;padding:0 56px;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;opacity:0;animation:splashFadeIn .5s ease .55s forwards}
.splash-sub::before,.splash-sub::after{content:"";position:absolute;top:50%;width:40px;height:1px;background:rgba(255,255,255,.18)}
.splash-sub::before{left:0}.splash-sub::after{right:0}
.splash-cta{opacity:0;animation:splashFadeIn .5s ease .75s forwards}
/* Button: hairline outline, no fill, no shimmer */
.splash-btn{background:transparent;color:#EDEDED;border:1px solid rgba(255,255,255,.22);padding:14px 42px;border-radius:0;font-size:13px;font-weight:500;cursor:pointer;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.16em;text-transform:uppercase;position:relative;overflow:hidden;transition:border-color .2s ease,color .2s ease,background .2s ease}
.splash-btn:hover{border-color:#D4A574;color:#D4A574;background:rgba(212,165,116,.04);transform:none;box-shadow:none}
.splash-btn::after{display:none}
.splash-btn .arrow{display:inline-flex;margin-left:10px;animation:none;transition:transform .2s ease}
.splash-btn:hover .arrow{transform:translateX(3px)}

/* Stats: monospaced, ledger-row spacing, hairline between */
.splash-stats{display:flex;gap:0;justify-content:center;margin-top:56px;opacity:0;animation:splashFadeIn .5s ease .95s forwards;border-top:1px solid rgba(255,255,255,.12);padding-top:24px}
.splash-stat{text-align:left;padding:0 32px;border-right:1px solid rgba(255,255,255,.08)}
.splash-stat:last-child{border-right:none}
.splash-stat-value{font-size:22px;font-weight:500;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;color:#D4A574;margin-bottom:6px;letter-spacing:-.01em}
.splash-stat-label{font-size:9px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.16em;font-weight:500;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}

.splash-particles{display:none}

/* Splash exit animation — gentle fade, no scale */
.splash.exit{animation:splashExit .45s ease forwards}
@keyframes splashExit{0%{opacity:1}100%{opacity:0}}

/* Mobile splash adjustments */
@media(max-width:640px){
  .splash-bg::before,.splash-bg::after,.splash::before,.splash::after{font-size:9px;top:16px;bottom:16px;left:16px;right:16px;letter-spacing:.14em}
  .splash-sub{padding:0 32px;letter-spacing:.18em}
  .splash-sub::before,.splash-sub::after{width:20px}
  .splash-stats{gap:0;flex-wrap:wrap;justify-content:space-around;padding-top:16px;margin-top:36px}
  .splash-stat{padding:8px 18px;border-right:none;text-align:center}
}

/* Pipeline status indicator */
.engine-status{display:flex;align-items:center;gap:10px;padding:10px 20px;border-radius:12px;background:var(--bg-card);border:1px solid var(--border);margin-bottom:24px}
.engine-status .status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.engine-status .status-dot.running{background:#34D399;box-shadow:0 0 12px rgba(52,211,153,.4);animation:pulse 2s ease-in-out infinite}
.engine-status .status-dot.paused{background:var(--amber)}
.engine-status .status-dot.offline{background:var(--red)}
.engine-status .status-text{font-size:13px;font-weight:600;color:var(--text)}
.engine-status .status-sub{font-size:11px;color:var(--text-secondary)}

/* Notification feed */
.notif-feed{max-height:320px;overflow-y:auto;scrollbar-width:thin}
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);transition:background .2s}
.notif-item:last-child{border-bottom:none}
.notif-icon{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.notif-icon.lead{background:rgba(212,165,116,.1);color:#D4A574}
.notif-icon.booking{background:rgba(52,211,153,.1);color:#34D399}
.notif-icon.score{background:rgba(167,139,250,.1);color:#A78BFA}
.notif-icon.reply{background:rgba(251,191,36,.1);color:#FBBF24}
.notif-icon.system{background:rgba(248,113,113,.1);color:#F87171}
.notif-text{font-size:13px;color:var(--text);line-height:1.4}
.notif-text strong{font-weight:600}
.notif-time{font-size:11px;color:var(--text-muted);margin-top:2px;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace}

/* ═══ AUTH PAGE ═══ */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg)}
.auth-card{width:100%;max-width:420px;background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;padding:40px;text-align:center}
body.light .auth-card{box-shadow:0 8px 32px rgba(0,0,0,.08)}
body.dark .auth-card{box-shadow:0 8px 32px rgba(0,0,0,.4)}
.auth-header{margin-bottom:28px}
.auth-title{font-size:24px;font-weight:800;margin:0 0 8px;color:var(--text);letter-spacing:-.03em}
.auth-subtitle{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}
.auth-form{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}
.auth-form .form-group{text-align:left}
.auth-form .form-group label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}
.auth-form .form-group input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:10px;background:var(--bg-card);color:var(--text);font-size:14px;font-family:inherit;transition:border-color .2s;box-sizing:border-box}
.auth-form .form-group input:focus{outline:none;border-color:var(--accent)}
.auth-submit{width:100%;padding:14px;background:var(--accent-bg);color:var(--accent-text);border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .2s}
.auth-submit:hover{opacity:.9}
.auth-submit:disabled{opacity:.5;cursor:not-allowed}
.auth-error{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.2);color:#F87171;padding:10px 14px;border-radius:10px;font-size:13px;margin-bottom:16px;text-align:left}
.auth-link{background:none;border:none;color:var(--accent);font-size:13px;cursor:pointer;font-family:inherit;font-weight:500;padding:0}
.auth-link:hover{text-decoration:underline}
.auth-footer{font-size:13px;color:var(--text-secondary);padding-top:16px;border-top:1px solid var(--border)}
.auth-back{background:none;border:none;color:var(--text-secondary);font-size:13px;cursor:pointer;font-family:inherit;margin-top:16px;padding:0}
.auth-back:hover{color:var(--text)}
.logout-btn{background:none;border:1px solid var(--border);color:var(--text-secondary);padding:6px 14px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:border-color .2s,color .2s}
.logout-btn:hover{border-color:var(--text);color:var(--text)}
.signin-topbar-btn{background:none;border:1px solid var(--accent);color:var(--accent);padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .2s,color .2s}
.signin-topbar-btn:hover{background:var(--accent-bg);color:var(--accent-text)}
.demo-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 20px;background:rgba(212,165,116,.08);border:1px solid rgba(212,165,116,.2);border-radius:12px;margin-bottom:16px;flex-wrap:wrap}
.demo-banner span{font-size:13px;color:var(--text-secondary)}
.demo-banner button{background:var(--accent-bg);color:var(--accent-text);border:none;padding:6px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap}
.nav-signin-btn{padding:8px 16px!important;font-size:13px!important;border-radius:8px!important}

/* ═══ FOOTER ═══ */
.footer{border-top:1px solid var(--border);padding:32px;text-align:center;font-size:13px;color:var(--text-secondary)}

/* ═══ UTILITIES ═══ */
.hidden{display:none!important}
.flex{display:flex}.items-center{align-items:center}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-14{gap:14px}.gap-16{gap:16px}
.flex-1{flex:1}.min-w-0{min-width:0}
.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}
.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}
.fs-12{font-size:12px}.fs-13{font-size:13px}.fs-14{font-size:14px}.fs-16{font-size:16px}

/* ═══ MOBILE RESPONSIVE ═══ */
@media(max-width:768px){
  .nav{padding:0 16px}
  .nav-links{display:none;position:absolute;top:64px;left:0;right:0;flex-direction:column;background:var(--bg-nav);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);padding:16px 24px;gap:16px;z-index:99}
  .nav-links.open{display:flex}
  .nav-links a{font-size:16px;padding:8px 0}
  .mobile-menu-btn{display:block}
  .nav-mobile-actions{display:flex}
  .mobile-portal-btn{display:inline-flex!important}
  .desktop-portal-btn{display:none!important}
  .mobile-bottom-nav{display:flex}
  .app-shell{padding-bottom:64px}

  .hero-section{padding:60px 20px 48px}
  .hero-title{font-size:clamp(32px,8vw,48px);margin-bottom:20px}
  .hero-sub{font-size:16px;margin-bottom:32px}
  .cta-btn{padding:14px 28px!important;font-size:15px!important;width:100%;justify-content:center}
  .btn-outline{padding:14px 28px;font-size:15px;width:100%;text-align:center}

  .stat-value{font-size:24px}
  .stat-label{font-size:12px}

  .section{padding:48px 20px}
  .section-title{font-size:28px;margin-bottom:32px}
  .grid-3{grid-template-columns:1fr;gap:16px}

  .testimonial-metric{font-size:36px}

  .setup-fee-card{padding:24px 20px}
  .setup-fee-card .price{font-size:28px}
  .setup-fee-includes{flex-direction:column;align-items:center;gap:12px}

  .plan-price.sub{font-size:36px}
  .plan-card.recommended{transform:none}
  .plan-card.recommended:hover{transform:none}

  .cta-section{padding:60px 20px}
  .cta-title{font-size:32px}
  .cta-sub{font-size:16px}
  .cta-btn{padding:16px 32px;font-size:16px}

  .app-shell{flex-direction:column}
  .sidebar{display:none}
  .topbar{padding:12px 16px}
  .page-content{padding:20px 16px}
  .page-title{font-size:22px}

  .metric-card{min-width:calc(50% - 8px)}
  .metric-value{font-size:22px}

  div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
  div[style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr!important}

  .data-table{font-size:12px}
  .data-table th,.data-table td{padding:10px 12px}
  .glow-card.no-hover[style*="padding:0"]{overflow-x:auto}

  .calendar-grid{grid-template-columns:40px repeat(7,1fr)}
  .calendar-header{padding:8px 4px;font-size:10px}
  .calendar-hour{font-size:9px;padding:4px}

  .chart-container{height:160px;gap:8px}

  .list-row{padding:12px 16px;gap:10px;flex-wrap:wrap}

  .connect-panel{padding:16px}

  .proof-body{grid-template-columns:1fr}
  .proof-metric .pm-value{font-size:20px}

  .objection-card{margin-bottom:0}

  .trust-bar{gap:16px;padding:16px 20px}
  .trust-bar-item{font-size:12px}
  .partner-bar{gap:20px;padding:20px}
  .partner-logo span{display:none}

  .compare-table{font-size:12px}
  .compare-table th,.compare-table td{padding:10px 12px}

  .industry-grid{grid-template-columns:repeat(2,1fr);gap:12px}

  .qualify-grid{grid-template-columns:1fr;gap:16px}
  .qualify-item{font-size:14px}

  .founder-card{flex-direction:column;text-align:center;gap:16px}
  .founder-avatar{margin:0 auto}
  .founder-bio{font-size:13px}

  .roi-calc{padding:24px 20px}
  .roi-big{font-size:28px}

  .pricing-toggle{gap:8px}

  .sticky-cta{padding:10px 16px;gap:10px}
  .sticky-cta p{font-size:12px}
  .sticky-cta .sticky-btn{padding:8px 16px;font-size:12px}

  .exit-popup-inner{padding:28px 20px}

  .guarantee-shield{width:52px;height:52px;font-size:24px}

  .app-form-disqualifier{font-size:12px;padding:8px 12px}

  .marquee-track span{font-size:11px}

  .system-badge{font-size:11px;padding:6px 14px}

  .splash-logo{width:88px;height:88px;margin-bottom:28px}
  .splash-stats{gap:24px;margin-top:48px}
  .splash-stat-value{font-size:22px}
  .splash-btn{padding:16px 40px;font-size:16px;border-radius:14px}
  .splash-sub{margin-bottom:40px}

  .engine-status{flex-wrap:wrap;gap:8px;padding:12px 16px}
  .notif-feed{max-height:260px}

  .footer{padding:24px 16px}
}

@media(max-width:480px){
  .hero-title{font-size:clamp(28px,8vw,36px)}
  .metric-card{min-width:100%}
  .filter-bar{gap:6px}
  .filter-btn{padding:6px 12px;font-size:11px}
  .plan-price.sub{font-size:32px}
  .proof-metric .pm-value{font-size:18px}
  .industry-grid{grid-template-columns:1fr;gap:10px}
  .trust-bar{flex-direction:column;gap:10px;text-align:center}
  .sticky-cta{flex-direction:column;gap:6px;padding:10px 12px}
  .sticky-cta p{font-size:11px}
  .roi-big{font-size:24px}
  .compare-table th,.compare-table td{padding:8px 8px;font-size:11px}
}

/* ═══ OBJECTION GRID ═══ */
.objection-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1000px;margin:0 auto}

/* ═══ HOW IT WORKS GRID ═══ */
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* ═══ TESTIMONIALS ═══ */
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{display:flex;flex-direction:column;gap:16px}
.testimonial-quote{font-size:15px;line-height:1.7;color:var(--text);font-style:italic;flex:1}
.testimonial-meta{display:flex;align-items:center;gap:12px}
.testimonial-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-dim);border:1px solid var(--icon-border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--accent);font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;flex-shrink:0}
.testimonial-stat{font-size:13px;font-weight:600;color:var(--green);padding:8px 12px;border-radius:8px;background:rgba(52,211,153,.08);border:1px solid rgba(52,211,153,.15)}

/* ═══ FOOTER (expanded) ═══ */
.footer-inner{max-width:600px;margin:0 auto}
.footer-links{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.footer-links a{color:var(--text-secondary);text-decoration:none;font-size:13px;transition:color .2s}
.footer-links a:hover{color:var(--accent)}
.footer-sep{color:var(--text-muted);font-size:12px}

/* ═══ LEGAL CONTENT ═══ */
.legal-content h3{font-size:16px;font-weight:700;color:var(--text);margin:20px 0 8px}
.legal-content p{font-size:14px;line-height:1.7;color:var(--text-secondary);margin:0 0 12px}

/* ═══ PAYWALL ═══ */
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.fs-11{font-size:11px}
.integration-card{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}

/* ═══ DONATION SECTION ═══ */
.donate-section{padding:80px 32px;background:var(--bg);border-top:1px solid var(--border)}
.donate-inner{max-width:720px;margin:0 auto}
.donate-title{font-size:clamp(28px,5vw,42px);font-weight:800;letter-spacing:-.03em;margin:0 0 16px;color:var(--text)}
.donate-sub{font-size:16px;line-height:1.6;color:var(--text-secondary);margin:0 0 40px;max-width:560px;margin-left:auto;margin-right:auto}
.donate-card{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:32px;box-shadow:0 4px 24px rgba(0,0,0,.04)}
.donate-amounts{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.donate-amount-btn{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:16px 0;font-size:16px;font-weight:700;color:var(--text);cursor:pointer;transition:all .2s;font-family:inherit}
.donate-amount-btn:hover{border-color:var(--accent);transform:translateY(-1px)}
.donate-amount-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}
.donate-custom{margin-bottom:24px}
.donate-custom-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}
.donate-custom-wrap{position:relative}
.donate-currency{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:16px;font-weight:700;color:var(--text-muted);pointer-events:none}
.donate-custom input{width:100%;padding:14px 16px 14px 32px;border:1.5px solid var(--border);border-radius:12px;font-size:16px;background:var(--bg);color:var(--text);font-family:inherit;transition:border-color .2s;box-sizing:border-box}
.donate-custom input:focus{outline:none;border-color:var(--accent)}
.donate-custom input::-webkit-outer-spin-button,.donate-custom input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.donate-custom input[type=number]{-moz-appearance:textfield}
.donate-submit{width:100%;padding:16px;background:var(--accent);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px}
.donate-submit:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.donate-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}
.donate-note{font-size:12px;color:var(--text-muted);text-align:center;margin:16px 0 0}

/* ═══ MOBILE OVERRIDES FOR NEW GRIDS ═══ */
@media(max-width:768px){
  .objection-grid{grid-template-columns:1fr}
  .how-grid{grid-template-columns:1fr}
  .testimonial-grid{grid-template-columns:1fr}
  .footer-links{flex-direction:column;gap:6px}
  .footer-sep{display:none}
  .donate-section{padding:60px 20px}
  .donate-card{padding:24px}
  .donate-amounts{grid-template-columns:repeat(2,1fr)}
}

/* ═══ MULTI-PAGE PUBLIC NAV ═══ */
.pub-nav{position:sticky;top:0;z-index:100;background:var(--card-bg);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:box-shadow .3s}
.pub-nav.scrolled{box-shadow:0 2px 24px rgba(0,0,0,.08)}
.pub-nav-inner{max-width:1200px;margin:0 auto;padding:0 32px;height:68px;display:flex;align-items:center;justify-content:space-between;gap:32px}
.pub-nav-logo{display:flex;align-items:center;gap:10px;cursor:pointer;text-decoration:none;flex-shrink:0}
.pub-nav-logo span{font-size:20px;font-weight:800;letter-spacing:-.03em;color:var(--text)}
.pub-nav-links{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}
.pub-nav-link{background:none;border:none;padding:8px 16px;font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s;font-family:inherit;letter-spacing:-.01em}
.pub-nav-link:hover{color:var(--text);background:var(--hover-bg)}
.pub-nav-link.active{color:var(--accent);background:var(--accent-dim)}
.pub-nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.pub-nav-signin{background:none;border:none;padding:8px 14px;font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s;font-family:inherit}
.pub-nav-signin:hover{color:var(--text)}
.pub-nav-cta{background:var(--accent);color:#fff;border:none;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}
.pub-nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.15)}
/* Sign-in button — ghost variant. Opens portal preview modal first so non-
   clients aren't dropped on a blind login. Visible weight kept lower than
   the primary "Book a call" CTA next to it. */
.pub-nav-signin-btn{
  background:transparent;color:var(--text);
  border:1px solid var(--border);
  padding:10px 16px;border-radius:10px;
  font-family:inherit;font-size:14px;font-weight:600;letter-spacing:.01em;
  cursor:pointer;white-space:nowrap;
  transition:border-color .18s ease,background .18s ease,color .18s ease,transform .12s ease;
}
.pub-nav-signin-btn:hover{
  border-color:var(--accent);
  color:var(--accent);
  background:var(--accent-dim);
  transform:translateY(-1px);
}
@media(max-width:900px){.pub-nav-signin-btn{display:none}}
.pub-nav-burger{display:none;background:none;border:none;font-size:22px;color:var(--text);cursor:pointer;padding:6px}
/* Drawer is mobile-only. Hard-forced off on desktop so it can never show
   regardless of state bugs that might leave .open class attached. */
.pub-nav-drawer{display:none !important;flex-direction:column;padding:16px 24px 24px;gap:4px;border-top:1px solid var(--border);background:var(--card-bg)}
@media(max-width:900px){
  .pub-nav-drawer.open{display:flex !important}
}
.pub-nav-drawer .pub-nav-link{text-align:left;font-size:16px;padding:12px 16px;width:100%;text-decoration:none;display:block}
.pub-nav-drawer .pub-nav-cta{width:100%;text-align:center;padding:14px;font-size:15px;margin-top:8px;border-radius:12px}

/* ═══ NAV SUB-MENU (More dropdown) ═══ */
.pub-nav-link{text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.pub-nav-more{position:relative;display:inline-block}
.pub-nav-more-btn{display:inline-flex;align-items:center;gap:4px}
.pub-nav-submenu{position:absolute;top:calc(100% + 4px);right:0;min-width:220px;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:8px;box-shadow:0 12px 40px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.06);opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s ease,transform .18s ease,visibility .18s;z-index:110;display:flex;flex-direction:column;gap:2px}
.pub-nav-more:hover .pub-nav-submenu,.pub-nav-more:focus-within .pub-nav-submenu{opacity:1;visibility:visible;transform:translateY(0)}
.pub-nav-sublink{display:flex;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:600;color:var(--text-secondary);border-radius:8px;text-decoration:none;transition:all .18s;letter-spacing:-.01em;white-space:nowrap}
.pub-nav-sublink:hover{color:var(--text);background:var(--hover-bg)}
.pub-nav-sublink.active{color:var(--accent);background:var(--accent-dim)}

/* ═══ NAV CTA WRAP (microcopy under button) ═══ */
.pub-nav-cta-wrap{display:flex;flex-direction:column;align-items:center;gap:2px}
.pub-nav-cta-sub{font-size:10px;font-weight:500;color:var(--text-muted);letter-spacing:.02em;margin-top:1px;line-height:1.1;white-space:nowrap}

/* ═══ BURGER BARS (accessible hamburger) ═══ */
.pub-nav-burger{align-items:center;justify-content:center;flex-direction:column;gap:4px;width:40px;height:40px;border-radius:8px;transition:background .2s}
.pub-nav-burger:hover{background:var(--hover-bg)}
.burger-bar{display:block;width:20px;height:2px;background:var(--text);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.pub-nav-burger[aria-expanded="true"] .burger-bar:nth-child(1){transform:translateY(6px) rotate(45deg)}
.pub-nav-burger[aria-expanded="true"] .burger-bar:nth-child(2){opacity:0}
.pub-nav-burger[aria-expanded="true"] .burger-bar:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ═══ DRAWER DIVIDER ═══ */
.pub-nav-drawer-divider{height:1px;background:var(--border);margin:8px 0;opacity:.6}

/* ═══ SKIP-TO-CONTENT (a11y) ═══ */
.skip-to-content{position:absolute;top:-48px;left:16px;z-index:9999;background:var(--accent);color:#fff;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:700;text-decoration:none;transition:top .18s ease}
.skip-to-content:focus{top:12px;outline:2px solid var(--text);outline-offset:2px}

/* ═══ FOCUS-VISIBLE (a11y — keyboard focus ring) ═══ */
:focus{outline:none}
button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}

/* ═══ PAGE TRANSITION ═══ */
.pub-content{min-height:calc(100vh - 68px)}
@keyframes pubPageIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.pub-page-animate{animation:pubPageIn .4s cubic-bezier(.22,1,.36,1) both}

/* ═══ SCROLL PROGRESS BAR ═══ */
.scroll-progress{position:fixed;top:0;left:0;height:3px;background:var(--accent);z-index:200;width:0%;transition:width .1s linear;pointer-events:none}

/* ═══ LOGO MARQUEE ═══ */
.marquee-wrap{overflow:hidden;padding:28px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.marquee-track{display:flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:32px}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{display:flex;align-items:center;gap:10px;padding:0 40px;opacity:.55;transition:opacity .2s;flex-shrink:0}
.marquee-item:hover{opacity:1}
.marquee-dot{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0}
.marquee-name{font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em}

/* ═══ HOME HERO (bigger) ═══ */
.home-hero{position:relative;padding:100px 40px 80px;text-align:center;overflow:hidden}
.home-hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--accent-dim);border:1px solid rgba(212,165,116,.2);border-radius:100px;padding:6px 16px;font-size:13px;font-weight:700;color:var(--accent);margin-bottom:32px;letter-spacing:.02em}
.home-hero-title{font-size:clamp(48px,7.5vw,88px);font-weight:900;letter-spacing:-.04em;line-height:1.05;margin:0 auto 24px;color:var(--text);max-width:920px}
.home-hero-sub{font-size:clamp(17px,2vw,21px);color:var(--text-secondary);line-height:1.6;max-width:580px;margin:0 auto 40px;font-weight:400}
.home-hero-actions{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:64px}
.home-hero-cta{background:var(--accent);color:#fff;border:none;padding:18px 36px;border-radius:14px;font-size:17px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .25s;display:inline-flex;align-items:center;gap:8px}
.home-hero-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.25)}
.home-hero-secondary{background:none;border:2px solid var(--border);padding:16px 28px;border-radius:14px;font-size:16px;font-weight:600;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:all .2s}
.home-hero-secondary:hover{border-color:var(--accent);color:var(--text)}
.home-hero-stats{display:flex;align-items:center;justify-content:center;gap:48px;padding:32px 0;border-top:1px solid var(--border);flex-wrap:wrap}
.home-stat{text-align:center}
.home-stat-val{font-size:clamp(28px,4vw,40px);font-weight:900;letter-spacing:-.03em;color:var(--text)}
.home-stat-label{font-size:13px;color:var(--text-secondary);margin-top:4px;font-weight:500}

/* ═══ SECTION FLOW ═══ */
.pub-section{padding:72px 40px}
.pub-section-alt{padding:72px 40px;background:var(--results-bg)}
.pub-section-inner{max-width:1100px;margin:0 auto}
.pub-section-header{text-align:center;margin-bottom:44px}
/* Donate + pricing header — tighten header-to-grid gap */
.donate-page-wrap .pub-section-header,.pricing-page-wrap .pub-section-header{margin-bottom:32px}
.donate-page-wrap .pub-section,.pricing-page-wrap .pub-section{padding-top:56px;padding-bottom:56px}
.pub-section-header.left{text-align:left}
.pub-section-tag{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.pub-section-title{font-size:clamp(32px,5vw,52px);font-weight:900;letter-spacing:-.04em;line-height:1.1;margin:0 0 16px;color:var(--text)}
.pub-section-sub{font-size:17px;color:var(--text-secondary);line-height:1.6;max-width:560px;margin:0 auto}
.pub-section-header.left .pub-section-sub{margin:0}

/* ═══ SERVICES PAGE ═══ */
.service-card{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:64px 0;border-bottom:1px solid var(--border)}
.service-card:last-child{border-bottom:none}
.service-card.reverse{direction:rtl}
.service-card.reverse>*{direction:ltr}
.service-icon-wrap{width:64px;height:64px;border-radius:18px;background:var(--accent-dim);border:1px solid rgba(212,165,116,.15);display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:24px}
.service-card-title{font-size:clamp(24px,3.5vw,34px);font-weight:900;letter-spacing:-.03em;margin:0 0 16px;color:var(--text)}
.service-card-desc{font-size:16px;color:var(--text-secondary);line-height:1.7;margin:0 0 24px}
.service-card-bullets{display:flex;flex-direction:column;gap:10px;margin:0;padding:0;list-style:none}
.service-bullet{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text-secondary);line-height:1.5}
.service-bullet-dot{width:20px;height:20px;border-radius:50%;background:var(--accent-dim);border:1px solid rgba(212,165,116,.3);display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--accent);flex-shrink:0;margin-top:1px}
.service-visual{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:12px}
.service-metric-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--hover-bg);border-radius:10px}
.service-metric-label{font-size:13px;color:var(--text-secondary);font-weight:500}
.service-metric-val{font-size:14px;font-weight:700;color:var(--green)}

/* ═══ RESULTS PAGE ═══ */
.case-study-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.case-study-card{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:32px;transition:all .25s}
.case-study-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.06)}
.case-study-industry{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.case-study-headline{font-size:22px;font-weight:800;letter-spacing:-.03em;margin:0 0 12px;color:var(--text)}
.case-study-desc{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0 0 24px}
.case-study-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:20px 0;border-top:1px solid var(--border)}
.cs-metric-val{font-size:24px;font-weight:900;letter-spacing:-.03em;color:var(--text)}
.cs-metric-label{font-size:11px;color:var(--text-secondary);margin-top:2px;font-weight:500}
.case-study-quote{font-size:14px;font-style:italic;color:var(--text-secondary);line-height:1.6;padding:16px 0 0;border-top:1px solid var(--border)}
.case-study-author{font-size:12px;font-weight:600;color:var(--text);margin-top:8px}

/* ═══ ABOUT PAGE ═══ */
.about-values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.about-value-card{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;padding:24px}
.about-value-icon{font-size:28px;margin-bottom:12px}
.about-value-title{font-size:16px;font-weight:700;margin:0 0 8px;color:var(--text)}
.about-value-desc{font-size:13px;color:var(--text-secondary);line-height:1.6;margin:0}

/* ═══ STAGGER ANIMATION ═══ */
.stagger>*:nth-child(1){animation-delay:.05s}
.stagger>*:nth-child(2){animation-delay:.12s}
.stagger>*:nth-child(3){animation-delay:.19s}
.stagger>*:nth-child(4){animation-delay:.26s}
.stagger>*:nth-child(5){animation-delay:.33s}
.stagger>*:nth-child(6){animation-delay:.40s}

/* ═══ PUBLIC FOOTER ═══ */
.pub-footer{padding:48px 40px;border-top:1px solid var(--border);background:var(--card-bg)}
.pub-footer-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.pub-footer-brand p{font-size:13px;color:var(--text-secondary);line-height:1.6;margin:12px 0 0;max-width:240px}
.pub-footer-col h4{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin:0 0 16px}
.pub-footer-col a{display:block;font-size:14px;color:var(--text-secondary);text-decoration:none;margin-bottom:10px;transition:color .2s}
.pub-footer-col a:hover{color:var(--accent)}
.pub-footer-bottom{max-width:1100px;margin:32px auto 0;padding-top:24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.pub-footer-bottom p{font-size:12px;color:var(--text-muted);margin:0}

/* ═══ MOBILE: MULTI-PAGE ═══ */
@media(max-width:900px){
  .pub-nav-links{display:none}
  .pub-nav-signin{display:none}
  .pub-nav-cta{display:none}
  .pub-nav-burger{display:block}
  .home-hero{padding:72px 24px 56px}
  .home-hero-stats{gap:28px}
  .pub-section,.pub-section-alt{padding:64px 24px}
  .service-card{grid-template-columns:1fr;gap:32px}
  .service-card.reverse{direction:ltr}
  .case-study-grid{grid-template-columns:1fr}
  .about-values-grid{grid-template-columns:1fr}
  .pub-footer-inner{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:480px){
  .pub-nav-inner{padding:0 16px}
  .home-hero{padding:56px 16px 48px}
  .case-study-metrics{gap:12px}
  .cs-metric-val{font-size:20px}
  /* Keep 2-column footer on mobile — a stacked 4-section footer is ~900px tall
     and swallows the viewport. 2x2 roughly halves it. */
  .pub-footer-inner{grid-template-columns:1fr 1fr;gap:24px}
  .pub-section,.pub-section-alt{padding:48px 16px}
}

/* ═══ MOBILE STICKY BOOK-A-CALL CTA ═══
   Mobile traffic is 40–60% of B2B landing traffic. The desktop header CTA
   hides at ≤900px which leaves only the hamburger. A sticky bottom bar keeps
   the primary action in reach regardless of scroll depth. Hidden on desktop
   and inside the authenticated app shell (handled via .app-shell sibling). */
.pub-mobile-sticky-cta{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:8500;
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:var(--bg-nav);backdrop-filter:blur(16px);
  border-top:1px solid var(--border);
}
.pub-mobile-sticky-cta button{
  width:100%;padding:14px 18px;border:none;border-radius:12px;
  background:linear-gradient(135deg,var(--accent) 0%,#4a75e6 100%);color:#fff;
  font-family:inherit;font-size:15px;font-weight:700;letter-spacing:.01em;
  cursor:pointer;box-shadow:0 8px 24px rgba(212,165,116,.3);
  transition:transform .15s ease,box-shadow .15s ease;
}
.pub-mobile-sticky-cta button:active{transform:translateY(1px);box-shadow:0 2px 6px rgba(0,0,0,.28)}
@media(max-width:900px){
  .pub-mobile-sticky-cta{display:block}
  /* Reserve room at the bottom of the landing so the sticky bar never
     obscures the last inch of content (including the final CTA + footer). */
  .landing-page{padding-bottom:88px}
}

/* ═══ HERO MICRO-COPY ═══ */
.home-hero-micro{font-size:13px;color:var(--text-muted);margin:-40px auto 56px;letter-spacing:.01em;font-weight:500}

/* ═══ SCARCITY LINE (pricing) ═══ */
.scarcity-line{display:inline-flex;align-items:center;gap:10px;margin-top:20px;padding:10px 18px;background:linear-gradient(135deg,rgba(255,180,50,.12),rgba(255,120,50,.08));border:1px solid rgba(255,150,50,.25);border-radius:100px;font-size:13px;color:var(--text);font-weight:500;letter-spacing:.01em}
.scarcity-line strong{color:var(--text);font-weight:800}
.scarcity-pulse{width:8px;height:8px;border-radius:50%;background:#ff8a3d;box-shadow:0 0 0 0 rgba(255,138,61,.6);animation:scarcityPulse 1.8s ease-out infinite;flex-shrink:0}
@keyframes scarcityPulse{
  0%{box-shadow:0 0 0 0 rgba(255,138,61,.6)}
  70%{box-shadow:0 0 0 10px rgba(255,138,61,0)}
  100%{box-shadow:0 0 0 0 rgba(255,138,61,0)}
}

/* ═══ PAGE-TO-PAGE NAVIGATION (next/prev arrows) ═══ */
.page-nav-section{padding:80px 40px;border-top:1px solid var(--border);background:linear-gradient(180deg,transparent,var(--results-bg) 60%)}
.page-nav-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.page-nav-spacer{display:block}
.page-nav-btn{display:flex;align-items:center;gap:20px;background:var(--card-bg);border:1.5px solid var(--border);border-radius:20px;padding:28px 32px;cursor:pointer;font-family:inherit;color:var(--text);text-align:left;transition:all .3s cubic-bezier(.22,1,.36,1);min-height:120px;overflow:hidden;position:relative}
.page-nav-btn:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.18)}
.page-nav-btn.next{justify-content:space-between;background:linear-gradient(135deg,var(--accent) 0%,#4a75e6 100%);border-color:transparent;color:#fff}
.page-nav-btn.next:hover{box-shadow:0 8px 24px rgba(0,0,0,.3);transform:translateY(-2px)}
.page-nav-btn.next .page-nav-dir,.page-nav-btn.next .page-nav-sub{color:rgba(255,255,255,.78)}
.page-nav-btn.next .page-nav-label{color:#fff}
.page-nav-text{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}
.page-nav-dir{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);opacity:.9}
.page-nav-label{font-size:22px;font-weight:900;letter-spacing:-.02em;color:var(--text);line-height:1.2}
.page-nav-sub{font-size:13px;color:var(--text-secondary);font-weight:500;margin-top:2px}
.page-nav-arrow{font-size:32px;font-weight:400;color:var(--accent);transition:transform .3s cubic-bezier(.22,1,.36,1);flex-shrink:0}
.page-nav-btn.next .page-nav-arrow{color:#fff}
.page-nav-btn:hover .page-nav-arrow{transform:translateX(6px)}
.page-nav-btn.prev:hover .page-nav-arrow{transform:translateX(-6px)}
.page-nav-btn.cta{background:linear-gradient(135deg,#D4A574 0%,#7B5BFF 100%)}

/* ═══ SCROLL REVEAL FADE POLISH ═══ */
.fade-in,.blur-in,.swoop-in,.slide-up,.scale-in,.bounce-in{will-change:transform,opacity}

/* ═══ MOBILE OPTIMIZATIONS (enhanced) ═══ */
@media(max-width:900px){
  .page-nav-section{padding:56px 20px}
  .page-nav-inner{grid-template-columns:1fr;gap:12px}
  .page-nav-btn{padding:22px 24px;min-height:96px}
  .page-nav-label{font-size:18px}
  .home-hero-title{font-size:clamp(38px,10vw,64px) !important;line-height:1.08}
  .home-hero-sub{font-size:16px !important;line-height:1.55}
  .home-hero-micro{font-size:12px;margin:-28px auto 36px;padding:0 20px}
  .home-hero-actions{flex-direction:column;width:100%;gap:10px}
  .home-hero-cta,.home-hero-secondary{width:100%;padding:16px 24px !important;font-size:15px !important;min-height:52px;justify-content:center}
  .home-hero-stats{gap:20px !important;padding:24px 0}
  .home-stat{padding-left:0 !important;border-left:none !important;min-width:140px}
  .home-stat-val{font-size:24px !important}
  .home-stat-label{font-size:11px}
  /* Bigger tap targets everywhere */
  .pub-nav-burger{width:44px;height:44px;font-size:22px;display:flex !important;align-items:center;justify-content:center}
  .pub-nav-logo{gap:8px}
  .pub-nav-logo span{font-size:15px}
  /* Sticky CTA → fixed bottom-right floating button on mobile */
  .sticky-cta{flex-direction:row;padding:10px 14px;gap:12px;align-items:center}
  .sticky-cta p{display:none}
  .sticky-cta .sticky-btn{flex:1;padding:14px 18px;font-size:14px;min-height:48px}
  /* Pricing cards on mobile */
  .plan-card{padding:24px 20px}
  .plan-price.sub{font-size:36px !important}
  /* Case study cards */
  .case-study-card{padding:24px 20px}
  .case-study-headline{font-size:18px !important}
  /* FAQ bigger tap */
  #faq .glow-card{padding:18px 20px;min-height:56px}
  /* Section spacing tightened */
  .pub-section,.pub-section-alt{padding:56px 20px}
  .pub-section-header{margin-bottom:40px}
  /* Scarcity line wraps on mobile */
  .scarcity-line{font-size:12px;padding:8px 14px;gap:8px;text-align:left;line-height:1.45}
  /* Donate section on mobile */
  .donate-amounts{grid-template-columns:repeat(2,1fr) !important;gap:10px}
  .donate-amount-btn{min-height:52px;font-size:17px !important}
  .donate-submit{min-height:56px;font-size:16px !important}
  /* Compare table scroll hint */
  .compare-table{font-size:12px}
  .compare-table th,.compare-table td{padding:10px 8px}
  /* Service cards stack cleanly */
  .service-card{padding:40px 0}
  .service-card-title{font-size:22px !important}
  .service-visual{padding:20px}
  /* Section titles sized for mobile readability */
  .pub-section-title{font-size:clamp(26px,6.5vw,36px) !important;line-height:1.15}
}
@media(max-width:480px){
  .home-hero{padding:44px 16px 40px}
  .home-hero-eyebrow{font-size:11px;padding:5px 12px;margin-bottom:20px}
  .home-hero-title{font-size:clamp(32px,9.5vw,46px) !important;margin-bottom:18px}
  .home-hero-stats{gap:14px !important}
  .home-stat-val{font-size:20px !important}
  .home-stat-label{font-size:10px}
  .page-nav-btn{padding:18px 18px;min-height:84px;gap:14px}
  .page-nav-label{font-size:16px}
  .page-nav-sub{font-size:12px}
  .page-nav-arrow{font-size:24px}
  .pub-section,.pub-section-alt{padding:44px 16px}
  .plan-card{padding:20px 16px}
  /* Extra thumb-friendly */
  .home-hero-cta,.home-hero-secondary{min-height:52px;border-radius:12px !important}
  .sticky-cta{padding:8px 10px}
  .sticky-cta .sticky-btn{padding:12px 14px;font-size:13px;min-height:46px}
}

/* ═══ REDUCED MOTION ACCESSIBILITY ═══ */
@media(prefers-reduced-motion:reduce){
  /* Neutralize long-running keyframe animations, but keep short UI transitions + splash entrance intact */
  *,*::before,*::after{scroll-behavior:auto !important}

  /* Scroll-reveal safety net — ensure they end visible even if observer misfires */
  .fade-in.visible,.slide-up.visible,.slide-left.visible,.slide-right.visible,
  .scale-in.visible,.blur-in.visible,.bounce-in.visible,.swoop-in.visible{
    opacity:1 !important;transform:none !important;filter:none !important
  }

  /* Kill background ambient animations but KEEP splash/entrance animations playing */
  .marquee-track{animation-play-state:paused !important}
  .scarcity-pulse{animation:none !important}
  /* Cursor-glow stays on under reduced-motion: it tracks user input, it's not
     independent motion. Many Windows users have "Show animations" off without
     realizing it forces prefers-reduced-motion=reduce site-wide. */
  .orb,.splash-orb,.splash-grid{animation:none !important}
  /* Splash entrance — keep fully animated so it feels intentional */
  .splash-logo,.splash-title,.splash-sub,.splash-cta,.splash-stats{animation-duration:.8s !important}
}

/* ════════════════════════════════════════════════════════════
   OVERKILL ANIMATION LAYER
   ════════════════════════════════════════════════════════════ */

:root{--scroll-velocity:0px}

/* ═══ CURSOR SPOTLIGHT ═══
   Soft blue spotlight that follows the pointer. Light mode is subtle (mix-blend
   does the work). Dark mode goes brighter + bigger and ditches the blend so the
   accent reads as a real glow against #06080C, not a faded smudge. */
.cursor-glow{position:fixed;top:0;left:0;width:360px;height:360px;pointer-events:none;z-index:9;background:radial-gradient(circle at center,rgba(212,165,116,.16),rgba(212,165,116,.04) 40%,transparent 70%);border-radius:50%;mix-blend-mode:screen;transition:opacity .3s;will-change:transform}
body.dark .cursor-glow{
  width:470px;height:470px;
  background:radial-gradient(circle at center,
    rgba(212,165,116,.55) 0%,
    rgba(212,165,116,.32) 18%,
    rgba(123,91,255,.16) 38%,
    rgba(212,165,116,.06) 58%,
    transparent 75%);
  mix-blend-mode:normal;
  filter:blur(8px);
}

/* ═══ MAGNETIC BUTTON TRANSITION ═══ */
.magnetic-btn{transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .3s,background .3s,border-color .3s}
.magnetic-btn:hover{filter:brightness(1.08)}

/* ═══ TILT CARDS ═══ */
[data-tilt]{transition:transform .4s cubic-bezier(.22,1,.36,1);will-change:transform;transform-style:preserve-3d}

/* ═══ LETTER-BY-LETTER REVEAL ═══ */
.split-word{display:inline-block;white-space:nowrap}
.split-char{display:inline-block;opacity:0;transform:translateY(40px) rotateX(-90deg);animation:charReveal .9s cubic-bezier(.22,1,.36,1) forwards}
@keyframes charReveal{
  0%{opacity:0;transform:translateY(40px) rotateX(-90deg);filter:blur(8px)}
  60%{opacity:1;filter:blur(0)}
  100%{opacity:1;transform:translateY(0) rotateX(0);filter:blur(0)}
}

/* ═══ AMBIENT FLOATING ORBS ═══ */
.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;pointer-events:none;z-index:0;mix-blend-mode:screen}
.orb-1{top:10%;left:8%;width:320px;height:320px;background:radial-gradient(circle,#D4A574,transparent 70%)}
.orb-2{top:30%;right:8%;width:380px;height:380px;background:radial-gradient(circle,#7B5BFF,transparent 70%)}
.orb-3{bottom:5%;left:40%;width:280px;height:280px;background:radial-gradient(circle,#FF6B9D,transparent 70%)}
.dark .orb{opacity:.35}
@keyframes orbDrift{
  0%{transform:translate(0,0) scale(1)}
  33%{transform:translate(80px,-60px) scale(1.15)}
  66%{transform:translate(-60px,70px) scale(.95)}
  100%{transform:translate(40px,40px) scale(1.1)}
}

/* ═══ GRADIENT HUE ROTATION (ambient background shift) ═══ */
.gradient-text{background-size:200% auto;animation:gradientSlide 6s ease-in-out infinite alternate}
@keyframes gradientSlide{
  from{background-position:0% center}
  to{background-position:100% center}
}

/* ═══ PULSE HEART (donate eyebrow) ═══ */
.pulse-heart{display:inline-block;color:#ff6b9d;animation:heartbeat 1.4s ease-in-out infinite}
@keyframes heartbeat{0%,100%{transform:scale(1)}14%{transform:scale(1.2)}28%{transform:scale(1)}42%{transform:scale(1.15)}70%{transform:scale(1)}}

/* ═══ DONATE HERO (dedicated page) ═══ */
.donate-hero{position:relative;padding:72px 40px 48px;text-align:center;overflow:hidden;display:flex;align-items:center}
.donate-hero-inner{position:relative;z-index:1;max-width:880px;margin:0 auto}

/* ═══ DONATE CARD (upgraded) ═══ */
.donate-card-pro{position:relative;background:var(--card-bg);border:1.5px solid var(--border);border-radius:28px;padding:40px;overflow:hidden;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s}
.donate-card-pro:hover{box-shadow:0 10px 28px rgba(0,0,0,.22)}
.donate-card-glow{position:absolute;inset:-2px;background:linear-gradient(135deg,#D4A574,#7B5BFF 30%,#FF6B9D 60%,#FFA13D 100%);opacity:0;filter:blur(24px);transition:opacity .5s;z-index:-1;border-radius:28px}
.donate-card-pro:hover .donate-card-glow{opacity:.5}
.donate-card-inner{position:relative}

/* ═══ ALLOCATION CARDS ═══ */
.allocation-card{display:flex;align-items:center;gap:24px;padding:24px 28px;background:var(--card-bg);border:1px solid var(--border);border-radius:20px;margin-bottom:14px;transition:all .35s cubic-bezier(.22,1,.36,1)}
.allocation-card:hover{transform:translateX(4px);border-color:var(--accent);box-shadow:0 4px 14px rgba(0,0,0,.15)}
.allocation-pct{font-size:40px;font-weight:900;letter-spacing:-.04em;background:linear-gradient(135deg,#D4A574,#7B5BFF);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;min-width:90px}
.allocation-body{flex:1}
.allocation-title{font-size:17px;font-weight:800;margin:0 0 4px;color:var(--text);letter-spacing:-.01em}
.allocation-desc{font-size:13px;color:var(--text-secondary);line-height:1.55;margin:0}

/* ═══ DEMO CLIENT PORTAL ═══ */
.portal-demo-overlay{position:fixed;inset:0;z-index:1000;background:rgba(4,6,16,.75);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .3s ease}
.portal-demo-overlay.visible{opacity:1}
.portal-demo-wrap{position:relative;width:100%;max-width:900px;max-height:90vh;border-radius:24px;overflow:hidden;box-shadow:0 40px 120px rgba(0,0,0,.6);transform:scale(.96);transition:transform .4s cubic-bezier(.22,1,.36,1)}
.portal-demo-overlay.visible .portal-demo-wrap{transform:scale(1)}

/* Mock portal (appears blurred behind lock) */
.portal-demo-mock{background:#0a0d1a;color:#fff;padding:0;filter:blur(3px);user-select:none;pointer-events:none}
.portal-demo-topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02)}
.portal-demo-chip{background:linear-gradient(135deg,#FFA13D,#FF6B9D);color:#fff;padding:3px 10px;border-radius:100px;font-size:10px;font-weight:800;letter-spacing:.1em;margin-left:8px}
.portal-demo-close{background:rgba(255,255,255,.06);border:none;color:#fff;width:34px;height:34px;border-radius:10px;font-size:15px;cursor:pointer;pointer-events:auto !important;filter:none;transition:background .2s}
.portal-demo-close:hover{background:rgba(255,255,255,.14)}
.portal-demo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:20px}
.portal-demo-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:16px}
.pdc-label{font-size:11px;color:rgba(255,255,255,.55);margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.pdc-value{font-size:22px;font-weight:900;letter-spacing:-.02em;margin-bottom:4px}
.pdc-change{font-size:11px;color:#7fe39b;font-weight:600}
.portal-demo-bookings{padding:0 20px 20px}
.pdb-head{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.55);margin-bottom:10px;font-weight:700}
.pdb-row{display:flex;align-items:center;gap:12px;padding:12px;background:rgba(255,255,255,.03);border-radius:12px;margin-bottom:8px}
.pdb-av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#D4A574,#7B5BFF);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff}
.pdb-c{font-size:13px;font-weight:700}
.pdb-t{font-size:11px;color:rgba(255,255,255,.55)}
.pdb-badge{background:rgba(127,227,155,.15);color:#7fe39b;font-size:10px;font-weight:800;padding:3px 10px;border-radius:100px;letter-spacing:.08em;text-transform:uppercase}

/* Lock overlay with CTA */
.portal-demo-lock{position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,rgba(212,165,116,.25),rgba(10,13,26,.85) 60%);display:flex;align-items:center;justify-content:center;padding:40px}
.portal-demo-lock-inner{max-width:480px;text-align:center;color:#fff}
.portal-demo-lock-icon{font-size:48px;margin-bottom:16px;filter:drop-shadow(0 8px 24px rgba(212,165,116,.5));animation:lockFloat 3s ease-in-out infinite}
@keyframes lockFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.portal-demo-lock-title{font-size:clamp(24px,3.5vw,32px);font-weight:900;letter-spacing:-.03em;margin:0 0 12px;color:#fff}
.portal-demo-lock-desc{font-size:15px;line-height:1.6;color:rgba(255,255,255,.78);margin:0 0 24px}
.portal-demo-lock-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.portal-demo-lock-actions .home-hero-secondary{color:#fff;border-color:rgba(255,255,255,.3)}
.portal-demo-lock-actions .home-hero-secondary:hover{border-color:#fff;color:#fff}

@media(max-width:640px){
  .portal-demo-grid{grid-template-columns:repeat(2,1fr)}
  .portal-demo-wrap{max-height:92vh;overflow-y:auto}
  .portal-demo-lock{padding:24px}
  .portal-demo-lock-actions{flex-direction:column}
  .portal-demo-lock-actions button{width:100%}
  .allocation-card{padding:18px 20px;gap:16px}
  .allocation-pct{font-size:28px;min-width:64px}
  .donate-card-pro{padding:28px 20px}
}

/* ═══════════════════════════════════════════
   CHAT WIDGET
   ═══════════════════════════════════════════ */
/* Container spans FAB + (invisible-when-closed) panel. Disable pointer-events
   on the wrapper so empty space doesn't intercept clicks on content below
   (footer links, ROI sliders, etc). Children re-enable as needed. */
#chat-widget{position:fixed;bottom:24px;right:24px;z-index:9000;display:flex;flex-direction:column;align-items:flex-end;gap:12px;pointer-events:none}
#chat-widget > *{pointer-events:auto}

/* FAB */
.chat-fab{position:relative;width:52px;height:52px;border-radius:50%;background:var(--accent);border:1px solid rgba(0,0,0,.12);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 6px 20px rgba(0,0,0,.35);transition:transform .18s ease,box-shadow .18s ease;color:var(--accent-text);flex-shrink:0}
.chat-fab:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(0,0,0,.45)}
.chat-fab:active{transform:scale(.96)}
.chat-unread{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:50%;background:#FF5F57;color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg);animation:chat-unread-bounce .8s cubic-bezier(.4,1.6,.5,1) 1}
@keyframes chat-unread-bounce{0%{transform:scale(0)}60%{transform:scale(1.25)}100%{transform:scale(1)}}

/* FAB pulse ring — draws attention when there's an unread message and the panel is closed */
.chat-fab-pulsing::before{content:'';position:absolute;inset:-6px;border-radius:50%;border:2px solid #D4A574;opacity:.55;animation:chat-fab-pulse 1.8s ease-out infinite;pointer-events:none}
@keyframes chat-fab-pulse{0%{transform:scale(.92);opacity:.55}80%{transform:scale(1.4);opacity:0}100%{transform:scale(1.4);opacity:0}}

/* Preview bubble — shows the actual first AI greeting next to the FAB so users
   know there's a real message waiting (not a fake "1" notification). */
.chat-preview{max-width:280px;background:var(--card-bg);color:var(--text);border:1px solid var(--border);border-radius:14px;padding:12px 14px 12px 14px;font-size:13px;line-height:1.5;box-shadow:0 12px 32px rgba(0,0,0,.18);position:relative;cursor:pointer;transform:translateY(8px) scale(.96);opacity:0;transition:transform .35s cubic-bezier(.16,1,.3,1),opacity .25s ease}
.chat-preview.chat-preview-visible{transform:translateY(0) scale(1);opacity:1}
.chat-preview::after{content:'';position:absolute;bottom:-7px;right:22px;width:14px;height:14px;background:var(--card-bg);border-right:1px solid var(--border);border-bottom:1px solid var(--border);transform:rotate(45deg)}
.chat-preview-head{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-weight:700;font-size:12px;color:var(--text)}
.chat-preview-avatar{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#D4A574,#7B5BFF);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0}
.chat-preview-close{position:absolute;top:6px;right:8px;background:transparent;border:0;color:var(--text-muted);font-size:14px;line-height:1;cursor:pointer;padding:4px 6px;border-radius:6px;transition:background .15s}
.chat-preview-close:hover{background:var(--hover-bg);color:var(--text)}
.chat-preview-body{color:var(--text-secondary);padding-right:14px}

/* Panel */
.chat-panel{width:360px;max-height:520px;background:var(--card-bg);border:1px solid var(--border);border-radius:20px;box-shadow:0 24px 80px rgba(0,0,0,.22);display:flex;flex-direction:column;opacity:0;transform:translateY(16px) scale(.97);pointer-events:none;transition:opacity .22s ease,transform .22s ease;overflow:hidden}
.chat-panel-open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}

/* Header */
.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--card-bg);flex-shrink:0}
.chat-header-left{display:flex;align-items:center;gap:10px}
.chat-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#D4A574,#7B5BFF);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;flex-shrink:0}
.chat-header-name{font-size:14px;font-weight:700;color:var(--text);line-height:1.2}
.chat-header-status{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.chat-status-dot{width:6px;height:6px;border-radius:50%;background:#28C840;flex-shrink:0}
.chat-header-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:15px;padding:4px 6px;border-radius:6px;transition:background .15s,color .15s;line-height:1}
.chat-header-btn:hover{background:var(--hover-bg);color:var(--text)}

/* Messages */
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;scroll-behavior:smooth}
.chat-messages::-webkit-scrollbar{width:4px}
.chat-messages::-webkit-scrollbar-track{background:transparent}
.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* Bubbles */
.chat-bubble{max-width:82%;padding:10px 14px;border-radius:16px;font-size:13px;line-height:1.55;word-wrap:break-word;animation:chatBubbleIn .18s ease both}
@keyframes chatBubbleIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.chat-bubble-user{background:linear-gradient(135deg,#D4A574,#7B5BFF);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-bubble-assistant{background:var(--hover-bg);color:var(--text);align-self:flex-start;border-bottom-left-radius:4px;border:1px solid var(--border)}

/* Typing indicator */
.chat-typing{display:flex;align-items:center;gap:4px;padding:12px 16px}
.chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:typingDot 1.2s ease-in-out infinite}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typingDot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}

/* Inline link buttons in assistant messages */
.chat-inline-link{background:none;border:none;color:var(--accent);font-size:inherit;font-weight:600;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}
.chat-inline-link:hover{opacity:.8}

/* Input */
.chat-input-wrap{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}
.chat-input{flex:1;background:var(--input-bg);border:1px solid var(--border);border-radius:10px;padding:9px 14px;font-size:13px;color:var(--text);outline:none;transition:border-color .15s}
.chat-input:focus{border-color:var(--accent)}
.chat-input::placeholder{color:var(--text-muted)}
.chat-input:disabled{opacity:.5}
.chat-send{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#D4A574,#7B5BFF);border:none;cursor:pointer;color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;transition:opacity .15s,transform .15s;flex-shrink:0}
.chat-send:hover{opacity:.88}
.chat-send:active{transform:scale(.94)}
.chat-send:disabled{opacity:.35;cursor:not-allowed}

/* Footer CTA */
.chat-footer{padding:0 16px 14px;flex-shrink:0}
.chat-schedule-prompt{width:100%;padding:10px;background:var(--accent-subtle);border:1px solid rgba(212,165,116,.25);border-radius:10px;color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;transition:background .15s;text-align:center}
.chat-schedule-prompt:hover{background:rgba(212,165,116,.18)}

/* On mobile, push the chat above the sticky Book-a-call bar and shrink the
   FAB so it doesn't swallow hero/ROI content. 88px clears 56px bar + padding. */
@media(max-width:900px){
  #chat-widget{bottom:calc(88px + env(safe-area-inset-bottom));right:16px}
  .chat-fab{width:48px;height:48px;font-size:20px;box-shadow:0 6px 18px rgba(212,165,116,.4)}
}
@media(max-width:480px){
  .chat-panel{width:calc(100vw - 32px)}
}

/* ═══════════════════════════════════════════
   SCHEDULE MODAL
   ═══════════════════════════════════════════ */
.schedule-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:9100;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .25s ease}
.schedule-modal-overlay.visible{opacity:1}
.schedule-modal-wrap{width:100%;max-width:760px;max-height:90vh;background:var(--bg-surface);border:1px solid var(--border);border-radius:24px;box-shadow:0 32px 100px rgba(0,0,0,.55);display:flex;flex-direction:column;overflow:hidden;transform:translateY(20px);transition:transform .25s ease;opacity:1 !important}
body.light .schedule-modal-wrap{background:#fff}
body.dark .schedule-modal-wrap{background:#0a0e1a}
.schedule-modal-overlay.visible .schedule-modal-wrap{transform:translateY(0)}
.schedule-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 28px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.schedule-modal-title{font-size:18px;font-weight:800;color:var(--text);margin:0 0 4px;letter-spacing:-.02em}
.schedule-modal-sub{font-size:13px;color:var(--text-secondary)}
.schedule-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:18px;padding:4px 8px;border-radius:8px;transition:background .15s,color .15s;line-height:1;flex-shrink:0;margin-top:-2px}
.schedule-modal-close:hover{background:var(--hover-bg);color:var(--text)}
/* Iframe renders FULL height so HubSpot's confirm button + form footer are
   never clipped. To hide HubSpot's free-tier "Create your own meeting"
   branding, we overlay a centered bottom strip (::after) that masks just
   the branding link area. pointer-events:none on the overlay so the iframe
   underneath stays interactive in case HubSpot ever moves a button there. */
/* Mask removed — could not distinguish between HubSpot's branding strip
   and the booking-form button row (same bottom edge, cross-origin iframe).
   Hiding branding was clipping Back/Next buttons. Function > fashion.
   Permanent fix: HubSpot Sales Hub Starter ($15/mo) removes branding
   natively. Until then, the strip stays visible. */
.schedule-modal-body{flex:1;overflow:hidden;min-height:680px;position:relative}
.schedule-modal-iframe{width:100%;height:100%;min-height:680px;border:none;display:block}
.schedule-modal-trust{display:flex;align-items:center;justify-content:center;gap:24px;padding:14px 28px;border-top:1px solid var(--border);flex-shrink:0;font-size:12px;color:var(--text-muted);font-weight:600;flex-wrap:wrap;gap:16px}

@media(max-width:600px){
  .schedule-modal-wrap{max-height:95vh;border-radius:16px}
  .schedule-modal-header{padding:18px 20px 16px}
  .schedule-modal-trust{gap:12px;font-size:11px}
}

/* Pipeline / Deliverability */
.table-wrap{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--bg-card)}
.stage-pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border:1px solid var(--border);background:var(--bg-card-hover);color:var(--text-secondary)}
.stage-research{background:rgba(120,120,120,.12);color:var(--text-secondary)}
.stage-contacted{background:rgba(59,130,246,.12);color:#3b82f6;border-color:rgba(59,130,246,.3)}
.stage-replied{background:rgba(168,85,247,.14);color:#a855f7;border-color:rgba(168,85,247,.3)}
.stage-booked{background:rgba(34,197,94,.14);color:#22c55e;border-color:rgba(34,197,94,.3)}
.stage-met{background:rgba(34,197,94,.22);color:#16a34a;border-color:rgba(34,197,94,.4)}
.stage-disqualified{background:rgba(239,68,68,.12);color:#ef4444;border-color:rgba(239,68,68,.3)}
.chip{padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.chip:hover{background:var(--bg-card-hover);color:var(--text-primary)}
.chip.active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}
.stage-select{padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border:1px solid var(--border);background:var(--bg-card-hover);color:var(--text-secondary);cursor:pointer;outline:none;font-family:inherit}
.stage-select:hover{border-color:var(--accent)}
.stage-select.stage-research{background:rgba(120,120,120,.12)}
.stage-select.stage-contacted{background:rgba(59,130,246,.12);color:#3b82f6;border-color:rgba(59,130,246,.3)}
.stage-select.stage-replied{background:rgba(168,85,247,.14);color:#a855f7;border-color:rgba(168,85,247,.3)}
.stage-select.stage-booked{background:rgba(34,197,94,.14);color:#22c55e;border-color:rgba(34,197,94,.3)}
.stage-select.stage-met{background:rgba(34,197,94,.22);color:#16a34a;border-color:rgba(34,197,94,.4)}
.stage-select.stage-disqualified{background:rgba(239,68,68,.12);color:#ef4444;border-color:rgba(239,68,68,.3)}

/* Prospect drawer */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:998;animation:fadeIn .15s ease}
.drawer-panel{position:fixed;top:0;right:0;bottom:0;width:min(520px,100%);background:var(--bg-primary);border-left:1px solid var(--border);z-index:999;display:flex;flex-direction:column;animation:slideInRight .2s ease}
@keyframes slideInRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.drawer-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--border);gap:16px}
.drawer-close{background:transparent;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:4px 10px;border-radius:6px}
.drawer-close:hover{background:var(--bg-card-hover)}
.drawer-body{flex:1;overflow-y:auto;padding:20px 28px 40px}
.drawer-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.drawer-label{font-size:11px;text-transform:uppercase;opacity:.6;letter-spacing:.05em;margin-bottom:4px}
.timeline{margin-top:10px;display:flex;flex-direction:column;gap:12px}
.timeline-row{display:flex;gap:12px;padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);align-items:flex-start}
@media(max-width:600px){.drawer-panel{width:100%}.drawer-grid{grid-template-columns:1fr}}

/* ═══ In-app UI: Toast + Modal (replaces browser alert/confirm) ═══ */
.ui-toast-stack{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;pointer-events:none;max-width:calc(100vw - 40px)}
.ui-toast{pointer-events:auto;min-width:280px;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;gap:12px;align-items:flex-start;box-shadow:0 18px 50px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.08);backdrop-filter:blur(16px);animation:uiToastIn .32s cubic-bezier(.2,1.1,.3,1);font-size:14px;color:var(--text);line-height:1.45}
.ui-toast.leaving{animation:uiToastOut .24s ease forwards}
.ui-toast-icon{flex:0 0 22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;margin-top:1px}
.ui-toast-success .ui-toast-icon{background:rgba(52,211,153,.15);color:var(--green)}
.ui-toast-error   .ui-toast-icon{background:rgba(255,100,100,.15);color:var(--red,#f87171)}
.ui-toast-info    .ui-toast-icon{background:rgba(212,165,116,.15);color:var(--accent)}
.ui-toast-body{flex:1;min-width:0}
.ui-toast-title{font-weight:600;margin-bottom:2px}
.ui-toast-msg{color:var(--text-secondary);font-size:13px;white-space:pre-wrap;word-wrap:break-word}
.ui-toast-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:2px 6px;border-radius:6px;font-size:14px;line-height:1;opacity:.7}
.ui-toast-close:hover{opacity:1;background:var(--bg-card-hover)}
@keyframes uiToastIn{from{opacity:0;transform:translateX(40px) scale(.96)}to{opacity:1;transform:none}}
@keyframes uiToastOut{to{opacity:0;transform:translateX(40px) scale(.96)}}

.ui-modal-overlay{position:fixed;inset:0;background:rgba(8,10,20,.55);backdrop-filter:blur(8px);z-index:9999;display:grid;place-items:center;padding:20px;opacity:0;transition:opacity .22s ease}
.ui-modal-overlay.visible{opacity:1}
.ui-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:28px;max-width:440px;width:100%;box-shadow:0 30px 80px rgba(0,0,0,.28);transform:scale(.96) translateY(8px);transition:transform .24s cubic-bezier(.2,1.1,.3,1);color:var(--text)}
.ui-modal-overlay.visible .ui-modal{transform:none}
.ui-modal-title{font-size:18px;font-weight:700;margin:0 0 8px;letter-spacing:-.01em}
.ui-modal-body{font-size:14px;color:var(--text-secondary);line-height:1.55;margin:0 0 22px;white-space:pre-wrap}
.ui-modal-actions{display:flex;gap:10px;justify-content:flex-end}
.ui-btn{padding:10px 18px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:transform .12s,background .12s,border-color .12s;font-family:inherit}
.ui-btn:active{transform:translateY(1px)}
.ui-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.ui-btn-primary:hover{filter:brightness(1.08)}
.ui-btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}
.ui-btn-danger:hover{filter:brightness(1.08)}
.ui-btn-ghost{background:transparent;color:var(--text);border-color:var(--border)}
.ui-btn-ghost:hover{background:var(--bg-card-hover);border-color:var(--text-secondary)}

/* ═══ Sleek Pipeline / action toolbar ═══ */
.action-bar{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 22px;align-items:center}
.action-bar .act{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:10px;font-size:13px;font-weight:600;border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;transition:transform .12s,background .12s,border-color .12s,box-shadow .12s;font-family:inherit;white-space:nowrap}
.action-bar .act:hover{background:var(--bg-card-hover);border-color:var(--text-secondary);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.06)}
.action-bar .act:active{transform:translateY(0)}
.action-bar .act[disabled]{opacity:.55;cursor:not-allowed;transform:none}
.action-bar .act-primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent);box-shadow:0 1px 2px rgba(0,0,0,.25)}
.action-bar .act-primary:hover{filter:brightness(1.08);border-color:var(--accent)}
.action-bar .act-ico{font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;opacity:.85;font-size:14px;line-height:1}

/* ═══ MOBILE POLISH PASS (Apr 2026) ═══
   Fixes surfaced by the 390px mobile audit: metric letter-spacing, scarcity
   badge wrap, hero stats column, traffic-light dots, footer toggle dedup,
   balanced hero headline wrap. Appended at end so these override earlier
   rules without churning the whole file. */

/* Proof-metric values render with visible gaps around . and , on mobile because
   the Space Mono monospace font treats punctuation as a full-width cell. Switch
   to the primary sans at mobile and lock to tabular-nums so columns still align. */
@media(max-width:640px){
  .proof-metric .pm-value,.pdc-value,.metric-value{
    font-family:'Inter Tight',sans-serif !important;
    font-variant-numeric:tabular-nums;
    letter-spacing:-.02em;
  }
}

/* Scarcity pill on mobile: the desktop inline-flex layout splits the sentence
   into uneven columns ("Only" / bold / trailing) and drops a stray period
   before "We". Block layout + normal wrap = one clean sentence. */
@media(max-width:640px){
  .scarcity-line{
    display:flex !important;align-items:flex-start;
    flex-wrap:nowrap;
    white-space:normal;
    text-align:left;
    max-width:100%;
  }
  .scarcity-line .scarcity-pulse{margin-top:6px}
}

/* Hero stats: at ≤480 the three tiles fall 2+1 — lonely third row looks
   like an accident. Single vertical stack with centered text gives each
   stat equal weight and makes them readable on narrow screens. */
@media(max-width:480px){
  .home-hero-stats{
    flex-direction:column !important;
    align-items:stretch;
    gap:12px !important;
    padding:20px 0 !important;
  }
  .home-stat{
    text-align:center;
    padding:12px 0 !important;
    border-left:0 !important;
    border-top:1px solid var(--border);
  }
  .home-hero-stats > .home-stat:first-child{border-top:0}
}

/* Traffic-light window-chrome dots on the hero dashboard mock add zero
   information on mobile and steal vertical space. Hide on narrow screens. */
@media(max-width:480px){
  .proof-dashboard .proof-dot{display:none}
  .proof-dashboard .proof-header{padding-top:10px;padding-bottom:10px}
}

/* Dedup: the header has a theme toggle. The footer-bottom one is redundant
   on mobile and competes with the sticky CTA bar for thumb space. Hide it
   at ≤768px — desktop keeps it as a discoverability aid. */
@media(max-width:768px){
  .pub-footer-bottom .theme-toggle{display:none}
}

/* Balanced wrap on the hero title. Browsers that support text-wrap:balance
   will avoid the "with" dangling alone on line 2. Older browsers fall back
   to default wrapping — no harm. */
.home-hero-title{text-wrap:balance}

/* Founder video + social proof grid: 2-up on desktop, stacked on mobile. */
@media(max-width:768px){
  .founder-video-grid{grid-template-columns:1fr !important;gap:16px !important}
  .founder-video-grid > .glow-card:first-child{min-height:200px}
}

/* ════════════════════════════════════════════════════════════
   EDITORIAL REFINEMENT LAYER
   Applied after all original rules — small global polish to
   make the type, numerics, and focus states feel deliberate.
   Restraint over decoration: this layer is intentionally short.
   ═══════════════════════════════════════════════════════════ */

/* Tabular numerics — line up dashboard numbers in tables and metric cards */
.metric-value,.plan-price,.stat-value,.testimonial-metric,
.proof-metric .pm-value,.roi-result .roi-big,.roi-input-group .roi-value,
.chart-label,.calendar-hour,.mono,.data-table td[data-numeric],
.user-avatar,.avatar-sm,.avatar-md,.proof-avatar{
  font-variant-numeric:tabular-nums;
  font-feature-settings:'tnum','zero','ss01';
}

/* Display headings — tighten letter-spacing for editorial feel */
h1,h2,h3,h4{font-family:'Inter Tight',sans-serif;letter-spacing:-.02em;font-weight:600}
h1{letter-spacing:-.035em}
h2{letter-spacing:-.028em}

/* Eyebrow / overline labels: monospace small-caps for that
   Linear/Vercel "we ship software" credibility */
.metric-label,.plan-recommended-tag,.plan-best-tag,
.compare-table th,.data-table th,.calendar-header,
.roi-input-group label{
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-weight:500;
  letter-spacing:.08em;
}

/* Refined focus rings — accent outline at 2px, 3px offset */
button:focus-visible,a:focus-visible,
input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
  border-radius:6px;
}

/* Inputs: lighter borders, tighter radius, no native focus glow */
input[type=text],input[type=email],input[type=tel],input[type=number],
input[type=password],input[type=search],input[type=url],textarea,select{
  font-family:'Inter Tight',sans-serif;
  letter-spacing:-.005em;
}
input:not([type=range]):not([type=checkbox]):not([type=radio]):focus,
textarea:focus,select:focus{
  outline:none;
  border-color:var(--accent);
}

/* Restraint: kill remaining decorative @keyframes by making them
   no-op. The classes that still reference them silently flatten. */
@keyframes glowPulse{0%,100%{box-shadow:none}}
@keyframes borderGlow{0%,100%{border-color:var(--border)}}
@keyframes gradientShift{0%,100%{background-position:0 0}}
@keyframes shimmer{0%,100%{background-position:0 0}}

/* Card hover: slimmer lift, no orange glow */
.glow-card:hover{border-color:var(--border-hover);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.18)}
body.light .glow-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.06)}

/* Body text: nudge line-height slightly for editorial breath */
p{line-height:1.55}

/* Universal reduced-motion guard — respects OS accessibility */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .fade-in,.slide-up,.slide-left,.slide-right,.scale-in,.blur-in,.bounce-in,.swoop-in{
    opacity:1 !important;transform:none !important;
  }
}

/* ════════════════════════════════════════════════════════════
   EDITORIAL LAYER 02 — hand-built moments
   Magazine-style refinements: corner ticks, ledger marks,
   colophon footer, asymmetric hero metadata. Pure CSS, no
   markup changes. Layered on top of edit-01 tokens.
   ═══════════════════════════════════════════════════════════ */

/* Hero metadata strip — appears under the hero title via .hero-section::after.
   Mono uppercase: edition, locale, vertical. Feels like a magazine masthead. */
.hero-section{position:relative}
.hero-section::after{
  content:"VOL. 01  /  B2B LEAD GENERATION  /  SANFORD, FL  —  EST. 2026";
  display:block;
  margin-top:48px;padding-top:18px;
  border-top:1px solid var(--border);
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-muted);
  max-width:880px;
}
@media(max-width:640px){
  .hero-section::after{font-size:9px;letter-spacing:.16em;margin-top:32px}
}

/* Corner ticks on cards — tiny L-marks at top-left and bottom-right of
   .glow-card and .metric-card. Same look as printer registration marks
   or magazine page corners. Pure pseudo-element, no markup change. */
.glow-card,.metric-card,.plan-card,.proof-dashboard,.industry-card,
.objection-card,.roi-calc,.setup-fee-card{position:relative}
.glow-card::before,.metric-card::before,.plan-card::before,
.proof-dashboard::before,.industry-card::before,.roi-calc::before,
.setup-fee-card::before{
  content:"";position:absolute;top:-1px;left:-1px;width:8px;height:8px;
  border-top:1px solid var(--accent);border-left:1px solid var(--accent);
  opacity:.45;pointer-events:none;
}
.glow-card::after,.metric-card::after,.plan-card::after,
.proof-dashboard::after,.industry-card::after,.roi-calc::after,
.setup-fee-card::after{
  content:"";position:absolute;bottom:-1px;right:-1px;width:8px;height:8px;
  border-bottom:1px solid var(--accent);border-right:1px solid var(--accent);
  opacity:.45;pointer-events:none;
}
/* Objection card has its own left-border rule — only top-right tick */
.objection-card::before{display:none}
.objection-card::after{
  content:"";position:absolute;top:-1px;right:-1px;width:8px;height:8px;
  border-top:1px solid var(--accent);border-right:1px solid var(--accent);
  opacity:.45;pointer-events:none;bottom:auto;left:auto;
}

/* Footer rebuilt as a magazine colophon */
.pub-footer{
  padding:80px 40px 32px;
  border-top:1px solid var(--border);
  background:var(--bg);
  position:relative;
}
.pub-footer::before{
  /* Big mono masthead at the top of footer */
  content:"SETORRA";
  position:absolute;top:-1px;left:50%;transform:translateX(-50%) translateY(-50%);
  padding:0 24px;background:var(--bg);
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10px;letter-spacing:.4em;color:var(--text-muted);
}
.pub-footer-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:64px;
  padding-bottom:48px;
  border-bottom:1px solid var(--border);
}
.pub-footer-brand p{
  font-size:14px;color:var(--text-secondary);line-height:1.55;
  margin:14px 0 0;max-width:300px;
}
.pub-footer-col h4{
  font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-muted);margin:0 0 18px;
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}
.pub-footer-col a{
  display:block;font-size:14px;color:var(--text);text-decoration:none;
  margin-bottom:10px;transition:color .18s ease;letter-spacing:-.005em;
}
.pub-footer-col a:hover{color:var(--accent)}
.pub-footer-bottom{
  max-width:1100px;margin:24px auto 0;padding-top:0;border-top:none;
  display:flex;align-items:flex-start;justify-content:space-between;
  flex-wrap:wrap;gap:16px;
}
.pub-footer-bottom p{
  font-size:11px;color:var(--text-muted);margin:0;
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  letter-spacing:.14em;text-transform:uppercase;
}
/* Colophon line — appears as a second row in the footer bottom */
.pub-footer-bottom::after{
  content:"VOL. 01  /  ISSUE 01  /  B2B LEAD GENERATION & APPOINTMENT SETTING  /  SANFORD, FL  /  EST. 2026  —  TYPESET IN INTER TIGHT + JETBRAINS MONO";
  display:block;width:100%;order:99;
  margin-top:24px;padding-top:18px;
  border-top:1px dashed var(--border);
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-muted);opacity:.7;
}
@media(max-width:880px){
  .pub-footer{padding:64px 24px 24px}
  .pub-footer-inner{grid-template-columns:1fr 1fr;gap:32px}
  .pub-footer-bottom::after{font-size:8px;letter-spacing:.14em}
}
@media(max-width:520px){
  .pub-footer-inner{grid-template-columns:1fr;gap:32px}
  .pub-footer-bottom::after{display:none}
}

/* Big numerals — make dashboard metric values feel magazine-bold */
.metric-card .metric-value{font-size:38px;font-weight:500;letter-spacing:-.025em}
.proof-metric .pm-value{font-size:36px;font-weight:500;letter-spacing:-.025em}
.testimonial-metric{font-size:64px;font-weight:500;letter-spacing:-.035em}
.roi-result .roi-big{font-size:42px;font-weight:500;letter-spacing:-.025em}

/* Pricing — refined numerals, less swagger */
.plan-price{font-weight:500;letter-spacing:-.035em}
.plan-price.sub{font-weight:500}

/* Cards: tighter radius, hairline border (no fuzzy box-shadow on dark) */
.glow-card,.metric-card,.proof-dashboard,.industry-card,.roi-calc,
.setup-fee-card,.plan-card,.pricing-note{border-radius:10px}
body.dark .glow-card,body.dark .metric-card,body.dark .proof-dashboard,
body.dark .industry-card,body.dark .roi-calc,body.dark .setup-fee-card{
  box-shadow:none;
}
body.dark .glow-card:hover{box-shadow:none;border-color:var(--accent)}

/* Quiet the recommended plan — no scale, just a hairline accent border */
.plan-card.recommended{transform:none;border-width:1px;border-color:var(--accent)}
.plan-card.recommended:hover{transform:translateY(-2px)}
.plan-recommended-tag,.plan-best-tag{
  letter-spacing:.22em;font-weight:500;font-size:10px;padding:8px;
}

/* Navigation — flatter, more deliberate */
.nav{padding:0 32px}
.nav-inner{height:60px}
.nav-links a{font-size:13px;font-weight:500;letter-spacing:-.005em;transition:color .18s ease}
.nav-links a:hover{color:var(--text)}

/* Sidebar in admin — refined */
.sidebar-brand{font-weight:600;letter-spacing:-.025em}
.sidebar-nav button{font-weight:500;letter-spacing:-.005em;font-size:13px;padding:10px 14px;border-radius:6px}

/* Dashboard topbar metadata — small mono at the bottom-right edge */
.topbar{padding:14px 28px}
.topbar-back{font-size:12px;letter-spacing:.04em}

/* Section: hairline above each section (subtle, only on standalone .section) */
section.section + section.section{
  border-top:1px solid var(--border);
}

/* Eyebrow alignment in cta-section (centered text) */
.cta-section .section-tag{justify-content:center}
.cta-section .section-tag::after{display:none}

/* Body link defaults — accent on hover only */
a{color:inherit;transition:color .18s ease}

/* Small print refinement */
small,.fineprint{font-size:11px;letter-spacing:.04em;color:var(--text-muted)}

/* ════════════════════════════════════════════════════════════
   MOTION LAYER 03 — tasteful, premium animation
   Strengthens scroll reveals and adds signature micro-interactions
   (underline draw, CTA sheen, nav underline, card lift, ambient hero
   wash). Editorial easing, modest travel — alive, not slop. The
   prefers-reduced-motion guard above flattens ALL of this.
   ═══════════════════════════════════════════════════════════ */

/* 1. Cinematic scroll reveals — more travel + premium ease-out + stagger */
.fade-in{opacity:0;transform:translateY(22px);transition:opacity .65s cubic-bezier(.16,1,.3,1),transform .65s cubic-bezier(.16,1,.3,1)}
.fade-in.visible{opacity:1;transform:none}
.slide-up{opacity:0;transform:translateY(36px);transition:opacity .72s cubic-bezier(.16,1,.3,1),transform .72s cubic-bezier(.16,1,.3,1)}
.slide-up.visible{opacity:1;transform:none}
.slide-left{opacity:0;transform:translateX(36px);transition:opacity .72s cubic-bezier(.16,1,.3,1),transform .72s cubic-bezier(.16,1,.3,1)}
.slide-left.visible{opacity:1;transform:none}
.slide-right{opacity:0;transform:translateX(-36px);transition:opacity .72s cubic-bezier(.16,1,.3,1),transform .72s cubic-bezier(.16,1,.3,1)}
.slide-right.visible{opacity:1;transform:none}
.scale-in{opacity:0;transform:scale(.95);transition:opacity .65s cubic-bezier(.16,1,.3,1),transform .65s cubic-bezier(.16,1,.3,1)}
.scale-in.visible{opacity:1;transform:none}
.blur-in{opacity:0;filter:blur(10px);transform:translateY(18px);transition:opacity .75s ease,filter .75s ease,transform .75s cubic-bezier(.16,1,.3,1)}
.blur-in.visible{opacity:1;filter:none;transform:none}
.swoop-in{opacity:0;transform:translateY(30px);transition:opacity .72s ease,transform .72s cubic-bezier(.16,1,.3,1)}
.swoop-in.visible{opacity:1;transform:none}

/* 2. Hero — ambient warm wash that drifts slowly behind the headline.
   One subtle gradient (NOT the old glow orbs). Sits under z-index:1 content. */
.home-hero{position:relative;overflow:hidden}
.home-hero::before{
  content:"";position:absolute;inset:-20% -10% auto -10%;height:80%;z-index:0;pointer-events:none;
  background:radial-gradient(50% 60% at 78% 0%, var(--accent-dim), transparent 72%);
  opacity:.7;animation:heroDrift 16s ease-in-out infinite alternate;
}
@keyframes heroDrift{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(-4%,3%,0) scale(1.08)}}

/* 3. Signature: accent underline draws in under the hero gradient phrase */
.home-hero-title .gradient-text{position:relative;display:inline-block}
.home-hero-title .gradient-text::after{
  content:"";position:absolute;left:0;bottom:-4px;height:2px;width:100%;
  background:var(--accent);border-radius:2px;
  transform:scaleX(0);transform-origin:left;
  animation:drawLine 1s cubic-bezier(.16,1,.3,1) .65s forwards;
}
@keyframes drawLine{to{transform:scaleX(1)}}

/* 4. Eyebrow star — barely-there breathing, signals "alive" without gimmick */
.home-hero-eyebrow span:first-child{display:inline-block;animation:starBreathe 4s ease-in-out infinite}
@keyframes starBreathe{0%,100%{opacity:.65}50%{opacity:1}}

/* 5. Primary CTAs — one-pass sheen sweep on hover (display:block beats the
   shimmer-btn::after{display:none} from the refinement layer) */
.home-hero-cta::after,.cta-btn::after{
  content:"";display:block;position:absolute;top:0;left:-130%;width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.22),transparent);
  transform:skewX(-18deg);pointer-events:none;
}
.home-hero-cta,.cta-btn{position:relative;overflow:hidden}
.home-hero-cta:hover::after,.cta-btn:hover::after{animation:ctaSheen .85s ease}
@keyframes ctaSheen{from{left:-130%}to{left:150%}}

/* 6. Nav links — underline slides in from left on hover */
.pub-nav-links a,.nav-links a{position:relative}
.pub-nav-links a::after,.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-5px;height:1px;width:100%;
  background:var(--accent);transform:scaleX(0);transform-origin:right;
  transition:transform .3s cubic-bezier(.16,1,.3,1);
}
.pub-nav-links a:hover::after,.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}

/* 7. Cards — refined hover lift with accent border (no fuzzy glow) */
.glow-card,.metric-card,.industry-card,.plan-card{transition:transform .32s cubic-bezier(.16,1,.3,1),border-color .25s ease,box-shadow .3s ease}
.glow-card:hover,.industry-card:hover{transform:translateY(-3px);border-color:var(--accent)}

/* 8. Stat values — gentle rise as they reveal (paired with home-hero-stats) */
.home-hero-stats .home-stat{transition:transform .5s cubic-bezier(.16,1,.3,1)}
.home-hero-stats:hover .home-stat{transform:translateY(-2px)}

/* 9. Buttons everywhere — consistent press feedback */
button,.btn-primary,.btn-secondary,.home-hero-secondary{transition:transform .15s ease,border-color .18s ease,background .18s ease,color .18s ease,filter .18s ease}
.home-hero-secondary:hover{transform:translateY(-1px);border-color:var(--accent);color:var(--accent)}
button:active{transform:translateY(1px)}

/* 10. Section eyebrow hairline — slow shimmer to draw the eye (very subtle) */
.section-tag::after{position:relative;overflow:hidden}



