/* ============================================================================
   THE MICHAELA QUIZ — Editorial edition
   Condé Nast / Vogue: Didone masthead, hairline rules, contents-page layouts,
   couture red used once per screen, restraint everywhere.
   ============================================================================ */

:root {
  --paper:      #f7f5f0;   /* warm white */
  --paper-deep: #efece4;
  --ink:        #17140f;   /* warm near-black */
  --ink-soft:   #463f37;   /* secondary reading text — darkened for contrast */
  --ink-faint:  #6b6153;   /* small labels — darkened to pass AA on warm white */
  --line:       rgba(23,20,15,.22);
  --line-strong:rgba(23,20,15,.72);
  --accent:     #a71126;   /* couture red — kickers, scores, reveals */
  --gold:       #a98a4e;
  --select:     #7b2d3a;   /* softer bordeaux — the selected answer */

  --display: "Bodoni Moda", "Didot", "Times New Roman", serif;
  --label:   "Jost", "Century Gothic", "Futura", sans-serif;

  --page-max: 40rem;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  min-height: 100dvh;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--display);
  font-optical-sizing: auto;
  -webkit-font-smoothing: antialiased;
  padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  position: relative;
  overflow-x: hidden;
}
/* faint letterpress paper tone */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(140% 120% at 50% 0%, rgba(255,255,255,.5), transparent 60%),
    linear-gradient(180deg, transparent, rgba(23,20,15,.03));
}

#app {
  position: relative; z-index: 1;
  width: 100%; max-width: var(--page-max);
  margin: 0 auto;
  padding: clamp(1.1rem, 3.5vw, 2rem) clamp(1.25rem, 6vw, 3rem) 3rem;
  min-height: 100dvh;
  display: flex; flex-direction: column;
}

/* ---------------------------------------------------------------- chrome */
.runhead {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 1rem;
  font-family: var(--label);
  font-size: .66rem; font-weight: 500;
  letter-spacing: .34em; text-transform: uppercase;
  color: var(--ink-soft);
  padding-bottom: .55rem;
}
.runhead .rh-title { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.runhead .folio { letter-spacing: .22em; color: var(--ink-faint); flex: 0 0 auto; }

.rule { height: 1px; background: var(--line-strong); transform-origin: left center; }
.rule.hair { background: var(--line); }
.rule.short { width: 3.2rem; height: 2px; background: var(--accent); }
.rule.center { margin-inline: auto; }
.draw { animation: draw .7s cubic-bezier(.16,1,.3,1) both; }
@keyframes draw { from { transform: scaleX(0); } to { transform: scaleX(1); } }

.progressline { height: 1px; background: var(--line); position: relative; margin-top: .55rem; }
.progressline::after {
  content: ""; position: absolute; left: 0; top: 0; height: 1px; background: var(--accent);
  width: var(--p, 0%); transition: width .5s cubic-bezier(.16,1,.3,1);
}

.kicker {
  font-family: var(--label);
  font-size: .74rem; font-weight: 500;
  letter-spacing: .32em; text-transform: uppercase;
  color: var(--accent);
  margin: 0;
}
.kicker.ink { color: var(--ink-soft); }

.standfirst {
  font-family: var(--display);
  font-style: italic; font-weight: 500;
  font-size: clamp(1.14rem, 3.9vw, 1.45rem);
  line-height: 1.5; color: var(--ink);
  margin: 0;
}
.standfirst em { font-style: normal; }   /* flip: emphasis becomes upright inside italic */

.display {
  font-family: var(--display);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -.005em;
  margin: 0;
}

/* screen entrance */
.screen { animation: fade-up .55s cubic-bezier(.16,1,.3,1) both; }
@keyframes fade-up { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

.grow { flex: 1 0 auto; }

/* ---------------------------------------------------------------- buttons */
.btn {
  font-family: var(--label);
  font-size: .82rem; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--paper); background: var(--ink);
  border: 1px solid var(--ink);
  padding: 1.05rem 1.6rem;
  cursor: pointer;
  transition: background .25s ease, color .25s ease, letter-spacing .25s ease;
  -webkit-tap-highlight-color: transparent;
}
.btn:hover { letter-spacing: .28em; }
.btn:active { background: var(--ink-soft); }
.btn.block { display: block; width: 100%; }
.btn.ghost { background: transparent; color: var(--ink); }
.btn.ghost:hover { background: var(--ink); color: var(--paper); }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }
.btn[disabled] { opacity: .4; cursor: not-allowed; }

.textlink {
  font-family: var(--label);
  font-size: .72rem; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--ink-soft);
  background: none; border: none; cursor: pointer;
  padding: .5rem 2px;
  border-bottom: 1px solid var(--line);
  transition: color .2s ease, border-color .2s ease;
}
.textlink:hover { color: var(--accent); border-color: var(--accent); }
.textlink:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }

/* ---------------------------------------------------------------- cover */
.cover { text-align: center; display: flex; flex-direction: column; justify-content: safe center; }
.cover .kicker { margin-bottom: 1.1rem; }
.masthead {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(3.6rem, 21vw, 8rem);
  line-height: .9;
  letter-spacing: .02em;
  text-transform: uppercase;
  margin: 0;
}
.cover .cover-rule { margin: 1.2rem auto; width: min(78%, 22rem); }
.cover .standfirst { max-width: 26rem; margin: 0 auto; }

.namebox { margin: 2.4rem auto 0; max-width: 22rem; width: 100%; text-align: left; }
.namebox label {
  display: block;
  font-family: var(--label);
  font-size: .68rem; font-weight: 500; letter-spacing: .28em; text-transform: uppercase;
  color: var(--ink-soft); margin-bottom: .5rem;
}
.editfield {
  width: 100%;
  font-family: var(--display); font-size: 1.4rem; font-weight: 500;
  color: var(--ink);
  background: transparent; border: none;
  border-bottom: 1.5px solid var(--line-strong);
  padding: .5rem .1rem .55rem;
  outline: none;
  transition: border-color .25s ease;
}
.editfield::placeholder { color: var(--ink-faint); font-style: italic; font-weight: 400; }
.editfield:focus { border-color: var(--accent); }
.namebox .btn { margin-top: 1.6rem; }
.namebox .name-hint {
  font-family: var(--label); font-weight: 500; font-size: .66rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--ink-soft); margin: .9rem 0 0;
}
.cover .hostrow { margin-top: 2rem; }

/* a small couture flourish between the standfirst and the form */
.fleuron { color: var(--gold); font-size: 1.15rem; line-height: 1; text-align: center; margin: 1.6rem 0 0; user-select: none; }

/* winner tag replaces the casual emoji in the editorial podium */
.win-tag {
  font-family: var(--label); font-size: .56rem; font-weight: 500;
  letter-spacing: .24em; text-transform: uppercase; color: var(--accent);
  vertical-align: middle; margin-left: .7rem; white-space: nowrap;
}

/* oldstyle (text) figures on inline numerals — a proper editorial detail */
.folio, .issue-line, .idx-pts, .plate-cap, .podium-row .pscore,
.host .team-row input.score, .review-q .rq-tag { font-variant-numeric: oldstyle-nums; }

/* ---------------------------------------------------------------- round intro */
.round-intro { display: flex; flex-direction: column; justify-content: safe center; text-align: left; }
.round-intro .kicker { margin-bottom: 1rem; }
.round-intro .round-title {
  font-size: clamp(2.6rem, 12vw, 4.6rem);
  margin: 0 0 1.1rem;
}
.round-intro .rule { width: 5rem; margin-bottom: 1.4rem; }
.round-intro .standfirst { max-width: 30rem; }
.round-intro .blurb {
  font-family: var(--display); font-weight: 500; font-size: 1.06rem; line-height: 1.55;
  color: var(--ink); margin: 1rem 0 0; max-width: 30rem;
  clear: left;   /* sit below the drop cap, never wrap around it */
}
.round-intro .btn { margin-top: 2.2rem; align-self: flex-start; }

/* dropcap for standfirsts */
.dropcap::first-letter {
  font-family: var(--display); font-weight: 700; font-style: normal;
  text-transform: uppercase;   /* a capital reads as a proper drop cap, not a stray lowercase letter */
  float: left; font-size: 3.4em; line-height: .74; padding: .05em .12em 0 0;
  color: var(--ink);
}

/* ---------------------------------------------------------------- question */
.qscreen { display: flex; flex-direction: column; justify-content: safe center; }
.qhead .qkicker {
  font-family: var(--label); font-size: .7rem; font-weight: 500;
  letter-spacing: .3em; text-transform: uppercase; color: var(--ink-faint);
  margin: 1.4rem 0 .5rem;
}
.qtext {
  font-size: clamp(1.55rem, 6.2vw, 2.3rem);
  line-height: 1.08;
  margin: 0 0 1.4rem;
}

/* editorial option list — rules, not boxes */
.options { border-top: 1px solid var(--line-strong); margin-top: .5rem; }
.opt {
  position: relative;
  display: flex; align-items: baseline; gap: 1rem;
  width: 100%; text-align: left;
  background: none; border: none;
  border-bottom: 1px solid var(--line);
  padding: 1.05rem 1.6rem 1.05rem .2rem;
  cursor: pointer;
  font-family: var(--display); color: var(--ink);
  transition: padding-left .28s cubic-bezier(.16,1,.3,1), color .2s ease;
  -webkit-tap-highlight-color: transparent;
}
.opt .ol {
  flex: 0 0 1.4rem;
  font-style: italic; font-size: 1.05rem; color: var(--ink-faint);
  transition: color .2s ease;
}
.opt .otext { font-size: 1.18rem; font-weight: 500; line-height: 1.25; }
.opt::before {
  content: ""; position: absolute; left: -1.6rem; top: 0; bottom: 0;
  width: 3px; background: var(--select);
  transform: scaleY(0); transform-origin: center; transition: transform .28s cubic-bezier(.16,1,.3,1);
}
.opt:hover { padding-left: .7rem; }
.opt:hover .ol { color: var(--ink); }
.opt.selected { padding-left: 1.1rem; }
.opt.selected::before { transform: scaleY(1); left: 0; }
.opt.selected .ol { color: var(--select); font-style: normal; font-weight: 600; }
.opt.selected .otext { font-weight: 600; }
.opt:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }

/* review states */
.opt.correct .ol { color: var(--accent); }
.opt.correct .otext { text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 4px; }
.opt.chosen-wrong .otext { text-decoration: line-through; text-decoration-thickness: 1px; color: var(--ink-faint); }
.opt .verdict { margin-left: auto; font-family: var(--label); font-size: .64rem; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); align-self: center; }

/* true / false */
.tf-grid { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line-strong); border-bottom: 1px solid var(--line-strong); }
.tf-btn {
  position: relative;
  font-family: var(--display); font-size: 1.7rem; font-weight: 500;
  color: var(--ink); background: none; border: none;
  padding: 1.5rem 1rem; cursor: pointer;
  transition: letter-spacing .25s ease, color .2s ease;
}
.tf-btn.true { border-right: 1px solid var(--line); }
.tf-btn::after {
  content: ""; position: absolute; left: 50%; right: 50%; bottom: 1.05rem; height: 1.5px;
  background: var(--select); transition: left .28s cubic-bezier(.16,1,.3,1), right .28s cubic-bezier(.16,1,.3,1);
}
.tf-btn.selected { color: var(--select); }
.tf-btn.selected::after { left: 30%; right: 30%; }
.tf-btn.correct::after { left: 30%; right: 30%; background: var(--ink); }
.tf-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: -3px; }

/* numeric */
.numeric-wrap { display: flex; align-items: baseline; gap: .7rem; border-bottom: 1.5px solid var(--line-strong); max-width: 16rem; padding-bottom: .3rem; }
.numeric-wrap input {
  width: 100%; font-family: var(--display); font-size: 2.6rem; font-weight: 500;
  color: var(--ink); background: none; border: none; outline: none; padding: .2rem 0;
}
.numeric-wrap input::placeholder { color: var(--ink-faint); font-style: italic; }
.numeric-wrap .unit { font-style: italic; color: var(--ink-faint); font-size: 1.1rem; white-space: nowrap; }

/* picture / plate */
.plate { margin: .4rem 0 1.3rem; }
.plate .frame {
  border: 1px solid var(--line-strong);
  padding: .55rem;
  background: var(--paper);
}
.plate .photo {
  aspect-ratio: 4 / 5; overflow: hidden; background: var(--paper-deep);
  display: grid; place-items: center;
}
.plate .photo img { width: 100%; height: 100%; object-fit: cover; display: block; animation: expose 1s ease-out both; }
@keyframes expose { from { opacity: 0; filter: contrast(.8) brightness(1.15); } to { opacity: 1; filter: none; } }
.plate .photo .missing {
  font-family: var(--display); font-style: italic; color: var(--ink-faint);
  font-size: 1.05rem; text-align: center; padding: 1.5rem;
}
.plate .plate-cap {
  display: flex; gap: .8rem; align-items: baseline;
  font-family: var(--label); font-size: .64rem; letter-spacing: .24em; text-transform: uppercase;
  color: var(--ink-faint); margin-top: .7rem;
}
.plate .plate-cap .cap-word { font-family: var(--display); font-style: italic; text-transform: none; letter-spacing: 0; font-size: .95rem; color: var(--ink-soft); }

/* two truths & a lie */
.ttl-hint {
  font-family: var(--label); font-size: .7rem; letter-spacing: .28em; text-transform: uppercase;
  color: var(--accent); margin: 0 0 .3rem;
}
.ttl-list { border-top: 1px solid var(--line-strong); }
.ttl-item {
  position: relative; display: flex; gap: 1rem; align-items: baseline;
  width: 100%; text-align: left; background: none; border: none;
  border-bottom: 1px solid var(--line);
  padding: 1.1rem 1.6rem 1.1rem .2rem; cursor: pointer;
  font-family: var(--display); color: var(--ink);
  transition: padding-left .28s cubic-bezier(.16,1,.3,1);
}
.ttl-item .rn { flex: 0 0 1.8rem; font-style: italic; color: var(--ink-faint); font-size: 1rem; }
.ttl-item .stext { font-size: 1.12rem; font-weight: 500; line-height: 1.3; }
.ttl-item::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--select);
  transform: scaleY(0); transition: transform .28s cubic-bezier(.16,1,.3,1);
}
.ttl-item:hover { padding-left: .7rem; }
.ttl-item.selected { padding-left: 1.1rem; }
.ttl-item.selected::before { transform: scaleY(1); }
.ttl-item.selected .rn { color: var(--select); font-style: normal; font-weight: 600; }
.ttl-item.selected .stext { font-weight: 600; }
.ttl-item.correct .stext { text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 4px; }
.ttl-item.chosen-wrong .stext { color: var(--ink-faint); }
.ttl-item .verdict { margin-left: auto; align-self: center; font-family: var(--label); font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); }
.ttl-item:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }

/* nav */
.qnav { display: flex; gap: 1px; margin-top: 2rem; border: 1px solid var(--ink); }
.qnav .btn { border: none; }
.qnav .btn.next { flex: 1; }
.qnav .btn.back { flex: 0 0 auto; background: var(--paper); color: var(--ink); border-right: 1px solid var(--ink); padding-inline: 1.3rem; }
.qnav .btn.back:hover { background: var(--ink); color: var(--paper); }

/* ---------------------------------------------------------------- results */
.results { text-align: center; display: flex; flex-direction: column; justify-content: safe center; }
.results .kicker { margin-bottom: 1.4rem; }
.results .score-num {
  font-family: var(--display); font-weight: 700;
  font-size: clamp(6rem, 34vw, 12rem); line-height: .84;
  letter-spacing: -.02em;
}
.results .score-of {
  font-family: var(--label); font-size: .74rem; letter-spacing: .3em; text-transform: uppercase;
  color: var(--ink-faint); margin-top: .6rem;
}
.results .cover-rule { width: min(60%, 16rem); margin: 1.6rem auto; }
.results .verdict-line { font-style: italic; font-size: clamp(1.2rem, 4.5vw, 1.6rem); color: var(--ink); margin: 0 auto; max-width: 26rem; }

/* contents-page index of round scores */
.index { text-align: left; margin: 2.2rem 0 1.2rem; }
.index .idx-row {
  display: flex; align-items: baseline; gap: .6rem;
  padding: .75rem 0; border-bottom: 1px solid var(--line);
}
.index .idx-row:first-child { border-top: 1px solid var(--line-strong); }
.index .idx-name { font-family: var(--display); font-size: 1.1rem; font-weight: 500; }
.index .idx-leader { flex: 1; border-bottom: 1px dotted var(--line); transform: translateY(-.28rem); }
.index .idx-pts { font-family: var(--display); font-style: italic; font-size: 1.15rem; color: var(--accent); }

.tell-host { font-family: var(--label); font-size: .66rem; letter-spacing: .24em; text-transform: uppercase; color: var(--ink-faint); margin: 1rem auto; }
.results .review-toggle { margin: 1rem 0; }
.results .mini-links { margin-top: 1.8rem; display: flex; gap: 1.4rem; justify-content: center; flex-wrap: wrap; }

.review-list { display: grid; gap: 0; text-align: left; margin-top: 1.2rem; border-top: 1px solid var(--line-strong); }
.review-q { padding: 1rem 0; border-bottom: 1px solid var(--line); }
.review-q .rq-text { font-family: var(--display); font-weight: 600; font-size: 1.08rem; margin-bottom: .5rem; }
.review-q .rq-line { font-family: var(--display); font-size: 1rem; display: flex; gap: .5rem; align-items: baseline; }
.review-q .rq-you { color: var(--ink-soft); }
.review-q .rq-you b { font-weight: 600; }
.review-q .rq-right { color: var(--accent); font-style: italic; }
.review-q .rq-tag { font-family: var(--label); font-size: .6rem; letter-spacing: .18em; text-transform: uppercase; }
.review-q .rq-tag.ok { color: var(--ink); }
.review-q .rq-tag.no { color: var(--accent); }

/* ---------------------------------------------------------------- host */
.host { display: flex; flex-direction: column; justify-content: safe center; }
.host .kicker { margin-bottom: .8rem; }
.host h2.display { font-size: clamp(2.4rem, 11vw, 3.6rem); margin-bottom: 1.4rem; }
.host .team-inputs { border-top: 1px solid var(--line-strong); margin-bottom: 1.6rem; }
.host .team-row {
  display: grid; grid-template-columns: 1fr 4.5rem; gap: 1rem; align-items: center;
  border-bottom: 1px solid var(--line); padding: .7rem 0;
}
.host .team-row input {
  font-family: var(--display); font-size: 1.15rem; color: var(--ink);
  background: none; border: none; outline: none; padding: .4rem 0;
}
.host .team-row input.tname::placeholder { color: var(--ink-faint); font-style: italic; }
.host .team-row input.score { font-weight: 600; text-align: right; font-size: 1.4rem; border-bottom: 1.5px solid var(--line-strong); }

.podium { border-top: 1px solid var(--line-strong); margin-top: 1.6rem; }
.podium-row {
  display: flex; align-items: baseline; gap: 1.1rem;
  padding: 1.1rem 0; border-bottom: 1px solid var(--line);
}
.podium-row .rank { font-family: var(--display); font-style: italic; font-size: 1.2rem; color: var(--ink-faint); flex: 0 0 2.4rem; }
.podium-row .pname { font-family: var(--display); font-weight: 500; font-size: 1.3rem; flex: 1; }
.podium-row .pscore { font-family: var(--display); font-weight: 700; font-size: 1.6rem; }
.podium-row.first { padding: 1.4rem 0; }
.podium-row.first .pname { font-size: clamp(1.8rem, 8vw, 2.6rem); font-weight: 700; }
.podium-row.first .rank { color: var(--accent); font-style: normal; }
.podium-row.first .pscore { color: var(--accent); font-size: 2rem; }

/* only shown on the podium when two teams finish level */
.tiebreak-panel { margin-top: 1.6rem; padding-top: 1.3rem; border-top: 1px solid var(--line-strong); text-align: left; }
.tiebreak-panel .kicker { color: var(--accent); margin-bottom: .7rem; }
.tiebreak-panel .tb-lead { font-family: var(--label); font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-soft); margin: 0 0 .5rem; }
.tiebreak-panel .tb-q { font-family: var(--display); font-weight: 600; font-size: 1.2rem; line-height: 1.25; color: var(--ink); margin: 0 0 .4rem; }
.tiebreak-panel .tb-a { font-family: var(--display); font-style: italic; font-size: 1.05rem; color: var(--accent); margin: 0; }

.mini-links { margin-top: 2rem; text-align: center; }
.mini-links .textlink { border: none; }

/* ---------------------------------------------------------------- confetti (restrained, monochrome + red + gold) */
#confetti-layer { position: fixed; inset: 0; pointer-events: none; z-index: 40; overflow: hidden; }

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
}
