@font-face {
  font-family: 'Robust';
  src: url('assets/fonts/ROBUST.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}


/*
Theme Name: Windpark Festival WP (Lite)
Theme URI: https://example.com/windpark-festival-wp
Author: ChatGPT
Author URI: https://example.com
Description: Ein schlankes One-Page-Event/Festival-Theme für WordPress mit Sektionen (Hero, Infos, Line-up, Tickets, Media, Kontakt). Keine Fremdinhalte – alles per Customizer einstellbar. Enthält CPT "Artists".
Version: 1.1.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: windpark-festival-wp
Tags: one-column, custom-logo, custom-menu, featured-images, custom-colors, event, festival, one-page
*/
:root{
  --bg: #0b0c10;
  --surface: #121318;
  --card: #181a20;
  --text: #e9ecf1;
  --muted: #b9bfca;
  --accent: #5de0e6;
  --accent2: #004aad;
  --border: #222631;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family: 'Robust', Arial, Helvetica, sans-serif;color:var(--text);background:linear-gradient(180deg,#0b0c10 0%,#121318 100%);line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(1120px,92%);margin:0 auto}
.site-header{position:sticky;top:0;background:rgba(11,12,16,.7);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);z-index:50}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;letter-spacing:.3px}
.brand img{height:28px;width:auto}
.nav{display:flex;gap:1rem;flex-wrap:wrap}
.nav a{color:var(--text);opacity:.9;font-weight:600}
.nav a:hover{opacity:1}
.burger{display:none;background:none;border:0;color:var(--text);font-size:1.2rem}
@media (max-width:820px){
  .nav{display:none}
  .burger{display:block}
  .nav.open{display:flex;flex-direction:column;gap:.6rem;position:absolute;top:60px;right:16px;background:var(--surface);border:1px solid var(--border);padding:.6rem 1rem;border-radius:12px}
}
.hero{min-height:78vh;display:grid;place-items:center;text-align:center;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(45% 40% at 50% 40%,rgba(93,224,230,.20) 0%,rgba(0,0,0,0) 70%)}
.hero-inner{position:relative;padding:7rem 0 4rem}
.hero h1{margin:0 0 .4rem;font-size:clamp(2.2rem,6vw,4rem)}
.hero .lead{margin:0 0 1.2rem;color:var(--muted);font-size:clamp(1.05rem,2.2vw,1.4rem)}
.btn{display:inline-block;padding:.85rem 1.2rem;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent2));color:#fff;font-weight:800;letter-spacing:.3px;border:0}
section{padding:4rem 0}
.section-title{font-size:clamp(1.6rem,3vw,2.2rem);margin:0 0 .6rem}
.subtle{color:var(--muted)}
.grid-2{display:grid;grid-template-columns:1fr;gap:1.4rem}
@media(min-width:960px){.grid-2{grid-template-columns:1.2fr .8fr}}
.notice{padding:.9rem 1rem;border-radius:12px;background:#0d1a28;border:1px solid #193048;color:#cfe9ff;margin-bottom:.6rem}
table.info{width:100%;border-collapse:collapse;margin-top:1rem}
table.info td{border-bottom:1px solid var(--border);padding:.6rem .2rem}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden}
.card .p{padding:.9rem 1rem}
.badge{display:inline-block;border:1px solid #2a2f3a;border-radius:999px;padding:.2rem .6rem;color:#eaeaea;font-size:.82rem}
.embed{aspect-ratio:16/9;background:#0b0c10;border:1px solid var(--border);border-radius:16px;display:grid;place-items:center}
.site-footer{padding:3rem 0;border-top:1px solid var(--border);color:var(--muted)}
.footer-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between}
.cookie{position:fixed;inset:auto 1rem 1rem 1rem;background:#111;border:1px solid var(--border);border-radius:12px;padding:1rem;display:none;z-index:60}
.cookie.on{display:block}
.cookie .actions{display:flex;gap:.6rem;margin-top:.6rem}


.countdown{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}
.countdown .cd{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:.6rem .8rem;min-width:86px;text-align:center}
.countdown .cd .n{display:block;font-weight:800;font-size:1.3rem}
.countdown .cd .l{display:block;color:var(--muted);font-size:.8rem}



/* Hero background video */
.hero{position:relative; overflow:hidden}
.hero .hero-video-wrap{position:absolute; inset:0; z-index:0; pointer-events:none}
.hero .hero-video{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:var(--hero-video-opacity, .35);}
.hero .hero-overlay{position:absolute; inset:0; background:radial-gradient(40% 35% at 50% 30%, rgba(93,224,230,.20) 0%, rgba(0,0,0,0) 70%), linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.35)); z-index:1;}
.hero .hero-inner{position:relative; z-index:2}

.hero-video {
  position: relative;
  -webkit-mask-image: linear-gradient(to bottom, black 85%, transparent 100%);
          mask-image: linear-gradient(to bottom, black 85%, transparent 100%);
}

/* Overlay lässt oben & unten ins Transparente auslaufen und blockiert keine Klicks */
.hero .hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: none; /* Basis löschen, wir nutzen die Maske */
  /* Transparente Maske: Mitte sichtbar, Ränder ausfaden */
  -webkit-mask-image: linear-gradient(
    to bottom,
    transparent 0%,
    black 12%,
    black 88%,
    transparent 100%
  );
          mask-image: linear-gradient(
    to bottom,
    transparent 0%,
    black 12%,
    black 88%,
    transparent 100%
  );
  background-color: rgba(0,0,0,0.35); /* leichte Abdunkelung in der Mitte */
}

/* --- Ensure Tickets button is clickable --- */
#tickets { position: relative; z-index: 10; }
#tickets .tickets-btn {
  display: inline-block;
  cursor: pointer !important;
  pointer-events: auto !important;
}

/* Falls ein Hero-Video/Overlay überlappt, keine Klicks abfangen: */
.hero .hero-video-wrap,
.hero .hero-overlay {
  pointer-events: none !important;
}

/* Header Titel höher setzen */
.hero .site-title {
  margin-bottom: 0.2em;   /* weniger Abstand nach unten */
  transform: translateY(-10px); /* leicht nach oben verschieben */
}

/* Jahreszahl direkt darunter */
.hero .site-year {
  display: block;
  font-size: 3.5em;
  font-weight: 400;
  margin-top: 0;
	
	  /* Schwarze Kontur via Textschatten */
  text-shadow:
     -1px -1px 0 #000,
      1px -1px 0 #000,
     -1px  1px 0 #000,
      1px  1px 0 #000;
}

.xtended-contact { max-width: 760px; margin: 0 auto; }
.xtended-contact .row { margin-bottom: 14px; text-align: left; }
.xtended-contact label { display: block; font-weight: 600; margin-bottom: 6px; }
.xtended-contact input[type="email"],
.xtended-contact input[type="text"],
.xtended-contact textarea {
  width: 100%; padding: .75rem; border-radius: 10px; border: 1px solid #2a2a2a;
  background: #111; color: #fff;
}
.xtended-contact .req { color: #ff7b7b; }
.contact-alert { padding: .8rem 1rem; border-radius: 10px; margin-bottom: 1rem; }
.contact-alert.success { background: #0e2a18; border: 1px solid #1f5a35; color: #c7f0d2; }
.contact-alert.error   { background: #2a1414; border: 1px solid #5a1f1f; color: #f0c7c7; }

/* Tickets-Hintergrund mit weicher Transparenz oben & unten */
#tickets {
  position: relative;
  padding: 60px 0;
  /* kein background hier – das Bild kommt in ::before */
}

#tickets::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("http://xtended-events.de/wp-content/uploads/2025/08/abstract-metal-background-light-falls-metal-generative-ai.jpg") center/cover no-repeat;
  z-index: 0;
  pointer-events: none;

  /* Maske: oben & unten ausblenden (transparent) */
  -webkit-mask-image: linear-gradient(
    to bottom,
    transparent 0%,
    black 12%,
    black 88%,
    transparent 100%
  );
          mask-image: linear-gradient(
    to bottom,
    transparent 0%,
    black 12%,
    black 88%,
    transparent 100%
  );
}

#tickets .container {
  position: relative; /* Inhalt über dem Bild */
  z-index: 1;
}






/* Footer .small zentrieren und untereinander darstellen */
.site-footer .small {
  display: flex;
  flex-direction: left; /* Inhalte untereinander */
  align-items: center;    /* horizontal zentrieren */
  text-align: left;     /* Text mittig ausrichten */
  gap: 6px;               /* Abstand zwischen Zeilen/Links */
}

/* Optional: Social-Icons unter .small setzen (wenn nötig) */
.site-footer .footer-row {
  flex-wrap: wrap;        /* erlaubt Zeilenumbruch */
  justify-content: center;
}

/* Schwarze Kontur um den Tickets-Titel */
#tickets .section-title {
  color: #fff; /* Textfarbe anpassen */
  text-shadow:
     -1.5px -1.5px 0 #000,  
      1.5px -1.5px 0 #000,
     -1.5px  1.5px 0 #000,
      1.5px  1.5px 0 #000; /* 4 Richtungen für saubere Kontur */
}
/* Schriftgröße des Tickets-Titels ändern */
#tickets .section-title {
  font-size: 55px; /* Hier die gewünschte Größe eintragen */
}
/* Größe des Hero-h1 ("X-Tended Festival") */
.hero h1 {
  font-size: 90px;     /* gewünschte Größe */
  line-height: 1.1;    /* Zeilenhöhe für besseren Abstand */
  font-weight: normal; /* falls du es leichter haben willst */
	
	  /* Schwarze Kontur via Textschatten */
  text-shadow:
     -1px -1px 0 #000,
      1px -1px 0 #000,
     -1px  1px 0 #000,
      1px  1px 0 #000;
}

.site-footer .social-icons {
  display: flex;
  gap: 15px;
  justify-content: right; /* oder left/right */
  margin-top: 10px;
}
.site-footer .social-icons a {
  color: #fff; /* Icon-Farbe */
  font-size: 24px;
  transition: color 0.3s;
}
.site-footer .social-icons a:hover {
  color: #caf0f8; /* Hover-Farbe */
}

/* Logo neben Site-Name sicher anzeigen */
.site-header .brand .brand-link{
  display:inline-flex !important;
  align-items:center !important;
  gap:10px !important;
  text-decoration:none;
  color:inherit;
}
/* ===== Logo: nutzt Customizer-Variablen ===== */
.site-header .brand{
  /* Default-Werte (werden vom Customizer überschrieben) */
  --logo-scale:    1;
  --logo-offset-x: 0px;
  --logo-offset-y: 0px;
  --logo-max-h:    60px;
  --logo-base-h:   50px; /* Grundhöhe, bevor skaliert wird */
}

.site-header .brand .site-logo{
  display: inline-block !important;
  width: auto !important;
  height: var(--logo-base-h) !important;
  max-height: var(--logo-max-h) !important;

  position: relative !important;
  top: var(--logo-offset-y) !important;
  left: var(--logo-offset-x) !important;

  transform: scale(var(--logo-scale)) !important;
  transform-origin: left center !important;
  vertical-align: middle !important;
}

}
/* Site-Name (X-Tended Festival) anpassen */
.site-header .brand .site-name {
  font-size: 25px;   /* Schriftgröße – hier anpassen */
  font-weight: 700;  /* Schriftstärke */
  line-height: 1.2;  /* Zeilenhöhe */
}
@media (max-width: 768px) {
  .site-header .brand .site-name {
    font-size: 22px; /* Mobile Größe */
  }
}

.accordion { max-width: 900px; margin: 0 auto; }
.accordion .accordion-controls {
  display: flex; gap: 10px; justify-content: flex-end; margin-bottom: 10px;
}
.accordion .accordion-controls .btn {
  padding: .5rem .8rem; border-radius: 10px; border: 1px solid #2a2f3a;
  background: #181a20; color: #e9ecf1; cursor: pointer;
}
.accordion .accordion-controls .btn:hover { filter: brightness(1.1); }

.accordion details {
  border: 1px solid #2a2f3a;
  border-radius: 12px;
  margin: 10px 0;
  background: #181a20;
  overflow: hidden;
  transition: border-color .2s ease;
}
.accordion details[open] { border-color: #3a4152; }

.accordion summary {
  cursor: pointer;
  list-style: none;     /* Standard-Marker ausblenden */
  padding: 14px 18px;
  font-weight: 700;
  position: relative;
}
.accordion summary::-webkit-details-marker { display: none; }

.accordion summary::after {
  content: "▸";
  position: absolute;
  right: 16px;
  transition: transform .2s ease;
}
.accordion details[open] summary::after { transform: rotate(90deg); }

.accordion .panel {
  padding: 12px 18px 18px;
  color: #e9ecf1;
  border-top: 1px solid #2a2f3a;
}

/* =========================
   Accordion (XF)
   ========================= */
.x-accordion{
  /* Standardwerte (kannst du global hier ändern) */
  --xf-title-size: 1.2rem;
  --xf-body-size:  1.0rem;

  /* "Größe des Hintergrundes" = Innenabstände  (höhe/breite der Fläche) */
  --xf-title-py: 16px;  /* oben/unten im Kopf */
  --xf-title-px: 18px;  /* links/rechts im Kopf */
  --xf-panel-py: 14px;  /* oben/unten im Panel */
  --xf-panel-px: 18px;  /* links/rechts im Panel */

  --xf-radius: 12px;
  --xf-gap:    10px;

  /* Farben */
  --xf-title-bg:  #181a20;
  --xf-title-col: #e9ecf1;
  --xf-panel-bg:  #0f1117;
  --xf-panel-col: #e9ecf1;
  --xf-border:     #2a2f3a;
  --xf-border-open:#3a4152;
  --xf-hover:      #1d212a;

  /* Cursor */
  --xf-cursor: pointer;

  max-width: 900px;
  margin: 0 auto;
}

.x-accordion .x-acc-controls{
  display:flex; gap:10px; justify-content:flex-end; margin-bottom:10px;
}
.x-accordion .x-acc-controls .btn{
  padding:.5rem .8rem; border-radius:10px; border:1px solid var(--xf-border);
  background: var(--xf-title-bg); color: var(--xf-title-col); cursor:pointer;
}
.x-accordion .x-acc-controls .btn:hover{ filter:brightness(1.08); }

.x-accordion .x-acc-item{
  border:1px solid var(--xf-border) !important;
  border-radius: var(--xf-radius) !important;
  margin: var(--xf-gap) 0 !important;
  overflow:hidden;
}
.x-accordion .x-acc-item[open]{ border-color: var(--xf-border-open) !important; }

/* Reiterkopf (Überschrift) */
.x-accordion .x-acc-head{
  display:block;
  background: var(--xf-title-bg) !important;
  color: var(--xf-title-col) !important;
  padding: var(--xf-title-py) var(--xf-title-px) !important;
  font-weight: 800;
  font-size: var(--xf-title-size);
  line-height: 1.35;
  position: relative;
  list-style: none;
  cursor: var(--xf-cursor) !important;
  user-select: none;
}
.x-accordion .x-acc-head::-webkit-details-marker{ display:none; }

/* Pfeil rechts */
.x-accordion .x-acc-item > .x-acc-head::after{
  content:"▸";
  position:absolute; right:16px; top:50%; transform:translateY(-50%);
  transition: transform .2s ease;
  opacity:.85;
}
.x-accordion .x-acc-item[open] > .x-acc-head::after{ transform: translateY(-50%) rotate(90deg); }

.x-accordion .x-acc-head:hover{ background: var(--xf-hover) !important; }

/* Panel (Inhalt) */
.x-accordion .x-acc-panel{
  background: var(--xf-panel-bg) !important;
  color: var(--xf-panel-col) !important;
  font-size: var(--xf-body-size);
  line-height: 1.6;
  padding: var(--xf-panel-py) var(--xf-panel-px) !important;
  border-top:1px solid var(--xf-border);
}

/* Fokus sichtbar für Tastatur-Nutzer (Barrierefreiheit) */
.x-accordion .x-acc-head:focus,
.x-accordion .x-acc-head:focus-visible{
  outline: 2px solid #3b82f6; outline-offset: 2px;
}

/* Header: Cursor auf Links & Brand */
.site-header .nav a,
.site-header .brand .brand-link { cursor: pointer !important; }

.faq-heading{
  font-size:24px; font-weight:700;
  margin:2rem 0 1rem; padding:10px 15px;
  background:#2a2f3a; color:#fff; border-radius:6px;
}


/* FAQ fixierte Überschriften */
.faq-heading {
  font-size: 24px;           /* Schriftgröße */
  font-weight: 700;
  margin: 2rem 0 1rem;       /* Abstand oben/unten */
  padding: 10px 15px;        /* Innenabstand */
  background: #2a2f3a;       /* Hintergrundfarbe */
  color: #ffffff;            /* Textfarbe */
  border-radius: 6px;        /* abgerundete Ecken */
  text-align: left;
}

