/* ═══════════════════════════════════════════════════════════
   components.css – Komponenten-Styles (ehemals inline in base.html.twig + header.html.twig)
   Wird im <head> eingebunden, damit keine <style>-Elemente im <body> nötig sind.
   ═══════════════════════════════════════════════════════════ */

/* ── NAV / HEADER ─────────────────────────────────────────── */
@keyframes rt-pulse { 0%,100%{opacity:1} 50%{opacity:.25} }

.rt-nav {
  background: var(--ink);
  border-bottom: 3px solid var(--red);
}
.rt-nav-inner {
  max-width: 80rem; margin: 0 auto; padding: 0 1.1rem;
  display: flex; align-items: center; gap: .5rem;
  height: 58px;
  container-type: inline-size;
}

.rt-brand {
  text-decoration: none; display: flex; flex-direction: column;
  line-height: 1; gap: 2px; flex-shrink: 0; margin-right: .5rem;
}
.rt-brand-name {
  font-size: clamp(1.2rem, 2.8vw, 1.65rem);
  line-height: .9; letter-spacing: -.01em;
  display: inline-flex; align-items: baseline; gap: .05em;
}
.rt-brand-r1 { font-family:'Bungee Shade',sans-serif; color:var(--paper); font-size:1em; }
.rt-brand-r2 { font-family:'Big Shoulders Stencil Display',sans-serif; font-weight:900; color:var(--red); font-size:.96em; }
.rt-brand-r3 { font-family:'Big Shoulders Stencil Display',sans-serif; font-weight:900; color:var(--paper); background:var(--red); padding:0 .1em; font-size:.88em; }
.rt-brand-r4 { font-family:'Bowlby One SC',sans-serif; color:var(--paper); font-size:.92em; }
.rt-brand-r5 { font-family:'Big Shoulders Stencil Display',sans-serif; font-weight:900; color:var(--yellow); font-size:.9em; }
.rt-brand-r6 { font-family:'Anton',sans-serif; color:var(--paper); font-size:.94em; }
.rt-brand-r7 { font-family:'Big Shoulders Stencil Display',sans-serif; font-weight:900; color:var(--ink); background:var(--paper); padding:0 .09em; font-size:.86em; }
.rt-brand:hover .rt-brand-r1 { text-shadow:2px 2px 0 var(--red); }
.rt-brand-sub {
  font-family: 'DM Mono', monospace;
  font-size: .62rem; letter-spacing: .2em; text-transform: uppercase;
  color: rgba(240,200,0,.85); line-height: 1;
}
.rt-brand-logo {
  height: clamp(2.2rem, 5vw, 3.2rem);
  width: auto;
  display: block;
  object-fit: contain;
  filter: drop-shadow(2px 2px 0 rgba(14,12,9,.55));
  transition: filter .2s, transform .2s;
}
.rt-brand:hover .rt-brand-logo {
  filter: drop-shadow(3px 3px 0 var(--red));
  transform: translateY(-1px);
}
.rt-brand-logo--footer {
  height: clamp(2.4rem, 4vw, 3.4rem);
  opacity: .92;
}

.rt-nav-list {
  display: flex; align-items: center; gap: 0; list-style: none;
  flex: 1; min-width: 0;
}
.rt-nl {
  font-family: 'Big Shoulders Stencil Display', 'Anton', sans-serif;
  font-weight: 900; font-size: .95rem; letter-spacing: .06em;
  color: rgba(237,224,196,.78); display: block;
  padding: .85rem .7rem; text-decoration: none;
  transition: color .12s;
  white-space: nowrap; position: relative;
}
.rt-nl:hover, .rt-nl.active { color: var(--paper); }
.rt-nl-sec { color: rgba(237,224,196,.5); }
.rt-nl:hover::after {
  content: ''; position: absolute; bottom: 0; left: .7rem; right: .7rem;
  height: 3px; background: var(--red);
}
.rt-nav-sep {
  width: 1px; height: 1rem;
  background: rgba(237,224,196,.12); margin: 0 .15rem;
  flex-shrink: 0;
}

.rt-nav-icons {
  display: flex; align-items: center; gap: .25rem;
  flex-shrink: 0; margin-left: auto;
}

.rt-dd {
  background: var(--ink);
  border: 2px solid var(--red);
  box-shadow: 4px 4px 0 rgba(0,0,0,.6);
  padding: .4rem 0;
}
.rt-dd-item {
  display: block; padding: .6rem 1.15rem;
  font-family: 'Big Shoulders Stencil Display', 'Anton', sans-serif;
  font-weight: 900; font-size: .85rem; letter-spacing: .06em;
  color: rgba(237,224,196,.72); text-decoration: none;
  transition: color .1s, background .1s, padding-left .1s;
  white-space: nowrap;
}
.rt-dd-item:hover { color: var(--paper); background: rgba(212,32,48,.2); padding-left: 1.5rem; }
.rt-dd-item.is-active { color: var(--yellow); }
.rt-dd-item.is-active:hover { color: var(--yellow); }
.rt-dd-flag {
  display: inline-block; min-width: 1.8rem;
  color: var(--red); font-weight: 400; letter-spacing: .04em;
}
.rt-dd-item.is-active .rt-dd-flag { color: var(--yellow); }
.rt-dd-rule { margin: .3rem .8rem; border-top: 1px dashed rgba(237,224,196,.15); }

.rt-lang-btn-icon {
  display: inline-flex; align-items: center; gap: .4rem;
  border: 1px solid rgba(237,224,196,.3);
  padding: .35rem .6rem;
  color: rgba(237,224,196,.75);
  transition: color .12s, border-color .12s, background .12s;
}
.rt-lang-btn-icon:hover,
.rt-lang-btn-icon.is-open {
  color: var(--paper); border-color: rgba(237,224,196,.55);
  background: rgba(237,224,196,.06);
}
.rt-lang-btn-icon svg { flex-shrink: 0; }
.rt-lang-cur {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1rem; letter-spacing: .08em; line-height: 1;
}

.rt-red-btn {
  font-family: 'Bebas Neue', sans-serif; font-size: 1.02rem; letter-spacing: .1em;
  color: #ff5565; border: 1px solid rgba(212,32,48,.5);
  padding: .35rem .9rem; text-decoration: none;
  transition: background .12s, color .12s;
}
.rt-red-btn:hover { background: var(--red); color: var(--paper); }

.rt-icon-btn {
  color: rgba(237,224,196,.7); padding: 4px;
  transition: color .12s; background: none; border: none; cursor: pointer;
}
.rt-icon-btn:hover { color: var(--paper); }

.rt-search-drawer { padding: 0 1rem .65rem; max-width: 80rem; margin: 0 auto; }
.rt-search-input {
  width: 100%;
  background: rgba(237,224,196,.06);
  border: 1px solid rgba(237,224,196,.15);
  border-bottom: 2px solid var(--red);
  color: var(--paper); padding: .55rem 1rem; font-size: .9rem;
  font-family: 'DM Mono', monospace; letter-spacing: .06em;
  outline: none; transition: border-color .15s, background .15s;
}
.rt-search-input:focus { background: rgba(237,224,196,.1); border-color: var(--paper); }
.rt-search-input::placeholder { color: rgba(237,224,196,.45); }

.rt-mob-menu {
  background: var(--ink);
  border-top: 1px solid rgba(237,224,196,.07);
  padding: .5rem 0 1rem;
}
.rt-mob-link {
  display: block; padding: .65rem 1.15rem;
  font-family: 'Big Shoulders Stencil Display', 'Anton', sans-serif;
  font-weight: 900; font-size: 1rem; letter-spacing: .05em;
  color: rgba(237,224,196,.78); text-decoration: none;
  transition: color .1s, background .1s;
}
.rt-mob-link:hover { color: var(--paper); background: rgba(212,32,48,.15); }
.rt-mob-sub { font-size: .95rem; color: rgba(237,224,196,.62); padding-left: 1.75rem; }
.rt-mob-langactive { color: var(--yellow); }
.rt-mob-langactive span { color: var(--yellow) !important; }
.rt-mob-section {
  padding: .7rem 1.15rem .25rem;
  font-family: 'DM Mono', monospace; font-size: .68rem; font-weight: 500; letter-spacing: .18em;
  text-transform: uppercase; color: var(--yellow);
  border-top: 1px solid rgba(237,224,196,.1); margin-top: .35rem;
}
.rt-mob-search { padding: .4rem 1rem .2rem; }
.rt-mob-search form { display: flex; gap: .5rem; }
.rt-mob-search input {
  flex: 1; background: rgba(237,224,196,.06);
  border: 1px solid rgba(237,224,196,.15); border-bottom: 2px solid var(--red);
  color: var(--paper); padding: .4rem .75rem;
  font-family: 'DM Mono', monospace; font-size: .8rem; letter-spacing: .05em; outline: none;
}
.rt-mob-search input::placeholder { color: rgba(237,224,196,.3); }
.rt-mob-search button {
  background: var(--red); color: var(--paper); border: none;
  padding: .4rem .75rem; font-family: 'Bebas Neue', sans-serif;
  font-size: .9rem; letter-spacing: .08em; cursor: pointer;
}

/* Auto-Hamburger via Container Query */
.rt-nav-list   { display: flex; }
.rt-search-ico { display: flex; }
.rt-ham-btn    { display: none; }

@container (max-width: 960px) {
  .rt-nav-list   { display: none; }
  .rt-search-ico { display: none; }
  .rt-ham-btn    { display: flex; }
}

/* ── SCHWARZES-BRETT-HINWEIS ──────────────────────────────── */
.sb-notify {
  background: #1e1b4b;
  border-bottom: 2px solid #6366f1;
  padding: .55rem 1.25rem;
  display: flex; align-items: center; justify-content: space-between;
  gap: .75rem; flex-wrap: wrap;
  font-family: 'Courier New', monospace;
  font-size: .8rem; letter-spacing: .04em;
  position: relative; z-index: 40;
}
.sb-notify-left { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; }
.sb-notify-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #818cf8; flex-shrink: 0;
  animation: sb-notify-blink 1.4s ease-in-out infinite;
}
@keyframes sb-notify-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: .25; }
}
.sb-notify-text { color: #a5b4fc; }
.sb-notify-count {
  background: #6366f1; color: #fff;
  font-weight: 700; padding: .1rem .5rem; font-size: .75rem;
}
.sb-notify-link {
  color: #fff; text-decoration: none;
  background: #6366f1; padding: .25rem .85rem;
  font-size: .75rem; letter-spacing: .07em; text-transform: uppercase;
  white-space: nowrap; transition: background .15s;
}
.sb-notify-link:hover { background: #4f46e5; }

/* ── COOKIE BANNER ────────────────────────────────────────── */
#rt-cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999;
  background: var(--paper);
  border-top: 3px solid var(--ink);
  box-shadow: 0 -4px 0 var(--red);
  padding: 1.1rem 1.5rem;
  display: flex; align-items: center; gap: 1.25rem;
  flex-wrap: wrap;
  font-family: 'DM Mono', monospace;
  transform: translateY(100%);
  transition: transform .3s ease;
}
#rt-cookie-banner.rt-cb-visible { transform: translateY(0); }
.rt-cb-text { flex: 1; min-width: 0; font-size: .75rem; color: var(--ink-soft); line-height: 1.6; }
.rt-cb-text a { color: var(--red-deep); text-decoration: none; }
.rt-cb-text a:hover { text-decoration: underline; }
.rt-cb-ok {
  flex-shrink: 0;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1rem; letter-spacing: .14em;
  background: var(--ink); color: var(--paper); border: 2px solid var(--ink);
  padding: .55rem 1.75rem; cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: transform .1s, box-shadow .1s, background .12s;
  white-space: nowrap;
}
.rt-cb-ok:hover { transform: translate(-2px,-2px); box-shadow: var(--shadow); background: var(--red); }

/* ── E-MAIL-SCHUTZ + KARTEN-BUTTON ───────────────────────── */
.ep-btn {
  display: inline-flex; align-items: center; gap: .35rem;
  font-family: 'DM Mono', monospace; font-size: .82rem;
  color: var(--ink-soft); background: none;
  border: 1px solid rgba(14,12,9,.2); padding: 2px 10px;
  cursor: pointer; transition: color .12s, border-color .12s;
  letter-spacing: .04em;
}
.ep-btn:hover { color: var(--red); border-color: rgba(212,32,48,.4); }
.ep-revealed { color: var(--red); text-decoration: none; }
.ep-revealed:hover { text-decoration: underline; }

.rt-map-btn {
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: 'DM Mono', monospace; font-size: .68rem;
  letter-spacing: .07em; text-transform: uppercase;
  color: var(--ink-soft); border: 1px solid rgba(14,12,9,.2); background: none;
  padding: .3rem .85rem; cursor: pointer;
  transition: color .12s, border-color .12s;
}
.rt-map-btn:hover:not(:disabled) { color: var(--red); border-color: rgba(212,32,48,.4); }
.rt-map-btn:disabled { opacity: .5; cursor: default; }
.rt-map-container { margin-top: .75rem; display: none; }

/* ── KONZERT-VIDEO MINI-PLAYER ────────────────────────────── */
#rt-mini-player {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 9990;
  background: var(--ink);
  border-top: 3px solid var(--red);
  box-shadow: 0 -6px 24px rgba(0,0,0,.45);
  transition: width .2s, left .2s;
}
#rt-mini-player.rt-pl-expanded {
  left: auto;
  width: min(480px, 100vw);
  border-top: 3px solid var(--red);
  border-left: 2px solid rgba(237,224,196,.15);
}
/* Bar wird zur Spalte: ytWrap nimmt volle Breite auf eigener Zeile */
#rt-mini-player.rt-pl-expanded .rt-pl-bar {
  flex-wrap: wrap;
  padding: 0;
  gap: 0;
}
#rt-mini-player.rt-pl-expanded .rt-pl-yt-wrap {
  flex-basis: 100%;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  border: none;
  overflow: hidden;
}
#rt-mini-player.rt-pl-expanded .rt-pl-yt-wrap iframe { width: 100%; height: 100%; }
/* Controls-Zeile unter dem Video */
#rt-mini-player.rt-pl-expanded .rt-pl-info,
#rt-mini-player.rt-pl-expanded .rt-pl-audio-icon,
#rt-mini-player.rt-pl-expanded .rt-pl-vol-wrap,
#rt-mini-player.rt-pl-expanded .rt-pl-ctrls { padding: .45rem .5rem; }
#rt-mini-player.rt-pl-expanded .rt-pl-info { padding-left: .75rem; }
.rt-pl-expand-wrap { display: none; }
.rt-pl-panel {
  max-height: 280px; overflow-y: auto;
  border-bottom: 1px solid rgba(237,224,196,.1);
  overscroll-behavior: contain;
}
.rt-pl-panel-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: .4rem 1rem;
  background: rgba(237,224,196,.06);
  border-bottom: 1px solid rgba(237,224,196,.08);
}
.rt-pl-panel-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: .85rem; letter-spacing: .2em; color: var(--yellow);
}
.rt-pl-btn-sm {
  font-family: 'DM Mono', monospace; font-size: .68rem;
  color: rgba(237,224,196,.4); background: none;
  border: 1px solid rgba(237,224,196,.18); padding: 2px 10px;
  cursor: pointer; letter-spacing: .05em;
  transition: color .12s, border-color .12s;
}
.rt-pl-btn-sm:hover { color: var(--red); border-color: var(--red); }
.rt-pl-list { list-style: none; margin: 0; padding: 0; }
.rt-pl-item {
  display: flex; align-items: center;
  border-bottom: 1px solid rgba(237,224,196,.05);
  transition: background .1s;
}
.rt-pl-item:hover { background: rgba(237,224,196,.05); }
.rt-pl-item.rt-pl-item-active {
  background: rgba(212,32,48,.15);
  border-left: 3px solid var(--red);
}
.rt-pl-item-play {
  display: flex; align-items: center; gap: .55rem;
  flex: 1; min-width: 0; padding: .4rem .85rem;
  background: none; color: rgba(237,224,196,.75);
  cursor: pointer; text-align: left; transition: color .1s;
}
.rt-pl-item-play:hover { color: var(--paper); }
.rt-pl-item-thumb {
  width: 48px; height: 27px; object-fit: cover; flex-shrink: 0;
  border: 1px solid rgba(237,224,196,.1); background: #111;
}
.rt-pl-item-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: .9rem; letter-spacing: .04em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rt-pl-item-del {
  flex-shrink: 0; padding: .4rem .75rem; background: none;
  color: rgba(237,224,196,.25); cursor: pointer; transition: color .12s;
}
.rt-pl-item-del:hover { color: var(--red); }
.rt-pl-empty {
  padding: .85rem 1rem;
  font-family: 'DM Mono', monospace; font-size: .72rem;
  color: rgba(237,224,196,.35); text-align: center;
}
.rt-pl-bar {
  display: flex; align-items: center; gap: .75rem;
  padding: .45rem 1rem; min-height: 60px;
}
.rt-pl-yt-wrap {
  flex-shrink: 0; width: 107px; height: 60px;
  background: #000; overflow: hidden;
  border: 1px solid rgba(237,224,196,.1);
}
.rt-pl-yt-wrap iframe { width: 100%; height: 100%; border: none; display: block; }
.rt-pl-yt-consent {
  width: 100%; height: 100%; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: .25rem;
  background: #111; text-align: center; padding: .25rem;
}
.rt-pl-expand-wrap .rt-pl-yt-consent { aspect-ratio: 16 / 9; height: auto; gap: .75rem; padding: 1.25rem; }
.rt-pl-yt-consent-btn {
  background: none; border: none; cursor: pointer; padding: 0; line-height: 0;
  transition: transform .15s;
}
.rt-pl-yt-consent-btn:hover { transform: scale(1.1); }
.rt-pl-yt-consent-txt {
  font-family: 'DM Mono', monospace; font-size: .58rem; color: #9ca3af;
  line-height: 1.3; margin: 0;
}
.rt-pl-expand-wrap .rt-pl-yt-consent-txt { font-size: .75rem; }
.rt-pl-info { flex: 1; min-width: 0; }
.rt-pl-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1rem; letter-spacing: .05em; color: var(--paper);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block;
}
.rt-pl-vol-wrap { display: flex; align-items: center; gap: .3rem; flex-shrink: 0; }
.rt-pl-vol-range {
  width: 64px; height: 3px;
  -webkit-appearance: none; appearance: none;
  background: rgba(237,224,196,.25); border-radius: 2px;
  accent-color: var(--red); cursor: pointer; outline: none;
}
@media (max-width: 480px) { .rt-pl-vol-wrap { display: none; } }
.rt-pl-ctrls { display: flex; align-items: center; gap: .3rem; flex-shrink: 0; }
.rt-pl-btn {
  display: flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  background: rgba(237,224,196,.08); color: rgba(237,224,196,.7);
  border: 1px solid rgba(237,224,196,.12); cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
}
.rt-pl-btn:hover { background: var(--red); color: #fff; border-color: var(--red); }
.rt-pl-btn-toggle.rt-pl-panel-open,
.rt-pl-btn-expand.rt-pl-panel-open { background: var(--red); color: #fff; border-color: var(--red); }

.rt-pl-badge-wrap { position: relative; display: inline-flex; }
#rt-pl-badge {
  position: absolute; top: -5px; right: -5px;
  min-width: 16px; height: 16px; padding: 0 4px;
  background: var(--red); color: #fff;
  font-family: 'DM Mono', monospace; font-size: .6rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  line-height: 1; border-radius: 8px;
}

.rt-pl-toast {
  position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%) translateY(8px);
  z-index: 9995;
  background: var(--ink); color: var(--paper);
  border: 1px solid var(--red);
  font-family: 'Bebas Neue', sans-serif; font-size: .95rem; letter-spacing: .08em;
  padding: .45rem 1.1rem;
  white-space: nowrap; max-width: 90vw; overflow: hidden; text-overflow: ellipsis;
  opacity: 0; transition: opacity .2s, transform .2s;
  pointer-events: none;
}
.rt-pl-toast.rt-pl-toast-in { opacity: 1; transform: translateX(-50%) translateY(0); }

@keyframes rt-pl-shake {
  0%,100% { transform: translateX(0) rotate(0); }
  20%     { transform: translateX(-4px) rotate(-5deg); }
  40%     { transform: translateX(4px)  rotate(5deg); }
  60%     { transform: translateX(-3px) rotate(-3deg); }
  80%     { transform: translateX(3px)  rotate(3deg); }
}
.rt-pl-shake { animation: rt-pl-shake .45s ease; }

#rt-pl-empty-hint {
  position: fixed;
  z-index: 9999;
  transform: translateX(-50%) translateY(-4px);
  background: var(--ink); color: var(--paper);
  border: 1px solid var(--red);
  border-radius: 3px;
  padding: .5rem 1rem;
  font-family: 'Courier New', monospace;
  font-size: .78rem;
  white-space: nowrap;
  opacity: 0; transition: opacity .2s, transform .2s;
  pointer-events: none;
}
#rt-pl-empty-hint b { color: var(--red); }
#rt-pl-empty-hint.rt-pl-hint-in { opacity: 1; transform: translateX(-50%) translateY(0); }
#rt-pl-empty-hint::before {
  content: '';
  position: absolute;
  top: -6px; left: 50%; transform: translateX(-50%);
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 6px solid var(--red);
}

.rt-pl-audio-icon {
  flex-shrink: 0; width: 107px; height: 60px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(14,12,9,.4);
  border: 1px solid rgba(237,224,196,.1);
}
#rt-pl-audio-prog { display: flex; }

.rt-pl-add-btn {
  display: flex; align-items: center; justify-content: center;
  width: 30px; height: 30px;
  background: rgba(14,12,9,.7); color: rgba(237,224,196,.8);
  border: 1px solid rgba(237,224,196,.25); cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
  backdrop-filter: blur(2px);
}
.rt-pl-add-btn:hover         { background: var(--red); color: #fff; border-color: var(--red); }
.rt-pl-add-btn.rt-pl-added   { background: var(--yellow); color: var(--ink); border-color: var(--yellow); }
