:root {
  --blue-900: #0a2e5c;
  --blue-800: #003d82;
  --blue-700: #0a4a99;
  --blue-600: #1e5fb8;
  --blue-100: #dde7f5;
  --blue-50:  #f3f7fc;
  --red:      #c8001e;
  --ink:      #0e1729;
  --ink-2:    #3b4658;
  --ink-3:    #6b7689;
  --line:     #e3e8f0;
  --bg:       #ffffff;
  --bg-soft:  #f7f9fc;

  --shadow-sm: 0 1px 2px rgba(10,46,92,.06), 0 1px 1px rgba(10,46,92,.04);
  --shadow:    0 8px 24px rgba(10,46,92,.08), 0 2px 4px rgba(10,46,92,.04);
  --shadow-lg: 0 24px 60px rgba(10,46,92,.14), 0 4px 12px rgba(10,46,92,.06);

  --radius:    10px;
  --radius-lg: 16px;

  --container: 1200px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
}

h1, h2, h3, h4 {
  margin: 0 0 .4em;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.02em;
  color: var(--ink);
}

p { margin: 0 0 1em; color: var(--ink-2); }

a { color: var(--blue-700); text-decoration: none; }
a:hover { text-decoration: underline; }

ul, ol { margin: 0; padding: 0; list-style: none; }

/* ---------- Top bar ---------- */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--line);
}
.topbar__inner {
  display: flex;
  align-items: center;
  gap: 32px;
  height: 72px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--ink);
  text-decoration: none;
  font-weight: 700;
}
.brand:hover { text-decoration: none; }
.brand__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 8px;
  background: var(--blue-800);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
}
.brand__name { font-size: 18px; letter-spacing: -.01em; }

.nav { display: flex; gap: 4px; margin-left: auto; }
.nav a {
  padding: 8px 14px;
  font-size: 15px;
  font-weight: 500;
  color: var(--ink-2);
  border-radius: 6px;
  transition: background .15s, color .15s;
}
.nav a:hover { background: var(--blue-50); color: var(--blue-800); text-decoration: none; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 22px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 15px;
  font-family: inherit;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .08s ease, background .15s, border-color .15s, color .15s;
  white-space: nowrap;
}
.btn:hover { text-decoration: none; transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn--sm { padding: 9px 16px; font-size: 14px; }
.btn--lg { padding: 16px 28px; font-size: 16px; }
.btn--primary { background: var(--blue-800); color: #fff; }
.btn--primary:hover { background: var(--blue-700); }
.btn--ghost { background: transparent; color: var(--blue-800); border-color: var(--blue-100); }
.btn--ghost:hover { background: var(--blue-50); border-color: var(--blue-600); }

.nav__toggle {
  display: none;
  background: none;
  border: 0;
  padding: 8px;
  cursor: pointer;
  flex-direction: column;
  gap: 4px;
  margin-left: auto;
}
.nav__toggle span {
  width: 22px; height: 2px;
  background: var(--ink);
  border-radius: 1px;
  transition: transform .2s, opacity .2s;
}

/* ---------- Hero ---------- */
.hero {
  position: relative;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(30,95,184,.12), transparent 60%),
    linear-gradient(180deg, var(--blue-50) 0%, #fff 100%);
  padding: 80px 0 100px;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(90deg, rgba(10,46,92,.04) 1px, transparent 1px),
    linear-gradient(0deg,  rgba(10,46,92,.04) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at top right, #000 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at top right, #000 0%, transparent 70%);
  pointer-events: none;
}
.hero__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 64px;
  align-items: center;
}
.eyebrow {
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--blue-700);
  background: var(--blue-100);
  padding: 6px 12px;
  border-radius: 999px;
  margin-bottom: 24px;
}
.eyebrow--center { display: inline-block; }
.hero__title {
  font-family: 'Source Serif 4', Georgia, serif;
  font-weight: 700;
  font-size: clamp(40px, 5.6vw, 76px);
  line-height: 1.02;
  letter-spacing: -.025em;
  margin-bottom: 24px;
}
.hero__title .accent { color: var(--blue-800); }
.hero__lead {
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 560px;
  margin-bottom: 32px;
}
.hero__cta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 48px; }
.hero__badges {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  border-top: 1px solid var(--line);
  padding-top: 28px;
  max-width: 520px;
}
.hero__badges li { display: flex; flex-direction: column; }
.hero__badges strong {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 30px;
  font-weight: 700;
  color: var(--blue-800);
  letter-spacing: -.02em;
}
.hero__badges span { font-size: 13px; color: var(--ink-3); }

.hero__visual { position: relative; }
.hero__card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  transform: rotate(.5deg);
}
.hero__avatar { aspect-ratio: 4/5; background: #fff; overflow: hidden; }
.hero__avatar img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
}
.hero__avatar svg { display: block; width: 100%; height: 100%; }
.hero__quote { padding: 24px 28px 28px; border-top: 4px solid var(--red); }
.hero__quote p {
  font-family: 'Source Serif 4', Georgia, serif;
  font-style: italic;
  font-size: 19px;
  line-height: 1.4;
  color: var(--ink);
  margin-bottom: 12px;
}
.hero__quote span { font-size: 13px; color: var(--ink-3); font-weight: 500; }

/* ---------- Values ---------- */
.values { padding: 60px 0; background: var(--bg); border-bottom: 1px solid var(--line); }
.values__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.value {
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  transition: border-color .15s, transform .15s, box-shadow .15s;
}
.value:hover { border-color: var(--blue-600); transform: translateY(-2px); box-shadow: var(--shadow); }
.value__icon { font-size: 28px; margin-bottom: 12px; }
.value h3 { font-size: 18px; margin-bottom: 8px; }
.value p { font-size: 14px; margin: 0; color: var(--ink-3); }

/* ---------- Section header ---------- */
.section-header { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.section-header h2 {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: clamp(32px, 4vw, 48px);
  letter-spacing: -.02em;
  margin-bottom: 16px;
}
.section-lead { font-size: 18px; color: var(--ink-2); margin: 0; }

/* ---------- Program ---------- */
.program { padding: 100px 0; background: var(--bg-soft); }
.program__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  counter-reset: program;
}
.program__item {
  display: flex;
  gap: 20px;
  padding: 28px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  transition: border-color .15s, transform .15s, box-shadow .15s;
}
.program__item:hover {
  border-color: var(--blue-600);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.program__num {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--blue-800);
  line-height: 1;
  letter-spacing: -.02em;
  min-width: 56px;
}
.program__item h3 { font-size: 18px; margin-bottom: 6px; }
.program__item p { font-size: 15px; margin: 0; color: var(--ink-2); }

/* ---------- Leadership ---------- */
.leadership { padding: 100px 0; background: #fff; }
.leaders {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.leaders--four { grid-template-columns: repeat(4, 1fr); gap: 24px; }
.leader {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform .15s, box-shadow .15s, border-color .15s;
}
.leader:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow);
  border-color: var(--blue-600);
}
.leader__photo {
  aspect-ratio: 4/5;
  background: #f0f3f8;
  position: relative;
  overflow: hidden;
}
.leader__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 22%;
  display: block;
  transition: transform .35s ease;
}
.leader:hover .leader__photo img {
  transform: scale(1.03);
}
.leader h3 { font-size: 18px; padding: 20px 22px 0; margin-bottom: 2px; }
.leader__role {
  display: block;
  padding: 0 22px;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--blue-700);
  margin-bottom: 10px;
}
.leader p { padding: 0 22px 22px; font-size: 14px; color: var(--ink-3); margin: 0; }

.leaders__pending {
  margin-top: 48px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.leaders__pending-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--red);
  background: rgba(200, 0, 30, .08);
  border: 1px solid rgba(200, 0, 30, .2);
  padding: 6px 14px;
  border-radius: 999px;
}
.leader--candidate {
  max-width: 320px;
  width: 100%;
  border-style: dashed;
  border-color: var(--ink-3);
  position: relative;
}
.leader--candidate:hover { border-color: var(--red); }
.leader--candidate .leader__photo::after {
  content: "?";
  position: absolute;
  top: 12px;
  right: 12px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  font-family: 'Source Serif 4', Georgia, serif;
  font-weight: 700;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(200, 0, 30, .35);
  z-index: 2;
}

.candidates {
  display: flex;
  align-items: stretch;
  gap: 24px;
  width: 100%;
  justify-content: center;
  flex-wrap: wrap;
}
.candidates__vs {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Source Serif 4', Georgia, serif;
  font-weight: 800;
  font-size: 28px;
  color: var(--red);
  letter-spacing: .04em;
  min-width: 48px;
  align-self: center;
}

.poll {
  margin: 16px 22px 22px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.poll__bar {
  height: 8px;
  background: var(--blue-50);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 10px;
}
.poll__fill {
  height: 100%;
  background: linear-gradient(90deg, #c8001e 0%, #e0223f 100%);
  border-radius: 999px;
  transition: width .6s ease;
}
.poll--leading .poll__fill {
  background: linear-gradient(90deg, var(--blue-800) 0%, var(--blue-600) 100%);
}
.poll__meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 13px;
  color: var(--ink-3);
}
.poll__meta strong {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.01em;
}
.poll--leading .poll__meta strong { color: var(--blue-800); }

.leaders__pending-note {
  margin: 18px 0 0;
  font-size: 13px;
  color: var(--ink-3);
  font-style: italic;
  text-align: center;
}

@media (max-width: 720px) {
  .candidates { flex-direction: column; align-items: center; }
  .candidates__vs { padding: 4px 0; font-size: 22px; }
  .leader--candidate { max-width: 320px; }
}

/* ---------- Gallery ---------- */
.gallery { padding: 100px 0; background: #fff; border-top: 1px solid var(--line); }
.gallery__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.gallery__item {
  margin: 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform .15s, box-shadow .15s, border-color .15s;
}
.gallery__item:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: var(--blue-600);
}
.gallery__media {
  position: relative;
  aspect-ratio: 4/3;
  background:
    repeating-linear-gradient(135deg, rgba(10,46,92,.04) 0 10px, transparent 10px 20px),
    linear-gradient(135deg, var(--blue-50) 0%, var(--blue-100) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue-700);
}
.gallery__media svg { width: 44px; height: 44px; opacity: .55; }
.gallery__media--photo {
  background: #000;
  padding: 0;
}
.gallery__media--photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}
.gallery__item:hover .gallery__media--photo img {
  transform: scale(1.03);
}
.gallery__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--blue-800);
  background: rgba(255, 255, 255, .92);
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--blue-100);
}
.gallery__item figcaption {
  padding: 16px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.gallery__item figcaption strong {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
}
.gallery__item figcaption span {
  font-size: 13px;
  color: var(--ink-3);
}
.gallery__note {
  text-align: center;
  margin: 40px auto 0;
  max-width: 640px;
  font-size: 14px;
  color: var(--ink-3);
  font-style: italic;
}
.gallery__item { cursor: zoom-in; }

/* ---------- Lightbox ---------- */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: rgba(6, 18, 38, .94);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5vh 8vw;
  animation: lightbox-in .2s ease-out;
}
.lightbox[hidden] { display: none; }
@keyframes lightbox-in {
  from { opacity: 0; }
  to { opacity: 1; }
}
.lightbox__figure {
  margin: 0;
  max-width: 100%;
  max-height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.lightbox__figure img {
  max-width: 100%;
  max-height: 80vh;
  border-radius: 6px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, .6);
  display: block;
}
.lightbox__figure figcaption {
  color: #fff;
  font-size: 15px;
  text-align: center;
  max-width: 720px;
  line-height: 1.4;
}
.lightbox__figure figcaption strong {
  display: block;
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 4px;
}
.lightbox__figure figcaption span { opacity: .7; font-size: 14px; }
.lightbox__close,
.lightbox__nav {
  position: absolute;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .15);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background .15s, border-color .15s, transform .15s;
  font-family: inherit;
}
.lightbox__close:hover,
.lightbox__nav:hover {
  background: rgba(255, 255, 255, .18);
  border-color: rgba(255, 255, 255, .35);
}
.lightbox__close {
  top: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  font-size: 28px;
  line-height: 1;
  padding-bottom: 4px;
}
.lightbox__nav {
  top: 50%;
  transform: translateY(-50%);
  width: 56px;
  height: 56px;
  font-size: 36px;
  line-height: 1;
  font-weight: 300;
}
.lightbox__nav:hover { transform: translateY(-50%) scale(1.08); }
.lightbox__nav--prev { left: 24px; padding-right: 4px; }
.lightbox__nav--next { right: 24px; padding-left: 4px; }
.lightbox__counter {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255, 255, 255, .55);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  letter-spacing: .04em;
}
body.lightbox-open { overflow: hidden; }

@media (max-width: 720px) {
  .lightbox { padding: 8vh 4vw 12vh; }
  .lightbox__close { top: 12px; right: 12px; width: 40px; height: 40px; }
  .lightbox__nav { width: 44px; height: 44px; font-size: 28px; }
  .lightbox__nav--prev { left: 8px; }
  .lightbox__nav--next { right: 8px; }
  .lightbox__figure img { max-height: 70vh; }
}

/* ---------- Kvíz ---------- */
.quiz { padding: 100px 0; background: #fff; border-top: 1px solid var(--line); }
.quiz__app {
  max-width: 760px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  padding: 40px 36px;
}

.quiz__intro,
.quiz__done { text-align: center; }

.quiz__intro h3,
.quiz__done h3 {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 28px;
  margin-bottom: 12px;
}
.quiz__intro p { color: var(--ink-2); margin-bottom: 24px; }
.quiz__intro ul {
  list-style: none;
  margin: 0 auto 28px;
  padding: 0;
  display: inline-flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
  color: var(--ink-2);
  font-size: 15px;
}
.quiz__intro ul li::before { content: "▸ "; color: var(--blue-700); font-weight: bold; }

.quiz__progress {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-3);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.quiz__score {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 18px;
  color: var(--blue-800);
  text-transform: none;
  font-weight: 700;
  letter-spacing: -.01em;
}

.quiz__timer {
  height: 8px;
  background: var(--blue-50);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 24px;
}
.quiz__timer-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--blue-800), var(--blue-600));
  transition: width .1s linear;
  border-radius: 999px;
}
.quiz__timer-fill.is-low {
  background: linear-gradient(90deg, var(--red), #e0223f);
}

.quiz__question {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 24px;
  line-height: 1.3;
  text-align: center;
  margin: 0 0 28px;
  letter-spacing: -.01em;
}

.quiz__answers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.quiz__answer {
  position: relative;
  background: var(--c, var(--blue-800));
  color: #fff;
  border: 0;
  border-radius: var(--radius);
  padding: 22px 20px 22px 56px;
  font-family: inherit;
  font-size: 16px;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  min-height: 88px;
  display: flex;
  align-items: center;
  transition: transform .12s, filter .12s, box-shadow .12s;
  box-shadow: 0 4px 0 rgba(0,0,0,.18), 0 2px 8px rgba(10,46,92,.18);
}
.quiz__answer:hover { transform: translateY(-2px); filter: brightness(1.05); }
.quiz__answer:active { transform: translateY(1px); box-shadow: 0 2px 0 rgba(0,0,0,.18); }
.quiz__answer[disabled] { cursor: not-allowed; }
.quiz__answer::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
}
.quiz__answer:nth-child(1) { --c: #1d4ed8; }
.quiz__answer:nth-child(1)::before { background: #fff; clip-path: polygon(50% 0, 100% 100%, 0 100%); }
.quiz__answer:nth-child(2) { --c: #c8001e; }
.quiz__answer:nth-child(2)::before { background: #fff; transform: translateY(-50%) rotate(45deg); }
.quiz__answer:nth-child(3) { --c: #e6a300; }
.quiz__answer:nth-child(3)::before { background: #fff; border-radius: 50%; }
.quiz__answer:nth-child(4) { --c: #047857; }
.quiz__answer:nth-child(4)::before { background: #fff; }

.quiz__answer.is-correct { outline: 4px solid #16a34a; outline-offset: -4px; animation: quiz-pop .35s ease; }
.quiz__answer.is-wrong { outline: 4px solid #1f2937; outline-offset: -4px; opacity: .55; }
.quiz__answer.is-faded { opacity: .35; }
@keyframes quiz-pop {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.04); }
}

.quiz__feedback {
  margin-top: 22px;
  text-align: center;
  font-size: 15px;
  color: var(--ink-2);
}
.quiz__feedback strong { color: var(--blue-800); font-family: 'Source Serif 4', Georgia, serif; }

.quiz__done h3 .quiz__final-score {
  display: block;
  font-size: 56px;
  font-weight: 800;
  color: var(--blue-800);
  letter-spacing: -.03em;
  margin-top: 4px;
}
.quiz__done .quiz__tag {
  display: inline-block;
  margin: 4px 0 18px;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--blue-100);
  color: var(--blue-800);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.quiz__review {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  text-align: left;
}
.quiz__review > summary {
  cursor: pointer;
  font-weight: 600;
  font-size: 15px;
  color: var(--ink);
  padding: 6px 0;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.quiz__review > summary::-webkit-details-marker { display: none; }
.quiz__review > summary::before {
  content: "▸";
  font-size: 14px;
  color: var(--blue-700);
  transition: transform .15s;
  display: inline-block;
}
.quiz__review[open] > summary::before { transform: rotate(90deg); }

.quiz__review-list {
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.quiz__review-item {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 16px;
}
.quiz__review-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 10px;
}
.quiz__review-num {
  font-family: 'Source Serif 4', Georgia, serif;
  font-weight: 700;
  color: var(--blue-800);
  font-size: 16px;
  min-width: 22px;
}
.quiz__review-q {
  flex: 1;
  font-weight: 600;
  font-size: 15px;
  line-height: 1.35;
  color: var(--ink);
}
.quiz__review-status {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  color: #fff;
}
.quiz__review-status.is-correct { background: #16a34a; }
.quiz__review-status.is-wrong { background: var(--red); }

.quiz__review-answers {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.quiz__review-ans {
  position: relative;
  padding: 6px 10px 6px 30px;
  border-radius: 6px;
  font-size: 14px;
  color: var(--ink-2);
  background: #fff;
  border: 1px solid var(--line);
}
.quiz__review-ans .quiz__review-mark {
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid var(--line);
  display: inline-block;
}
.quiz__review-ans.is-correct {
  background: rgba(22, 163, 74, .08);
  border-color: #16a34a;
  color: #166534;
  font-weight: 600;
}
.quiz__review-ans.is-correct .quiz__review-mark {
  background: #16a34a;
  border-color: #16a34a;
}
.quiz__review-ans.is-correct .quiz__review-mark::after {
  content: "✓";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
}
.quiz__review-ans.is-wrong {
  background: rgba(200, 0, 30, .06);
  border-color: var(--red);
  color: var(--red);
}
.quiz__review-ans.is-wrong .quiz__review-mark {
  background: var(--red);
  border-color: var(--red);
}
.quiz__review-ans.is-wrong .quiz__review-mark::after {
  content: "✕";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
}
.quiz__review-ans.is-chosen:not(.is-correct):not(.is-wrong) {
  border-style: dashed;
}

.quiz__form {
  text-align: left;
  margin-top: 20px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}
.quiz__form h4 {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 20px;
  margin-bottom: 6px;
}
.quiz__form p { color: var(--ink-3); font-size: 14px; margin-bottom: 18px; }
.quiz__form-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr 1fr;
}
.quiz__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.quiz__field--full { grid-column: 1 / -1; }
.quiz__field label {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-3);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.quiz__field input {
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-family: inherit;
  font-size: 15px;
  color: var(--ink);
  background: #fff;
  transition: border-color .15s, box-shadow .15s;
}
.quiz__field input:focus {
  outline: none;
  border-color: var(--blue-600);
  box-shadow: 0 0 0 3px rgba(30,95,184,.15);
}
.quiz__submit-row {
  margin-top: 16px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}
.quiz__success {
  background: rgba(22, 163, 74, .08);
  border: 1px solid rgba(22, 163, 74, .25);
  color: #166534;
  padding: 14px 16px;
  border-radius: 8px;
  font-size: 14px;
  text-align: left;
}
.quiz__error {
  background: rgba(200, 0, 30, .08);
  border: 1px solid rgba(200, 0, 30, .25);
  color: var(--red);
  padding: 14px 16px;
  border-radius: 8px;
  font-size: 14px;
  text-align: left;
}

@media (max-width: 720px) {
  .quiz__app { padding: 28px 20px; }
  .quiz__question { font-size: 20px; }
  .quiz__answers { grid-template-columns: 1fr; }
  .quiz__answer { padding-left: 50px; min-height: 64px; font-size: 15px; }
  .quiz__answer::before { left: 14px; width: 20px; height: 20px; }
  .quiz__form-grid { grid-template-columns: 1fr; }
  .quiz__done h3 .quiz__final-score { font-size: 44px; }
}

/* ---------- Shop ---------- */
.shop { padding: 100px 0; background: var(--bg-soft); }
.shop__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.product {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .15s, box-shadow .15s, border-color .15s;
}
.product:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow);
  border-color: var(--blue-600);
}
.product__media {
  aspect-ratio: 1/1;
  background: linear-gradient(135deg, var(--blue-50) 0%, var(--blue-100) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue-800);
}
.product__media svg { width: 56%; height: 56%; }
.product__body {
  padding: 18px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.product h3 { font-size: 16px; margin: 0; line-height: 1.3; }
.product__desc {
  font-size: 13px;
  color: var(--ink-3);
  margin: 0;
  flex: 1;
}
.product__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 4px;
  gap: 10px;
}
.product__price {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--blue-800);
  letter-spacing: -.01em;
}
.product .btn--ghost[disabled] {
  opacity: .55;
  cursor: not-allowed;
  pointer-events: none;
  padding: 7px 12px;
  font-size: 12px;
}
.shop__note {
  text-align: center;
  margin: 40px auto 0;
  max-width: 640px;
  font-size: 14px;
  color: var(--ink-3);
  font-style: italic;
}

/* ---------- CTA ---------- */
.cta { padding: 80px 0; background: var(--blue-900); color: #fff; }
.cta__inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 48px;
  align-items: center;
}
.cta h2 {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: clamp(28px, 3.4vw, 40px);
  color: #fff;
  margin-bottom: 12px;
  letter-spacing: -.02em;
}
.cta p { color: rgba(255,255,255,.78); font-size: 17px; margin: 0; max-width: 540px; }
.cta__actions { display: flex; flex-direction: column; gap: 12px; align-items: stretch; }
.cta .btn--primary { background: #fff; color: var(--blue-900); }
.cta .btn--primary:hover { background: var(--blue-100); }
.cta .btn--ghost { color: #fff; border-color: rgba(255,255,255,.25); }
.cta .btn--ghost:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.5); }

/* ---------- Footer ---------- */
.footer { background: #061d3d; color: rgba(255,255,255,.7); padding: 64px 0 0; font-size: 14px; }
.footer__inner {
  display: grid;
  grid-template-columns: 1.2fr 2fr;
  gap: 48px;
  padding-bottom: 48px;
}
.footer__brand .brand { color: #fff; margin-bottom: 16px; }
.footer__brand p { color: rgba(255,255,255,.55); max-width: 320px; margin: 0 0 10px; }
.footer__slogan {
  font-family: 'Source Serif 4', Georgia, serif;
  font-style: italic;
  font-size: 17px;
  color: rgba(255,255,255,.85) !important;
  line-height: 1.35;
  margin-bottom: 14px !important;
  padding-left: 12px;
  border-left: 3px solid var(--red);
}
.footer__cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.footer__cols h4 { color: #fff; font-size: 13px; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 14px; }
.footer__cols ul li { margin-bottom: 8px; }
.footer__cols a { color: rgba(255,255,255,.7); }
.footer__cols a:hover { color: #fff; }
.footer__bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding: 20px 0;
  font-size: 13px;
  color: rgba(255,255,255,.5);
}
.footer__bottom .container {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.footer__disclaimer { font-style: italic; }

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .hero { padding: 56px 0 72px; }
  .hero__inner { grid-template-columns: 1fr; gap: 48px; }
  .hero__visual { max-width: 420px; }
  .values__grid { grid-template-columns: repeat(2, 1fr); }
  .program__list { grid-template-columns: 1fr; }
  .leaders,
  .leaders--four { grid-template-columns: repeat(2, 1fr); }
  .shop__grid { grid-template-columns: repeat(2, 1fr); }
  .gallery__grid { grid-template-columns: repeat(2, 1fr); }
  .cta__inner { grid-template-columns: 1fr; }
  .footer__inner { grid-template-columns: 1fr; gap: 32px; }
}

@media (max-width: 720px) {
  .nav, .topbar .btn--primary { display: none; }
  .nav__toggle { display: flex; }
  .nav.is-open {
    display: flex;
    position: absolute;
    top: 72px;
    left: 0; right: 0;
    flex-direction: column;
    background: #fff;
    border-bottom: 1px solid var(--line);
    padding: 12px 24px 16px;
    gap: 2px;
  }
  .nav.is-open a { padding: 12px 8px; }
  .hero__title { font-size: clamp(36px, 9vw, 52px); }
  .hero__badges { grid-template-columns: 1fr; gap: 16px; }
  .values__grid { grid-template-columns: 1fr; }
  .leaders,
  .leaders--four { grid-template-columns: 1fr; }
  .shop__grid { grid-template-columns: 1fr; }
  .gallery__grid { grid-template-columns: 1fr; }
  .program__item { padding: 22px; gap: 14px; }
  .program__num { font-size: 26px; min-width: 44px; }
  .footer__cols { grid-template-columns: 1fr 1fr; }
}
