/* ==========================================================================
   TG Langenselbold – Integrations-Styles
   (Skip-Link, Mobil-Navigation, Cookie-Banner, Fokus/Barrierefreiheit)
   Ergänzt assets/tgl/styles.css
   ========================================================================== */

/* ---------- Skip-Link (Barrierefreiheit) ---------- */
.skip-link {
  position: fixed;
  top: -100px;
  left: 12px;
  z-index: 100000;
  background: var(--ink);
  color: #fff;
  padding: 12px 18px;
  border-radius: var(--radius);
  font-family: var(--f-mono);
  font-size: 13px;
  letter-spacing: 0.05em;
  transition: top .2s ease;
}
.skip-link:focus { top: 12px; outline: 3px solid var(--gold); }

/* ---------- Sichtbarer Fokus (Tastaturbedienung) ---------- */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: 3px solid var(--blue);
  outline-offset: 2px;
  border-radius: 2px;
}

/* ==========================================================================
   Mobil-Navigation (Burger) – das Basis-Layout blendet .nav-links < 980px aus
   ========================================================================== */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 10px;
  margin-left: auto;
}
.nav-burger span {
  display: block;
  height: 2px;
  width: 100%;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .25s ease, opacity .2s ease;
}
.nav-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 980px) {
  /* Mobile Nav als Flex-Reihe: Logo links · Tickets + Burger rechts (kein Umbruch) */
  .nav-inner { display: flex; align-items: center; gap: 12px; position: relative; }
  .nav-brand { margin-right: auto; }
  .nav-cta { order: 2; }
  .nav-cta .btn { padding: 10px 16px; font-size: 13px; }
  .nav-burger { display: flex; order: 3; margin-left: 0; }

  /* Mobil-Menü als ausklappbares Panel statt komplett versteckt */
  .nav .nav-links {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: var(--paper);
    border-top: 1px solid var(--g-200);
    box-shadow: 0 24px 48px rgba(10,14,26,0.18);
    padding: 8px 0;
    max-height: 80vh;
    overflow-y: auto;
    z-index: 9000;
  }
  .nav.nav-open .nav-links { display: flex; }

  .nav-links > a,
  .nav-drop-btn {
    width: 100%;
    text-align: left;
    padding: 14px var(--gutter);
    font-size: 16px;
    border-bottom: 1px solid var(--g-100);
  }
  .nav-drop { width: 100%; }
  .nav-drop-menu {
    position: static;
    display: none;
    box-shadow: none;
    border: none;
    background: var(--g-50);
    padding: 0;
    min-width: 0;
    opacity: 1;
    transform: none;
    visibility: visible;
  }
  .nav-drop.open .nav-drop-menu { display: block; }
  .nav-drop-menu a { padding: 12px var(--gutter) 12px calc(var(--gutter) + 16px); border-bottom: 1px solid var(--g-100); }
}

/* ---------- Desktop: Dropdown bei Hover (ohne Layout-Versatz) ---------- */
@media (min-width: 981px) {
  /* Menü bei Hover ODER Klick zeigen – Zentrierung (translateX(-50%)) bleibt erhalten */
  .nav-drop:hover .nav-drop-menu,
  .nav-drop:focus-within .nav-drop-menu,
  .nav-drop.open .nav-drop-menu {
    display: block;
  }
  .nav-drop:hover .nav-drop-btn,
  .nav-drop:focus-within .nav-drop-btn { color: var(--red); }
  .nav-drop:hover .nav-arrow,
  .nav-drop:focus-within .nav-arrow { transform: rotate(180deg); color: var(--red); }

  /* Unsichtbare Brücke über die 6px-Lücke, damit Hover beim Wechsel
     Button -> Menü nicht abbricht (kein Flackern/Schließen) */
  .nav-drop-menu::before {
    content: "";
    position: absolute;
    top: -8px;
    left: 0;
    right: 0;
    height: 8px;
  }
}

/* ==========================================================================
   Cookie-Consent-Banner (DSGVO) – im TG-Design
   ========================================================================== */
.cookie-consent-overlay {
  position: fixed;
  inset: 0;
  z-index: 99000;
  display: none;
  align-items: flex-end;
  justify-content: center;
  background: rgba(10,14,26,0.55);
  padding: 20px;
  backdrop-filter: blur(2px);
}
.cookie-consent-overlay.active { display: flex; animation: cookieFade .25s ease; }
.cookie-consent-overlay.hiding { animation: cookieFade .25s ease reverse; }
@keyframes cookieFade { from { opacity: 0; } to { opacity: 1; } }

.cookie-consent-banner {
  background: var(--paper);
  color: var(--ink);
  width: 100%;
  max-width: 720px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--g-200);
  box-shadow: 0 30px 80px rgba(10,14,26,0.35);
  padding: 28px;
  margin-bottom: 12px;
  max-height: 88vh;
  overflow-y: auto;
}
@media (min-width: 720px) { .cookie-consent-overlay { align-items: center; } }

.cookie-consent-header .cookie-icon {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--ink); color: var(--gold);
  border-radius: 50%; margin-bottom: 14px;
}
.cookie-consent-title {
  display: block;
  font-family: var(--f-head);
  font-weight: 800;
  font-size: 22px;
  margin-bottom: 8px;
}
.cookie-consent-header p { color: var(--g-600); font-size: 15px; max-width: 60ch; }

.cookie-categories { margin: 20px 0; display: grid; gap: 12px; }
.cookie-category { border: 1px solid var(--g-200); border-radius: var(--radius); padding: 14px 16px; }
.cookie-category-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.cookie-category-info { display: flex; gap: 12px; align-items: flex-start; }
.cookie-category-icon {
  width: 36px; height: 36px; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--radius); background: var(--g-100); color: var(--ink);
}
.cookie-category-icon.essential { background: #0f3; background: var(--green); color: #fff; }
.cookie-category-icon.statistics { background: var(--blue); color: #fff; }
.cookie-category-icon.marketing { background: var(--red); color: #fff; }
.cookie-category-icon.external { background: var(--gold-2); color: #fff; }
.cookie-category-title { display: block; font-family: var(--f-head); font-weight: 700; font-size: 15px; }
.cookie-category-info p { font-size: 13px; color: var(--g-500); margin-top: 2px; }

/* Toggle Switch */
.cookie-toggle { position: relative; display: inline-flex; align-items: center; cursor: pointer; flex-shrink: 0; }
.cookie-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.cookie-toggle-slider {
  width: 46px; height: 26px; border-radius: 26px; background: var(--g-300);
  position: relative; transition: background .2s ease;
}
.cookie-toggle-slider::after {
  content: ""; position: absolute; top: 3px; left: 3px;
  width: 20px; height: 20px; border-radius: 50%; background: #fff;
  transition: transform .2s ease;
}
.cookie-toggle input:checked + .cookie-toggle-slider { background: var(--green); }
.cookie-toggle input:checked + .cookie-toggle-slider::after { transform: translateX(20px); }
.cookie-toggle.disabled { opacity: .7; cursor: not-allowed; }
.cookie-always-on { font-family: var(--f-mono); font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: var(--g-500); margin-left: 8px; }

.cookie-consent-buttons { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }
.cookie-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 18px; border-radius: var(--radius);
  font-family: var(--f-head); font-weight: 700; font-size: 14px;
  border: 1px solid var(--g-300); background: #fff; color: var(--ink);
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.cookie-btn:hover { border-color: var(--ink); }
.cookie-btn-accept { background: var(--red); border-color: var(--red); color: #fff; margin-left: auto; }
.cookie-btn-accept:hover { background: var(--red-2); border-color: var(--red-2); }
.cookie-btn-settings { background: transparent; }
.cookie-btn-save { background: var(--ink); border-color: var(--ink); color: #fff; margin-left: auto; }
.cookie-consent-footer { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--g-200); display: flex; gap: 12px; font-size: 13px; }
.cookie-consent-footer a { color: var(--g-600); text-decoration: underline; }
.cookie-divider { color: var(--g-300); }

/* Floating Settings Button */
.cookie-settings-btn {
  position: fixed; left: 20px; bottom: 20px; z-index: 90000;
  display: none; align-items: center; gap: 8px;
  width: 46px; height: 46px; overflow: hidden;
  padding: 0 12px;
  background: var(--ink); color: var(--gold);
  border-radius: 999px; box-shadow: 0 8px 24px rgba(10,14,26,0.3);
  transition: width .25s ease;
}
.cookie-settings-btn svg { flex: 0 0 auto; color: var(--gold); }
.cookie-settings-btn .cookie-settings-label { white-space: nowrap; opacity: 0; font-family: var(--f-mono); font-size: 12px; color: #fff; }
.cookie-settings-btn:hover { width: 210px; }
.cookie-settings-btn:hover .cookie-settings-label { opacity: 1; }

@media (max-width: 560px) {
  .cookie-consent-banner { padding: 20px; }
  .cookie-btn-accept, .cookie-btn-save { margin-left: 0; width: 100%; justify-content: center; }
}
