/* =================================================================
   VERFLIXT IM KOPF · Die Besetzung (Kopf-WG)
   Baut auf style.css auf · reuse aller Tokens · Charakter-Galerie
   ================================================================= */

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* =================================================================
   Hero
   ================================================================= */

.cast-hero {
  padding-top: clamp(2.75rem, 6vw, 4.5rem);
  padding-bottom: clamp(2.25rem, 5vw, 3.5rem);
  background:
    radial-gradient(ellipse 55% 60% at 14% 12%, rgba(26, 147, 166, 0.10) 0%, transparent 70%),
    radial-gradient(ellipse 55% 55% at 88% 24%, rgba(209, 68, 56, 0.09) 0%, transparent 70%);
  border-bottom: 1px solid var(--line);
}
.cast-hero-headline { margin-bottom: 1.25rem; }
.cast-hero-sub {
  font-size: var(--fs-lead);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 660px;
  margin: 0;
}

/* =================================================================
   Gruppen-Sektionen
   ================================================================= */

.cast-group {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}
.cast-group--wg     { background: var(--bg); }
.cast-group--gaeste {
  background: var(--bg-alt);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cast-group-intro {
  max-width: 660px;
  margin: 0 0 2.75rem;
  font-size: var(--fs-lead);
  line-height: 1.5;
  color: var(--ink-soft);
}

/* =================================================================
   Charakter-Grid
   ================================================================= */

.char-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 262px), 1fr));
  gap: clamp(1rem, 2vw, 1.5rem);
}
.char-grid > li {
  display: flex;
}

/* =================================================================
   Charakter-Karte
   ================================================================= */

.char-card {
  --ca: var(--accent);
  --ca-deep: var(--accent-deep);
  --ca-soft: var(--accent-soft);
  display: flex;
  flex-direction: column;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  transition: transform var(--transition-base),
              box-shadow var(--transition-base),
              border-color var(--transition-base);
}
/* Akzent-Rotation aus der Cover-Palette */
.char-grid > li:nth-child(3n+2) .char-card {
  --ca: var(--accent-2);  --ca-deep: var(--accent-2-deep); --ca-soft: var(--accent-2-soft);
}
.char-grid > li:nth-child(3n+3) .char-card {
  --ca: var(--accent-3);  --ca-deep: #9C7A14;              --ca-soft: rgba(232, 185, 69, 0.18);
}

.char-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
  border-color: var(--ca);
}

/* ---------- Foto-Bühne ---------- */
.char-photo {
  position: relative;
  aspect-ratio: 4 / 3.45;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  border-bottom: 1px solid var(--line);
  background:
    radial-gradient(ellipse 72% 58% at 50% 36%, rgba(255, 255, 255, 0.55) 0%, transparent 72%),
    var(--ca-soft);
}
.char-photo img {
  width: 80%;
  max-width: 230px;
  height: auto;
  display: block;
  margin-bottom: -2px;
  filter: drop-shadow(0 9px 14px rgba(31, 26, 38, 0.16));
  transition: transform var(--transition-base);
}
.char-card:hover .char-photo img { transform: translateY(-3px) scale(1.02); }

/* ---------- Text ---------- */
.char-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1.3rem 1.4rem 1.5rem;
}
.char-region {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ca-deep);
  margin: 0 0 0.55rem;
}
.char-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-variation-settings: 'wght' 700, 'wdth' 100, 'opsz' 32;
  font-size: 1.45rem;
  line-height: 1.06;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0 0 0.3rem;
}
.char-role {
  font-family: var(--font-display);
  font-weight: 500;
  font-style: italic;
  font-variation-settings: 'wght' 500, 'wdth' 100, 'opsz' 20;
  font-size: 1rem;
  line-height: 1.25;
  color: var(--ca-deep);
  margin: 0 0 0.85rem;
}
.char-desc {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0;
}


/* =================================================================
   Abschluss · CTA (invertiert)
   ================================================================= */

.cast-closing {
  position: relative;
  color: var(--bg-elev);
  border-top: 1px solid var(--line);
  background:
    radial-gradient(ellipse 50% 50% at 15% 0%, rgba(26, 147, 166, 0.20) 0%, transparent 65%),
    radial-gradient(ellipse 60% 60% at 85% 100%, rgba(209, 68, 56, 0.20) 0%, transparent 65%),
    var(--bg-inverse);
}
.cast-closing .section-label { color: rgba(255, 255, 255, 0.55); }
.cast-closing .section-label .rule { background: rgba(255, 255, 255, 0.4); }
.cast-closing .section-label .title { color: var(--bg-elev); }
.cast-closing .section-headline { color: var(--bg-elev); }
.cast-closing .section-headline em { border-bottom-color: var(--accent); }
.cast-closing-sub {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-variation-settings: 'wght' 400, 'wdth' 100, 'opsz' 24;
  font-size: clamp(1rem, 1.6vw, 1.2rem);
  color: rgba(255, 255, 255, 0.72);
  margin: 0 0 2.5rem;
}
.cast-closing-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.1rem;
}
.cast-closing .btn-primary {
  background: var(--bg-elev);
  color: var(--ink);
  border-color: var(--bg-elev);
}
.cast-closing .btn-primary:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--bg-elev);
}
.cast-closing-back {
  font-family: var(--font-mono);
  font-size: var(--fs-micro);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.cast-closing-back:hover { color: var(--bg-elev); }

/* =================================================================
   Reveal (nutzt .reveal/.is-visible aus style.css)
   ================================================================= */

.char-card.reveal { will-change: opacity, transform; }

/* =================================================================
   Responsive
   ================================================================= */

@media (max-width: 560px) {
  .char-grid { gap: 0.85rem; }
  .char-body { padding: 1.1rem 1.15rem 1.25rem; }
  .char-name { font-size: 1.3rem; }
}

@media (prefers-reduced-motion: reduce) {
  .char-card, .char-photo img { transition: none; }
  .char-card:hover { transform: none; }
  .char-card:hover .char-photo img { transform: none; }
}
