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

:root {
  --cream: #FBF1D6;
  --cream-2: #F5E6B8;
  --cobalt: #3282c8; /* ALIVE album packaging blue */
  --cobalt-deep: #2468a3;
  --sky: #B8D9FF;
  --sky-deep: #7BB0FF;
  --pink: #FFB8C9;
  --pink-deep: #FF8FA8;
  --orange: #FF7E3D;
  --gerbera: #F5AAAF; /* ALIVE album packaging pink */
  --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; }
[hidden] { display: none !important; }

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; }

/* ============================================================
   INTRO
   ============================================================ */
/* ---- Intro — shared structure ---- */
.intro {
  padding: 36px 22px 32px;
  border: 2px solid var(--ink);
  position: relative;
  overflow: hidden;
  transition: background .35s ease, box-shadow .35s ease;
}
.intro-content { position: relative; z-index: 5; }

.intro-eyebrow {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: 14px;
  transition: color .35s ease;
}
.intro-title {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(1.7rem, 6.5vw, 2.2rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin-bottom: 18px;
  transition: color .35s ease;
}
.intro-title em {
  font-style: normal;
  padding: 0 4px;
  transition: color .35s ease, background .35s ease, box-shadow .35s ease;
}
.intro-deck {
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.55;
  max-width: 34ch;
  margin-bottom: 22px;
  transition: color .35s ease;
}
.intro-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 24px;
}
.intro-chip {
  padding: 5px 10px;
  border: 1.5px solid var(--ink);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  transition: background .35s ease, color .35s ease;
}
.intro-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 26px;
  border: 2px solid var(--ink);
  cursor: pointer;
  font-family: var(--display);
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  transition: transform .1s var(--ease), box-shadow .1s var(--ease), background .35s ease, color .35s ease;
}
.intro-cta:hover { transform: translate(-1px, -1px); }
.intro-cta:active { transform: translate(2px, 2px); }
.intro-fineprint {
  margin-top: 18px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  transition: color .35s ease;
}

/* ---- Studio Garden — paper-flower photograph ---- */
.intro-garden {
  background: #f1ece6 url('assets/img/intro-garden.jpg') center/cover no-repeat;
  box-shadow: 8px 8px 0 #8a72c2;
  padding: 0;
}
/* ZH title (你是哪一朵花?) fits on 1 line where EN (WHAT FLOWER ARE YOU?)
   wraps to 3. Without intervention, the ZH .intro-garden section ends
   up shorter than EN and `cover` shows less zoom on the flower photo.
   Anchor the ZH section's min-height so it matches EN's natural render
   — EN keeps its natural rendering, only ZH gets stretched. clamp
   scales between phone and small-tablet widths. */
html[data-lang="zh"] .intro-garden {
  min-height: clamp(440px, 110vw, 560px);
}
.intro-garden .intro-content {
  margin: 12% auto;
  padding: 28px 26px 26px;
  background: rgba(252, 248, 244, 0.86);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 2px solid var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
  max-width: 36ch;
}
.intro-garden .intro-eyebrow { color: #6f56b3; }
.intro-garden .intro-title { color: var(--ink); }
.intro-garden .intro-title em {
  color: #c44a6a;
  background: #f5d4d2;
  box-shadow: 3px 3px 0 var(--ink);
}
.intro-garden .intro-deck { color: var(--ink); }
.intro-garden .intro-deck em {
  font-style: normal;
  font-weight: 800;
  color: #6f56b3;
}
.intro-garden .intro-chip {
  background: rgba(255, 255, 255, 0.85);
  color: var(--ink);
}
.intro-garden .intro-chip b { color: #6f56b3; font-weight: 800; }
.intro-garden .intro-cta {
  background: #6f56b3;
  color: #fef8f2;
  box-shadow: 4px 4px 0 var(--ink);
}
.intro-garden .intro-cta:hover { box-shadow: 5px 5px 0 var(--ink); }
.intro-garden .intro-cta:active { box-shadow: 2px 2px 0 var(--ink); }
.intro-garden .intro-fineprint { color: rgba(22, 22, 22, 0.55); }

@media (max-width: 560px) {
  .intro-garden { background-position: 70% center; }
  .intro-garden .intro-content {
    margin: 18px;
    background: rgba(252, 248, 244, 0.92);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
}

/* ============================================================
   QUESTION FRAME
   ============================================================ */
.qframe {
  background:
    linear-gradient(rgba(252, 248, 244, 0.7), rgba(252, 248, 244, 0.7)),
    url('assets/img/intro-garden.jpg') center/cover no-repeat,
    #f1ece6;
  padding: 0;
  border: 2px solid var(--ink);
  box-shadow: 8px 8px 0 #8a72c2;
  position: relative;
  overflow: hidden;
}
.qframe .qcontent {
  margin: 24px;
  padding: 24px 22px;
  background: rgba(252, 248, 244, 0.82);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 2px solid var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
}
@media (max-width: 560px) {
  .qframe {
    background:
      linear-gradient(rgba(252, 248, 244, 0.72), rgba(252, 248, 244, 0.72)),
      url('assets/img/intro-garden.jpg') 70% center/cover no-repeat,
      #f1ece6;
  }
  .qframe .qcontent {
    margin: 14px;
    padding: 18px 16px;
    background: rgba(252, 248, 244, 0.86);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
}

.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: #6f56b3;
  letter-spacing: -0.04em;
  text-shadow: 2px 2px 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: 16px;
}
.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: #6f56b3; }

.q-scene {
  display: grid;
  place-items: center;
  margin: 0 0 18px;
}
.q-scene img {
  width: min(100%, 420px);
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border: 2px solid var(--ink);
  box-shadow: 5px 5px 0 #8a72c2;
  background: var(--cream-2);
}

.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 #6f56b3; outline-offset: 3px; }
.answer.is-picked { background: #6f56b3; color: var(--cream); border-color: var(--ink); }
.answer.is-picked .marker { background: var(--cream); color: #6f56b3; }

.marker {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: #6f56b3;
  color: var(--cream);
  display: grid;
  place-items: center;
  font-family: var(--display);
  font-size: 12px;
}
.answer.a2 .marker { background: #c44a6a; }
.answer.a3 .marker { background: #7a8f55; }
.answer.a4 .marker { background: #e4a3aa; }

.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: #6f56b3; }
.q-back:focus-visible { outline: 2px solid #6f56b3; outline-offset: 4px; }

/* ============================================================
   RESULT — outer wrapper holds the shareable card + the actions below
   ============================================================ */
.rframe {
  position: relative;
  /* --accent cascades to both .r-card and .r-actions (sibling).
     Defaults to album cobalt for cream/sky modes; per-track variants override below. */
  --accent: var(--cobalt);
  --accent-deep: var(--cobalt-deep);
  /* 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(--accent);
  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(--accent);
  margin-bottom: 4px;
}
.mode-sky .r-you { color: var(--accent-deep); }
.mode-sienna .r-you { color: var(--accent); }
.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(--accent); font-weight: 700; }
.mode-sienna .r-secondary-line b { color: var(--accent); }
.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(--accent);
  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(--accent); color: var(--midnight); border-color: var(--midnight); }
/* Goodbye's camellia-red wants light text for legibility (matches its .r-quick-tag treatment). */
.rframe.track-goodbye .r-cta-primary { color: #EDE4D4; }
.mode-neon .r-cta-primary { background: var(--neon); color: var(--charcoal); border-color: var(--charcoal); box-shadow: 4px 4px 0 var(--neon-deep); }

/* Secondary primary — outlined version, used for the Lyrics CTA when stacked under Listen.
   Same shape/typography, no fill, so two stacked CTAs don't read as a heavy double-block. */
.r-cta-primary.r-cta-primary-alt { background: transparent; color: var(--ink); }
.mode-sienna .r-cta-primary.r-cta-primary-alt { background: transparent; color: var(--ivory); border-color: var(--ivory); }
.rframe.track-goodbye .r-cta-primary.r-cta-primary-alt { color: #EDE4D4; }
.mode-neon .r-cta-primary.r-cta-primary-alt { background: transparent; color: var(--silver); border-color: var(--neon); 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;
  flex-wrap: wrap;
  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; }

/* At narrow widths, the 4-button row gets lumpy because labels wrap unevenly.
   Snap to a 2x2 grid below 380px so each button takes ~half-width. */
@media (max-width: 380px) {
  .r-share-row a, .r-share-row button,
  .r-share-row #share-x { flex: 0 0 calc(50% - 4px); }
}

.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(--accent); border-color: var(--accent); }

/* ============================================================
   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: #6f56b3; border-color: #6f56b3; }
.foot a.foot-mark {
  font-family: var(--display);
  font-size: 18px;
  letter-spacing: -0.02em;
  color: #6f56b3;
  text-decoration: none;
  text-transform: uppercase;
}
.foot a.foot-mark:hover { color: #6f56b3; border-color: transparent; }

/* ============================================================
   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); }

/* Identity line — the sharp one-liner under the kicker, above the quick-tags.
   Italic + tighter tracking gives it voice distinct from the all-caps kicker above
   and the bold chips below — same register as .q-setting in the question frame. */
.r-identity {
  display: none;
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.35;
  font-weight: 500;
  font-style: italic;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin: 8px 0 2px;
  max-width: 36ch;
  position: relative;
  z-index: 5;
}
.mode-sienna .r-identity { color: rgba(238, 232, 220, 0.92); font-weight: 600; }
.mode-neon .r-identity { color: rgba(228, 232, 240, 0.92); font-weight: 600; }
/* Per-track identity text — dark text on light cards, light text on dark cards */
.r-card.track-haerise .r-identity { color: #4A3810; font-weight: 600; }
.r-card.track-race .r-identity { color: #4A1828; font-weight: 600; }
.r-card.track-rocket .r-identity { color: #2A1848; font-weight: 600; }
.r-card.track-help .r-identity { color: #d0daea; font-weight: 600; }
.r-card.track-goodbye .r-identity { color: #ede4d4; font-weight: 600; }
.r-card.track-too-late .r-identity { color: #d0cce0; font-weight: 600; }

.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.3rem, 5.2vw, 1.7rem);
  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), 3px 3px 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: 2px 2px 0 #fff, 3px 3px 0 var(--ink); }
.mode-sienna .r-track-title { color: var(--ember); text-shadow: 2px 2px 0 var(--rain-deep), 3px 3px 0 var(--ink); }
.mode-neon .r-track-title { color: var(--neon); text-shadow: 2px 2px 0 var(--neon-low), 3px 3px 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) 150px;
  gap: 8px;
  align-items: start;
  margin-bottom: 12px;
  position: relative;
  z-index: 5;
}
@media (max-width: 380px) {
  .r-hero { grid-template-columns: minmax(0, 1fr) 120px; gap: 10px; }
  .r-mascot-slot { width: 120px; height: 120px; }
}
.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: 150px;
  height: 150px;
  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: none;
  flex-wrap: nowrap;
  justify-content: flex-start;
  gap: 3px;
  margin: 0 0 6px;
  position: relative;
  z-index: 5;
}
.r-quick-tag {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  min-height: 18px;
  background: var(--ink);
  color: var(--cream);
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.4;
  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-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); }

/* Made of — playful percentage breakdown */
.r-ingredient-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.r-ingredient-line {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.35;
  padding: 0;
  color: inherit;
}
.r-ingredient-pct {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  font-weight: 700;
  color: var(--cobalt);
}
.mode-sienna .r-ingredient-pct { color: var(--ember); }
.mode-neon .r-ingredient-pct { color: var(--neon); }

/* Strengths + The Catch — side-by-side two-column layout */
.r-traits-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 14px;
  margin-top: 18px;
}
.r-traits-col {
  min-width: 0;
}

/* Trait bullet lists */
.r-trait-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.r-trait-line {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 650;
  line-height: 1.3;
  padding: 2px 0 2px 14px;
  position: relative;
  color: inherit;
}
.r-strength-line::before {
  content: '+';
  position: absolute;
  left: 2px;
  font-weight: 800;
  color: var(--cobalt);
}
.r-catch-line::before {
  content: '~';
  position: absolute;
  left: 2px;
  font-weight: 800;
  color: rgba(22, 22, 22, 0.42);
}
.mode-sienna .r-strength-line::before { color: var(--ember); }
.mode-neon .r-strength-line::before { color: var(--neon); }
.mode-sienna .r-catch-line::before { color: rgba(227, 230, 236, 0.4); }
.mode-neon .r-catch-line::before { color: rgba(201, 208, 217, 0.4); }

/* Pills — "in your handwriting" mundane-specific trait pills */
.r-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 0;
  padding: 0;
}
.r-pill {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  min-height: 28px;
  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.35;
  color: var(--ink);
  box-shadow: 2px 2px 0 var(--ink);
}
.mode-sienna .r-pill {
  background: rgba(255, 255, 255, 0.08);
  color: var(--ivory);
  border-color: var(--ember);
  box-shadow: 2px 2px 0 var(--ember);
}
.mode-neon .r-pill {
  background: rgba(255, 255, 255, 0.06);
  color: var(--silver);
  border-color: var(--neon-deep);
  box-shadow: 2px 2px 0 var(--neon-deep);
}

/* phrases + chips removed — replaced by Made of / Strengths / The Catch */

/* Stats — 4 flower-coded axes rated 1–5 */
.r-stats {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 8px;
}
.r-stat-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.r-stat-label {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  min-width: 70px;
  color: inherit;
}
.r-stat-bar {
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: 0.15em;
  color: var(--cobalt);
}
.mode-sienna .r-stat-bar { color: var(--ember); }
.mode-neon .r-stat-bar { color: var(--neon); }

/* 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: 10px;
  font-weight: 800;
  color: var(--cobalt);
}
.r-compat-label-minor {
  font-size: 10px;
  font-weight: 600;
  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: normal;
  word-break: keep-all;
  overflow-wrap: anywhere;
  line-height: 1.15;
  max-width: 100%;
  min-height: 21px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.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;
  text-wrap: balance;
  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 #8a72c2;
  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: #6f56b3; box-shadow: 4px 4px 0 #6f56b3; }
.n-submit {
  padding: 16px;
  background: #6f56b3;
  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 — flower-led redesign (2026-05-01)
   Each track's palette is derived from its Korean flower (꽃말).
   Per-track rules come AFTER mode rules so they win on source-order.
   ============================================================ */

/* Capture-only pill/chip alignment overrides.
   html2canvas places text line-boxes ~2px lower in the flex cross-axis than
   the browser does. These apply asymmetric padding only during capture. */
.r-card.is-capturing .r-pill { padding: 5px 14px 9px; }
.r-card.is-capturing .r-quick-tag { padding: 2px 8px 5px; }

/* Good Day — JASMINE 재스민 · early morning, jasmine fragrance at dawn */
.r-card.track-good-day {
  background:
    radial-gradient(circle at 30% 40%, rgba(255,235,200,.7), transparent 35%),
    linear-gradient(180deg, #FFF0DC 0%, #F2D8A8 35%, #C8D8B8 65%, #8EBAA8 100%);
  box-shadow: 8px 8px 0 #7BA68A;
  color: #2A2118;
}
.r-card.track-good-day.is-capturing {
  background: linear-gradient(180deg, #FFF0DC 0%, #F2D8A8 35%, #C8D8B8 65%, #8EBAA8 100%);
}
.r-card.track-good-day .r-track-title { color: #3A7A52; text-shadow: 2px 2px 0 #E8D8A8, 3px 3px 0 #7BA68A; }
.r-card.track-good-day .r-kicker { color: #C8A24E; }
.r-card.track-good-day .r-compat-label-major { color: #3A7A52; }
.r-card.track-good-day .r-ingredient-pct { color: #7BA68A; }
.r-card.track-good-day .r-strength-line::before { color: #7BA68A; }
.r-card.track-good-day .r-stat-bar { color: #7BA68A; }
.r-card.track-good-day .r-fanmade { border-color: rgba(42, 33, 24, 0.25); color: rgba(42, 33, 24, 0.55); }

/* East Coast — MARIGOLD 금잔화 · golden hour fading to twilight, marigold against dusk sky */
.r-card.track-east-coast {
  background:
    radial-gradient(circle at 20% 85%, rgba(90,122,170,.18), transparent 40%),
    linear-gradient(180deg, #FFF0D0 0%, #FFD9A8 30%, #C8B5D8 65%, #8B9DC8 100%);
  box-shadow: 8px 8px 0 #5A7AAA;
  color: #1F2C45;
}
.r-card.track-east-coast.is-capturing {
  background: linear-gradient(180deg, #FFF0D0 0%, #FFD9A8 30%, #C8B5D8 65%, #8B9DC8 100%);
}
.r-card.track-east-coast .r-track-title { color: #2C4576; text-shadow: 2px 2px 0 #FFD9A8, 3px 3px 0 #5A7AAA; }
.r-card.track-east-coast .r-kicker { color: #C46818; }
.r-card.track-east-coast .r-id,
.r-card.track-east-coast .r-claim-prefix,
.r-card.track-east-coast .r-block-label { color: rgba(31, 44, 69, 0.6); }
.r-card.track-east-coast .r-pill { background: rgba(255, 255, 255, 0.7); border-color: #5A7AAA; box-shadow: 2px 2px 0 #5A7AAA; }
.r-card.track-east-coast .r-compat-label-major { color: #2C4576; }
.r-card.track-east-coast .r-ingredient-pct { color: #5A7AAA; }
.r-card.track-east-coast .r-strength-line::before { color: #5A7AAA; }
.r-card.track-east-coast .r-stat-bar { color: #5A7AAA; }
.r-card.track-east-coast .r-compat-track { background: #5A7AAA; color: #FFF0D0; border-color: #1F2C45; box-shadow: 1.5px 1.5px 0 #1F2C45; }
.r-card.track-east-coast .r-fanmade { border-color: rgba(31, 44, 69, 0.25); color: rgba(31, 44, 69, 0.55); }

/* 해 떮네 — SUNFLOWER 해바라기 · blazing noon, full sun */
.r-card.track-haerise {
  background:
    radial-gradient(circle at 50% 10%, rgba(255,240,160,.6), transparent 45%),
    linear-gradient(180deg, #FFF5D0 0%, #F5E0A0 35%, #E8C860 70%, #D4A830 100%);
  box-shadow: 8px 8px 0 #A88020;
  color: #2A2010;
}
.r-card.track-haerise.is-capturing {
  background: linear-gradient(180deg, #FFF5D0 0%, #F5E0A0 35%, #E8C860 70%, #D4A830 100%);
}
.r-card.track-haerise .r-track-title { color: #7A5A10; text-shadow: 2px 2px 0 #F2D86A, 3px 3px 0 #A88020; }
.r-card.track-haerise .r-kicker { color: #A87A18; }
.r-card.track-haerise .r-id,
.r-card.track-haerise .r-claim-prefix,
.r-card.track-haerise .r-block-label { color: rgba(42, 32, 16, 0.55); }
.r-card.track-haerise .r-pill { background: rgba(255, 255, 255, 0.6); border-color: #A88020; box-shadow: 2px 2px 0 #A88020; }
.r-card.track-haerise .r-compat-label-major { color: #7A5A10; }
.r-card.track-haerise .r-ingredient-pct { color: #A88020; }
.r-card.track-haerise .r-strength-line::before { color: #A88020; }
.r-card.track-haerise .r-stat-bar { color: #A88020; }
.r-card.track-haerise .r-compat-track { background: #A88020; color: #FFF8E0; border-color: #2A2010; box-shadow: 1.5px 1.5px 0 #2A2010; }
.r-card.track-haerise .r-fanmade { border-color: rgba(42, 32, 16, 0.25); color: rgba(42, 32, 16, 0.55); }

/* Race — MUGUNGHWA 무궁화 · resilient bloom, warm rose */
.r-card.track-race {
  background:
    radial-gradient(circle at 60% 15%, rgba(240,180,200,.5), transparent 40%),
    linear-gradient(180deg, #FDE8F0 0%, #F0C8D8 40%, #E0A0B8 70%, #C87898 100%);
  box-shadow: 8px 8px 0 #A04068;
  color: #2A1018;
}
.r-card.track-race.is-capturing {
  background: linear-gradient(180deg, #FDE8F0 0%, #F0C8D8 40%, #E0A0B8 70%, #C87898 100%);
}
.r-card.track-race .r-track-title { color: #8A2850; text-shadow: 2px 2px 0 #F0C8D8, 3px 3px 0 #A04068; }
.r-card.track-race .r-kicker { color: #A04068; }
.r-card.track-race .r-id,
.r-card.track-race .r-claim-prefix,
.r-card.track-race .r-block-label { color: rgba(42, 16, 24, 0.55); }
.r-card.track-race .r-pill { background: rgba(255, 255, 255, 0.6); border-color: #A04068; box-shadow: 2px 2px 0 #A04068; }
.r-card.track-race .r-compat-label-major { color: #8A2850; }
.r-card.track-race .r-ingredient-pct { color: #A04068; }
.r-card.track-race .r-strength-line::before { color: #A04068; }
.r-card.track-race .r-stat-bar { color: #A04068; }
.r-card.track-race .r-compat-track { background: #A04068; color: #FDE8F0; border-color: #2A1018; box-shadow: 1.5px 1.5px 0 #2A1018; }
.r-card.track-race .r-fanmade { border-color: rgba(42, 16, 24, 0.25); color: rgba(42, 16, 24, 0.55); }

/* Help — FORGET-ME-NOT 물망초 · blue hour twilight, between day and night */
.r-card.track-help {
  background:
    radial-gradient(circle at 50% 100%, rgba(91,155,213,.15), transparent 50%),
    linear-gradient(180deg, #142540 0%, #1A3050 45%, #223A5A 100%);
  box-shadow: 8px 8px 0 #5B9BD5;
  color: #E0E8F2;
}
.r-card.track-help.is-capturing {
  background: linear-gradient(180deg, #142540 0%, #1A3050 45%, #223A5A 100%);
}
.r-card.track-help .r-track-title { color: #7BB8E0; text-shadow: 2px 2px 0 #1A3A5A, 3px 3px 0 #030508; }
.r-card.track-help .r-kicker { color: #5B9BD5; }
.r-card.track-help .r-id,
.r-card.track-help .r-claim-prefix,
.r-card.track-help .r-block-label,
.r-card.track-help .r-compat-label-major { color: rgba(224, 232, 242, 0.5); }
.r-card.track-help .r-compat-label-major { color: #7BB8E0; }
.r-card.track-help .r-pill { background: rgba(255, 255, 255, 0.09); color: #E0E8F2; border-color: #5B9BD5; box-shadow: 2px 2px 0 #5B9BD5; }
.r-card.track-help .r-quick-tag { background: #5B9BD5; color: #0A1520; }
.r-card.track-help .r-ingredient-pct { color: #5B9BD5; }
.r-card.track-help .r-strength-line::before { color: #5B9BD5; }
.r-card.track-help .r-catch-line::before { color: rgba(224, 232, 242, 0.4); }
.r-card.track-help .r-stat-bar { color: #5B9BD5; }
.r-card.track-help .r-compat-track { background: #5B9BD5; color: #080E1A; border-color: #080E1A; box-shadow: 1.5px 1.5px 0 #080E1A; }
.r-card.track-help .r-fanmade { border-color: rgba(224, 232, 242, 0.2); color: rgba(224, 232, 242, 0.5); }

/* Rocket — MORNING GLORY 나팔꽃 · dawn light, first violet streaks */
.r-card.track-rocket {
  background:
    radial-gradient(circle at 75% 15%, rgba(160,140,230,.4), transparent 40%),
    linear-gradient(180deg, #E8E0F8 0%, #D8CCF0 35%, #C4B0E8 70%, #A890D8 100%);
  box-shadow: 8px 8px 0 #6A4CE0;
  color: #1A1030;
}
.r-card.track-rocket.is-capturing {
  background: linear-gradient(180deg, #E8E0F8 0%, #D8CCF0 35%, #C4B0E8 70%, #A890D8 100%);
}
.r-card.track-rocket .r-track-title { color: #4A2AA0; text-shadow: 2px 2px 0 #D4C8E8, 3px 3px 0 #6A4CE0; }
.r-card.track-rocket .r-kicker { color: #6A4CE0; }
.r-card.track-rocket .r-id,
.r-card.track-rocket .r-claim-prefix,
.r-card.track-rocket .r-block-label { color: rgba(26, 16, 48, 0.55); }
.r-card.track-rocket .r-pill { background: rgba(255, 255, 255, 0.6); border-color: #6A4CE0; box-shadow: 2px 2px 0 #6A4CE0; }
.r-card.track-rocket .r-compat-label-major { color: #4A2AA0; }
.r-card.track-rocket .r-ingredient-pct { color: #6A4CE0; }
.r-card.track-rocket .r-strength-line::before { color: #6A4CE0; }
.r-card.track-rocket .r-stat-bar { color: #6A4CE0; }
.r-card.track-rocket .r-compat-track { background: #6A4CE0; color: #F0E8FC; border-color: #1A1030; box-shadow: 1.5px 1.5px 0 #1A1030; }
.r-card.track-rocket .r-fanmade { border-color: rgba(26, 16, 48, 0.25); color: rgba(26, 16, 48, 0.55); }

/* Goodbye — CAMELLIA 동백꽃 · winter dusk, last warm light */
.r-card.track-goodbye {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(196,64,64,.18), transparent 50%),
    linear-gradient(180deg, #302018 0%, #281A14 40%, #201410 100%);
  box-shadow: 8px 8px 0 #C44040;
  color: #EDE4D4;
}
.r-card.track-goodbye.is-capturing {
  background: linear-gradient(180deg, #302018 0%, #281A14 40%, #201410 100%);
}
.r-card.track-goodbye .r-track-title { color: #D44848; text-shadow: 2px 2px 0 #4A2020, 3px 3px 0 #0A0608; }
.r-card.track-goodbye .r-kicker { color: #C44040; }
.r-card.track-goodbye .r-id,
.r-card.track-goodbye .r-claim-prefix,
.r-card.track-goodbye .r-block-label { color: rgba(237, 228, 212, 0.5); }
.r-card.track-goodbye .r-compat-label-major { color: #D44848; }
.r-card.track-goodbye .r-pill { background: rgba(237, 228, 212, 0.09); color: #EDE4D4; border-color: #C44040; box-shadow: 2px 2px 0 #C44040; }
.r-card.track-goodbye .r-quick-tag { background: #C44040; color: #EDE4D4; }
.r-card.track-goodbye .r-ingredient-pct { color: #C44040; }
.r-card.track-goodbye .r-strength-line::before { color: #C44040; }
.r-card.track-goodbye .r-catch-line::before { color: rgba(237, 228, 212, 0.4); }
.r-card.track-goodbye .r-stat-bar { color: #C44040; }
.r-card.track-goodbye .r-compat-track { background: #C44040; color: #EDE4D4; border-color: #0A0608; box-shadow: 1.5px 1.5px 0 #0A0608; }
.r-card.track-goodbye .r-fanmade { border-color: rgba(237, 228, 212, 0.2); color: rgba(237, 228, 212, 0.5); }

/* Too Late — HYDRANGEA 수국 · rainy evening, blue-grey mist */
.r-card.track-too-late {
  background:
    radial-gradient(circle at 30% 90%, rgba(138,126,184,.15), transparent 50%),
    linear-gradient(180deg, #1A2538 0%, #223048 45%, #283855 100%);
  box-shadow: 8px 8px 0 #8A7EB8;
  color: #E3E0EC;
}
.r-card.track-too-late.is-capturing {
  background: linear-gradient(180deg, #1A2538 0%, #223048 45%, #283855 100%);
}
.r-card.track-too-late .r-track-title { color: #9B8EC8; text-shadow: 2px 2px 0 #3A3A5A, 3px 3px 0 #070A10; }
.r-card.track-too-late .r-kicker { color: #8A7EB8; }
.r-card.track-too-late .r-id,
.r-card.track-too-late .r-claim-prefix,
.r-card.track-too-late .r-block-label { color: rgba(227, 224, 236, 0.5); }
.r-card.track-too-late .r-compat-label-major { color: #9B8EC8; }
.r-card.track-too-late .r-pill { background: rgba(227, 224, 236, 0.09); color: #E3E0EC; border-color: #8A7EB8; box-shadow: 2px 2px 0 #8A7EB8; }
.r-card.track-too-late .r-quick-tag { background: #8A7EB8; color: #0E1520; }
.r-card.track-too-late .r-ingredient-pct { color: #8A7EB8; }
.r-card.track-too-late .r-strength-line::before { color: #8A7EB8; }
.r-card.track-too-late .r-catch-line::before { color: rgba(227, 224, 236, 0.4); }
.r-card.track-too-late .r-stat-bar { color: #8A7EB8; }
.r-card.track-too-late .r-compat-track { background: #8A7EB8; color: #0E1520; border-color: #0E1520; box-shadow: 1.5px 1.5px 0 #0E1520; }
.r-card.track-too-late .r-fanmade { border-color: rgba(227, 224, 236, 0.2); color: rgba(227, 224, 236, 0.5); }

/* Flower — VIOLET 제비꽃 · spring afternoon, dappled shade (cool violet) */
.r-card.track-flower {
  background:
    radial-gradient(circle at 70% 20%, rgba(160,140,210,.3), transparent 40%),
    linear-gradient(180deg, #E0D4F0 0%, #D4C4E8 40%, #E8E0F4 100%);
  box-shadow: 8px 8px 0 #5E3D8A;
  color: #1A1028;
}
.r-card.track-flower.is-capturing {
  background: linear-gradient(180deg, #E0D4F0 0%, #D4C4E8 40%, #E8E0F4 100%);
}
.r-card.track-flower .r-track-title { color: #5E3D8A; text-shadow: 2px 2px 0 #D4C8E0, 3px 3px 0 #1A1028; }
.r-card.track-flower .r-kicker { color: #5E3D8A; }
.r-card.track-flower .r-id,
.r-card.track-flower .r-claim-prefix,
.r-card.track-flower .r-block-label { color: rgba(26, 16, 40, 0.55); }
.r-card.track-flower .r-pill { border-color: #5E3D8A; box-shadow: 2px 2px 0 #5E3D8A; }
.r-card.track-flower .r-compat-label-major { color: #5E3D8A; }
.r-card.track-flower .r-ingredient-pct { color: #5E3D8A; }
.r-card.track-flower .r-strength-line::before { color: #5E3D8A; }
.r-card.track-flower .r-stat-bar { color: #5E3D8A; }
.r-card.track-flower .r-compat-track { background: #5E3D8A; color: #F0E8FC; border-color: #1A1028; box-shadow: 1.5px 1.5px 0 #1A1028; }
.r-card.track-flower .r-fanmade { border-color: rgba(26, 16, 40, 0.25); color: rgba(26, 16, 40, 0.55); }

/* HBD — DAISY 데이지 · bright morning meadow, warm sun */
.r-card.track-hbd {
  background:
    radial-gradient(circle at 50% 15%, rgba(255,248,180,.5), transparent 45%),
    linear-gradient(180deg, #FFF8D8 0%, #F8ECC0 40%, #E8DCA8 70%, #D0D8A8 100%);
  box-shadow: 8px 8px 0 #C8941A;
  color: #2A2A18;
}
.r-card.track-hbd.is-capturing {
  background: linear-gradient(180deg, #FFF8D8 0%, #F8ECC0 40%, #E8DCA8 70%, #D0D8A8 100%);
}
.r-card.track-hbd .r-track-title { color: #E85A8A; text-shadow: 2px 2px 0 #F2D86A, 3px 3px 0 #2A2A18; }
.r-card.track-hbd .r-kicker { color: #D4941A; }
.r-card.track-hbd .r-id,
.r-card.track-hbd .r-claim-prefix,
.r-card.track-hbd .r-block-label { color: rgba(42, 42, 24, 0.55); }
.r-card.track-hbd .r-pill { border-color: #C8941A; box-shadow: 2px 2px 0 #C8941A; }
.r-card.track-hbd .r-compat-label-major { color: #C8941A; }
.r-card.track-hbd .r-ingredient-pct { color: #C8941A; }
.r-card.track-hbd .r-strength-line::before { color: #C8941A; }
.r-card.track-hbd .r-stat-bar { color: #C8941A; }
.r-card.track-hbd .r-compat-track { background: #C8941A; color: #FFF8E0; border-color: #2A2A18; box-shadow: 1.5px 1.5px 0 #2A2A18; }
.r-card.track-hbd .r-fanmade { border-color: rgba(42, 42, 24, 0.25); color: rgba(42, 42, 24, 0.55); }

/* Beautiful — MAGNOLIA 목련 · misty early spring, blush fog */
.r-card.track-beautiful {
  background:
    radial-gradient(circle at 40% 25%, rgba(240,210,220,.5), transparent 45%),
    linear-gradient(180deg, #EDE4EA 0%, #F0E4E8 40%, #F8F0F2 65%, #FFFFFF 100%);
  box-shadow: 8px 8px 0 #8A6878;
  color: #2A2028;
}
.r-card.track-beautiful.is-capturing {
  background: linear-gradient(180deg, #EDE4EA 0%, #F0E4E8 40%, #F8F0F2 65%, #FFFFFF 100%);
}
.r-card.track-beautiful .r-track-title { color: #7A5A6A; text-shadow: 2px 2px 0 #E0D0D8, 3px 3px 0 #2A2028; }
.r-card.track-beautiful .r-kicker { color: #8A6878; }
.r-card.track-beautiful .r-id,
.r-card.track-beautiful .r-claim-prefix,
.r-card.track-beautiful .r-block-label { color: rgba(42, 32, 40, 0.55); }
.r-card.track-beautiful .r-pill { border-color: #8A6878; box-shadow: 2px 2px 0 #8A6878; }
.r-card.track-beautiful .r-compat-label-major { color: #7A5A6A; }
.r-card.track-beautiful .r-ingredient-pct { color: #8A6878; }
.r-card.track-beautiful .r-strength-line::before { color: #8A6878; }
.r-card.track-beautiful .r-stat-bar { color: #8A6878; }
.r-card.track-beautiful .r-compat-track { background: #8A6878; color: #FFFFFF; border-color: #2A2028; box-shadow: 1.5px 1.5px 0 #2A2028; }
.r-card.track-beautiful .r-fanmade { border-color: rgba(42, 32, 40, 0.25); color: rgba(42, 32, 40, 0.55); }

/* ============================================================
   Per-track --accent overrides
   Drives .r-stamp bg, .r-you color, .r-secondary-line b color,
   .r-cta-primary bg, and .r-retake:hover. Mirrored onto .rframe
   from JS so the token cascades to .r-actions (sibling of .r-card).
   mode-sienna / mode-neon already override these hooks directly,
   so the --accent value there is effectively unused — but we still
   set it for cohesion with future hooks.
   ============================================================ */
.rframe.track-good-day  { --accent: #7BA68A; --accent-deep: #3A7A52; }
.rframe.track-east-coast{ --accent: #5A7AAA; --accent-deep: #2C4576; }
.rframe.track-haerise   { --accent: #A88020; --accent-deep: #7A5A10; }
.rframe.track-race      { --accent: #A04068; --accent-deep: #8A2850; }
.rframe.track-help      { --accent: #5B9BD5; --accent-deep: #2C6FA8; }
.rframe.track-rocket    { --accent: #6A4CE0; --accent-deep: #4A2AA0; }
.rframe.track-goodbye   { --accent: #C44040; --accent-deep: #8A2828; }
.rframe.track-too-late  { --accent: #8A7EB8; --accent-deep: #5A4E8A; }
.rframe.track-flower    { --accent: #5E3D8A; --accent-deep: #3E2860; }
.rframe.track-hbd       { --accent: #C8941A; --accent-deep: #8A6410; }
.rframe.track-beautiful { --accent: #8A6878; --accent-deep: #5A3D4A; }

/* ============================================================
   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; }
  .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(0.9rem, 4vw, 1.2rem); letter-spacing: -0.02em; }
  .n-prompt { font-size: 1.4rem; }
}
