/* ══ FONT FALLBACK: size-adjusted system fonts to reduce CLS while web fonts load ══ */
@font-face { font-family:'Satoshi Fallback'; src:local('BlinkMacSystemFont'),local('-apple-system'),local('Segoe UI'),local('Arial'); size-adjust:104%; ascent-override:95%; descent-override:22%; line-gap-override:0%; }
@font-face { font-family:'Instrument Serif Fallback'; src:local('Georgia'),local('Times New Roman'); size-adjust:108%; ascent-override:90%; descent-override:25%; line-gap-override:0%; }
@font-face { font-family:'Fira Code Fallback'; src:local('Menlo'),local('Consolas'),local('Monaco'); size-adjust:100%; ascent-override:90%; }
/* ═══════════════════════════════════════════════
   CV ARCHITECT PRO v4 — DUAL THEME DESIGN SYSTEM
   Dark: Deep navy · Lime accent · IBM Mono
   Light: Warm parchment · Forest green · Serif
   ═══════════════════════════════════════════════ */
/* ── DARK THEME TOKENS ── */
[data-theme="dark"] {
  --bg:        #09090b;
  --s1:        #18181b;
  --s2:        #27272a;
  --s3:        #3f3f46;
  --s4:        #52525b;
  --s5:        #71717a;
  --nav-bg:    rgba(9,9,11,0.82);
  --border:    rgba(255,255,255,0.08);
  --border2:   rgba(255,255,255,0.12);
  --border3:   rgba(255,255,255,0.16);
  --ink:       #fafafa;
  --ink2:      #d4d4d8;
  --muted:     #a1a1aa;
  --muted2:    #71717a;
  --accent:    #4a90d9;
  --accent2:   #6bb3ff;
  --accent-lt: rgba(74,144,217,0.16);
  --accent-mid:rgba(74,144,217,0.28);
  --accent-glow:rgba(74,144,217,0.20);
  --amber:     #FFD54F;
  --amber-lt:  rgba(254,203,0,0.18);
  --gold:      #FECC02;
  --gold-lt:   rgba(254,204,2,0.18);
  --gold-mid:  rgba(254,204,2,0.28);
  --gold-glow: rgba(254,204,2,0.22);
  --rose:      #fb7185;
  --rose-lt:   rgba(244,63,94,0.18);
  --cyan:      #22d3ee;
  --cyan-lt:   rgba(34,211,238,0.16);
  --violet:    #c4b5fd;
  --violet-lt: rgba(167,139,250,0.18);
  --emerald:   #34d399;
  --before-bg: rgba(254,203,0,0.10);
  --before-brd:rgba(254,203,0,0.24);
  --hl-bg:     rgba(74,144,217,0.20);
  --hl-txt:    #93c5fd;
  --hl-brd:    rgba(74,144,217,0.35);
  --surface-card: var(--s1);
  --shadow:    0 1px 2px rgba(0,0,0,0.3), 0 2px 8px rgba(0,0,0,0.2);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.4), 0 2px 8px rgba(0,0,0,0.3);
  --glow-a:    0 0 0 3px rgba(74,144,217,0.18);
  --font-head: 'Satoshi', 'Satoshi Fallback', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body: 'Satoshi', 'Satoshi Fallback', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'Fira Code', 'Fira Code Fallback', monospace;
  --font-serif:'Instrument Serif', serif;
}
/* ── LIGHT THEME TOKENS ── */
[data-theme="light"] {
  --bg:        #fafafa;
  --s1:        #ffffff;
  --s2:        #f5f5f5;
  --s3:        #e5e5e5;
  --s4:        #d4d4d4;
  --s5:        #a3a3a3;
  --nav-bg:    rgba(255,255,255,0.82);
  --border:    rgba(0,0,0,0.08);
  --border2:   rgba(0,0,0,0.12);
  --border3:   rgba(0,0,0,0.18);
  --ink:       #0a0a0a;
  --ink2:      #404040;
  --muted:     #525252;
  --muted2:    #737373;
  --accent:    #002F6C;
  --accent2:   #4a90d9;
  --accent-lt: rgba(0,47,108,0.08);
  --accent-mid:rgba(0,47,108,0.18);
  --accent-glow:rgba(0,47,108,0.15);
  --amber:     #b8860b;
  --amber-lt:  rgba(184,134,11,0.10);
  --gold:      #b8860b;
  --gold-lt:   rgba(184,134,11,0.10);
  --gold-mid:  rgba(184,134,11,0.20);
  --gold-glow: rgba(184,134,11,0.15);
  --rose:      #be123c;
  --rose-lt:   rgba(190,18,60,0.08);
  --cyan:      #0e7490;
  --cyan-lt:   rgba(14,116,144,0.08);
  --violet:    #6d28d9;
  --violet-lt: rgba(109,40,217,0.08);
  --emerald:   #047857;
  --before-bg: rgba(184,134,11,0.07);
  --before-brd:rgba(184,134,11,0.18);
  --hl-bg:     rgba(0,47,108,0.10);
  --hl-txt:    #002F6C;
  --hl-brd:    rgba(0,47,108,0.25);
  --surface-card: var(--s1);
  --shadow:    0 1px 2px rgba(0,0,0,0.04), 0 2px 8px rgba(0,0,0,0.06);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.04);
  --glow-a:    0 0 0 3px rgba(0,47,108,0.15);
  --font-head: 'Satoshi', 'Satoshi Fallback', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body: 'Satoshi', 'Satoshi Fallback', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'Fira Code', 'Fira Code Fallback', monospace;
  --font-serif:'Instrument Serif', serif;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  transition:background 0.4s ease, color 0.3s ease;
}
/* DARK GRAIN TEXTURE */
[data-theme="dark"] body::before {
  content:'';
  position:fixed;
  inset:0;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:0;
  opacity:0.6;
}
[data-theme="dark"] body::after {
  content:'';
  position:fixed;
  inset:0;
  background:radial-gradient(ellipse 900px 700px at 15% 10%,rgba(74,144,217,0.03) 0%,transparent 70%),radial-gradient(ellipse 700px 600px at 85% 85%,rgba(167,139,250,0.02) 0%,transparent 70%);
  pointer-events:none;
  z-index:0;
}
/* ══ SKIP LINK — WCAG 2.4.1 ══ */
.skip-nav {
  position:absolute;top:-100px;left:16px;
  background:var(--accent);color:#fff;padding:12px 20px;min-height:44px;font-size:14px;font-weight:700;
  z-index:9999;border-radius:0 0 8px 8px;text-decoration:none;
  transition:top 0.15s;
  /* WCAG 2.2: focus indicator must have 3:1 contrast & min 2px outline */
  outline:3px solid transparent;
}
.skip-nav:focus { top:0;outline:3px solid #fff;outline-offset:2px; }
/* ══ GLOBAL FOCUS RING — WCAG 2.4.11 & 2.4.12 ══
   Minimum area: perimeter ≥ 2×component perimeter
   Contrast: ≥ 3:1 against adjacent colours         */
:focus-visible {
  outline:2px solid var(--accent);
  outline-offset:2px;
}
/* Remove browser default outline only when we supply our own */
:focus:not(:focus-visible) { outline:none; }
/* High-contrast override for elements on dark nav background */
.site-nav :focus-visible {
  outline:2px solid var(--accent);
  outline-offset:2px;
}
.site-nav .btn-profile:focus-visible,
.site-nav .btn-theme:focus-visible {
  outline:2px solid var(--accent);
  outline-offset:2px;
}
/* ══ TOUCH TARGETS — WCAG 2.5.8 (min 24×24, best-practice 44×44) ══ */
.btn-theme {
  width:44px;height:44px;border-radius:10px;border:1px solid var(--border);
  background:var(--s2);color:var(--muted);font-size:16px;
  cursor:pointer;transition:all 0.2s;display:grid;place-items:center;flex-shrink:0;
}
.btn-theme:hover { background:var(--s3);border-color:var(--border2);color:var(--ink); }
.btn-up {
  background:var(--accent);color:#fff;border:none;padding:12px 24px;border-radius:10px;
  font-family:var(--font-body);font-size:12px;font-weight:800;cursor:pointer;
  transition:all 0.2s;white-space:nowrap;letter-spacing:0.01em;min-height:44px;
}
[data-theme="light"] .btn-up { color:#fff;background:var(--accent); }
.btn-up:hover { transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,47,108,0.15),0 8px 24px rgba(74,144,217,0.2); }
[data-theme="light"] .btn-up:hover { box-shadow:0 4px 16px rgba(0,47,108,0.12),0 8px 24px rgba(0,47,108,0.1); }
.site-nav {
  background:var(--nav-bg);
  position:sticky; top:0; z-index:100;
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
}
.nav-inner {
  max-width:1200px; margin:0 auto; padding:0 32px;
  display:flex; align-items:center; height:56px; gap:0;
}
/* LOGO */
.logo { display:flex;align-items:center;gap:11px;text-decoration:none;flex-shrink:0;margin-right:24px;min-height:44px; }
.logo-gem {
  width:34px; height:34px; border-radius:8px;
  display:grid; place-items:center; flex-shrink:0;
  font-family:var(--font-serif); font-size:13px; font-style:italic;
  background:var(--accent); color:var(--bg); font-weight:400;
  transition:background 0.3s;
}
[data-theme="dark"] .logo-gem { background:var(--accent); color:#fff; }
[data-theme="light"] .logo-gem { background:var(--accent); color:#fff; }
.logo-text { font-family:var(--font-head); font-size:14px; font-weight:700; letter-spacing:-0.03em; color:var(--ink); white-space:nowrap; }
.logo-text em { color:var(--accent); font-style:normal; font-weight:800; }
.logo-badge { font-family:var(--font-mono); font-size:8.5px; text-transform:uppercase; letter-spacing:0.12em; color:var(--gold); margin-top:2px; }
/* STEPPER */
.stepper { display:flex;align-items:center;gap:0;flex:1;justify-content:center; }
.stp-btn {
  display:flex;align-items:center;gap:10px;padding:10px 16px;min-height:44px;border-radius:10px;
  cursor:pointer;transition:all 0.3s cubic-bezier(.4,0,.2,1);flex-shrink:0;background:transparent;border:none;font-family:var(--font-body);
  position:relative;
}
.stp-btn:hover { background:var(--accent-lt);transform:translateY(-1px); }
.stp-btn:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
.stp-btn.active { background:var(--accent-lt); }
.stp-circle {
  width:30px;height:30px;border-radius:50%;border:2px solid var(--border2);
  display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;font-weight:600;
  color:var(--muted2);transition:all 0.3s cubic-bezier(.4,0,.2,1);flex-shrink:0;
}
.stp-btn.active .stp-circle {
  background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700;
  box-shadow:0 3px 12px rgba(0,47,108,0.25), 0 0 0 3px rgba(0,47,108,0.08);
}
[data-theme="light"] .stp-btn.active .stp-circle {
  color:#fff;background:var(--accent);
  box-shadow:0 3px 12px rgba(0,47,108,0.25), 0 0 0 3px rgba(0,47,108,0.08);
}
.stp-btn.done .stp-circle {
  background:linear-gradient(135deg, var(--gold-lt), var(--gold-mid));
  border-color:var(--gold);color:var(--gold);
  box-shadow:0 2px 8px rgba(183,142,58,0.15);
}
.stp-btn.done .stp-circle::after { content:'✓';font-size:14px;font-weight:700; }
.stp-btn.done .stp-circle span { display:none; }
.stp-label {
  font-size:13px;font-weight:500;color:var(--muted2);white-space:nowrap;
  letter-spacing:0.02em;transition:color 0.3s, font-weight 0.3s;
}
.stp-btn.active .stp-label { color:var(--ink);font-weight:700;letter-spacing:-0.01em; }
.stp-btn.done .stp-label { color:var(--gold);font-weight:600; }
.stp-btn.reachable { cursor:pointer; }
.stp-btn.reachable .stp-circle { border-color:var(--accent);color:var(--accent); }
.stp-btn.reachable .stp-label { color:var(--muted); }
.stp-btn.reachable:hover { background:var(--accent-lt); }
.stp-btn.reachable:hover .stp-label { color:var(--ink); }
.stp-btn:disabled { cursor:default;opacity:0.45; }
.stp-btn:disabled:hover { background:transparent;transform:none; }
.stp-sep.reachable { background:var(--accent);opacity:0.3; }
.stp-sep {
  flex:1;max-width:80px;height:2px;background:var(--border);flex-shrink:1;
  transition:background 0.4s, box-shadow 0.4s;border-radius:1px;
}
.stp-sep.done { background:var(--gold);box-shadow:0 0 6px rgba(183,142,58,0.2); }
/* STEPPER BODY — below pipeline viz */
.stepper-body {
  display:flex !important;
  background:var(--s1);padding:14px 32px;margin:32px auto 20px;
  border-radius:12px;border:1px solid var(--border);
  max-width:720px;justify-content:center;align-items:center;
}
/* Inline stepper — inside screens 2/3/4 */
.stepper-inline { margin:0 auto 24px;max-width:780px; }
@media(max-width:700px){
  .stepper-body{padding:10px 8px;margin:20px auto 12px;max-width:calc(100% - 12px);border-radius:12px;justify-content:space-between;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
  .stepper-body::-webkit-scrollbar{display:none;}
  .stepper-body .stp-btn{padding:5px 5px;gap:5px;min-width:0;flex-shrink:0;}
  .stepper-body .stp-circle{width:24px;height:24px;font-size:9px;border-width:1.5px;}
  .stepper-body .stp-label{font-size:10.5px;letter-spacing:-0.01em;}
  .stepper-body .stp-sep{width:12px;min-width:8px;flex-shrink:0;}
}
/* NAV RIGHT */
.nav-right { margin-left:auto;display:flex;align-items:center;gap:10px;flex-shrink:0; }
.usage-pill {
  font-family:var(--font-mono);font-size:10px;color:var(--muted);
  background:var(--s2);border:1px solid var(--border);
  border-radius:20px;padding:6px 14px;display:flex;align-items:center;gap:6px;white-space:nowrap;
  height:34px;
}
.upulse { width:5px;height:5px;border-radius:50%;background:var(--accent);animation:upulse 2s infinite; }
@keyframes upulse { 0%,100%{opacity:1} 50%{opacity:0.3} }
.btn-theme {
  width:44px;height:44px;border-radius:10px;border:1px solid var(--border);
  background:var(--s2);color:var(--muted);font-size:16px;
  cursor:pointer;transition:all 0.2s;display:grid;place-items:center;flex-shrink:0;
}
.btn-theme:hover { background:var(--s3);border-color:var(--border2);color:var(--ink); }
.btn-theme:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
/* Language picker */
.lang-wrap { position:relative;flex-shrink:0; }
.lang-drop { display:none;position:absolute;top:calc(100% + 8px);right:0;background:var(--s1);border:1px solid var(--border2);border-radius:12px;box-shadow:var(--shadow-lg);z-index:2600;width:280px;max-height:340px;overflow-y:auto;padding:8px;scrollbar-width:thin; }
.lang-drop.open { display:block;animation:slideUp 0.18s ease; }
.lang-drop::-webkit-scrollbar { width:5px; }
.lang-drop::-webkit-scrollbar-thumb { background:var(--border2);border-radius:3px; }
.lang-opt { display:flex;align-items:center;gap:10px;padding:8px 12px;border:none;background:none;width:100%;text-align:left;border-radius:8px;cursor:pointer;font-family:var(--font-body);font-size:13px;color:var(--ink);transition:background 0.15s; }
.lang-opt:hover { background:var(--s3); }
.lang-opt.active { background:var(--accent-lt);color:var(--accent);font-weight:600; }
.lang-opt-flag { font-size:18px;flex-shrink:0;width:24px;text-align:center; }
.lang-opt-name { flex:1; }
.lang-opt-code { font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:0.06em; }
.lang-search { width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--s2);color:var(--ink);font-family:var(--font-body);font-size:12px;margin-bottom:6px;outline:none; }
.lang-search:focus { border-color:var(--accent); }
.lang-search::placeholder { color:var(--muted2); }
.btn-up {
  background:var(--accent);color:#fff;border:none;padding:12px 24px;border-radius:10px;
  font-family:var(--font-body);font-size:12px;font-weight:800;cursor:pointer;
  transition:all 0.2s;white-space:nowrap;letter-spacing:0.01em;
}
[data-theme="light"] .btn-up { color:#fff; background:var(--accent); }
.btn-up:hover { filter:brightness(1.1); box-shadow:0 6px 20px rgba(74,144,217,0.25); }
[data-theme="light"] .btn-up:hover { box-shadow:0 6px 20px rgba(0,47,108,0.25); }
.btn-up:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
/* ── PROFILE BUTTON ── */
.profile-wrap { position:relative; }
.btn-profile {
  width:44px;height:44px;border-radius:50%;border:2px solid var(--border2);
  background:var(--s3);color:var(--ink2);
  display:grid;place-items:center;cursor:pointer;
  transition:all 0.2s;font-size:16px;flex-shrink:0;
  position:relative;
}
.btn-profile:hover { border-color:var(--accent);color:var(--accent);background:var(--accent-lt); }
.btn-profile.authed { background:linear-gradient(135deg,var(--accent),var(--violet));border:2px solid rgba(255,255,255,0.15);color:#fff;font-weight:700;font-size:15px; }
.btn-profile.authed:hover { background:linear-gradient(135deg,var(--accent),var(--violet));border-color:rgba(255,255,255,0.4);color:#fff;transform:scale(1.05); }
.btn-profile.open { border-color:var(--accent);background:var(--accent-lt);color:var(--accent); }
.btn-profile.open.authed { background:linear-gradient(135deg,var(--accent),var(--violet));border-color:rgba(255,255,255,0.5);color:#fff; }
.btn-profile:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
.profile-dot {
  position:absolute;top:-2px;right:-2px;width:9px;height:9px;border-radius:50%;
  background:var(--emerald);border:2px solid var(--s1);
}
.profile-dot.pro { background:var(--accent); }
/* ── PROFILE DROPDOWN ── */
.profile-drop {
  display:none;position:absolute;top:calc(100% + 12px);right:0;
  width:300px;background:var(--s1);border:1.5px solid var(--border2);
  border-radius:16px;box-shadow:var(--shadow-lg);z-index:400;
  overflow:hidden;animation:dropIn 0.2s cubic-bezier(0.34,1.3,0.64,1) both;
}
.profile-drop.open { display:block; }
@keyframes dropIn { from{opacity:0;transform:translateY(-8px) scale(0.97)} to{opacity:1;transform:translateY(0) scale(1)} }
.pd-header {
  padding:18px 20px 14px;background:var(--s2);border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:13px;
}
.pd-avatar {
  width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--accent-lt),var(--cyan-lt));
  border:2px solid var(--accent-mid);display:grid;place-items:center;font-size:18px;flex-shrink:0;
}
.pd-name { font-size:13px;font-weight:700;color:var(--ink); }
.pd-email { font-size:11px;color:var(--muted);font-family:var(--font-mono);margin-top:1px; }
.pd-plan-badge {
  margin-left:auto;font-family:var(--font-mono);font-size:9px;font-weight:700;
  padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:0.08em;flex-shrink:0;
}
.pd-plan-free  { background:var(--s4);color:var(--muted);border:1px solid var(--border2); }
.pd-plan-pro   { background:var(--accent-lt);color:var(--accent);border:1px solid var(--accent-mid); }
.pd-plan-career{ background:linear-gradient(135deg,var(--gold-lt),rgba(254,204,2,0.08));color:var(--gold);border:1px solid var(--gold-mid); }
.pd-plan-pass  { background:linear-gradient(135deg,rgba(245,158,11,0.12),rgba(251,191,36,0.12));color:var(--amber);border:1px solid rgba(245,158,11,0.3); }
.pd-usage { padding:14px 20px;border-bottom:1px solid var(--border); }
.pd-usage-lbl { font-family:var(--font-mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:8px;display:flex;justify-content:space-between; }
.pd-usage-lbl span { color:var(--ink2); }
.pd-bar-track { height:5px;background:var(--s4);border-radius:3px;overflow:hidden; }
.pd-bar-fill  { height:100%;border-radius:3px;background:var(--accent);transition:width 0.5s ease; }
.pd-bar-fill.full { background:var(--rose); }
.pd-usage-note { font-size:10.5px;color:var(--muted);font-family:var(--font-mono);margin-top:7px; }
.pd-section { padding:8px 10px; }
.pd-row {
  display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;
  cursor:pointer;transition:background 0.15s;text-decoration:none;
  border:none;background:none;width:100%;text-align:left;
}
.pd-row:hover { background:var(--s3); }
.pd-row-ico { width:28px;height:28px;border-radius:7px;background:var(--s3);display:grid;place-items:center;font-size:13px;flex-shrink:0; }
.pd-row-txt { font-size:12.5px;color:var(--ink);font-family:var(--font-body);font-weight:500; }
.pd-row-sub { font-size:10.5px;color:var(--muted);font-family:var(--font-mono);margin-top:1px; }
.pd-row-arr { margin-left:auto;color:var(--muted2);font-size:11px; }
.pd-row.accent .pd-row-ico { background:var(--accent-lt); }
.pd-row.accent .pd-row-txt { color:var(--accent); }
.pd-row.accent .pd-row-arr { color:var(--accent); }
.pd-row.danger .pd-row-ico { background:var(--rose-lt); }
.pd-row.danger .pd-row-txt { color:var(--rose); }
.pd-divider { height:1px;background:var(--border);margin:4px 10px; }
.pd-footer {
  padding:12px 20px;background:var(--s2);border-top:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.pd-footer-note { font-size:10px;color:var(--muted2);font-family:var(--font-mono);line-height:1.5; }
.pd-upgrade-btn {
  margin-left:auto;flex-shrink:0;background:var(--accent);color:#fff;border:none;
  padding:7px 14px;border-radius:8px;font-size:11px;font-weight:700;
  font-family:var(--font-body);cursor:pointer;transition:all 0.2s;white-space:nowrap;
}
.pd-upgrade-btn:hover { filter:brightness(1.1); }
.pd-upgrade-btn.hidden { display:none; }
/* ══════════════════ PROOF BAR ══════════════════ */
/* ── PROOF BAR — Social proof strip ── */
.proof-bar { background:var(--s2);border-bottom:1px solid var(--border);padding:14px 0;overflow:hidden; }
.proof-inner { max-width:1200px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:center;gap:16px 28px;flex-wrap:wrap; }
.proof-item { display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);flex-shrink:0;font-family:var(--font-mono);letter-spacing:0.01em; }
.proof-val { font-family:var(--font-head);font-size:14px;font-weight:800;color:var(--gold);letter-spacing:-0.02em; }
[data-theme="dark"] .proof-val { color:var(--gold); }
.proof-sep { width:4px;height:4px;border-radius:50%;background:var(--border3);flex-shrink:0; }
/* ══════════════════ LOADING OVERLAY ══════════════════ */
/* ── Loading Modal (Pipeline Progress) ── */
.load-ov {
  display:none;position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,0.45);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  align-items:center;justify-content:center;
  padding:24px;
  animation:modalBdIn 0.3s ease both;
}
[data-theme="dark"] .load-ov { background:rgba(0,0,0,0.6); }
@keyframes modalBdIn{from{opacity:0}to{opacity:1}}
.load-ov.on { display:flex; }
.load-ov.fade-out { animation:loadOvOut 0.45s ease forwards; pointer-events:none; }
@keyframes loadOvOut{from{opacity:1}to{opacity:0}}

/* Modal card */
.load-modal {
  background:var(--bg);
  border:1.5px solid var(--border);
  border-radius:24px;
  padding:36px 32px 28px;
  width:560px;max-width:92vw;max-height:88vh;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;
  box-shadow:0 24px 80px rgba(0,0,0,0.12),0 0 0 1px rgba(255,255,255,0.05) inset;
  display:flex;flex-direction:column;gap:24px;
  position:relative;
  animation:modalCardIn 0.35s cubic-bezier(0.34,1.56,0.64,1) both;
}
.load-modal::-webkit-scrollbar{display:none}
[data-theme="dark"] .load-modal { box-shadow:0 24px 80px rgba(0,0,0,0.4),0 0 0 1px rgba(255,255,255,0.04) inset; }
.load-spinner{display:flex;justify-content:center;padding:16px 0 4px;}
.load-spinner::after{content:'';width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:loadSpin 0.8s linear infinite;}
@keyframes loadSpin{to{transform:rotate(360deg)}}
@keyframes modalCardIn{from{opacity:0;transform:translateY(16px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.load-modal::before {
  content:'';position:absolute;top:0;left:0;right:0;height:120px;
  background:linear-gradient(160deg,var(--accent-lt) 0%,transparent 70%);
  border-radius:24px 24px 0 0;pointer-events:none;opacity:0.6;
}
[data-theme="dark"] .load-modal::before { opacity:0.15; }
.load-modal>* { position:relative;z-index:1; }

/* Modal header */
.load-modal-header { text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px; }
.lm-icon-wrap {
  width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--accent-lt),color-mix(in srgb,var(--accent) 12%,transparent));
  border:1.5px solid color-mix(in srgb,var(--accent) 20%,transparent);
  margin-bottom:4px;
  animation:iconFloat 3s ease-in-out infinite;
}
@keyframes iconFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.lm-icon { font-size:22px;line-height:1; }
.load-title {
  font-family:var(--font-head);font-size:22px;font-weight:700;
  color:var(--ink);text-align:center;margin:0;line-height:1.3;
}
.load-sub {
  font-family:var(--font-mono);font-size:10px;color:var(--muted);
  text-align:center;letter-spacing:0.1em;text-transform:uppercase;min-height:16px;
}

/* Pipeline nodes row */
.pipeline-nodes { display:flex;align-items:center;gap:0;justify-content:center; }
.pn-node {
  display:flex;flex-direction:column;align-items:center;gap:8px;width:100px;
  transition:all 0.4s;
}
.pn-step {
  font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.10em;
  color:var(--muted2);transition:color 0.4s;
}
.pn-orb {
  width:56px;height:56px;border-radius:50%;
  border:2px solid var(--border2);background:var(--s2);
  display:flex;align-items:center;justify-content:center;font-size:22px;
  transition:all 0.4s;position:relative;
  box-shadow:inset 0 1px 3px rgba(0,0,0,0.06);
}
.pn-node.run .pn-step { color:var(--accent); }
.pn-node.run .pn-orb {
  border-color:var(--accent);background:var(--accent-lt);
  box-shadow:0 0 0 0 var(--accent-glow);
  animation:orbPulse 2s ease-out infinite;
}
@keyframes orbPulse{0%{box-shadow:0 0 0 0 var(--accent-glow)}70%{box-shadow:0 0 0 12px transparent}100%{box-shadow:0 0 0 0 transparent}}
.pn-node.done .pn-step { color:var(--gold); }
.pn-node.done .pn-orb {
  border-color:var(--gold);background:var(--gold-lt);
  box-shadow:0 0 20px var(--gold-glow);
}
.pn-node.done .pn-orb::after {
  content:'';position:absolute;inset:0;border-radius:50%;
  border:2px solid transparent;
  background:linear-gradient(135deg,var(--gold-glow),transparent) border-box;
  -webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0.5;
}
.pn-lbl {
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  color:var(--muted2);text-align:center;letter-spacing:0.06em;
  transition:color 0.4s;
}
.pn-node.run .pn-lbl { color:var(--accent); }
.pn-node.done .pn-lbl { color:var(--gold); }
.pn-conn {
  width:36px;height:3px;background:var(--border);margin-bottom:30px;
  flex-shrink:0;transition:background 0.5s;position:relative;overflow:hidden;border-radius:3px;
}
.pn-conn.lit { background:linear-gradient(90deg,var(--gold),var(--accent)); }
.pn-conn.flow::after {
  content:'';position:absolute;inset:0;border-radius:3px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  animation:flowAnim 1.2s linear infinite;
}
@keyframes flowAnim{from{transform:translateX(-100%)}to{transform:translateX(200%)}}

/* Cancel button */
.load-cancel-btn {
  display:block;margin:18px auto 0;padding:8px 28px;border-radius:8px;
  background:transparent;border:1px solid var(--muted);color:var(--muted);
  font:500 13px/1 var(--font);cursor:pointer;transition:all 0.2s;
  letter-spacing:0.3px;
}
.load-cancel-btn:hover { border-color:var(--rose);color:var(--rose); }
/* Progress bar */
.load-prog-wrap { width:100%; }
.load-prog-track {
  background:var(--border);border-radius:6px;height:5px;
  overflow:hidden;
}
.load-prog-bar {
  height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));
  border-radius:6px;width:0%;transition:width 0.8s ease;
  position:relative;overflow:hidden;
}
.load-prog-bar::after {
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.25) 50%,transparent 100%);
  animation:progShimmer 1.8s ease-in-out infinite;
}
@keyframes progShimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* Feed items — grouped by layer */
.load-feed {
  width:100%;
  display:flex;flex-direction:column;gap:8px;
}
.lf-group {
  border-radius:10px;padding:10px 14px 8px;
  border:1px solid var(--border);background:var(--s2);
  opacity:0.45;transition:all 0.4s ease;
}
.lf-group.active {
  opacity:1;border-color:var(--accent);background:var(--accent-lt);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 10%,transparent);
}
.lf-group.done {
  opacity:0.85;border-color:var(--gold);background:color-mix(in srgb,var(--gold) 5%,var(--s2));
}
.lf-layer-header {
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.1em;
  color:var(--muted2);margin-bottom:4px;display:flex;align-items:center;gap:6px;
  transition:color 0.4s;
}
.lf-layer-num {
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;font-size:9px;font-weight:800;
  background:var(--border);color:var(--muted2);transition:all 0.4s;
}
.lf-group.active .lf-layer-header { color:var(--accent); }
.lf-group.active .lf-layer-num { background:var(--accent);color:#fff; }
.lf-group.done .lf-layer-header { color:var(--gold); }
.lf-group.done .lf-layer-num { background:var(--gold);color:#fff; }
.lf-item {
  font-family:var(--font-mono);font-size:11px;color:var(--muted2);
  display:flex;align-items:center;gap:8px;transition:all 0.3s;padding:3px 0;
  border-left:2px solid transparent;padding-left:8px;
}
.lf-item.on { color:var(--ink);border-left-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);border-radius:0 6px 6px 0;padding:5px 8px; }
.lf-item.ok { color:var(--accent); }
.lf-icon { flex-shrink:0;font-size:11px;width:14px;text-align:center; }

/* Modal responsive */
@media(max-width:600px){
  .load-modal { padding:28px 20px 22px;border-radius:20px; }
  .pn-node { width:72px; }
  .pn-orb { width:44px;height:44px;font-size:18px; }
  .pn-conn { width:20px; }
  .load-title { font-size:18px; }
}
/* ══════════════════ MAIN APP ══════════════════ */
.app { max-width:1200px;margin:0 auto;padding:0 28px;position:relative;z-index:1; }
/* SCREENS */
.screen { display:none; }
.screen.active { display:block;animation:screenIn 0.45s cubic-bezier(0.34,1.3,0.64,1) both; }
@keyframes screenIn { from{opacity:0;transform:translateX(28px)} to{opacity:1;transform:translateX(0)} }
/* ══════════════════ STEP 1 — INTAKE ══════════════════ */
/* ── HERO SECTION — Premium SaaS Landing ── */
.intake-hero { text-align:center;padding:64px 36px 48px;position:relative;overflow:hidden;background:var(--s2);width:100vw;margin-left:calc(-50vw + 50%); }
.intake-hero::before { content:'';position:absolute;inset:0;background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:32px 32px;opacity:0.25;pointer-events:none; }
.intake-hero::after { content:'';position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:800px;height:500px;background:radial-gradient(ellipse,var(--accent-lt) 0%,transparent 70%);pointer-events:none;opacity:0.5;z-index:0; }
/* ── Hero 2-column grid ── */
.hero-grid { display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center;max-width:1280px;margin:0 auto;position:relative;z-index:1; }
.hero-copy { text-align:left; }
.hero-copy .hero-eyebrow { justify-content:flex-start; }
.hero-copy .hero-headline { margin-left:0;margin-right:0; }
.hero-copy .hero-h2 { margin-left:0;margin-right:0;max-width:none; }
.hero-copy .hero-cred { margin-left:0;margin-right:0;max-width:none; }
.hero-video { position:relative;width:100%; }
@media(max-width:900px){
  .hero-grid { grid-template-columns:1fr;gap:32px; }
  .hero-copy { text-align:center; }
  .hero-copy .hero-eyebrow { justify-content:center; }
  .hero-copy .hero-headline { margin-left:auto;margin-right:auto; }
  .hero-copy .hero-h2 { margin-left:auto;margin-right:auto;max-width:800px; }
  .hero-copy .hero-cred { margin-left:auto;margin-right:auto;max-width:800px; }
  .hero-video { max-width:560px;margin:0 auto; }
}
@media(max-width:600px){
  .intake-hero { padding:40px 16px 32px; }
  .hero-grid { gap:24px; }
}
/* ── Lite YouTube Embed — Glass UI ── */
.lite-yt-wrap { position:relative;width:100%;max-width:100%;margin:0 auto;aspect-ratio:16/9;overflow:hidden;border-radius:20px;background:var(--s1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.1);box-shadow:0 8px 32px rgba(0,0,0,0.12),0 2px 8px rgba(0,0,0,0.06),inset 0 1px 0 rgba(255,255,255,0.05);cursor:pointer;transition:all 0.4s cubic-bezier(0.16,1,0.3,1);z-index:2; }
.lite-yt-wrap:hover { border-color:rgba(255,255,255,0.18);box-shadow:0 20px 48px rgba(0,0,0,0.18),0 4px 12px rgba(0,0,0,0.08),inset 0 1px 0 rgba(255,255,255,0.08);transform:translateY(-3px); }
.lite-yt-thumb { position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:1;transform:scale(1); }
.lite-yt-overlay { position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.3),transparent 60%,rgba(0,0,0,0.05));pointer-events:none; }
.lite-yt-play { position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;padding:0; }
.lite-yt-play-circle { position:relative;width:72px;height:72px;border-radius:50%;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(0,0,0,0.15);transition:all 0.3s cubic-bezier(0.16,1,0.3,1); }
.lite-yt-wrap:hover .lite-yt-play-circle { background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.3);transform:scale(1.08);box-shadow:0 8px 32px rgba(0,0,0,0.2); }
.lite-yt-play-icon { width:0;height:0;border-style:solid;border-width:13px 0 13px 23px;border-color:transparent transparent transparent rgba(255,255,255,0.9);margin-left:4px; }
.lite-yt-pulse { position:absolute;width:88px;height:88px;border-radius:50%;background:rgba(255,255,255,0.08);animation:yt-pulse 3s cubic-bezier(0,0,0.2,1) infinite; }
@keyframes yt-pulse { 0%,100%{transform:scale(1);opacity:0.5;} 50%{transform:scale(1.4);opacity:0;} }
.lite-yt-label { position:absolute;bottom:16px;left:16px;z-index:2;font-size:12px;font-weight:600;color:rgba(255,255,255,0.85);background:rgba(255,255,255,0.08);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:6px 14px;border-radius:100px;opacity:0;transition:opacity 0.3s;border:1px solid rgba(255,255,255,0.12); }
.lite-yt-wrap:hover .lite-yt-label { opacity:1; }
.lite-yt-iframe { position:absolute;inset:-2px;width:calc(100% + 4px);height:calc(100% + 4px);border:0;border-radius:20px; }
[data-theme="light"] .lite-yt-wrap { background:rgba(0,0,0,0.03);border:1px solid rgba(0,0,0,0.1);box-shadow:0 8px 32px rgba(0,0,0,0.08),inset 0 1px 0 rgba(255,255,255,0.5); }
[data-theme="light"] .lite-yt-wrap:hover { border-color:rgba(0,0,0,0.15);box-shadow:0 16px 48px rgba(0,0,0,0.12),inset 0 1px 0 rgba(255,255,255,0.6); }
[data-theme="light"] .lite-yt-play-circle { background:rgba(0,0,0,0.06);border:1px solid rgba(0,0,0,0.12); }
[data-theme="light"] .lite-yt-wrap:hover .lite-yt-play-circle { background:rgba(0,0,0,0.1);border-color:rgba(0,0,0,0.18); }
[data-theme="light"] .lite-yt-play-icon { border-color:transparent transparent transparent rgba(0,0,0,0.7); }
[data-theme="light"] .lite-yt-label { background:rgba(0,0,0,0.06);border-color:rgba(0,0,0,0.1);color:rgba(0,0,0,0.7); }
@media(max-width:600px){ .lite-yt-play-circle{width:56px;height:56px} .lite-yt-pulse{width:72px;height:72px} .lite-yt-play-icon{border-width:10px 0 10px 18px} }
[data-theme="dark"] .intake-hero { background:var(--s1); }
[data-theme="dark"] .intake-hero::after { background:radial-gradient(ellipse,rgba(74,144,217,0.06) 0%,transparent 70%);opacity:1; }
.hero-eyebrow { font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;color:var(--accent);text-transform:uppercase;margin-bottom:20px;display:inline-block;text-align:left;padding:10px 22px;border-radius:16px;background:var(--accent-lt);border:1px solid var(--accent-mid);position:relative;z-index:1;line-height:1.8; }
/* hero-eyebrow pseudo-elements removed (unused) */
.hero-h1 { font-family:var(--font-head);font-size:clamp(2.5rem,5vw,3.5rem);font-weight:800;color:var(--ink);letter-spacing:-0.03em;line-height:1.08;margin-bottom:20px;position:relative;z-index:1; }
[data-theme="dark"] .hero-h1 { color:var(--ink); }
.hero-h1 strong { font-style:normal;font-weight:800;color:var(--accent); }
.hero-h1 { background:linear-gradient(135deg,var(--ink) 0%,var(--muted) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.hero-h1 strong { -webkit-text-fill-color:var(--accent); }
.hero-h1 strong em { font-style:italic; }
.hero-headline { font-family:var(--font-head);font-size:clamp(1.8rem,3.6vw,2.8rem);font-weight:800;color:var(--ink);letter-spacing:-0.025em;line-height:1.2;margin-bottom:24px;max-width:920px;margin-left:auto;margin-right:auto;position:relative;z-index:1; }
.hero-headline strong { color:var(--accent);font-weight:800; }
.hero-pillstrip { display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:22px; }
.hero-pill { font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;padding:6px 16px;border-radius:100px;background:var(--s2);border:1.5px solid var(--border);color:var(--muted);transition:all 0.25s; }
.hero-pill:hover { border-color:var(--accent);color:var(--accent); }
.hero-pill-dot { width:4px;height:4px;border-radius:50%;background:var(--border2);flex-shrink:0; }
.hero-cred { font-size:14px;color:var(--muted);max-width:800px;margin:12px auto 0;line-height:1.7;font-style:normal;opacity:0.75;position:relative;z-index:1; }
.hero-h2 { font-family:var(--font-body);font-size:clamp(0.9rem,1.3vw,1.05rem);font-weight:500;color:var(--muted);max-width:800px;margin:0 auto;line-height:1.65;letter-spacing:0;position:relative;z-index:1; }
.hero-h2 strong { color:var(--ink);font-weight:700; }
.h2-layers { color:var(--accent);font-weight:600; }
.h2-ats { color:var(--accent);font-weight:600; }
.h2-rec { color:var(--accent);font-weight:600; }
.h2-short { color:var(--accent);font-weight:600; }
.hero-p { font-size:16px;color:var(--muted);max-width:860px;margin:0 auto;line-height:1.7; }
/* PIPELINE STAGES VISUAL (Step 1) — compact strip */
.pipeline-viz { display:flex;align-items:center;justify-content:center;gap:0;margin:20px 0 36px;flex-wrap:wrap;row-gap:0; }
.pvz-stage {
  display:flex;align-items:center;gap:8px;padding:10px 18px;
  background:var(--s1);border:1.5px solid var(--border);border-radius:12px;
  transition:all 0.25s;cursor:default;flex-shrink:0;
  box-shadow:0 2px 8px rgba(0,0,0,0.03);
}
.pvz-stage:hover { border-color:var(--accent-mid);box-shadow:0 4px 16px rgba(74,144,217,0.08); }
[data-theme="dark"] .pvz-stage:hover { border-color:rgba(74,144,217,0.25); }
.pvz-num { font-family:var(--font-mono);font-size:8px;color:var(--muted2);letter-spacing:0.12em;text-transform:uppercase;display:none; }
.pvz-icon { font-size:16px;flex-shrink:0;display:block;margin-bottom:0; }
.pvz-name { font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--ink);white-space:nowrap; }
.pvz-desc { display:none; }
.pvz-arrow { font-size:14px;color:var(--muted2);padding:0 8px;flex-shrink:0;opacity:0.5; }
/* ── SINGLE-COLUMN INTAKE FLOW ── */
.intake-flow { display:flex;flex-direction:column;gap:0;margin-bottom:24px;max-width:680px;margin-left:auto;margin-right:auto; }
.intake-step {
  display:flex;gap:20px;align-items:flex-start;
  padding:0 0 0 0;
  position:relative;
}
/* connector line between steps */
.intake-step:not(:last-child)::after {
  content:'';position:absolute;left:19px;top:44px;bottom:-4px;width:2px;
  background:linear-gradient(180deg,var(--border2),var(--border));z-index:0;
}
.intake-step.step-done:not(:last-child)::after { background:linear-gradient(180deg,var(--accent-mid),var(--accent)); }
.is-num {
  width:40px;height:40px;border-radius:14px;border:2px solid var(--border2);background:var(--s1);
  display:grid;place-items:center;font-family:var(--font-mono);font-size:13px;font-weight:700;
  color:var(--muted);flex-shrink:0;margin-top:2px;transition:all 0.3s;position:relative;z-index:1;
}
.intake-step.step-active .is-num { border-color:var(--accent);color:#fff;background:var(--accent);box-shadow:0 4px 16px rgba(74,144,217,0.2); }
[data-theme="light"] .intake-step.step-active .is-num { box-shadow:0 4px 16px rgba(0,47,108,0.15); }
.intake-step.step-done .is-num { border-color:var(--gold);background:var(--gold);color:#1a1a00;font-size:15px;border-radius:14px; }
[data-theme="light"] .intake-step.step-done .is-num { color:#1a1a00; }
.is-body { flex:1;padding-bottom:28px; }
.is-label {
  font-family:var(--font-mono);font-size:9.5px;text-transform:uppercase;letter-spacing:0.18em;
  color:var(--muted2);margin-bottom:8px;padding-top:10px;display:flex;align-items:center;gap:10px;
}
.is-label strong { color:var(--ink);font-size:14px;font-family:var(--font-body);font-weight:700;letter-spacing:0;text-transform:none; }
.is-label .is-done-badge { font-family:var(--font-mono);font-size:9px;padding:3px 10px;border-radius:9999px;background:var(--gold-lt);color:var(--gold);border:1px solid var(--gold-mid);display:none; }
.intake-step.step-done .is-done-badge { display:inline-block; }
.is-card { background:var(--s1);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:all 0.25s ease; }
.intake-step.step-active .is-card { border-color:var(--accent-mid);box-shadow:0 4px 20px rgba(0,0,0,0.04); }
[data-theme="dark"] .intake-step.step-active .is-card { box-shadow:0 0 0 1px var(--accent-mid),0 4px 20px rgba(0,0,0,0.15); }
/* MISSING HIGHLIGHT — keyword gap alert */
.miss-alert-banner {
  background:linear-gradient(135deg,var(--rose-lt),var(--amber-lt));
  border:1.5px solid rgba(255,61,110,0.3);
  border-radius:12px;padding:16px 20px;margin-bottom:20px;
  display:flex;align-items:flex-start;gap:14px;
  animation:pulseAlert 2s ease 0.5s 3;
}
@keyframes pulseAlert {
  0%,100%{ box-shadow:0 0 0 0 rgba(255,61,110,0); }
  50%{ box-shadow:0 0 0 6px rgba(255,61,110,0.15); }
}
[data-theme="light"] .miss-alert-banner { border-color:#FECDD3; }
.mab-icon { font-size:24px;flex-shrink:0;margin-top:2px; }
.mab-body { flex:1; }
.mab-title { font-size:13px;font-weight:700;color:var(--rose);margin-bottom:4px; }
[data-theme="light"] .mab-title { color:var(--rose); }
.mab-sub { font-size:12px;color:var(--muted);line-height:1.65; }
.mab-chips { display:flex;flex-wrap:wrap;gap:7px;margin-top:10px; }
/* Pulsing missing chip */
.kw-miss-pulse {
  padding:6px 14px;border-radius:6px;font-family:var(--font-mono);font-size:12px;
  background:var(--rose-lt);border:1.5px solid var(--rose);color:var(--rose);
  cursor:pointer;user-select:none;transition:all 0.2s;
  animation:chipPulse 2s ease infinite;
  display:inline-flex;align-items:center;gap:5px;
}
@keyframes chipPulse {
  0%,100%{ box-shadow:0 0 0 0 rgba(255,61,110,0); }
  50%{ box-shadow:0 0 0 5px rgba(255,61,110,0.2); }
}
.kw-miss-pulse:hover { background:rgba(255,61,110,0.2);transform:scale(1.05); }
.kw-miss-pulse:focus-visible { outline:2px solid var(--rose);outline-offset:2px; }
.kw-miss-pulse.confirmed { background:var(--accent-lt);border-color:var(--accent-mid);color:var(--accent);animation:none; }
.kw-miss-pulse.declined  { background:var(--s3);border-color:var(--border2);color:var(--muted2);animation:none;opacity:0.5; }
/* TABS */
.tab-row { display:flex;gap:4px;border-bottom:none;margin-bottom:20px;padding:4px;background:var(--s2);border-radius:12px; }
.tab-btn {
  flex:1;padding:12px 16px;min-height:44px;border:none;background:transparent;border-bottom:none;
  margin-bottom:0;font-family:var(--font-body);font-size:12px;font-weight:500;
  color:var(--muted);cursor:pointer;transition:all 0.2s;border-radius:9px;
  display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;
}
.tab-btn:hover { color:var(--ink);background:var(--s3); }
.tab-btn.on {
  color:var(--accent);font-weight:700;border-bottom:none;
  background:var(--bg);box-shadow:0 2px 8px rgba(0,0,0,0.06),0 0 0 1px var(--border);
}
[data-theme="light"] .tab-btn.on { color:var(--accent); }
[data-theme="dark"] .tab-btn.on { background:var(--s1); }
.tab-btn:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
.tab-pane { display:none; }
.tab-pane.on { display:block;animation:fadeUp 0.22s ease both; }
@keyframes fadeUp { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
/* DROP ZONE */
.dz {
  border:2px dashed var(--border2);border-radius:16px;padding:40px 24px;
  text-align:center;cursor:pointer;position:relative;transition:all 0.3s;
  background:linear-gradient(160deg,var(--s2) 40%,color-mix(in srgb,var(--accent) 3%,var(--s2)));
}
.dz:hover,.dz.over { border-color:var(--accent);background:linear-gradient(160deg,var(--accent-lt) 0%,var(--s2) 100%);box-shadow:0 0 0 4px rgba(74,144,217,0.08); }
[data-theme="light"] .dz:hover,[data-theme="light"] .dz.over { box-shadow:0 0 0 4px rgba(0,47,108,0.06); }
.dz input[type=file] { position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%; }
.dz-ico { font-size:36px;display:block;margin-bottom:12px;opacity:0.7; }
.dz-h { font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px; }
.dz-p { font-size:11.5px;color:var(--muted);line-height:1.65;margin-bottom:16px;font-family:var(--font-mono); }
.dz-fmts { display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin-bottom:16px; }
.dz-fmt { font-family:var(--font-mono);font-size:9.5px;padding:3px 10px;border-radius:6px;border:1px solid var(--border2);color:var(--muted);background:var(--s1);font-weight:600;transition:all 0.2s; }
.dz:hover .dz-fmt { border-color:var(--accent-mid);color:var(--accent); }
.btn-browse { background:var(--accent);border:none;border-radius:10px;color:#fff;padding:12px 24px;min-height:44px;font-family:var(--font-body);font-size:12px;font-weight:700;cursor:pointer;transition:all 0.2s;box-shadow:0 2px 8px rgba(74,144,217,0.2); }
.btn-browse:hover { filter:brightness(1.08);box-shadow:0 4px 16px rgba(74,144,217,0.3);transform:translateY(-1px); }
/* FILE PREVIEW */
.file-prev { background:var(--s2);border:1.5px solid var(--border);border-radius:10px;padding:13px 16px;display:flex;align-items:center;gap:12px;margin-top:12px; }
.fp-ico { font-size:26px;flex-shrink:0; }
.fp-name { font-size:13px;font-weight:600;color:var(--ink); }
.fp-meta { font-size:10.5px;color:var(--muted);margin-top:2px;font-family:var(--font-mono); }
.fp-rm { margin-left:auto;background:none;border:1px solid var(--border2);color:var(--muted);border-radius:5px;padding:8px 14px;font-size:11px;cursor:pointer;font-family:var(--font-body);transition:all 0.2s;min-height:32px; }
.fp-rm:hover { border-color:var(--rose);color:var(--rose); }
.fp-img { width:52px;height:52px;object-fit:cover;border-radius:6px;border:1px solid var(--border); }
/* FORM FIELDS */
.field { display:flex;flex-direction:column;gap:6px;margin-bottom:16px; }
.field:last-child { margin-bottom:0; }
.lbl { font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);display:flex;justify-content:space-between;align-items:center; }
.lbl .req { color:var(--accent); }
.lbl .cc { font-size:9px;color:var(--muted2); }
.lbl .cc.lit { color:var(--accent); }
textarea, input[type=text] {
  background:var(--bg);border:1.5px solid var(--border);border-radius:12px;
  color:var(--ink);font-family:var(--font-mono);font-size:12px;
  padding:13px 16px;resize:vertical;transition:all 0.25s;outline:none;line-height:1.75;width:100%;
}
textarea:focus, input[type=text]:focus { border-color:var(--accent);box-shadow:0 0 0 3px rgba(74,144,217,0.1);background:var(--s1); }
textarea::placeholder, input::placeholder { color:var(--muted2); }
#jobUrl::placeholder { color:var(--muted2);opacity:0.55; }
/* URL ROW */
.url-row { display:flex;gap:8px; }
.url-row input { flex:1; }
.btn-fetch {
  flex-shrink:0;background:var(--s2);border:1.5px solid var(--border2);border-radius:12px;
  color:var(--ink);font-family:var(--font-body);font-size:12px;font-weight:600;
  padding:0 20px;cursor:pointer;transition:all 0.25s;display:flex;align-items:center;gap:6px;min-height:46px;
}
.btn-fetch:hover { border-color:var(--accent);color:var(--accent);box-shadow:0 2px 8px rgba(74,144,217,0.1); }
.btn-fetch:disabled { opacity:0.4;cursor:not-allowed; }
.fetch-st { font-family:var(--font-mono);font-size:11px;color:var(--muted);margin-top:9px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;line-height:1.65; }
.fst-err { color:var(--rose); }
.fst-ok  { color:var(--emerald); }
.fetch-inline-st { flex-shrink:0;display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;color:var(--muted);padding:0 12px;white-space:nowrap; }
.fetch-inline-st .fis-spinner { width:18px;height:18px;border:2.5px solid var(--border2);border-top-color:var(--cyan);border-radius:50%;animation:fis-spin 0.7s linear infinite; }
.fetch-inline-st.fis-ok { color:var(--emerald); }
.fetch-inline-st.fis-err { color:var(--rose); }
@keyframes fis-spin { to { transform:rotate(360deg); } }
.fetch-err-banner { background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.25);border-radius:8px;padding:10px 14px;margin-bottom:12px;font-family:var(--font-mono);font-size:11px;color:var(--rose);line-height:1.6;display:flex;align-items:center;gap:8px; }
/* JD Review Card */
.jd-review-card { margin-top:14px;border:1.5px solid var(--amber,#d97706);border-radius:10px;padding:16px 18px;background:rgba(217,119,6,0.04);animation:screenIn 0.35s ease both; }
.jd-review-header { display:flex;gap:12px;align-items:flex-start;margin-bottom:14px; }
.jd-review-icon { font-size:22px;flex-shrink:0;margin-top:1px; }
.jd-review-title { font-weight:700;font-size:13px;color:var(--t1);margin-bottom:2px; }
.jd-review-why { font-size:11px;color:var(--muted);font-family:var(--font-mono);line-height:1.5; }
.jd-review-actions { display:flex;flex-wrap:wrap;gap:8px;margin-top:14px; }
.jd-review-confirm { padding:9px 18px;font-size:12px;font-weight:600;border:none;border-radius:8px;cursor:pointer;background:var(--emerald,#059669);color:#fff;font-family:var(--font-mono);touch-action:manipulation;-webkit-tap-highlight-color:transparent; }
.jd-review-confirm:hover { opacity:0.9; }
.jd-review-edit { padding:9px 18px;font-size:12px;font-weight:600;border:1.5px solid var(--border2);border-radius:8px;cursor:pointer;background:var(--bg);color:var(--t1);font-family:var(--font-mono);touch-action:manipulation;-webkit-tap-highlight-color:transparent; }
.jd-review-edit:hover { border-color:var(--accent); }
.jd-review-reject { padding:9px 14px;font-size:11px;border:none;border-radius:8px;cursor:pointer;background:transparent;color:var(--muted);font-family:var(--font-mono);text-decoration:underline;text-underline-offset:2px;touch-action:manipulation;-webkit-tap-highlight-color:transparent; }
.jd-review-reject:hover { color:var(--rose); }
.jd-confirmed-banner { display:flex;align-items:center;gap:8px;margin-top:10px;padding:8px 14px;border-radius:8px;background:rgba(5,150,105,0.06);border:1px solid rgba(5,150,105,0.2);font-size:12px;font-weight:600;font-family:var(--font-mono);color:var(--emerald); }
.jd-review-reopen { margin-left:auto;font-size:10px;color:var(--muted);background:none;border:none;cursor:pointer;text-decoration:underline;font-family:var(--font-mono); }
.jd-review-reopen:hover { color:var(--t1); }
/* EXTRAS CARD */
.extras-card { background:var(--s1);border:1.5px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--shadow);margin-bottom:18px; }
.extras-grid { display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:14px; }
/* PRIVACY NOTE */
.privacy-note { display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:var(--s1);border:1px solid var(--border);border-radius:8px;font-size:10.5px;color:var(--muted);font-family:var(--font-mono);margin-bottom:20px;white-space:nowrap;flex-wrap:nowrap;max-width:720px;margin-left:auto;margin-right:auto; }
/* CTA BUTTONS — Premium SaaS style */
.btn-cta {
  display:inline-flex;align-items:center;gap:10px;
  background:var(--accent);color:#fff;
  border:none;padding:16px 48px;border-radius:10px;font-family:var(--font-body);font-size:15px;
  font-weight:700;cursor:pointer;transition:all 0.2s cubic-bezier(.4,0,.2,1);letter-spacing:-0.01em;position:relative;overflow:hidden;
  box-shadow:0 1px 2px rgba(0,0,0,0.06),0 4px 12px rgba(0,0,0,0.08);
}
[data-theme="dark"] .btn-cta { background:var(--accent);box-shadow:0 1px 2px rgba(0,0,0,0.2),0 4px 16px rgba(74,144,217,0.2); }
[data-theme="light"] .btn-cta { background:var(--accent);color:#fff; }
.btn-cta::before { content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0.1) 0%,transparent 50%);pointer-events:none; }
.btn-cta:hover:not(:disabled) { transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.12),0 8px 32px rgba(74,144,217,0.2); }
[data-theme="dark"] .btn-cta:hover:not(:disabled) { box-shadow:0 4px 16px rgba(0,0,0,0.3),0 8px 32px rgba(74,144,217,0.3); }
[data-theme="light"] .btn-cta:hover:not(:disabled) { box-shadow:0 4px 16px rgba(0,47,108,0.15),0 8px 32px rgba(0,47,108,0.12); }
.btn-cta:disabled { opacity:0.35;cursor:not-allowed;transform:none; }
.btn-cta:focus-visible { outline:2px solid var(--accent);outline-offset:3px; }
.btn-outline {
  display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--ink);
  border:1.5px solid var(--border2);padding:13px 28px;border-radius:10px;
  font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s;
}
.btn-outline:hover { border-color:var(--accent);color:var(--accent); }
.btn-outline:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
.cta-row { display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:12px 0 48px; }
.cta-note { font-size:11.5px;color:var(--muted);font-family:var(--font-mono); }
/* AD ZONE */
.ad-zone { background:var(--s2);border:1px dashed var(--border2);border-radius:10px;padding:14px;text-align:center;font-family:var(--font-mono);font-size:10.5px;color:var(--muted2);margin-bottom:18px; }
.ad-zone a { color:var(--cyan);text-decoration:none; }
.ad-zone a:hover { text-decoration:underline; }
/* ══════════════════ STEP 2 — DIAGNOSIS ══════════════════ */
.diag-hero { text-align:center;padding:40px 0 28px; }
.step-eyebrow { font-family:var(--font-mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);margin-bottom:12px; }
.step-title { font-family:var(--font-serif);font-size:clamp(28px,4vw,48px);font-style:italic;color:var(--ink);letter-spacing:-0.02em;line-height:1.1; }
[data-theme="dark"] .step-title { color:#e8f0ff; }
.step-sub { font-size:14px;color:var(--muted);margin-top:10px;line-height:1.75;max-width:520px;margin-left:auto;margin-right:auto; }
/* SCORE RINGS ROW */
.rings-row { display:flex;gap:14px;flex-wrap:wrap;margin-bottom:20px;justify-content:center;align-items:stretch; }
.ring-card {
  flex:1;min-width:120px;max-width:170px;background:var(--s1);border:1.5px solid var(--border);
  border-radius:16px;padding:20px 14px;text-align:center;display:flex;flex-direction:column;
  align-items:center;gap:6px;box-shadow:var(--shadow);transition:border-color 0.25s,box-shadow 0.25s;
}
.ring-card:hover { border-color:var(--border2);box-shadow:0 4px 16px rgba(0,0,0,0.08); }
.ring-card-hero {
  min-width:150px;max-width:200px;border:1.5px solid var(--accent-mid);
  background:linear-gradient(160deg,var(--s1) 60%,var(--accent-lt));
  box-shadow:0 4px 24px rgba(74,144,217,0.12);
}
.ring-card-hero:hover { border-color:var(--accent);box-shadow:0 6px 32px rgba(74,144,217,0.18); }
.ring-svg { width:100px;height:100px; }
.r-track { fill:none;stroke:var(--s3);stroke-width:9; }
.r-prog { fill:none;stroke-width:9;stroke-linecap:round;transition:stroke-dashoffset 1.6s cubic-bezier(0.34,1.3,0.64,1); }
.r-label { font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted); }
.conf-badge { padding:5px 14px;border-radius:20px;font-family:var(--font-mono);font-size:10px;font-weight:600;border:1px solid;letter-spacing:0.06em;text-transform:uppercase; }
.cb-high { background:var(--accent-lt);color:var(--accent);border-color:var(--accent-mid); }
.cb-med  { background:var(--amber-lt);color:var(--amber);border-color:rgba(255,184,48,0.3); }
.cb-low  { background:var(--rose-lt);color:var(--rose);border-color:rgba(255,61,110,0.3); }
/* SALARY BANNER */
.salary-banner { background:var(--s1);border:1.5px solid var(--border);border-radius:12px;padding:14px 20px;display:flex;align-items:flex-start;gap:12px;font-size:13px;color:var(--ink);margin-bottom:28px;line-height:1.65; }
.salary-ico { font-size:20px;flex-shrink:0;margin-top:1px; }
/* SECTION DIVIDERS */
.diag-divider { height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:8px 0 28px; }
/* DONUT HERO */
.donut-hero {
  display:flex;align-items:center;justify-content:center;gap:48px;padding:40px 48px;flex-wrap:wrap;
  background:linear-gradient(160deg,var(--s1) 40%,var(--accent-lt) 100%);
  border:1.5px solid var(--border);border-radius:20px;
  box-shadow:0 4px 32px rgba(0,0,0,0.04);margin-bottom:32px;
}
[data-theme="dark"] .donut-hero { background:linear-gradient(160deg,var(--s1) 40%,rgba(74,144,217,0.06) 100%); }
.donut-left { display:flex;flex-direction:column;align-items:center;flex-shrink:0; }
.donut-wrap { position:relative;width:200px;height:200px;flex-shrink:0; }
.donut-svg { width:200px;height:200px; }
.d-track { fill:none;stroke:var(--s3);stroke-width:16; }
.d-prog { fill:none;stroke-width:16;stroke-linecap:round;transition:stroke-dashoffset 1.8s cubic-bezier(0.34,1.2,0.64,1),stroke 0.5s; }
.donut-center { position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;pointer-events:none; }
.donut-val { font-family:var(--font-serif);font-size:48px;font-style:italic;line-height:1;transition:color 0.5s; }
[data-theme="dark"] .donut-val { color:#e8f0ff; }
.donut-unit { font-size:13px;font-family:var(--font-mono);color:var(--muted);margin-top:2px; }
.donut-sub { font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--ink);opacity:0.5;margin-top:10px;font-weight:500;text-align:center; }
.score-panel { max-width:320px; }
.score-grade {
  font-family:var(--font-serif);font-size:72px;font-style:italic;line-height:1;margin-bottom:14px;
  display:inline-flex;align-items:center;justify-content:center;
  width:90px;height:90px;border-radius:50%;
  background:var(--accent-lt);
}
[data-theme="dark"] .score-grade { background:rgba(74,144,217,0.1); }
.score-verdict { font-size:13.5px;color:var(--muted);line-height:1.75;margin-bottom:22px; }
.score-stats { display:flex;gap:14px;flex-wrap:nowrap; }
.score-stat {
  text-align:center;background:var(--s1);border:1px solid var(--border);
  border-radius:12px;padding:14px 20px;min-width:90px;flex:1;
  transition:box-shadow 0.2s;
}
[data-theme="dark"] .score-stat { background:var(--s2); }
.score-stat:hover { box-shadow:0 2px 12px rgba(0,0,0,0.06); }
.ss-val { font-family:var(--font-serif);font-size:28px;font-style:italic;line-height:1; }
.ss-lbl { font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted2);margin-top:5px; }
/* REPORT TABS */
/* Unified report section container */
.report-section {
  background:var(--bg);border:1.5px solid var(--border);border-radius:18px;
  box-shadow:0 2px 12px rgba(0,0,0,0.04);margin-bottom:24px;overflow:hidden;
}
[data-theme="dark"] .report-section { box-shadow:0 2px 12px rgba(0,0,0,0.12); }
.report-tab-body { padding:24px; }
.report-tabs {
  display:flex;gap:4px;border-bottom:none;
  margin-bottom:0;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;
  background:var(--s2);border-bottom:1.5px solid var(--border);border-radius:0;
  padding:6px 8px;
}
.report-tabs::-webkit-scrollbar { display:none; }
.rt-btn {
  flex-shrink:0;padding:11px 20px;border:none;background:transparent;
  border-bottom:none;margin-bottom:0;
  font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;
  transition:all 0.2s;display:flex;align-items:center;gap:8px;white-space:nowrap;
  border-radius:10px;
}
.rt-btn:hover { color:var(--ink);background:var(--s3); }
.rt-btn.on {
  color:var(--accent);font-weight:700;border-bottom:none;
  background:var(--bg);box-shadow:0 2px 8px rgba(0,0,0,0.08),0 0 0 1px var(--border);
}
[data-theme="light"] .rt-btn.on { color:var(--accent); }
[data-theme="dark"] .rt-btn.on { background:var(--s1); }
.rt-btn:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
.rt-badge { font-family:var(--font-mono);font-size:11px;padding:3px 10px;border-radius:20px;font-weight:700; }
.rtb-a { background:var(--accent-lt);color:var(--accent); }
.rtb-b { background:var(--amber-lt);color:var(--amber); }
.rtb-c { background:var(--rose-lt);color:var(--rose); }
.rtb-d { background:var(--cyan-lt);color:var(--cyan); }
.rtb-e { background:var(--violet-lt);color:var(--violet); }
.rtb-f { background:linear-gradient(135deg,var(--violet-lt),var(--accent-lt));color:var(--violet);font-weight:700; }
/* BENCHMARK */
.bench-rank-box{text-align:center;padding:28px 20px;background:linear-gradient(135deg,var(--violet-lt),var(--accent-lt));border:1.5px solid var(--accent-mid);border-radius:16px;margin-bottom:24px}
.bench-rank-num{font-size:56px;font-weight:800;background:linear-gradient(135deg,var(--violet),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.bench-rank-lbl{font-size:14px;color:var(--muted);margin-top:6px;font-weight:500}
.bench-insight{padding:16px 20px;background:var(--s1);border:1.5px solid var(--border);border-radius:12px;margin-bottom:24px;font-size:13px;line-height:1.7;color:var(--ink)}
.bench-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
@media(max-width:700px){.bench-grid{grid-template-columns:1fr}}
.bench-card{background:var(--s1);border:1.5px solid var(--border);border-radius:14px;padding:20px;position:relative;overflow:hidden}
.bench-card.user-card{border-color:var(--accent-mid);box-shadow:0 0 0 2px var(--accent-lt)}
.bench-card-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);margin-bottom:10px;font-weight:600}
.bench-card-profile{font-size:12px;color:var(--muted2);line-height:1.5;margin-bottom:14px;min-height:36px}
.bench-scores{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.bench-score-row{display:flex;align-items:center;gap:8px;font-size:11px}
.bench-score-lbl{width:60px;font-family:var(--font-mono);color:var(--muted);font-size:10px;text-transform:uppercase}
.bench-score-bar{flex:1;height:8px;background:var(--s2);border-radius:4px;overflow:hidden}
.bench-score-fill{height:100%;border-radius:4px;transition:width 0.6s ease}
.bench-score-val{width:32px;font-family:var(--font-mono);font-weight:700;font-size:11px;text-align:right}
.bench-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.bench-chip{padding:3px 8px;border-radius:5px;font-size:10px;font-family:var(--font-mono)}
.bench-chip-g{background:var(--accent-lt);color:var(--accent);border:1px solid var(--accent-mid)}
.bench-chip-r{background:var(--rose-lt);color:var(--rose);border:1px solid var(--rose)}
.bench-chip-a{background:var(--amber-lt);color:var(--amber);border:1px solid var(--amber)}
.bench-edge-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:900px){.bench-grid,.bench-cards-grid{grid-template-columns:repeat(2,1fr)!important}}
@media(max-width:700px){.bench-edge-grid{grid-template-columns:1fr}}
.bench-edge-box{padding:16px;background:var(--s1);border:1.5px solid var(--border);border-radius:12px}
.bench-edge-title{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);margin-bottom:10px;font-weight:600}
.bench-gate{text-align:center;padding:48px 24px}
.bench-gate-ico{font-size:48px;margin-bottom:16px}
.bench-gate-title{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:8px}
.bench-gate-sub{font-size:13px;color:var(--muted);margin-bottom:20px;line-height:1.6}
.report-tab-pane { display:none; }
.report-tab-pane.on { display:block;animation:fadeUp 0.3s ease both; }
/* KW INTELLIGENCE STAT PILLS */
.ki-pills { display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px; }
.ki-pill { display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:8px;font-family:var(--font-mono);font-size:11px;font-weight:600; }
.ki-matched { background:var(--accent-lt);color:var(--accent); }
.ki-semantic { background:var(--cyan-lt);color:var(--cyan); }
.ki-missing { background:var(--rose-lt);color:var(--rose); }
.ki-emphasise { background:var(--amber-lt);color:var(--amber); }
.ki-boolean { background:var(--s3);color:var(--muted); }
/* QW / IA CARDS */
.qw-card,.ia-card { background:var(--s1);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 12px 12px 0;padding:14px 18px;margin-bottom:10px;transition:box-shadow 0.2s;font-size:13px;line-height:1.7;color:var(--ink);display:flex;align-items:flex-start; }
.ia-card { border-left-color:var(--cyan); }
.qw-card:hover,.ia-card:hover { box-shadow:0 2px 12px rgba(0,0,0,0.06); }
.qw-num,.ia-num { display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;border-radius:6px;font-family:var(--font-mono);font-size:10px;font-weight:700;margin-right:12px;flex-shrink:0;margin-top:2px; }
.qw-num { background:var(--accent-lt);color:var(--accent); }
.ia-num { background:var(--cyan-lt);color:var(--cyan); }
/* KEYWORD CHIPS */
.kw-cols { display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px; }
.kw-panel { background:var(--s1);border:1.5px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow); }
.kwp-hdr { padding:14px 20px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--ink); }
.kwp-count { margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--muted); }
.kwp-body { padding:16px 18px;min-height:100px; }
.kw-chips { display:flex;flex-wrap:wrap;gap:7px; }
.kw { padding:6px 14px;border-radius:6px;font-family:var(--font-mono);font-size:12px;border:1px solid;transition:all 0.2s;cursor:default;user-select:none; }
.kw-green { background:var(--accent-lt);border-color:var(--accent-mid);color:var(--accent); }
.kw-cyan  { background:var(--cyan-lt);border-color:rgba(0,229,255,0.2);color:var(--cyan); }
[data-theme="light"] .kw-cyan  { border-color:#BAE0FD;color:var(--cyan); }
.kw-red   { background:var(--rose-lt);border-color:rgba(255,61,110,0.3);color:var(--rose);cursor:pointer; }
[data-theme="light"] .kw-red { border-color:#FECDD3; }
.kw-red:hover { filter:brightness(1.05);box-shadow:0 2px 8px rgba(190,18,60,0.15); }
.kw-red:focus-visible { outline:2px solid var(--rose);outline-offset:2px; }
.kw-amber { background:var(--amber-lt);border-color:rgba(255,184,48,0.3);color:var(--amber); }
[data-theme="light"] .kw-amber { border-color:#FDE68A; }
.kw-violet { background:var(--violet-lt);border-color:rgba(124,92,252,0.3);color:var(--violet); }
.kw-grey  { background:var(--s3);border-color:var(--border2);color:var(--muted); }
.kw-confirmed { background:var(--accent-lt);border-color:var(--accent-mid);color:var(--accent); }
.kw-legend { font-size:11px;color:var(--muted2);font-family:var(--font-mono);margin-top:12px;line-height:1.75; }
/* SKILL POPOVER */
.skill-pop {
  display:none;position:fixed;z-index:9600;background:var(--s1);border:1.5px solid var(--border2);
  border-radius:12px;box-shadow:var(--shadow-lg);padding:18px 20px;width:248px;
  animation:popIn 0.2s cubic-bezier(0.34,1.56,0.64,1) both;
}
.skill-pop.on { display:block; }
@keyframes popIn { from{opacity:0;transform:scale(0.88) translateY(5px)} to{opacity:1;transform:scale(1) translateY(0)} }
.sp-skill { font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--ink);margin-bottom:8px;text-align:center; }
.sp-q { font-size:13px;color:var(--muted);text-align:center;margin-bottom:16px;line-height:1.55; }
.sp-btns { display:flex;gap:8px; }
.sp-yes { flex:1;background:var(--accent);border:none;padding:9px;border-radius:8px;font-family:var(--font-body);font-size:13px;font-weight:700;cursor:pointer;transition:all 0.2s; }
[data-theme="dark"] .sp-yes { color:#fff; }
[data-theme="light"] .sp-yes { color:#fff; }
.sp-yes:hover { filter:brightness(1.1); }
.sp-no { flex:1;background:var(--s3);color:var(--muted);border:1.5px solid var(--border2);padding:9px;border-radius:8px;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s; }
.sp-no:hover { border-color:var(--rose);color:var(--rose); }
.sp-context { margin-bottom:14px; }
.sp-input { width:100%;padding:8px 10px;border:1.5px solid var(--border2);border-radius:8px;font-family:var(--font-body);font-size:12px;background:var(--bg);color:var(--ink);outline:none;transition:border-color 0.2s; }
.sp-input:focus { border-color:var(--accent-mid); }
.sp-hint { font-size:10px;color:var(--muted2);margin-top:4px; }
.skill-added-toast { position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:10px 20px;border-radius:10px;font-family:var(--font-body);font-size:13px;font-weight:600;z-index:700;box-shadow:var(--shadow-lg);animation:toastIn .3s ease,toastOut .3s ease 2.5s forwards; }
@keyframes toastIn { from{opacity:0;transform:translateX(-50%) translateY(20px)} to{opacity:1;transform:translateX(-50%) translateY(0)} }
@keyframes toastOut { to{opacity:0;transform:translateX(-50%) translateY(20px)} }
/* SECTION TITLE */
.sec-title { font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.14em;color:var(--ink);padding-bottom:10px;border-bottom:1.5px solid var(--border);margin-bottom:16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-weight:600; }
.stag { padding:2px 9px;border-radius:20px;font-size:9.5px;border:1px solid;font-weight:600; }
.stag-a { background:var(--accent-lt);color:var(--accent);border-color:var(--accent-mid); }
.stag-b { background:var(--amber-lt);color:var(--amber);border-color:rgba(255,184,48,0.3); }
.stag-c { background:var(--rose-lt);color:var(--rose);border-color:rgba(255,61,110,0.3); }
.stag-d { background:var(--cyan-lt);color:var(--cyan);border-color:rgba(0,229,255,0.2); }
.stag-e { background:var(--violet-lt);color:var(--violet);border-color:rgba(124,92,252,0.3); }
/* PANEL CARD */
.panel-card { background:var(--s1);border:1.5px solid var(--border);border-radius:16px;padding:22px 24px;margin-bottom:18px;box-shadow:var(--shadow);transition:border-color 0.2s; }
.panel-card:hover { border-color:var(--border2); }
/* Preview / Paywall blur overlay */
.preview-blur-wrap { position:relative;overflow:hidden; }
.preview-blur-wrap .preview-blur-content { filter:blur(4px);user-select:none;pointer-events:none; }
.preview-blur-overlay { position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(180deg,transparent 0%,var(--bg) 60%);z-index:2;padding:20px;text-align:center; }
.preview-blur-overlay .pbo-icon { font-size:28px;margin-bottom:8px; }
.preview-blur-overlay .pbo-text { font-size:13px;font-weight:600;color:var(--ink);margin-bottom:4px; }
.preview-blur-overlay .pbo-sub { font-size:11px;color:var(--muted);margin-bottom:12px; }
.preview-blur-overlay .pbo-btn { display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font-body); }
.preview-blur-overlay .pbo-btn:hover { filter:brightness(1.1); }
/* ATS FORMAT GRID */
.ats-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:10px;margin-bottom:14px; }
.ats-item { background:var(--s2);border:1px solid var(--border);border-radius:8px;padding:12px 14px;display:flex;align-items:center;gap:9px; }
.ats-ico { font-size:15px;flex-shrink:0; }
.ats-lbl { font-size:11.5px;color:var(--muted);font-family:var(--font-mono); }
.ats-status { margin-left:auto;font-family:var(--font-mono);font-size:9px;padding:2px 8px;border-radius:20px;white-space:nowrap; }
.as-pass { background:var(--accent-lt);color:var(--accent); }
.as-fail { background:var(--rose-lt);color:var(--rose); }
.as-warn { background:var(--amber-lt);color:var(--amber); }
/* KNOCKOUT LIST */
.ko-list { display:flex;flex-direction:column;gap:9px; }
.ko-item { background:var(--s2);border:1px solid var(--border);border-radius:8px;padding:13px 16px;display:flex;align-items:flex-start;gap:11px; }
.ko-badge { font-family:var(--font-mono);font-size:9px;padding:3px 9px;border-radius:4px;flex-shrink:0;margin-top:1px;white-space:nowrap; }
.kob-p { background:var(--accent-lt);color:var(--accent); }
.kob-f { background:var(--rose-lt);color:var(--rose); }
.kob-u { background:var(--amber-lt);color:var(--amber); }
.ko-text { font-size:12px;color:var(--muted);line-height:1.6;font-family:var(--font-mono); }
.ko-text strong { color:var(--ink);display:block;margin-bottom:3px;font-size:12.5px; }
/* DENSITY BARS */
.density-row { display:flex;align-items:center;gap:12px;padding:9px 13px;background:var(--s2);border:1px solid var(--border);border-radius:7px;margin-bottom:7px; }
.dr-kw { font-family:var(--font-mono);font-size:11px;color:var(--ink);min-width:130px;flex-shrink:0; }
.dr-bar { flex:1;height:6px;background:var(--s3);border-radius:4px;overflow:hidden; }
.dr-fill { height:100%;border-radius:4px;transition:width 1.2s ease; }
.drf-opt { background:var(--accent); }
.drf-low { background:var(--amber); }
.drf-high { background:var(--rose); }
.dr-tag { font-family:var(--font-mono);font-size:9px;padding:2px 7px;border-radius:20px;white-space:nowrap; }
/* CHARTS */
.charts-2 { display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px; }
.charts-3 { display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-bottom:18px; }
.chart-card { background:var(--s1);border:1px solid var(--border);border-radius:16px;padding:20px 22px;box-shadow:var(--shadow); }
.chart-card.full { grid-column:1/-1; }
.cc-title { font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:0.12em;color:var(--ink);margin-bottom:16px;display:flex;align-items:center;gap:8px;font-weight:600; }
.cc-title::before { content:'';display:inline-block;width:3px;height:12px;background:var(--accent);border-radius:2px;flex-shrink:0; }
/* SIX SECOND BOX */
.six-sec-box { background:linear-gradient(135deg,var(--accent-lt),var(--cyan-lt));border:1px solid var(--accent-mid);border-radius:12px;padding:20px 24px;margin-bottom:18px;position:relative;overflow:hidden; }
.six-sec-box::before { content:'"6-second scan"';position:absolute;top:12px;right:16px;font-family:var(--font-mono);font-size:9px;color:var(--muted2);letter-spacing:0.1em;text-transform:uppercase; }
.six-sec-label { font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.14em;color:var(--accent);margin-bottom:10px; }
.six-sec-text { font-family:var(--font-serif);font-size:15px;font-style:italic;line-height:1.8;color:var(--ink2); }
[data-theme="dark"] .six-sec-text { color:var(--ink); }
/* TRAJ BARS */
.traj-row { display:flex;align-items:center;gap:10px;margin-bottom:10px; }
.traj-role { font-family:var(--font-mono);font-size:10.5px;color:var(--muted);min-width:200px;flex-shrink:0; }
.traj-bar { flex:1;height:8px;background:var(--s3);border-radius:4px;overflow:hidden; }
.traj-fill { height:100%;border-radius:4px;background:linear-gradient(90deg,var(--violet),var(--cyan));transition:width 1.2s ease; }
.traj-dur { font-family:var(--font-mono);font-size:9.5px;color:var(--muted2);min-width:60px;text-align:right; }
/* STAR TRANSFORMS */
.star-card { background:var(--s2);border:1px solid var(--border);border-radius:10px;padding:15px 18px;margin-bottom:12px;overflow:hidden; }
.star-before-lbl { font-family:var(--font-mono);font-size:8.5px;text-transform:uppercase;letter-spacing:0.12em;color:var(--amber);margin-bottom:7px; }
.star-before { font-size:12px;color:var(--muted);padding:10px 12px;background:var(--before-bg);border:1px solid var(--before-brd);border-radius:6px;margin-bottom:8px;line-height:1.65;font-family:var(--font-mono);font-style:italic; }
.star-arr { text-align:center;font-size:14px;color:var(--accent);margin:4px 0; }
.star-after-lbl { font-family:var(--font-mono);font-size:8.5px;text-transform:uppercase;letter-spacing:0.12em;color:var(--accent);margin-bottom:7px; }
.star-after { font-size:12.5px;color:var(--ink);padding:10px 12px;background:var(--accent-lt);border:1px solid var(--accent-mid);border-radius:6px;line-height:1.65;font-family:var(--font-mono); }
/* HOPPING FLAG */
.hop-alert { background:var(--amber-lt);border:1px solid rgba(255,184,48,0.3);border-radius:9px;padding:14px 16px;margin-bottom:10px;display:flex;gap:11px;align-items:flex-start;font-size:12px;color:var(--muted);line-height:1.7;font-family:var(--font-mono); }
/* INFO/WARN BOXES */
.info-box { background:var(--cyan-lt);border:1px solid rgba(0,229,255,0.2);border-radius:9px;padding:13px 16px;font-size:12.5px;color:var(--cyan);line-height:1.7;margin-bottom:14px;display:flex;gap:10px; }
[data-theme="light"] .info-box { border-color:#BAE0FD;color:var(--cyan); }
.warn-box { background:var(--rose-lt);border:1px solid rgba(255,61,110,0.25);border-radius:9px;padding:13px 16px;font-size:12.5px;line-height:1.7;margin-bottom:14px;display:flex;gap:10px; }
[data-theme="dark"] .warn-box { color:#ff9ab5; }
[data-theme="light"] .warn-box { color:var(--rose); }
/* TIP LIST */
.tip-list { list-style:none;display:flex;flex-direction:column;gap:8px; }
.tip-list li { display:flex;gap:11px;font-size:13px;line-height:1.65;padding:11px 14px;background:var(--s2);border:1px solid var(--border);border-radius:7px;align-items:flex-start; }
.tip-n { font-family:var(--font-mono);font-size:10px;color:var(--muted2);flex-shrink:0;padding-top:2px;min-width:20px; }
/* COVER LETTER */
.cover-block { background:var(--s1);border:1.5px solid var(--border);border-left:3px solid var(--violet);border-radius:10px;padding:24px 26px;font-family:var(--font-serif);font-size:14px;font-style:italic;line-height:1.95;color:var(--ink);margin-bottom:12px; }
/* ══════════════════ STEP 3 — WORKSHOP ══════════════════ */
.workshop-hdr { padding:32px 0 22px;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap; }
.wh-left .eyebrow { font-family:var(--font-mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:8px; }
.wh-left h2 { font-family:var(--font-serif);font-size:clamp(24px,3.5vw,40px);font-style:italic;color:var(--ink);letter-spacing:-0.02em; }
[data-theme="dark"] .wh-left h2 { color:#e8f0ff; }
.wh-right { display:flex;flex-direction:column;align-items:flex-end;gap:8px; }
.wp-row { display:flex;align-items:center;gap:10px; }
.wp-track { width:200px;height:4px;background:var(--border);border-radius:4px;overflow:hidden; }
.wp-bar { height:100%;background:var(--accent);border-radius:4px;transition:width 0.6s ease; }
.wp-lbl { font-family:var(--font-mono);font-size:11px;color:var(--muted);white-space:nowrap; }
/* SECTION DOTS NAV */
.sec-dots { display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:20px; }
.sec-dot { width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border2);background:var(--s1);display:grid;place-items:center;font-family:var(--font-mono);font-size:10px;color:var(--muted);cursor:pointer;transition:all 0.2s; }
.sec-dot.current { background:var(--ink);border-color:var(--ink); }
[data-theme="dark"] .sec-dot.current { background:var(--ink);color:var(--bg); }
[data-theme="light"] .sec-dot.current { background:var(--ink);color:#fff; }
.sec-dot.ok { background:var(--accent-lt);color:var(--accent);border-color:var(--accent-mid); }
.sec-dot:hover:not(.current) { border-color:var(--ink); }
/* WORKSHOP CARD */
.workshop-card {
  background:var(--s1);border:1.5px solid var(--border);border-radius:16px;
  box-shadow:var(--shadow-lg);overflow:hidden;margin-bottom:20px;
  animation:cardIn 0.4s cubic-bezier(0.34,1.3,0.64,1) both;
}
@keyframes cardIn { from{opacity:0;transform:translateX(24px) scale(0.98)} to{opacity:1;transform:translateX(0) scale(1)} }
.wc-accepted-card { border-color:var(--accent-mid);box-shadow:0 0 0 3px var(--accent-lt),var(--shadow); }
.wcard-hdr { padding:16px 22px;border-bottom:1px solid var(--border);background:var(--nav-bg);display:flex;align-items:center;gap:12px; }
.wch-role { font-size:14px;font-weight:700;color:rgba(255,255,255,0.9);letter-spacing:-0.01em; }
.wch-meta { font-size:11px;color:rgba(255,255,255,0.38);font-family:var(--font-mono);margin-top:1px; }
.wch-st { margin-left:auto;font-family:var(--font-mono);font-size:10px; }
.wchs-ok { color:var(--accent); }
.wchs-pend { color:rgba(255,255,255,0.25); }
/* DIFF PANELS */
.diff-grid { display:grid;grid-template-columns:1fr 1fr; }
.diff-panel { padding:22px; }
.diff-panel:first-child { border-right:1px solid var(--border); }
.diff-lbl { font-family:var(--font-mono);font-size:9.5px;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted2);margin-bottom:13px;display:flex;align-items:center;gap:8px; }
.dl-tag { padding:1px 8px;border-radius:20px;font-size:8.5px;font-weight:600; }
.dl-b { background:var(--before-bg);color:var(--amber);border:1px solid var(--before-brd); }
.dl-a { background:var(--accent-lt);color:var(--accent);border:1px solid var(--accent-mid); }
.diff-before { background:var(--before-bg); }
[data-theme="dark"] .diff-before { background:rgba(255,184,48,0.03); }
.diff-bullets { list-style:none;display:flex;flex-direction:column;gap:8px; }
.diff-bullet { font-family:var(--font-body);font-size:13px;color:var(--ink2);line-height:1.65;padding:8px 12px;border-radius:6px;position:relative;padding-left:20px; }
.diff-bullet::before { content:'–';position:absolute;left:8px;color:var(--muted2); }
.diff-before .diff-bullet { background:rgba(255,255,255,0.3);color:var(--muted);font-style:italic; }
[data-theme="dark"] .diff-before .diff-bullet { background:rgba(255,255,255,0.03); }
.diff-after .diff-bullet { background:var(--s2); }
.diff-hl-note { font-size:10.5px;color:var(--muted2);font-family:var(--font-mono);margin-top:10px; }
/* KEYWORD HIGHLIGHT */
mark.kwhl {
  background:var(--hl-bg);color:var(--hl-txt);border-radius:3px;padding:0 3px;
  font-weight:700;border-bottom:1.5px solid var(--hl-brd);cursor:help;position:relative;
}
mark.kwhl::after {
  content:attr(data-tip);position:absolute;bottom:calc(100% + 7px);left:50%;
  transform:translateX(-50%);background:var(--nav-bg);color:rgba(255,255,255,0.88);
  padding:8px 12px;border-radius:8px;font-size:11px;font-family:var(--font-body);
  font-weight:500;white-space:normal;opacity:0;pointer-events:none;transition:opacity 0.2s;
  z-index:200;box-shadow:0 4px 16px rgba(0,0,0,0.35);max-width:260px;text-align:center;
  font-style:normal;border:1px solid var(--border2);
}
mark.kwhl:hover::after { opacity:1; }
/* KEYWORD SUGGESTIONS SECTION */
.ws-kw-section { padding:14px 22px;border-top:1px solid var(--border);background:var(--s1); }
.ws-kw-title { font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted2);margin-bottom:10px;font-weight:600; }
.ws-kw-chips { display:flex;flex-wrap:wrap;gap:8px; }
.ws-kw-chip { font-size:11.5px!important;padding:5px 12px!important;line-height:1.5!important;cursor:help; }
/* CARD CONTROLS */
.wcard-ctrl { padding:15px 22px;border-top:1px solid var(--border);background:var(--s2);display:flex;align-items:center;gap:10px;flex-wrap:wrap; }
.wc-btn { display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:8px;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s;border:none; }
.wc-btn:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
.wcb-accept { background:var(--accent); }
[data-theme="dark"] .wcb-accept { color:#fff; }
[data-theme="light"] .wcb-accept { color:#fff;background:var(--accent); }
.wcb-accept:hover { filter:brightness(1.08);box-shadow:0 4px 16px rgba(0,47,108,0.2); }
.wcb-regen { background:var(--s1);color:var(--ink);border:1.5px solid var(--border2); }
.wcb-regen:hover { border-color:var(--amber);color:var(--amber); }
.wcb-edit  { background:var(--s1);color:var(--ink);border:1.5px solid var(--border2); }
.wcb-edit:hover { border-color:var(--cyan);color:var(--cyan); }
.wcb-keep  { background:transparent;color:var(--muted);border:1.5px solid var(--border);font-size:12px; }
.wcb-keep:hover { border-color:var(--muted);color:var(--ink); }
.wcb-regen:disabled { opacity:0.4;cursor:not-allowed; }
.wc-accepted-badge { display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;color:var(--accent);font-weight:700; }
.wcb-undo { background:transparent;color:var(--muted);border:1.5px solid var(--border);font-size:12px;padding:6px 12px; }
.wcb-undo:hover { color:var(--ink);border-color:var(--muted); }
.wcb-next { background:var(--s1);color:var(--ink);border:1.5px solid var(--border2);margin-left:auto; }
.wcb-next:hover { border-color:var(--accent);color:var(--accent); }
/* EDIT MODAL */
.edit-modal { display:none;position:fixed;inset:0;background:rgba(0,0,0,0.65);z-index:600;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(6px); }
.edit-modal.on { display:flex; }
.edit-card { background:var(--s1);border:1.5px solid var(--border2);border-radius:16px;padding:28px;max-width:620px;width:100%;box-shadow:var(--shadow-lg);animation:popIn 0.3s ease both; }
.edit-card h3 { font-family:var(--font-serif);font-size:22px;font-style:italic;margin-bottom:6px;color:var(--ink); }
.edit-card p { font-size:12.5px;color:var(--muted);margin-bottom:18px;line-height:1.65; }
.edit-actions { display:flex;gap:10px;margin-top:16px;justify-content:flex-end; }
/* ══════════════════ STEP 4 — EXPORT ══════════════════ */
.export-layout { display:grid;grid-template-columns:1fr 380px;gap:24px;padding:32px 0 60px;align-items:start; }
.a4-wrap { background:var(--s2);border:1.5px solid var(--border);border-radius:16px;padding:20px;box-shadow:var(--shadow); }
.a4-toolbar { display:flex;align-items:center;gap:12px;margin-bottom:16px; }
.a4-tag { font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted);flex:1; }
.a4-frame { background:#fff;width:100%;aspect-ratio:1 / 1.414;border-radius:6px;box-shadow:0 4px 32px rgba(0,0,0,0.2);overflow:hidden; }
[data-theme="light"] .a4-frame { box-shadow:0 4px 32px rgba(26,23,20,0.15); }
.a4-inner { padding:38px 42px;height:100%;overflow-y:auto;font-family:var(--tpl-bfont,'Barlow',sans-serif);font-size:11px;line-height:1.6;color:#1a1714; }
.a4-name { font-size:22px;font-weight:400;color:var(--tpl-accent,#0a3d1e);font-family:var(--tpl-hfont,'Crimson Pro',serif);letter-spacing:-0.01em;margin-bottom:3px; }
.a4-jobt { font-size:11px;text-transform:uppercase;letter-spacing:0.09em;color:#3d3830;margin-bottom:5px;font-family:sans-serif;font-weight:600; }
.a4-contact { font-size:10px;color:#7a7060; }
.a4-hr { border:none;border-top:1.5px solid var(--tpl-accent,#0a3d1e);margin:11px 0 9px; }
.a4-sh { font-size:8px;text-transform:uppercase;letter-spacing:0.18em;color:var(--tpl-accent,#0a3d1e);font-weight:700;margin-bottom:7px;padding-bottom:4px;border-bottom:1px solid #e0dcd5;font-family:sans-serif; }
.a4-summary { font-size:11px;color:#3d3830;line-height:1.7;margin-bottom:11px;font-style:italic; }
.a4-eb { margin-bottom:11px; }
.a4-eh { display:flex;justify-content:space-between;margin-bottom:2px;gap:8px; }
.a4-er { font-size:11px;font-weight:700;color:#1a1714;font-family:sans-serif; }
.a4-ep { font-size:9.5px;color:#7a7060;white-space:nowrap;flex-shrink:0; }
.a4-ec { font-size:9.5px;color:#7a7060;margin-bottom:4px; }
.a4-ul { list-style:none;padding-left:10px; }
.a4-ul li { font-size:10px;color:#3d3830;line-height:1.65;margin-bottom:2px;position:relative;padding-left:10px; }
.a4-ul li::before { content:'–';position:absolute;left:0;color:#0a3d1e; }
.a4-skrow { font-size:10px;color:#3d3830;margin-bottom:3px;display:flex;gap:8px; }
.a4-skrow b { font-weight:700;color:#1a1714;min-width:80px;flex-shrink:0;font-family:sans-serif; }
/* EXPORT SIDEBAR */
.export-panel { display:flex;flex-direction:column;gap:16px;position:sticky;top:78px; }
.ep-card { background:var(--s1);border:1.5px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow); }
.ep-hdr { padding:13px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:9px;background:var(--s2); }
.ep-hdr-title { font-size:12px;font-weight:700;color:var(--ink); }
.ep-body { padding:18px; }
/* FINAL SCORE */
.final-score-row { display:flex;align-items:center;gap:18px;margin-bottom:12px; }
.fsn { font-family:var(--font-serif);font-size:56px;font-style:italic;line-height:1; }
.fsg { font-family:var(--font-serif);font-size:22px;font-style:italic; }
.fsl { font-family:var(--font-mono);font-size:10px;color:var(--muted);margin-top:3px; }
/* ATS CHECKLIST */
.chk-list { list-style:none;display:flex;flex-direction:column;gap:9px; }
.chk-item { display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink2);padding:10px 12px;background:var(--s2);border:1px solid var(--border);border-radius:8px; }
.chk-ico { width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:11px;flex-shrink:0; }
.ci-pass { background:var(--accent-lt);color:var(--accent); }
.ci-warn { background:var(--amber-lt);color:var(--amber); }
.ci-fail { background:var(--rose-lt);color:var(--rose); }
/* DOWNLOAD BUTTONS */
.dl-btns { display:flex;flex-direction:column;gap:10px; }
.btn-dl { background:var(--ink);color:var(--bg);border:none;padding:13px 20px;border-radius:10px;font-family:var(--font-body);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:8px;justify-content:center;transition:all 0.2s;width:100%; }
[data-theme="dark"] .btn-dl { background:var(--accent);color:#fff; }
[data-theme="light"] .btn-dl { background:var(--ink);color:#fff; }
.btn-dl:hover { transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.15),0 8px 24px rgba(0,0,0,0.1); }
.btn-dl-2 { background:var(--s2);color:var(--ink);border:1.5px solid var(--border2);padding:11px 20px;border-radius:10px;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;justify-content:center;transition:all 0.2s;width:100%; }
.btn-dl-2:hover { border-color:var(--accent);color:var(--accent); }
.dl-note { font-size:10.5px;color:var(--muted2);font-family:var(--font-mono);margin-top:10px;line-height:1.7; }
/* AFFILIATE */
.aff-row { display:flex;gap:8px;flex-wrap:wrap;margin-top:12px; }
.aff-a { display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:7px;border:1px solid var(--border2);color:var(--muted);text-decoration:none;font-size:12px;font-family:var(--font-body);transition:all 0.2s;background:var(--s2); }
.aff-a:hover { border-color:var(--gold);color:var(--gold); }
.aff-a:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
/* PRO BANNER (export) */
.pro-banner { background:linear-gradient(135deg,#1a2332,#0f1a12);border-radius:16px;padding:22px;color:#fff; }
.pro-banner h3 { font-family:var(--font-serif);font-size:20px;font-style:italic;margin-bottom:6px;color:#fff; }
.pro-banner p { font-size:12.5px;color:rgba(255,255,255,0.78);line-height:1.65;margin-bottom:16px; }
.btn-pro { background:var(--accent);color:#fff;border:none;padding:11px 20px;border-radius:10px;font-family:var(--font-body);font-size:13px;font-weight:700;cursor:pointer;width:100%;transition:all 0.2s; }
.btn-pro:hover { transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,47,108,0.15),0 8px 24px rgba(74,144,217,0.2); }
/* PRO CTA BAR (inline) */
.pro-cta { background:linear-gradient(135deg,var(--violet-lt),var(--accent-lt));border:1px solid var(--violet);border-radius:16px;padding:22px 24px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin:24px 0; }
.pct-text h3 { font-family:var(--font-head);font-size:14px;font-weight:700;letter-spacing:-0.02em;margin-bottom:4px; }
.pct-text p { font-size:12px;color:var(--muted);line-height:1.65; }
.pct-btn { margin-left:auto;background:var(--violet);color:#fff;border:none;padding:11px 22px;border-radius:10px;font-family:var(--font-body);font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all 0.2s;flex-shrink:0; }
.pct-btn:hover { transform:translateY(-1px);box-shadow:0 4px 16px rgba(124,92,252,0.2),0 8px 24px rgba(124,92,252,0.15); }
/* ══════════════════ MODALS ══════════════════ */
.modal { display:none;position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:2000;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(8px); }
.modal.on { display:flex; }
.modal-card { background:var(--s1);border:1.5px solid var(--border2);border-radius:16px;padding:36px;max-width:500px;width:100%;box-shadow:var(--shadow-lg);animation:popIn 0.3s ease; }
.modal-icon { font-size:44px;text-align:center;margin-bottom:12px; }
.modal-title { font-family:var(--font-serif);font-size:26px;font-style:italic;text-align:center;margin-bottom:10px; }
.modal-sub { font-size:13px;color:var(--muted);text-align:center;line-height:1.7;margin-bottom:0; }
.modal-plans { display:flex;gap:14px;margin:22px 0;flex-wrap:wrap; }
.mplan { flex:1;min-width:130px;background:var(--s2);border:1.5px solid var(--border);border-radius:11px;padding:18px 14px;text-align:center; }
.mplan.feat { border-color:var(--gold); }
[data-theme="light"] .mplan.feat { background:var(--gold-lt); }
.mplan-name { font-family:var(--font-body);font-size:12px;font-weight:700;margin-bottom:8px; }
.mplan-price { font-family:var(--font-serif);font-size:28px;font-style:italic;line-height:1; }
.mplan-freq { font-size:11px;color:var(--muted); }
.mplan ul { list-style:none;margin-top:10px;font-size:10.5px;color:var(--muted);line-height:2;text-align:left;font-family:var(--font-mono); }
.mplan ul li::before { content:'✓ ';color:var(--accent); }
.mplan ul li.no::before { content:'✗ ';color:var(--muted2); }
.modal-dismiss { background:transparent;border:none;color:var(--muted);font-size:12px;cursor:pointer;display:block;width:100%;text-align:center;margin-top:14px;padding:8px;font-family:var(--font-body); }
.modal-dismiss:hover { color:var(--ink); }
/* ── UPGRADE MODAL REDESIGN ── */
.up-card { max-width:620px;padding:32px 28px 24px;position:relative; }
.up-close { position:absolute;top:14px;right:16px;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--s1);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all 0.15s;font-family:var(--font-body);z-index:2; }
.up-close:hover { border-color:var(--rose);color:var(--rose); }
.up-offer-pill { display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,rgba(254,204,2,0.15),rgba(254,204,2,0.08));border:1px solid var(--gold-mid);color:var(--gold);font-size:11px;font-weight:700;letter-spacing:0.04em;padding:5px 14px;border-radius:20px;margin:0 auto 14px;text-align:center;font-family:var(--font-mono);text-transform:uppercase; }
[data-theme="light"] .up-offer-pill { background:linear-gradient(135deg,rgba(254,204,2,0.12),rgba(254,204,2,0.05));color:#b8860b; }
.up-card .modal-title { font-size:24px;margin-bottom:6px; }
.up-card .modal-sub { font-size:12.5px;line-height:1.65;margin-bottom:20px;max-width:440px;margin-left:auto;margin-right:auto; }
.up-plans { display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px; }
.up-plan { background:var(--s2);border:1.5px solid var(--border);border-radius:14px;padding:20px 18px 16px;position:relative;display:flex;flex-direction:column;transition:border-color 0.2s,box-shadow 0.2s; }
.up-plan:hover { border-color:var(--accent-mid);box-shadow:0 8px 24px rgba(74,144,217,0.08); }
.up-pro { border-color:var(--gold); }
[data-theme="light"] .up-pro { background:linear-gradient(180deg,rgba(254,204,2,0.06),var(--s2)); }
[data-theme="dark"] .up-pro { background:linear-gradient(180deg,rgba(254,204,2,0.05),var(--s2)); }
.up-plus { border-color:var(--violet); }
[data-theme="dark"] .up-plus { background:linear-gradient(180deg,rgba(167,139,250,0.06),var(--s2)); }
[data-theme="light"] .up-plus { background:linear-gradient(180deg,rgba(167,139,250,0.05),var(--s2)); }
.up-badge { font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--gold);background:var(--gold-lt);padding:3px 10px;border-radius:5px;display:inline-block;margin-bottom:10px;font-family:var(--font-mono); }
.up-badge-plus { color:var(--violet);background:var(--violet-lt); }
.up-plan-head { margin-bottom:14px; }
.up-plan-name { font-family:var(--font-body);font-size:16px;font-weight:800;color:var(--ink);margin-bottom:6px; }
.up-price-row { display:flex;align-items:baseline;gap:4px;flex-wrap:wrap; }
.up-price-old { font-family:var(--font-serif);font-size:16px;color:var(--muted);text-decoration:line-through;font-style:italic;opacity:0.6; }
.up-price { font-family:var(--font-serif);font-size:32px;font-style:italic;color:var(--ink);line-height:1; }
.up-price-unit { font-size:13px;color:var(--muted);font-weight:500;align-self:flex-end;margin-bottom:4px; }
.up-price-note { font-size:10px;color:var(--muted);font-family:var(--font-mono);margin-top:4px; }
.up-features { list-style:none;padding:0;margin:0 0 16px;flex:1; }
.up-features li { font-size:11.5px;color:var(--ink2);line-height:1.4;padding:3px 0 3px 18px;position:relative;font-family:var(--font-mono); }
.up-features li::before { content:'✓';position:absolute;left:0;color:var(--accent);font-weight:700;font-size:11px; }
.up-btn { width:100%;padding:11px 16px;border:none;border-radius:10px;font-family:var(--font-body);font-size:13px;font-weight:700;cursor:pointer;transition:all 0.2s;color:#fff;position:relative;overflow:hidden; }
.up-btn::before { content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.12),transparent);pointer-events:none; }
.up-btn:hover { transform:translateY(-1px);filter:brightness(1.08); }
.up-btn-pro { background:linear-gradient(135deg,var(--ink),color-mix(in srgb,var(--ink) 70%,var(--accent))); }
[data-theme="dark"] .up-btn-pro { background:linear-gradient(135deg,var(--accent),var(--violet)); }
.up-btn-pro:hover { box-shadow:0 8px 24px rgba(74,144,217,0.25); }
.up-btn-plus { background:linear-gradient(135deg,var(--violet),var(--accent2)); }
.up-btn-plus:hover { box-shadow:0 8px 24px rgba(167,139,250,0.3); }
.up-guarantee { text-align:center;font-size:10px;color:var(--muted);font-family:var(--font-mono);padding:8px 0 0;line-height:1.6; }
.up-guarantee span { color:var(--accent); }
@media(max-width:600px){
  .up-card{padding:24px 16px 20px;max-width:100%}
  .up-plans{grid-template-columns:1fr}
  .up-card .modal-title{font-size:20px}
}
/* CONFIRM DIALOG */
.confirm-card{background:var(--s1);border:1.5px solid var(--border2);border-radius:14px;padding:28px 30px;max-width:380px;width:100%;box-shadow:var(--shadow-lg);animation:popIn 0.3s ease;text-align:center}
.confirm-icon{font-size:36px;margin-bottom:10px}
.confirm-title{font-family:var(--font-serif);font-size:20px;font-style:italic;margin-bottom:6px;color:var(--ink)}
.confirm-msg{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:22px}
.confirm-actions{display:flex;gap:10px;justify-content:center}
.confirm-cancel{background:var(--s2);border:1.5px solid var(--border);color:var(--ink);border-radius:9px;padding:10px 22px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all 0.2s}
.confirm-cancel:hover{background:var(--border);border-color:var(--border2)}
.confirm-danger{background:linear-gradient(135deg,#FF3D6E,#e0245e);border:none;color:#fff;border-radius:10px;padding:10px 22px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all 0.2s;box-shadow:0 2px 8px rgba(255,61,110,0.25)}
.confirm-danger:hover{filter:brightness(1.1);transform:translateY(-1px)}
.confirm-primary{background:var(--accent);border:none;color:#fff;border-radius:10px;padding:10px 22px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all 0.2s;box-shadow:0 2px 8px rgba(0,0,0,0.1)}
.confirm-primary:hover{filter:brightness(1.08);transform:translateY(-1px)}
.confirm-danger:disabled,.confirm-primary:disabled{opacity:0.55;cursor:wait;transform:none;filter:none}
/* DOWNGRADE CONFIRMATION MODAL */
.dg-card { max-width:460px;padding:32px 28px 24px;position:relative;max-height:calc(100vh - 48px);overflow-y:auto; }
.dg-close { position:absolute;top:14px;right:16px;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--s1);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all 0.15s;font-family:var(--font-body);z-index:2; }
.dg-close:hover { border-color:var(--rose);color:var(--rose); }
.dg-icon { font-size:36px;text-align:center;margin-bottom:10px; }
.dg-title { font-family:var(--font-serif);font-size:22px;font-style:italic;text-align:center;margin-bottom:6px;color:var(--ink); }
.dg-sub { font-size:12.5px;color:var(--muted);text-align:center;line-height:1.65;margin-bottom:20px;max-width:380px;margin-left:auto;margin-right:auto; }
.dg-compare { display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px; }
.dg-col { background:var(--s2);border:1.5px solid var(--border);border-radius:12px;padding:16px 14px;text-align:left; }
.dg-col-current { border-color:var(--violet-mid);background:var(--violet-lt); }
.dg-col-target { border-color:var(--accent-mid);background:var(--accent-lt); }
.dg-col-label { font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;font-family:var(--font-mono);margin-bottom:8px; }
.dg-col-current .dg-col-label { color:var(--violet); }
.dg-col-target .dg-col-label { color:var(--accent); }
.dg-col-plan { font-family:var(--font-body);font-size:15px;font-weight:800;color:var(--ink);margin-bottom:2px; }
.dg-col-price { font-family:var(--font-serif);font-size:13px;font-style:italic;color:var(--muted);margin-bottom:10px; }
.dg-col ul { list-style:none;padding:0;margin:0; }
.dg-col li { font-size:10.5px;color:var(--ink2);line-height:1.4;padding:2px 0 2px 16px;position:relative;font-family:var(--font-mono); }
.dg-col-current li::before { content:'\2716';position:absolute;left:0;color:var(--rose);font-size:9px; }
.dg-col-target li::before { content:'\2714';position:absolute;left:0;color:var(--accent);font-weight:700;font-size:9px; }
.dg-warn { font-size:11px;color:var(--amber);background:var(--amber-lt);border:1px solid var(--amber-mid);border-radius:8px;padding:10px 14px;margin-bottom:18px;text-align:center;line-height:1.5;font-family:var(--font-mono); }
.dg-actions { display:flex;gap:10px;justify-content:center;margin-bottom:12px; }
.dg-btn-keep { background:var(--s2);border:1.5px solid var(--border);color:var(--ink);border-radius:10px;padding:11px 24px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all 0.2s; }
.dg-btn-keep:hover { background:var(--border);border-color:var(--border2); }
.dg-btn-confirm { background:linear-gradient(135deg,var(--accent),var(--violet));border:none;color:#fff;border-radius:10px;padding:11px 24px;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font-body);transition:all 0.2s;box-shadow:0 2px 8px rgba(74,144,217,0.25); }
.dg-btn-confirm:hover { filter:brightness(1.08);transform:translateY(-1px); }
.dg-btn-confirm:disabled { opacity:0.5;pointer-events:none; }
.dg-footer { text-align:center;font-size:10px;color:var(--muted);font-family:var(--font-mono);line-height:1.6; }
.dg-footer span { color:var(--accent); }
.dg-email-note { display:flex;align-items:center;gap:6px;justify-content:center;font-size:10px;color:var(--muted);font-family:var(--font-mono);margin-top:6px; }
.dg-email-note span { color:var(--accent); }
@media(max-width:600px){
  .dg-card{padding:24px 16px 20px;max-width:100%}
  .dg-compare{grid-template-columns:1fr}
  .dg-title{font-size:18px}
}
/* CV PREVIEW MODAL */
.cv-modal-inner { max-width:900px;width:100%;position:relative; }
.cv-modal-bar { display:flex;justify-content:space-between;align-items:center;margin-bottom:12px; }
.cv-modal-bar span { font-family:var(--font-head);font-size:13px;font-weight:700;color:rgba(255,255,255,0.85); }
.cv-modal-actions { display:flex;gap:10px; }
.btn-modal-close { background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.7);border-radius:10px;padding:8px 16px;cursor:pointer;font-family:var(--font-body);font-size:12px;transition:all 0.2s; }
.btn-modal-close:hover { border-color:var(--rose);color:var(--rose); }
#cvPreviewFrame { width:100%;height:86vh;border:none;border-radius:8px;background:#fff; }
/* ══════════════════ ERROR ══════════════════ */
.err-box { background:var(--rose-lt);border:1.5px solid rgba(255,61,110,0.3);border-radius:10px;padding:22px 24px;color:var(--rose);font-size:13px;line-height:1.7;margin-bottom:20px; }
[data-theme="light"] .err-box { border-color:#FECDD3; }
/* ── FORM VALIDATION STATES ── */
.field-error textarea,
.field-error input[type=text],
textarea.has-error,
input.has-error { border-color:var(--rose)!important;box-shadow:0 0 0 3px rgba(225,29,72,0.08)!important; }
.field-error-msg {
  display:none;font-size:11.5px;color:var(--rose);font-weight:500;
  margin-top:4px;line-height:1.4;
  animation:errShake 0.3s ease;
}
.field-error .field-error-msg { display:block; }
@keyframes errShake {
  0%,100%{transform:translateX(0)} 25%{transform:translateX(-4px)} 75%{transform:translateX(4px)}
}
/* Success state */
.field-success textarea,
.field-success input[type=text] { border-color:var(--emerald)!important; }
.field-success .field-success-ico { display:inline-block; }
.field-success-ico { display:none;color:var(--emerald);font-size:12px;margin-left:6px; }
/* ══════════════════ MARKETING — Premium SaaS ══════════════════ */
.mkt { max-width:100%;margin:0 auto;padding:0; }
.mkt-sec { padding:96px 32px 88px;max-width:1200px;margin:0 auto;position:relative; }

/* ── Section Background System — creative, subtle per-section BGs ── */
/* Wrap: full-bleed background containers */
.mkt-sec-wrap { position:relative;overflow:hidden; }

/* 1. Value Props — elevated surface with accent glow top-right, violet bottom-left */
.mkt-sec-wrap--vp { background:var(--s2); }
.mkt-sec-wrap--vp::before {
  content:'';position:absolute;top:-80px;right:-120px;width:500px;height:500px;
  background:radial-gradient(circle,var(--accent-lt) 0%,transparent 70%);
  pointer-events:none;opacity:0.7;
}
.mkt-sec-wrap--vp::after {
  content:'';position:absolute;bottom:-60px;left:-80px;width:400px;height:400px;
  background:radial-gradient(circle,var(--violet-lt) 0%,transparent 70%);
  pointer-events:none;opacity:0.5;
}
[data-theme="dark"] .mkt-sec-wrap--vp { background:var(--s1); }
[data-theme="dark"] .mkt-sec-wrap--vp::before { opacity:0.4; }
[data-theme="dark"] .mkt-sec-wrap--vp::after { opacity:0.3; }

/* 2. Stats + GVT — elevated surface with subtle dot pattern */
.mkt-sec-wrap--stats { background:var(--bg); }
.mkt-sec-wrap--stats::before {
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,var(--border) 0.8px,transparent 0.8px);
  background-size:20px 20px;opacity:0.35;pointer-events:none;
}
[data-theme="dark"] .mkt-sec-wrap--stats::before { opacity:0.2; }

/* 3. How It Works — gradient sweep from accent to violet */
.mkt-sec-wrap--how { background:var(--s2); }
[data-theme="dark"] .mkt-sec-wrap--how { background:var(--s1); }
.mkt-sec-wrap--how::before {
  content:'';position:absolute;top:0;left:0;right:0;height:100%;
  background:linear-gradient(160deg,var(--accent-lt) 0%,transparent 30%,transparent 70%,var(--violet-lt) 100%);
  pointer-events:none;opacity:0.5;
}
[data-theme="dark"] .mkt-sec-wrap--how::before { opacity:0.25; }

/* 4. Comparison — clean surface with subtle top-left glow */
.mkt-sec-wrap--compare { background:var(--bg); }
.mkt-sec-wrap--compare::before {
  content:'';position:absolute;top:-40px;left:-60px;width:350px;height:350px;
  background:radial-gradient(circle,var(--cyan-lt) 0%,transparent 70%);
  pointer-events:none;opacity:0.6;
}
[data-theme="dark"] .mkt-sec-wrap--compare { background:var(--bg); }
[data-theme="dark"] .mkt-sec-wrap--compare::before { opacity:0.3; }

/* 5. Pricing — warm gold glow center, premium feel */
.mkt-sec-wrap--pricing { background:var(--s2); }
[data-theme="dark"] .mkt-sec-wrap--pricing { background:var(--s1); }
.mkt-sec-wrap--pricing::before {
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:700px;height:500px;
  background:radial-gradient(ellipse,var(--gold-lt) 0%,transparent 65%);
  pointer-events:none;opacity:0.5;
}
.mkt-sec-wrap--pricing::after {
  content:'';position:absolute;bottom:-80px;right:-80px;width:350px;height:350px;
  background:radial-gradient(circle,var(--gold-lt) 0%,transparent 70%);
  pointer-events:none;opacity:0.45;
}
[data-theme="dark"] .mkt-sec-wrap--pricing::before { opacity:0.25; }
[data-theme="dark"] .mkt-sec-wrap--pricing::after { opacity:0.18; }

/* 6. Final CTA — warm gold gradient, urgency feel */
.mkt-sec-wrap--final { background:var(--bg); }
.mkt-sec-wrap--final::before {
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--gold-lt) 0%,transparent 35%,transparent 65%,var(--accent-lt) 100%);
  pointer-events:none;opacity:0.5;
}
.mkt-sec-wrap--final::after {
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:600px;height:400px;
  background:radial-gradient(ellipse,var(--gold-lt) 0%,transparent 60%);
  pointer-events:none;opacity:0.5;
}
[data-theme="dark"] .mkt-sec-wrap--final { background:var(--bg); }
[data-theme="dark"] .mkt-sec-wrap--final::before { opacity:0.2; }
[data-theme="dark"] .mkt-sec-wrap--final::after { opacity:0.25; }
.mkt-eyebrow { font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;display:inline-flex;align-items:center;gap:10px;padding:8px 20px;border-radius:100px;background:var(--accent-lt);border:1px solid var(--accent-mid); }
.mkt-h2 { font-family:var(--font-head);font-size:clamp(28px,4.2vw,46px);font-style:normal;font-weight:800;letter-spacing:-0.03em;color:var(--ink);margin-bottom:18px;line-height:1.1; }
[data-theme="dark"] .mkt-h2 { color:#f0f4ff; }
.mkt-p { font-size:16px;color:var(--muted);line-height:1.8;max-width:560px; }
/* HOW IT WORKS GRID */
.how-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:20px;margin-top:48px; }
.how-card { background:var(--s1);border:1px solid var(--border);border-radius:16px;padding:28px;position:relative;overflow:hidden;transition:border-color 0.25s,box-shadow 0.25s,transform 0.25s;box-shadow:var(--shadow); }
.how-card:hover { border-color:var(--accent-mid);transform:translateY(-2px);box-shadow:var(--shadow-lg); }
[data-theme="dark"] .how-card:hover { box-shadow:0 8px 24px rgba(0,0,0,0.3);border-color:rgba(74,144,217,0.3); }
[data-theme="light"] .how-card:hover { box-shadow:0 8px 24px rgba(0,47,108,0.06); }
.how-card::after { content:attr(data-num);position:absolute;bottom:-20px;right:-4px;font-family:var(--font-head);font-size:80px;font-weight:900;color:var(--accent-lt);pointer-events:none;line-height:1;letter-spacing:-0.04em;opacity:0.5; }
[data-theme="dark"] .how-card::after { opacity:0.25; }
/* ── GENERIC vs TAILORED GRID ── */
.gvt-grid { display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:40px; }
@media(max-width:680px){ .gvt-grid{grid-template-columns:1fr} }
.gvt-col { border-radius:16px;padding:28px;border:1px solid var(--border);box-shadow:var(--shadow);transition:all 0.25s ease; }
.gvt-bad  { background:var(--rose-lt);border-color:rgba(190,18,60,0.15); }
[data-theme="dark"] .gvt-bad { background:rgba(190,18,60,0.08);border-color:rgba(190,18,60,0.2); }
.gvt-good { background:var(--accent-lt);border-color:var(--accent-mid); }
[data-theme="dark"] .gvt-good { background:rgba(74,144,217,0.08);border-color:rgba(74,144,217,0.2); }
.gvt-head { font-family:var(--font-body);font-size:14px;font-weight:800;margin-bottom:20px;display:flex;align-items:center;gap:8px;letter-spacing:0.01em; }
.gvt-bad  .gvt-head { color:var(--rose); }
.gvt-good .gvt-head { color:var(--accent); }
.gvt-row { padding:13px 0;border-top:1px solid var(--border);display:grid;gap:5px; }
.gvt-row strong { font-size:13px;font-weight:700;color:var(--ink); }
.gvt-row span { font-size:12px;color:var(--ink2);line-height:1.65;font-family:var(--font-body); }
.how-tag { font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.15em;color:var(--accent);margin-bottom:14px; }
.how-h { font-family:var(--font-head);font-size:16px;font-weight:700;letter-spacing:-0.02em;margin-bottom:10px; }
.how-p { font-size:13px;color:var(--muted);line-height:1.8; }
/* PRICING — Premium SaaS */
.pricing-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:48px; }
.pc { background:var(--s1);border:1px solid var(--border);border-radius:16px;padding:28px;display:flex;flex-direction:column;gap:16px;transition:all 0.25s ease;box-shadow:var(--shadow); }
.pc:hover { transform:translateY(-2px);box-shadow:var(--shadow-lg); }
[data-theme="dark"] .pc:hover { box-shadow:0 8px 24px rgba(0,0,0,0.3); }
[data-theme="light"] .pc:hover { box-shadow:0 8px 24px rgba(0,47,108,0.06); }
.pc-pledge {
  background:var(--accent-lt);border:1px solid var(--accent-mid);border-radius:10px;
  padding:14px 16px;font-size:11.5px;color:var(--ink2);line-height:1.75;font-family:var(--font-body);
}
[data-theme="dark"] .pc-pledge { background:rgba(74,144,217,0.07);border-color:rgba(74,144,217,0.2); }
.pc-pledge strong { color:var(--gold);display:block;font-size:11px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.09em;margin-bottom:5px; }
.pc-promise { display:flex;flex-direction:column;gap:6px;margin-top:2px; }
.pc-promise-item { display:flex;align-items:flex-start;gap:8px;font-size:11.5px;color:var(--ink2);line-height:1.6; }
.pc-promise-item span.ico { flex-shrink:0;font-size:13px;margin-top:1px; }
.pc-cta-note { display:none; }
.pc.feat { border:2px solid var(--gold);box-shadow:0 0 0 1px var(--gold-glow),0 8px 32px rgba(0,0,0,0.08);position:relative; }
[data-theme="dark"] .pc.feat { box-shadow:0 0 40px var(--gold-glow),0 8px 32px rgba(0,0,0,0.3); }
[data-theme="light"] .pc.feat { background:var(--s1);box-shadow:0 0 0 1px var(--gold-glow),0 8px 24px rgba(0,47,108,0.08); }
.pc-badge { font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.12em;padding:3px 10px;border-radius:20px;width:fit-content;border:1px solid; }
.pcb-free { color:var(--accent);border-color:var(--accent-mid);background:var(--accent-lt); }
.pcb-pro  { color:var(--gold);border-color:var(--gold-mid);background:var(--gold-lt); }
[data-theme="light"] .pcb-pro { color:var(--gold);border-color:var(--gold-mid); }
.pcb-team { color:var(--gold);border-color:var(--gold-mid);background:var(--gold-lt); }
.pc-name { font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--ink);letter-spacing:-0.02em; }
[data-theme="dark"] .pc-name { color:var(--ink); }
.pc-price { font-family:var(--font-head);font-size:42px;font-weight:800;color:var(--ink);line-height:1;letter-spacing:-0.03em; }
[data-theme="dark"] .pc-price { color:var(--ink); }
.pc-freq { font-size:13px;font-family:var(--font-body);color:var(--muted);font-style:normal; }
.pc-freq-alt { font-size:11px;color:var(--gold);font-family:var(--font-mono);font-weight:600;margin-top:2px; }
.mplan-badge { font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--gold);background:var(--gold-lt);padding:2px 8px;border-radius:4px;margin-bottom:6px;display:inline-block; }
.pc-feats { list-style:none;display:flex;flex-direction:column;gap:9px;font-size:13px;color:var(--ink2); }
.pc-feats li.y::before { content:'✓  ';color:var(--accent);font-weight:700; }
.pc-feats li.n { color:var(--muted2); }.pc-feats li.n::before { content:'–  '; }
.pc-cta { margin-top:auto;padding:14px;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all 0.2s ease; }
.pcc-free { background:var(--s3);color:var(--ink);border:1.5px solid var(--border2); }
.pcc-free:hover { border-color:var(--accent);color:var(--accent);background:var(--accent-lt); }
.pcc-pro { background:var(--ink);color:var(--bg); }
[data-theme="dark"] .pcc-pro { background:#fafafa;color:#09090b; }
.pcc-pro:hover { box-shadow:0 8px 24px var(--gold-glow);transform:translateY(-1px); }
.pcc-team { background:transparent;color:var(--ink);border:1.5px solid var(--border2); }
.pcc-team:hover { border-color:var(--accent);color:var(--accent);background:var(--accent-lt); }
/* FAQ */
.faq-list { margin-top:36px;max-width:740px; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-q { display:flex;align-items:center;justify-content:space-between;padding:19px 0;cursor:pointer;font-size:14.5px;font-weight:600;gap:12px;background:none;border:none;color:var(--ink);width:100%;text-align:left;font-family:var(--font-body); }
.faq-q:focus-visible { outline:2px solid var(--accent);outline-offset:2px;border-radius:4px; }
.fq-ico { font-size:18px;color:var(--muted2);flex-shrink:0;transition:transform 0.3s; }
.faq-a { height:0;overflow:hidden;transition:height 0.35s ease; }
.faq-a-inner { padding:0 0 20px;font-size:13.5px;color:var(--muted);line-height:1.9; }
.faq-item.open .fq-ico { transform:rotate(45deg);color:var(--gold); }
/* ══════════════════ TESTIMONIALS ══════════════════ */
.testi-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:36px; }
.testi-card { background:var(--s1);border:1px solid var(--border);border-radius:16px;padding:28px;position:relative;box-shadow:var(--shadow);transition:all 0.25s ease; }
.testi-card:hover { border-color:var(--border2);transform:translateY(-2px);box-shadow:var(--shadow-lg); }
[data-theme="dark"] .testi-card:hover { box-shadow:0 8px 24px rgba(0,0,0,0.3); }
[data-theme="light"] .testi-card:hover { box-shadow:0 8px 24px rgba(0,47,108,0.06); }
.testi-stars { color:var(--gold);font-size:13px;letter-spacing:2px;margin-bottom:13px; }
.testi-quote { font-family:var(--font-body);font-size:14.5px;font-style:normal;line-height:1.8;color:var(--ink);margin-bottom:18px; }
[data-theme="dark"] .testi-quote { color:var(--ink2); }
.testi-author { display:flex;align-items:center;gap:11px; }
.testi-av { width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:16px;flex-shrink:0;background:var(--s3);border:1.5px solid var(--border2); }
.testi-name { font-size:13px;font-weight:700;color:var(--ink); }
.testi-role { font-size:11px;color:var(--muted);font-family:var(--font-mono);margin-top:1px; }
.testi-badge { position:absolute;top:20px;right:20px;font-family:var(--font-mono);font-size:9px;padding:2px 9px;border-radius:20px;background:var(--accent-lt);color:var(--accent);border:1px solid var(--accent-mid); }
/* ══════════════════ VALUE PROPS — Premium Cards ══════════════════ */
.vp-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px;margin-top:48px; }
.vp-card { padding:28px;border:1px solid var(--border);border-radius:16px;background:var(--s1);transition:all 0.25s;position:relative;box-shadow:var(--shadow); }
.vp-card:hover { border-color:var(--accent-mid);transform:translateY(-2px);box-shadow:var(--shadow-lg); }
[data-theme="dark"] .vp-card:hover { box-shadow:0 8px 24px rgba(0,0,0,0.3); }
[data-theme="light"] .vp-card:hover { box-shadow:0 8px 24px rgba(0,47,108,0.06); }
.vp-icon { font-size:28px;margin-bottom:16px;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:var(--accent-lt);border:1px solid var(--accent-mid); }
.vp-h { font-family:var(--font-head);font-size:16px;font-weight:700;letter-spacing:-0.02em;margin-bottom:10px;color:var(--ink); }
.vp-p { font-size:14px;color:var(--muted);line-height:1.85; }
.vp-p strong { color:var(--ink); }
/* ══════════════════ COMPARE TABLE — Clean ══════════════════ */
.compare-wrap { overflow-x:auto;margin-top:40px;border-radius:16px;border:1px solid var(--border);background:var(--s1);box-shadow:var(--shadow); }
.compare-table { width:100%;border-collapse:collapse;min-width:640px; }
.compare-table th { padding:16px 18px;text-align:center;font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:0;color:var(--muted);background:var(--s2);border-bottom:1px solid var(--border); }
.compare-table th:first-child { text-align:left;width:220px; }
.compare-table th.us { background:var(--accent-lt);color:var(--accent);font-weight:700; }
.compare-table td { padding:14px 18px;font-size:13px;color:var(--muted);border-bottom:1px solid var(--border);vertical-align:middle;text-align:center; }
.compare-table tr:last-child td { border-bottom:none; }
.compare-table td:first-child { font-weight:600;color:var(--ink);font-size:13px;text-align:left; }
.compare-table td.us { background:var(--accent-lt);font-weight:600;color:var(--accent);font-size:13px; }
.compare-table tr:hover td { background:var(--s2); }
.compare-table tr:hover td.us { background:var(--accent-lt); }
[data-theme="dark"] .compare-table tr:hover td.us { background:rgba(74,144,217,0.08); }
.ct-yes { color:var(--emerald);font-weight:700; }
.ct-no  { color:var(--muted2); }
.ct-part{ color:var(--amber); }
.compare-note { font-size:11px;color:var(--muted2);font-family:var(--font-mono);margin-top:14px;line-height:1.7; }
/* ══════════════════ STAT STRIP — Premium Numbers ══════════════════ */
.stat-strip { display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-top:40px;background:var(--s1);box-shadow:var(--shadow); }
.stat-cell { padding:32px 24px;text-align:center;border-right:1px solid var(--border); }
.stat-cell:last-child { border-right:none; }
.stat-num { font-family:var(--font-head);font-size:36px;font-weight:800;font-style:normal;line-height:1;color:var(--gold);margin-bottom:8px;letter-spacing:-0.03em; }
[data-theme="dark"] .stat-num { color:var(--gold); }
.stat-lbl { font-family:var(--font-body);font-size:12px;letter-spacing:0;text-transform:none;color:var(--muted);line-height:1.5; }
@media(max-width:700px){.stat-strip{grid-template-columns:1fr 1fr}.stat-cell:nth-child(2){border-right:none}.stat-cell:nth-child(3){border-right:1px solid var(--border)}.testi-grid{grid-template-columns:1fr}.vp-grid{grid-template-columns:1fr}}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
/* FOOTER — Clean & Professional */
footer { border-top:1px solid var(--border);padding:0;margin-top:0;background:var(--s1); }
.ft-top { max-width:1200px;margin:0 auto;padding:56px 32px 40px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;align-items:start;gap:48px; }
@media(max-width:780px){ .ft-top{grid-template-columns:1fr 1fr;gap:24px 16px;padding:32px 20px 24px} .ft-top>div:first-child{grid-column:1/-1} .ft-top>div:last-child{grid-column:1/-1} .ft-bottom{padding:16px 20px;flex-direction:column;align-items:flex-start} }
.ft-brand { font-family:var(--font-head);font-size:16px;font-weight:700;font-style:normal;color:var(--ink);letter-spacing:-0.02em; }
.ft-brand b { color:var(--accent);font-style:normal; }
.ft-tagline { font-family:var(--font-body);font-size:13px;color:var(--muted);margin-top:8px;line-height:1.6; }
.ft-legal-entity { font-family:var(--font-mono);font-size:10px;color:var(--muted2);margin-top:16px;line-height:1.8;opacity:0.7; }
.ft-col-title { font-family:var(--font-body);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-bottom:16px; }
.ft-col-links { display:flex;flex-direction:column;gap:12px; }
.ft-col-links a,.ft-col-links button { font-size:13px;color:var(--muted);text-decoration:none;font-family:var(--font-body);transition:color 0.2s;letter-spacing:0;background:none;border:none;padding:0;cursor:pointer;text-align:left; }
.ft-col-links a:hover,.ft-col-links button:hover { color:var(--ink); }
.ft-col-links a:focus-visible,.ft-col-links button:focus-visible { outline:2px solid var(--accent);outline-offset:2px;border-radius:2px; }
.ft-compliance { display:flex;gap:8px;flex-wrap:wrap;margin-top:18px; }
.ft-badge { font-family:var(--font-mono);font-size:9px;padding:5px 12px;border-radius:6px;border:1px solid var(--border2);color:var(--muted);background:var(--s2);letter-spacing:0.04em; }
.ft-bottom { border-top:1px solid var(--border);padding:20px 32px;max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px; }
.ft-copy { font-family:var(--font-mono);font-size:11px;color:var(--muted2);line-height:1.7; }
.ft-note { font-family:var(--font-body);font-size:12px;color:var(--muted2);line-height:1.6; }
.ft-trust { display:flex;align-items:center;gap:20px;flex-wrap:wrap; }
.ft-trust-item { font-family:var(--font-body);font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px; }
/* ══ COOKIE CONSENT BANNER — GDPR/ePrivacy ══ */
.cookie-banner {
  position:fixed;bottom:0;left:0;right:0;z-index:800;
  background:var(--s1);border-top:2px solid var(--border2);
  padding:18px 28px;display:none;align-items:center;gap:20px;flex-wrap:wrap;
  box-shadow:0 -4px 24px rgba(0,0,0,0.2);
}
.cookie-banner.show { display:flex; }
.cookie-text { flex:1;min-width:260px;font-size:12px;color:var(--ink2);line-height:1.75;font-family:var(--font-body); }
.cookie-text a { color:var(--accent);text-decoration:underline; }
.cookie-text a:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
.cookie-btns { display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap; }
.cb-accept { background:var(--accent);color:#fff;border:none;padding:10px 22px;border-radius:8px;font-family:var(--font-body);font-size:13px;font-weight:700;cursor:pointer;transition:all 0.2s;min-height:44px; }
.cb-accept:hover { filter:brightness(1.08); }
.cb-accept:focus-visible { outline:3px solid var(--accent);outline-offset:3px; }
.cb-settings { background:transparent;color:var(--ink);border:1.5px solid var(--border2);padding:10px 18px;border-radius:8px;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s;min-height:44px; }
.cb-settings:hover { border-color:var(--accent);color:var(--accent); }
.cb-settings:focus-visible { outline:3px solid var(--accent);outline-offset:3px; }
.cb-reject { background:transparent;color:var(--muted);border:none;padding:10px 14px;border-radius:8px;font-family:var(--font-body);font-size:12px;cursor:pointer;transition:all 0.2s;min-height:44px; }
.cb-reject:hover { color:var(--ink); }
/* ══ LEGAL MODAL ══ */
.legal-modal {
  display:none;position:fixed;inset:0;z-index:600;
  background:rgba(6,8,15,0.85);backdrop-filter:blur(8px);
  align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto;
}
.legal-modal.open { display:flex; }
.legal-card {
  background:var(--s1);border:1.5px solid var(--border2);border-radius:20px;
  width:100%;max-width:760px;padding:40px 44px;position:relative;
  box-shadow:var(--shadow-lg);
}
@media(max-width:600px){ .legal-card{padding:28px 20px} }
.legal-close {
  position:absolute;top:18px;right:18px;background:var(--s3);border:1px solid var(--border2);
  color:var(--muted);width:36px;height:36px;border-radius:8px;cursor:pointer;font-size:16px;
  display:grid;place-items:center;transition:all 0.2s;
}
.legal-close:hover { border-color:var(--rose);color:var(--rose); }
.legal-close:focus-visible { outline:3px solid var(--accent);outline-offset:3px; }
.legal-tabs { display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:28px; }
.legal-tab { padding:10px 18px;border:none;background:transparent;border-bottom:2.5px solid transparent;margin-bottom:-2px;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;transition:all 0.18s; }
.legal-tab.on { color:var(--accent);font-weight:700;border-bottom-color:var(--accent);background:var(--accent-lt); }
.legal-tab:focus-visible { outline:2px solid var(--accent);outline-offset:2px; }
.legal-content { max-height:60vh;overflow-y:auto;padding-right:8px;scroll-behavior:smooth; }
.legal-content::-webkit-scrollbar { width:4px; }
.legal-content::-webkit-scrollbar-thumb { background:var(--border2);border-radius:2px; }
.legal-pane { display:none; }
.legal-pane.on { display:block; }
.legal-h1 { font-family:var(--font-serif);font-size:26px;font-style:italic;color:var(--ink);margin-bottom:6px; }
.legal-meta { font-family:var(--font-mono);font-size:10px;color:var(--muted);margin-bottom:24px;line-height:1.8; }
.legal-h2 { font-size:13px;font-weight:700;color:var(--ink);margin:22px 0 8px;text-transform:uppercase;letter-spacing:0.06em;font-family:var(--font-mono); }
.legal-p { font-size:13px;color:var(--ink2);line-height:1.85;margin-bottom:12px; }
.legal-p a { color:var(--accent);text-decoration:underline; }
.legal-p strong { color:var(--ink); }
.legal-list { list-style:none;padding-left:0;margin-bottom:14px; }
.legal-list li { font-size:13px;color:var(--ink2);line-height:1.8;padding-left:18px;position:relative;margin-bottom:4px; }
.legal-list li::before { content:'–';position:absolute;left:0;color:var(--accent); }
.legal-highlight { background:var(--accent-lt);border:1px solid var(--accent-mid);border-radius:8px;padding:14px 18px;margin:16px 0; }
.legal-highlight p { margin-bottom:0;color:var(--ink); }
/* ══════════════════ HAMBURGER (hidden on desktop) ══════════════════ */
.nav-hamburger{
  display:none;flex-direction:column;justify-content:center;align-items:center;
  width:44px;height:44px;background:transparent;border:1px solid var(--border);border-radius:10px;
  cursor:pointer;gap:5px;flex-shrink:0;margin-left:auto;transition:background 0.2s;
}
.nav-hamburger:hover{background:var(--s2)}
.nav-hamburger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.ham-line{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform 0.3s,opacity 0.3s}
.nav-hamburger.open .ham-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open .ham-line:nth-child(2){opacity:0}
.nav-hamburger.open .ham-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@keyframes mobileNavSlide{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
/* ══════════════════ RESPONSIVE ══════════════════ */
@media(max-width:1000px){.charts-3{grid-template-columns:1fr 1fr}.export-layout{grid-template-columns:1fr}.export-panel{position:static}}
@media(max-width:900px){.proof-inner{gap:12px 20px}.proof-sep{display:none}.proof-item{font-size:11px}}
@media(max-width:800px){.intake-zones{grid-template-columns:1fr}.diff-grid{grid-template-columns:1fr}.diff-panel:first-child{border-right:none;border-bottom:1px solid var(--border)}.kw-cols{grid-template-columns:1fr}.rings-row{justify-content:center}.charts-2{grid-template-columns:1fr}.chart-card.full{grid-column:1}}
@media(max-width:700px){
  .site-nav .stepper{display:none}
  .nav-hamburger{display:flex}
  .nav-right{
    display:none!important;position:fixed;top:60px;left:0;right:0;
    background:var(--s1);border-top:1px solid var(--border);flex-direction:column;
    padding:20px 24px;gap:12px;z-index:99;overflow-y:auto;
    margin-left:0;align-items:stretch;height:calc(100vh - 60px);width:100%;
    animation:mobileNavSlide 0.25s ease;
  }
  .nav-right.open{display:flex!important}
  .nav-right .usage-pill{width:100%;justify-content:center;min-width:0}
  .nav-right .btn-theme{width:100%;height:48px;border-radius:10px;font-size:18px}
  .nav-right .lang-wrap{width:100%}
  .nav-right .lang-wrap .btn-theme{width:100%}
  .nav-right .lang-drop{left:0;right:0;width:100%}
  .nav-right .btn-up{width:100%;text-align:center;padding:14px 24px;border-radius:10px}
  .nav-right .nav-sign-in-btn{width:100%;text-align:center;padding:14px 18px;border-radius:10px;font-size:14px}
  .nav-right .nav-auth-avatar{width:100%;height:48px;border-radius:10px}
  .nav-right .profile-wrap{width:100%}
  /* Mobile profile row: left-aligned avatar + name, no gradient, subtle surface.
     Previously the img's natural size (~512px) blew the grid cell open to ~120px.
     Now we hard-constrain the inner to 36px and strip the .authed gradient so the
     button looks like a nav row rather than a full-width CTA bar. */
  .nav-right .btn-profile{width:100%;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:0 14px;overflow:hidden}
  .nav-right .btn-profile.authed{background:var(--s2,rgba(255,255,255,0.06));border:1.5px solid var(--border,rgba(255,255,255,0.1));transform:none}
  .nav-right .btn-profile.authed:hover{background:var(--s3,rgba(255,255,255,0.1));transform:none}
  .nav-right .btn-profile #profileBtnInner{width:36px;height:36px;flex-shrink:0;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1}
  .nav-right .btn-profile #profileBtnInner img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}
  .nav-right .btn-profile.authed::after{content:attr(title);font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 70px)}
  .nav-right .btn-profile .profile-dot{top:50%;right:14px;transform:translateY(-50%)}
  .profile-drop{
    position:fixed;top:60px;left:0;right:0;bottom:0;
    width:100%;
    max-height:calc(100vh - 60px);
    max-height:calc(100dvh - 60px);
    border-radius:0;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    z-index:500;
    padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));
    /* Kill the desktop dropIn animation (animation-fill-mode:both freezes opacity:0).
       Use a plain opacity transition instead — works reliably after display:none→block. */
    animation:none;
    opacity:0;
    transition:opacity 0.18s ease;
  }
  .profile-drop.open{opacity:1;}
  body.profile-open{overflow:hidden;touch-action:none}
  .extras-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .how-grid{grid-template-columns:1fr}
  .stat-strip{grid-template-columns:1fr 1fr}
  .stat-cell:nth-child(2){border-right:none}
  .stat-cell:nth-child(3){border-right:1px solid var(--border)}
  .testi-grid{grid-template-columns:1fr}
  .vp-grid{grid-template-columns:1fr}
  .pro-cta{flex-direction:column}
  .pct-btn{margin-left:0;width:100%}
  .modal-plans{flex-direction:column}
  .pipeline-viz{flex-direction:column;align-items:center;gap:8px}
  .pvz-arrow{transform:rotate(90deg);padding:2px 0}
  .pipeline-nodes{flex-wrap:wrap;justify-content:center;gap:6px}
  .ft-top{grid-template-columns:1fr 1fr;gap:20px 16px} .ft-top>div:first-child,.ft-top>div:last-child{grid-column:1/-1}
}
@media(max-width:600px){
  .dash-modal{max-width:100%;max-height:100vh;border-radius:0;margin:0}
  .dash-overlay{padding:0}
  .modal{padding:10px}
  .modal-card{max-width:100%;border-radius:12px;padding:24px 20px}
  .gvt-grid{grid-template-columns:1fr}
  .legal-card{padding:28px 20px}
}
@media(max-width:520px){
  .app{padding:0 16px}.nav-inner{padding:0 16px}.mkt{padding:0}.mkt-sec{padding-left:16px;padding-right:16px}.ft-inner{padding:0 16px}
  .usage-pill{display:none}.wp-track{width:120px}
  .intake-hero{padding:48px 0 36px}
  .hero-p{font-size:14px}
  .hero-eyebrow{font-size:9px;padding:6px 14px}
  .privacy-note{white-space:normal;flex-wrap:wrap;text-align:center;justify-content:center;padding:12px 16px}
  .cta-row{flex-direction:column;align-items:stretch;text-align:center}
  .btn-cta{width:100%}
  .cta-note{text-align:center}
  .a4-toolbar{flex-wrap:wrap;gap:8px}
  .cookie-banner{flex-direction:column;padding:16px;gap:12px}
  .cookie-btns{width:100%;justify-content:stretch}
  .cookie-btns button{flex:1}
  .toast-wrap{left:16px;right:16px;bottom:16px}
  .toast{min-width:0;max-width:100%}
  .intake-step{gap:12px}
  .is-num{width:32px;height:32px;font-size:13px;flex-shrink:0}
  .intake-step:not(:last-child)::after{left:15px}
  .is-label{font-size:8.5px;letter-spacing:0.12em}
  .pvz-stage{padding:7px 12px}
  .pvz-name{font-size:10px}
}
@media(max-width:400px){
  .stat-strip{grid-template-columns:1fr}
  .stat-cell{border-right:none;border-bottom:1px solid var(--border)}
  .stat-cell:last-child{border-bottom:none}
  .modal{padding:8px}
  .modal-card{padding:20px 14px;border-radius:10px}
  .pipeline-nodes{flex-direction:column;gap:4px}
  .pn-conn{width:3px;height:20px;margin:0;margin-left:auto;margin-right:auto}
  .pn-node{width:auto;flex-direction:row;gap:12px}
  .pn-orb{width:56px;height:56px;font-size:22px}
  .pn-step{display:none}
  .tmpl-grid{grid-template-columns:1fr}
  .proof-inner{flex-direction:column;gap:6px;text-align:center}
  .proof-sep{display:none}
}
/* Overflow & touch fixes */
.tab-row{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tab-row::-webkit-scrollbar{display:none}
.dash-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none}
.dash-tabs::-webkit-scrollbar{display:none}
.is-body{min-width:0;overflow:hidden}
.compare-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
.mkt{overflow-x:hidden}
.intake-flow{max-width:100%}
.intake-step{max-width:100%}
/* ══════════════════ TOAST NOTIFICATIONS ══════════════════ */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9000;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.toast{
  background:var(--s1);border:1px solid var(--border2);border-radius:10px;
  padding:13px 18px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:11px;
  font-size:13px;color:var(--ink);min-width:260px;max-width:380px;
  animation:toastIn 0.3s cubic-bezier(0.34,1.4,0.64,1) both;pointer-events:all;
  font-family:var(--font-body);
}
.toast.out{animation:toastOut 0.3s ease both;}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(40px)}}
.toast-ico{font-size:18px;flex-shrink:0}
.toast-msg{flex:1;line-height:1.45}
.toast-close{background:none;border:none;color:var(--muted2);cursor:pointer;font-size:15px;flex-shrink:0;padding:0}
.toast.t-success{border-left:3px solid var(--emerald)}
.toast.t-error{border-left:3px solid var(--rose)}
.toast.t-info{border-left:3px solid var(--accent)}
.toast.t-warn{border-left:3px solid var(--amber)}
/* ══════════════════ NAV AUTH AVATAR ══════════════════ */
.nav-auth-avatar{
  width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--violet));
  border:2px solid rgba(255,255,255,0.15);display:grid;place-items:center;cursor:pointer;
  font-size:14px;font-weight:700;color:#fff;font-family:var(--font-body);
  transition:all 0.2s;flex-shrink:0;
}
.nav-auth-avatar:hover{border-color:rgba(255,255,255,0.4);transform:scale(1.05)}
.nav-sign-in-btn{
  background:transparent;border:1px solid var(--border2);color:var(--ink);
  padding:8px 18px;border-radius:10px;font-family:var(--font-body);font-size:12px;font-weight:600;
  cursor:pointer;transition:all 0.2s;white-space:nowrap;
}
.nav-sign-in-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-lt)}
/* ══════════════════ AUTH MODAL ══════════════════ */
.auth-modal{
  position:fixed;inset:0;z-index:2000;display:none;align-items:center;justify-content:center;
  background:rgba(0,0,0,0.75);backdrop-filter:blur(8px);padding:20px;
}
.auth-modal.on{display:flex}
.auth-box{
  background:var(--s1);border:1.5px solid var(--border2);border-radius:20px;
  width:100%;max-width:420px;padding:36px 36px 32px;box-shadow:var(--shadow-lg);
  position:relative;
}
.auth-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;width:32px;height:32px;border-radius:6px;display:grid;place-items:center}
.auth-close:hover{background:var(--s3);color:var(--ink)}
.auth-logo-row{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.auth-gem{width:34px;height:34px;border-radius:8px;background:var(--accent);display:grid;place-items:center;font-family:var(--font-serif);font-size:12px;font-style:italic;color:#fff}
.auth-title{font-family:var(--font-head);font-size:20px;font-weight:700;letter-spacing:-0.03em;color:var(--ink)}
.auth-sub{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:24px}
.auth-google-btn{
  width:100%;padding:12px 20px;border-radius:10px;border:1.5px solid var(--border2);
  background:var(--s2);color:var(--ink);font-family:var(--font-body);font-size:14px;font-weight:600;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;
  transition:all 0.2s;margin-bottom:20px;
}
.auth-google-btn:hover{border-color:var(--accent);background:var(--accent-lt)}
.auth-google-btn svg{width:20px;height:20px;flex-shrink:0}
.auth-divider{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-divider span{font-size:11px;color:var(--muted2);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.1em;white-space:nowrap}
.auth-field-wrap{display:flex;flex-direction:column;gap:14px;margin-bottom:20px}
.auth-input{
  width:100%;padding:11px 14px;border-radius:9px;border:1.5px solid var(--border2);
  background:var(--s2);color:var(--ink);font-family:var(--font-body);font-size:13px;
  transition:border-color 0.2s;
}
.auth-input:focus{outline:none;border-color:var(--accent)}
.auth-input::placeholder{color:var(--muted2)}
.auth-submit{
  width:100%;padding:13px;border-radius:10px;border:none;background:var(--accent);color:#fff;
  font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;transition:all 0.2s;
  margin-bottom:14px;
}
.auth-submit:hover{filter:brightness(1.1)}
.auth-switch{text-align:center;font-size:12px;color:var(--muted)}
.auth-switch button{background:none;border:none;color:var(--accent);font-family:var(--font-body);font-size:12px;cursor:pointer;font-weight:600;padding:0}
.auth-terms{font-size:10px;color:var(--muted2);text-align:center;line-height:1.6;margin-top:14px}
.auth-terms a{color:var(--accent);text-decoration:none}
.auth-error{background:var(--rose-lt);border:1px solid rgba(255,61,110,0.3);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--rose);margin-bottom:14px;display:none}
.auth-error.on{display:block}
.auth-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin 0.7s linear infinite;display:none}
.auth-spinner.on{display:block}
/* ══════════════════ USER DASHBOARD MODAL ══════════════════ */
.dash-overlay{
  position:fixed;inset:0;z-index:1800;display:none;
  background:rgba(26,23,20,0.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  align-items:center;justify-content:center;padding:24px;
}
.dash-overlay.on{display:flex;animation:dashFadeIn 0.25s ease both}
@keyframes dashFadeIn{from{opacity:0}to{opacity:1}}
@keyframes dashSlideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
[data-theme="dark"] .dash-overlay{background:rgba(12,14,20,0.6)}
.dash-modal{
  background:var(--s1);border:1.5px solid var(--border);border-radius:20px;
  width:100%;max-width:680px;max-height:88vh;display:flex;flex-direction:column;
  box-shadow:var(--shadow-lg);animation:dashSlideUp 0.3s ease both;overflow:hidden;
}
.dash-header{
  padding:24px 28px 0;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
}
.dash-header-left{display:flex;align-items:center;gap:14px}
.dash-h-title{font-family:var(--font-serif);font-size:28px;font-style:italic;color:var(--ink);letter-spacing:-0.01em}
.dash-back{
  width:36px;height:36px;border-radius:10px;border:1.5px solid var(--border);
  background:var(--s2);color:var(--muted);font-size:16px;cursor:pointer;
  transition:all 0.2s;display:grid;place-items:center;flex-shrink:0;
}
.dash-back:hover{border-color:var(--border2);color:var(--ink);background:var(--s3)}
/* ── HORIZONTAL TAB BAR ── */
.dash-tabs{
  display:flex;gap:0;padding:0 28px;margin-top:20px;border-bottom:1.5px solid var(--border);flex-shrink:0;overflow-x:auto;
}
.dash-nav-item{
  display:flex;align-items:center;gap:7px;padding:10px 16px 12px;
  cursor:pointer;transition:all 0.15s;border:none;background:none;
  border-bottom:2.5px solid transparent;margin-bottom:-1.5px;white-space:nowrap;
}
.dash-nav-item:hover{background:var(--s2);border-radius:8px 8px 0 0}
.dash-nav-item.active{border-bottom-color:var(--accent)}
.dash-nav-ico{font-size:14px;flex-shrink:0}
.dash-nav-lbl{font-size:13px;font-weight:500;color:var(--muted);font-family:var(--font-body);letter-spacing:0.01em}
.dash-nav-item.active .dash-nav-lbl{color:var(--accent);font-weight:700}
.dash-nav-item:hover .dash-nav-lbl{color:var(--ink)}
/* ── CONTENT AREA ── */
.dash-content{flex:1;overflow-y:auto;padding:24px 28px 28px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.dash-content::-webkit-scrollbar{width:5px}
.dash-content::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.dash-tab-pane{display:none}
.dash-tab-pane.on{display:block;animation:fadeUp 0.25s ease both}
.dash-section-title{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.16em;color:var(--muted2);margin-bottom:14px}
.dash-card{background:var(--s2);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:16px;transition:all 0.2s ease}
.dash-profile-row{display:flex;align-items:center;gap:18px;margin-bottom:20px}
.dash-big-avatar{
  width:56px;height:56px;border-radius:16px;background:var(--accent);
  display:grid;place-items:center;font-size:22px;font-weight:700;color:#fff;font-family:var(--font-serif);font-style:italic;
  flex-shrink:0;
}
.dash-profile-name{font-size:20px;font-weight:700;color:var(--ink);font-family:var(--font-serif);font-style:italic;letter-spacing:-0.01em;margin-bottom:2px}
.dash-profile-email{font-size:12px;color:var(--muted);font-family:var(--font-mono)}
.dash-profile-meta{font-size:10.5px;color:var(--muted2);margin-top:3px;font-family:var(--font-mono)}
.dash-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.dash-kpi{background:var(--s1);border:1px solid var(--border);border-radius:12px;padding:16px}
.dash-kpi-val{font-family:var(--font-serif);font-size:26px;font-style:italic;color:var(--accent);margin-bottom:2px}
.dash-kpi-lbl{font-size:10px;color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.08em}
.plan-card{background:var(--accent-lt);border:1px solid var(--accent-mid);border-radius:16px;padding:24px;margin-bottom:16px}
.plan-card-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.plan-name{font-family:var(--font-head);font-size:20px;font-weight:700;color:var(--accent);letter-spacing:-0.02em}
.plan-price-big{font-family:var(--font-serif);font-size:32px;font-style:italic;color:var(--ink)}
.plan-features{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.plan-feat{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted)}
.plan-feat-ico{color:var(--accent);font-size:13px;flex-shrink:0}
.history-list{display:flex;flex-direction:column;gap:8px}
.history-item{background:var(--s1);border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;align-items:center;gap:12px;transition:border-color 0.2s}
.history-item:hover{border-color:var(--accent-mid)}
.hi-score{
  width:46px;height:46px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-serif);font-size:18px;font-style:italic;font-weight:700;
}
.hi-score.good{background:var(--accent-lt);color:var(--accent)}
.hi-score.mid{background:var(--amber-lt);color:var(--amber)}
.hi-score.low{background:var(--rose-lt);color:var(--rose)}
.hi-role{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:2px}
.hi-co{font-size:11px;color:var(--muted);font-family:var(--font-mono)}
.hi-date{font-size:10px;color:var(--muted2);font-family:var(--font-mono);margin-top:2px}
.hi-reload{margin-left:auto;background:var(--s2);border:1.5px solid var(--border);color:var(--muted);padding:8px 16px;border-radius:8px;font-size:11px;font-weight:600;cursor:pointer;transition:all 0.2s;white-space:nowrap;font-family:var(--font-body);min-height:36px}
.hi-reload:hover{border-color:var(--accent);color:var(--accent)}
.hi-empty{text-align:center;padding:32px 16px;color:var(--muted);font-family:var(--font-mono);font-size:12px}
.hi-actions{display:flex;gap:6px;align-items:center;margin-left:auto;flex-shrink:0}
.hi-btn{background:var(--s2);border:1.5px solid var(--border);color:var(--muted);padding:8px 14px;border-radius:8px;font-size:11px;font-weight:600;cursor:pointer;transition:all 0.2s;white-space:nowrap;font-family:var(--font-body);min-height:36px}
.hi-btn:hover{border-color:var(--accent);color:var(--accent)}
.hi-btn-view{background:var(--accent-lt);border-color:var(--accent-mid);color:var(--accent)}
.hi-btn-view:hover{background:var(--accent);color:#fff}
.hi-btn-dl{background:rgba(37,99,235,0.06);border-color:rgba(37,99,235,0.2);color:#2563EB}
.hi-btn-dl:hover{background:#2563EB;color:#fff}
.hi-btn-del{background:none;border:none;color:var(--muted2);padding:8px 10px;font-size:14px;cursor:pointer;opacity:0.4;transition:opacity 0.2s;min-height:32px;min-width:32px}
.hi-btn-del:hover{opacity:1;color:var(--rose)}
.hi-saved{font-size:8px;font-family:var(--font-mono);color:var(--accent);background:var(--accent-lt);padding:1px 6px;border-radius:3px;letter-spacing:0.05em;text-transform:uppercase}
.hi-nosave{font-size:8px;font-family:var(--font-mono);color:var(--muted2);padding:1px 6px;border-radius:3px;letter-spacing:0.05em;text-transform:uppercase}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}
.settings-row:last-child{border-bottom:none}
.settings-lbl{font-size:13px;font-weight:600;color:var(--ink)}
.settings-sub{font-size:11px;color:var(--muted);margin-top:2px;font-family:var(--font-mono)}
.toggle-sw{width:44px;height:24px;background:var(--s4);border-radius:12px;position:relative;cursor:pointer;border:none;transition:background 0.2s;flex-shrink:0}
.toggle-sw.on{background:var(--accent)}
.toggle-sw::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform 0.2s;box-shadow:0 1px 3px rgba(0,0,0,0.2)}
.toggle-sw.on::after{transform:translateX(20px)}
.settings-select{background:var(--s1);border:1.5px solid var(--border);border-radius:8px;padding:7px 11px;font-family:var(--font-body);font-size:12px;color:var(--ink);cursor:pointer}
.settings-select:focus{outline:none;border-color:var(--accent)}
/* ── DASHBOARD RESPONSIVE ── */
@media(max-width:600px){
  .dash-modal{max-width:100%;max-height:100vh;border-radius:0;margin:0}
  .dash-overlay{padding:0}
  .dash-tabs{padding:0 16px;gap:0}
  .dash-nav-item{padding:8px 10px 10px}
  .dash-content{padding:16px}
  .dash-header{padding:16px 16px 0}
  .dash-kpi-grid{grid-template-columns:1fr}
}
/* ══════════════════ ADMIN PANEL ══════════════════ */
.admin-panel{
  position:fixed;inset:0;z-index:1900;display:none;background:var(--bg);flex-direction:column;
}
.admin-panel.on{display:flex;animation:fadeIn 0.2s ease both}
.admin-exit-btn{
  padding:8px 16px;border-radius:10px;border:1.5px solid var(--border);
  background:var(--s2);color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;
  transition:all 0.2s;flex-shrink:0;white-space:nowrap;font-family:var(--font-body);
}
.admin-exit-btn:hover{border-color:var(--border2);color:var(--ink);background:var(--s3)}
.admin-header{
  background:var(--nav-bg);border-bottom:1px solid rgba(255,255,255,0.06);
  padding:0 28px;height:60px;display:flex;align-items:center;gap:16px;flex-shrink:0;
}
.admin-badge{background:var(--rose-lt);color:var(--rose);border:1px solid rgba(255,61,110,0.3);padding:4px 10px;border-radius:20px;font-family:var(--font-mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em}
.admin-body{display:flex;flex:1;overflow:hidden}
.admin-sidebar{
  width:220px;flex-shrink:0;background:var(--s1);border-right:1px solid var(--border);
  padding:20px 12px;display:flex;flex-direction:column;gap:4px;
}
.admin-nav-item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;
  cursor:pointer;transition:background 0.15s;border:none;background:none;width:100%;text-align:left;
}
.admin-nav-item:hover{background:var(--s3)}
.admin-nav-item.active{background:var(--rose-lt)}
.admin-nav-lbl{font-size:13px;font-weight:500;color:var(--ink)}
.admin-nav-item.active .admin-nav-lbl{color:var(--rose);font-weight:700}
.admin-content{flex:1;overflow-y:auto;padding:20px 28px}
.admin-tab-pane{display:none}
.admin-tab-pane.on{display:block;animation:fadeUp 0.25s ease both}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.kpi-card{background:var(--s1);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow);transition:all 0.2s ease}
.kpi-val{font-family:var(--font-serif);font-size:22px;font-style:italic;color:var(--accent);margin-bottom:2px}
.kpi-lbl{font-size:9.5px;color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.08em;line-height:1.3}
.kpi-delta{font-size:10px;font-family:var(--font-mono);margin-top:3px}
.kpi-delta.up{color:var(--emerald)}
.kpi-delta.dn{color:var(--rose)}
.admin-section{background:var(--s1);border:1.5px solid var(--border);border-radius:12px;padding:16px 18px;margin-bottom:14px;box-shadow:var(--shadow)}
.admin-section canvas{max-height:140px}
.admin-section-title{font-family:var(--font-mono);font-size:9.5px;text-transform:uppercase;letter-spacing:0.18em;color:var(--muted);padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{font-family:var(--font-mono);font-size:9.5px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);padding:9px 12px;text-align:left;border-bottom:2px solid var(--border)}
.admin-table td{padding:11px 12px;border-bottom:1px solid var(--border);font-size:12.5px;color:var(--ink);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--s2)}
.user-avatar-sm{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--violet));display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;font-family:var(--font-body);flex-shrink:0}
.plan-chip{display:inline-block;padding:2px 9px;border-radius:20px;font-family:var(--font-mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em}
.chip-free{background:var(--s4);color:var(--muted);border:1px solid var(--border2)}
.chip-pro{background:var(--accent-lt);color:var(--accent);border:1px solid var(--accent-mid)}
.chip-ent{background:var(--violet-lt);color:var(--violet);border:1px solid rgba(139,124,248,0.3)}
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}
.sd-active{background:var(--emerald)}
.sd-inactive{background:var(--muted2)}
.sd-suspended{background:var(--rose)}
.admin-search{
  background:var(--s2);border:1.5px solid var(--border2);border-radius:9px;
  padding:9px 14px;font-family:var(--font-body);font-size:13px;color:var(--ink);
  width:280px;
}
.admin-search:focus{outline:none;border-color:var(--accent)}
.admin-search::placeholder{color:var(--muted2)}
.admin-btn-sm{background:var(--s3);border:1.5px solid var(--border2);color:var(--muted);padding:5px 12px;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all 0.15s}
.admin-btn-sm:hover{border-color:var(--accent);color:var(--accent)}
.admin-btn-sm.danger:hover{border-color:var(--rose);color:var(--rose)}
.health-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.health-row:last-child{border-bottom:none}
.health-lbl{font-size:13px;font-weight:600;color:var(--ink)}
.health-sub{font-size:11px;color:var(--muted);font-family:var(--font-mono);margin-top:2px}
.health-badge{padding:4px 12px;border-radius:20px;font-family:var(--font-mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.07em}
.hb-ok{background:rgba(52,211,153,0.12);color:var(--emerald);border:1px solid rgba(52,211,153,0.3)}
.hb-warn{background:var(--amber-lt);color:var(--amber);border:1px solid rgba(255,184,48,0.3)}
.hb-err{background:var(--rose-lt);color:var(--rose);border:1px solid rgba(255,61,110,0.3)}
.rev-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px}
.rev-card{background:var(--s2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.rev-val{font-family:var(--font-serif);font-size:20px;font-style:italic;color:var(--ink);margin-bottom:2px}
.rev-lbl{font-size:10px;color:var(--muted);font-family:var(--font-mono)}
.content-editor textarea{width:100%;background:var(--s2);border:1.5px solid var(--border2);border-radius:9px;padding:12px 14px;font-family:var(--font-mono);font-size:12px;color:var(--ink);resize:vertical;min-height:120px}
.content-editor textarea:focus{outline:none;border-color:var(--accent)}
.export-csv-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--s3);border:1.5px solid var(--border2);border-radius:8px;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all 0.2s}
.export-csv-btn:hover{border-color:var(--accent);color:var(--accent)}
/* ══════════════════ PRO FEATURE MODALS ══════════════════ */
.pro-modal{
  position:fixed;inset:0;z-index:2100;display:none;align-items:center;justify-content:center;
  background:rgba(0,0,0,0.75);backdrop-filter:blur(8px);padding:20px;
}
.pro-modal.on{display:flex}
.pro-modal-box{
  background:var(--s1);border:1.5px solid var(--border2);border-radius:20px;
  width:100%;max-width:680px;max-height:85vh;display:flex;flex-direction:column;
  box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.pm-header{padding:22px 28px 18px;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;gap:12px}
.pm-title{font-size:18px;font-weight:700;color:var(--ink);font-family:var(--font-head);letter-spacing:-0.02em;flex:1}
.pm-close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;width:32px;height:32px;border-radius:6px;display:grid;place-items:center;transition:all 0.15s}
.pm-close:hover{background:var(--s3);color:var(--ink)}
.pm-body{flex:1;overflow-y:auto;padding:22px 28px}
.pm-footer{padding:16px 28px;border-top:1px solid var(--border);flex-shrink:0;display:flex;gap:10px;justify-content:flex-end}
.pm-run-btn{background:var(--accent);color:#fff;border:none;padding:11px 24px;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:8px}
.pm-run-btn:hover{filter:brightness(1.1)}
.pm-run-btn:disabled{opacity:0.5;cursor:not-allowed}
.pm-result-block{background:var(--s2);border:1.5px solid var(--border);border-radius:12px;padding:18px 20px;margin-top:18px;font-size:13px;color:var(--muted);line-height:1.8;white-space:pre-wrap;font-family:var(--font-mono)}
.pm-pro-gate{background:linear-gradient(135deg,var(--violet-lt),var(--accent-lt));border:1.5px solid var(--accent-mid);border-radius:12px;padding:22px 24px;text-align:center;margin:20px 0}
.pm-gate-title{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:6px}
.pm-gate-sub{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:16px}
.pm-gate-btn{background:var(--accent);color:#fff;border:none;padding:12px 28px;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;transition:all 0.2s}
.pm-gate-btn:hover{filter:brightness(1.1)}
/* ══════════════════ CV TEMPLATE SELECTOR ══════════════════ */
.template-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
.tpl-card{
  border:2px solid var(--border);border-radius:16px;overflow:hidden;cursor:pointer;
  transition:all 0.2s;background:var(--s1);
}
.tpl-card:hover{border-color:var(--accent-mid);transform:translateY(-2px)}
.tpl-card.selected{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-lt)}
.tpl-preview{height:120px;position:relative;overflow:hidden;border-bottom:1px solid var(--border)}
.tpl-preview-content{padding:8px;transform-origin:top left;transform:scale(0.4);width:250%;height:250%}
.tpl-info{padding:12px 14px}
.tpl-name{font-size:12px;font-weight:700;color:var(--ink);margin-bottom:3px}
.tpl-desc{font-size:10.5px;color:var(--muted);font-family:var(--font-mono)}
.tpl-pro-badge{display:inline-block;background:var(--violet-lt);color:var(--violet);border:1px solid rgba(139,124,248,0.3);padding:1px 7px;border-radius:20px;font-size:9px;font-family:var(--font-mono);font-weight:700;text-transform:uppercase;margin-left:6px}
.tpl-free-badge{display:inline-block;background:var(--accent-lt);color:var(--accent);border:1px solid var(--accent-mid);padding:1px 7px;border-radius:20px;font-size:9px;font-family:var(--font-mono);font-weight:700;text-transform:uppercase;margin-left:6px}
.tpl-unlocked-badge{background:rgba(16,185,129,0.1);color:#059669;border-color:rgba(16,185,129,0.3)}
.tpl-locked{opacity:0.7;cursor:not-allowed}
.tpl-locked:hover{transform:none;box-shadow:none}
.tpl-lock-overlay{position:absolute;inset:0;background:rgba(255,255,255,0.6);display:flex;align-items:center;justify-content:center;font-size:28px;border-radius:12px;backdrop-filter:blur(2px)}
.tpl-preview{position:relative}
/* ══════════════════ ATS SYSTEM SELECTOR (Pro) ══════════════════ */
.ats-sys-select{
  background:var(--s2);border:1.5px solid var(--border2);border-radius:9px;
  padding:9px 14px;font-family:var(--font-body);font-size:13px;color:var(--ink);width:100%;
}
.ats-sys-select:focus{outline:none;border-color:var(--accent)}
/* ══════════════════ SIGN-IN NUDGE BANNER ══════════════════ */
.sign-in-nudge{
  background:linear-gradient(135deg,var(--accent-lt),var(--violet-lt));
  border:1.5px solid var(--accent-mid);border-radius:12px;padding:14px 20px;
  display:flex;align-items:center;gap:14px;margin-bottom:20px;
}
.sin-ico{font-size:22px;flex-shrink:0}
.sin-text{flex:1;font-size:13px;color:var(--ink);line-height:1.55}
.sin-text strong{color:var(--accent)}
.sin-btn{background:var(--accent);color:#fff;border:none;padding:9px 18px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:all 0.2s;white-space:nowrap;font-family:var(--font-body)}
.sin-btn:hover{filter:brightness(1.1)}
.sin-dismiss{background:none;border:none;color:var(--muted2);cursor:pointer;font-size:18px;padding:0}
@keyframes spin{to{transform:rotate(360deg)}}
/* ══════════════════════════════════════
   AUTH MODAL — Sign In / Sign Up
══════════════════════════════════════ */
.auth-modal{position:fixed;inset:0;background:rgba(0,0,0,0.72);backdrop-filter:blur(6px);z-index:3200;display:none;align-items:center;justify-content:center;padding:20px}
.auth-modal.open{display:flex}
.auth-card{background:var(--s1);border:1px solid var(--border2);border-radius:20px;padding:36px 40px;width:100%;max-width:440px;box-shadow:var(--shadow-lg);position:relative;animation:slideUp 0.25s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.auth-close{position:absolute;top:16px;right:16px;background:transparent;border:1px solid var(--border2);border-radius:8px;width:32px;height:32px;display:grid;place-items:center;cursor:pointer;color:var(--muted);font-size:14px;transition:all 0.15s}
.auth-close:hover{border-color:var(--rose);color:var(--rose)}
.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}
.auth-logo-gem{width:32px;height:32px;background:var(--accent);border-radius:8px;display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;font-weight:700;color:#fff;letter-spacing:-0.03em}
.auth-logo-txt{font-family:var(--font-body);font-size:14px;font-weight:700;color:var(--ink)}
.auth-tabs{display:flex;gap:0;border:1px solid var(--border2);border-radius:10px;padding:4px;margin-bottom:28px}
.auth-tab{flex:1;padding:9px 12px;border:none;background:transparent;border-radius:7px;font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all 0.18s}
.auth-tab.on{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(74,144,217,0.3)}
.auth-pane{display:none}.auth-pane.on{display:block}
.auth-h{font-size:20px;font-weight:800;color:var(--ink);margin-bottom:6px}
.auth-sub{font-size:13px;color:var(--muted);margin-bottom:24px;line-height:1.6}
.auth-field{margin-bottom:16px}
.auth-field label{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.auth-field input{width:100%;background:var(--s2);border:1px solid var(--border2);border-radius:10px;padding:12px 14px;font-family:var(--font-body);font-size:14px;color:var(--ink);transition:border-color 0.18s;outline:none}
.auth-field input:focus{border-color:var(--accent);box-shadow:var(--glow-a)}
.auth-field input.err{border-color:var(--rose)}
.auth-err{font-size:12px;color:var(--rose);margin-top:5px;display:none}
.auth-err.show{display:block}
.auth-btn{width:100%;padding:13px;background:var(--accent);border:none;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:800;color:#fff;cursor:pointer;transition:all 0.2s;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:8px}
.auth-btn:hover{filter:brightness(1.1)}.auth-btn:disabled{opacity:0.6;cursor:not-allowed}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted2);font-size:12px;font-family:var(--font-mono)}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border2)}
.google-btn{width:100%;padding:12px;background:var(--s2);border:1px solid var(--border2);border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--ink);cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:10px}
.google-btn:hover{border-color:var(--accent);background:var(--accent-lt)}
.auth-switch{text-align:center;margin-top:18px;font-size:13px;color:var(--muted)}
.auth-switch button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;font-weight:600;text-decoration:underline;padding:0}
.auth-footer-note{font-size:11px;color:var(--muted2);text-align:center;margin-top:16px;line-height:1.6}
.auth-footer-note a{color:var(--accent)}
.auth-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin 0.6s linear infinite}
/* old dashboard modal styles removed — unified in main dashboard block above */
/* ══════════════════════════════════════
   ADMIN PANEL
══════════════════════════════════════ */
.admin-panel{position:fixed;inset:0;background:var(--bg);z-index:4000;display:none;flex-direction:column;overflow:hidden}
.admin-panel.open{display:flex}
.admin-nav{background:var(--nav-bg);border-bottom:1px solid rgba(255,255,255,0.08);padding:0 28px;display:flex;align-items:center;gap:6px;height:60px;flex-shrink:0;overflow-x:auto}
.admin-nav-logo{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--rose);letter-spacing:0.06em;margin-right:12px;display:flex;align-items:center;gap:8px;flex-shrink:0}
.admin-nav-tab{padding:8px 14px;border:none;background:transparent;border-radius:8px;font-family:var(--font-body);font-size:13px;font-weight:600;color:rgba(255,255,255,0.55);cursor:pointer;transition:all 0.18s;white-space:nowrap}
.admin-nav-tab.on{background:rgba(255,255,255,0.1);color:#fff}
.admin-nav-tab:hover{background:rgba(255,255,255,0.07);color:rgba(255,255,255,0.85)}
.admin-close-btn{margin-left:auto;padding:8px 16px;background:rgba(242,87,116,0.12);border:1px solid rgba(242,87,116,0.3);border-radius:8px;font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--rose);cursor:pointer;transition:all 0.18s;flex-shrink:0}
.admin-close-btn:hover{background:rgba(242,87,116,0.22)}
.admin-body{flex:1;overflow-y:auto;padding:28px}
.admin-pane{display:none}.admin-pane.on{display:block}
.admin-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.admin-kpi{background:var(--s1);border:1px solid var(--border);border-radius:16px;padding:20px 22px}
.admin-kpi-lbl{font-family:var(--font-mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.admin-kpi-val{font-size:28px;font-weight:800;color:var(--ink)}
.admin-kpi-sub{font-size:12px;color:var(--muted);margin-top:4px}
.admin-kpi-delta{display:inline-block;font-size:11px;font-weight:700;padding:2px 7px;border-radius:20px;margin-top:6px}
.admin-kpi-delta.up{background:rgba(52,211,153,0.12);color:var(--emerald)}
.admin-kpi-delta.dn{background:var(--rose-lt);color:var(--rose)}
.admin-table-wrap{background:var(--s1);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-bottom:24px}
.admin-table-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}
.admin-table-title{font-size:14px;font-weight:700;color:var(--ink)}
.admin-search{background:var(--s2);border:1px solid var(--border2);border-radius:8px;padding:8px 12px;font-family:var(--font-body);font-size:13px;color:var(--ink);outline:none;width:220px;transition:border-color 0.18s}
.admin-search:focus{border-color:var(--accent)}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);padding:10px 16px;text-align:left;border-bottom:1px solid var(--border)}
.admin-table td{padding:12px 16px;font-size:13px;color:var(--ink2);border-bottom:1px solid var(--border)}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--s2)}
.admin-badge{padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:0.06em;font-family:var(--font-mono)}
.admin-badge.free{background:var(--s4);color:var(--muted)}
.admin-badge.pro{background:rgba(74,144,217,0.12);color:var(--accent)}
.admin-badge.active{background:rgba(52,211,153,0.12);color:var(--emerald)}
.admin-badge.cancelled{background:var(--rose-lt);color:var(--rose)}
.admin-badge.suspended{background:var(--amber-lt);color:var(--amber)}
.admin-action-btn{padding:5px 10px;background:var(--s3);border:1px solid var(--border2);border-radius:6px;font-size:11px;font-weight:600;color:var(--muted);cursor:pointer;transition:all 0.15s;margin-right:4px}
.admin-action-btn:hover{border-color:var(--accent);color:var(--accent)}
.admin-action-btn.danger:hover{border-color:var(--rose);color:var(--rose)}
.admin-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
.admin-chart-card{background:var(--s1);border:1px solid var(--border);border-radius:16px;padding:20px}
.admin-chart-title{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:16px}
.admin-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.admin-editor-card{background:var(--s1);border:1px solid var(--border);border-radius:16px;padding:20px}
.admin-editor-card h3{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:14px}
.admin-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.admin-toggle-row label{color:var(--ink2)}
.admin-textarea{width:100%;background:var(--s2);border:1px solid var(--border2);border-radius:8px;padding:10px 12px;font-family:var(--font-body);font-size:13px;color:var(--ink);resize:vertical;outline:none;min-height:80px}
.admin-textarea:focus{border-color:var(--accent)}
.admin-save-btn{margin-top:12px;padding:9px 20px;background:var(--accent);border:none;border-radius:8px;font-family:var(--font-body);font-size:13px;font-weight:700;color:#fff;cursor:pointer;transition:all 0.2s}
.admin-save-btn:hover{filter:brightness(1.1)}
/* ── Admin layout utility classes (replace inline styles for responsive control) ── */
.admin-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.admin-4col{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.admin-search-bar{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.admin-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.health-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.health-card{background:var(--s1);border:1px solid var(--border);border-radius:16px;padding:20px}
.health-status{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.health-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.health-dot.ok{background:var(--emerald)}
.health-dot.warn{background:var(--amber)}
.health-dot.err{background:var(--rose);animation:hpulse 1.5s infinite}
@keyframes hpulse{0%,100%{opacity:1}50%{opacity:0.4}}
.health-name{font-size:13px;font-weight:700;color:var(--ink)}
.health-val{font-size:24px;font-weight:800;color:var(--ink);margin-bottom:4px}
.health-sub{font-size:12px;color:var(--muted)}
.admin-log{background:var(--s2);border:1px solid var(--border);border-radius:10px;padding:14px;font-family:var(--font-mono);font-size:11px;color:var(--muted);max-height:200px;overflow-y:auto;line-height:1.9}
.admin-log .log-ok{color:var(--emerald)}.admin-log .log-warn{color:var(--amber)}.admin-log .log-err{color:var(--rose)}
.admin-export-btn{padding:9px 18px;background:var(--s2);border:1px solid var(--border2);border-radius:8px;font-size:13px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all 0.18s}
.admin-export-btn:hover{border-color:var(--accent);color:var(--accent)}
/* ── Admin responsive: tablet ─────────────────────────────── */
@media(max-width:900px){
  .admin-kpi-grid{grid-template-columns:repeat(2,1fr)}
  .admin-charts-row{grid-template-columns:1fr}
  .admin-editor-grid{grid-template-columns:1fr}
  .health-grid{grid-template-columns:1fr 1fr}
  .kpi-grid{grid-template-columns:1fr 1fr;gap:8px}
  .rev-grid{grid-template-columns:1fr 1fr;gap:8px}
  .admin-2col{grid-template-columns:1fr}
  .admin-4col{grid-template-columns:1fr 1fr}
}
/* ── Admin responsive: mobile ─────────────────────────────── */
@media(max-width:700px){
  /* Sidebar → compact horizontal tab strip */
  .admin-body{flex-direction:column}
  .admin-sidebar{
    width:100%;flex-direction:row;flex-wrap:nowrap;
    overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
    padding:6px 10px;border-right:none;border-bottom:1px solid var(--border);
    gap:2px;flex-shrink:0;height:auto;
  }
  .admin-sidebar::-webkit-scrollbar{display:none}
  .admin-nav-item{flex-direction:column;flex-shrink:0;gap:2px;padding:6px 10px;min-width:auto;align-items:center;border-radius:8px}
  .admin-nav-lbl{font-size:10px;white-space:nowrap}
  /* Header */
  .admin-header{padding:0 14px;gap:8px}
  .admin-header>div:last-child{display:none}
  .admin-badge{font-size:8px;padding:3px 7px}
  /* Content */
  .admin-content{padding:12px 10px;flex:1;overflow-y:auto}
  /* KPI / revenue grids */
  .kpi-grid{grid-template-columns:1fr 1fr;gap:7px;margin-bottom:10px}
  .kpi-val{font-size:17px}
  .kpi-card{padding:10px 12px}
  .rev-grid{grid-template-columns:1fr 1fr;gap:7px}
  .rev-card{padding:10px 12px}
  .rev-val{font-size:16px}
  /* Column grids → single col */
  .admin-2col{grid-template-columns:1fr}
  .admin-4col{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
  .health-grid{grid-template-columns:1fr}
  /* Tables: scroll container */
  .admin-section{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:12px 10px}
  .admin-table{min-width:520px}
  .admin-section-title{font-size:9px}
  /* Search bar: stack on small screens */
  .admin-search-bar{flex-wrap:wrap}
  .admin-search-bar .admin-search,.admin-search-bar .settings-select{width:100%;flex:1 1 100%}
  .admin-search-bar .export-csv-btn{width:100%}
  /* Admin nav (top bar variant) */
  .admin-nav{padding:0 10px}
}
@media(max-width:480px){
  .kpi-grid{gap:5px}
  .kpi-val{font-size:15px}
  .admin-4col{grid-template-columns:1fr 1fr}
  .admin-content{padding:8px}
  .admin-header{padding:0 10px}
  .admin-header .dash-h-title{font-size:13px}
  .admin-badge{display:none}
  .admin-exit-btn{font-size:12px;padding:6px 12px}
}
/* ══════════════════════════════════════
   PRO FEATURES
══════════════════════════════════════ */
.pro-feature-modal{position:fixed;inset:0;background:rgba(0,0,0,0.72);backdrop-filter:blur(6px);z-index:3000;display:none;align-items:center;justify-content:center;padding:20px}
.pro-feature-modal.open{display:flex}
.pf-card{background:var(--s1);border:1px solid var(--border2);border-radius:20px;width:100%;max-width:760px;max-height:88vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden;animation:slideUp 0.25s ease}
.pf-header{padding:22px 28px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.pf-title{font-size:18px;font-weight:800;color:var(--ink)}
.pf-close{background:transparent;border:1px solid var(--border2);border-radius:8px;width:32px;height:32px;display:grid;place-items:center;cursor:pointer;color:var(--muted);font-size:14px;transition:all 0.15s}
.pf-close:hover{border-color:var(--rose);color:var(--rose)}
.pf-body{overflow-y:auto;padding:24px 28px;flex:1}
.pf-body h3{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:12px;margin-top:20px}
.pf-body h3:first-child{margin-top:0}
.pf-body p{font-size:13px;color:var(--ink2);line-height:1.8;margin-bottom:12px}
.pf-run-btn{padding:11px 24px;background:var(--accent);border:none;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:700;color:#fff;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:8px}
.pf-run-btn:hover{filter:brightness(1.1)}.pf-run-btn:disabled{opacity:0.5;cursor:not-allowed}
.pf-result-box{background:var(--s2);border:1px solid var(--border2);border-radius:12px;padding:18px;margin-top:16px;font-size:13px;color:var(--ink2);line-height:1.85;white-space:pre-wrap}
.pf-result-box strong{color:var(--ink)}
.tmpl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.tmpl-card{border:2px solid var(--border2);border-radius:12px;padding:14px;cursor:pointer;transition:all 0.2s;text-align:center}
.tmpl-card:hover{border-color:var(--accent)}
.tmpl-card.sel{border-color:var(--accent);background:var(--accent-lt)}
.tmpl-preview{height:90px;background:var(--s3);border-radius:8px;margin-bottom:10px;display:flex;align-items:center;justify-content:center;font-size:10px;font-family:var(--font-mono);color:var(--muted)}
.tmpl-name{font-size:13px;font-weight:700;color:var(--ink)}
.tmpl-desc{font-size:11px;color:var(--muted);margin-top:3px}
.ats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.ats-opt{padding:10px 14px;background:var(--s2);border:1px solid var(--border2);border-radius:10px;cursor:pointer;transition:all 0.18s;font-size:13px;color:var(--ink2);display:flex;flex-direction:column;gap:3px}
.ats-opt:hover{border-color:var(--accent)}
.ats-opt.sel{border-color:var(--accent);background:var(--accent-lt);color:var(--ink)}
.ats-opt span{font-size:10px;color:var(--muted);font-family:var(--font-mono)}
.salary-table{width:100%;border-collapse:collapse;margin-top:14px}
.salary-table th{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);padding:8px 12px;text-align:left;border-bottom:1px solid var(--border)}
.salary-table td{padding:10px 12px;font-size:13px;color:var(--ink2);border-bottom:1px solid var(--border)}
.salary-table td.hl{color:var(--ink);font-weight:700}
.interview-q{background:var(--s2);border:1px solid var(--border2);border-radius:10px;padding:14px 16px;margin-bottom:10px}
.interview-q-num{font-family:var(--font-mono);font-size:10px;color:var(--accent);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:5px}
.interview-q-text{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:8px}
.interview-q-hint{font-size:12px;color:var(--muted);line-height:1.6}
.pro-gate{background:var(--s1);border:1px solid var(--accent-mid);border-radius:16px;padding:28px;text-align:center;margin-bottom:20px}
.pro-gate-icon{font-size:36px;margin-bottom:12px}
.pro-gate-title{font-size:18px;font-weight:800;color:var(--ink);margin-bottom:8px}
.pro-gate-sub{font-size:13px;color:var(--muted);margin-bottom:20px;line-height:1.6}
.pro-gate-btn{padding:12px 28px;background:var(--accent);border:none;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:700;color:#fff;cursor:pointer;transition:all 0.2s}
.pro-gate-btn:hover{filter:brightness(1.1)}
.pdf-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--accent),var(--violet));border:none;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:800;color:#fff;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:10px}
.pdf-btn:hover{filter:brightness(1.1);box-shadow:0 6px 20px rgba(74,144,217,0.3)}
.pdf-btn:disabled{opacity:0.5;cursor:not-allowed}
.pro-feature-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.pf-action-btn{padding:10px 12px;background:var(--s2);border:1px solid var(--border2);border-radius:10px;font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all 0.18s;display:flex;align-items:center;gap:6px;text-align:left}
.pf-action-btn:hover{border-color:var(--accent);color:var(--accent)}
.pf-action-btn .pf-lock{color:var(--amber);font-size:10px}
.btn-signin{background:transparent;border:1px solid rgba(255,255,255,0.2);border-radius:8px;padding:8px 16px;font-family:var(--font-body);font-size:13px;font-weight:600;color:rgba(255,255,255,0.85);cursor:pointer;transition:all 0.2s}
.btn-signin:hover{background:rgba(255,255,255,0.08)}
/* ══ SHARE YOUR SCORE — Viral Growth Mechanic ══ */
.share-score-card{background:linear-gradient(135deg,var(--accent-lt),var(--violet-lt));border:1.5px solid var(--accent-mid);border-radius:16px;padding:20px 22px;margin-top:16px;text-align:center}
.share-score-card .ssc-title{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--ink);margin-bottom:6px}
.share-score-card .ssc-sub{font-size:11px;color:var(--muted);margin-bottom:14px;line-height:1.5}
.share-score-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.share-score-btns button{padding:9px 16px;border-radius:8px;font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border2);background:var(--s1);color:var(--ink);transition:all 0.18s;display:flex;align-items:center;gap:6px}
.share-score-btns button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-lt)}
.share-score-btns .share-li{border-color:rgba(10,102,194,0.3);color:#0a66c2}
.share-score-btns .share-li:hover{background:rgba(10,102,194,0.08)}
.share-score-btns .share-x{border-color:rgba(0,0,0,0.2);color:var(--ink)}
.share-score-btns .share-x:hover{background:var(--s2)}
.share-score-btns .share-wa{border-color:rgba(37,211,102,0.3);color:#25d366}
.share-score-btns .share-wa:hover{background:rgba(37,211,102,0.06)}
.share-score-btns .share-copy{border-color:var(--accent-mid);color:var(--accent)}
/* ══ LAUNCH COUNTDOWN BANNER ══ */
.launch-banner{background:#f0c640;color:#1a1a1a;padding:10px 20px;text-align:center;font-family:var(--font-body);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:relative;z-index:10}
.launch-banner .lb-text{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}
.launch-banner .lb-timer{font-family:var(--font-mono);font-size:14px;font-weight:700;background:rgba(0,0,0,0.12);padding:4px 10px;border-radius:6px;letter-spacing:0.05em;min-width:90px;text-align:center}
.launch-banner .lb-cta{padding:6px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-family:var(--font-body);font-size:12px;font-weight:700;cursor:pointer;transition:all 0.15s;white-space:nowrap}
.launch-banner .lb-cta:hover{transform:scale(1.04);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.launch-banner .lb-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(0,0,0,0.4);font-size:16px;cursor:pointer;padding:4px}
.launch-banner .lb-close:hover{color:#1a1a1a}
@media(max-width:600px){.launch-banner{font-size:11px;padding:8px 14px;gap:8px}.launch-banner .lb-timer{font-size:12px}}
/* ══ WELCOME BANNER — Auto-created users (post-payment) ══ */
.welcome-banner{background:linear-gradient(135deg,#059669,#10b981);color:#fff;padding:12px 20px;text-align:center;font-family:var(--font-body);font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;position:relative;z-index:10}
.welcome-banner strong{font-weight:700}
.welcome-banner .wb-cta{padding:6px 16px;background:#fff;color:#059669;border:none;border-radius:6px;font-family:var(--font-body);font-size:12px;font-weight:700;cursor:pointer;transition:all 0.15s;white-space:nowrap}
.welcome-banner .wb-cta:hover{transform:scale(1.04);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.welcome-banner .wb-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(255,255,255,0.6);font-size:16px;cursor:pointer;padding:4px}
.welcome-banner .wb-close:hover{color:#fff}
@media(max-width:600px){.welcome-banner{font-size:11px;padding:8px 14px;gap:8px}}
/* ══ EMAIL CAPTURE — Post-pipeline nudge ══ */
.email-capture{background:var(--s2);border:1.5px solid var(--border2);border-radius:14px;padding:20px 22px;margin-top:14px;text-align:center}
.email-capture .ec-title{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--ink);margin-bottom:4px}
.email-capture .ec-sub{font-size:11px;color:var(--muted);margin-bottom:12px;line-height:1.5}
.email-capture .ec-row{display:flex;gap:8px;max-width:400px;margin:0 auto}
.email-capture .ec-input{flex:1;padding:10px 14px;border:1px solid var(--border2);border-radius:8px;font-family:var(--font-body);font-size:13px;color:var(--ink);background:var(--s1);outline:none;transition:border-color 0.18s}
.email-capture .ec-input:focus{border-color:var(--accent)}
.email-capture .ec-btn{padding:10px 18px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-family:var(--font-body);font-size:12px;font-weight:700;cursor:pointer;transition:all 0.15s;white-space:nowrap}
.email-capture .ec-btn:hover{filter:brightness(1.1)}
.email-capture .ec-btn:disabled{opacity:0.5;cursor:not-allowed}
.email-capture .ec-note{font-size:9px;color:var(--muted2);margin-top:8px;font-family:var(--font-mono)}
.email-capture.ec-done .ec-row{display:none}
.email-capture.ec-done .ec-success{display:block}
.email-capture .ec-success{display:none;font-size:13px;font-weight:600;color:var(--emerald)}
@media(max-width:480px){.email-capture .ec-row{flex-direction:column}.email-capture .ec-btn{width:100%}}
/* ══ Print ══ */
@media print{.site-nav,.proof-bar,.mkt,footer,.cookie-banner,.modal,.auth-modal,.dash-modal,.admin-panel,.pro-feature-modal,.load-ov,.a4-toolbar,.export-panel,.ad-zone,.pro-cta,.pro-banner,.skip-nav,#screen1,#screen2,#screen3{display:none!important}#screen4,.export-layout{display:block!important}.a4-inner{box-shadow:none!important;border:none!important}body{background:#fff;color:#000}}
/* ══ Reduced Motion ══ */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}}