/* =============================================================
   tango-in-leipzig.de v2 — Design-System „Nachtelegant" (Konzept B)
   Dunkel, warmes Gold, moderne Serife (Fraunces). WordPress-frei.
   Editierbar in VS Code. Funktions-Hooks (IDs/Klassen) bleiben stabil.
   ============================================================= */

/* ---------- Schriften (lokal, kein Google-CDN — DSGVO) ---------- */
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-latin-400-normal.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-latin-500-normal.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-latin-600-normal.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-latin-700-normal.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('../fonts/fraunces-latin-400-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Inter';src:url('../fonts/inter-v20-latin_latin-ext-regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('../fonts/inter-v20-latin_latin-ext-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('../fonts/inter-v20-latin_latin-ext-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --bg:#161018; --bg-2:#1C1620; --bg-3:#211A28; --bg-raised:#241C2C;
  --line:#2C2434; --line-2:#3A3046;
  --ink:#F4ECE2; --text:#D7CcC2; --muted:#9E92A2; --muted-2:#7C7188;
  --gold:#D69652; --gold-light:#E8C896; --gold-dim:#B98443;
  --milonga:#E06A57; --practica:#B59AD6; --workshop:#6FBF9B; --festival:#E0B062; --kurs:#8FB0D9; --schnupperkurs:#C9A2B6;
  --font-display:'Fraunces',Georgia,serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --fs-xs:.8125rem; --fs-sm:.9375rem; --fs-base:1.0625rem; --fs-lg:1.2rem; --fs-xl:1.6rem; --fs-2xl:2.4rem; --fs-3xl:3.4rem;
  --space-xs:.5rem; --space-sm:1rem; --space-md:1.5rem; --space-lg:2.5rem; --space-xl:4rem; --space-2xl:6rem;
  --max-width:1180px; --max-width-narrow:760px;
  --radius:14px; --radius-sm:9px; --radius-pill:999px;
  --shadow:0 16px 40px rgba(0,0,0,.35); --glow:0 14px 40px rgba(214,150,82,.12);
  --header-h:62px;
}

/* ---------- Basis ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-size:var(--fs-base);line-height:1.65;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.1;letter-spacing:-.01em;color:var(--ink);margin:0 0 .4em}
h1{font-size:var(--fs-3xl)} h2{font-size:var(--fs-2xl)} h3{font-size:var(--fs-xl)} h4{font-size:var(--fs-lg)}
p{margin:0 0 1em}
a{color:var(--gold-light);text-decoration:none;transition:color .15s} a:hover{color:var(--gold)}
img,svg{max-width:100%;display:block}
.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-md)}
.narrow{max-width:var(--max-width-narrow)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.eyebrow{font-family:var(--font-body);font-size:var(--fs-xs);font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-md)}
.section-head a{font-family:var(--font-body);font-size:var(--fs-sm);font-weight:500}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-body);font-size:var(--fs-sm);font-weight:600;padding:.66em 1.3em;border-radius:var(--radius-pill);border:1px solid transparent;cursor:pointer;transition:all .15s;text-decoration:none;line-height:1}
.btn-primary{background:var(--gold);color:#1a130b;border-color:var(--gold)}
.btn-primary:hover{background:var(--gold-light);color:#1a130b}
.btn-outline{background:transparent;color:var(--gold-light);border-color:var(--line-2)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold-light)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:200;background:rgba(18,13,21,.9);backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);height:var(--header-h)}
.brand{text-decoration:none;display:flex;align-items:center;gap:.55rem}
.brand::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 9px rgba(214,150,82,.65);flex:0 0 auto}
.wordmark{font-family:var(--font-display);font-weight:600;font-size:1.3rem;letter-spacing:.01em;color:var(--gold-light);white-space:nowrap}
.brand:hover .wordmark{color:var(--gold)}
.main-nav{display:flex;align-items:center}
.nav-links{display:flex;align-items:center;gap:1.7rem;list-style:none;margin:0;padding:0}
.nav-links a{position:relative;display:inline-block;color:var(--text);font-family:var(--font-body);font-size:.95rem;font-weight:500;letter-spacing:.01em;padding:.35rem 0;transition:color .15s}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;background:var(--gold);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .22s ease}
.nav-links a:hover,.nav-links a.is-active{color:var(--gold-light)}
.nav-links a:hover::after,.nav-links a.is-active::after{transform:scaleX(1)}
.lang-switch{display:inline-flex;align-items:center;gap:.2rem;margin-left:1.5rem;padding-left:1.5rem;border-left:1px solid var(--line-2)}
.lang-switch a{padding:.22rem .55rem;border-radius:7px;font-family:var(--font-body);font-size:.8rem;font-weight:600;letter-spacing:.03em;color:var(--muted);transition:all .15s}
.lang-switch a:hover{color:var(--gold-light)}
.lang-switch a.is-active{color:#1a130b;background:var(--gold)}
.lang-switch a.is-active:hover{color:#1a130b}
.nav-toggle{display:none;background:none;border:0;color:var(--gold-light);cursor:pointer;padding:.3rem;font-size:1.5rem;line-height:1}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:radial-gradient(120% 90% at 78% -10%,rgba(214,150,82,.16),transparent 55%),var(--bg)}
.hero-inner{position:relative;z-index:2;padding:var(--space-2xl) 0 var(--space-xl);max-width:880px}
.hero-title{font-size:clamp(2.6rem,7vw,var(--fs-3xl));color:var(--ink);margin:.35rem 0 .3em;line-height:1.02}
.hero .lede{color:var(--text);font-size:var(--fs-lg);max-width:560px;opacity:.92}
/* Featured-Event */
.featured{display:block;margin-top:var(--space-md);background:var(--bg-2);border:1px solid var(--line-2);border-left:4px solid var(--tc,var(--gold));border-radius:var(--radius);padding:1rem 1.2rem;max-width:540px;box-shadow:var(--glow);transition:transform .15s,box-shadow .15s}
.featured:hover{transform:translateY(-2px);box-shadow:0 18px 48px rgba(214,150,82,.18)}
.featured-row{display:flex;align-items:center;gap:.7rem;margin-bottom:.5rem;flex-wrap:wrap}
.featured-when{font-size:var(--fs-sm);color:var(--muted)}
.featured-title{font-family:var(--font-display);font-weight:600;font-size:var(--fs-lg);color:var(--ink);margin:0 0 .2rem;line-height:1.15}
.featured-sub{font-size:var(--fs-sm);color:var(--muted);margin:0}
.featured-cta{display:inline-block;margin-top:.7rem;color:var(--gold-light);font-family:var(--font-body);font-weight:600;font-size:var(--fs-sm)}

.hero-stat-line{margin-top:var(--space-md);color:var(--muted);font-size:var(--fs-sm);max-width:560px}
.hero-stat-line strong{color:var(--gold-light);font-weight:600}

/* ---------- Highlights ---------- */
.highlights{padding:var(--space-lg) 0 0}
.highlights--festivals{padding-top:var(--space-lg)}
.highlights--festivals .section-head h2{position:relative}
.highlight-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:var(--space-sm)}
.hl-card{display:block;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.05rem 1.15rem;text-decoration:none;transition:border-color .15s,transform .15s,background .15s}
.hl-card:hover{border-color:var(--line-2);transform:translateY(-2px);background:var(--bg-3)}
.hl-type{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--tc,var(--gold))}
.hl-type .dot{width:7px;height:7px;border-radius:50%;background:var(--tc,var(--gold))}
.hl-title{font-family:var(--font-display);font-weight:600;font-size:var(--fs-lg);color:var(--ink);margin:.5rem 0 .25rem;line-height:1.12}
.hl-when{font-size:var(--fs-sm);color:var(--muted);margin:0}

/* ---------- Filterleiste ---------- */
.events-head{margin:var(--space-lg) 0 .2rem}
.events-head .muted{color:var(--muted);font-family:var(--font-body);font-size:var(--fs-sm)}
.filterbar{position:sticky;top:var(--header-h);z-index:150;background:rgba(20,14,24,.92);backdrop-filter:blur(8px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);transition:box-shadow .2s,border-color .2s}
.filterbar.is-stuck{box-shadow:0 12px 30px rgba(0,0,0,.5);border-bottom-color:var(--line-2);background:rgba(20,14,24,.97)}
.filterbar.is-stuck::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.filterbar-inner{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:.7rem 0}
.f-search{flex:1 1 200px;min-width:160px;display:flex;align-items:center;gap:.5rem;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-pill);padding:.5rem .9rem}
.f-search input{border:0;background:transparent;font-family:var(--font-body);font-size:var(--fs-sm);width:100%;color:var(--ink)}
.f-search input::placeholder{color:var(--muted-2)} .f-search input:focus{outline:none}
.f-search svg{flex:0 0 auto;color:var(--muted)}
select.f-city{font-family:var(--font-body);font-size:var(--fs-sm);color:var(--text);background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-pill);padding:.5rem .9rem;cursor:pointer}
.f-chips{display:flex;gap:.4rem;flex-wrap:wrap}
.chip{font-family:var(--font-body);font-size:var(--fs-xs);font-weight:500;padding:.45rem .9rem;border-radius:var(--radius-pill);border:1px solid var(--line-2);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}
.chip:hover{border-color:var(--gold-dim);color:var(--text)}
.chip.is-on{background:var(--gold);border-color:var(--gold);color:#1a130b}
.f-dates{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}
.f-range{display:flex;gap:.35rem;align-items:center}
.f-range input[type=date]{font-family:var(--font-body);font-size:var(--fs-xs);border:1px solid var(--line-2);border-radius:var(--radius-sm);padding:.35rem .55rem;background:var(--bg-2);color:var(--text);color-scheme:dark}
.view-toggle{display:inline-flex;border:1px solid var(--line-2);border-radius:var(--radius-pill);overflow:hidden;margin-left:auto}
.view-toggle button{font-family:var(--font-body);font-size:var(--fs-xs);font-weight:600;padding:.5rem .85rem;background:transparent;color:var(--muted);border:0;cursor:pointer;border-left:1px solid var(--line-2)}
.view-toggle button:first-child{border-left:0}
.view-toggle button.is-on{background:var(--gold);color:#1a130b}
.f-meta{display:flex;align-items:center;gap:.8rem;padding:.1rem 0 .7rem;font-size:var(--fs-xs);color:var(--muted)}
.f-reset{background:none;border:0;color:var(--gold-light);font-size:var(--fs-xs);font-weight:600;cursor:pointer;text-decoration:underline}

/* ---------- Layout Liste + Karte ---------- */
.events-section{padding:var(--space-lg) 0 var(--space-2xl)}
.events-layout{display:grid;grid-template-columns:1fr;gap:var(--space-lg);align-items:start}
body[data-view="both"] .events-layout{grid-template-columns:minmax(0,1.55fr) minmax(0,1fr)}
body[data-view="map"] #events-col{display:none}
body[data-view="map"] .events-layout{grid-template-columns:1fr}
body[data-view="list"] #map-col{display:none}
#map-col{position:sticky;top:calc(var(--header-h) + 74px)}

/* ---------- Datumsgruppen ---------- */
.day-head{display:flex;align-items:baseline;gap:.6rem;margin:var(--space-md) 0 .8rem;padding-bottom:.45rem;border-bottom:1px solid var(--line)}
.day-head .wd{font-family:var(--font-display);font-weight:600;font-size:var(--fs-lg);color:var(--gold-light)}
.day-head .today-tag{font-size:var(--fs-xs);font-weight:600;color:var(--workshop);text-transform:uppercase;letter-spacing:.1em}

/* ---------- Event-Karte ---------- */
.ev-card{display:grid;grid-template-columns:62px 1fr auto;gap:var(--space-sm);align-items:start;background:var(--bg-2);border:1px solid var(--line);border-left:3px solid var(--tc,var(--gold));border-radius:var(--radius);padding:.95rem 1.15rem;margin-bottom:.6rem;transition:border-color .15s,transform .15s,background .15s}
.ev-card:hover{border-color:var(--line-2);background:var(--bg-3);transform:translateY(-1px)}
.ev-date{text-align:center;line-height:1.05}
.ev-date .d{font-family:var(--font-display);font-weight:600;font-size:1.9rem;color:var(--ink)}
.ev-date .w{font-size:var(--fs-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.ev-date .m{font-size:var(--fs-xs);color:var(--muted-2);text-transform:uppercase}
.ev-main{min-width:0}
.ev-title{font-family:var(--font-display);font-weight:600;font-size:var(--fs-lg);color:var(--ink);margin:0 0 .2rem;line-height:1.15}
.ev-title a{color:inherit}.ev-title a:hover{color:var(--gold-light)}
.ev-meta{font-size:var(--fs-sm);color:var(--muted);display:flex;flex-wrap:wrap;gap:.2rem .9rem;align-items:center}
.ev-meta .mi{display:inline-flex;align-items:center;gap:.32rem}
.ev-meta svg,svg.i{width:14px;height:14px;color:var(--gold-dim);flex:0 0 auto}
.ev-aside{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;white-space:nowrap}
.ev-cost{font-size:var(--fs-xs);color:var(--muted)}
.ev-links{display:flex;gap:.5rem;align-items:center;font-size:var(--fs-xs)}
.ev-details{font-weight:600;color:var(--gold-light)}

/* Typ-Badges (getönt) */
.badge{font-family:var(--font-body);font-size:.7rem;font-weight:600;letter-spacing:.04em;padding:.22rem .65rem;border-radius:var(--radius-pill);white-space:nowrap}
.badge--milonga{color:var(--milonga);background:rgba(224,106,87,.15)}
.badge--practica{color:var(--practica);background:rgba(181,154,214,.15)}
.badge--workshop{color:var(--workshop);background:rgba(111,191,155,.15)}
.badge--festival{color:var(--festival);background:rgba(224,176,98,.15)}
.badge--kurs{color:var(--kurs);background:rgba(143,176,217,.15)}
.badge--schnupperkurs{color:var(--schnupperkurs);background:rgba(201,162,182,.15)}

.empty-state{text-align:center;padding:var(--space-xl) 0;color:var(--muted)}
.empty-state h3{color:var(--text)}

/* ---------- Pagination ---------- */
.pager{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.35rem;margin:var(--space-lg) 0 0}
.pager:empty{display:none}
.pg-btn{min-width:38px;height:38px;padding:0 .65rem;border-radius:10px;border:1px solid var(--line-2);background:var(--bg-2);color:var(--text);font-family:var(--font-body);font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:all .15s}
.pg-btn:hover:not([disabled]){border-color:var(--gold-dim);color:var(--gold-light)}
.pg-btn.is-on{background:var(--gold);border-color:var(--gold);color:#1a130b;font-weight:600}
.pg-btn[disabled]{opacity:.35;cursor:default}
.pg-dots{color:var(--muted);padding:0 .15rem}

/* ---------- Karte ---------- */
.map-wrap{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--bg-2);min-height:460px}
#til-map{height:540px;width:100%;background:var(--bg-2)}
.map-consent{position:absolute;inset:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.7rem;padding:var(--space-md);background:var(--bg-2)}
.map-consent svg{width:38px;height:38px;color:var(--gold)}
.map-consent h3{margin:0}.map-consent p{margin:0;max-width:320px;font-size:var(--fs-sm);color:var(--muted)}
.leaflet-popup-content-wrapper{background:var(--bg-3);color:var(--text);border-radius:10px}
.leaflet-popup-tip{background:var(--bg-3)}
.leaflet-popup-content{font-family:var(--font-body);font-size:var(--fs-sm)}
.leaflet-popup-content b{font-family:var(--font-display);font-size:var(--fs-base);color:var(--ink)}

/* ---------- Region-Tags ---------- */
.region{border-top:1px solid var(--line);padding:var(--space-lg) 0}
.region h2{font-size:var(--fs-xl)}
.region .sub{color:var(--muted);margin-bottom:var(--space-md)}
.region-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.region-tag{display:inline-flex;align-items:center;gap:.45rem;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-pill);padding:.45rem 1rem;font-size:var(--fs-sm);color:var(--text);font-weight:500}
.region-tag:hover{border-color:var(--gold-dim);color:var(--gold-light)}
.region-tag .cnt{font-size:var(--fs-xs);color:var(--muted)}

/* ---------- Inhalts-Sektionen ---------- */
.section{padding:var(--space-xl) 0}
.prose{max-width:var(--max-width-narrow);color:var(--text)}
.prose h2,.prose h3{font-family:var(--font-display);color:var(--ink)}
.prose h2{margin-top:1.4em}.prose h3{margin-top:1.2em}
.prose a{text-decoration:underline}
.prose strong{color:var(--ink)}
.prose .lead{font-size:var(--fs-lg);color:var(--ink);line-height:1.5}
.prose ul,.prose ol{padding-left:1.25rem;margin:1rem 0}
.prose li{margin:.35rem 0;color:var(--text)}
.prose ol li::marker,.prose ul li::marker{color:var(--gold-dim)}
.format-list{list-style:none;padding:0;margin:1.1rem 0}
.format-list li{position:relative;padding:.6rem 0 .6rem 1.5rem;border-bottom:1px solid var(--line);margin:0}
.format-list li:last-child{border-bottom:0}
.fmt-dot{position:absolute;left:0;top:1.05rem;width:10px;height:10px;border-radius:50%}
.card-cta{background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius);padding:var(--space-lg);text-align:center;box-shadow:var(--glow)}
.card-cta h2{color:var(--ink)} .card-cta p{color:var(--muted);max-width:48ch;margin-inline:auto}

/* ---------- Event-Detail & Inhaltsseiten ---------- */
.event-detail .badge{display:inline-block;margin-bottom:.6rem}
.event-back{font-size:var(--fs-sm)}
.event-facts{margin:var(--space-md) 0;border-top:1px solid var(--line)}
.event-facts .fact{display:grid;grid-template-columns:200px 1fr;gap:var(--space-sm);padding:.75rem 0;border-bottom:1px solid var(--line)}
.event-facts dt{margin:0;font-size:var(--fs-sm);font-weight:600;color:var(--muted);display:flex;align-items:center;gap:.45rem}
.event-facts dt svg{width:16px;height:16px;color:var(--gold-dim)}
.event-facts dd{margin:0;color:var(--text)} .event-facts .muted{color:var(--muted);font-size:var(--fs-sm)}
.event-desc{margin:var(--space-md) 0}
.event-actions{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:var(--space-md)}
.page-content{padding:var(--space-xl) 0}
.hero--compact .hero-inner{padding:var(--space-lg) 0 var(--space-md)}
.hero--compact .hero-title{font-size:var(--fs-2xl)}

/* Anbieter */
.provider-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-md);margin-top:var(--space-md)}
.provider-card{background:var(--bg-2);border:1px solid var(--line);border-top:3px solid var(--gold-dim);border-radius:var(--radius);padding:var(--space-md)}
.provider-card h3{margin-bottom:.2rem;color:var(--ink)}
.prov-city{display:flex;align-items:center;gap:.35rem;font-size:var(--fs-sm);color:var(--muted);margin:0 0 .6rem}
.prov-city svg{width:14px;height:14px;color:var(--gold-dim)}
.prov-desc{font-size:var(--fs-sm);color:var(--text);margin:0 0 .8rem}
.prov-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin:0 0 .9rem}
.prov-tag{font-size:var(--fs-xs);background:var(--bg-3);color:var(--text);padding:.15rem .6rem;border-radius:var(--radius-pill)}

/* FAQ */
.faq-list{margin:var(--space-sm) 0}
.faq{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:.6rem;background:var(--bg-2)}
.faq summary{cursor:pointer;padding:.85rem 1.1rem;font-family:var(--font-display);font-weight:600;font-size:var(--fs-lg);color:var(--ink);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--gold)}
.faq[open] summary::after{content:"\2013"}
.faq-a{padding:0 1.1rem 1rem;color:var(--text)}

/* Spotify */
.spotify-embed{background:var(--bg-2);border:1px dashed var(--gold-dim);border-radius:var(--radius);padding:var(--space-md);text-align:center}
.spotify-embed p{color:var(--muted);font-size:var(--fs-sm)}

/* ---------- Footer ---------- */
.site-footer{background:#120D15;border-top:1px solid var(--line);padding:var(--space-xl) 0 var(--space-lg);margin-top:var(--space-xl)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:var(--space-lg)}
.footer-brand .wordmark{font-size:1.25rem}
.footer-brand p{font-size:var(--fs-sm);color:var(--muted);max-width:36ch;margin-top:.7rem}
.footer-col h4{color:var(--text);font-family:var(--font-body);font-size:var(--fs-xs);font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.9rem}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.footer-col a{color:var(--muted);font-size:var(--fs-sm)} .footer-col a:hover{color:var(--gold-light)}
.footer-bottom{border-top:1px solid var(--line);margin-top:var(--space-lg);padding-top:var(--space-md);display:flex;justify-content:space-between;gap:var(--space-md);flex-wrap:wrap;font-size:var(--fs-xs);color:var(--muted-2)}
.footer-bottom a{color:var(--muted)} .footer-bottom strong{color:var(--gold-light);font-weight:600}

/* ---------- Scroll-to-top ---------- */
#scroll-top{position:fixed;right:1.2rem;bottom:1.2rem;z-index:180;width:46px;height:46px;border-radius:50%;background:var(--gold);color:#1a130b;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s,transform .15s;box-shadow:var(--shadow)}
#scroll-top.show{opacity:1;pointer-events:auto} #scroll-top:hover{transform:translateY(-2px);background:var(--gold-light)}

/* ---------- Datenschutz-/Cookie-Hinweis (dezent, einmalig schließbar) ---------- */
.cookie-note{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:190;max-width:720px;margin:0 auto;display:flex;align-items:center;gap:1.1rem;padding:.85rem 1.15rem;background:var(--bg-raised);border:1px solid var(--line-2);border-top:2px solid var(--gold);border-radius:var(--radius-sm);box-shadow:0 10px 34px rgba(0,0,0,.5);transform:translateY(calc(100% + 1.5rem));opacity:0;transition:transform .45s cubic-bezier(.2,.7,.2,1),opacity .4s;pointer-events:none}
.cookie-note.show{transform:none;opacity:1;pointer-events:auto}
.cookie-note__text{margin:0;font-size:var(--fs-sm);color:var(--text);line-height:1.55}
.cookie-note__text strong{color:var(--ink);font-weight:600}
.cookie-note__text a{color:var(--gold-light);text-decoration:underline;text-underline-offset:2px}
.cookie-note__text a:hover{color:var(--gold)}
.cookie-note__btn{flex:0 0 auto;font-family:var(--font-body);font-size:var(--fs-sm);font-weight:600;color:#1a130b;background:var(--gold);border:0;border-radius:var(--radius-pill);padding:.55rem 1.3rem;cursor:pointer;transition:background .15s,transform .15s}
.cookie-note__btn:hover{background:var(--gold-light);transform:translateY(-1px)}
.cookie-note__btn:focus-visible{outline:2px solid var(--gold-light);outline-offset:2px}
@media (max-width:600px){.cookie-note{left:0;right:0;bottom:0;border-radius:0;border-left:0;border-right:0;flex-direction:column;align-items:stretch;gap:.7rem}.cookie-note__btn{width:100%}}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  body[data-view="both"] .events-layout{grid-template-columns:1fr}
  body[data-view="both"] #map-col{display:none}
  #map-col{position:static}
}
@media (max-width:768px){
  .main-nav{position:fixed;top:var(--header-h);left:0;right:0;background:var(--bg);flex-direction:column;align-items:stretch;gap:0;padding:var(--space-sm) var(--space-md) var(--space-md);transform:translateY(-130%);transition:transform .25s;box-shadow:var(--shadow);border-bottom:1px solid var(--line)}
  .main-nav.open{transform:translateY(0)}
  .nav-links{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .nav-links a{padding:.85rem 0;width:100%;border-bottom:1px solid var(--line);font-size:1.05rem}
  .nav-links a::after{display:none}
  .lang-switch{margin:1rem 0 0;padding:0;border-left:0;align-self:flex-start}
  .nav-toggle{display:block}
  .view-toggle{margin-left:0}
  .footer-grid{grid-template-columns:1fr;gap:var(--space-md)}
  .ev-card{grid-template-columns:50px 1fr;grid-template-areas:"date main" "date aside";row-gap:.5rem}
  .ev-aside{grid-area:aside;flex-direction:row;align-items:center;justify-content:flex-start;gap:.8rem}
  .ev-date .d{font-size:1.55rem}
  .event-facts .fact{grid-template-columns:1fr;gap:.1rem}
}
@media (max-width:479px){ .hero-title{font-size:2.2rem} .container{padding:0 var(--space-sm)} }
