/* ── Start-scherm + level-select (#99 Routekaart-refresh) ────────────
   Visuele herziening naar handoff-stijl: paper-bg, ink-borders, harde
   drop-shadows, chunky radii. Consumeert tokens uit css/tokens.css.
   Scope: alléén Home/level-select. Mode-select ondergaat geen refresh
   tot #101 (Quiz-refresh) zodat de overgang visueel consistent blijft
   zolang die schermen nog de oude donkerblauwe stijl hebben. */

/* #start-screen is een transparante wrapper — de card-styling zit op de
   actieve kind-sectie (#level-select óf #mode-select) zodat elk scherm
   onafhankelijk hergestyled kan worden (refresh van mode-select volgt in #101). */
#start-screen {
  display: none;
  width: 100%;
  color: var(--color-ink);
  font-family: var(--font-body);
}

/* ── Header: sky-gradient met titel ────────────────────────────────── */
.home-header {
  background: linear-gradient(180deg, var(--color-sky) 0%, var(--color-sky-deep) 100%);
  border-bottom: var(--border-thick);
  padding: 18px 20px 16px;
}
.home-title {
  font-family: var(--font-display);
  font-size: var(--fs-30);
  letter-spacing: var(--letter-display);
  color: var(--color-ink);
  line-height: 1.0;
}
@media (min-width: 768px) {
  .home-title { font-size: var(--fs-46); }
}
/* Emoji in titel zit in de weg op smalle schermen — verberg ≤480px. */
@media (max-width: 480px) {
  .home-title-emoji { display: none; }
}
.home-subtitle {
  font-family: var(--font-body);
  font-size: var(--fs-11);
  color: var(--color-ink-soft);
  margin-top: 4px;
  line-height: 1.3;
}

/* ── Body: intro, group-select, sets-lijst ─────────────────────────── */
#level-select {
  background: var(--color-paper);
  border: var(--border-hero);
  border-radius: var(--radius-14);
  box-shadow: var(--shadow-lg);
  overflow: hidden;           /* header-gradient mag niet uit de chunky rand lopen */
  text-align: center;
}
/* .home-body bevat alle niet-header-content met nette horizontale padding.
   Voorkomt het margin+width:100%-overflow-patroon dat ontstond met children
   die zichzelf 100% breed maken. */
.home-body {
  padding: 14px 18px 18px;
}
#level-select h2.home-title {
  /* Reset default h2-size/-weight (browser-defaults), de .home-title-regels
     hieronder bepalen de look. Specificiteit hoger dan #level-select h2. */
  margin: 0;
  font-weight: 400;
}
.home-intro {
  margin: 12px 0 14px;
  font-size: var(--fs-14);
  color: var(--color-ink-soft);
  line-height: 1.4;
}

/* ── Group-select: chunky knoppen ──────────────────────────────────── */
.group-hint {
  font-family: var(--font-display);
  font-size: var(--fs-12);
  color: var(--color-ink);
  letter-spacing: var(--letter-display);
  margin: 4px 0 8px;
  text-transform: uppercase;
}
.group-select {
  display: flex;
  gap: 8px;
  margin: 6px 0 18px;
}
.group-btn {
  flex: 1;
  padding: 10px 4px;
  background: var(--color-paper);
  border: var(--border-thick);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-sm);
  color: var(--color-ink);
  font-family: var(--font-display);
  font-size: var(--fs-14);
  letter-spacing: var(--letter-display);
  cursor: pointer;
  transition: transform 0.08s, box-shadow 0.08s;
}
@media (hover: hover) {
  .group-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 0 var(--color-ink);
  }
}
.group-btn:active {
  transform: translateY(2px);
  box-shadow: 0 0 0 var(--color-ink);
}
.group-btn.active {
  background: var(--color-red);
  color: var(--color-paper);
  text-shadow: 1px 1px 0 var(--color-red-dark);
}
/* Prominente call-to-action als er nog geen groep gekozen is */
.group-select.no-selection .group-btn {
  padding: 14px 4px;
  font-size: var(--fs-16);
  animation: pulse-group 1.8s ease-in-out infinite;
}
.group-select.no-selection .group-btn:nth-child(2) { animation-delay: 0.15s; }
.group-select.no-selection .group-btn:nth-child(3) { animation-delay: 0.30s; }
.group-select.no-selection .group-btn:nth-child(4) { animation-delay: 0.45s; }
@keyframes pulse-group {
  0%, 100% { box-shadow: var(--shadow-sm); }
  50%       { box-shadow: 0 2px 0 var(--color-ink), 0 0 0 4px var(--color-yellow); }
}

/* ── Set-buttons (route-node stijl, platte lijst) ──────────────────── */
/* Alleen binnen #level-select — mode-select-knoppen behouden nog de
   oude stijl tot #101 hun eigen refresh krijgt. */
#level-select .mode-btn {
  display: block;
  width: 100%;
  padding: 14px 16px;
  margin-bottom: 10px;
  background: var(--color-paper);
  color: var(--color-ink);
  border: var(--border-hero);
  border-radius: var(--radius-12);
  box-shadow: var(--shadow);
  font-family: var(--font-display);
  font-size: var(--fs-16);
  letter-spacing: var(--letter-display);
  cursor: pointer;
  text-align: left;
  transition: transform 0.08s, box-shadow 0.08s;
}
@media (hover: hover) {
  #level-select .mode-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 5px 0 var(--color-ink);
  }
}
#level-select .mode-btn:active {
  transform: translateY(3px);
  box-shadow: 0 1px 0 var(--color-ink);
}
/* Daily: grass-accent */
#level-select .mode-btn.daily-btn {
  background: var(--color-grass);
  color: var(--color-paper);
  text-shadow: 1px 1px 0 var(--color-grass-dark);
}
#level-select .mode-btn.daily-btn.done { opacity: 0.55; cursor: default; }
#level-select .mode-btn.daily-btn .daily-sub {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-12);
  font-weight: 500;
  margin-top: 3px;
  text-shadow: none;
  opacity: 0.92;
}
/* Bonus: yellow-accent */
#level-select .mode-btn.bonus-btn {
  background: var(--color-yellow);
  color: var(--color-ink);
  text-shadow: none;
}

/* BETA-label */
.beta-label {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--fs-10);
  font-weight: 700;
  letter-spacing: var(--letter-mono-caps);
  background: var(--color-badge-fire);
  color: var(--color-paper);
  padding: 2px 6px;
  border-radius: var(--radius-6);
  margin-left: 8px;
  vertical-align: middle;
}

/* mode-desc: kleine omschrijving ónder de mode-knop (alléén mode-select) */
.mode-btn .mode-desc {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-12);
  font-weight: 500;
  color: var(--color-ink-soft);
  margin-top: 4px;
  line-height: 1.35;
  letter-spacing: 0;
}

/* Daily-share & emoji-grid (na afronden dagelijkse uitdaging) */
.daily-emoji {
  font-size: var(--fs-22);
  letter-spacing: 3px;
  margin: 14px 0 4px;
  color: var(--color-ink);
}
#daily-share-wrap { margin: 16px 0; }
#share-btn {
  padding: 11px 24px;
  background: var(--color-grass);
  border: var(--border-thick);
  border-radius: var(--radius-10);
  box-shadow: var(--shadow-sm);
  color: var(--color-paper);
  font-family: var(--font-display);
  font-size: var(--fs-14);
  letter-spacing: var(--letter-display);
  cursor: pointer;
  text-shadow: 1px 1px 0 var(--color-grass-dark);
}
@media (hover: hover) {
  #share-btn:hover { background: var(--color-grass-dark); }
}

/* ── Mode-select (#114 Routekaart-refresh) ──────────────────────────
   Paper-card met Luckiest Guy titel + chunky route-node mode-knoppen,
   consistent met Home (#99) en Quiz (#101). */
#mode-select {
  background: var(--color-paper);
  border: var(--border-hero);
  border-radius: var(--radius-14);
  box-shadow: var(--shadow-lg);
  padding: 20px 18px 16px;
  color: var(--color-ink);
  text-align: center;
}
#mode-select h2 {
  font-family: var(--font-display);
  font-size: var(--fs-22);
  letter-spacing: var(--letter-display);
  color: var(--color-ink);
  font-weight: 400;
  margin-bottom: 4px;
  line-height: 1.1;
}
@media (min-width: 768px) {
  #mode-select h2 { font-size: var(--fs-30); }
}
#mode-select p {
  font-family: var(--font-body);
  font-size: var(--fs-14);
  color: var(--color-ink-soft);
  margin-bottom: 16px;
}
#mode-select .mode-btn {
  display: block;
  width: 100%;
  padding: 14px 16px;
  margin-bottom: 10px;
  background: var(--color-paper);
  color: var(--color-ink);
  border: var(--border-hero);
  border-radius: var(--radius-12);
  box-shadow: var(--shadow-sm);
  font-family: var(--font-display);
  font-size: var(--fs-16);
  letter-spacing: var(--letter-display);
  font-weight: 400;
  cursor: pointer;
  text-align: left;
  transition: transform 0.08s, box-shadow 0.08s;
}
@media (hover: hover) {
  #mode-select .mode-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 0 var(--color-ink);
  }
}
#mode-select .mode-btn:active {
  transform: translateY(2px);
  box-shadow: 0 1px 0 var(--color-ink);
}

/* ── Terug-knop + hamburger-menu + install ─────────────────────────── */
#back-btn {
  margin-top: 8px;
  background: none;
  border: none;
  color: var(--color-ink-soft);
  font-family: var(--font-body);
  font-size: var(--fs-12);
  font-weight: 600;
  cursor: pointer;
  text-decoration: underline;
}
@media (hover: hover) { #back-btn:hover { color: var(--color-ink); } }
/* ── Hamburger-menu (#113 + #115 Routekaart-refresh) ─────────────────
   Chunky ink-button met paper-bg + hard offset-shadow, matchend met de
   mode-buttons en opt-buttons. Dropdown is een mini paper-card. */
#menu-btn {
  background: var(--color-paper);
  border: var(--border-thin);
  color: var(--color-ink);
  font-size: var(--fs-18);
  font-weight: 700;
  cursor: pointer;
  padding: 4px 10px;
  line-height: 1;
  border-radius: var(--radius-6);
  box-shadow: var(--shadow-sm);
  position: relative;
  transition: transform 0.08s, box-shadow 0.08s;
}
@media (hover: hover) {
  #menu-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 0 var(--color-ink);
  }
}
#menu-btn:active {
  transform: translateY(1px);
  box-shadow: 0 1px 0 var(--color-ink);
}
#quiz-menu {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  background: var(--color-paper);
  border: var(--border-hero);
  border-radius: var(--radius-10);
  padding: 6px;
  z-index: 900;
  min-width: 220px;
  box-shadow: var(--shadow);
}
#quiz-menu.open { display: block; }
#quiz-menu button {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  background: transparent;
  border: none;
  color: var(--color-ink);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-14);
  padding: 10px 12px;
  cursor: pointer;
  text-align: left;
  border-radius: var(--radius-6);
  transition: background 0.12s;
}
@media (hover: hover) {
  #quiz-menu button:hover {
    background: var(--color-sky);
  }
}

/* Install-btn (#111): chunky Routekaart-stijl, consistent met .mode-btn
   maar secundair (font-body ipv display, fs-14 ipv fs-16). */
#install-btn {
  display: none;
  background: var(--color-paper);
  border: var(--border-hero);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-14);
  border-radius: var(--radius-12);
  padding: 12px 18px;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  margin: 14px auto 0;
  transition: transform 0.08s, box-shadow 0.08s;
}
@media (hover: hover) {
  #install-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 0 var(--color-ink);
  }
}
#install-btn:active {
  transform: translateY(2px);
  box-shadow: 0 1px 0 var(--color-ink);
}
#install-tooltip {
  display: none;
  background: var(--color-paper);
  border: var(--border-hero);
  border-radius: var(--radius-12);
  box-shadow: var(--shadow-sm);
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: var(--fs-12);
  color: var(--color-ink);
  line-height: 1.5;
  margin: 10px auto 0;
  max-width: 320px;
  text-align: left;
}

/* Level-divider: verticale scheider (legacy, nog in DOM, nu onzichtbaar) */
.level-divider { display: none; }
