/* ============================================================================
   GoComet ROI Calculator — "Supply Chain Savings Quest"
   Dark theme. Built on the GoComet design system tokens.
   Brand font: Proxima Nova (bundled, offline-safe).
   ========================================================================== */

/* ---- Fonts (bundled woff2 — works fully offline) ----------------------- */
@font-face {
  font-family: "Proxima Nova";
  src: url("../assets/fonts/ProximaNova-Regular.woff2") format("woff2");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Proxima Nova";
  src: url("../assets/fonts/ProximaNova-Semibold.woff2") format("woff2");
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Proxima Nova";
  src: url("../assets/fonts/ProximaNova-Bold.woff2") format("woff2");
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Proxima Nova";
  src: url("../assets/fonts/ProximaNova-Extrabold.woff2") format("woff2");
  font-weight: 800; font-style: normal; font-display: swap;
}

/* ---- Design tokens (Dark theme) ---------------------------------------- */
:root {
  /* Brand colors — GoComet Dark theme */
  --primary: #0054FF;
  --primary-hover: #112F6B;
  --secondary: #3376FF;
  --accent: #A033FF;
  --success: #179E60;
  --warning: #F68C00;
  --danger: #EB2E2E;
  --bg: #000000;
  --surface: #0A0A0A;
  --border: #262626;
  --text: #F5F7FA;
  --text-muted: #FFFFFF; /* all secondary text is now pure white (requested) */

  /* Derived elevated surfaces for the dark UI */
  --surface-2: #111317;
  --surface-3: #16181d;
  --border-soft: #1d1f25;

  /* Spacing scale (4px base) */
  --xs: 4px;  --sm: 8px;  --md: 12px; --lg: 16px; --xl: 24px;
  --2xl: 32px; --3xl: 48px; --4xl: 64px; --5xl: 96px; --6xl: 128px;

  /* Radius */
  --r-sm: 4px; --r-md: 8px; --r-lg: 12px; --r-xl: 16px; --r-2xl: 24px; --r-full: 9999px;

  --maxw: 1440px;
  --ease: cubic-bezier(0.2, 0.8, 0.3, 1);
  --shadow-lg: 0 24px 60px -20px rgba(0,0,0,0.8);
}

/* ---- Reset ------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; background: var(--bg); }
body {
  margin: 0;
  font-family: "Proxima Nova", system-ui, sans-serif;
  font-weight: 400;
  color: var(--text);
  background: transparent; /* WebGL canvas shows through */
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
button { font-family: inherit; cursor: pointer; }
img { max-width: 100%; display: block; }
h1, h2, h3, h4, h5 { margin: 0; line-height: 1.15; font-weight: 700; letter-spacing: -0.02em; }
p { margin: 0; }

/* WebGL animated background — fixed, behind everything, non-interactive */
#bgfx {
  position: fixed; inset: 0; width: 100vw; height: 100vh;
  z-index: -1; pointer-events: none; display: block; opacity: 0.45;
  background: var(--bg); /* solid fallback before/while the shader paints */
}

/* ---- Layout helpers ---------------------------------------------------- */
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--xl); }
@media (max-width: 640px) { .container { padding: 0 var(--lg); } }
.hidden { display: none !important; }

/* ---- Top bar ----------------------------------------------------------- */
.topbar {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
}
.topbar-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: var(--md) var(--xl);
  display: flex; align-items: center; justify-content: space-between; gap: var(--lg);
}
/* GoComet wordmark is now all-white — no backing chip needed on dark */
.brand-chip {
  background: transparent; border-radius: 0;
  padding: 0; display: inline-flex; align-items: center; box-shadow: none;
}
.brand-chip img { height: 26px; width: auto; }
.topbar-tag {
  font-size: 16px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-muted); font-weight: 600;
}
.topbar-right { display: flex; align-items: center; gap: var(--lg); }
.reset-btn {
  background: transparent; border: 1px solid var(--border); color: var(--text-muted);
  border-radius: var(--r-full); padding: 7px 14px; font-size: 16px; font-weight: 600;
  transition: border-color .2s, color .2s;
}
.reset-btn:hover { border-color: var(--primary); color: var(--text); }

/* ---- Screen system ----------------------------------------------------- */
.stage { padding: var(--3xl) 0 var(--5xl); }
.screen { display: none; animation: screenIn .5s var(--ease) both; }
.screen.active { display: block; }
@keyframes screenIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ---- Eyebrow / pill ---------------------------------------------------- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 16px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--secondary);
  background: color-mix(in srgb, var(--primary) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--primary) 30%, transparent);
  padding: 6px 14px; border-radius: var(--r-full);
}
.eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--secondary); box-shadow: 0 0 10px var(--secondary); }

/* ============================ WELCOME ================================== */
.hero { text-align: center; padding-top: var(--xl); position: relative; }
.hero > * { position: relative; z-index: 1; }
.hero h1 {
  font-size: clamp(3rem, 6vw, 5.5rem); font-weight: 800;
  max-width: 16ch; margin: var(--xl) auto var(--lg);
  background: linear-gradient(180deg, #fff 30%, #b9c4d6);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.hero h1 .grad {
  background: linear-gradient(110deg, var(--secondary), var(--accent));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.hero-lede {
  font-size: clamp(1.3rem, 2.2vw, 1.65rem); color: var(--text-muted);
  max-width: 60ch; margin: 0 auto var(--xl);
}
.hero-meta { color: var(--text-muted); font-size: 17px; margin-top: var(--lg); }
.hero-meta b { color: var(--text); }

/* Stat strip */
.stat-strip {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--lg);
  max-width: 760px; margin: var(--2xl) auto 0;
}
.stat {
  background: linear-gradient(180deg, var(--surface-2), var(--surface));
  border: 1px solid var(--border); border-radius: var(--r-xl);
  padding: var(--xl); text-align: center; position: relative; overflow: hidden;
}
.stat::after {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--secondary), transparent); opacity: .7;
}
.stat .v { font-size: clamp(2.4rem, 4vw, 3.4rem); font-weight: 800; color: #fff; letter-spacing: -0.03em; }
.stat .l { font-size: 16px; color: var(--text-muted); margin-top: 4px; letter-spacing: .02em; }

/* CTA row */
.cta-row { display: flex; gap: var(--md); justify-content: center; flex-wrap: wrap; margin-top: var(--2xl); }

/* Buttons */
.btn {
  border: none; border-radius: var(--r-md); padding: 18px 34px;
  font-size: 19px; font-weight: 700; letter-spacing: .01em;
  display: inline-flex; align-items: center; gap: 10px;
  transition: transform .15s var(--ease), box-shadow .2s, background .2s, border-color .2s, color .2s;
  min-height: 60px; /* touch target */
}
.btn:active { transform: translateY(1px) scale(.99); }
.btn-primary {
  color: #fff; background: linear-gradient(120deg, var(--primary), var(--secondary));
  box-shadow: 0 10px 30px -10px rgba(0,84,255,.7), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-primary:hover { box-shadow: 0 16px 40px -10px rgba(0,84,255,.9); transform: translateY(-2px); }
.btn-secondary { background: transparent; border: 1px solid var(--border); color: var(--text); }
.btn-secondary:hover { border-color: var(--secondary); background: color-mix(in srgb, var(--secondary) 10%, transparent); }
.btn-ghost { background: transparent; color: var(--secondary); border: 1px solid transparent; }
.btn-ghost:hover { background: color-mix(in srgb, var(--primary) 12%, transparent); }
.btn[disabled] { opacity: .45; cursor: not-allowed; transform: none; }
.btn .arrow { transition: transform .2s; }
.btn:hover .arrow { transform: translateX(3px); }

/* Feature preview */
.feature-preview {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--md);
  margin-top: var(--3xl);
}
.fp {
  background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg);
  padding: var(--lg); text-align: left;
}
.fp .ic { font-size: 26px; }
.fp h5 { font-size: 18px; margin: 8px 0 4px; color: #fff; }
.fp p { font-size: 16px; color: var(--text-muted); line-height: 1.45; }

/* Trust strip */
.trust { margin-top: var(--3xl); text-align: center; }
.trust .label { font-size: 16px; letter-spacing: .18em; text-transform: uppercase; color: var(--text-muted); }
.logo-wall {
  display: flex; flex-wrap: wrap; gap: var(--xl) var(--3xl); align-items: center; justify-content: center;
  margin-top: var(--lg);
}
.logo-wall img {
  height: 60px; width: auto; opacity: .82;
  filter: brightness(0) invert(1); /* render dark customer marks legibly on black */
  transition: opacity .2s;
}
.logo-wall img:hover { opacity: 1; }
.gartner-row { margin-top: var(--2xl); display: flex; justify-content: center; }
.gartner-row img {
  height: 110px; width: auto;
  filter: brightness(0) invert(1); /* white Gartner Customers' Choice badge */
}

/* ============================ QUEST PROGRESS ============================ */
.quest {
  display: flex; align-items: center; justify-content: center; gap: 0;
  margin: 0 auto var(--2xl); max-width: 620px;
}
.quest-node { display: flex; align-items: center; flex: 1; }
.quest-node:last-child { flex: 0; }
.qn-dot {
  width: 34px; height: 34px; border-radius: 50%; flex: 0 0 34px;
  display: grid; place-items: center; font-size: 17px; font-weight: 700;
  background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text-muted);
  position: relative; transition: all .35s var(--ease);
}
.qn-label {
  position: absolute; top: 42px; left: 50%; transform: translateX(-50%);
  font-size: 16px; white-space: nowrap; color: var(--text-muted); letter-spacing: .04em;
}
.qn-wrap { position: relative; display: grid; place-items: center; }
.qn-line { flex: 1; height: 2px; background: var(--border); margin: 0 6px; position: relative; overflow: hidden; }
.qn-line::after {
  content: ""; position: absolute; inset: 0; width: 0;
  background: linear-gradient(90deg, var(--primary), var(--secondary)); transition: width .5s var(--ease);
}
.quest-node.done .qn-line::after { width: 100%; }
.quest-node.done .qn-dot,
.quest-node.active .qn-dot {
  background: linear-gradient(120deg, var(--primary), var(--secondary)); border-color: transparent; color: #fff;
}
.quest-node.active .qn-dot { box-shadow: 0 0 0 5px color-mix(in srgb, var(--primary) 22%, transparent); }
.quest-node.active .qn-label { color: var(--text); font-weight: 600; }

/* ============================ FORM PANELS =============================== */
.panel {
  max-width: 720px; margin: 0 auto;
  background: linear-gradient(180deg, var(--surface-2), var(--surface));
  border: 1px solid var(--border); border-radius: var(--r-2xl);
  padding: var(--3xl); box-shadow: var(--shadow-lg);
}
.panel-head { text-align: center; margin-bottom: var(--2xl); }
.panel-head h2 { font-size: clamp(2.1rem, 4vw, 2.9rem); }
.panel-head p { color: var(--text-muted); margin-top: 8px; }
.panel-wide { max-width: 880px; }

.field { margin-bottom: var(--lg); }
.field label { display: block; font-size: 17px; font-weight: 600; color: var(--text); margin-bottom: 7px; }
.field label .req { color: var(--secondary); }
.field .hint { font-size: 16px; color: var(--text-muted); font-weight: 400; }
.input, .select {
  width: 100%; background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--r-md);
  padding: 16px 18px; font-size: 19px; min-height: 58px; transition: border-color .2s, box-shadow .2s;
  appearance: none;
}
.input::placeholder { color: rgba(255,255,255,0.45); }
.input:focus, .select:focus {
  outline: none; border-color: var(--secondary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 25%, transparent);
}
.select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238E98A8' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px;
}
.select option { background: #0c0d11; color: var(--text); }

/* Raffle opt-in checkbox */
.checkbox-field {
  display: flex; align-items: center; gap: 14px; cursor: pointer;
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-md);
  padding: 16px 18px; min-height: 58px; margin-bottom: var(--lg);
  user-select: none; transition: border-color .2s, background .2s;
}
.checkbox-field:hover { border-color: var(--secondary); }
.checkbox-field input { position: absolute; opacity: 0; width: 1px; height: 1px; }
.checkbox-field .cb-box {
  flex: 0 0 26px; width: 26px; height: 26px; border-radius: 7px;
  border: 2px solid var(--border); background: var(--surface);
  position: relative; transition: border-color .2s, background .2s;
}
.checkbox-field input:checked ~ .cb-box {
  background: linear-gradient(135deg, var(--primary), var(--accent)); border-color: transparent;
}
.checkbox-field input:checked ~ .cb-box::after {
  content: ""; position: absolute; left: 8px; top: 3px; width: 7px; height: 13px;
  border: solid #fff; border-width: 0 3px 3px 0; transform: rotate(45deg);
}
.checkbox-field input:focus-visible ~ .cb-box { box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 30%, transparent); }
.checkbox-field .cb-label { font-size: 19px; font-weight: 600; color: #fff; }

/* Phone field: country-code dropdown + number input */
.phone-group { display: flex; gap: 10px; align-items: stretch; }
.phone-group .cs { flex: 0 0 138px; }
.phone-group .input { flex: 1 1 auto; }

/* ---- Custom dropdown (replaces native <select>) --------------------- */
.cs { position: relative; width: 100%; }
.cs-native { position: absolute; opacity: 0; pointer-events: none; width: 1px; height: 1px; }
.cs-btn {
  width: 100%; background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--r-md);
  padding: 16px 44px 16px 18px; font-size: 19px; min-height: 58px;
  text-align: left; position: relative; transition: border-color .2s, box-shadow .2s;
  display: flex; align-items: center; gap: 12px;
}
.cs-btn::after {
  content: ""; position: absolute; right: 18px; top: 50%; width: 11px; height: 7px;
  transform: translateY(-50%); transition: transform .2s;
  background: #fff;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M6 8 0 0h12z'/%3E%3C/svg%3E") center/contain no-repeat;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M6 8 0 0h12z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.cs.open .cs-btn::after { transform: translateY(-50%) rotate(180deg); }
.cs-btn:focus-visible { outline: none; border-color: var(--secondary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 25%, transparent); }
.cs.open .cs-btn { border-color: var(--secondary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 25%, transparent); }
.cs-btn .cs-ph { color: rgba(255,255,255,0.45); } /* placeholder state */
.cs-btn .flag { width: 26px; height: 19px; border-radius: 3px; flex: 0 0 26px; object-fit: cover; box-shadow: 0 0 0 1px rgba(255,255,255,.12); }
.field.invalid .cs-btn { border-color: var(--danger); }

.cs-panel {
  position: absolute; z-index: 60; top: calc(100% + 8px); left: 0; right: 0;
  background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg); padding: 6px; max-height: 320px; overflow-y: auto;
  display: none; animation: csIn .16s var(--ease);
}
.cs.open .cs-panel { display: block; }
@keyframes csIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
.cs-opt {
  display: flex; align-items: center; gap: 12px; width: 100%;
  padding: 14px 16px; border-radius: var(--r-md); font-size: 18px; color: var(--text);
  cursor: pointer; border: none; background: transparent; text-align: left; min-height: 52px;
}
.cs-opt:hover, .cs-opt.active { background: color-mix(in srgb, var(--primary) 18%, transparent); }
.cs-opt[aria-selected="true"] { color: #fff; font-weight: 600; }
.cs-opt[aria-selected="true"]::after { content: "✓"; margin-left: auto; color: var(--secondary); }
.cs-opt .flag { width: 28px; height: 20px; border-radius: 3px; flex: 0 0 28px; object-fit: cover; box-shadow: 0 0 0 1px rgba(255,255,255,.12); }
.cs-opt .dial { color: rgba(255,255,255,0.7); font-variant-numeric: tabular-nums; }
.cs-opt .cname { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* scrollbar */
.cs-panel::-webkit-scrollbar { width: 10px; }
.cs-panel::-webkit-scrollbar-thumb { background: var(--border); border-radius: 8px; }
.field.invalid .input { border-color: var(--danger); }
.field .error { font-size: 16px; color: var(--danger); margin-top: 6px; display: none; }
.field.invalid .error { display: block; }
.row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--lg); }
@media (max-width: 560px){ .row-2 { grid-template-columns: 1fr; } }

/* Chip selects */
.chips { display: flex; flex-wrap: wrap; gap: 10px; }
.chip {
  border: 1px solid var(--border); background: var(--bg); color: var(--text);
  border-radius: var(--r-full); padding: 15px 24px; font-size: 18px; font-weight: 600;
  display: inline-flex; align-items: center; gap: 10px; min-height: 56px;
  transition: all .18s var(--ease); user-select: none;
}
.chip .ic { font-size: 19px; }
.chip:hover { border-color: var(--secondary); }
.chip.selected {
  background: color-mix(in srgb, var(--primary) 20%, transparent);
  border-color: var(--secondary); color: #fff;
  box-shadow: 0 0 0 1px var(--secondary), 0 8px 24px -12px rgba(0,84,255,.8);
}
.chip.selected .ic::before { content: "✓ "; }

.panel-foot { display: flex; justify-content: space-between; align-items: center; margin-top: var(--2xl); gap: var(--md); flex-wrap: wrap; }
.panel-foot .left { color: var(--text-muted); font-size: 16px; }

/* ============================ CALCULATING =============================== */
.calc-wrap { max-width: 560px; margin: var(--4xl) auto 0; text-align: center; }
.scanner {
  width: 180px; height: 180px; margin: 0 auto var(--2xl); position: relative;
  border-radius: 50%;
}
.scanner .ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 2px solid var(--border);
}
.scanner .ring.r1 { border-top-color: var(--secondary); animation: spin 1.1s linear infinite; }
.scanner .ring.r2 { inset: 22px; border-right-color: var(--accent); animation: spin 1.6s linear infinite reverse; }
.scanner .ring.r3 { inset: 44px; border-bottom-color: var(--primary); animation: spin .9s linear infinite; }
.scanner .core {
  position: absolute; inset: 64px; border-radius: 50%;
  background: radial-gradient(circle, var(--primary), transparent 70%);
  display: grid; place-items: center; font-size: 36px; animation: pulse 1.2s ease-in-out infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes pulse { 0%,100%{ transform: scale(1); opacity:.9 } 50%{ transform: scale(1.12); opacity:1 } }
.calc-status { font-size: 22px; font-weight: 600; color: #fff; min-height: 26px; }
.calc-sub { color: var(--text-muted); margin-top: 8px; font-size: 17px; }
.calc-bar { height: 6px; background: var(--surface-2); border-radius: var(--r-full); overflow: hidden; margin-top: var(--2xl); }
.calc-bar i { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--primary), var(--secondary)); border-radius: inherit; transition: width .3s linear; }

/* ============================ RESULTS =================================== */
.results-head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--lg); flex-wrap: wrap; margin-bottom: var(--xl); }
.rh-left .who { font-size: 17px; color: var(--text-muted); letter-spacing: .04em; }
.rh-left h2 { font-size: clamp(2.1rem, 4vw, 3.1rem); margin-top: 4px; }
.rh-left .role-tag {
  display: inline-block; margin-top: 8px; font-size: 16px; font-weight: 700;
  color: var(--secondary); background: color-mix(in srgb, var(--primary) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--primary) 30%, transparent);
  padding: 4px 12px; border-radius: var(--r-full);
}

/* The "scoreboard" hero — the game payoff */
.scoreboard {
  position: relative; overflow: hidden;
  background:
    radial-gradient(600px 240px at 80% -40%, rgba(160,51,255,.20), transparent 60%),
    linear-gradient(180deg, var(--surface-2), var(--surface));
  border: 1px solid var(--border); border-radius: var(--r-2xl);
  padding: var(--3xl); margin-bottom: var(--xl);
}
.sb-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: var(--3xl); align-items: center; }
@media (max-width: 820px){ .sb-grid { grid-template-columns: 1fr; gap: var(--xl); } }
.sb-main .cap { font-size: 17px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-muted); }
.sb-bignum {
  font-size: clamp(3.8rem, 10vw, 7.2rem); font-weight: 800; letter-spacing: -0.04em; line-height: 1;
  margin: 8px 0; color: #fff;
  background: linear-gradient(110deg, #fff, var(--secondary));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.sb-sub { color: var(--text-muted); font-size: 19px; }
.sb-pills { display: flex; gap: var(--md); flex-wrap: wrap; margin-top: var(--xl); }
.sb-pill {
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 12px 16px; min-width: 116px;
}
.sb-pill .k { font-size: 16px; color: var(--text-muted); text-transform: uppercase; letter-spacing: .08em; }
.sb-pill .v { font-size: 30px; font-weight: 800; color: #fff; margin-top: 2px; }

/* Rank badge */
.rank-card { text-align: center; }
.rank-medal {
  width: 188px; height: 188px; margin: 0 auto var(--md); border-radius: 50%;
  display: grid; place-items: center; position: relative;
  background: conic-gradient(from 0deg, var(--tier-a), var(--tier-b), var(--tier-a));
  box-shadow: 0 0 40px -6px var(--tier-glow);
}
.rank-medal::before { content: ""; position: absolute; inset: 8px; border-radius: 50%; background: var(--surface); }
.rank-medal .inner { position: relative; text-align: center; padding: 0 6px; }
.rank-medal .tier { font-size: 17px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-muted); }
.rank-medal .pct { font-size: 38px; white-space: nowrap; font-weight: 800; color: #fff; line-height: 1; }
.rank-medal .top { font-size: 16px; color: var(--secondary); font-weight: 700; }
.rank-name { font-size: 24px; font-weight: 800; color: #fff; }
.rank-desc { font-size: 17px; color: var(--text-muted); margin-top: 4px; }

/* Confetti */
.confetti { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.confetti i {
  position: absolute; top: -12px; width: 8px; height: 14px; opacity: 0;
  animation: fall 2.4s var(--ease) forwards;
}
@keyframes fall {
  0% { opacity: 1; transform: translateY(-10px) rotate(0); }
  100% { opacity: 0; transform: translateY(420px) rotate(540deg); }
}

/* Result section blocks */
.rsection { margin-top: var(--xl); animation: screenIn .5s var(--ease) both; }
.rsection-head { display: flex; align-items: center; gap: 12px; margin-bottom: var(--lg); }
.rsection-head .num {
  width: 30px; height: 30px; border-radius: var(--r-md); flex: 0 0 30px;
  display: grid; place-items: center; font-size: 17px; font-weight: 800; color: #fff;
  background: linear-gradient(120deg, var(--primary), var(--secondary));
}
.rsection-head h3 { font-size: 1.65rem; }
.rsection-head .lead-badge {
  margin-left: auto; font-size: 16px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--warning); border: 1px solid color-mix(in srgb, var(--warning) 40%, transparent);
  background: color-mix(in srgb, var(--warning) 12%, transparent);
  padding: 3px 10px; border-radius: var(--r-full); font-weight: 700;
}

/* metric grids */
.mgrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(215px, 1fr)); gap: var(--md); }
.metric {
  background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg);
  padding: var(--lg) var(--xl); position: relative; overflow: hidden;
}
.metric.hi { border-color: color-mix(in srgb, var(--primary) 45%, transparent); }
.metric .k { font-size: 16px; color: var(--text-muted); display: flex; align-items: center; gap: 6px; }
.metric .k .pri { width: 6px; height: 6px; border-radius: 50%; background: var(--danger); }
.metric .k .pri.med { background: var(--warning); }
.metric .v { font-size: 32px; font-weight: 800; color: #fff; margin-top: 6px; letter-spacing: -0.02em; }
.metric .kpi { font-size: 16px; color: var(--secondary); margin-top: 4px; }

/* pain point cards */
.pp-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--md); }
.pp-card {
  background: linear-gradient(180deg, var(--surface-2), var(--surface));
  border: 1px solid var(--border); border-radius: var(--r-xl); padding: var(--xl);
  transition: transform .2s, border-color .2s;
}
.pp-card:hover { transform: translateY(-3px); border-color: var(--secondary); }
.pp-card .kpi-name { font-size: 16px; letter-spacing: .04em; color: var(--secondary); font-weight: 700; text-transform: uppercase; }
.pp-card .big { font-size: 38px; font-weight: 800; color: #fff; margin: 6px 0; }
.pp-card .insight { font-size: 18px; color: var(--text-muted); line-height: 1.5; }
.pp-card .pp-stats { display: flex; gap: var(--lg); margin: 10px 0; flex-wrap: wrap; }
.pp-card .pp-stats span { font-size: 16px; color: var(--text-muted); }
.pp-card .pp-stats b { color: #fff; font-size: 19px; display: block; }

/* benchmark bars */
.bench { display: grid; gap: var(--lg); }
.bench-row { background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: var(--lg) var(--xl); }
.bench-row .bh { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 10px; }
.bench-row .bh .name { font-weight: 600; font-size: 18px; }
.bench-row .bh .tgt { font-size: 16px; color: var(--text-muted); }
.bar-track { height: 12px; background: var(--surface-3); border-radius: var(--r-full); position: relative; overflow: hidden; margin-bottom: 8px; }
.bar-fill { height: 100%; border-radius: inherit; width: 0; transition: width 1.3s var(--ease); }
.bar-fill.cur { background: var(--secondary); }
.bar-fill.goc { background: var(--accent); }
.bench-legend { display: flex; gap: var(--xl); font-size: 16px; color: var(--text-muted); }
.bench-legend i { display: inline-block; width: 12px; height: 8px; border-radius: 3px; margin-right: 6px; vertical-align: middle; }

/* score gauges */
.score-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--md); }
.score-card { background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: var(--xl); }
.score-card .sname { font-size: 17px; color: var(--text-muted); }
.score-card .sval { font-size: 46px; font-weight: 800; color: #fff; margin: 4px 0 10px; }
.score-card .sval small { font-size: 18px; color: var(--text-muted); font-weight: 600; }
.gauge { height: 10px; background: var(--surface-3); border-radius: var(--r-full); overflow: hidden; }
.gauge i { display: block; height: 100%; width: 0; border-radius: inherit; background: linear-gradient(90deg, var(--primary), var(--accent)); transition: width 1.3s var(--ease); }

/* AI recommendation cards */
.ai-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--md); }
.ai-card {
  background: linear-gradient(180deg, var(--surface-2), var(--surface));
  border: 1px solid var(--border); border-radius: var(--r-xl); padding: var(--xl); position: relative;
}
.ai-card::before {
  content: "AI"; position: absolute; top: var(--lg); right: var(--lg);
  font-size: 16px; font-weight: 800; letter-spacing: .1em; color: var(--accent);
  border: 1px solid color-mix(in srgb, var(--accent) 40%, transparent); border-radius: var(--r-full);
  padding: 2px 8px;
}
.ai-card .kpi-name { font-size: 16px; color: var(--secondary); font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.ai-card .rec { font-size: 18px; color: var(--text); margin-top: 8px; line-height: 1.55; }
.ai-card .rec b { color: #fff; }

/* locked achievements */
.locked-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--md); }
.locked-card {
  background: repeating-linear-gradient(45deg, var(--surface), var(--surface) 10px, var(--surface-2) 10px, var(--surface-2) 20px);
  border: 1px dashed var(--border); border-radius: var(--r-xl); padding: var(--xl);
  position: relative; transition: border-color .2s, transform .2s; text-align: left;
}
.locked-card:hover { border-color: var(--secondary); transform: translateY(-3px); }
.locked-card .lock { font-size: 30px; opacity: .8; }
.locked-card .q { font-size: 19px; font-weight: 700; color: #fff; margin: 8px 0; line-height: 1.35; }
.locked-card .need { font-size: 16px; color: var(--text-muted); }
.locked-card .unlock { margin-top: 12px; font-size: 16px; font-weight: 700; color: var(--secondary); display: inline-flex; align-items: center; gap: 6px; }

/* final CTA */
.final-cta {
  margin-top: var(--2xl); text-align: center;
  background: radial-gradient(600px 200px at 50% 0%, rgba(0,84,255,.22), transparent 60%), var(--surface);
  border: 1px solid var(--border); border-radius: var(--r-2xl); padding: var(--3xl);
}
.final-cta h3 { font-size: clamp(1.9rem, 3.5vw, 2.7rem); }
.final-cta p { color: var(--text-muted); margin: 10px auto var(--xl); max-width: 56ch; }

/* toast */
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(80px);
  background: var(--surface-2); border: 1px solid var(--secondary); color: #fff;
  padding: 14px 22px; border-radius: var(--r-full); font-size: 18px; font-weight: 600;
  box-shadow: var(--shadow-lg); z-index: 200; opacity: 0; transition: all .35s var(--ease); max-width: 90vw; text-align: center;
}
.toast.show { transform: translateX(-50%) translateY(0); opacity: 1; }

/* footer */
.site-foot { border-top: 1px solid var(--border); padding: var(--xl) 0; text-align: center; color: var(--text-muted); font-size: 16px; }
.site-foot b { color: var(--text); }

/* responsive */
@media (max-width: 720px) {
  .stat-strip { grid-template-columns: 1fr; }
  .feature-preview { grid-template-columns: 1fr 1fr; }
  .panel { padding: var(--xl); }
  .scoreboard { padding: var(--xl); }
}
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

/* Sections + branding that appear only in the emailed PDF, not on the page */
.pdf-only { display: none; }
.pdf-brand { display: none; }
#screen-results.exporting .pdf-only { display: block; }
#screen-results.exporting .pdf-brand { display: flex; }
#screen-results.exporting .results-head { display: none; }

.pdf-head {
  align-items: center; gap: 20px; padding: 8px 4px 22px;
  border-bottom: 1px solid var(--border); margin-bottom: 24px;
}
.pdf-head .pdf-logo { height: 34px; width: auto; }
.pdf-head-r { margin-left: auto; text-align: right; }
.pdf-head .pdf-title { font-size: 20px; font-weight: 700; color: #fff; }
.pdf-head .pdf-sub { font-size: 14px; color: var(--text-muted); margin-top: 2px; }
.pdf-foot {
  align-items: center; gap: 16px; margin-top: 28px; padding-top: 20px;
  border-top: 1px solid var(--border);
}
.pdf-foot .pdf-foot-logo { height: 22px; width: auto; opacity: .9; }
.pdf-foot .pdf-foot-txt { font-size: 13px; color: var(--text-muted); }
.pdf-foot .pdf-disc { font-size: 11px; opacity: .7; margin-top: 2px; }
