/*
Theme Name: Rothfuss Modern
Theme URI: https://www.thomas-rothfuss.de/
Author: Markus Pfahler
Description: Modernes, responsives Theme fuer den Saenger und Autor Thomas Rothfuss. Mit Streaming-, Social- und Video-Integration.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: rothfuss
*/

:root {
  --bg: #fbf7f5;            /* warmes Creme */
  --bg-soft: #f4ebe9;       /* zarter Rosé-Ton */
  --card: #ffffff;
  --text: #2b1a1f;          /* dunkles Weinrot-Schwarz */
  --muted: #7c6a6e;
  --accent: #6e2433;        /* tiefes Bordeaux (Logo "THOMAS") */
  --accent-2: #a8556a;      /* Altrosa (Logo "Rothfuß") */
  --accent-soft: #f0dde2;
  --line: rgba(110,36,51,.14);
  --radius: 18px;
  --shadow: 0 16px 44px rgba(110,36,51,.14);
  --maxw: 1140px;
  --font: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
  --display: "Playfair Display", Georgia, serif;
  --script: "Praise", "Playfair Display", cursive;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--accent); text-decoration: none; transition: color .2s; }
a:hover { color: var(--accent-2); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.section { padding: 96px 0; }
.section--soft { background: var(--bg-soft); }
.eyebrow {
  display: inline-block;
  text-transform: uppercase; letter-spacing: .18em; font-size: .74rem;
  color: var(--accent); font-weight: 700; margin: 0 0 14px;
  background: rgba(110, 36, 51, .08);
  border: 1px solid rgba(110, 36, 51, .18);
  padding: 6px 16px; border-radius: 999px; line-height: 1;
}
.eyebrow[style*="center"] { display: block; width: fit-content; margin-left: auto; margin-right: auto; }
.hero .eyebrow { display: inline-block; background: none; border: 0; padding: 0; letter-spacing: .22em; }
h1,h2,h3 { font-family: var(--display); font-weight: 700; line-height: 1.15; }
/* H1 in der Schreibschrift "Praise" */
h1 { font-family: var(--script); font-weight: 400; line-height: 1.2; letter-spacing: 0; }
h2.section-title { font-size: clamp(2rem, 4vw, 3rem); margin: 0 0 18px; }
.lead { color: var(--muted); font-size: 1.12rem; max-width: 60ch; }

/* ---------- Autor-Seite ---------- */
.autor-foto { margin: 28px 0; }
.autor-foto img { width: 100%; height: auto; display: block; border-radius: 14px; box-shadow: 0 18px 40px rgba(110,36,51,.18); }
.autor-buecher { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin: 28px 0 8px; }
.autor-buecher figure { margin: 0; text-align: center; }
.autor-buecher img { width: 100%; height: auto; display: block; border-radius: 10px; box-shadow: 0 12px 28px rgba(110,36,51,.16); }
.autor-buecher figcaption { margin-top: 10px; color: var(--muted); font-size: .95rem; }
@media (max-width: 560px) { .autor-buecher { grid-template-columns: 1fr; } }
/* Buch-Reihe (Autor-Seite): drei kompakte Cover nebeneinander */
/* Bücher als 2x2-Raster mit Boxen: Cover links, Infos rechts */
.buch-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin: 28px 0 8px; }
.buch-grid--row { grid-template-columns: repeat(3, 1fr); margin-top: 24px; }
.buch-box { display: flex; align-items: center; gap: 22px; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px 24px; box-shadow: 0 6px 18px rgba(110,36,51,.06); transition: transform .2s, box-shadow .25s; }
.buch-box--feature { gap: 36px; padding: 36px 40px; margin: 28px 0 0; background: var(--card); border-color: var(--line); }
.buch-box--feature .buch-cover { flex: 0 0 230px; }
.buch-box--feature .buch-cover img { width: 230px; box-shadow: -14px 18px 32px rgba(0,0,0,.32); }
.buch-box--feature .buch-info strong { font-size: 1.5rem; }
.buch-box--feature .buch-meta { font-size: .92rem; }
.buch-text { margin: 10px 0 14px; color: var(--text); font-size: .96rem; line-height: 1.7; }
.buch-grid--row .buch-box { flex-direction: column; align-items: flex-start; gap: 18px; text-align: left; }
.buch-grid--row .buch-cover img { width: 110px; }
.buch-box:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.buch-cover { flex: 0 0 96px; perspective: 1000px; }
.buch-cover img { width: 96px; height: auto; display: block; border-radius: 4px; transform: rotateY(20deg); transform-origin: left center; box-shadow: -10px 14px 24px rgba(0,0,0,.30); transition: transform .4s ease, box-shadow .4s ease; }
.buch-box:hover .buch-cover img { transform: rotateY(8deg); box-shadow: -8px 12px 22px rgba(0,0,0,.26); }
.buch-info { flex: 1 1 auto; min-width: 0; }
.buch-info strong { display: block; color: var(--text); font-family: var(--display); font-size: 1.08rem; line-height: 1.3; margin-bottom: 6px; }
.buch-badge { display: inline-block; background: var(--accent); color: #fff; font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 3px 11px; border-radius: 999px; margin-bottom: 8px; }
.buch-badge--soft { background: var(--accent-2); }
.buch-meta { display: block; margin-top: 4px; color: var(--muted); font-size: .82rem; line-height: 1.6; }
.buch-status { display: inline-flex; align-items: center; gap: 7px; margin-top: 12px; padding: 5px 13px; border-radius: 999px; font-size: .78rem; font-weight: 600; border: 1px solid transparent; }
.buch-status::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: currentColor; flex: 0 0 auto; }
.buch-status--available { color: #2f7d4f; background: rgba(47,125,79,.1); border-color: rgba(47,125,79,.25); }
.buch-status--request { color: var(--accent); background: rgba(110,36,51,.08); border-color: rgba(110,36,51,.2); }
.buch-status--soldout { color: var(--muted); background: rgba(124,106,110,.1); border-color: rgba(124,106,110,.22); }
.buch-shop { margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); }
.buch-shop-title { display: block; font-family: var(--display); font-size: 1.02rem; color: var(--accent); margin-bottom: 14px; }
.buch-shop-grid { display: flex; flex-wrap: wrap; gap: 22px 36px; }
.shop-retailer { display: flex; flex-direction: column; gap: 8px; }
.shop-name { font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.shop-link { display: inline-flex; align-items: center; justify-content: space-between; gap: 14px; min-width: 168px; padding: 9px 15px; border-radius: 10px; background: #fff; border: 1px solid var(--accent-2); color: var(--accent); font-size: .9rem; font-weight: 600; text-decoration: none; transition: background .2s, color .2s, transform .15s; }
.shop-link:hover { background: var(--accent); color: #fff; transform: translateY(-2px); }
.shop-price { font-variant-numeric: tabular-nums; font-weight: 700; }
@media (max-width: 560px) { .shop-link { min-width: 0; width: 100%; } }
@media (max-width: 760px) { .buch-grid, .buch-grid--row { grid-template-columns: 1fr; } .buch-box--feature { flex-direction: column; align-items: flex-start; gap: 22px; padding: 26px 24px; } }
/* Schäferbarde-Intro: Text links, rundes (quadratisch zugeschnittenes) Foto rechts */
.barde-intro { display: flex; align-items: center; gap: 40px; margin: 28px 0 8px; }
.barde-intro-text { flex: 1 1 auto; }
.barde-intro-text > :first-child { margin-top: 0; }
.barde-rund { flex: 0 0 auto; width: 280px; max-width: 38%; margin: 0; }
.barde-rund img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 50%; display: block;
  box-shadow: 0 18px 40px rgba(110,36,51,.22); }
@media (max-width: 720px) {
  .barde-intro { flex-direction: column-reverse; gap: 20px; }
  .barde-rund { width: 200px; max-width: 60%; }
}

/* ---------- Diskografie ---------- */
.disco-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 28px; margin: 28px 0 8px; }
.disc-card { display: block; }
/* Karte = reines Cover; Infos liegen als Overlay darauf */
.disc-cover-wrap { position: relative; border-radius: 16px; overflow: hidden; aspect-ratio: 1 / 1;
  box-shadow: 0 14px 32px rgba(110,36,51,.18); transition: box-shadow .35s, transform .35s; }
.disc-cover-wrap:hover { transform: translateY(-4px); box-shadow: 0 22px 44px rgba(110,36,51,.3); }
.disc-cover { width: 100%; height: 100%; object-fit: cover; display: block; }
/* Overlay: zentriert; getrennte Ebenen (Blur / Tönung / Text) – keine Container-Opacity-Animation,
   damit der Backdrop-Blur nicht erst am Ende der Animation einspringt */
.disc-overlay { position: absolute; inset: 0; display: flex; flex-direction: column;
  justify-content: flex-end; align-items: center; gap: 6px; padding: 18px 16px; color: #fff; text-align: center; }
/* Blur-Ebene: unten am stärksten, nach oben hin auslaufend; weicht sanft ein */
.disc-overlay::before { content: ""; position: absolute; inset: 0; z-index: 0;
  -webkit-backdrop-filter: blur(0px) saturate(1.1); backdrop-filter: blur(0px) saturate(1.1);
  -webkit-mask-image: linear-gradient(to top, #000 30%, rgba(0,0,0,.4) 65%, transparent 100%);
  mask-image: linear-gradient(to top, #000 30%, rgba(0,0,0,.4) 65%, transparent 100%);
  transition: -webkit-backdrop-filter .4s ease, backdrop-filter .4s ease; }
/* Rote Tönung als eigene Ebene (separat einblendbar) */
.disc-overlay::after { content: ""; position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(to top, rgba(110,36,51,.92) 0%, rgba(110,36,51,.6) 55%, rgba(110,36,51,.3) 100%);
  opacity: 0; transition: opacity .4s ease; }
.disc-overlay > * { position: relative; z-index: 1; opacity: 0; transform: translateY(6px);
  transition: opacity .35s ease, transform .35s ease; }
.disc-cover-wrap:hover .disc-overlay::before,
.disc-cover-wrap:focus-within .disc-overlay::before { -webkit-backdrop-filter: blur(9px) saturate(1.1); backdrop-filter: blur(9px) saturate(1.1); }
.disc-cover-wrap:hover .disc-overlay::after,
.disc-cover-wrap:focus-within .disc-overlay::after { opacity: 1; }
.disc-cover-wrap:hover .disc-overlay > *,
.disc-cover-wrap:focus-within .disc-overlay > * { opacity: 1; transform: none; }
.disc-title { font-family: var(--font); color: #fff; font-size: 1.02rem; font-weight: 700; line-height: 1.25; margin: 0; }
.disc-overlay .disc-sub { color: #fff; font-size: .82rem; margin: 0 0 12px; }
.disc-links { display: flex; gap: 9px; flex-wrap: wrap; justify-content: center; }
.disc-btn { width: 40px; height: 40px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.92); color: var(--accent); transition: background .2s, color .2s, transform .2s, box-shadow .2s; }
.disc-btn svg { width: 20px; height: 20px; }
.disc-btn.amazon svg { width: 24px; height: 24px; }
.disc-btn:not(.is-disabled):hover { transform: translateY(-3px); box-shadow: 0 8px 18px rgba(0,0,0,.28); }
.disc-btn.spotify:not(.is-disabled):hover { background: #1DB954; color: #fff; }
.disc-btn.apple:not(.is-disabled):hover   { background: #fa2d48; color: #fff; }
.disc-btn.tidal:not(.is-disabled):hover    { background: #0a0a0a; color: #fff; }
.disc-btn.amazon:not(.is-disabled):hover   { background: #25D1DA; color: #06222b; }
.disc-btn.is-disabled { background: rgba(255,255,255,.28); color: rgba(255,255,255,.55); cursor: not-allowed; }
/* Touch-Geräte ohne Hover: Overlay dauerhaft sichtbar */
@media (hover: none) {
  .disc-overlay::before { -webkit-backdrop-filter: blur(9px) saturate(1.1); backdrop-filter: blur(9px) saturate(1.1); }
  .disc-overlay::after { opacity: 1; }
  .disc-overlay > * { opacity: 1; transform: none; }
}
@media (max-width: 560px) { .disco-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .disc-overlay { padding: 12px; } .disc-title { font-size: .92rem; } .disc-btn { width: 36px; height: 36px; } .disc-btn svg { width: 18px; height: 18px; } }

/* ---------- Ansicht-Umschalter (Raster / Coverflow) ---------- */
.disco-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 4px; }
.disco-head--toggle-only { justify-content: flex-end; }
.disco-head h3 { margin: 0; }
.disco-toggle { display: inline-flex; gap: 4px; padding: 4px; border-radius: 999px; background: #f3e9eb; flex: 0 0 auto; }
.disco-tab { border: 0; cursor: pointer; color: var(--accent); background: transparent;
  width: 38px; height: 38px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s; }
.disco-tab svg { width: 19px; height: 19px; display: block; }
.disco-tab.is-active { background: var(--accent); color: #fff; }
.disco-tab:not(.is-active):hover { background: rgba(110,36,51,.12); }
[data-view-panel][hidden] { display: none; }

/* ---------- Coverflow (iPod-Stil) ---------- */
/* overflow-x: clip begrenzt nur seitlich (kein Seiten-Scroll), lässt aber die
   Reflektion nach unten frei – overflow:hidden hätte sie abgeschnitten */
.disco-flow { position: relative; margin: 8px 0 8px; }
/* Nur die Bühne seitlich beschneiden (verhindert Seiten-Scroll durch weit entfernte Cover);
   die Nav-Buttons liegen außerhalb, damit ihre Schatten nicht abgeschnitten werden */
.flow-viewport { overflow-x: clip; }
.flow-stage { position: relative; height: 300px; margin: 0 0 96px; perspective: 1200px;
  display: flex; align-items: center; justify-content: center; overflow: visible; }
.flow-item { position: absolute; width: 264px; height: 264px; margin: 0; left: 50%; top: 50%; will-change: transform;
  transform: translate(-50%, -50%); transition: transform .5s cubic-bezier(.2,.7,.2,1), opacity .5s, filter .5s; cursor: pointer; }
.flow-cover { position: relative; width: 100%; height: 100%; }
.flow-item img { width: 100%; height: 100%; object-fit: cover; border-radius: 12px; display: block;
  box-shadow: 0 22px 44px rgba(0,0,0,.32);
  -webkit-box-reflect: below 8px linear-gradient(transparent 58%, rgba(0,0,0,.25)); }
/* Firefox kennt -webkit-box-reflect nicht: Spiegelung dort über ein Pseudo-Element nachbauen */
@supports not ((-webkit-box-reflect: below) or (box-reflect: below)) {
  .flow-cover::after { content: ""; position: absolute; left: 0; right: 0; top: calc(100% + 8px); height: 80%;
    background-image: var(--cover); background-size: cover; background-position: center bottom; border-radius: 12px;
    transform: scaleY(-1); pointer-events: none;
    -webkit-mask-image: linear-gradient(to top, rgba(0,0,0,.25) 0%, transparent 42%);
    mask-image: linear-gradient(to top, rgba(0,0,0,.25) 0%, transparent 42%); }
}
.flow-item.is-active { cursor: default; }
/* Overlay (Titel/Jahr/Buttons) wie in der Rasteransicht – nur am aktiven Cover beim Hover */
/* Kein overflow:hidden, damit die Button-Schatten nicht abgeschnitten werden;
   stattdessen runden die Blur-/Tönungs-Ebenen selbst ab */
.flow-cover .disc-overlay { border-radius: 12px; }
.flow-cover .disc-overlay::before,
.flow-cover .disc-overlay::after { border-radius: 12px; }
.flow-item:not(.is-active) .disc-overlay { display: none; }
.flow-item.is-active:hover .disc-overlay::before { -webkit-backdrop-filter: blur(9px) saturate(1.1); backdrop-filter: blur(9px) saturate(1.1); }
.flow-item.is-active:hover .disc-overlay::after { opacity: 1; }
.flow-item.is-active:hover .disc-overlay > * { opacity: 1; transform: none; }
.flow-nav { position: absolute; top: 130px; transform: translateY(-50%); z-index: 30; width: 46px; height: 46px; border: 0; cursor: pointer;
  border-radius: 50%; background: #fff; color: var(--accent); display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 22px rgba(110,36,51,.22); transition: transform .2s, box-shadow .2s; }
.flow-nav svg { width: 22px; height: 22px; display: block; }
.flow-nav:hover { transform: translateY(-50%) scale(1.08); box-shadow: 0 12px 28px rgba(110,36,51,.3); }
.flow-prev { left: 0; }
.flow-next { right: 0; }
@media (max-width: 560px) {
  .flow-stage { height: 230px; margin-bottom: 80px; }
  .flow-item { width: 180px; height: 180px; }
  .flow-nav { top: 100px; width: 40px; height: 40px; }
}

/* ---------- Header / Nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: transparent;
}
/* Weiße Menüfläche als Pseudo-Element, damit die Logo-Kontur dahinter liegen kann */
.site-header::after {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background: #fff;
  border-bottom: 1px solid var(--line);
}
/* Inhalte über die weiße Fläche heben */
.site-header .topbar { position: relative; z-index: 2; }
.site-header .nav { position: relative; z-index: 2; }
/* Kontur-Kopie des Logos hinter der weißen Fläche */
.brand-bg { position: absolute; left: 0; right: 0; bottom: 0; z-index: -1; pointer-events: none; }
.brand-bg .nav--ghost { justify-content: flex-start; }
.brand-bg .brand { z-index: auto; }
.brand-logo-outline {
  filter:
    drop-shadow(1px 0 0 var(--line))
    drop-shadow(-1px 0 0 var(--line))
    drop-shadow(0 1px 0 var(--line))
    drop-shadow(0 -1px 0 var(--line));
}
/* Kontur skaliert mit, wenn man über das echte Logo fährt */
.site-header:has(.brand:hover) .brand-logo-outline { transform: scale(1.06); }

/* Streaming-Leiste über dem Menü – beim Runterscrollen einklappen */
.topbar { background: var(--accent); color: #f3dde2; overflow: hidden; max-height: 80px; opacity: 1;
  transition: max-height .35s ease, opacity .25s ease; }
.site-header.scrolled .topbar { max-height: 0; opacity: 0; }
.topbar-inner {
  max-width: var(--maxw); margin: 0 auto;
  display: flex; align-items: center; justify-content: flex-end; flex-wrap: wrap;
  gap: 18px; padding: 7px 24px;
}
.topbar-label { font-size: .8rem; letter-spacing: .04em; color: #e7c2cb; }
.topbar-link { display: inline-flex; align-items: center; gap: 6px; color: #f6e3e8; font-size: .82rem; font-weight: 600; }
.topbar-link svg { width: 15px; height: 15px; }
.topbar-link:hover { color: #fff; }
.topbar-sep { width: 1px; align-self: stretch; min-height: 16px; background: rgba(255,255,255,.22); margin: 0 4px; }

.nav {
  position: relative;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 24px; max-width: var(--maxw); margin: 0 auto;
}

/* Logo: größer und über das Menü überlappend, ohne Kasten – mit weißer Kontur */
.brand { position: relative; z-index: 60; display: flex; align-items: center; }
.brand-logo {
  display: block; height: 158px; width: auto;
  /* Deutliche Überlappung nach oben und unten über das Menü hinaus */
  margin-top: -42px;
  margin-bottom: -74px;
  transform-origin: left center;
  transition: height .3s ease, margin .3s ease, transform .25s ease;
}
/* Beim Hover etwas größer */
.brand:hover .brand-logo { transform: scale(1.06); }
/* Beim Runterscrollen kleiner */
.site-header.scrolled .brand-logo { height: 78px; margin-top: -8px; margin-bottom: -28px; }
.brand span { color: var(--accent-2); }

/* Menülinks mit Icons */
.nav-links { display: flex; gap: 22px; list-style: none; margin: 0; padding: 0; align-items: center; }
.nav-links a { display: inline-flex; align-items: center; gap: 7px; color: var(--text); font-size: .95rem; font-weight: 500; }
.nav-links a:hover { color: var(--accent); }
.menu-ico { width: 18px; height: 18px; flex: 0 0 auto; color: var(--accent-2); }
.nav-links a:hover .menu-ico { color: var(--accent); }
.nav-toggle { display: none; background: none; border: 0; color: var(--accent); font-size: 1.6rem; cursor: pointer; }

/* ---------- Dropdown-Untermenü ---------- */
.nav-links li { position: relative; }
.nav-links .menu-caret { width: 14px; height: 14px; flex: 0 0 auto; transition: transform .2s; color: var(--accent-2); }
.nav-links .menu-item-has-children:hover > a .menu-caret,
.nav-links .menu-item-has-children.open > a .menu-caret { transform: rotate(180deg); color: var(--accent); }
.nav-links .sub-menu {
  position: absolute; top: calc(100% + 6px); left: -8px; min-width: 230px;
  list-style: none; margin: 0; padding: 8px;
  background: #fff; border: 1px solid var(--line); border-radius: 14px;
  box-shadow: 0 18px 44px rgba(110,36,51,.18);
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease; z-index: 60;
}
.nav-links .menu-item-has-children:hover > .sub-menu,
.nav-links .menu-item-has-children:focus-within > .sub-menu,
.nav-links .menu-item-has-children.open > .sub-menu {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.nav-links .sub-menu li { width: 100%; }
.nav-links .sub-menu a { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 9px; white-space: nowrap; width: 100%; }
.nav-links .sub-menu a:hover { background: rgba(110,36,51,.08); color: var(--accent); }

/* ---------- Hero ---------- */
.hero {
  position: relative; min-height: 62vh; display: flex; align-items: center;
  padding: 56px 0;
  background:
    linear-gradient(90deg, rgba(251,247,245,.97) 0%, rgba(251,247,245,.82) 42%, rgba(251,247,245,.30) 100%),
    radial-gradient(70% 60% at 80% 15%, rgba(168,85,106,.20), transparent 60%),
    var(--bg-soft);
  overflow: hidden;
}
.hero--photo {
  background:
    linear-gradient(90deg, rgba(251,247,245,.97) 0%, rgba(251,247,245,.80) 40%, rgba(251,247,245,.25) 100%),
    var(--hero-img) center center/cover no-repeat,
    var(--bg-soft);
}
.hero-inner { position: relative; z-index: 2; }
.hero h1 { font-size: clamp(2.8rem, 7vw, 5.2rem); margin: 0 0 18px; color: var(--accent); line-height: 1.05; }
.hero h1 .accent { color: var(--accent-2); }
.hero p { font-size: 1.25rem; color: var(--text); max-width: 52ch; margin: 0 0 32px; }
.hero-cta { display: flex; gap: 16px; flex-wrap: wrap; }

.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 26px; border-radius: 999px; font-weight: 600; font-size: .98rem;
  cursor: pointer; border: 1px solid transparent; transition: transform .15s, box-shadow .2s, background .2s;
}
.btn:hover { transform: translateY(-2px); }
.btn .menu-ico { width: 19px; height: 19px; color: currentColor; }
.btn-primary { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #fff; box-shadow: 0 10px 26px rgba(110,36,51,.30); }
.btn-primary:hover { color: #fff; }
.btn-ghost { background: #fff; border-color: var(--line); color: var(--accent); }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
.btn-logo { height: 22px; width: auto; display: block; }
.btn-tyrolis { gap: 12px; }

/* ---------- Hero-Slider ---------- */
.hero-slider { position: relative; overflow: hidden; }
.hero-inner--split { display: flex; align-items: center; gap: 48px; }
.hero-inner--split .hero-text { flex: 1 1 auto; min-width: 0; }
.slide-cover {
  flex: 0 0 auto; width: 320px; max-width: 34%;
  border-radius: 16px; box-shadow: var(--shadow);
  border: 4px solid #fff;
}
.slide-cover--round {
  width: 340px; aspect-ratio: 1 / 1; object-fit: cover; object-position: center 20%;
  border-radius: 50%; border-width: 6px;
}
@media (max-width: 820px) {
  .hero-inner--split { flex-direction: column; align-items: flex-start; gap: 22px; }
  .slide-cover { width: 180px; max-width: 50%; }
  .slide-cover--round { width: 200px; }
}
.hero-slider .slides { display: flex; transition: transform .6s cubic-bezier(.5,0,.2,1); }
.hero-slider .slide { flex: 0 0 100%; min-width: 100%; }
.slider-arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 5;
  width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--line);
  background: rgba(255,255,255,.85); color: var(--accent); font-size: 1.9rem; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 18px rgba(110,36,51,.15); transition: background .2s, transform .2s;
}
.slider-arrow:hover { background: #fff; transform: translateY(-50%) scale(1.07); }
.slider-ico { width: 24px; height: 24px; display: block; }
.slider-prev { left: 22px; }
.slider-next { right: 22px; }
.slider-dots { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); display: flex; gap: 10px; z-index: 5; }
.slider-dot { width: 12px; height: 12px; border-radius: 50%; border: 2px solid var(--accent); background: transparent; cursor: pointer; padding: 0; transition: background .2s, transform .2s; }
.slider-dot.is-active { background: var(--accent); transform: scale(1.2); }
@media (max-width: 560px) { .slider-arrow { width: 38px; height: 38px; } .slider-ico { width: 20px; height: 20px; } .slider-prev { left: 10px; } .slider-next { right: 10px; } }

/* ---------- Streaming bar ---------- */
.streaming { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--bg); }
.streaming-inner { display: flex; align-items: center; flex-wrap: wrap; gap: 18px; padding: 28px 0; justify-content: center; }
.streaming-label { color: var(--muted); font-weight: 600; letter-spacing: .04em; margin-right: 8px; }
.stream-link {
  display: inline-flex; align-items: center; gap: 9px; padding: 12px 20px;
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  color: var(--text); font-weight: 600; font-size: .92rem; transition: all .2s;
}
.stream-link:hover { border-color: var(--accent); transform: translateY(-2px); color: var(--accent); background: var(--accent-soft); }
.stream-link svg { width: 20px; height: 20px; }

/* ---------- Album feature ---------- */
.album { display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center; }
.album-cover {
  position: relative; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow);
  aspect-ratio: 1/1;
}
.album-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.badge-new { position: absolute; top: 12px; left: 12px; z-index: 2; background: var(--accent); color:#fff; font-weight:800; font-size:.82rem; letter-spacing:.12em; padding:9px 18px; border-radius:999px; border:2px solid #fff; box-shadow:0 6px 18px rgba(0,0,0,.28); text-transform: uppercase; }
/* Streaming-Icons (wie im Coverflow), auf hellem Hintergrund getönt */
.album-streams { margin-top: 24px; }
.album-streams .disc-links { justify-content: flex-start; gap: 12px; }
.album-streams .disc-btn { width: 46px; height: 46px; background: #fff; color: var(--accent); box-shadow: 0 4px 14px rgba(110,36,51,.12); }
.album-streams .disc-btn svg { width: 22px; height: 22px; }
.album-streams .disc-btn.amazon svg { width: 27px; height: 27px; }
.album-streams .disc-btn.is-disabled { background: #ededed; color: #c2c2c2; }
.album-buy { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 22px; }

/* ---------- About ---------- */
.about { display: grid; grid-template-columns: 1.2fr .8fr; gap: 56px; align-items: start; }
.about-media { display: flex; flex-direction: column; align-items: center; justify-content: center; }
.about-portrait { width: 320px; height: 320px; max-width: 100%; aspect-ratio: 1/1; object-fit: cover; object-position: center top; border-radius: 50%; box-shadow: var(--shadow); }
.stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 0; width: 100%; }
.stat { background: var(--accent-soft); border: 1px solid rgba(110,36,51,.12); border-radius: 18px; padding: 18px; aspect-ratio: 1/1; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 6px; }
.stat b { font-family: var(--display); font-size: 1.9rem; color: var(--accent); display:block; line-height: 1; }
.stat span { color: var(--muted); font-size: .85rem; }

/* ---------- Videos ---------- */
.video-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 28px; }
.video-card { background: var(--card); border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow); }
.video-frame { position: relative; aspect-ratio: 16/9; }
.video-frame iframe { position:absolute; inset:0; width:100%; height:100%; border:0; }
.video-card h3 { margin: 0; padding: 18px 20px; font-size: 1.05rem; }
.video-card.is-hidden { display: none; }
.video-filter { display: inline-flex; flex-wrap: wrap; gap: 4px; padding: 4px; border-radius: 999px; background: #f3e9eb; margin-bottom: 8px; }
.video-filter-btn { border: 0; cursor: pointer; color: var(--accent); background: transparent; padding: 9px 20px; border-radius: 999px; font-weight: 600; font-size: .95rem; transition: background .2s, color .2s; }
.video-filter-btn.is-active { background: var(--accent); color: #fff; }
.video-filter-btn:not(.is-active):hover { background: rgba(110,36,51,.12); }

/* ---------- Social ---------- */
.social-row { display:flex; gap:18px; flex-wrap:wrap; justify-content:center; }
.social-btn {
  display:inline-flex; align-items:center; gap:10px; padding:16px 28px;
  border-radius:14px; background:var(--card); border:1px solid var(--line);
  color:var(--text); font-weight:600; transition: all .2s;
}
.social-btn:hover { transform: translateY(-3px); border-color: var(--accent); color:var(--accent); background: var(--accent-soft); }
.social-btn svg { width:22px; height:22px; }

/* ---------- Contact / Footer ---------- */
.contact-box { background: var(--card); border:1px solid var(--line); border-radius: var(--radius); padding: 40px; text-align:center; max-width:640px; margin:0 auto; }
.site-footer { background: var(--accent); color:#f3dde2; border-top:1px solid var(--line); padding: 48px 0 32px; }
.site-footer .brand { color:#fff; }
.site-footer .brand span { color: var(--accent-soft); }
.footer-inner { display:flex; justify-content:space-between; flex-wrap:wrap; gap:24px; align-items:center; }
.footer-brand { display:flex; flex-direction:column; align-items:flex-start; gap:10px; }
.footer-logo { display:block; height:84px; width:auto; }
.footer-socials { display:flex; gap:14px; margin-top:4px; }
.footer-socials a {
  display:inline-flex; align-items:center; justify-content:center;
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.12); color:#fff; transition:background .2s, transform .2s;
}
.footer-socials a:hover { background:rgba(255,255,255,.24); transform:translateY(-2px); }
.footer-socials svg { width:18px; height:18px; }
.footer-links { display:flex; flex-direction:column; gap:10px; list-style:none; margin:0; padding:0; }
.footer-links a { color:#f0d6dc; font-size:.9rem; }
.footer-links a:hover { color:#fff; }
.copy { color:#e7c2cb; font-size:.85rem; }

/* ---------- Generic page ---------- */
.page-hero { padding: 120px 0 60px; background: var(--bg-soft); border-bottom:1px solid var(--line); }
.page-hero h1 { font-size: clamp(2.8rem, 6.5vw, 4.6rem); line-height: 1.08; }
.page-hero h1 .accent { color: var(--accent); }
.page-hero .eyebrow { background: var(--accent); color: #fff; border-color: var(--accent); }
.page-hero .hero-lead { color: var(--muted); font-size: 1.18rem; line-height: 1.6; max-width: 62ch; margin: 22px 0 0; }
.page-hero .hero-text { color: var(--muted); font-size: 1.02rem; line-height: 1.6; max-width: 62ch; margin: 14px 0 0; }
/* Hero mit Bild rechts (Schäferbarde) */
.page-hero--media .container { display: flex; align-items: center; gap: 48px; }
.page-hero--media .page-hero-main { flex: 1 1 auto; }
.page-hero--media .hero-media.barde-rund { flex: 0 0 300px; width: 300px; max-width: 38%; }
@media (max-width: 800px) {
  .page-hero--media .container { flex-direction: column-reverse; align-items: flex-start; gap: 24px; }
  .page-hero--media .hero-media.barde-rund { width: 200px; max-width: 60%; }
}
.page-content { padding: 64px 0 96px; }
.page-content p { color: var(--text); }

/* ---------- Biografie: Karten-Slider ---------- */
.timeline { position: relative; margin: 40px 0 56px; }
.timeline-track {
  display: flex; gap: 24px; overflow-x: auto; overflow-y: hidden;
  -webkit-overflow-scrolling: touch; overscroll-behavior-x: contain;
  padding: 8px 4px 22px; position: relative;
  scrollbar-width: thin; scrollbar-color: var(--accent) transparent;
}
.timeline-track::-webkit-scrollbar { height: 8px; }
.timeline-track::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 999px; }
.timeline-track::-webkit-scrollbar-track { background: var(--line); border-radius: 999px; }
.tl-item { position: relative; flex: 0 0 300px; width: 300px; }
.tl-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: 0 10px 28px rgba(110,36,51,.10); overflow: hidden; height: 100%;
}
.tl-media { height: 170px; overflow: hidden; }
.tl-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.tl-item:hover .tl-media img { transform: scale(1.05); }
.tl-body { padding: 18px 20px 22px; }
.tl-year {
  display: inline-block; background: var(--accent); color: #fff;
  font-family: var(--display); font-weight: 700; font-size: .9rem;
  letter-spacing: .04em; padding: 5px 14px; border-radius: 999px; margin-bottom: 12px;
}
.tl-title { margin: 0 0 8px; font-size: 1.15rem; }
.tl-body p { color: var(--muted); font-size: .92rem; margin: 0; line-height: 1.55; }
.tl-nav {
  position: absolute; top: -56px; width: 42px; height: 42px; border-radius: 50%;
  background: #fff; border: 1px solid var(--line); color: var(--accent); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 16px rgba(110,36,51,.12); transition: background .2s, transform .15s; z-index: 4;
}
.tl-nav:hover { background: var(--accent-soft); transform: translateY(-1px); }
.tl-nav svg { width: 20px; height: 20px; }
.tl-prev { right: 58px; }
.tl-next { right: 4px; }
@media (max-width: 600px) {
  .tl-item { flex: 0 0 260px; width: 260px; }
}

/* ---------- Biografie: weitere Sektionen ---------- */
.bio-split { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin: 48px 0; }
.bio-split h3 { font-size: 1.4rem; margin: 0 0 12px; }
.bio-privat { display: grid; grid-template-columns: 1.1fr .9fr; gap: 48px; align-items: center; margin: 48px 0 8px; background: var(--accent-soft); border-radius: var(--radius); padding: 40px; }
.bio-privat h3 { font-size: 1.6rem; margin: 0 0 12px; }
.bio-privat-media img { width: 100%; border-radius: var(--radius); box-shadow: var(--shadow); display: block; }
.hobby-chips { list-style: none; display: flex; flex-wrap: wrap; gap: 10px; padding: 0; margin: 20px 0 0; }
.hobby-chips li { background: #fff; color: var(--accent); border: 1px solid rgba(110,36,51,.18); border-radius: 999px; padding: 8px 16px; font-weight: 600; font-size: .9rem; }
.bio-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; margin: 20px 0 8px; }
.bio-gallery-item { margin: 0; border-radius: var(--radius); overflow: hidden; box-shadow: 0 8px 24px rgba(110,36,51,.08); background: #fff; }
.bio-gallery-item img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; transition: transform .4s; }
.bio-gallery-item:hover img { transform: scale(1.06); }
.bio-gallery-item figcaption { padding: 12px 14px; font-size: .85rem; color: var(--muted); }
@media (max-width: 760px) {
  .bio-split, .bio-privat { grid-template-columns: 1fr; }
  .bio-privat { padding: 28px; }
}
.fade-in { opacity:0; transform: translateY(24px); transition: opacity .7s, transform .7s; }
.fade-in.visible { opacity:1; transform:none; }

/* ---------- Terminkalender ---------- */
.cal-legend { display:flex; flex-wrap:wrap; gap:16px; margin:18px 0 36px; }
.cal-cat { display:inline-flex; align-items:center; gap:7px; font-size:.85rem; color:var(--muted); }
.cal-dot { width:11px; height:11px; border-radius:50%; display:inline-block; }
.cal-month { font-size:1.2rem; color:var(--accent); margin:34px 0 14px; padding-bottom:8px; border-bottom:1px solid var(--line); text-transform:capitalize; }
.cal-filter { display:flex; flex-wrap:wrap; gap:8px; margin:18px 0 32px; }
.cal-filter-btn { display:inline-flex; align-items:center; gap:8px; border:1px solid var(--line); cursor:pointer; color:var(--accent); background:#fff; padding:8px 16px; border-radius:999px; font-weight:600; font-size:.88rem; transition:background .2s, color .2s, border-color .2s; }
.cal-filter-btn .cal-dot { width:10px; height:10px; }
.cal-filter-btn:not(.is-active):hover { background:rgba(110,36,51,.08); }
.cal-filter-btn.is-active { background:var(--accent); color:#fff; border-color:var(--accent); }
.cal-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; align-items:start; }
.cal-item.is-hidden, .cal-chip.is-hidden, .cal-month-group.is-hidden { display:none; }
.cal-empty { color:var(--muted); }
.cal-more { margin-top:28px; text-align:center; color:var(--muted); font-style:italic; font-size:.98rem; }
@media (max-width:760px){ .cal-grid{ grid-template-columns:1fr; } }
.autogramm-box { display:flex; align-items:flex-start; gap:20px; margin-top:36px; background:var(--accent-soft); border:1px solid var(--accent-2); border-radius:var(--radius); padding:24px 28px; }
.autogramm-icon { flex:0 0 auto; display:inline-flex; align-items:center; justify-content:center; width:52px; height:52px; border-radius:50%; background:var(--accent); color:#fff; }
.autogramm-icon svg { width:26px; height:26px; }
.autogramm-text h3 { margin:2px 0 8px; font-family:var(--display); color:var(--accent); font-size:1.3rem; }
.autogramm-text p { margin:0; color:var(--text); font-size:.96rem; line-height:1.65; }
@media (max-width:560px){ .autogramm-box{ flex-direction:column; gap:14px; } }
.note-inline { color:var(--muted); font-size:.85rem; line-height:1.6; border-left:3px solid var(--accent-2); padding:10px 0 10px 14px; margin:18px 0; background:rgba(168,85,106,.06); border-radius:0 8px 8px 0; }
.cal-list { display:flex; flex-direction:column; gap:14px; }
.cal-item { display:flex; gap:20px; background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:20px 24px; box-shadow:0 6px 18px rgba(110,36,51,.06); transition:transform .15s, box-shadow .2s; }
.cal-item:hover { transform:translateY(-2px); box-shadow:var(--shadow); }
.cal-date { flex:0 0 64px; text-align:center; background:var(--accent-soft); border-radius:12px; padding:10px 6px; align-self:flex-start; }
.cal-day { display:block; font-family:var(--display); font-size:1.8rem; line-height:1; color:var(--accent); font-weight:700; }
.cal-mon { display:block; font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--accent-2); margin-top:4px; }
.cal-body h4 { margin:0 0 6px; font-family:var(--display); font-size:1.3rem; }
.cal-meta { margin:0 0 10px; color:var(--muted); font-size:.92rem; }
.cal-desc { color:var(--text); font-size:.95rem; margin-bottom:10px; }
.cal-badge { display:inline-block; color:#fff; font-size:.72rem; font-weight:700; letter-spacing:.03em; padding:4px 11px; border-radius:999px; margin-right:8px; }
.cal-link { font-weight:600; font-size:.9rem; }
.cal-list--home { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; max-width:var(--maxw); margin:0 auto; }
.cal-list--home .cal-item { height:100%; }
@media (max-width:760px){ .cal-list--home{ grid-template-columns:1fr; } }
@media (max-width:560px){ .cal-item{ flex-direction:row; } .cal-date{ flex-basis:54px; } }

/* --- Termine: Standort/Karte --- */
.cal-loc { display:flex; align-items:center; gap:7px; flex-wrap:wrap; margin:0 0 10px; color:var(--text); font-size:.92rem; }
.cal-pin { width:16px; height:16px; flex:0 0 auto; color:var(--accent-2); }
.cal-maps { font-weight:600; font-size:.85rem; color:var(--accent); white-space:nowrap; }
.cal-maps::before { content:"· "; color:var(--muted); }
.cal-tags { display:flex; align-items:center; flex-wrap:wrap; gap:8px; }
.cal-tags .cal-badge { margin-right:0; }

/* --- Termine: hervorgehobene öffentliche Konzerte --- */
.cal-featured { margin:6px 0 30px; padding:22px 24px 24px; background:var(--accent-soft); border:1px solid var(--accent-2); border-radius:var(--radius); }
.cal-featured-title { display:flex; align-items:center; gap:10px; margin:0 0 16px; font-family:var(--display); color:var(--accent); font-size:1.25rem; }
.cal-featured-title .cal-dot { width:12px; height:12px; }
.cal-featured-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(250px,1fr)); gap:16px; }
.cal-feat { background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px 18px; display:flex; flex-direction:column; box-shadow:0 6px 16px rgba(110,36,51,.08); }
.cal-feat-date { font-size:.82rem; font-weight:700; color:var(--accent-2); }
.cal-feat h4 { margin:6px 0 4px; font-family:var(--display); font-size:1.18rem; line-height:1.25; }
.cal-feat-loc { margin:0 0 8px; color:var(--text); font-size:.9rem; }
.cal-feat-desc { margin:0 0 12px; color:var(--muted); font-size:.86rem; line-height:1.55; }
.cal-feat-actions { margin-top:auto; display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.cal-feat-actions .cal-maps::before { content:none; }

/* --- Termine: Steuerleiste + Ansichtsumschalter --- */
.cal-controls { display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:14px; margin:8px 0 26px; }
.cal-controls .cal-filter { margin:0; }
.cal-viewtoggle { display:inline-flex; background:#fff; border:1px solid var(--line); border-radius:999px; padding:3px; }
.cal-view-btn { border:0; cursor:pointer; background:transparent; color:var(--accent); font-weight:600; font-size:.86rem; padding:7px 18px; border-radius:999px; transition:background .2s, color .2s; }
.cal-view-btn.is-active { background:var(--accent); color:#fff; }

.cal-month-group:first-child .cal-month { margin-top:6px; }

/* --- Termine: Kalenderraster --- */
.cal-month-group--cal { overflow-x:auto; }
.cal-cal { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; min-width:660px; }
.cal-wd { text-align:center; font-size:.74rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-2); padding:4px 0; }
.cal-cell { min-height:96px; background:var(--card); border:1px solid var(--line); border-radius:10px; padding:6px; display:flex; flex-direction:column; gap:4px; }
.cal-cell--pad { background:transparent; border:0; }
.cal-cell.has-ev { border-color:var(--accent-2); }
.cal-cell-day { font-size:.78rem; font-weight:700; color:var(--muted); }
.cal-cell.has-ev .cal-cell-day { color:var(--accent); }
.cal-chip { display:block; font-size:.72rem; line-height:1.2; color:#fff; background:var(--chip,#6e2433); border-radius:6px; padding:3px 6px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; text-decoration:none; }
.cal-chip b { font-weight:700; }
.cal-chip:hover { filter:brightness(1.08); }
@media (max-width:560px){
  .cal-controls { flex-direction:column; align-items:stretch; }
  .cal-viewtoggle { align-self:flex-start; }
}

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  .album, .about { grid-template-columns: 1fr; }
  .nav-links {
    position: absolute; top: 100%; left:0; right:0; flex-direction: column;
    background: var(--bg); border-bottom:1px solid var(--line); padding: 18px 24px; gap:14px;
    display: none;
  }
  .nav-links.open { display: flex; }
  .nav-toggle { display: block; }

  /* Untermenü auf Mobil: eingerückt aufklappen statt schwebend */
  .nav-links li { width: 100%; }
  .nav-links .sub-menu {
    position: static; opacity: 1; visibility: visible; transform: none;
    box-shadow: none; border: 0; background: transparent; padding: 4px 0 4px 26px;
    display: none; min-width: 0;
  }
  .nav-links .menu-item-has-children.open > .sub-menu { display: block; }
  .nav-links .menu-caret { margin-left: auto; }
}
