/* =====================================================================
   ÚzkostDeprese.cz — Base + komponenty
   Vyžaduje tokens.css. Sémantické, znovupoužitelné, mobile-first.
   ===================================================================== */

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}
body {
  font-family: var(--font-sans);
  font-size: var(--fs-200);
  line-height: var(--lh-relaxed);
  color: var(--color-ink);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg, picture { display: block; max-width: 100%; }
img { height: auto; }
a { color: var(--color-primary-ink); text-underline-offset: 0.18em; text-decoration-thickness: 1px; }
a:hover { color: var(--color-primary-strong); }
button, input, textarea, select { font: inherit; color: inherit; }
ul, ol { padding-left: 1.3em; }

/* Accessibility: focus + skip link */
:focus-visible { outline: 3px solid var(--color-primary); outline-offset: 2px; border-radius: var(--radius-xs); }
.skip-link {
  position: absolute; left: var(--space-4); top: -10rem;
  background: var(--color-primary); color: #fff; padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-pill); z-index: 200; font-weight: var(--fw-semibold);
  transition: top var(--dur) var(--ease);
}
.skip-link:focus { top: var(--space-4); color: #fff; }
.visually-hidden {
  position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ---------- TYPOGRAFIE ---------- */
h1, h2, h3, h4 { font-family: var(--font-serif); font-weight: var(--fw-medium); line-height: var(--lh-tight); color: var(--color-ink); letter-spacing: var(--ls-tight); text-wrap: balance; }
h1 { font-size: var(--fs-600); }
h2 { font-size: var(--fs-500); }
h3 { font-size: var(--fs-400); line-height: var(--lh-snug); }
h4 { font-size: var(--fs-300); line-height: var(--lh-snug); }
p { text-wrap: pretty; }
.lead { font-size: var(--fs-300); line-height: var(--lh-normal); color: var(--color-ink-soft); }
.eyebrow {
  font-family: var(--font-sans); font-size: var(--fs-50); font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--color-primary-ink);
  display: inline-flex; align-items: center; gap: var(--space-2);
}
.eyebrow::before { content: ""; width: 1.6rem; height: 2px; background: var(--color-accent); border-radius: 2px; }
.muted { color: var(--color-ink-muted); }
.serif { font-family: var(--font-serif); }

/* ---------- LAYOUT HELPERS ---------- */
.wrap { width: 100%; max-width: var(--maxw-full); margin-inline: auto; padding-inline: var(--gutter); }
.wrap--wide { max-width: var(--maxw-wide); }
.wrap--text { max-width: var(--maxw-text); }
.wrap--prose { max-width: var(--maxw-prose); }
.section { padding-block: clamp(var(--space-8), 7vw, var(--space-11)); }
.section--tight { padding-block: clamp(var(--space-7), 5vw, var(--space-9)); }
.section--warm { background: var(--color-bg-warm); }
.section--surface { background: var(--color-surface); }
.stack > * + * { margin-top: var(--space-4); }
.stack-lg > * + * { margin-top: var(--space-6); }
.cluster { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; }
.grid { display: grid; gap: var(--space-5); }
.section-head { max-width: var(--maxw-text); margin-bottom: var(--space-7); }
.section-head .lead { margin-top: var(--space-3); }

/* ---------- BUTTONS ---------- */
.btn {
  --_bg: var(--color-primary); --_fg: #fff; --_bd: var(--color-primary);
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-weight: var(--fw-semibold); font-size: var(--fs-100); line-height: 1;
  padding: 0.95em 1.5em; border-radius: var(--radius-pill);
  background: var(--_bg); color: var(--_fg); border: 1.5px solid var(--_bd);
  cursor: pointer; text-decoration: none; transition: background var(--dur) var(--ease), transform var(--dur-fast) var(--ease), box-shadow var(--dur) var(--ease);
  min-height: 48px; /* hit target */
  white-space: nowrap;
}
.btn:hover { background: var(--color-primary-strong); border-color: var(--color-primary-strong); color: #fff; transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.btn:active { transform: translateY(0); }
.btn--accent { --_bg: var(--color-accent-ink); --_bd: var(--color-accent-ink); }
.btn--accent:hover { background: var(--color-accent-strong); border-color: var(--color-accent-strong); }
.btn--ghost { --_bg: transparent; --_fg: var(--color-primary-ink); --_bd: var(--color-line-strong); }
.btn--ghost:hover { background: var(--color-primary-tint); border-color: var(--color-primary); color: var(--color-primary-ink); }
.btn--soft { --_bg: var(--color-primary-tint); --_fg: var(--color-primary-ink); --_bd: var(--color-primary); }
.btn--soft:hover { background: var(--color-primary-tint-2); border-color: var(--color-primary-strong); color: var(--color-primary-ink); transform: translateY(-1px); }
.btn--on-dark { --_bg: var(--color-on-dark); --_fg: var(--color-dark); --_bd: var(--color-on-dark); }
.btn--on-dark:hover { background: #fff; color: var(--color-dark); border-color: #fff; }
.btn--lg { font-size: var(--fs-200); padding: 1.05em 1.8em; }
.btn .ic { width: 1.1em; height: 1.1em; }
.link-arrow { font-weight: var(--fw-semibold); color: var(--color-primary-ink); text-decoration: none; display: inline-flex; align-items: center; gap: var(--space-2); }
.link-arrow .ic { width: 1em; height: 1em; transition: transform var(--dur) var(--ease); }
.link-arrow:hover .ic { transform: translateX(3px); }

/* ---------- BADGE / CHIP ---------- */
.badge {
  display: inline-flex; align-items: center; gap: 0.4em; align-self: flex-start; justify-self: start;
  font-size: var(--fs-50); font-weight: var(--fw-semibold); letter-spacing: 0.04em;
  text-transform: uppercase; padding: 0.4em 0.8em; border-radius: var(--radius-pill);
  background: var(--color-primary-tint); color: var(--color-primary-ink); text-decoration: none;
}
.badge::before { content: ""; width: 0.45em; height: 0.45em; border-radius: 50%; background: var(--color-primary); }
.badge--uzkost   { background: var(--color-primary-tint); color: var(--color-primary-ink); }
.badge--uzkost::before { background: var(--color-primary); }
.badge--deprese  { background: var(--color-sage-tint); color: var(--color-sage-deep); }
.badge--deprese::before { background: var(--color-sage-deep); }
.badge--panika   { background: var(--color-accent-tint); color: var(--color-accent-ink); }
.badge--panika::before { background: var(--color-accent-ink); }
.badge--lecba    { background: var(--color-bg-warm); color: var(--color-ink-soft); }
.badge--lecba::before { background: var(--color-ink-muted); }
.badge-verified {
  display: inline-flex; align-items: center; gap: 0.5em; align-self: flex-start; justify-self: start;
  font-size: var(--fs-100); font-weight: var(--fw-semibold);
  padding: 0.5em 0.95em; border-radius: var(--radius-pill);
  background: var(--color-sage-tint); color: var(--color-sage-deep); text-decoration: none;
}
.badge-verified .ic { width: 1.1em; height: 1.1em; }

/* ---------- CARD (článek) ---------- */
.card {
  display: flex; flex-direction: column; background: var(--color-surface);
  border: 1px solid var(--color-line); border-radius: var(--radius-lg); overflow: hidden;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--color-line-strong); }
.card__media { aspect-ratio: 16 / 10; position: relative; }
.card__body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-3); flex: 1; }
.card__title { font-size: var(--fs-400); }
.card__title a { color: var(--color-ink); text-decoration: none; }
.card__title a:hover { color: var(--color-primary-ink); }
.card__excerpt { color: var(--color-ink-soft); font-size: var(--fs-100); }
.card__meta { margin-top: auto; display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; font-size: var(--fs-50); color: var(--color-ink-muted); }
.card__meta .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--color-line-strong); }

/* ---------- IMAGE PLACEHOLDER (abstraktní klid) ---------- */
.ph {
  position: absolute; inset: 0; overflow: hidden;
  background:
    radial-gradient(120% 90% at 18% 12%, var(--color-sage-tint), transparent 60%),
    radial-gradient(120% 110% at 92% 96%, var(--color-primary-tint-2), transparent 58%),
    linear-gradient(135deg, var(--color-sage) 0%, var(--color-primary) 100%);
}
.ph--accent { background:
    radial-gradient(120% 90% at 20% 10%, var(--color-accent-tint), transparent 60%),
    linear-gradient(135deg, var(--color-accent) 0%, var(--color-primary) 120%); }
.ph--soft   { background:
    radial-gradient(120% 90% at 20% 14%, #ffffff66, transparent 55%),
    linear-gradient(160deg, var(--color-sage-tint), var(--color-primary-tint)); }
.ph__label {
  position: absolute; left: var(--space-3); bottom: var(--space-3);
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.02em;
  color: #ffffffdd; background: #00000026; padding: 0.3em 0.6em; border-radius: var(--radius-xs);
  backdrop-filter: blur(2px);
}
.ph--soft .ph__label { color: var(--color-ink-soft); background: #ffffff99; }
/* jemné dýchající vlny v placeholderu */
.ph__waves { position: absolute; inset: 0; opacity: 0.5; }
.ph__waves path { fill: none; stroke: #ffffff55; stroke-width: 1.5; }

/* ---------- HEADER ---------- */
.site-header { position: sticky; top: 0; z-index: 100; background: color-mix(in srgb, var(--color-bg) 88%, transparent); backdrop-filter: blur(10px); border-bottom: 1px solid var(--color-line); }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-5); min-height: 72px; }
.brand { display: inline-flex; align-items: baseline; gap: 0.08em; text-decoration: none; font-family: var(--font-serif); font-size: 1.4rem; line-height: 1; letter-spacing: -0.01em; }
.brand b { font-weight: var(--fw-semibold); color: var(--color-ink); }
.brand .sep { color: var(--color-accent); font-weight: var(--fw-bold); padding-inline: 0.05em; }
.brand .em { font-weight: var(--fw-medium); color: var(--color-primary-ink); }
.brand .tld { font-family: var(--font-sans); font-size: 0.62em; font-weight: var(--fw-semibold); color: var(--color-ink-muted); letter-spacing: 0.02em; align-self: center; margin-left: 0.15em; }
.main-nav { display: flex; align-items: center; gap: var(--space-2); }
.main-nav a { font-family: var(--font-sans); font-size: var(--fs-100); font-weight: var(--fw-medium); color: var(--color-ink-soft); text-decoration: none; padding: 0.55em 0.7em; border-radius: var(--radius-sm); transition: color var(--dur) var(--ease), background var(--dur) var(--ease); }
.main-nav a:hover, .main-nav a[aria-current="page"] { color: var(--color-primary-ink); background: var(--color-primary-tint); }
.header-cta { display: inline-flex; gap: var(--space-2); align-items: center; }
.header-cta .btn { font-size: var(--fs-50); padding: 0.72em 1.15em; min-height: 42px; }
.icon-btn { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 50%; border: 1.5px solid var(--color-line-strong); background: var(--color-surface); color: var(--color-ink-soft); cursor: pointer; transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.icon-btn:hover { background: var(--color-primary-tint); color: var(--color-primary-ink); border-color: var(--color-primary); }
.icon-btn .ic { width: 1.2rem; height: 1.2rem; }
.nav-toggle { display: none; }

/* ---------- VYHLEDÁVACÍ PANEL ---------- */
.search-panel { background: var(--color-surface); border-bottom: 1px solid var(--color-line); }
.search-panel[hidden] { display: none; }
.search-form { display: flex; align-items: center; gap: var(--space-3); padding-block: var(--space-4); }
.search-form__field { flex: 1; display: flex; align-items: center; gap: var(--space-3); background: var(--color-bg); border: 1.5px solid var(--color-line-strong); border-radius: var(--radius-pill); padding: 0 var(--space-3) 0 var(--space-4); min-height: 52px; }
.search-form__field:focus-within { border-color: var(--color-primary); box-shadow: var(--ring); }
.search-form__field .ic { flex: none; width: 1.3rem; height: 1.3rem; color: var(--color-ink-muted); }
.search-form input[type="search"] { flex: 1; border: 0; background: transparent; outline: none; font-size: var(--fs-200); padding: 0.6em 0; color: var(--color-ink); appearance: none; }
.search-form input[type="search"]::-webkit-search-cancel-button { appearance: none; }
.search-close { flex: none; width: 44px; height: 44px; border-radius: 50%; border: 0; background: transparent; color: var(--color-ink-muted); cursor: pointer; display: grid; place-items: center; }
.search-close:hover { background: var(--color-bg-warm); color: var(--color-ink); }
.search-close .ic { width: 1.3rem; height: 1.3rem; }
@media (prefers-reduced-motion: no-preference) {
  .search-panel:not([hidden]) { animation: searchDrop var(--dur) var(--ease); }
}
@keyframes searchDrop { from { transform: translateY(-8px); } to { transform: none; } }
@media (max-width: 560px) {
  .search-form__submit { display: none; }
}

/* ---------- KRIZOVÁ POMOC (lišta) ---------- */
.crisis-bar { background: var(--color-care-tint); border-bottom: 1px solid color-mix(in srgb, var(--color-care) 22%, transparent); }
.crisis-bar__inner { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-3) var(--space-5); padding-block: 0.6rem; font-size: var(--fs-100); }
.crisis-bar__label { display: inline-flex; align-items: center; gap: 0.5em; font-weight: var(--fw-semibold); color: var(--color-care); }
.crisis-bar__label .ic { width: 1.1em; height: 1.1em; }
.crisis-bar__lines { display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-5); }
.crisis-bar a { color: var(--color-ink); text-decoration: none; font-weight: var(--fw-medium); display: inline-flex; align-items: center; gap: 0.4em; }
.crisis-bar a strong { color: var(--color-care); }
.crisis-bar a:hover strong { text-decoration: underline; }

/* ---------- KRIZOVÝ BOX (v obsahu) ---------- */
.crisis-card { background: var(--color-care-tint); border: 1px solid color-mix(in srgb, var(--color-care) 25%, transparent); border-radius: var(--radius-lg); padding: var(--space-6); }
.crisis-card h3 { color: var(--color-care); font-size: var(--fs-300); }
.crisis-card .lines { display: grid; gap: var(--space-3); margin-top: var(--space-4); }
.crisis-card .lines a { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-4); padding: var(--space-3) var(--space-4); background: var(--color-surface); border-radius: var(--radius-md); text-decoration: none; color: var(--color-ink); }
.crisis-card .lines a:hover { background: #fff; box-shadow: var(--shadow-xs); }
.crisis-card .lines .num { font-family: var(--font-mono); font-weight: var(--fw-semibold); color: var(--color-care); white-space: nowrap; }

/* ---------- DISCLAIMER / ALERT ---------- */
.alert { display: flex; gap: var(--space-4); padding: var(--space-5); border-radius: var(--radius-lg); background: var(--color-surface-2); border: 1px solid var(--color-line); font-size: var(--fs-100); color: var(--color-ink-soft); }
.alert .ic { flex: none; width: 1.4rem; height: 1.4rem; color: var(--color-ink-muted); margin-top: 0.15em; }
.alert strong { color: var(--color-ink); }
.alert--care { background: var(--color-care-tint); border-color: color-mix(in srgb, var(--color-care) 22%, transparent); }
.alert--care .ic { color: var(--color-care); }

/* ---------- AFFILIATE BOX ---------- */
.affiliate { display: grid; grid-template-columns: 7.5rem 1fr; gap: var(--space-5); align-items: center; padding: var(--space-5); border: 1px solid var(--color-accent); background: var(--color-accent-tint); border-radius: var(--radius-lg); }
.affiliate__media { aspect-ratio: 1; border-radius: var(--radius-md); position: relative; overflow: hidden; }
.affiliate__tag { font-size: var(--fs-50); font-weight: var(--fw-semibold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--color-accent-ink); }
.affiliate h4 { font-family: var(--font-sans); font-size: var(--fs-200); font-weight: var(--fw-semibold); margin-top: 0.2em; }
.affiliate p { font-size: var(--fs-100); color: var(--color-ink-soft); margin: var(--space-2) 0 var(--space-3); }

/* ---------- AD SLOT ---------- */
.ad-slot { border: 1px dashed var(--color-line-strong); border-radius: var(--radius-md); background: var(--color-surface-2); padding: var(--space-5); text-align: center; color: var(--color-ink-muted); }
.ad-slot .ad-label { font-size: var(--fs-50); font-weight: var(--fw-semibold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--color-ink-muted); }
.ad-slot .ad-box { margin-top: var(--space-3); min-height: 90px; display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 0.8rem; color: var(--color-ink-muted); }

/* ---------- NEWSLETTER ---------- */
.newsletter { background: var(--color-dark); color: var(--color-on-dark); border-radius: var(--radius-xl); padding: clamp(var(--space-6), 5vw, var(--space-9)); position: relative; overflow: hidden; }
.newsletter h2, .newsletter h3 { color: #fff; }
.newsletter p { color: var(--color-on-dark-soft); }
.newsletter__form { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-5); max-width: 34rem; }
.field { flex: 1 1 16rem; }
.field input { width: 100%; padding: 0.95em 1.1em; border-radius: var(--radius-pill); border: 1.5px solid transparent; background: #ffffff; color: var(--color-ink); }
.field input::placeholder { color: var(--color-ink-muted); }
.newsletter .glow { position: absolute; width: 26rem; height: 26rem; right: -8rem; top: -10rem; border-radius: 50%; background: radial-gradient(circle, color-mix(in srgb, var(--color-sage) 55%, transparent), transparent 65%); opacity: 0.5; pointer-events: none; }
.form-hint { font-size: var(--fs-50); color: var(--color-on-dark-soft); margin-top: var(--space-3); }

/* ---------- BREADCRUMBS ---------- */
.breadcrumbs { font-size: var(--fs-100); color: var(--color-ink-muted); display: flex; flex-wrap: wrap; gap: 0.5em; align-items: center; }
.breadcrumbs a { color: var(--color-ink-soft); text-decoration: none; }
.breadcrumbs a:hover { color: var(--color-primary-ink); text-decoration: underline; }
.breadcrumbs .sep { color: var(--color-line-strong); }

/* ---------- COOKIE LIŠTA ---------- */
.cookie-bar { position: fixed; left: var(--space-4); right: var(--space-4); bottom: var(--space-4); z-index: 150; background: var(--color-surface); border: 1px solid var(--color-line-strong); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: var(--space-5); display: grid; gap: var(--space-4); max-width: 40rem; margin-inline: auto; }
.cookie-bar p { font-size: var(--fs-100); color: var(--color-ink-soft); }
.cookie-bar .actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.cookie-bar .btn { font-size: var(--fs-50); padding: 0.7em 1.2em; min-height: 42px; }

/* ---------- FOOTER ---------- */
.site-footer { background: var(--color-dark); color: var(--color-on-dark-soft); padding-block: var(--space-9) var(--space-6); margin-top: var(--space-8); }
.site-footer a { color: var(--color-on-dark-soft); text-decoration: none; }
.site-footer a:hover { color: #fff; text-decoration: underline; }
.footer-grid { display: grid; gap: var(--space-7); grid-template-columns: 1.4fr repeat(3, 1fr); }
.footer-brand .brand b { color: #fff; } .footer-brand .brand .em { color: var(--color-sage); } .footer-brand .brand .tld { color: var(--color-on-dark-soft); }
.footer-brand p { margin-top: var(--space-4); font-size: var(--fs-100); max-width: 28rem; }
.footer-col h4 { font-family: var(--font-sans); font-size: var(--fs-50); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--color-on-dark); margin-bottom: var(--space-4); }
.footer-col ul { list-style: none; padding: 0; display: grid; gap: var(--space-3); font-size: var(--fs-100); }
.footer-crisis { margin-top: var(--space-7); padding: var(--space-5); border: 1px solid #ffffff22; border-radius: var(--radius-md); display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-6); align-items: center; font-size: var(--fs-100); }
.footer-crisis strong { color: var(--color-sage); }
.footer-crisis .num { font-family: var(--font-mono); color: #fff; }
.footer-bottom { margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px solid #ffffff1f; display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-4); font-size: var(--fs-50); }

/* ---------- DECOR: dýchací vlna jako oddělovač ---------- */
.wave-rule { width: 100%; height: 28px; color: var(--color-sage); opacity: 0.7; }
.wave-rule path { fill: none; stroke: currentColor; stroke-width: 2; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 780px) {
  .main-nav, .header-cta .btn { display: none; }
  .nav-toggle { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; border: 1.5px solid var(--color-line-strong); background: var(--color-surface); border-radius: var(--radius-md); cursor: pointer; }
  .nav-toggle .ic { width: 1.5rem; height: 1.5rem; }
  .affiliate { grid-template-columns: 1fr; text-align: left; }
  .affiliate__media { width: 6rem; }
}
@media (max-width: 560px) {
  .footer-grid { grid-template-columns: 1fr; }
  .crisis-bar__inner { font-size: var(--fs-50); }
}


/* ===== Sloučeno z home.css (sekce úvodní stránky) ===== */
/* =====================================================================
   ÚzkostDeprese.cz — Úvodní stránka (sekce specifické)
   Vyžaduje tokens.css + main.css
   ===================================================================== */

/* ---------- MOBILNÍ NAV ---------- */
.mobile-nav { border-top: 1px solid var(--color-line); background: var(--color-surface); }
.mobile-nav .wrap { display: grid; gap: var(--space-1); padding-block: var(--space-4); }
.mobile-nav a { padding: var(--space-3) var(--space-2); border-radius: var(--radius-sm); text-decoration: none; color: var(--color-ink-soft); font-weight: var(--fw-medium); }
.mobile-nav a:hover { background: var(--color-primary-tint); color: var(--color-primary-ink); }

/* ---------- HERO ---------- */
.hero { position: relative; overflow: hidden; background: linear-gradient(180deg, var(--color-sage-tint) 0%, var(--color-bg) 78%); }
.hero__bg { position: absolute; inset: 0; pointer-events: none; }
.hero__waves { position: absolute; left: -5%; right: -5%; bottom: 0; width: 110%; height: 70%; opacity: 0.5; color: var(--color-sage); }
.hero__waves path { fill: none; stroke: currentColor; stroke-width: 1.5; }
.hero__waves path:nth-child(2) { stroke: var(--color-primary); opacity: 0.4; }
.hero__waves path:nth-child(3) { stroke: var(--color-accent); opacity: 0.35; }
.hero__inner { position: relative; padding-block: clamp(var(--space-9), 11vw, var(--space-12)); max-width: 56rem; }
.hero__title { font-size: var(--fs-700); font-weight: var(--fw-medium); letter-spacing: var(--ls-tight); margin-top: var(--space-4); }
.hero__lead { margin-top: var(--space-5); max-width: 42rem; }
.hero__actions { margin-top: var(--space-7); }
.hero__note { margin-top: var(--space-4); font-size: var(--fs-100); }
@media (prefers-reduced-motion: no-preference) {
  .hero__waves path { animation: breathe 9s var(--ease) infinite alternate; }
  .hero__waves path:nth-child(2) { animation-delay: -3s; }
  .hero__waves path:nth-child(3) { animation-delay: -6s; }
}
@keyframes breathe { from { transform: translateY(6px); } to { transform: translateY(-10px); } }

/* ---------- SECTION HEAD (řádkové uspořádání) ---------- */
.section-head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-5); max-width: none; }

/* ---------- PILÍŘE ---------- */
.pillars { grid-template-columns: repeat(4, 1fr); }
.pillar {
  display: flex; flex-direction: column; gap: var(--space-3);
  padding: var(--space-6); background: var(--color-surface);
  border: 1px solid var(--color-line); border-radius: var(--radius-lg);
  text-decoration: none; color: var(--color-ink);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.pillar:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--color-primary); color: var(--color-ink); }
.pillar__icon { width: 3rem; height: 3rem; display: grid; place-items: center; border-radius: var(--radius-md); background: var(--color-primary-tint); color: var(--color-primary-ink); margin-bottom: var(--space-1); }
.pillar__icon svg { width: 1.6rem; height: 1.6rem; }
.pillar h3 { font-size: var(--fs-400); }
.pillar p { font-size: var(--fs-100); color: var(--color-ink-soft); flex: 1; }
.pillar .link-arrow { margin-top: var(--space-2); }

/* ---------- KARTY MŘÍŽKA ---------- */
.cards-grid { grid-template-columns: repeat(3, 1fr); }

/* ---------- VÝZKUM ---------- */
.research { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(var(--space-6), 5vw, var(--space-9)); align-items: start; background: var(--color-primary-tint); border: 1px solid var(--color-primary-tint-2); border-radius: var(--radius-xl); padding: clamp(var(--space-6), 4vw, var(--space-8)); }
.research__head .lead { margin: var(--space-3) 0 var(--space-5); }
.research__list { list-style: none; padding: 0; display: grid; gap: var(--space-3); }
.research__list a { display: grid; gap: var(--space-1); padding: var(--space-5); background: var(--color-surface); border-radius: var(--radius-md); text-decoration: none; transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.research__list a:hover { transform: translateX(3px); box-shadow: var(--shadow-sm); }
.research__src { font-family: var(--font-mono); font-size: var(--fs-50); color: var(--color-accent-ink); letter-spacing: 0.02em; }
.research__title { font-family: var(--font-serif); font-size: var(--fs-300); line-height: var(--lh-snug); color: var(--color-ink); }
.research__cite { font-size: var(--fs-50); color: var(--color-ink-muted); }

/* ---------- SEBETEST ---------- */
.selftest { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(var(--space-6), 5vw, var(--space-9)); align-items: center; }
.selftest__copy .lead { margin: var(--space-3) 0 var(--space-6); }
.selftest__time { font-size: var(--fs-100); }
.selftest__visual .ph__waves path { animation: none; }

/* ---------- NEWSLETTER ---------- */
.newsletter__inner { position: relative; max-width: 40rem; }
.newsletter__inner h2 { margin-top: var(--space-3); }
.newsletter__inner p { margin-top: var(--space-4); }

/* ---------- DŮVĚRYHODNOST ---------- */
.trust-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.trust { text-align: left; }
.trust__icon { width: 3rem; height: 3rem; display: grid; place-items: center; border-radius: var(--radius-md); background: var(--color-sage-tint); color: var(--color-sage-deep); margin-bottom: var(--space-4); }
.trust__icon svg { width: 1.6rem; height: 1.6rem; }
.trust h3 { font-size: var(--fs-400); }
.trust p { font-size: var(--fs-100); color: var(--color-ink-soft); margin-top: var(--space-2); }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1000px) {
  .pillars { grid-template-columns: repeat(2, 1fr); }
  .cards-grid { grid-template-columns: repeat(2, 1fr); }
  .research { grid-template-columns: 1fr; }
  .selftest { grid-template-columns: 1fr; }
  .trust-grid { grid-template-columns: 1fr; gap: var(--space-5); }
}
@media (max-width: 620px) {
  .pillars { grid-template-columns: 1fr; }
  .cards-grid { grid-template-columns: 1fr; }
  .section-head--row { flex-direction: column; align-items: flex-start; }
}

/* =====================================================================
   MEDAILONEK AUTORA (.author-box) — pod článkem
   ===================================================================== */
.author-box {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-5);
  align-items: start;
  padding: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
}
.author-box__avatar {
  width: 84px; height: 84px;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: 0 0 0 4px var(--color-primary-tint);
}
.author-box__body { min-width: 0; }
.author-box .eyebrow { font-size: var(--fs-50); }
.author-box__name {
  font-family: var(--font-serif);
  font-size: var(--fs-300);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-snug);
  color: var(--color-ink);
  margin-top: var(--space-1);
}
.author-box__role {
  font-size: var(--fs-50);
  color: var(--color-ink-muted);
  margin-top: 2px;
}
.author-box__bio {
  font-size: var(--fs-100);
  line-height: var(--lh-normal);
  color: var(--color-ink-soft);
  margin-top: var(--space-3);
  max-width: 52ch;
}
.author-box__foot {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3) var(--space-4);
  margin-top: var(--space-4);
}
.author-box__foot .link-arrow { font-size: var(--fs-100); white-space: nowrap; }
.author-box__social {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--color-bg); border: 1px solid var(--color-line);
  color: var(--color-ink-soft);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.author-box__social:hover { background: var(--color-primary-tint); color: var(--color-primary-ink); border-color: var(--color-primary); }
.author-box__social .ic { width: 1.15rem; height: 1.15rem; }
.author-box__sep { width: 1px; height: 1.4rem; background: var(--color-line); }
@media (max-width: 520px) {
  .author-box { grid-template-columns: 1fr; gap: var(--space-4); padding: var(--space-5); }
  .author-box__avatar { width: 72px; height: 72px; }
}

/* ---- Hlavička stránky autora (author.php archiv) ---- */
.author-hero { text-align: center; }
.author-hero__inner { max-width: 46rem; margin-inline: auto; padding-block: clamp(var(--space-7), 5vw, var(--space-9)); display: flex; flex-direction: column; align-items: center; }
.author-hero .breadcrumbs { justify-content: center; margin-bottom: var(--space-5); }
.author-hero__avatar { width: 112px; height: 112px; border-radius: 50%; object-fit: cover; box-shadow: 0 0 0 5px var(--color-surface), 0 0 0 6px var(--color-primary-tint-2); }
.author-hero .eyebrow { justify-content: center; margin-top: var(--space-5); }
.author-hero__name { font-family: var(--font-serif); font-weight: var(--fw-semibold); font-size: var(--fs-600); line-height: var(--lh-tight); margin-top: var(--space-2); }
.author-hero__role { font-size: var(--fs-100); color: var(--color-ink-muted); margin-top: var(--space-2); }
.author-hero__bio { font-size: var(--fs-200); line-height: var(--lh-relaxed); color: var(--color-ink-soft); margin-top: var(--space-4); max-width: 42rem; text-wrap: pretty; }
.author-hero__foot { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--space-4); margin-top: var(--space-6); }
.author-hero__count { font-size: var(--fs-100); font-weight: var(--fw-semibold); color: var(--color-primary-ink); display: inline-flex; align-items: center; gap: var(--space-2); }
.author-hero__count .ic { width: 1.1rem; height: 1.1rem; }

/* =====================================================================
   FAQ — rozklikávací (accordion) · nativní <details>/<summary>
   ===================================================================== */
.faq { display: grid; gap: var(--space-3); }
.faq__item { border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface); overflow: hidden; transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.faq__item[open] { border-color: var(--color-line-strong); box-shadow: var(--shadow-xs); }
.faq__q {
  list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-4); padding: var(--space-5); font-family: var(--font-serif);
  font-size: var(--fs-300); line-height: var(--lh-snug); color: var(--color-ink); font-weight: var(--fw-medium);
}
.faq__q::-webkit-details-marker { display: none; }
.faq__q:hover { color: var(--color-primary-ink); }
.faq__icon { flex: none; width: 1.6rem; height: 1.6rem; border-radius: 50%; background: var(--color-primary-tint); color: var(--color-primary-ink); display: grid; place-items: center; transition: transform var(--dur) var(--ease), background var(--dur) var(--ease); }
.faq__icon .ic { width: 1rem; height: 1rem; }
.faq__item[open] .faq__icon { transform: rotate(45deg); background: var(--color-primary); color: #fff; }
.faq__a { padding: 0 var(--space-5) var(--space-5); }
.faq__a > * { font-size: var(--fs-100); line-height: var(--lh-relaxed); color: var(--color-ink-soft); max-width: var(--maxw-prose); }
.faq__a > * + * { margin-top: var(--space-3); }
.faq__a a { color: var(--color-accent-ink); text-decoration: underline; }
.faq__q:focus-visible { outline: 3px solid var(--color-primary); outline-offset: -3px; border-radius: var(--radius-md); }
@media (prefers-reduced-motion: no-preference) {
  .faq__item[open] .faq__a { animation: faqReveal var(--dur) var(--ease); }
}
@keyframes faqReveal { from { transform: translateY(-6px); } to { transform: none; } }

/* =====================================================================
   POZVÁNKA NA PRŮZKUM (.survey-invite) — úvodka / konec článku
   ===================================================================== */
.survey-invite {
  display: grid; grid-template-columns: 1.4fr 0.9fr; gap: clamp(var(--space-5), 4vw, var(--space-8));
  align-items: center; background: var(--color-primary-tint); border: 1px solid var(--color-primary-tint-2);
  border-radius: var(--radius-xl); padding: clamp(var(--space-6), 4vw, var(--space-8)); overflow: hidden;
}
.survey-invite__copy h2, .survey-invite__copy h3 { font-size: var(--fs-500); }
.survey-invite__copy p { margin-top: var(--space-3); color: var(--color-ink-soft); }
.survey-invite__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; margin-top: var(--space-5); }
.survey-invite__aside { display: grid; gap: var(--space-3); }
.survey-invite__stat { background: var(--color-surface); border-radius: var(--radius-lg); padding: var(--space-5); text-align: center; }
.survey-invite__stat b { display: block; font-family: var(--font-serif); font-size: var(--fs-500); font-weight: var(--fw-semibold); color: var(--color-primary-ink); line-height: 1; }
.survey-invite__stat span { font-size: var(--fs-50); color: var(--color-ink-muted); }
.survey-invite--compact { grid-template-columns: 1fr; gap: var(--space-5); text-align: left; }
@media (max-width: 760px) {
  .survey-invite { grid-template-columns: 1fr; gap: var(--space-5); }
}
