/* ==========================================================================
   NAVI × Cologne Warm-up Activation — page styles
   Consumes Limitless tokens (tokens.css). No hardcoded hex in here.
   ========================================================================== */

/* --- Limitless title font: MD Nichrome (weights match production app) ---- */
@font-face {
  font-family: 'MD Nichrome';
  src: url('../assets/fonts/MDNichrome-Regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'MD Nichrome';
  src: url('../assets/fonts/MDNichrome-Dark.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'MD Nichrome';
  src: url('../assets/fonts/MDNichrome-Bold.woff2') format('woff2');
  font-weight: 700; font-style: normal; font-display: swap;
}

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-paragraph);
  line-height: var(--lh-paragraph);
  color: var(--text-primary);
  background: var(--bg-app);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }
a { color: inherit; }

/* Layout container -------------------------------------------------------- */
.ls-container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-gutter);
}
@media (max-width: 720px) {
  .ls-container { padding: 0 20px; }
}

/* Buttons (global press, per Emil skill) ---------------------------------- */
button { font-family: inherit; cursor: pointer; }
button:active { transform: scale(0.97); transition: transform 160ms var(--ease-out); }
button:disabled { cursor: not-allowed; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 48px; padding: 0 28px;
  font-size: var(--fs-ui); font-weight: var(--fw-bold);
  border: none; border-radius: var(--radius-btn);
  box-shadow: var(--shadow-button);
  transition: transform 160ms var(--ease-out), filter 160ms var(--ease-out), opacity 160ms var(--ease-out);
}
.btn--neon { background: var(--color-neon-500); color: var(--text-on-neon); }
.btn--navi { background: var(--navi-yellow); color: var(--navi-black); }
.btn--block { width: 100%; }
.btn--lg { height: 56px; font-size: 16px; padding: 0 36px; }
.btn:disabled { background: var(--bg-button); color: var(--text-tertiary); box-shadow: none; }
@media (hover: hover) and (pointer: fine) {
  .btn--neon:not(:disabled):hover,
  .btn--navi:not(:disabled):hover { filter: brightness(1.05); }
}

/* ====================  TOP BAR  ========================================== */
.topbar {
  position: sticky; top: 0; z-index: 40;
  background: var(--navi-black);
  border-bottom: 1px solid var(--navi-panel-line);
}
.topbar__inner { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.lockup { display: flex; align-items: center; gap: 14px; }
.lockup__limitless { display: inline-flex; align-items: center; gap: 9px; text-decoration: none; color: var(--color-gray-50); }
.lockup__mark { width: 26px; height: 26px; flex: none; color: var(--color-gray-50); }
.lockup__wordmark { font-family: var(--font-title); font-weight: var(--fw-bold); font-size: 18px; color: var(--color-gray-50); letter-spacing: 0.5px; }
.lockup__x { color: var(--color-gray-600); font-size: 14px; }
.lockup__navi { height: 26px; width: auto; display: block; }
.topbar__cta { display: flex; align-items: center; gap: 10px; }
.topbar__deadline { color: var(--color-gray-600); font-size: var(--fs-caption); }
@media (max-width: 720px) {
  .topbar__deadline { display: none; }
  .topbar__cta .btn { height: 40px; padding: 0 16px; }
  .lockup__wordmark { font-size: 16px; }
  .lockup__mark { width: 22px; height: 22px; }
  .lockup__navi { height: 22px; }
}

/* ====================  HERO (Screen 1 top)  ============================= */
.hero {
  position: relative; overflow: hidden;
  background: var(--navi-black);
  color: var(--color-gray-50);
  padding: 64px 0 0;
}
.hero::before { /* yellow glow */
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(120% 80% at 80% -10%, rgba(255,229,0,0.18), transparent 55%);
  pointer-events: none;
}
.hero__inner { position: relative; display: block; }
.hero__copy { padding-bottom: 0; max-width: 680px; }
.hero__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: var(--fs-caption); font-weight: var(--fw-bold); letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--navi-yellow); margin-bottom: 20px;
}
.hero__eyebrow .dot { width: 7px; height: 7px; border-radius: var(--radius-pill); background: var(--color-live); }
.hero h1 {
  font-family: var(--font-title); font-weight: var(--fw-bold);
  font-size: clamp(30px, 7vw, 64px); line-height: 1.04; margin: 0 0 16px;
  overflow-wrap: break-word;
}
.hero h1 .accent { color: var(--navi-yellow); }
.hero__sub { font-size: clamp(15px, 2vw, 19px); line-height: 1.5; color: var(--color-gray-500); max-width: 30ch; margin: 0; }
.hero__players { position: relative; display: flex; justify-content: center; align-items: flex-end; margin-top: 8px; }
.hero__players img {
  width: 22%; align-self: flex-end; object-fit: contain;
  filter: drop-shadow(0 18px 42px rgba(0,0,0,0.7));
  margin-left: -2.5%;
}
.hero__players img:first-child { margin-left: 0; }
@media (max-width: 880px) {
  .hero { padding-top: 40px; }
  .hero__inner { gap: 0; }
  .hero__copy { padding-bottom: 0; max-width: none; }
  .hero__players { margin-top: 8px; max-width: 100%; }
  .hero__players img { width: 23%; }
}
@media (max-width: 560px) {
  .hero h1 { font-size: 30px; line-height: 1.08; }
  .hero__players img { width: 23%; }
}

/* ====================  RULES (big & noticeable per brief)  ============== */
.rules {
  position: relative; z-index: 2;
  margin: -28px auto 0; /* lift over hero seam */
  background: var(--navi-yellow);
  border-radius: var(--radius-card);
  color: var(--navi-black);
  padding: 28px 32px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.18);
}
.rules__head { display: flex; align-items: baseline; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.rules__title { font-family: var(--font-title); font-weight: var(--fw-bold); font-size: clamp(24px, 4vw, 34px); margin: 0; letter-spacing: 0.5px; }
.rules__deadline {
  font-weight: var(--fw-bold); font-size: var(--fs-ui);
  background: var(--navi-black); color: var(--navi-yellow);
  padding: 6px 12px; border-radius: var(--radius-pill);
}
.rules__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.rule {
  display: flex; gap: 14px; align-items: flex-start;
  background: rgba(0,0,0,0.06); border-radius: var(--radius-btn); padding: 16px;
}
.rule__num {
  flex: none; width: 34px; height: 34px; border-radius: var(--radius-pill);
  background: var(--navi-black); color: var(--navi-yellow);
  display: grid; place-items: center; font-family: var(--font-title); font-weight: var(--fw-bold); font-size: 16px;
}
.rule__txt { font-size: 15px; line-height: 1.4; font-weight: var(--fw-medium); }
.rules__more {
  margin-top: 16px; border-top: 1px solid rgba(0,0,0,0.15); padding-top: 8px;
}
.rules__more summary {
  list-style: none; cursor: pointer; font-weight: var(--fw-bold); font-size: var(--fs-ui);
  display: flex; align-items: center; gap: 8px; padding: 8px 0;
}
.rules__more summary::-webkit-details-marker { display: none; }
.rules__more summary .chev { transition: transform 200ms var(--ease-out); }
.rules__more[open] summary .chev { transform: rotate(90deg); }
.rules__more ol { margin: 4px 0 6px; padding-left: 20px; }
.rules__more li { font-size: 14px; line-height: 1.55; margin-bottom: 8px; }
@media (max-width: 720px) { .rules__grid { grid-template-columns: 1fr; } }

/* ====================  SECTION SCAFFOLD  ================================ */
.section { padding: 56px 0; }
.section__kicker { font-size: var(--fs-caption); font-weight: var(--fw-bold); letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-tertiary); margin: 0 0 6px; }
.section__title { font-family: var(--font-title); font-weight: var(--fw-bold); font-size: var(--fs-h2); margin: 0 0 6px; }
.section__sub { color: var(--text-secondary); margin: 0; }
.section__head { margin-bottom: 28px; }

/* Prize teaser — incentive line shown before the quiz questions */
.prize-teaser {
  display: flex; gap: 14px; align-items: center; flex-wrap: wrap;
  background: var(--color-gray-100); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-card); padding: 16px 18px; margin-bottom: 24px;
}
.prize-teaser__chip {
  flex: none; font-family: var(--font-title); font-weight: var(--fw-bold);
  font-size: var(--fs-caption); letter-spacing: 1px;
  background: var(--navi-yellow); color: var(--navi-black);
  padding: 6px 12px; border-radius: var(--radius-pill);
}
.prize-teaser__text { margin: 0; font-size: var(--fs-paragraph); color: var(--text-secondary); }
.prize-teaser__text strong { color: var(--text-primary); }

/* ====================  PRIZE POOL (Screen 2)  ========================== */
.prizes { background: var(--navi-black); color: var(--color-gray-50); }
.prizes .section__kicker { color: var(--navi-yellow); }
.prizes .section__title { color: var(--color-gray-50); }
.prizes .section__sub { color: var(--color-gray-500); }
.tier-block { margin-bottom: 36px; }
.tier-block:last-child { margin-bottom: 0; }
.tier-block__head { display: flex; align-items: baseline; gap: 12px; margin-bottom: 16px; }
.tier-block__rank {
  font-family: var(--font-title); font-weight: var(--fw-bold); font-size: var(--fs-caption);
  letter-spacing: 1px; color: var(--navi-black); background: var(--navi-yellow);
  padding: 4px 10px; border-radius: var(--radius-pill);
}
.tier-block__what { font-family: var(--font-title); font-size: var(--fs-h3); font-weight: var(--fw-bold); margin: 0; letter-spacing: 0.5px; }

.prize-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.prize-card {
  margin: 0; background: var(--navi-panel); border: 1px solid var(--navi-panel-line);
  border-radius: var(--radius-card); overflow: hidden;
  transition: transform 200ms var(--ease-out), border-color 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .prize-card:hover { transform: translateY(-3px); border-color: var(--navi-yellow); }
}
.prize-card img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; }
.prize-card figcaption { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 2px; }
.prize-card__name { font-family: var(--font-title); font-size: 16px; font-weight: var(--fw-bold); color: var(--color-gray-50); }
.prize-card__wear { font-size: var(--fs-caption); color: var(--color-gray-600); }

.credit-banner {
  display: flex; align-items: center; gap: 16px;
  background: var(--navi-panel); border: 1px solid var(--navi-panel-line);
  border-radius: var(--radius-card); padding: 22px 26px;
}
.credit-banner__amount { font-family: var(--font-title); font-weight: var(--fw-bold); font-size: 40px; color: var(--navi-yellow); line-height: 1; }
.credit-banner__label { font-size: var(--fs-paragraph); color: var(--color-gray-500); }

.prizes__note { margin-top: 18px; font-size: var(--fs-caption); color: var(--color-gray-600); }
.prizes__note a { color: var(--navi-yellow); }
@media (max-width: 720px) { .prize-grid { grid-template-columns: 1fr; } }

/* ====================  QUIZ  =========================================== */
.quiz__progress {
  position: sticky; top: 64px; z-index: 30;
  background: var(--bg-app); padding: 14px 0; border-bottom: 1px solid var(--border-subtle);
}
.quiz__progress .ls-container { display: flex; align-items: center; gap: 16px; }
.progress__bar { flex: 1; height: 8px; background: var(--bg-muted); border-radius: var(--radius-pill); overflow: hidden; }
.progress__fill { height: 100%; width: 0%; background: var(--color-neon-500); border-radius: var(--radius-pill); transition: width 280ms var(--ease-out); }
.progress__label { font-size: var(--fs-caption); font-weight: var(--fw-bold); color: var(--text-secondary); white-space: nowrap; }

.q-list { display: grid; gap: 16px; }
.q-card {
  background: var(--bg-surface); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-card); box-shadow: var(--shadow-card);
  padding: 20px 22px; display: flex; align-items: center; gap: 20px;
}
.q-card.answered { border-color: var(--color-gray-500); }
.q-card__num { flex: none; }
.q-card__main { flex: 1; min-width: 0; }
.yn { flex: none; }
.q-index { font-size: var(--fs-caption); font-weight: var(--fw-bold); color: var(--text-tertiary); letter-spacing: 1px; }
.q-text { font-size: 17px; font-weight: var(--fw-medium); line-height: 1.35; margin: 4px 0 8px; }
.q-evidence { display: inline-flex; align-items: center; gap: 6px; font-size: var(--fs-caption); font-weight: var(--fw-bold); color: var(--text-secondary); text-decoration: none; }
.q-evidence:hover { color: var(--text-primary); }
.yn { display: inline-flex; gap: 8px; }
.yn__btn {
  height: 44px; min-width: 80px; padding: 0 20px; border-radius: var(--radius-btn);
  font-weight: var(--fw-bold); font-size: var(--fs-ui);
  background: var(--bg-muted); color: var(--text-secondary); border: 2px solid transparent;
  transition: transform 160ms var(--ease-out), background-color 160ms var(--ease-out), color 160ms var(--ease-out), border-color 160ms var(--ease-out);
}
.yn__btn[aria-pressed="true"][data-val="YES"] { background: var(--color-yes); color: var(--color-gray-50); }
.yn__btn[aria-pressed="true"][data-val="NO"]  { background: var(--color-no);  color: var(--color-gray-50); }
@media (hover: hover) and (pointer: fine) {
  .yn__btn:hover { color: var(--text-primary); }
  .yn__btn[aria-pressed="true"]:hover { color: var(--color-gray-50); }
}
@media (max-width: 640px) {
  .q-card { flex-wrap: wrap; gap: 12px; }
  .q-card__main { flex: 1 1 100%; order: 1; }
  .q-card__num { order: 0; }
  .yn { order: 2; width: 100%; }
  .yn__btn { flex: 1; }
}

.quiz__submit { margin-top: 32px; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.quiz__submit .hint { font-size: var(--fs-caption); color: var(--text-tertiary); }

/* ====================  MODAL  ========================================== */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 20px;
  background: rgba(0,0,0,0.55);
  opacity: 0; visibility: hidden; transition: opacity 280ms var(--ease-out), visibility 280ms var(--ease-out);
}
.modal-backdrop.open { opacity: 1; visibility: visible; }
.modal {
  width: 100%; max-width: 460px; background: var(--bg-surface); border-radius: var(--radius-card);
  overflow: hidden; box-shadow: 0 24px 60px rgba(0,0,0,0.35);
  transform: scale(0.95); opacity: 0; transition: transform 280ms var(--ease-out), opacity 280ms var(--ease-out);
}
.modal-backdrop.open .modal { transform: scale(1); opacity: 1; }
.modal__hero { background: var(--navi-black); color: var(--color-gray-50); padding: 28px 28px 24px; text-align: center; position: relative; }
.modal__score {
  font-family: var(--font-title); font-weight: var(--fw-bold); font-size: 40px; color: var(--navi-yellow); line-height: 1;
}
.modal__score small { font-size: 18px; color: var(--color-gray-600); }
.modal__rate { font-size: var(--fs-caption); color: var(--color-gray-500); margin-top: 6px; letter-spacing: 0.5px; }
.modal__h1 { font-family: var(--font-title); font-weight: var(--fw-bold); font-size: 22px; line-height: 1.15; margin: 14px 0 8px; }
.modal__text { font-size: var(--fs-paragraph); color: var(--color-gray-500); margin: 0; }
.modal__body { padding: 24px 28px 28px; }
.field { margin-bottom: 16px; }
.field label { display: block; font-size: var(--fs-ui); font-weight: var(--fw-bold); margin-bottom: 6px; }
.field input {
  width: 100%; height: 48px; padding: 0 14px; font-family: inherit; font-size: var(--fs-paragraph);
  border: 1px solid var(--border-subtle); border-radius: var(--radius-btn); background: var(--color-gray-100);
  transition: border-color 160ms var(--ease-out);
}
.field input:focus { outline: none; border-color: var(--color-gray-800); }
.field input.invalid { border-color: var(--color-no); }
.field .help { font-size: var(--fs-caption); color: var(--text-tertiary); margin-top: 6px; }
.field .help.error, #emailError { color: var(--color-no); }
.field--optional label::after { content: " (optional)"; font-weight: var(--fw-regular); color: var(--text-tertiary); }
.modal__highlight {
  display: flex; gap: 10px; align-items: flex-start;
  background: var(--navi-yellow); color: var(--navi-black);
  border-radius: var(--radius-btn); padding: 12px 14px; margin-bottom: 18px;
  font-size: 13px; font-weight: var(--fw-bold); line-height: 1.4;
}
.modal__highlight .ico { flex: none; }
.modal__close {
  position: absolute; top: 14px; right: 14px; width: 32px; height: 32px; border-radius: var(--radius-pill);
  background: rgba(255,255,255,0.08); color: var(--color-gray-50); border: none; font-size: 16px; line-height: 1;
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}

/* ====================  FOOTER  ========================================= */
.footer { background: var(--navi-black); color: var(--color-gray-600); padding: 28px 0; font-size: var(--fs-caption); }
.footer .ls-container { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.footer a { color: var(--color-gray-500); }
