/* ══════════════════════════════════════════════════════════
   TRIPLE MUFFIN AUDIT v4 — Editorial / Typographic style
   No generic AI circles. No icon-driven layout.
   Typography leads. Structure informs.
   ══════════════════════════════════════════════════════════ */
@import url("https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800;900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600;700&display=swap");

:root {
  --bg: #fefcff;
  --surface: #fff;
  --surface-2: #f9f6fd;
  --surface-3: #f0ecf5;
  --ink: #1c1625;
  --ink-2: #3d3552;
  --ink-3: #6b6180;
  --ink-4: #a59bb4;
  --border: #e2d9ef;
  --border-soft: #eee7f7;
  --violet: #7c3aed;
  --violet-2: #a78bfa;
  --fuchsia: #c026d3;
  --orange: #f97316;
  --grad: linear-gradient(135deg, #7c3aed, #a855f7, #c026d3, #f97316);
  --grad-btn: linear-gradient(135deg, #7c3aed 0%, #9333ea 35%, #c026d3 70%, #f97316 100%);
  --critical: #dc2626;
  --critical-bg: #fef2f2;
  --warning: #d97706;
  --warning-bg: #fffbeb;
  --ok: #059669;
  --ok-bg: #ecfdf5;
  --r: .6rem; --r-md: 1rem; --r-lg: 1.3rem; --r-xl: 1.6rem; --r-pill: 999px;
  --sh: 0 1px 3px rgba(22,17,31,.04);
  --sh-md: 0 6px 24px rgba(22,17,31,.06);
  --sh-lg: 0 16px 48px rgba(22,17,31,.08);
  --sh-glow: 0 8px 32px rgba(124,58,237,.16);
  --ease: cubic-bezier(.16,1,.3,1);
}

*, *::before, *::after { box-sizing: border-box }
html { scroll-behavior: smooth; -webkit-tap-highlight-color: transparent }
body {
  margin: 0; min-height: 100vh;
  background: radial-gradient(circle at 100% 0%, rgba(124, 58, 237, 0.05) 0%, transparent 40%),
              radial-gradient(circle at 0% 100%, rgba(249, 115, 22, 0.03) 0%, transparent 40%),
              var(--bg);
  color: var(--ink); font-family: "Plus Jakarta Sans", system-ui, sans-serif;
  font-size: 15px; line-height: 1.6; -webkit-font-smoothing: antialiased;
  position: relative; overflow-x: hidden;
}
a { color: inherit; text-decoration: none }
img { display: block; max-width: 100% }
button, input { font: inherit }

/* ── Shell ──────────────────────────────────────── */
.shell { width: min(calc(100% - 2rem), 1080px); margin: 0 auto; padding: 1rem 0 3rem; position: relative; z-index: 1 }
.shell--report { padding-bottom: 6rem; display: grid; gap: 1rem }

/* ── Topbar / Brand ─────────────────────────────── */
.topbar { padding: .3rem 0 }
.brand { display: inline-flex; align-items: center; gap: .6rem }
.brand img { width: 32px; height: 32px; border-radius: 8px }
.brand span { display: grid }
.brand strong { font-family: "Outfit"; font-size: .78rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase }
.brand small { font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--violet) }

/* ── Shared ──────────────────────────────────────── */
.kicker { margin: 0 0 .3rem; font-size: .65rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; color: var(--violet) }
.pulse-dot {
  height: 0.5rem; width: 0.5rem; border-radius: 50%;
  background-color: var(--violet); position: relative; display: inline-block;
}
.pulse-dot::before {
  content: ''; position: absolute; inset: 0; border-radius: 50%;
  background-color: var(--violet);
  animation: ping 1.5s cubic-bezier(0, 0, 0.2, 1) infinite;
}
@keyframes ping {
  75%, 100% { transform: scale(2.5); opacity: 0 }
}
.pill { display: inline-flex; align-items: center; gap: .3rem; padding: .3rem .7rem; border-radius: var(--r-pill); font-size: .68rem; font-weight: 700 }
.pill--live { background: var(--ok-bg); color: var(--ok) }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .45rem;
  min-height: 2.9rem; padding: .7rem 1.4rem; border: 0; border-radius: var(--r-pill);
  font-weight: 700; font-size: .88rem; cursor: pointer;
  transition: all 220ms var(--ease);
}
.btn--primary { background: var(--grad-btn); color: #fff; box-shadow: var(--sh-glow) }
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(124,58,237,.24) }
.btn--ghost { background: var(--surface); color: var(--ink); border: 1.5px solid var(--border); box-shadow: var(--sh) }
.btn--ghost:hover { border-color: var(--violet-2); box-shadow: var(--sh-md) }
.btn--full { width: 100% }
.btn[disabled] { opacity: .45; cursor: wait }

/* ════════════════════════════════════════════════════
   ENTRY PAGE
   ════════════════════════════════════════════════════ */
.entry { display: grid; grid-template-columns: 1fr 380px; gap: 3rem; align-items: start; padding: 2.5rem 0 }
.entry__left { padding-top: 1.5rem; animation: slideUp 600ms var(--ease) both }
.entry__left h1 { margin: 0; font-family: "Outfit"; font-size: clamp(2.5rem, 5.5vw, 4.8rem); font-weight: 900; line-height: .92; letter-spacing: -.04em }
.entry__sub { margin: .8rem 0 0; color: var(--ink-2); font-size: 1.02rem; line-height: 1.7; max-width: 38ch }
.entry__pills { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .8rem }
.entry__pills span {
  padding: .45rem .75rem;
  background: rgba(255, 255, 255, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: var(--r-pill);
  font-size: .78rem;
  font-weight: 600;
  color: var(--ink-2);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--sh);
}

.txt-grad {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: inline-block;
}

.form-card {
  display: grid; gap: .75rem; padding: 1.5rem; border-radius: var(--r-xl);
  animation: slideUp 600ms var(--ease) 100ms both;
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--sh-lg);
}
.form-card h2 { margin: 0; font-family: "Outfit"; font-size: 1.6rem; font-weight: 800; letter-spacing: -.03em }
.field { display: grid; gap: .25rem }
.field span { font-size: .8rem; font-weight: 700; color: var(--ink-2) }
.field input {
  width: 100%; min-height: 3.2rem; padding: .75rem 1rem;
  border: 1px solid var(--border-soft); border-radius: var(--r-md);
  background: rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  font-size: .9rem; transition: all 300ms var(--ease);
}
.field input:focus {
  outline: 0; border-color: var(--violet);
  background: var(--surface);
  box-shadow: 0 0 0 4px rgba(124, 58, 237, 0.1);
}
.field input::placeholder { color: var(--ink-4) }
.consent { display: grid; grid-template-columns: 1.1rem 1fr; gap: .5rem; align-items: start }
.consent input { margin-top: .2rem; accent-color: var(--violet) }
.consent span { font-size: .72rem; color: var(--ink-3); line-height: 1.5 }
.form-fb { min-height: .8rem; font-size: .78rem; color: var(--ink-3) }
.form-fb[data-state="error"] { color: var(--critical) }

/* ════════════════════════════════════════════════════
   RESULTS — HERO CARD
   ════════════════════════════════════════════════════ */
.hero-card {
  display: grid; grid-template-columns: 1fr auto; gap: 1.5rem; align-items: center;
  padding: 1.4rem 1.6rem; border-radius: var(--r-xl);
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--sh-md);
  position: relative; overflow: hidden;
}
.hero-card::after { content: ""; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: var(--grad) }
.hero-card__status { display: flex; align-items: center; gap: .6rem; margin-bottom: .3rem }
.hero-card__date { font-size: .72rem; color: var(--ink-4) }
.hero-card__name { margin: 0; font-family: "Outfit"; font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 900; letter-spacing: -.04em; line-height: 1 }
.hero-card__url { margin: .2rem 0 0; font-size: .78rem; color: var(--ink-3); font-family: "JetBrains Mono"; font-weight: 500 }

.hero-card__right { min-width: 200px }
.pbar__fill { height: 5px; background: var(--grad); border-radius: var(--r-pill); transition: width 500ms var(--ease); position: relative }
.pbar__fill::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent); animation: shimmer 2.2s ease-in-out infinite }
.pbar { height: 5px; background: var(--surface-3); border-radius: var(--r-pill); overflow: hidden }
.pbar__meta { display: flex; justify-content: space-between; margin-top: .4rem; font-size: .72rem; color: var(--ink-3) }
.pbar__meta strong { font-family: "JetBrains Mono"; font-weight: 600; color: var(--violet) }
.hero-card__progress[data-done] .pbar__meta span { color: var(--ok); font-weight: 700 }
.hero-card__progress[data-done] .pbar__fill::after { animation: none }

/* ════════════════════════════════════════════════════
   STATS ROW  (3 cards)
   ════════════════════════════════════════════════════ */
.stats-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: .8rem }

.stat-card {
  display: flex; flex-direction: column; align-items: center; gap: .25rem;
  padding: 1.2rem .8rem; border-radius: var(--r-xl);
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--sh);
  cursor: pointer; transition: all 220ms var(--ease); text-align: center;
}
.stat-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md) }
.stat-card[aria-pressed="true"] { box-shadow: var(--sh-md); transform: translateY(-3px) }

.stat-card__num {
  font-family: "Outfit"; font-size: 2.4rem; font-weight: 900; letter-spacing: -.04em; line-height: 1;
}
.stat-card--critical .stat-card__num { color: var(--critical) }
.stat-card--warning .stat-card__num { color: var(--warning) }
.stat-card--ok .stat-card__num { color: var(--ok) }

.stat-card--critical[aria-pressed="true"] { border-color: var(--critical); background: var(--critical-bg) }
.stat-card--warning[aria-pressed="true"] { border-color: var(--warning); background: var(--warning-bg) }
.stat-card--ok[aria-pressed="true"] { border-color: var(--ok); background: var(--ok-bg) }

.stat-card__label { font-size: .72rem; font-weight: 700; color: var(--ink-3); text-transform: uppercase; letter-spacing: .08em }

/* ════════════════════════════════════════════════════
   PERFORMANCE ROW  (2 cards)
   ════════════════════════════════════════════════════ */
.perf-row { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem }

.perf-card {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 1.2rem 1.4rem; border-radius: var(--r-xl);
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--sh);
  transition: all 220ms var(--ease);
}
.perf-card:hover { transform: translateY(-2px); box-shadow: var(--sh-md) }
.perf-card__info h3 { margin: 0; font-family: "Outfit"; font-size: 1.1rem; font-weight: 800; letter-spacing: -.02em }
.perf-card__note { margin: .2rem 0 0; font-size: .76rem; color: var(--ink-3); max-width: 22ch; line-height: 1.4 }

/* Score ring — clean conic gradient */
.ring {
  --s: 0; --c: var(--ink-4);
  width: 68px; height: 68px; border-radius: 50%; flex-shrink: 0;
  display: grid; place-items: center;
  background: conic-gradient(from 220deg, var(--c) calc(var(--s) * 3.6deg), var(--surface-3) calc(var(--s) * 3.6deg));
  position: relative; transition: all .7s var(--ease);
}
.ring::before { content: ""; position: absolute; inset: 6px; border-radius: 50%; background: var(--surface) }
.ring strong { position: relative; z-index: 1; font-family: "Outfit"; font-size: 1.35rem; font-weight: 900; letter-spacing: -.04em }
.ring[data-sev="ok"] { --c: var(--ok) } .ring[data-sev="ok"] strong { color: var(--ok) }
.ring[data-sev="warning"] { --c: var(--warning) } .ring[data-sev="warning"] strong { color: var(--warning) }
.ring[data-sev="critical"] { --c: var(--critical) } .ring[data-sev="critical"] strong { color: var(--critical) }
.ring.celebrate { animation: celebrate 550ms cubic-bezier(.34,1.56,.64,1) }

/* ════════════════════════════════════════════════════
   CONTENT GRID (modules + sidebar)
   ════════════════════════════════════════════════════ */
.content-grid { display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 1.2rem; align-items: start }

.section-title {
  margin: 0 0 .6rem; font-family: "Outfit"; font-size: 1.25rem; font-weight: 800;
  letter-spacing: -.03em; color: var(--ink);
}

.modules-list { display: grid; gap: .55rem }
.modules-list--grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.2rem;
  align-items: start;
}

/* ── Pillar cards ────────────────────────────── */
.pillar-card {
  padding: 1.3rem;
  border-radius: var(--r-xl);
  background: rgba(255, 255, 255, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.4);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: var(--sh);
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  transition: all 220ms var(--ease);
}
.pillar-card:hover {
  box-shadow: var(--sh-md);
  transform: translateY(-2px);
}
.pillar-card__head {
  display: flex;
  align-items: center;
  gap: .8rem;
  border-bottom: 1px solid var(--border-soft);
  padding-bottom: .8rem;
}
.pillar-card__icon {
  font-size: 1.25rem;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 12px;
  background: var(--surface);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border: 1px solid var(--border-soft);
  box-shadow: var(--sh);
}
.pillar-card__info {
  flex: 1;
}
.pillar-card__title {
  margin: 0;
  font-family: "Outfit";
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--ink);
}
.pillar-card__desc {
  margin: .15rem 0 0;
  font-size: .72rem;
  color: var(--ink-3);
  line-height: 1.4;
}
.pillar-card__status {
  font-size: .65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: .35rem .65rem;
  border-radius: var(--r-pill);
  flex-shrink: 0;
}
.pillar-card__status--critical {
  background: var(--critical-bg);
  color: var(--critical);
  border: 1px solid rgba(220, 38, 38, 0.2);
}
.pillar-card__status--warning {
  background: var(--warning-bg);
  color: var(--warning);
  border: 1px solid rgba(217, 119, 6, 0.2);
}
.pillar-card__status--ok {
  background: var(--ok-bg);
  color: var(--ok);
  border: 1px solid rgba(5, 150, 105, 0.2);
}
.pillar-card__body {
  display: grid;
  gap: .6rem;
}

/* ── Module accordion (native <details>) ────────── */
.mod {
  position: relative;
  border-radius: var(--r-lg);
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--sh);
  overflow: hidden; transition: all 220ms var(--ease);
}
.mod:hover { box-shadow: var(--sh-md) }
.mod[open] { box-shadow: var(--sh-md) }

/* Severity left accent vertical pill */
.mod::before {
  content: "";
  position: absolute;
  left: 9px;
  top: 12px;
  bottom: 12px;
  width: 4px;
  border-radius: var(--r-pill);
  background: var(--ink-4);
  transition: all 220ms var(--ease);
  z-index: 2;
}
.mod[data-sev="critical"]::before { background: var(--critical) }
.mod[data-sev="warning"]::before { background: var(--warning) }
.mod[data-sev="ok"]::before { background: var(--ok) }
.mod[data-sev="running"]::before { background: var(--violet-2) }
.mod[data-sev="pending"]::before { background: var(--ink-4) }

/* Running shimmer */
.mod[data-sev="running"]::after {
  content: ""; display: block; height: 2px;
  background: linear-gradient(90deg, transparent, var(--violet), transparent);
  animation: shimmer 1.8s ease-in-out infinite;
}

.mod__head {
  display: flex; align-items: center; gap: .6rem;
  padding: .85rem 1.1rem .85rem 1.6rem; cursor: pointer;
  list-style: none; -webkit-user-select: none; user-select: none;
}
.mod__head::-webkit-details-marker { display: none }
.mod__head::marker { display: none; content: "" }

.mod__icon { font-size: 1rem; width: 2rem; text-align: center; flex-shrink: 0 }
.mod__title { flex: 1; font-family: "Outfit"; font-size: .9rem; font-weight: 700; letter-spacing: -.01em }

.mod__score {
  font-family: "JetBrains Mono"; font-size: .7rem; font-weight: 700;
  min-width: 1.5rem; text-align: center; padding: .2rem .4rem;
  border-radius: var(--r-pill); background: var(--surface-3); color: var(--ink-3);
}
.mod__score[data-sev="critical"] { background: var(--critical-bg); color: var(--critical) }
.mod__score[data-sev="warning"] { background: var(--warning-bg); color: var(--warning) }
.mod__score[data-sev="ok"] { background: var(--ok-bg); color: var(--ok) }

.mod__chev { width: 1.1rem; height: 1.1rem; color: var(--ink-4); transition: transform 280ms var(--ease); flex-shrink: 0 }
.mod[open] .mod__chev { transform: rotate(180deg) }

.mod__body { padding: 0 1.1rem 1rem 1.6rem; display: grid; gap: .4rem }
.mod__note { margin: .4rem 0 0; padding: .5rem .7rem; border-radius: var(--r); background: var(--surface-2); font-size: .72rem; color: var(--ink-3); line-height: 1.5; border-left: 2px solid var(--violet-2) }
.mod__note:empty { display: none }

/* ── Check rows (individual audit items) ────────── */
.check-row {
  display: grid; grid-template-columns: auto 1fr minmax(0, 400px); gap: .5rem; align-items: baseline;
  padding: .55rem .7rem; border-radius: var(--r); transition: background 150ms;
}
.check-row:hover { background: var(--surface-2) }

.check-row__tag {
  font-family: "JetBrains Mono"; font-size: .6rem; font-weight: 700; letter-spacing: .06em;
  padding: .15rem .4rem; border-radius: 4px; text-transform: uppercase; line-height: 1;
}
.check-row--critical .check-row__tag { background: var(--critical); color: #fff }
.check-row--warning .check-row__tag { background: var(--warning); color: #fff }
.check-row--ok .check-row__tag { background: var(--ok); color: #fff }

.check-row__label { font-size: .82rem; font-weight: 600; color: var(--ink); line-height: 1.3 }
.check-row--critical .check-row__label { color: var(--critical) }

.check-row__val {
  font-family: "JetBrains Mono";
  font-size: .7rem;
  font-weight: 500;
  color: var(--ink-3);
  white-space: normal;
  word-break: break-word;
  overflow-wrap: anywhere;
  text-align: right;
}

/* ── Visuals ─────────────────────────────────────── */
.mod-visual { margin-top: .5rem }
.mod-visual--img { padding: .4rem; border-radius: var(--r-md); background: var(--surface-2); border: 1px solid var(--border-soft) }
.mod-visual--img img { border-radius: calc(var(--r-md) - 3px); box-shadow: var(--sh-md) }
.mod-visual--bench { display: grid; gap: .35rem }
.bench-row { display: grid; grid-template-columns: minmax(0,1fr) minmax(100px,160px) auto; gap: .5rem; align-items: center; padding: .5rem .7rem; border-radius: var(--r); background: var(--surface-2) }
.bench-row--self { background: rgba(124,58,237,.04); box-shadow: inset 0 0 0 1px rgba(124,58,237,.1) }
.bench-row__who { display: grid; gap: .04rem }
.bench-row__who strong { font-size: .76rem }
.bench-row__who span { font-size: .64rem; color: var(--ink-3) }
.bench-row__bar { height: 4px; border-radius: var(--r-pill); background: var(--surface-3); overflow: hidden }
.bench-row__bar span { display: block; height: 100%; border-radius: inherit; background: var(--grad); transition: width 500ms var(--ease) }
.bench-row__val { font-family: "JetBrains Mono"; font-size: .65rem; color: var(--ink-3); font-style: normal }

/* ── Aside cards ─────────────────────────────────── */
.content-aside { position: sticky; top: 1rem; display: grid; gap: .8rem }
.aside-card {
  padding: 1.1rem; border-radius: var(--r-xl);
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--sh);
}
.aside-card h3 { margin: 0 0 .4rem; font-family: "Outfit"; font-size: 1rem; font-weight: 800; letter-spacing: -.02em }
.aside-card p { margin: 0 0 .7rem; font-size: .78rem; color: var(--ink-3); line-height: 1.5 }
.aside-card--cta { display: grid; gap: .45rem }
.aside-card--upsell ul { margin: .3rem 0; padding: 0; list-style: none; display: grid; gap: .3rem }
.aside-card--upsell li { padding: .4rem .6rem; border-radius: var(--r); background: var(--surface-2); font-size: .76rem; color: var(--ink-2) }
.aside-card--upsell li::before { content: "→ "; color: var(--violet); font-weight: 700 }

/* ── Filter focus view ───────────────────────────── */
.result-focus { display: grid; gap: .6rem }
.result-focus__intro { display: flex; align-items: center; gap: 1rem; padding: 1rem 1.2rem; border-radius: var(--r-xl); background: var(--surface); border: 1.5px solid var(--border-soft); box-shadow: var(--sh) }
.result-focus__copy { flex: 1 }
.result-focus__copy h2 { margin: 0; font-family: "Outfit"; font-size: 1.3rem; font-weight: 800; letter-spacing: -.03em }
.result-focus__copy p { margin: .15rem 0 0; font-size: .76rem; color: var(--ink-3) }
.result-focus__total { font-family: "Outfit"; font-size: 2rem; font-weight: 900; padding: .3rem .7rem; border-radius: var(--r-lg); background: var(--surface-2) }
.result-focus__groups { display: grid; gap: .5rem }
.result-focus-group { padding: .9rem; border-radius: var(--r-xl); background: var(--surface); border: 1.5px solid var(--border-soft); box-shadow: var(--sh) }
.result-focus-group__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: .5rem }
.result-focus-group__eyebrow { font-family: "Outfit"; font-size: .82rem; font-weight: 800; color: var(--ink) }
.result-focus-group__count { font-family: "JetBrains Mono"; font-size: .72rem; color: var(--ink-3); padding: .2rem .5rem; border-radius: var(--r-pill); background: var(--surface-2) }
.result-focus-group__rows { display: grid; gap: .35rem }
.result-focus--empty .result-focus__intro { flex-direction: column; text-align: center }

/* ── Mobile bar ──────────────────────────────────── */
.mobile-bar {
  display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
  padding: .65rem 1rem calc(.65rem + env(safe-area-inset-bottom, 0));
  background: rgba(244,240,249,.92); backdrop-filter: blur(20px);
  border-top: 1.5px solid var(--border-soft); box-shadow: 0 -4px 16px rgba(22,17,31,.06);
}

/* ════════════════════════════════════════════════════
   ANIMATIONS
   ════════════════════════════════════════════════════ */
@keyframes slideUp { from { opacity: 0; transform: translateY(12px) } to { opacity: 1; transform: translateY(0) } }
@keyframes shimmer { 0% { transform: translateX(-100%) } 100% { transform: translateX(250%) } }
@keyframes celebrate { 0% { transform: scale(1) } 30% { transform: scale(1.1) } 60% { transform: scale(1) } 80% { transform: scale(1.05) } 100% { transform: scale(1) } }

.slide-up-animate { animation: slideUp 350ms var(--ease) both }

/* ════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════ */
@media (max-width: 960px) {
  .content-grid { grid-template-columns: 1fr }
  .content-aside { position: static; order: -1 }
  .aside-card--cta { display: none }
  .mobile-bar { display: block }
  .modules-list--grid { grid-template-columns: 1fr; gap: 1rem }
}

/* ── Background Glowing Bubbles & Grids ────────── */
.glow-bubble {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(100px);
  -webkit-filter: blur(100px);
  opacity: 0.45;
  animation: float-drift 12s ease-in-out infinite alternate;
  z-index: 0;
}
.bubble-right {
  top: 3rem;
  right: -12rem;
  height: 30rem;
  width: 30rem;
  background-color: rgba(124, 58, 237, 0.12);
}
.bubble-left {
  bottom: 0;
  left: -9rem;
  height: 28rem;
  width: 28rem;
  background-color: rgba(249, 115, 22, 0.08);
  animation-delay: -6s;
}
@keyframes float-drift {
  0% { transform: translate(0, 0) scale(1); }
  100% { transform: translate(-30px, 30px) scale(1.08); }
}
.bg-grid-overlay {
  position: absolute;
  inset: 0;
  background-image: 
    linear-gradient(to right, var(--border-soft) 1px, transparent 1px),
    linear-gradient(to bottom, var(--border-soft) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity: 0.35;
  pointer-events: none;
  z-index: 0;
}

@media (max-width: 680px) {
  body { font-size: 14px }
  .glow-bubble { opacity: 0.25 }
  .shell { width: calc(100% - 1.2rem) }
  .shell--report { padding-bottom: 5.5rem }
  .entry { grid-template-columns: 1fr; gap: 1.5rem }
  .entry__left { padding-top: .5rem }
  .entry__left h1 { font-size: 2.2rem }
  .hero-card { grid-template-columns: 1fr; gap: .8rem; padding: 1.1rem }
  .hero-card__name { font-size: 1.6rem }
  .hero-card__right { min-width: 0 }
  .stats-row { grid-template-columns: repeat(3, 1fr); gap: .5rem }
  .stat-card { padding: .8rem .5rem }
  .stat-card__num { font-size: 1.8rem }
  .perf-row { gap: .5rem }
  .perf-card { padding: .9rem 1rem; flex-direction: column; align-items: flex-start; gap: .6rem }
  .perf-card__info h3 { font-size: .95rem }
  .ring { width: 56px; height: 56px }
  .ring::before { inset: 5px }
  .ring strong { font-size: 1.1rem }
  .mod__head { padding: .7rem .85rem }
  .mod__body { padding: 0 .85rem .85rem }
  .check-row { grid-template-columns: auto 1fr; gap: .4rem }
  .check-row__val { grid-column: 2; font-size: .65rem }
  .bench-row { grid-template-columns: 1fr; gap: .25rem }
  .result-focus__intro { flex-direction: column; gap: .4rem; text-align: center }
}
@media (max-width: 400px) {
  .entry__left h1 { font-size: 1.9rem }
  .stat-card__num { font-size: 1.5rem }
  .ring { width: 48px; height: 48px }
  .ring strong { font-size: .95rem }
}

/* ── Wrapped Live Card ────────────────────────── */
.wrapped-live-card {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding: 1.8rem;
  border-radius: var(--r-xl);
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.08) 0%, rgba(192, 38, 211, 0.05) 50%, rgba(249, 115, 22, 0.03) 100%), rgba(255, 255, 255, 0.8);
  border: 1.5px solid rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--sh-lg), var(--sh-glow);
  position: relative;
  overflow: hidden;
  animation: slideUp 600ms var(--ease) both;
}

/* Subtle moving gradient background */
.wrapped-live-card::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, rgba(124, 58, 237, 0.06) 0%, transparent 60%);
  pointer-events: none;
  animation: bg-rotate 20s linear infinite;
  z-index: 0;
}

@keyframes bg-rotate {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.wrapped-live-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  z-index: 1;
}

.wrapped-live-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.45rem 0.9rem;
  background: var(--violet);
  color: #fff;
  border-radius: var(--r-pill);
  font-family: "Outfit";
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  box-shadow: var(--sh-glow);
}

.wrapped-live-card__badge .pulse-dot {
  background-color: #fff;
}
.wrapped-live-card__badge .pulse-dot::before {
  background-color: #fff;
}

.wrapped-live-card__progress-text {
  font-size: 0.82rem;
  color: var(--ink-2);
  font-family: "Plus Jakarta Sans";
}
.wrapped-live-card__progress-text strong {
  font-family: "JetBrains Mono";
  color: var(--violet);
  font-size: 0.95rem;
}

.wrapped-live-card__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  align-items: center;
  position: relative;
  z-index: 1;
  border-bottom: 1px solid var(--border-soft);
  padding-bottom: 1.5rem;
}

.wrapped-live-card__active {
  display: flex;
  align-items: center;
  gap: 1.2rem;
}

.wrapped-live-card__loader-wrapper {
  position: relative;
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.wrapped-live-card__spinner {
  position: absolute;
  inset: 0;
  border: 3.5px solid var(--border-soft);
  border-top-color: var(--violet);
  border-radius: 50%;
  animation: spin 1.2s cubic-bezier(0.5, 0.1, 0.4, 0.9) infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.wrapped-live-card__active-icon {
  font-size: 1.6rem;
  position: relative;
  z-index: 1;
}

.wrapped-live-card__active-text {
  display: flex;
  flex-direction: column;
}

.wrapped-live-card__sub {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  font-weight: 700;
}

.wrapped-live-card__title {
  margin: 0.15rem 0 0;
  font-family: "Outfit";
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.02em;
}

.wrapped-live-card__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}

.live-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0.8rem 0.5rem;
  background: rgba(255, 255, 255, 0.4);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: var(--r-md);
  box-shadow: var(--sh);
}

.live-stat__val {
  font-family: "Outfit";
  font-size: 1.45rem;
  font-weight: 800;
  line-height: 1;
  color: var(--ink);
}

.live-stat__val--critical { color: var(--critical); }
.live-stat__val--warning { color: var(--warning); }
.live-stat__val--ok { color: var(--ok); }

.live-stat__lbl {
  margin-top: 0.25rem;
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--ink-3);
  letter-spacing: 0.05em;
}

.wrapped-live-card__checklist {
  position: relative;
  z-index: 1;
}

.wrapped-live-card__checklist-title {
  margin: 0 0 0.75rem;
  font-family: "Outfit";
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--ink-2);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.wrapped-live-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.live-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0.75rem;
  border-radius: var(--r-pill);
  font-size: 0.72rem;
  font-weight: 600;
  transition: all 250ms var(--ease);
}

.badge--pending {
  background: var(--surface-2);
  color: var(--ink-4);
  border: 1px solid var(--border-soft);
  opacity: 0.7;
}

.badge--running {
  background: rgba(124, 58, 237, 0.08);
  color: var(--violet);
  border: 1.5px solid rgba(124, 58, 237, 0.3);
  font-weight: 700;
  box-shadow: 0 0 10px rgba(124, 58, 237, 0.08);
  animation: pulse-border 1.5s infinite alternate;
}

@keyframes pulse-border {
  from { border-color: rgba(124, 58, 237, 0.2); }
  to { border-color: rgba(124, 58, 237, 0.6); }
}

.badge--completed {
  background: var(--ok-bg);
  color: var(--ok);
  border: 1px solid rgba(5, 150, 105, 0.25);
  font-weight: 700;
}

.live-badge__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
}

.pulse-dot-violet {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--violet);
  position: relative;
  display: inline-block;
}
.pulse-dot-violet::before {
  content: ''; position: absolute; inset: 0; border-radius: 50%;
  background-color: var(--violet);
  animation: ping 1.5s cubic-bezier(0, 0, 0.2, 1) infinite;
}

@media (max-width: 768px) {
  .wrapped-live-card__body {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
  .wrapped-live-card__stats {
    grid-template-columns: repeat(2, 1fr);
  }
}
