/*
Theme Name: Junge Paldauer
Theme URI: https://www.junge-paldauer.at
Author: Die Jungen Paldauer
Description: Modernes WordPress-Theme – Bühnenlicht-Atmosphäre, warm-dunkel, orange-amber Töne.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: junge-paldauer
*/

/* ============================================================
   CSS VARIABLES
   ============================================================ */
:root {
  --jp-orange:       #E8540A;
  --jp-orange-light: #FF7A2F;
  --jp-amber:        #C47A1E;
  --jp-gold:         #D4A017;
  --jp-gold-light:   #F0C84A;
  --jp-dark:         #080503;
  --jp-dark-2:       #120D08;
  --jp-dark-3:       #1E1508;
  --jp-dark-4:       #2A1E0C;
  --jp-dark-5:       #382A12;
  --jp-gray:         #9A8870;
  --jp-light:        #F5EED8;
  --jp-white:        #FFFFFF;
  --jp-font-heading: 'Oswald', 'Arial Narrow', sans-serif;
  --jp-font-body:    'Open Sans', 'Helvetica Neue', sans-serif;
  --jp-transition:   0.3s ease;
  --jp-radius:       4px;
  --jp-shadow-orange: 0 0 40px rgba(232,84,10,0.5);
  --jp-shadow-gold:   0 0 30px rgba(212,160,23,0.3);
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background-color:var(--jp-dark);
  background-image:radial-gradient(ellipse 80% 40% at 50% 0%,rgba(180,60,5,0.12) 0%,transparent 60%);
  color:var(--jp-light);
  font-family:var(--jp-font-body);
  font-size:16px;line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--jp-orange);text-decoration:none;transition:color var(--jp-transition)}
a:hover{color:var(--jp-orange-light)}
h1,h2,h3,h4,h5,h6{font-family:var(--jp-font-heading);font-weight:700;line-height:1.15;letter-spacing:0.03em;color:var(--jp-white);text-transform:uppercase}
h1{font-size:clamp(2.2rem,6vw,4.5rem)}
h2{font-size:clamp(1.6rem,4vw,2.8rem)}
h3{font-size:clamp(1.1rem,3vw,1.6rem)}
p{margin-bottom:1rem}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.container--wide{max-width:1400px;margin:0 auto;padding:0 1.5rem}
.container--narrow{max-width:800px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:2rem}
.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}
.text-center{text-align:center}

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.section-heading{text-align:center;margin-bottom:3rem}
.section-heading__label{display:inline-block;font-size:.75rem;font-family:var(--jp-font-heading);letter-spacing:.4em;color:var(--jp-gold);text-transform:uppercase;margin-bottom:.5rem}
.section-heading__title{margin-bottom:.75rem}
.section-heading__line{width:60px;height:3px;background:linear-gradient(90deg,transparent,var(--jp-orange),var(--jp-gold),var(--jp-orange),transparent);margin:0 auto}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-block;padding:.85rem 2rem;font-family:var(--jp-font-heading);font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;border:none;cursor:pointer;transition:all var(--jp-transition);border-radius:var(--jp-radius);font-weight:600}
.btn--primary{background:linear-gradient(135deg,var(--jp-orange),var(--jp-amber));color:var(--jp-white);box-shadow:0 2px 16px rgba(232,84,10,.3)}
.btn--primary:hover{background:linear-gradient(135deg,var(--jp-orange-light),var(--jp-orange));color:var(--jp-white);transform:translateY(-2px);box-shadow:var(--jp-shadow-orange)}
.btn--gold{background:linear-gradient(135deg,var(--jp-gold),var(--jp-amber));color:var(--jp-dark);font-weight:700}
.btn--gold:hover{background:linear-gradient(135deg,var(--jp-gold-light),var(--jp-gold));color:var(--jp-dark);transform:translateY(-2px);box-shadow:var(--jp-shadow-gold)}
.btn--outline{background:transparent;color:var(--jp-orange-light);border:2px solid var(--jp-orange)}
.btn--outline:hover{background:rgba(232,84,10,.15);color:var(--jp-orange-light);border-color:var(--jp-orange-light)}
.btn--dark{background:rgba(255,255,255,.07);color:var(--jp-light);border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(4px)}
.btn--dark:hover{background:rgba(255,255,255,.12);color:var(--jp-white)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(8,5,3,.85);backdrop-filter:blur(12px);border-bottom:1px solid rgba(232,84,10,.25);transition:all var(--jp-transition)}
.site-header.scrolled{background:rgba(12,8,4,.97);border-bottom-color:rgba(232,84,10,.4);box-shadow:0 2px 30px rgba(0,0,0,.9)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.5rem;max-width:1200px;margin:0 auto}
.site-logo{display:flex;align-items:center;gap:.75rem}
.site-logo img{height:48px;width:auto}
.site-logo__text{font-family:var(--jp-font-heading);font-size:1.35rem;color:var(--jp-white);text-transform:uppercase;letter-spacing:.06em;line-height:1}
.site-logo__text span{color:var(--jp-orange)}
.main-nav ul{display:flex;list-style:none;padding:0;margin:0;gap:.1rem}
.main-nav a{display:block;padding:.5rem .85rem;font-family:var(--jp-font-heading);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(245,238,216,.8);border-radius:var(--jp-radius);transition:all var(--jp-transition)}
.main-nav a:hover,.main-nav .current-menu-item>a{color:var(--jp-orange-light);background:rgba(232,84,10,.12)}
.burger-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px}
.burger-btn span{display:block;width:25px;height:2px;background:var(--jp-light);transition:all var(--jp-transition)}
@media(max-width:768px){
  .burger-btn{display:flex}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(12,8,4,.98);border-top:2px solid var(--jp-orange);padding:1rem;backdrop-filter:blur(10px)}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:0}
  .main-nav a{padding:.8rem 1rem;font-size:1rem;border-bottom:1px solid rgba(255,255,255,.06)}
}

/* ============================================================
   HERO — Bühnenlicht wie Plakat
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:var(--jp-dark)}

/* Bühnenstrahler oben */
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 60% at 15% -10%,rgba(255,110,20,.45) 0%,transparent 65%),
    radial-gradient(ellipse 70% 60% at 85% -10%,rgba(220,70,10,.40) 0%,transparent 65%),
    radial-gradient(ellipse 50% 40% at 50% -5%, rgba(255,160,40,.30) 0%,transparent 55%),
    radial-gradient(ellipse 90% 70% at 50% 110%,rgba(100,30,5,.60) 0%,transparent 70%);
  z-index:1;
}

.hero__bg{position:absolute;inset:0;background-image:url('assets/images/hero-bg.jpg');background-size:cover;background-position:center top;opacity:.22}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,5,3,.2) 0%,rgba(8,5,3,.55) 55%,rgba(8,5,3,1) 100%);z-index:2}

.hero__content{position:relative;z-index:3;padding:2rem;max-width:950px}

.hero__label{
  display:inline-block;font-family:var(--jp-font-heading);font-size:.78rem;letter-spacing:.5em;
  color:var(--jp-gold-light);text-transform:uppercase;margin-bottom:1.5rem;
  opacity:0;animation:fadeInDown .8s .2s forwards;
}

.hero__title{
  font-size:clamp(3.5rem,9vw,7rem);margin-bottom:.3rem;
  opacity:0;animation:fadeInDown .8s .4s forwards;color:var(--jp-white);
  text-shadow:0 0 40px rgba(232,84,10,.7),0 0 80px rgba(232,84,10,.3),0 4px 8px rgba(0,0,0,.9);
}
.hero__title span{color:var(--jp-orange-light);text-shadow:0 0 30px rgba(255,120,40,.9),0 0 70px rgba(232,84,10,.5)}

.hero__subtitle{
  font-family:var(--jp-font-heading);font-size:clamp(.8rem,2vw,1rem);letter-spacing:.35em;
  color:var(--jp-gold);text-transform:uppercase;margin-bottom:2.5rem;
  opacity:0;animation:fadeInDown .8s .6s forwards;text-shadow:0 0 20px rgba(212,160,23,.4);
}

.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeInUp .8s .8s forwards}

.hero__scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--jp-gray);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;font-family:var(--jp-font-heading);animation:bounce 2.5s infinite;z-index:3}

@keyframes fadeInDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ============================================================
   TICKER
   ============================================================ */
.ticker{background:linear-gradient(90deg,#8B2E00,var(--jp-orange),var(--jp-amber),var(--jp-orange),#8B2E00);padding:.65rem 0;overflow:hidden}
.ticker__inner{display:flex;white-space:nowrap;animation:ticker 35s linear infinite}
.ticker__item{font-family:var(--jp-font-heading);font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;color:var(--jp-white);padding:0 2rem}
.ticker__sep{color:rgba(255,255,255,.4)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   EVENTS
   ============================================================ */
.events-section{background:linear-gradient(180deg,var(--jp-dark-2) 0%,var(--jp-dark) 100%)}
.events-list{display:flex;flex-direction:column;gap:.6rem}

.event-card{
  display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:1.5rem;
  padding:1.25rem 1.5rem;
  background:linear-gradient(135deg,var(--jp-dark-3),var(--jp-dark-4));
  border-radius:var(--jp-radius);border-left:3px solid var(--jp-orange);
  transition:all var(--jp-transition);box-shadow:0 2px 12px rgba(0,0,0,.4);
}
.event-card:hover{background:linear-gradient(135deg,var(--jp-dark-4),var(--jp-dark-5));transform:translateX(4px);box-shadow:0 4px 24px rgba(0,0,0,.6),-4px 0 0 var(--jp-orange)}
.event-card__day{font-family:var(--jp-font-heading);font-size:2rem;color:var(--jp-orange-light);line-height:1;text-shadow:0 0 20px rgba(232,84,10,.5)}
.event-card__month{font-size:.65rem;font-family:var(--jp-font-heading);letter-spacing:.15em;color:var(--jp-gold);text-transform:uppercase}
.event-card__info h3{font-size:.95rem;margin-bottom:.2rem}
.event-card__location{font-size:.82rem;color:var(--jp-gray)}
.events-empty{text-align:center;padding:3rem;color:var(--jp-gray)}

/* ============================================================
   BAND
   ============================================================ */
.band-section{
  background:var(--jp-dark);
  background-image:
    radial-gradient(ellipse 60% 50% at 20% 0%,rgba(232,84,10,.12) 0%,transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 0%,rgba(200,70,10,.10) 0%,transparent 60%),
    linear-gradient(180deg,var(--jp-dark) 0%,var(--jp-dark-2) 50%,var(--jp-dark) 100%);
}
.member-card{position:relative;border-radius:var(--jp-radius);overflow:hidden;background:var(--jp-dark-3);transition:transform var(--jp-transition),box-shadow var(--jp-transition)}
.member-card:hover{transform:translateY(-8px);box-shadow:0 16px 40px rgba(0,0,0,.7),0 0 30px rgba(232,84,10,.2)}
.member-card__img{aspect-ratio:3/4;overflow:hidden}
.member-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease,filter .4s;filter:grayscale(30%) sepia(20%)}
.member-card:hover .member-card__img img{transform:scale(1.06);filter:grayscale(0%) sepia(5%)}
.member-card__overlay{position:absolute;bottom:0;left:0;right:0;padding:2.5rem 1.25rem 1.25rem;background:linear-gradient(to top,rgba(8,5,3,.97) 0%,rgba(30,15,5,.7) 60%,transparent 100%)}
.member-card__name{font-size:1.1rem;margin-bottom:.15rem}
.member-card__role{font-size:.72rem;color:var(--jp-gold);font-family:var(--jp-font-heading);letter-spacing:.18em;text-transform:uppercase}

/* ============================================================
   CTA STRIP
   ============================================================ */
.cta-strip{position:relative;padding:5rem 0;text-align:center;overflow:hidden;background:linear-gradient(135deg,#1A0A02,#2A1205,#1A0A02)}
.cta-strip::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(232,84,10,.22) 0%,transparent 70%),radial-gradient(ellipse 50% 40% at 20% 0%,rgba(255,120,30,.18) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 80% 0%,rgba(200,70,10,.15) 0%,transparent 60%)}
.cta-strip .container{position:relative;z-index:1}
.cta-strip h2{color:var(--jp-white);margin-bottom:.75rem;text-shadow:0 0 40px rgba(232,84,10,.6)}
.cta-strip p{color:rgba(245,238,216,.75);font-size:1.05rem;margin-bottom:2rem}

/* ============================================================
   NEWS
   ============================================================ */
.news-section{background:linear-gradient(180deg,var(--jp-dark-2) 0%,var(--jp-dark) 100%)}
.news-card{background:linear-gradient(160deg,var(--jp-dark-3),var(--jp-dark-4));border-radius:var(--jp-radius);overflow:hidden;transition:transform var(--jp-transition),box-shadow var(--jp-transition);display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.04)}
.news-card:hover{transform:translateY(-5px);box-shadow:0 12px 30px rgba(0,0,0,.6),0 0 20px rgba(232,84,10,.1)}
.news-card__img{aspect-ratio:16/9;overflow:hidden}
.news-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,filter .3s;filter:sepia(15%)}
.news-card:hover .news-card__img img{transform:scale(1.05);filter:sepia(0%)}
.news-card__img--placeholder{background:var(--jp-dark-4);display:flex;align-items:center;justify-content:center;color:var(--jp-orange)}
.news-card__body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.news-card__cat{font-size:.68rem;font-family:var(--jp-font-heading);letter-spacing:.25em;color:var(--jp-gold);text-transform:uppercase;margin-bottom:.5rem}
.news-card__title{font-size:.95rem;margin-bottom:.75rem}
.news-card__excerpt{font-size:.88rem;color:var(--jp-gray);flex:1;margin-bottom:1rem}
.news-card__meta{font-size:.78rem;color:var(--jp-gray);display:flex;align-items:center;gap:.5rem}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-section{background:var(--jp-dark);background-image:radial-gradient(ellipse 60% 50% at 20% 0%,rgba(232,84,10,.12) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 0%,rgba(200,70,10,.10) 0%,transparent 60%)}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.4rem}
.gallery-item{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,filter .4s;filter:grayscale(20%) sepia(25%) brightness(.9)}
.gallery-item:hover img{transform:scale(1.08);filter:grayscale(0%) sepia(0%) brightness(1.05)}
.gallery-item__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(232,84,10,.75),rgba(180,50,0,.75));display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--jp-transition)}
.gallery-item:hover .gallery-item__overlay{opacity:1}
.gallery-item__overlay svg{color:white}

/* ============================================================
   CONTACT / FORMS
   ============================================================ */
.contact-section{background:linear-gradient(180deg,var(--jp-dark) 0%,var(--jp-dark-2) 100%)}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:start}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr;gap:2rem}}
.contact-item{display:flex;gap:1rem;margin-bottom:1.5rem}
.contact-item__icon{width:44px;height:44px;background:linear-gradient(135deg,rgba(232,84,10,.2),rgba(200,60,0,.1));border:1px solid rgba(232,84,10,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--jp-orange);flex-shrink:0}
.contact-item__label{font-size:.72rem;color:var(--jp-gold);text-transform:uppercase;letter-spacing:.12em;font-family:var(--jp-font-heading)}
.contact-item__value{color:var(--jp-light)}
.wpcf7-form input,.wpcf7-form textarea,.jp-form input,.jp-form textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:var(--jp-white);padding:.85rem 1rem;border-radius:var(--jp-radius);font-family:var(--jp-font-body);font-size:.95rem;margin-bottom:1rem;transition:border-color var(--jp-transition),background var(--jp-transition)}
.wpcf7-form input:focus,.wpcf7-form textarea:focus,.jp-form input:focus,.jp-form textarea:focus{outline:none;border-color:var(--jp-orange);background:rgba(232,84,10,.06)}
.wpcf7-form textarea{min-height:140px;resize:vertical}
.wpcf7-submit,.jp-form button[type="submit"]{background:linear-gradient(135deg,var(--jp-orange),var(--jp-amber));color:white;border:none;padding:.85rem 2rem;font-family:var(--jp-font-heading);font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border-radius:var(--jp-radius);transition:all var(--jp-transition)}
.wpcf7-submit:hover,.jp-form button[type="submit"]:hover{background:linear-gradient(135deg,var(--jp-orange-light),var(--jp-orange));transform:translateY(-2px);box-shadow:var(--jp-shadow-orange)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:#030200;border-top:1px solid rgba(232,84,10,.2);position:relative}
.site-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--jp-orange),var(--jp-gold),var(--jp-orange),transparent)}
.footer-top{padding:4rem 0 3rem;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem}
@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.footer-top{grid-template-columns:1fr}}
.footer-brand__logo{font-family:var(--jp-font-heading);font-size:1.5rem;color:var(--jp-white);text-transform:uppercase;margin-bottom:1rem}
.footer-brand__logo span{color:var(--jp-orange)}
.footer-brand__desc{color:var(--jp-gray);font-size:.88rem;line-height:1.7;margin-bottom:1.5rem}
.footer-social{display:flex;gap:.75rem}
.footer-social a{width:40px;height:40px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--jp-gray);transition:all var(--jp-transition)}
.footer-social a:hover{background:var(--jp-orange);color:var(--jp-white);border-color:var(--jp-orange);box-shadow:0 0 15px rgba(232,84,10,.4)}
.footer-col h4{font-size:.75rem;letter-spacing:.25em;color:var(--jp-gold);margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:1px solid rgba(212,160,23,.3);display:inline-block}
.footer-col ul{list-style:none;padding:0}
.footer-col ul li{margin-bottom:.5rem}
.footer-col ul a{color:var(--jp-gray);font-size:.88rem}
.footer-col ul a:hover{color:var(--jp-orange-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.05);padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{color:var(--jp-gray);font-size:.78rem;margin:0}
.footer-bottom a{color:var(--jp-gray)}
.footer-bottom a:hover{color:var(--jp-orange)}

/* ============================================================
   PAGE BANNER
   ============================================================ */
.page-banner{padding:8rem 0 4rem;text-align:center;position:relative;background:linear-gradient(180deg,var(--jp-dark-2) 0%,var(--jp-dark) 100%);overflow:hidden}
.page-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 20% -20%,rgba(232,84,10,.2) 0%,transparent 65%),radial-gradient(ellipse 70% 80% at 80% -20%,rgba(180,60,10,.15) 0%,transparent 65%)}
.page-banner::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:80px;height:2px;background:linear-gradient(90deg,transparent,var(--jp-orange),var(--jp-gold),var(--jp-orange),transparent)}
.page-banner .container{position:relative;z-index:1}
.page-banner__title{margin-bottom:0;text-shadow:0 0 30px rgba(232,84,10,.4)}

/* ============================================================
   SINGLE / ENTRY
   ============================================================ */
.entry-content{max-width:760px;margin:0 auto;padding:4rem 1.5rem}
.entry-content p{color:var(--jp-light);line-height:1.85}
.entry-content h2,.entry-content h3{margin:2rem 0 1rem}
.post-meta{display:flex;gap:1rem;font-size:.82rem;color:var(--jp-gray);margin-bottom:2rem;flex-wrap:wrap}

/* ============================================================
   TERMINE
   ============================================================ */
.termine-grid{display:flex;flex-direction:column;gap:.4rem}
.termin-row{display:grid;grid-template-columns:100px 1fr auto;gap:1.5rem;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,var(--jp-dark-3),var(--jp-dark-4));border-radius:var(--jp-radius);border-left:3px solid transparent;transition:all var(--jp-transition)}
.termin-row:hover{border-left-color:var(--jp-orange);background:linear-gradient(135deg,var(--jp-dark-4),var(--jp-dark-5))}
.termin-date-block{font-family:var(--jp-font-heading);text-align:center}
.termin-date-block .day{font-size:2rem;color:var(--jp-orange-light);line-height:1}
.termin-date-block .month-year{font-size:.65rem;color:var(--jp-gold);letter-spacing:.12em}

/* ============================================================
   MISC
   ============================================================ */
.instruments-list{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}
.instrument-tag{background:rgba(212,160,23,.1);color:var(--jp-gold);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-family:var(--jp-font-heading);letter-spacing:.12em;border:1px solid rgba(212,160,23,.25)}
.scroll-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;background:linear-gradient(135deg,var(--jp-orange),var(--jp-amber));color:white;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all var(--jp-transition);z-index:999;box-shadow:var(--jp-shadow-orange)}
.scroll-top.visible{opacity:1;pointer-events:all}
.scroll-top:hover{transform:translateY(-3px);box-shadow:0 0 50px rgba(232,84,10,.6)}
.pagination{display:flex;justify-content:center;gap:.5rem;padding:3rem 0}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--jp-dark-3);color:var(--jp-light);border-radius:var(--jp-radius);font-family:var(--jp-font-heading);transition:all var(--jp-transition);border:1px solid rgba(255,255,255,.05)}
.pagination .page-numbers.current,.pagination .page-numbers:hover{background:linear-gradient(135deg,var(--jp-orange),var(--jp-amber));color:white;border-color:transparent}
.aligncenter{margin:2rem auto;display:block}
.alignleft{float:left;margin:0 1.5rem 1rem 0}
.alignright{float:right;margin:0 0 1rem 1.5rem}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.skip-link{position:absolute;top:-100px;left:0;background:var(--jp-orange);color:white;padding:.5rem 1rem;z-index:9999}
.skip-link:focus{top:0}
@media(max-width:768px){.section{padding:3rem 0}.event-card{grid-template-columns:70px 1fr}.event-card>.btn{grid-column:1/-1}}

/* ============================================================
   FIX: LOGO GRÖSSE (Desktop kleiner)
   ============================================================ */
.site-logo img {
  height: 55px !important;
  max-height: 55px;
  width: auto;
}

@media (max-width: 768px) {
  .site-logo img { height: 42px !important; }
}

/* ============================================================
   HERO: FOTO-MODUS (wenn kein Text-Overlay)
   ============================================================ */
.hero__bg {
  opacity: 0.55;  /* Foto deutlicher sichtbar */
}

/* Wenn Foto gesetzt: Text kleiner / kompakter */
.hero--has-photo .hero__title {
  font-size: clamp(2.5rem, 6vw, 5rem);
}

/* Foto-Overlay: weniger dunkel damit Foto sichtbar */
.hero--has-photo .hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(8,5,3,0.15)   0%,
    rgba(8,5,3,0.45)  50%,
    rgba(8,5,3,0.95) 100%
  );
}


/* ============================================================
   HERO OVERRIDES v1.6 – SAUBER, KEIN KONFLIKT
   ============================================================ */

/* 1. HERO: Flexbox von unten, alles zentriert */
.hero {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  text-align: center;
}

/* 2. FOTO: kräftig sichtbar */
.hero__bg {
  opacity: 0.80;
}

/* 3. OVERLAY: nur unten abdunkeln, oben transparent */
.hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(8,5,3,0.05)   0%,
    rgba(8,5,3,0.20)  35%,
    rgba(8,5,3,0.72)  65%,
    rgba(8,5,3,0.97) 100%
  );
}

/* 4. BÜHNENLICHT: etwas zurückhalten */
.hero::before { opacity: 0.55; }

/* 5. HERO-CONTENT: am unteren Rand, MITTIG */
.hero__content {
  position: relative;
  z-index: 3;
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;       /* horizontal zentriert */
  text-align: center;
  padding: 0 2rem 11rem;     /* 11rem = Logo weit unten */
  margin: 0;
}

/* 6. LOGO-BILD: groß und mittig */
.hero__logo-img {
  display: block;
  width: min(680px, 88vw);
  max-width: min(680px, 88vw);
  height: auto;
  margin: 0 auto;
  filter:
    drop-shadow(0 0 25px rgba(232,84,10,0.7))
    drop-shadow(0 0 60px rgba(180,60,5,0.35))
    drop-shadow(0 6px 16px rgba(0,0,0,0.95));
  opacity: 0;
  animation: fadeInDown 0.9s 0.4s forwards;
}

/* 7. SUBTITLE */
.hero__subtitle {
  font-family: var(--jp-font-heading);
  font-size: clamp(0.8rem, 2vw, 1rem);
  letter-spacing: 0.35em;
  color: var(--jp-gold);
  text-transform: uppercase;
  margin: 0.75rem 0 0;
  text-shadow: 0 0 20px rgba(212,160,23,0.4);
  opacity: 0;
  animation: fadeInUp 0.8s 0.7s forwards;
}

/* 8. BUTTONS: zentriert */
.hero__cta {
  display: flex;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
  opacity: 0;
  animation: fadeInUp 0.8s 0.9s forwards;
}

/* 9. LOGO IM HEADER */
.site-logo img {
  height: 62px;
  max-height: 62px;
  width: auto;
}

/* 10. SCROLL-PFEIL bleibt absolut positioniert */
.hero__scroll {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
}

/* Mobil */
@media (max-width: 768px) {
  .hero__content { padding: 0 1rem 8rem; }
  .hero__logo-img { width: min(300px, 88vw); max-width: min(300px, 88vw); }
  .site-logo img { height: 44px; max-height: 44px; }
}

/* ============================================================
   FIX v1.7: LOGO HEADER KLEINER
   ============================================================ */
.site-logo img {
  height: 48px !important;
  max-height: 48px !important;
}
.header-inner {
  min-height: 72px !important;
  padding: 0 1.5rem !important;
  align-items: center !important;
}
@media(max-width:768px){
  .site-logo img { height: 36px !important; max-height: 36px !important; }
  .header-inner  { min-height: 58px !important; }
}

/* ============================================================
   FIX v1.9: HERO FOTO HÖHER POSITIONIEREN
   ============================================================ */
.hero__bg {
  background-position: center 15% !important;
}
/* ============================================================
   HERO Z-INDEX FIX – Glow HINTER dem Foto
   ============================================================ */

/* Stacking-Reihenfolge von unten nach oben:
   0 = Glow (Lichteffekt)
   1 = Foto (hero__bg)
   2 = Overlay (Abdunkelung)
   3 = Content (Logo, Text, Buttons)          */

.hero::before    { z-index: 0 !important; }  /* Bühnenstrahler hinter Foto */
.hero__glow      { position: absolute; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.hero__bg        { z-index: 1; }             /* Foto ÜBER dem Glow */
.hero__overlay   { z-index: 2; }
.hero__content   { z-index: 3; }
.hero__scroll    { z-index: 3; }

/* Foto-Opacity: etwas transparenter damit Glow durchkommt */
.hero__bg { opacity: 0.70 !important; }

/* ============================================================
   HERO GLOW EFFEKTE v3.0
   Speziell für hinter dem Foto – intensiv & breitflächig
   Auswahl: Customizer → Startseite → Hero → Lichteffekt
   ============================================================ */

/* ── 1. ATEM – warmes Pulsieren ── */
@keyframes jpfx-atem  { 0%,100%{ opacity:.55 } 50%{ opacity:1 } }
@keyframes jpfx-atem2 { 0%,100%{ opacity:.4  } 50%{ opacity:.85} }
.jp-fx-atem {
  background:
    radial-gradient(ellipse 130% 70% at 20% -10%, rgba(255,130,40,.9)  0%, rgba(220,80,15,.5)  45%, transparent 75%),
    radial-gradient(ellipse 130% 70% at 80% -10%, rgba(240,110,30,.85) 0%, rgba(200,70,10,.45) 45%, transparent 75%),
    radial-gradient(ellipse  90% 55% at 50%  -5%, rgba(255,165,65,.75) 0%, rgba(230,100,25,.4) 40%, transparent 65%),
    radial-gradient(ellipse 150% 50% at 50%  70%, rgba(180,55,10,.4)   0%, transparent 65%);
  animation: jpfx-atem 5s ease-in-out infinite;
}
.jp-fx-atem::after {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 110% 60% at 35% -15%, rgba(255,180,80,.6)  0%, transparent 65%),
    radial-gradient(ellipse 110% 60% at 65% -15%, rgba(245,150,55,.55) 0%, transparent 65%);
  animation: jpfx-atem2 7.5s ease-in-out infinite;
}

/* ── 2. WELLE – breite Farbbewegung ── */
@keyframes jpfx-welle  { 0%,100%{ opacity:.5; transform:scaleY(1)    } 50%{ opacity:1;   transform:scaleY(1.08) } }
@keyframes jpfx-welle2 { 0%,100%{ opacity:.35; transform:translateY(0)  } 50%{ opacity:.8; transform:translateY(15px) } }
.jp-fx-welle {
  background:
    radial-gradient(ellipse 160% 75% at 50% -15%, rgba(255,160,60,.95) 0%, rgba(230,100,25,.5) 45%, transparent 72%),
    radial-gradient(ellipse 160% 45% at 50%  70%, rgba(190,60,10,.45)  0%, transparent 65%);
  animation: jpfx-welle 6s ease-in-out infinite;
}
.jp-fx-welle::after {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 100% 55% at 15% -20%, rgba(255,140,50,.7)  0%, transparent 65%),
    radial-gradient(ellipse 100% 55% at 85% -20%, rgba(240,120,40,.65) 0%, transparent 65%);
  animation: jpfx-welle2 8.5s ease-in-out infinite;
}

/* ── 3. AURORA – zwei Bänder gleiten ── */
@keyframes jpfx-aur1 { 0%,100%{ transform:translateX(0)   scaleX(1);    opacity:.6  } 50%{ transform:translateX(-30px) scaleX(1.12); opacity:1   } }
@keyframes jpfx-aur2 { 0%,100%{ transform:translateX(0)   scaleX(1);    opacity:.45 } 45%{ transform:translateX( 30px) scaleX(.92);  opacity:.9  } }
.jp-fx-aurora {
  background:
    radial-gradient(ellipse 160% 55% at 35% -10%, rgba(255,155,55,.95) 0%, rgba(220,90,20,.45) 50%, transparent 72%),
    radial-gradient(ellipse 150% 40% at 50%  70%, rgba(180,55,10,.38)  0%, transparent 60%);
  animation: jpfx-aur1 7s ease-in-out infinite;
}
.jp-fx-aurora::after {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 160% 55% at 68% -15%, rgba(245,130,45,.88) 0%, rgba(200,70,12,.4) 50%, transparent 72%);
  animation: jpfx-aur2 9s ease-in-out infinite;
}

/* ── 4. GLUT – Feuer von unten & oben ── */
@keyframes jpfx-glut1 { 0%,100%{ opacity:.5; transform:scaleY(1)    } 50%{ opacity:1;   transform:scaleY(1.12) } }
@keyframes jpfx-glut2 { 0%,100%{ opacity:.4; transform:scaleY(1)    } 40%{ opacity:.85; transform:scaleY(1.08) } }
.jp-fx-glut {
  background:
    radial-gradient(ellipse 180% 70% at 50% 120%, rgba(220,65,8,.9)   0%, rgba(245,110,25,.5) 45%, transparent 70%),
    radial-gradient(ellipse 110% 45% at 50%  -5%, rgba(255,145,55,.6) 0%, rgba(230,100,25,.3) 40%, transparent 62%);
  animation: jpfx-glut1 5.5s ease-in-out infinite;
}
.jp-fx-glut::after {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 130% 60% at 25% 115%, rgba(200,55,8,.75)  0%, transparent 62%),
    radial-gradient(ellipse 130% 60% at 75% 115%, rgba(210,65,10,.7)  0%, transparent 62%);
  animation: jpfx-glut2 7s ease-in-out infinite reverse;
}

/* ── 5. MORGENROT – sanfter Himmel-Verlauf ── */
@keyframes jpfx-mr1 { 0%,100%{ opacity:.45 } 50%{ opacity:.92 } }
@keyframes jpfx-mr2 { 0%,100%{ opacity:.3  } 45%{ opacity:.78 } }
.jp-fx-morgenrot {
  background:
    linear-gradient(to bottom, rgba(255,145,65,.72) 0%, rgba(235,105,40,.48) 22%, rgba(200,70,25,.28) 50%, transparent 78%),
    radial-gradient(ellipse 260% 35% at 50% 12%, rgba(255,205,110,.42) 0%, transparent 55%);
  animation: jpfx-mr1 9s ease-in-out infinite;
}
.jp-fx-morgenrot::after {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 180% 30% at 30% 80%, rgba(185,60,12,.32) 0%, transparent 55%),
    radial-gradient(ellipse 180% 30% at 70% 80%, rgba(195,65,12,.28) 0%, transparent 55%);
  animation: jpfx-mr2 12s ease-in-out infinite reverse;
}

/* ── 6. SPOTLIGHT – ein wandernder Kegel ── */
@keyframes jpfx-spot { 0%,100%{ left:10% } 50%{ left:65% } }
@keyframes jpfx-spot2 { 0%,100%{ opacity:.45 } 50%{ opacity:.9 } }
.jp-fx-spotlight::before {
  content:''; position:absolute; top:-40px; width:280px; height:130%;
  background: conic-gradient(from 168deg at 50% 0%, transparent 0deg, rgba(255,165,60,.85) 24deg, transparent 48deg);
  animation: jpfx-spot 11s cubic-bezier(.45,0,.55,1) infinite;
}
.jp-fx-spotlight {
  background: radial-gradient(ellipse 160% 35% at 50% 78%, rgba(185,60,10,.35) 0%, transparent 60%);
  animation: jpfx-spot2 11s cubic-bezier(.45,0,.55,1) infinite;
}

/* ── 7. DREI-STRAHLER – 3 wandernde Kegel ── */
@keyframes jpfx-t1 { 0%,100%{transform-origin:50% 0%;transform:rotate(-30deg);opacity:.5} 50%{transform-origin:50% 0%;transform:rotate(22deg);opacity:1} }
@keyframes jpfx-t2 { 0%,100%{transform-origin:50% 0%;transform:rotate(20deg); opacity:.6} 50%{transform-origin:50% 0%;transform:rotate(-28deg);opacity:.9} }
@keyframes jpfx-t3 { 0%,100%{transform-origin:50% 0%;transform:rotate(-8deg); opacity:.55}50%{transform-origin:50% 0%;transform:rotate(25deg);opacity:.95} }
.jp-beam { position:absolute; top:0; height:220%; }
.jp-fx-drei-strahler .jp-beam:nth-child(1) { left:12%; width:140px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(255,155,55,.9) 18deg,transparent 36deg); animation:jpfx-t1 10s cubic-bezier(.45,0,.55,1) infinite; }
.jp-fx-drei-strahler .jp-beam:nth-child(2) { left:42%; width:150px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(255,180,80,.82) 18deg,transparent 36deg); animation:jpfx-t2 13s cubic-bezier(.45,0,.55,1) infinite 1.5s; }
.jp-fx-drei-strahler .jp-beam:nth-child(3) { left:68%; width:140px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(245,148,58,.88) 18deg,transparent 36deg); animation:jpfx-t3 11s cubic-bezier(.45,0,.55,1) infinite 0.8s; }
.jp-fx-drei-strahler::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 170% 35% at 50% 82%,rgba(185,60,10,.32) 0%,transparent 60%); animation:jpfx-atem 6s ease-in-out infinite; }

/* ── 8. FÜNF-CHAOS – 5 Strahler, langsam ── */
@keyframes jpfx-c1 { 0%{transform-origin:50% 0%;transform:rotate(-35deg);opacity:.42} 42%{transform-origin:50% 0%;transform:rotate(22deg);opacity:.98} 72%{transform-origin:50% 0%;transform:rotate(-8deg);opacity:.58} 100%{transform-origin:50% 0%;transform:rotate(-35deg);opacity:.42} }
@keyframes jpfx-c2 { 0%{transform-origin:50% 0%;transform:rotate(28deg);opacity:.72} 45%{transform-origin:50% 0%;transform:rotate(-26deg);opacity:.35} 75%{transform-origin:50% 0%;transform:rotate(16deg);opacity:.88} 100%{transform-origin:50% 0%;transform:rotate(28deg);opacity:.72} }
@keyframes jpfx-c3 { 0%{transform-origin:50% 0%;transform:rotate(-8deg);opacity:.48} 30%{transform-origin:50% 0%;transform:rotate(30deg);opacity:.9} 62%{transform-origin:50% 0%;transform:rotate(-22deg);opacity:.42} 85%{transform-origin:50% 0%;transform:rotate(12deg);opacity:.82} 100%{transform-origin:50% 0%;transform:rotate(-8deg);opacity:.48} }
@keyframes jpfx-c4 { 0%{transform-origin:50% 0%;transform:rotate(22deg);opacity:.62} 38%{transform-origin:50% 0%;transform:rotate(-32deg);opacity:.36} 68%{transform-origin:50% 0%;transform:rotate(25deg);opacity:.88} 100%{transform-origin:50% 0%;transform:rotate(22deg);opacity:.62} }
@keyframes jpfx-c5 { 0%{transform-origin:50% 0%;transform:rotate(-20deg);opacity:.48} 42%{transform-origin:50% 0%;transform:rotate(33deg);opacity:.94} 74%{transform-origin:50% 0%;transform:rotate(-10deg);opacity:.52} 100%{transform-origin:50% 0%;transform:rotate(-20deg);opacity:.48} }
.jp-fx-chaos-slow .jp-beam:nth-child(1) { left:2%;  width:155px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(255,152,55,.92) 16deg,transparent 32deg); animation:jpfx-c1 11s cubic-bezier(.45,0,.55,1) infinite; }
.jp-fx-chaos-slow .jp-beam:nth-child(2) { left:22%; width:155px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(255,182,82,.82) 14deg,transparent 28deg); animation:jpfx-c2  9s cubic-bezier(.45,0,.55,1) infinite 1.2s; }
.jp-fx-chaos-slow .jp-beam:nth-child(3) { left:42%; width:155px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(252,165,68,.88) 16deg,transparent 32deg); animation:jpfx-c3 13s cubic-bezier(.45,0,.55,1) infinite 2.4s; }
.jp-fx-chaos-slow .jp-beam:nth-child(4) { left:60%; width:155px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(242,145,52,.92) 14deg,transparent 28deg); animation:jpfx-c4 10s cubic-bezier(.45,0,.55,1) infinite 0.6s; }
.jp-fx-chaos-slow .jp-beam:nth-child(5) { left:78%; width:155px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(255,170,72,.86) 16deg,transparent 32deg); animation:jpfx-c5 12s cubic-bezier(.45,0,.55,1) infinite 3.1s; }
.jp-fx-chaos-slow::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 175% 32% at 50% 83%,rgba(190,62,10,.35) 0%,transparent 62%); animation:jpfx-atem 7s ease-in-out infinite; }

/* ── 9. FÜNF-PARALLEL – synchron ── */
@keyframes jpfx-par { 0%,100%{ transform:translateX(-55px) } 50%{ transform:translateX(55px) } }
@keyframes jpfx-par-f { 0%,100%{ opacity:.48 } 50%{ opacity:.95 } }
.jp-fx-parallel { animation:jpfx-par 10s cubic-bezier(.45,0,.55,1) infinite; }
.jp-fx-parallel .jp-beam:nth-child(1) { left:2%;  width:140px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(255,155,58,.9) 14deg,transparent 28deg); animation:jpfx-par-f 10s cubic-bezier(.45,0,.55,1) infinite; }
.jp-fx-parallel .jp-beam:nth-child(2) { left:22%; width:140px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(255,182,82,.82) 14deg,transparent 28deg); animation:jpfx-par-f 10s cubic-bezier(.45,0,.55,1) infinite .25s; }
.jp-fx-parallel .jp-beam:nth-child(3) { left:42%; width:140px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(252,167,70,.86) 14deg,transparent 28deg); animation:jpfx-par-f 10s cubic-bezier(.45,0,.55,1) infinite .5s; }
.jp-fx-parallel .jp-beam:nth-child(4) { left:62%; width:140px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(242,148,56,.9) 14deg,transparent 28deg); animation:jpfx-par-f 10s cubic-bezier(.45,0,.55,1) infinite .75s; }
.jp-fx-parallel .jp-beam:nth-child(5) { left:80%; width:140px; background:conic-gradient(from 168deg at 50% 0%,transparent 0deg,rgba(255,172,75,.84) 14deg,transparent 28deg); animation:jpfx-par-f 10s cubic-bezier(.45,0,.55,1) infinite 1s; }
.jp-fx-parallel::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 170% 30% at 50% 82%,rgba(185,60,10,.32) 0%,transparent 58%); animation:jpfx-atem 5s ease-in-out infinite; }

/* ── 10. KERZE – unregelmäßig ── */
@keyframes jpfx-flick1 { 0%{opacity:.52} 12%{opacity:.88} 28%{opacity:.62} 45%{opacity:1} 68%{opacity:.68} 84%{opacity:.92} 100%{opacity:.52} }
@keyframes jpfx-flick2 { 0%{opacity:.38} 18%{opacity:.82} 38%{opacity:.48} 58%{opacity:.88} 78%{opacity:.55} 100%{opacity:.38} }
.jp-fx-kerze {
  background:
    radial-gradient(ellipse 120% 70% at 50% -8%, rgba(255,165,58,.92) 0%, rgba(235,100,28,.48) 48%, transparent 72%),
    radial-gradient(ellipse 145% 42% at 50% 68%, rgba(195,65,14,.42) 0%, transparent 62%);
  animation: jpfx-flick1 3.8s ease-in-out infinite;
}
.jp-fx-kerze::after {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 90% 52% at 25% -12%, rgba(255,148,52,.62) 0%, transparent 62%),
    radial-gradient(ellipse 90% 52% at 75% -12%, rgba(245,132,48,.58) 0%, transparent 62%);
  animation: jpfx-flick2 2.9s ease-in-out infinite;
}

/* Kein Effekt */
.jp-fx-keiner { display: none; }

/* ============================================================
   VIDEO SEKTION
   ============================================================ */
.jp-video-section {
  background: linear-gradient(180deg, var(--jp-dark) 0%, var(--jp-dark-2) 50%, var(--jp-dark) 100%);
}

.jp-video-wrap {
  position: relative;
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,0.7), 0 0 0 1px rgba(232,84,10,0.2);
}

.jp-video-wrap iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* ============================================================
   FACEBOOK FEED SEKTION
   ============================================================ */
.jp-fb-section {
  background: linear-gradient(180deg, var(--jp-dark-2) 0%, var(--jp-dark) 100%);
}

.jp-fb-wrap {
  max-width: 1100px;
  margin: 0 auto;
}

/* Smash Balloon Overrides – ans Dark-Theme anpassen */
.jp-fb-wrap .cff-wrapper,
.jp-fb-wrap #cff {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

/* Post-Karten */
.jp-fb-wrap .cff-item {
  background: linear-gradient(135deg, var(--jp-dark-3), var(--jp-dark-4)) !important;
  border: 1px solid rgba(255,255,255,.05) !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  transition: transform .25s ease, box-shadow .25s ease !important;
}

.jp-fb-wrap .cff-item:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 30px rgba(0,0,0,.6), 0 0 20px rgba(232,84,10,.1) !important;
}

/* Text-Farben */
.jp-fb-wrap .cff-post-text,
.jp-fb-wrap .cff-text,
.jp-fb-wrap p {
  color: var(--jp-light) !important;
}

.jp-fb-wrap .cff-date,
.jp-fb-wrap .cff-meta {
  color: var(--jp-gray) !important;
  font-size: .8rem !important;
}

.jp-fb-wrap a {
  color: var(--jp-orange-light) !important;
}

.jp-fb-wrap a:hover {
  color: var(--jp-gold) !important;
}

/* Like/Kommentar-Buttons */
.jp-fb-wrap .cff-action-links a {
  color: var(--jp-gray) !important;
  font-size: .8rem !important;
}

.jp-fb-wrap .cff-action-links a:hover {
  color: var(--jp-orange) !important;
}

/* "Mehr laden" Button */
.jp-fb-wrap .cff-load-btn,
.jp-fb-wrap #cff-load-btn {
  background: linear-gradient(135deg, var(--jp-orange), var(--jp-amber)) !important;
  color: white !important;
  border: none !important;
  padding: .75rem 2rem !important;
  border-radius: 4px !important;
  font-family: var(--jp-font-heading) !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: all .25s !important;
  margin-top: 1.5rem !important;
}

.jp-fb-wrap .cff-load-btn:hover {
  background: linear-gradient(135deg, var(--jp-orange-light), var(--jp-orange)) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 0 25px rgba(232,84,10,.4) !important;
}

/* ============================================================
   FACEBOOK SEKTION – gleicher Glow-Effekt wie Hero
   ============================================================ */
.jp-fb-section {
  position: relative;
  overflow: hidden;
}

/* Bühnenlicht-Glow oben (gleiche Farben wie Hero) */
.jp-fb-section::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 130% 60% at 20% -10%, rgba(255,130,40,.55)  0%, rgba(220,80,15,.25)  50%, transparent 75%),
    radial-gradient(ellipse 130% 60% at 80% -10%, rgba(240,110,30,.50)  0%, rgba(200,70,10,.22)  50%, transparent 75%),
    radial-gradient(ellipse  90% 45% at 50%  -5%, rgba(255,165,65,.45)  0%, rgba(230,100,25,.2)  40%, transparent 65%),
    radial-gradient(ellipse 150% 40% at 50%  90%, rgba(180,55,10,.30)   0%, transparent 60%);
  animation: jpfx-atem 6s ease-in-out infinite;
}

/* Zweite Schicht versetzt */
.jp-fb-section::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 110% 50% at 35% -15%, rgba(255,180,80,.35)  0%, transparent 62%),
    radial-gradient(ellipse 110% 50% at 65% -15%, rgba(245,150,55,.32)  0%, transparent 62%);
  animation: jpfx-atem2 8s ease-in-out infinite;
}

/* Content über dem Glow */
.jp-fb-section .container {
  position: relative;
  z-index: 1;
}

/* ============================================================
   CTA-STRIP – gleicher animierter Glow wie Hero
   ============================================================ */
.cta-strip {
  position: relative;
  overflow: hidden;
}

/* Glow Schicht 1 – Bühnenstrahler von oben */
.cta-strip::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 140% 70% at 20% -20%, rgba(255,130,40,.65)  0%, rgba(220,80,15,.30)  50%, transparent 75%),
    radial-gradient(ellipse 140% 70% at 80% -20%, rgba(240,110,30,.60)  0%, rgba(200,70,10,.28)  50%, transparent 75%),
    radial-gradient(ellipse  90% 55% at 50%  -5%, rgba(255,165,65,.52)  0%, rgba(230,100,25,.25) 40%, transparent 65%),
    radial-gradient(ellipse 150% 45% at 50%  95%, rgba(180,55,10,.38)   0%, transparent 65%);
  animation: jpfx-atem 5.5s ease-in-out infinite;
}

/* Glow Schicht 2 – versetzt */
.cta-strip::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 120% 55% at 35% -20%, rgba(255,180,80,.42)  0%, transparent 65%),
    radial-gradient(ellipse 120% 55% at 65% -20%, rgba(245,150,55,.38)  0%, transparent 65%);
  animation: jpfx-atem2 7.5s ease-in-out infinite;
}

/* Content über dem Glow */
.cta-strip .container {
  position: relative;
  z-index: 1;
}

/* Hintergrundfarbe anpassen – dunkler damit Glow besser wirkt */
.cta-strip {
  background: linear-gradient(135deg, #0F0805, #1A0C05, #0F0805) !important;
}

/* ============================================================
   FIX: HERO HINTERGRUNDBILD MOBIL (Hochformat)
   ============================================================ */
@media (max-width: 768px) {
  .hero__bg {
    background-position: center 10% !important;
    background-attachment: scroll !important; /* kein Parallax auf Mobil */
  }

  /* Hero höher damit mehr Bild sichtbar */
  .hero {
    min-height: 100svh; /* safe viewport height auf iOS */
  }

  /* Content weiter oben auf Mobil */
  .hero__content {
    padding: 0 1rem 7rem !important;
  }

  /* Logo kleiner auf Mobil */
  .hero__logo-img {
    width: min(260px, 82vw) !important;
    max-width: min(260px, 82vw) !important;
  }
}

/* Sehr schmale Hochformat-Geräte */
@media (max-width: 480px) {
  .hero__bg {
    background-position: 40% 10% !important;
  }
  .hero__content {
    padding: 0 1rem 6rem !important;
  }
}

/* ============================================================
   FIX: HERO FOTO VOLLBREITE AUF ALLEN GERÄTEN
   ============================================================ */
.hero__bg {
  background-size: contain !important;    /* ganzes Foto sichtbar */
  background-repeat: no-repeat !important;
  background-position: center 15% !important;
  background-color: var(--jp-dark) !important;
}

@media (max-width: 768px) {
  .hero__bg {
    background-size: contain !important;
    background-position: center top !important;
    background-attachment: scroll !important;
    opacity: 0.85 !important;
  }
}

/* ============================================================
   FIX: HERO MOBIL – Foto oben, Logo über den Beinen
   ============================================================ */

/* DESKTOP bleibt: contain, Foto + Logo überlagert */

@media (max-width: 768px) {
  /* Hero als Column: Foto oben, Content unten überlappend */
  .hero {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: center !important;
    min-height: 100svh !important;
    position: relative !important;
  }

  /* Foto: oben, volle Breite, kein Zuschneiden */
  .hero__bg {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 70% !important;           /* Foto nimmt obere 70% ein */
    width: 100% !important;
    background-size: contain !important;
    background-position: center top !important;
    background-repeat: no-repeat !important;
    background-attachment: scroll !important;
    background-color: transparent !important;
    opacity: 0.90 !important;
  }

  /* Overlay: nur unten abdunkeln für Logo-Lesbarkeit */
  .hero__overlay {
    background: linear-gradient(
      to bottom,
      rgba(8,5,3,0)    0%,
      rgba(8,5,3,0)   45%,
      rgba(8,5,3,0.5) 60%,
      rgba(8,5,3,0.95) 75%,
      rgba(8,5,3,1)   100%
    ) !important;
  }

  /* Content: Logo liegt im unteren Drittel, über den Beinen */
  .hero__content {
    position: relative !important;
    z-index: 3 !important;
    margin-top: 48% !important;       /* schiebt Content unter das Foto */
    padding: 0 1rem 5rem !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
  }

  /* Logo kleiner auf Mobil */
  .hero__logo-img {
    width: min(280px, 85vw) !important;
    max-width: min(280px, 85vw) !important;
    filter:
      drop-shadow(0 0 20px rgba(232,84,10,0.8))
      drop-shadow(0 0 50px rgba(232,84,10,0.4))
      drop-shadow(0 4px 12px rgba(0,0,0,1)) !important;
  }

  /* Buttons nebeneinander */
  .hero__cta {
    flex-direction: row !important;
    gap: .6rem !important;
  }
  .hero__cta .btn {
    font-size: .75rem !important;
    padding: .7rem 1rem !important;
  }
}

/* Sehr schmale Geräte */
@media (max-width: 400px) {
  .hero__bg {
    height: 65% !important;
  }
  .hero__content {
    margin-top: 42% !important;
  }
  .hero__cta {
    flex-direction: column !important;
    width: 100% !important;
  }
  .hero__cta .btn {
    width: 100% !important;
    text-align: center !important;
  }
}

/* ── Vergangene Termine – kleiner ── */
.jp-vergangen-liste .event-card {
    padding: .65rem 1rem;
    font-size: .88em;
}
.jp-vergangen-liste .event-card__day  { font-size: 1.4rem; }
.jp-vergangen-liste .event-card__month{ font-size: .6rem; }
.jp-vergangen-liste .event-card h3    { font-size: .82rem; }
.jp-vergangen-liste .event-card__location { font-size: .72rem; }
.jp-vergangen-liste .btn              { font-size: .72rem; padding: .35rem .8rem; }

/* ============================================================
   NEWS
   ============================================================ */
.jp-news-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
}

.jp-news-card {
  background: var(--jp-dark-2);
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.05);
  transition: transform .3s, box-shadow .3s;
  display: flex;
  flex-direction: column;
}
.jp-news-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 36px rgba(0,0,0,.6), 0 0 24px rgba(232,84,10,.12);
}

.jp-news-card__img {
  display: block;
  aspect-ratio: 3/2;
  overflow: hidden;
}
.jp-news-card__img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .5s;
}
.jp-news-card:hover .jp-news-card__img img { transform: scale(1.06); }

.jp-news-card__body {
  padding: 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.jp-news-card__date {
  font-size: .72rem;
  color: var(--jp-gold);
  font-family: var(--jp-font-heading);
  letter-spacing: .15em;
  text-transform: uppercase;
  margin-bottom: .4rem;
}
.jp-news-card__title {
  font-size: 1rem;
  margin: 0 0 .6rem;
  line-height: 1.4;
}
.jp-news-card__title a {
  color: var(--jp-white);
  text-decoration: none;
  transition: color .2s;
}
.jp-news-card__title a:hover { color: var(--jp-orange); }

.jp-news-card__excerpt {
  font-size: .85rem;
  color: var(--jp-gray);
  line-height: 1.65;
  margin: 0 0 1rem;
  flex: 1;
}
.jp-news-card__link {
  color: var(--jp-orange);
  font-size: .8rem;
  font-family: var(--jp-font-heading);
  letter-spacing: .1em;
  text-transform: uppercase;
  text-decoration: none;
  transition: color .2s;
}
.jp-news-card__link:hover { color: var(--jp-gold); }

/* News Content */
.jp-news-content p  { margin-bottom: 1rem; }
.jp-news-content h2 { font-size: 1.3rem; margin: 1.5rem 0 .75rem; color: var(--jp-white); }
.jp-news-content h3 { font-size: 1.1rem; margin: 1.25rem 0 .6rem; color: var(--jp-light); }
.jp-news-content img { max-width: 100%; border-radius: 6px; margin: .5rem 0; }
.jp-news-content a  { color: var(--jp-orange); }
