/* ============================================================
   ALIVE QUIZ — Bloom system (decoupled from site.css)
   ============================================================ */

:root {
  --cream: #FBF1D6;
  --cream-2: #F5E6B8;
  --cobalt: #1B4FD9;
  --cobalt-deep: #0F3AB8;
  --sky: #B8D9FF;
  --sky-deep: #7BB0FF;
  --pink: #FFB8C9;
  --pink-deep: #FF8FA8;
  --orange: #FF7E3D;
  --gerbera: #FF9DAB;
  --leaf: #6FA559;
  --leaf-deep: #3F7A2C;
  --tulip: #FFD66B;
  --sienna: #C9764A;
  --sienna-deep: #9C5532;
  --amber: #FFB74A;
  --rust: #B0421E;
  /* midnight palette (ported from too-late.html — rain/ember/lamplight) */
  --midnight: #0e1520;
  --midnight-2: #141c2a;
  --rain: #8fa4bc;
  --rain-deep: #5a6f8a;
  --pearl: #d8d4c6;
  --ember: #c98b75;
  --ivory: #e3e6ec;
  /* neon palette (ported from race.html — charcoal/neon/chrome) */
  --charcoal: #0a0a0d;
  --charcoal-2: #14141a;
  --neon: #a3ff12;
  --neon-deep: #6fbf0a;
  --neon-low: #1e2a05;
  --silver: #c9d0d9;
  --ink: #161616;
  --ink-60: rgba(22, 22, 22, 0.62);
  --ink-30: rgba(22, 22, 22, 0.3);
  --display: 'Archivo Black', 'Archivo', 'Pretendard Variable', sans-serif;
  --sans: 'Pretendard Variable', Pretendard, -apple-system, system-ui, sans-serif;
  --ko-display: 'Black Han Sans', var(--sans);
  --ease: cubic-bezier(.2, .7, .2, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body { height: 100%; }
body {
  background: var(--cream);
  color: var(--ink);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
  padding: 24px 16px 80px;
  overflow-x: hidden;
}

img, svg { display: block; max-width: 100%; }
button { font: inherit; }
a { color: inherit; }

/* container */
.shell { max-width: 460px; margin: 0 auto; position: relative; }

/* ============================================================
   TOP BAR — minimal "back to alive" + brand mark
   ============================================================ */
.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.topbar-mark {
  font-family: var(--display);
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--cobalt);
  text-decoration: none;
}
.topbar-back {
  color: var(--ink-60);
  text-decoration: none;
  border-bottom: 1.5px solid transparent;
  transition: color .15s, border-color .15s;
}
.topbar-back:hover { color: var(--cobalt); border-color: var(--cobalt); }

/* ============================================================
   INTRO
   ============================================================ */
.intro {
  background: var(--cream);
  padding: 36px 22px 32px;
  border: 2px solid var(--ink);
  box-shadow: 8px 8px 0 var(--cobalt);
  position: relative;
  overflow: hidden;
}
.intro-deco {
  position: absolute;
  pointer-events: none;
  z-index: 0;
}
.intro-deco.bop { top: -30px; right: -60px; width: 220px; height: 300px; transform: rotate(6deg); }
.intro-deco.gerbera-sm { top: 18px; left: -22px; width: 70px; height: 70px; opacity: .9; }
.intro-deco.tulip { bottom: -50px; left: -30px; width: 110px; height: 200px; transform: rotate(-8deg); }
.intro-content { position: relative; z-index: 5; }

.intro-eyebrow {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--cobalt);
  margin-bottom: 14px;
}
.intro-title {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(1.9rem, 7vw, 2.4rem);
  line-height: 1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 18px;
}
.intro-title em {
  font-style: normal;
  color: var(--cobalt);
  background: var(--tulip);
  padding: 0 4px;
  box-shadow: 3px 3px 0 var(--ink);
}
.intro-deck {
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 500;
  line-height: 1.5;
  color: var(--ink);
  max-width: 32ch;
  margin-bottom: 22px;
}
.intro-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 24px;
}
.intro-chip {
  padding: 5px 10px;
  background: #fff;
  border: 1.5px solid var(--ink);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  color: var(--ink);
  box-shadow: 2px 2px 0 var(--ink);
}
.intro-chip b { color: var(--cobalt); font-weight: 800; }

.intro-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 26px;
  background: var(--cobalt);
  color: var(--cream);
  border: 2px solid var(--ink);
  cursor: pointer;
  font-family: var(--display);
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  box-shadow: 4px 4px 0 var(--ink);
  transition: transform .1s var(--ease), box-shadow .1s var(--ease);
}
.intro-cta:hover { transform: translate(-1px, -1px); box-shadow: 5px 5px 0 var(--ink); }
.intro-cta:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--ink); }
.intro-fineprint {
  margin-top: 18px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--ink-60);
}

/* ============================================================
   QUESTION FRAME
   ============================================================ */
.qframe {
  background: var(--cream);
  padding: 22px 22px 24px;
  border: 2px solid var(--ink);
  box-shadow: 8px 8px 0 var(--cobalt);
  position: relative;
  overflow: hidden;
}

.q-deco {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  opacity: 0.85;
}
.q-deco.q1 { top: -40px; right: -50px; width: 180px; height: 220px; transform: rotate(8deg); }
.q-deco.q2 { top: -20px; right: -40px; width: 130px; height: 130px; }
.q-deco.q3 { top: -30px; right: -30px; width: 130px; height: 220px; transform: rotate(-6deg); }
.q-deco.q4 { bottom: -50px; left: -30px; width: 110px; height: 200px; transform: rotate(-10deg); }
.q-deco.q5 { top: -50px; right: -50px; width: 200px; height: 200px; }

.qcontent { position: relative; z-index: 5; }

.qmeta {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 14px;
  gap: 14px;
}
.qcount {
  font-family: var(--display);
  font-size: 56px;
  line-height: 0.85;
  color: var(--cobalt);
  letter-spacing: -0.04em;
  text-shadow: 3px 3px 0 var(--ink);
}
.qmeta-r {
  text-align: right;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-60);
  line-height: 1.5;
  padding-top: 6px;
}
.qmeta-r b { display: block; color: var(--ink); font-size: 11px; }

/* progress bar */
.progress {
  display: flex;
  gap: 4px;
  margin-bottom: 22px;
}
.pcap {
  flex: 1;
  height: 14px;
  background: var(--cream-2);
  border: 1.5px solid var(--ink);
  border-radius: 100px;
  transition: background .2s var(--ease);
}
.pcap.done { background: var(--gerbera); }
.pcap.now { background: var(--cobalt); }

.q-title {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(1.55rem, 5.2vw, 1.85rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 22px;
}

.answers {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.answer {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  width: 100%;
  padding: 16px 18px;
  background: #fff;
  border: 2px solid var(--ink);
  border-radius: 28px;
  cursor: pointer;
  text-align: left;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 550;
  line-height: 1.5;
  box-shadow: 3px 3px 0 var(--ink);
  transition: transform .08s var(--ease), box-shadow .08s var(--ease), background .12s var(--ease);
}
/* hover only on real pointers — kills sticky touch state */
@media (hover: hover) {
  .answer:hover { background: var(--cream-2); transform: translate(-1px, -1px); box-shadow: 4px 4px 0 var(--ink); }
}
.answer:active { transform: translate(2px, 2px); box-shadow: 1px 1px 0 var(--ink); }
.answer:focus-visible { outline: 3px solid var(--cobalt); outline-offset: 3px; }
.answer.is-picked { background: var(--cobalt); color: var(--cream); border-color: var(--ink); }
.answer.is-picked .marker { background: var(--cream); color: var(--cobalt); }

.marker {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--cobalt);
  color: var(--cream);
  display: grid;
  place-items: center;
  font-family: var(--display);
  font-size: 12px;
}
.answer.a2 .marker { background: var(--orange); }
.answer.a3 .marker { background: var(--leaf); }
.answer.a4 .marker { background: var(--pink-deep); }

.q-back {
  display: block;
  margin-top: 18px;
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-60);
  padding: 8px 0;
  position: relative;
  z-index: 5;
}
.q-back:hover { color: var(--cobalt); }
.q-back:focus-visible { outline: 2px solid var(--cobalt); outline-offset: 4px; }

/* ============================================================
   RESULT — outer wrapper holds the shareable card + the actions below
   ============================================================ */
.rframe {
  position: relative;
  /* No card chrome here — that's on .r-card */
}

/* ============================================================
   THE SHAREABLE CARD — screenshot region, all card chrome lives here
   ============================================================ */
.r-card {
  padding: 18px 22px 22px;
  border: 2px solid var(--ink);
  box-shadow: 8px 8px 0 var(--cobalt);
  position: relative;
  overflow: hidden;
  background: var(--cream); /* fallback before per-track palette kicks in */
}
.r-card.mode-cream { background: var(--cream); }
.r-card.mode-sky {
  background: linear-gradient(180deg, var(--sky) 0%, #DCE9FF 60%, var(--cream) 100%);
}
.r-card.mode-sienna {
  background: linear-gradient(180deg, var(--midnight) 0%, var(--midnight-2) 100%);
  box-shadow: 8px 8px 0 var(--ink);
  color: var(--ivory);
}
.r-card.mode-neon {
  background: linear-gradient(180deg, var(--charcoal) 0%, var(--charcoal-2) 100%);
  box-shadow: 8px 8px 0 var(--neon-deep);
  color: var(--silver);
}

.r-deco {
  position: absolute;
  pointer-events: none;
  z-index: 0;
}
.r-deco svg { display: block; width: 100%; height: 100%; overflow: visible; }

/* cream-mode decoration positions */
.r-deco.cream-sun { top: -60px; right: -60px; width: 220px; height: 220px; }
.r-deco.cream-sun-left { top: -50px; left: -70px; width: 180px; height: 180px; transform: rotate(-12deg); }
.r-deco.cream-gerbs { bottom: -40px; left: -30px; width: 180px; height: 160px; }
.r-deco.cream-calla { top: 220px; right: -30px; width: 110px; height: 180px; transform: rotate(18deg); opacity: .95; }
.r-deco.cream-cafe { top: -20px; right: -30px; width: 200px; height: 240px; }
.r-deco.cream-spotlight { top: -40px; right: -60px; width: 230px; height: 280px; opacity: .9; }
.r-deco.cream-candle { top: -10px; right: -30px; width: 180px; height: 240px; }
.r-deco.cream-sparkle { bottom: 80px; left: 16px; width: 44px; height: 44px; opacity: .9; }

/* sky-mode decoration positions */
.r-deco.sky-rocket { top: -50px; right: -70px; width: 200px; height: 280px; transform: rotate(15deg); opacity: .85; }
.r-deco.sky-cloud-1 { top: 30px; left: -30px; width: 130px; height: 60px; }
.r-deco.sky-cloud-2 { top: 200px; right: 60px; width: 90px; height: 40px; opacity: .8; }
.r-deco.sky-horizon { top: -40px; right: -40px; width: 220px; height: 220px; }
.r-deco.sky-three-suns { top: 0; right: -30px; width: 220px; height: 180px; }
.r-deco.sky-flag { top: -20px; right: -50px; width: 180px; height: 220px; transform: rotate(-6deg); }
.r-deco.sky-barbell { top: 40px; right: -50px; width: 220px; height: 200px; transform: rotate(-8deg); }

/* sienna-mode decoration positions */
.r-deco.sienna-glow {
  top: 60px; right: 40px; width: 160px; height: 160px;
  background: radial-gradient(circle, rgba(255, 183, 74, 0.45), transparent 65%);
  filter: blur(2px);
}
.r-deco.sienna-door { top: 0; right: -50px; width: 140px; height: 240px; }
.r-deco.sienna-hand { bottom: -40px; left: -10px; width: 200px; height: 220px; }
.r-deco.sienna-flag { top: -30px; right: -60px; width: 160px; height: 200px; }
.r-deco.sienna-chair { top: 40px; right: -10px; width: 180px; height: 240px; }
.r-deco.sienna-clock { top: 20px; right: -30px; width: 200px; height: 200px; }
.r-deco.sienna-phone { top: -10px; right: -40px; width: 180px; height: 260px; transform: rotate(6deg); }
.r-deco.sienna-paper { bottom: -20px; left: -20px; width: 110px; height: 110px; opacity: .85; }

/* neon-mode decoration positions */
.r-deco.neon-barbell { top: 22px; right: 14px; width: 170px; height: 85px; transform: rotate(-4deg); opacity: .95; }
.r-deco.neon-bolt { bottom: 70px; left: 18px; width: 56px; height: 88px; opacity: .85; }

.rcontent { position: relative; z-index: 5; }

.r-stamp-row { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.r-stamp {
  padding: 4px 10px;
  background: var(--cobalt);
  color: var(--cream);
  font-family: var(--display);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transform: rotate(-1.5deg);
}
.r-stamp.alt { background: var(--ink); }
.mode-sienna .r-stamp { background: var(--pearl); color: var(--midnight); }
.mode-sienna .r-stamp.alt { background: var(--ember); color: var(--midnight); }
.mode-neon .r-stamp { background: var(--neon); color: var(--charcoal); }
.mode-neon .r-stamp.alt { background: var(--silver); color: var(--charcoal); }

.r-you {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cobalt);
  margin-bottom: 4px;
}
.mode-sky .r-you { color: var(--cobalt-deep); }
.mode-sienna .r-you { color: var(--ember); }
.mode-neon .r-you { color: var(--neon); }

.r-title {
  font-family: var(--display);
  font-size: clamp(3.2rem, 12vw, 4rem);
  line-height: 0.9;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--cobalt);
  margin-bottom: 14px;
  text-shadow: 4px 4px 0 var(--cream), 6px 6px 0 var(--ink);
}
.r-title.lang-ko {
  font-family: var(--ko-display);
  font-weight: 400;
  font-size: clamp(4.5rem, 16vw, 6rem);
  letter-spacing: -0.02em;
  text-transform: none;
}
.mode-sky .r-title { text-shadow: 4px 4px 0 #fff, 6px 6px 0 var(--ink); }
.mode-sienna .r-title { color: var(--ember); text-shadow: 4px 4px 0 var(--rain-deep), 6px 6px 0 var(--ink); }
.mode-neon .r-title { color: var(--neon); text-shadow: 4px 4px 0 var(--neon-low), 6px 6px 0 var(--charcoal); }

.r-tag {
  font-family: var(--display);
  font-size: 19px;
  line-height: 1.25;
  margin-bottom: 16px;
  max-width: 24ch;
}
.r-why {
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-60);
  margin-bottom: 22px;
  max-width: 36ch;
}
.mode-sienna .r-why { color: rgba(227, 230, 236, 0.82); }
.mode-neon .r-why { color: rgba(201, 208, 217, 0.82); }
.r-why p + p { margin-top: 16px; }
.r-why-lore { line-height: 1.7; }
.r-why em {
  font-style: normal;
  font-weight: 600;
  background: var(--tulip);
  padding: 0 3px;
  box-shadow: 2px 2px 0 var(--ink);
  color: var(--ink);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
.mode-sky .r-why em { background: #fff; box-shadow: 2px 2px 0 var(--cobalt); }
.mode-sienna .r-why em { background: var(--pearl); box-shadow: 2px 2px 0 var(--ink); color: var(--midnight); }
.mode-neon .r-why em { background: var(--neon); box-shadow: 2px 2px 0 var(--charcoal); color: var(--charcoal); }

/* secondary block — traces of */
.r-traces {
  margin-bottom: 22px;
}
.r-traces-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-60);
  margin-bottom: 10px;
}
.mode-sienna .r-traces-label { color: rgba(227, 230, 236, 0.55); }
.mode-neon .r-traces-label { color: rgba(201, 208, 217, 0.55); }
.r-trace-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.r-trace {
  padding: 5px 12px;
  background: #fff;
  border: 1.5px solid var(--ink);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  color: var(--ink);
  box-shadow: 2px 2px 0 var(--ink);
}
.mode-sienna .r-trace { background: var(--midnight-2); color: var(--ivory); border-color: var(--rain-deep); box-shadow: 2px 2px 0 var(--rain-deep); }
.mode-neon .r-trace { background: var(--charcoal-2); color: var(--silver); border-color: var(--neon-deep); box-shadow: 2px 2px 0 var(--neon-deep); }

.r-secondary-line {
  margin-top: 14px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.5);
  border: 1.5px solid var(--ink);
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink);
}
.mode-sienna .r-secondary-line {
  background: rgba(255, 255, 255, 0.06);
  color: var(--ivory);
  border-color: var(--rain-deep);
}
.mode-neon .r-secondary-line {
  background: rgba(163, 255, 18, 0.06);
  color: var(--silver);
  border-color: var(--neon-deep);
}
.r-secondary-line b { color: var(--cobalt); font-weight: 700; }
.mode-sienna .r-secondary-line b { color: var(--ember); }
.mode-neon .r-secondary-line b { color: var(--neon); }

/* CTAs */
.r-ctas {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}
.r-cta-primary {
  display: block;
  width: 100%;
  padding: 16px;
  background: var(--cobalt);
  color: var(--cream);
  border: 2px solid var(--ink);
  text-decoration: none;
  text-align: center;
  font-family: var(--display);
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: 4px 4px 0 var(--ink);
  transition: transform .1s var(--ease), box-shadow .1s var(--ease);
}
.r-cta-primary:hover { transform: translate(-1px, -1px); box-shadow: 5px 5px 0 var(--ink); }
.r-cta-primary:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--ink); }
.mode-sienna .r-cta-primary { background: var(--ember); color: var(--midnight); border-color: var(--midnight); }
.mode-neon .r-cta-primary { background: var(--neon); color: var(--charcoal); border-color: var(--charcoal); box-shadow: 4px 4px 0 var(--neon-deep); }

/* share row — X is primary (ELF's main channel); Threads + Copy are secondary */
.r-share-row {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
}
.r-share-row a, .r-share-row button {
  flex: 1;
  min-height: 44px;
  padding: 12px 10px;
  background: #fff;
  border: 1.5px solid var(--ink);
  cursor: pointer;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  text-align: center;
  text-decoration: none;
  box-shadow: 2px 2px 0 var(--ink);
}
.r-share-row #share-x {
  flex: 1.6;
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}
.mode-sienna .r-share-row a, .mode-sienna .r-share-row button { background: var(--midnight-2); color: var(--ivory); border-color: var(--rain-deep); box-shadow: 2px 2px 0 var(--rain-deep); }
.mode-sienna .r-share-row #share-x { background: var(--ivory); color: var(--midnight); border-color: var(--ivory); box-shadow: 2px 2px 0 var(--ink); }
.mode-neon .r-share-row a, .mode-neon .r-share-row button { background: var(--charcoal-2); color: var(--silver); border-color: var(--neon-deep); box-shadow: 2px 2px 0 var(--neon-deep); }
.mode-neon .r-share-row #share-x { background: var(--neon); color: var(--charcoal); border-color: var(--neon); box-shadow: 2px 2px 0 var(--charcoal); }
.r-share-row .copied { background: var(--leaf); color: #fff; }

.r-retake {
  width: 100%;
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-60);
  padding: 10px;
  border-bottom: 1.5px solid var(--ink-30);
}
.mode-sienna .r-retake { color: rgba(227, 230, 236, 0.7); border-color: rgba(227, 230, 236, 0.4); }
.mode-neon .r-retake { color: rgba(201, 208, 217, 0.7); border-color: rgba(163, 255, 18, 0.4); }
.r-retake:hover { color: var(--cobalt); border-color: var(--cobalt); }

/* ============================================================
   FOOTER
   ============================================================ */
.foot {
  margin-top: 28px;
  padding: 18px 4px 0;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-60);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}
.foot a {
  color: var(--ink-60);
  text-decoration: none;
  border-bottom: 1.5px solid transparent;
  transition: color .15s, border-color .15s;
}
.foot a:hover { color: var(--cobalt); border-color: var(--cobalt); }

/* ============================================================
   PANELS — fade transition (respect reduced-motion)
   ============================================================ */
.panel { animation: fade-up .28s var(--ease); }
@keyframes fade-up {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .panel { animation: none; }
  .answer, .r-cta-primary, .intro-cta, .pcap { transition: none !important; }
}

/* ============================================================
   SVG defaults
   ============================================================ */
.ink-fill { stroke: var(--ink); stroke-width: 2; stroke-linejoin: round; stroke-linecap: round; }
.ink-stroke { stroke: var(--ink); stroke-width: 2; stroke-linejoin: round; stroke-linecap: round; fill: none; }

/* ============================================================
   RESULT ACTIONS — sit BELOW the shareable card, outside the screenshot region
   ============================================================ */
.r-actions {
  margin-top: 22px;
  padding: 0 4px;
}
.r-actions .r-ctas {
  margin-bottom: 12px;
}
.r-actions .r-share-row {
  margin-bottom: 12px;
}
.r-actions .r-retake {
  margin: 0;
  border-bottom: none;
}

/* ============================================================
   RESULT FRAME v2 — new anatomy (kicker, name+ID, phrase block, chip block, 2+2 compat, mascot slot, fanmade footer)
   Per copy-A2-results.md, copy-A5-disclaimer.md, copy-A6-beautiful-trigger.md
   ============================================================ */

.r-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 4px;
  position: relative;
  z-index: 5;
}
.r-kicker {
  font-family: var(--display);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.16em;
  color: var(--cobalt);
  text-transform: uppercase;
  margin-top: 2px;
}
.r-kicker.lang-ko {
  font-family: var(--sans);
  letter-spacing: 0.08em;
}
.mode-sienna .r-kicker { color: var(--ember); }
.mode-neon .r-kicker { color: var(--neon); }
.r-id {
  font-family: 'JetBrains Mono', ui-monospace, SF Mono, Menlo, monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--ink-60);
  white-space: nowrap;
  text-align: right;
}
.mode-sienna .r-id { color: rgba(227, 230, 236, 0.6); }
.mode-neon .r-id { color: rgba(201, 208, 217, 0.6); }

.r-claim-prefix {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-60);
}
.mode-sienna .r-claim-prefix { color: rgba(227, 230, 236, 0.65); }
.mode-neon .r-claim-prefix { color: rgba(201, 208, 217, 0.65); }

.r-track-title {
  font-family: var(--display);
  font-size: clamp(1.9rem, 7.6vw, 2.6rem);
  line-height: 0.95;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--cobalt);
  margin: 0 0 2px;
  text-shadow: 2px 2px 0 var(--cream), 4px 4px 0 var(--ink);
  position: relative;
  z-index: 5;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
  white-space: pre-line;
}
.mode-sky .r-track-title { text-shadow: 4px 4px 0 #fff, 6px 6px 0 var(--ink); }
.mode-sienna .r-track-title { color: var(--ember); text-shadow: 4px 4px 0 var(--rain-deep), 6px 6px 0 var(--ink); }
.mode-neon .r-track-title { color: var(--neon); text-shadow: 4px 4px 0 var(--neon-low), 6px 6px 0 var(--charcoal); }

/* Hero row — kicker/name/title/quick-tags on left, mascot side-billed on right */
.r-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 130px;
  gap: 14px;
  align-items: start;
  margin-bottom: 6px;
  position: relative;
  z-index: 5;
}
.r-hero-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.r-hero-text .r-quick-tags {
  margin-top: 6px;
}
.r-mascot-slot {
  width: 130px;
  height: 130px;
  display: grid;
  place-items: center;
  position: relative;
  z-index: 5;
}
.r-mascot-slot img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* Quick-tags — 3 hashtag chips below the track title */
.r-quick-tags {
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-start;
  gap: 3px;
  margin: 0 0 6px;
  position: relative;
  z-index: 5;
}
.r-quick-tag {
  padding: 2px 6px;
  background: var(--ink);
  color: var(--cream);
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.02em;
  border-radius: 4px;
  white-space: nowrap;
  flex: 0 0 auto;
}
@media (max-width: 340px) {
  .r-quick-tags { flex-wrap: wrap; }
}

.r-block {
  margin: 14px 0;
  position: relative;
  z-index: 5;
}
.r-brag-block {
  margin: 10px 0 14px;
  position: relative;
  z-index: 5;
}
.r-block-label {
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-60);
  margin: 0 0 10px 0;
}
.mode-sienna .r-block-label { color: rgba(227, 230, 236, 0.55); }
.mode-neon .r-block-label { color: rgba(201, 208, 217, 0.55); }

/* Brag Sheet — 3 quirky stat-style brag lines, screenshot-bait */
.r-brag-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.r-brag-line {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 650;
  line-height: 1.35;
  padding: 4px 0 4px 14px;
  position: relative;
  color: inherit;
}
.r-brag-line::before {
  content: '·';
  position: absolute;
  left: 4px;
  color: var(--cobalt);
  font-weight: 800;
}
.mode-sienna .r-brag-line::before { color: var(--ember); }
.mode-neon .r-brag-line::before { color: var(--neon); }
.r-card.track-haerise .r-brag-line::before { color: #c83a3a; }
.r-card.track-rocket .r-brag-line::before { color: #ff6a2c; }

/* Phrases — pill flow (was bullet-list; designer proof shows pills) */
.r-phrases {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.r-phrase {
  display: inline-block;
  padding: 6px 11px;
  background: rgba(255, 255, 255, 0.78);
  border: 1.5px solid var(--ink);
  border-radius: 999px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--ink);
  box-shadow: 2px 2px 0 var(--ink);
}
.r-phrase::before { content: none; }
/* Dark-bg cards get translucent-on-dark phrase pills */
.mode-sienna .r-phrase {
  background: rgba(255, 255, 255, 0.08);
  color: var(--ivory);
  border-color: var(--ember);
  box-shadow: 2px 2px 0 var(--ember);
}
.mode-neon .r-phrase {
  background: rgba(255, 255, 255, 0.06);
  color: var(--silver);
  border-color: var(--neon-deep);
  box-shadow: 2px 2px 0 var(--neon-deep);
}
/* Flaw is intentionally not visually marked — per team-discussion principle (the inoculation works only when invisible). */

.r-chips {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px;
  position: relative;
  z-index: 5;
}
.r-chip {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 6px 10px;
  background: #fff;
  border: 1.5px solid var(--ink);
  border-radius: 100px;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  color: var(--ink);
  box-shadow: 1.5px 1.5px 0 var(--ink);
  line-height: 1.35;
}
.mode-sienna .r-chip {
  background: var(--midnight-2);
  color: var(--ivory);
  border-color: var(--rain-deep);
  box-shadow: 2px 2px 0 var(--rain-deep);
}
.mode-neon .r-chip {
  background: var(--charcoal-2);
  color: var(--silver);
  border-color: var(--neon-deep);
  box-shadow: 2px 2px 0 var(--neon-deep);
}

/* Compat — 2-column (Twins | Tension), each with mini-mascots beside track names */
.r-compat {
  margin: 14px 0 10px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  position: relative;
  z-index: 5;
}
.r-compat-block {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.r-compat-label {
  font-family: var(--sans);
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin: 0;
}
.r-compat-label-major {
  font-size: 11px;
  color: var(--cobalt);
}
.r-compat-label-minor {
  font-size: 9px;
  color: var(--ink-60);
}
.mode-sienna .r-compat-label-major { color: var(--ember); }
.mode-sienna .r-compat-label-minor { color: rgba(227, 230, 236, 0.5); }
.mode-neon .r-compat-label-major { color: var(--neon); }
.mode-neon .r-compat-label-minor { color: rgba(201, 208, 217, 0.5); }
.r-compat-tracks {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
/* Compat track — mascot is the main visual, tiny caption below.
   Twins and Tension use IDENTICAL sizing/styling — only section labels differ. */
.r-compat-tracks {
  display: flex;
  gap: 6px;
}
.r-compat-track {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 8px 4px 6px;
  background: var(--tulip);
  border: 1.5px solid var(--ink);
  border-radius: 8px;
  text-decoration: none;
  color: var(--ink);
  box-shadow: 2px 2px 0 var(--ink);
  transition: transform .08s var(--ease);
  min-width: 0;
}
.r-compat-track:hover { transform: translate(-1px, -1px); }
.r-compat-mascot {
  width: 44px;
  height: 44px;
  object-fit: contain;
  background: rgba(255, 255, 255, 0.55);
  border-radius: 50%;
  padding: 2px;
  flex-shrink: 0;
}
.r-compat-name {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.r-compat-name.lang-ko {
  font-family: var(--ko-display);
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0;
  text-transform: none;
}
.mode-sienna .r-compat-track {
  background: var(--ember);
  color: var(--midnight);
  border-color: var(--midnight);
  box-shadow: 2px 2px 0 var(--midnight);
}
.mode-neon .r-compat-track {
  background: var(--neon);
  color: var(--charcoal);
  border-color: var(--charcoal);
  box-shadow: 2px 2px 0 var(--charcoal);
}

.r-fanmade {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed var(--ink-30);
  font-family: 'JetBrains Mono', ui-monospace, SF Mono, Menlo, monospace;
  font-size: 9px;
  font-weight: 400;
  letter-spacing: 0.05em;
  color: var(--ink-60);
  text-align: center;
  line-height: 1.5;
  position: relative;
  z-index: 5;
}
.mode-sienna .r-fanmade {
  border-color: rgba(227, 230, 236, 0.2);
  color: rgba(227, 230, 236, 0.5);
}
.mode-neon .r-fanmade {
  border-color: rgba(201, 208, 217, 0.2);
  color: rgba(201, 208, 217, 0.5);
}

/* Question setting prose (between Q-title and options) */
.q-setting {
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.55;
  color: var(--ink-60);
  margin: -10px 0 18px;
  font-style: italic;
}
/* Italic-as-image emphasis inside option text */
.answer em {
  font-style: italic;
  font-weight: 700;
  background: var(--tulip);
  padding: 0 3px;
  box-shadow: 1.5px 1.5px 0 var(--ink);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  color: var(--ink);
}
.answer.is-picked em {
  background: var(--cream);
}

/* ============================================================
   NAME ENTRY FRAME
   ============================================================ */
.nameframe {
  background: var(--cream);
  padding: 56px 22px 48px;
  border: 2px solid var(--ink);
  box-shadow: 8px 8px 0 var(--cobalt);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.ncontent {
  max-width: 380px;
  margin: 0 auto;
  position: relative;
  z-index: 5;
}
.n-prompt {
  font-family: var(--display);
  font-size: clamp(1.5rem, 5.5vw, 1.75rem);
  line-height: 1.25;
  color: var(--ink);
  margin-bottom: 28px;
  letter-spacing: -0.01em;
  text-transform: lowercase;
}
.n-form {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 14px;
  margin-bottom: 18px;
}
.n-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-60);
  text-align: left;
}
.n-label-opt {
  font-weight: 600;
  color: var(--ink-30);
  letter-spacing: 0.16em;
  text-transform: lowercase;
}
.n-input::placeholder {
  color: var(--ink-30);
  font-weight: 400;
  font-style: italic;
}
.n-input {
  padding: 14px 16px;
  background: #fff;
  border: 2px solid var(--ink);
  border-radius: 0;
  font-family: var(--sans);
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
  outline: none;
  text-align: center;
}
.n-input:focus { border-color: var(--cobalt); box-shadow: 4px 4px 0 var(--cobalt); }
.n-submit {
  padding: 16px;
  background: var(--cobalt);
  color: var(--cream);
  border: 2px solid var(--ink);
  cursor: pointer;
  font-family: var(--display);
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: 4px 4px 0 var(--ink);
  transition: transform .1s var(--ease), box-shadow .1s var(--ease);
}
.n-submit:hover { transform: translate(-1px, -1px); box-shadow: 5px 5px 0 var(--ink); }
.n-submit:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--ink); }
.n-fineprint {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--ink-60);
}

/* ============================================================
   PER-TRACK PALETTES — per mascot-handoff.md
   Mode classes are layout-grouping only. Each track has a unique palette.
   Lifted verbatim from mockups/mascot-proof.html — these are the approved hex values.
   Per-track rules come AFTER mode rules so they win on source-order tiebreak.
   ============================================================ */

/* East Coast — cassette-cover palette (owner-supplied) */
.r-card.track-east-coast {
  background:
    radial-gradient(circle at 15% 10%, rgba(255,242,166,.9), transparent 24%),
    linear-gradient(180deg, #DCC7FF 0%, #FFC4D8 42%, #FFF2A6 72%, #9FD4F3 100%);
  box-shadow: 8px 8px 0 #5E8FDA;
  color: #2D5CA8;
}
.r-card.track-east-coast .r-track-title { color: #2D5CA8; text-shadow: 3px 3px 0 #FFF2A6, 5px 5px 0 #F58DB7; }
.r-card.track-east-coast .r-kicker { color: #F58DB7; }
.r-card.track-east-coast .r-name { color: #2D5CA8; }
.r-card.track-east-coast .r-id,
.r-card.track-east-coast .r-name-label,
.r-card.track-east-coast .r-block-label { color: rgba(45, 92, 168, 0.6); }
.r-card.track-east-coast .r-fanmade { border-color: rgba(45, 92, 168, 0.25); color: rgba(45, 92, 168, 0.55); }

/* Good Day — playground/MV palette (owner-supplied) */
.r-card.track-good-day {
  background:
    radial-gradient(circle at 78% 12%, rgba(255,242,214,.92), transparent 30%),
    linear-gradient(180deg, #F6E7CF 0%, #E9C88E 43%, #8BCAD4 100%);
  box-shadow: 8px 8px 0 #E86F6F;
  color: #2A2118;
}
.r-card.track-good-day .r-track-title { color: #2387A8; text-shadow: 3px 3px 0 #F3D58E, 5px 5px 0 #E86F6F; }
.r-card.track-good-day .r-kicker { color: #E86F6F; }
.r-card.track-good-day .r-name { color: #2387A8; }

/* 해 떴네 — dark sunrise (lyric page) */
.r-card.track-haerise {
  background: linear-gradient(180deg, #0d0a0e 0%, #181218 100%);
  box-shadow: 8px 8px 0 #c83a3a;
  color: #f4ece0;
}
.r-card.track-haerise .r-track-title { color: #d4a93a; text-shadow: 3px 3px 0 #c83a3a, 5px 5px 0 #050305; }
.r-card.track-haerise .r-kicker { color: #c83a3a; }
.r-card.track-haerise .r-name { color: #d4a93a; }
.r-card.track-haerise .r-id,
.r-card.track-haerise .r-name-label,
.r-card.track-haerise .r-claim-prefix,
.r-card.track-haerise .r-block-label,
.r-card.track-haerise .r-compat-label-minor { color: rgba(244, 236, 224, 0.55); }
.r-card.track-haerise .r-phrase { background: rgba(255, 255, 255, 0.06); color: #f4ece0; border-color: #c83a3a; box-shadow: 2px 2px 0 #c83a3a; }
.r-card.track-haerise .r-phrase::before { color: #c83a3a; }
.r-card.track-haerise .r-chip { background: rgba(255,255,255,0.08); color: #f4ece0; border-color: #c83a3a; box-shadow: 1.5px 1.5px 0 #c83a3a; }
.r-card.track-haerise .r-compat-track { background: #c83a3a; color: #f4ece0; border-color: #050305; box-shadow: 1.5px 1.5px 0 #050305; }
.r-card.track-haerise .r-fanmade { border-color: rgba(244, 236, 224, 0.2); color: rgba(244, 236, 224, 0.5); }

/* Race — charcoal/neon */
.r-card.track-race {
  background: linear-gradient(180deg, #0a0a0d 0%, #14141a 100%);
  color: #c9d0d9;
  box-shadow: 8px 8px 0 #a3ff12;
}
.r-card.track-race .r-track-title { color: #a3ff12; text-shadow: 3px 3px 0 #1e2a05, 5px 5px 0 #040406; }
.r-card.track-race .r-kicker { color: #a3ff12; }
.r-card.track-race .r-name { color: #a3ff12; }
.r-card.track-race .r-id,
.r-card.track-race .r-name-label,
.r-card.track-race .r-block-label { color: rgba(201, 208, 217, 0.5); }
.r-card.track-race .r-phrase { color: #c9d0d9; }
.r-card.track-race .r-phrase::before { color: #a3ff12; }
.r-card.track-race .r-chip { background: #14141a; color: #c9d0d9; border-color: #6fbf0a; box-shadow: 1.5px 1.5px 0 #6fbf0a; }
.r-card.track-race .r-compat-track { background: #a3ff12; color: #0a0a0d; border-color: #0a0a0d; box-shadow: 1.5px 1.5px 0 #0a0a0d; }
.r-card.track-race .r-fanmade { border-color: rgba(201, 208, 217, 0.2); color: rgba(201, 208, 217, 0.5); }

/* Help — black/magenta/green/silver */
.r-card.track-help {
  background: linear-gradient(180deg, #070508 0%, #140c15 100%);
  color: #f3eef2;
  box-shadow: 8px 8px 0 #ec1c7c;
}
.r-card.track-help .r-track-title { color: #ec1c7c; text-shadow: 3px 3px 0 #3d7a4a, 5px 5px 0 #030204; }
.r-card.track-help .r-kicker { color: #ff5a88; }
.r-card.track-help .r-name { color: #ff5a88; }
.r-card.track-help .r-id,
.r-card.track-help .r-name-label,
.r-card.track-help .r-block-label { color: rgba(243, 238, 242, 0.5); }
.r-card.track-help .r-phrase { color: #f3eef2; }
.r-card.track-help .r-phrase::before { color: #ec1c7c; }
.r-card.track-help .r-chip { background: rgba(255,255,255,0.06); color: #f3eef2; border-color: #ec1c7c; box-shadow: 1.5px 1.5px 0 #ec1c7c; }
.r-card.track-help .r-compat-track { background: #ec1c7c; color: #070508; border-color: #070508; box-shadow: 1.5px 1.5px 0 #070508; }
.r-card.track-help .r-fanmade { border-color: rgba(243, 238, 242, 0.2); color: rgba(243, 238, 242, 0.5); }

/* Rocket — space/red/ignition */
.r-card.track-rocket {
  background:
    radial-gradient(circle at 78% 18%, rgba(229,57,53,.28), transparent 42%),
    linear-gradient(180deg, #05070f 0%, #0e1220 100%);
  color: #f2f4f8;
  box-shadow: 8px 8px 0 #e53935;
}
.r-card.track-rocket .r-track-title { color: #c9d0d9; text-shadow: 3px 3px 0 #e53935, 5px 5px 0 #030409; }
.r-card.track-rocket .r-kicker { color: #ff6a2c; }
.r-card.track-rocket .r-name { color: #ff6a2c; }
.r-card.track-rocket .r-id,
.r-card.track-rocket .r-name-label,
.r-card.track-rocket .r-claim-prefix,
.r-card.track-rocket .r-block-label,
.r-card.track-rocket .r-compat-label-minor { color: rgba(242, 244, 248, 0.5); }
.r-card.track-rocket .r-phrase { background: rgba(255, 255, 255, 0.06); color: #f2f4f8; border-color: #e53935; box-shadow: 2px 2px 0 #e53935; }
.r-card.track-rocket .r-phrase::before { color: #e53935; }
.r-card.track-rocket .r-chip { background: rgba(255,255,255,0.06); color: #f2f4f8; border-color: #e53935; box-shadow: 1.5px 1.5px 0 #e53935; }
.r-card.track-rocket .r-compat-track { background: #e53935; color: #f2f4f8; border-color: #030409; box-shadow: 1.5px 1.5px 0 #030409; }
.r-card.track-rocket .r-fanmade { border-color: rgba(242, 244, 248, 0.2); color: rgba(242, 244, 248, 0.5); }

/* Goodbye — plum/rose/parchment/lavender */
.r-card.track-goodbye {
  background: linear-gradient(180deg, #1a1524 0%, #221a2c 100%);
  color: #ede4d4;
  box-shadow: 8px 8px 0 #b86b7a;
}
.r-card.track-goodbye .r-track-title { color: #b86b7a; text-shadow: 3px 3px 0 #5d5d7a, 5px 5px 0 #0a0810; }
.r-card.track-goodbye .r-kicker { color: #d8c89a; }
.r-card.track-goodbye .r-name { color: #d8c89a; }
.r-card.track-goodbye .r-id,
.r-card.track-goodbye .r-name-label,
.r-card.track-goodbye .r-block-label { color: rgba(237, 228, 212, 0.5); }
.r-card.track-goodbye .r-phrase { color: #ede4d4; }
.r-card.track-goodbye .r-phrase::before { color: #b86b7a; }
.r-card.track-goodbye .r-chip { background: rgba(237,228,212,0.06); color: #ede4d4; border-color: #8a8ab0; box-shadow: 1.5px 1.5px 0 #8a8ab0; }
.r-card.track-goodbye .r-compat-track { background: #b86b7a; color: #0a0810; border-color: #0a0810; box-shadow: 1.5px 1.5px 0 #0a0810; }
.r-card.track-goodbye .r-fanmade { border-color: rgba(237, 228, 212, 0.2); color: rgba(237, 228, 212, 0.5); }

/* Too Late — midnight/rain/pearl/ember */
.r-card.track-too-late {
  background: linear-gradient(180deg, #0e1520 0%, #161f2d 100%);
  color: #e3e6ec;
  box-shadow: 8px 8px 0 #c98b75;
}
.r-card.track-too-late .r-track-title { color: #c98b75; text-shadow: 3px 3px 0 #5a6f8a, 5px 5px 0 #070a10; }
.r-card.track-too-late .r-kicker { color: #c98b75; }
.r-card.track-too-late .r-name { color: #c98b75; }
.r-card.track-too-late .r-id,
.r-card.track-too-late .r-name-label,
.r-card.track-too-late .r-block-label { color: rgba(227, 230, 236, 0.5); }
.r-card.track-too-late .r-phrase { color: #e3e6ec; }
.r-card.track-too-late .r-phrase::before { color: #c98b75; }
.r-card.track-too-late .r-chip { background: rgba(227,230,236,0.06); color: #e3e6ec; border-color: #5a6f8a; box-shadow: 1.5px 1.5px 0 #5a6f8a; }
.r-card.track-too-late .r-compat-track { background: #c98b75; color: #0e1520; border-color: #0e1520; box-shadow: 1.5px 1.5px 0 #0e1520; }
.r-card.track-too-late .r-fanmade { border-color: rgba(227, 230, 236, 0.2); color: rgba(227, 230, 236, 0.5); }

/* Flower — blush/coral/sage (lyric page) */
.r-card.track-flower {
  background: linear-gradient(180deg, #f6dfd9 0%, #fdf3ee 100%);
  box-shadow: 8px 8px 0 #b0513f;
  color: #1a1118;
}
.r-card.track-flower .r-track-title { color: #d97764; text-shadow: 3px 3px 0 #f5d6ca, 5px 5px 0 #1a1118; }
.r-card.track-flower .r-kicker { color: #b0513f; }
.r-card.track-flower .r-name { color: #b0513f; }
.r-card.track-flower .r-id,
.r-card.track-flower .r-name-label,
.r-card.track-flower .r-block-label { color: rgba(26, 17, 24, 0.55); }
.r-card.track-flower .r-fanmade { border-color: rgba(26, 17, 24, 0.25); color: rgba(26, 17, 24, 0.55); }

/* HBD — birthday confetti (lyric page) */
.r-card.track-hbd {
  background:
    repeating-linear-gradient(90deg,
      rgba(255,77,143,.16) 0 20px,
      rgba(255,210,63,.16) 20px 40px,
      rgba(142,211,74,.16) 40px 60px,
      rgba(78,193,232,.16) 60px 80px,
      rgba(155,106,214,.16) 80px 100px,
      rgba(255,138,60,.16) 100px 120px),
    linear-gradient(180deg, #FFF4E0 0%, #FFFAEC 100%);
  box-shadow: 8px 8px 0 #FF4D8F;
  color: #2E3A59;
}
.r-card.track-hbd .r-track-title { color: #FF4D8F; text-shadow: 3px 3px 0 #FFD23F, 5px 5px 0 #2E3A59; }
.r-card.track-hbd .r-kicker { color: #FF4D8F; }
.r-card.track-hbd .r-name { color: #FF4D8F; }
.r-card.track-hbd .r-id,
.r-card.track-hbd .r-name-label,
.r-card.track-hbd .r-block-label { color: rgba(46, 58, 89, 0.55); }
.r-card.track-hbd .r-fanmade { border-color: rgba(46, 58, 89, 0.25); color: rgba(46, 58, 89, 0.55); }

/* Beautiful — lavender/mist (lyric page) */
.r-card.track-beautiful {
  background: linear-gradient(180deg, #ecebf0 0%, #ffffff 100%);
  box-shadow: 8px 8px 0 #8a84a8;
  color: #2a2a35;
}
.r-card.track-beautiful .r-track-title { color: #8a84a8; text-shadow: 3px 3px 0 #c9c5d4, 5px 5px 0 #2a2a35; }
.r-card.track-beautiful .r-kicker { color: #5a5578; }
.r-card.track-beautiful .r-name { color: #5a5578; }
.r-card.track-beautiful .r-id,
.r-card.track-beautiful .r-name-label,
.r-card.track-beautiful .r-block-label { color: rgba(42, 42, 53, 0.55); }
.r-card.track-beautiful .r-fanmade { border-color: rgba(42, 42, 53, 0.25); color: rgba(42, 42, 53, 0.55); }

/* ============================================================
   Phone tier
   ============================================================ */
@media (max-width: 380px) {
  body { padding: 16px 12px 60px; }
  .qcount { font-size: 48px; }
  .q-title { font-size: 1.5rem; }
  .answer { padding: 12px 14px; font-size: 14px; }
  .intro { padding: 28px 18px; }
  .qframe, .nameframe { padding: 22px 18px; }
  .r-card { padding: 22px 16px 18px; }
  .r-hero { grid-template-columns: minmax(0, 1fr) 120px; gap: 10px; }
  .r-mascot-slot { width: 120px; height: 120px; }
  .r-track-title { font-size: clamp(1.45rem, 6vw, 1.95rem); letter-spacing: -0.02em; }
  .n-prompt { font-size: 1.4rem; }
}
