/* ==========================================================================
   components.css – Wiederverwendbare Bausteine
   Buttons · Section-Heading · Badges · Buttons · Cards · Slider ·
   Quote · Icon-Themes · Feature-Columns · Reviews · Forms
   ========================================================================== */

/* --- Section-Label & Heading ----------------------------------------- */
/* Rote Roofline – Stil wie Hero-Roofline (.hero__kicker), aber etwas kleiner */
.section-label {
  display: inline-block;
  font-family: var(--font-body);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  font-size: 1rem;              /* 16px (Hero-Roofline: 20px) */
  color: var(--color-accent);
  margin-bottom: var(--space-2);
}

.section-heading { margin-bottom: var(--space-5); }
.section-heading__title { font-size: var(--fs-700); }
.section-heading__lead {
  margin-top: var(--space-2);
  max-width: 56ch;
  color: var(--color-text-muted);
}
.section-heading--center {
  text-align: center;
}
.section-heading--center .section-heading__lead { margin-inline: auto; }

/* --- Buttons ---------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.875rem;
  line-height: 1;
  padding: 0.95em 1.5em;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  transition: background var(--transition), color var(--transition),
    border-color var(--transition), transform var(--transition);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
/* Chevron „›" per Border – ersetzt den früheren →-Glyph, scharf & größenrichtig */
.btn__icon {
  width: 0.46em;
  height: 0.46em;
  border-style: solid;
  border-width: 0.12em 0.12em 0 0;
  border-color: currentColor;
  transform: rotate(45deg);
  transition: transform var(--transition);
}
.btn:hover .btn__icon { transform: translateX(3px) rotate(45deg); }

.btn--primary {
  background: var(--color-accent);
  color: var(--color-on-accent);
  box-shadow: 0 8px 20px rgba(214, 43, 43, 0.25);
}
.btn--primary:hover { background: var(--color-accent-hover); }

.btn--ghost {
  background: transparent;
  color: var(--color-heading);
  border-color: color-mix(in srgb, var(--color-text) 45%, transparent);
}
.btn--ghost:hover {
  border-color: var(--color-accent);
  color: var(--color-accent-hover);
}

.btn--block { width: 100%; justify-content: center; }
.btn--sm { padding: 0.7em 1.1em; font-size: 0.8125rem; }
.btn--lg { padding: 1.05em 1.9em; font-size: 0.95rem; }

/* Textlink mit Chevron */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-family: var(--font-display);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.8125rem;
  color: var(--color-accent);
  transition: gap var(--transition), color var(--transition);
}
/* Chevron „›" per Border gezeichnet – scharf, skaliert mit der Schriftgröße */
.link-arrow::after {
  content: "";
  width: 0.46em;
  height: 0.46em;
  border-style: solid;
  border-width: 0.12em 0.12em 0 0;   /* oben + rechts → ergibt nach 45°-Drehung ein Chevron */
  border-color: currentColor;
  transform: rotate(45deg);
  margin-left: -0.05em;
  transition: transform var(--transition);
}
.link-arrow:hover { gap: 0.7rem; color: var(--color-accent-hover); }

/* --- Badge ------------------------------------------------------------ */
.badge {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.6875rem;
  padding: 0.35em 0.7em;
  border-radius: var(--radius-sm);
  background: var(--color-accent);
  color: var(--color-on-accent);
}
.badge--soft {
  background: color-mix(in srgb, var(--color-accent) 18%, transparent);
  color: var(--color-accent-hover);
}

/* --- Book-Card -------------------------------------------------------- */
.book-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.book-card__media {
  position: relative;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--color-panel);
  aspect-ratio: 1 / 1.6;   /* echtes Buchcover-Verhältnis (938×1500) – kein Beschnitt */
}
.book-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 400ms var(--ease);
}
.book-card:hover .book-card__media img { transform: scale(1.05); }
.book-card__badge {
  position: absolute;
  top: var(--space-2);
  left: var(--space-2);
  z-index: 2;
}
.book-card__body { display: flex; flex-direction: column; gap: var(--space-1); }
.book-card__title {
  font-size: 1.0625rem;
  letter-spacing: 0.02em;
}
.book-card__meta {
  font-size: var(--fs-300);
  color: var(--color-heading);   /* gleiche Farbe wie der Buchtitel */
}
.book-card__link { margin-top: var(--space-2); font-size: 1rem; }

/* --- 3D-Buch-Effekt (wiederverwendbar) -------------------------------
   Macht ein Cover wie ein echtes Buch (Seitenschnitt rechts + Schatten).
   Verwendung: auf einen Wrapper legen, der GENAU EIN <img> enthält:

     <div class="book3d"><img src="cover.png" alt="..."></div>

   Hinweise:
   - Der Wrapper braucht Platz nach rechts/unten (KEIN overflow:hidden),
     da der Seitenschnitt rechts heraussteht.
   - Für die kleinen Slider-/Grid-Karten (mit overflow + Hover-Zoom) ist der
     Effekt NICHT gedacht – dort bleiben die Cover flach.
   - Stärke/Optik zentral hier anpassbar (Dicke, Versatz, Neigung, Papierfarbe).
   --------------------------------------------------------------------- */
.book3d {
  position: relative;
  display: block;
}
.book3d > img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: auto;
  border-radius: 2px 3px 3px 2px;
  box-shadow: var(--shadow-cover);
}
/* Seitenschnitt rechts (Fore-Edge) */
.book3d::after {
  content: "";
  position: absolute;
  top: 2.5%;
  right: -6.5%;
  width: 10%;
  height: 95%;
  z-index: 0;
  border-radius: 0 6px 6px 0;
  background: repeating-linear-gradient(90deg, #e4e1d9 0 2px, #b9b5ac 2px 4px);
  box-shadow: inset 10px 0 24px rgba(0, 0, 0, 0.25);
  transform: skewY(-2deg);
}
/* weicher Schlagschatten unter dem Buch */
.book3d::before {
  content: "";
  position: absolute;
  inset: 8% -8% -10% 14%;
  z-index: 0;
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.7), transparent 68%);
  filter: blur(16px);
}

/* --- Foto-Credit (kleine Überschrift am Bildrand) --------------------- */
.photo-credit {
  position: absolute;
  right: 0;
  bottom: 0;
  margin: 0;
  padding: 0.25em 0.6em;
  font-size: 0.6875rem;            /* klein */
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.9);
  background: rgba(0, 0, 0, 0.45);
  border-top-left-radius: var(--radius-sm);
  pointer-events: none;
}

/* --- Social-Icons: Markenfarben (als --brand-Variable) ---------------- */
.social--facebook  { --brand: #1877F2; }
.social--instagram { --brand: #E4405F; }
.social--spotify   { --brand: #1DB954; }
.social--amazon    { --brand: #FF9900; }
.social--tiktok    { --brand: #25F4EE; }

/* Große Social-Buttons mit Label (z. B. Kontaktseite) */
.social-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
  list-style: none;
  padding: 0;
}
.social-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.7em 1.2em;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: var(--color-panel);
  color: var(--brand, var(--color-heading));   /* Icon in Markenfarbe */
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: 0.02em;
  transition: background var(--transition), color var(--transition),
    border-color var(--transition), transform var(--transition);
}
.social-pill svg { width: 20px; height: 20px; }
.social-pill span { color: var(--color-heading); }
.social-pill:hover {
  background: var(--brand, var(--color-accent));
  border-color: var(--brand, var(--color-accent));
  color: #fff;
  transform: translateY(-2px);
}
.social-pill:hover span { color: #fff; }

/* --- Slider (horizontale Karten-Reihe) -------------------------------- */
.slider { position: relative; }
.slider__viewport {
  display: grid;
  grid-auto-flow: column;
  /* Mobil/Tablet: genau 2 ganze Cover pro Ansicht (keine angeschnittenen Karten),
     Breite an den Viewport gekoppelt. Scroll-Snap rückt karteweise weiter. */
  grid-auto-columns: calc((100% - var(--space-4)) / 2);
  gap: var(--space-4);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-inline: 0;
  padding-bottom: var(--space-2);
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--color-border) transparent;
}
.slider__viewport > * { scroll-snap-align: start; }
.slider__viewport::-webkit-scrollbar { height: 6px; }
.slider__viewport::-webkit-scrollbar-thumb {
  background: var(--color-border);
  border-radius: var(--radius-pill);
}

/* Ab ~600px (breitere Phones / kleine Tablets): genau 3 ganze Cover */
@media (min-width: 600px) {
  .slider__viewport {
    grid-auto-columns: calc((100% - 2 * var(--space-4)) / 3);
  }
}

/* Auf großen Screens: festes Raster statt Scrollen */
@media (min-width: 900px) {
  .slider__viewport {
    grid-auto-flow: row;
    grid-template-columns: repeat(var(--slider-cols, 5), 1fr);
    overflow: visible;
  }
}

/* Slider-Steuerung (Pfeile) – nur Mobile/Tablet sichtbar */
.slider__controls {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-3);
}
.slider__btn {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  color: var(--color-heading);
  background: var(--color-panel);
  transition: background var(--transition), border-color var(--transition);
}
.slider__btn:hover { border-color: var(--color-accent); }
.slider__btn[disabled] { opacity: 0.35; cursor: default; }
@media (min-width: 900px) { .slider__controls { display: none; } }

/* --- Karten-Grid (Katalog) ------------------------------------------- */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: clamp(1.25rem, 3vw, 2.25rem);
}

/* --- Quote / Blockquote ---------------------------------------------- */
.quote {
  position: relative;
  padding: var(--space-4) var(--space-4) var(--space-4) var(--space-5);
  border-left: 3px solid var(--color-accent);
  background: color-mix(in srgb, var(--color-panel) 60%, transparent);
  border-radius: 0 var(--radius) var(--radius) 0;
}
.quote__text {
  font-family: var(--font-display);
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0.01em;
  font-size: var(--fs-600);
  line-height: var(--lh-snug);
  color: var(--color-heading);
}
.quote__cite {
  display: block;
  margin-top: var(--space-3);
  font-size: var(--fs-400);
  font-weight: 400;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-accent);
}

/* --- Icon-Theme-Card ("Was mich bewegt") ----------------------------- */
.theme-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: clamp(1.25rem, 3vw, 2rem);
}
.theme-card {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}
.theme-card__icon {
  width: 64px;
  height: 64px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-pill);
  background: var(--color-panel);
  border: 1px solid var(--color-border);
  color: var(--color-accent);
  transition: transform var(--transition), border-color var(--transition);
}
.theme-card:hover .theme-card__icon {
  transform: translateY(-3px);
  border-color: var(--color-accent);
}
.theme-card__title {
  font-size: 1rem;
  letter-spacing: 0.06em;
}
.theme-card__text { font-size: var(--fs-300); color: var(--color-text-muted); }

/* --- Feature-Column ("Hinter den Kulissen") -------------------------- */
.feature {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.feature__icon { color: var(--color-accent); }
.feature__title { font-size: 1.0625rem; }
.feature__text { font-size: 0.9375rem; }

/* --- Card (generisch: News/Event/Review) ----------------------------- */
.card {
  background: var(--color-panel);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color var(--transition), transform var(--transition);
  display: flex;
  flex-direction: column;
}
.card:hover { border-color: color-mix(in srgb, var(--color-accent) 50%, var(--color-border)); }
.card__media { aspect-ratio: 16 / 10; overflow: hidden; }
.card__media img { width: 100%; height: 100%; object-fit: cover; }
.card__body { padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); flex: 1; }
.card__kicker {
  font-size: var(--fs-300);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-accent);
}
.card__title { font-size: 1.125rem; }
.card__text { font-size: 0.9375rem; flex: 1; }
.card__link { margin-top: var(--space-2); }

/* Datums-Badge (Lesungen) */
.date-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  border-radius: var(--radius-sm);
  background: var(--color-accent);
  color: var(--color-on-accent);
  line-height: 1;
  flex-shrink: 0;
}
.date-badge__day { font-family: var(--font-display); font-weight: 700; font-size: 1.5rem; }
.date-badge__month { font-size: 0.625rem; text-transform: uppercase; letter-spacing: 0.1em; margin-top: 2px; }

/* --- Review-Card ("Pressestimmen") ----------------------------------- */
.review {
  background: var(--color-panel);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.review__stars { color: var(--color-accent); letter-spacing: 0.15em; font-size: 0.9rem; }
.review__text {
  color: var(--color-text);
  font-style: italic;
}
.review__cite {
  font-size: var(--fs-300);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-dim);
  font-style: normal;
}

/* --- Forms ------------------------------------------------------------ */
.field { display: flex; flex-direction: column; gap: var(--space-1); }
.field label { font-size: 0.875rem; color: var(--color-text-muted); }

.input,
.field input,
.field textarea {
  width: 100%;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text);
  padding: 0.85em 1em;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.field textarea { min-height: 140px; resize: vertical; }
.field input::placeholder,
.field textarea::placeholder { color: var(--color-text-dim); }
.field input:focus-visible,
.field textarea:focus-visible {
  border-color: var(--color-accent);
  box-shadow: var(--focus-ring);
}
.field input[aria-invalid="true"],
.field textarea[aria-invalid="true"] { border-color: var(--color-accent); }
.field__error {
  font-size: var(--fs-300);
  color: var(--color-accent-hover);
  min-height: 1em;
}

.form-message {
  font-size: 0.9375rem;
  min-height: 1.4em;
}
.form-message.is-success { color: #57c98a; }
.form-message.is-error { color: var(--color-accent-hover); }
