:root{--bg:#f7f0c9;--bg-dark:#f0e6b5;--primary:#8c001a;--primary-dark:#5a0011;--accent:#f7b731;--text:#3b2620;--card-bg:#fff7df;--shadow:0 18px 35px rgba(0,0,0,.13);--r-xl:26px}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:radial-gradient(circle at top,#fdf6d4 0,var(--bg) 45%,#f5e6b0 100%);color:var(--text);line-height:1.6;overflow-x:hidden;position:relative}
body::before{content:"";position:fixed;left:50%;top:50%;width:140vmax;height:140vmax;transform:translate(-50%,-50%) rotate(-10deg);border-radius:50%;background:repeating-conic-gradient(from -10deg,#f7f0c9 0 15deg,#b7001f 15deg 30deg);opacity:.14;pointer-events:none;z-index:-1}
a{color:inherit}a:hover{text-decoration:underline}
.skip-link{position:absolute;left:-999px;top:0;background:#fff;color:#000;padding:.5rem .75rem;z-index:1000;border-radius:0 0 10px 0;box-shadow:0 8px 18px rgba(0,0,0,.15)}
.skip-link:focus{left:.75rem;top:.75rem}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
header{position:sticky;top:0;z-index:50;background:linear-gradient(90deg,var(--primary-dark),var(--primary));color:#fff;box-shadow:0 8px 16px rgba(0,0,0,.35)}
.nav{max-width:1200px;margin:0 auto;padding:.75rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.nav-left{display:flex;align-items:center;gap:.75rem}
.nav-logo{width:46px;height:46px;border-radius:999px;background:radial-gradient(circle at 30% 30%,#fff 0,#fbd7b9 45%,#8c001a 100%);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 0 0 3px #fff3,0 0 0 5px #0002}
.nav-logo img{width:120%;height:auto;object-fit:cover}
.nav-title{display:flex;flex-direction:column;line-height:1.1}
.nav-title span:first-child{font-weight:800;letter-spacing:.03em;font-size:1.1rem}
.nav-title span:last-child{font-size:.8rem;opacity:.92}
.nav-links{display:flex;gap:1.2rem;align-items:center}
.nav-links a{position:relative;text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:.8rem;opacity:.92;padding:.25rem 0;white-space:nowrap}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-.25rem;height:2px;border-radius:999px;background:linear-gradient(90deg,#fff,var(--accent));transform:scaleX(0);transform-origin:center;transition:transform .2s ease-out}
.nav-links a:hover::after,.nav-links a:focus-visible::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:.5rem}
.cart-icon-btn{position:relative;background:transparent;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:8px;transition:background .2s;display:flex;align-items:center;justify-content:center}
.cart-icon-btn:hover{background:rgba(255,255,255,.15)}
.cart-badge{position:absolute;top:0;right:0;background:var(--accent);color:var(--primary-dark);font-size:.7rem;font-weight:900;padding:.15rem .4rem;border-radius:999px;min-width:18px;text-align:center;line-height:1.2;box-shadow:0 2px 4px rgba(0,0,0,.2)}
.ticket-pill{background:#fff;color:var(--primary-dark);padding:.4rem .9rem;border-radius:999px;font-weight:800;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;box-shadow:0 0 0 2px #ffffff55}
.ticket-pill small{display:block;font-weight:600;font-size:.65rem;opacity:.85}
.menu-toggle{display:none;border:0;background:transparent;color:#fff;font-size:1.25rem;cursor:pointer}
main{max-width:1200px;margin:1.5rem auto 3rem;padding:0 1.25rem}
.grid-2{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);gap:1.5rem;align-items:start}
.card{background:rgba(255,255,255,.92);border-radius:18px;padding:1.1rem 1.2rem;box-shadow:0 12px 24px rgba(0,0,0,.12)}
.hero{background:radial-gradient(circle at 50% 50%,#ffe9c8 0,var(--bg-dark) 60%,rgba(0,0,0,.03) 100%);border-radius:var(--r-xl);box-shadow:var(--shadow);padding:1.5rem}
.hero .topline{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;color:var(--primary-dark);font-weight:900}
.hero h1{margin:.35rem 0 0;font-size:clamp(2.1rem,3vw,2.6rem);color:var(--primary-dark);letter-spacing:.04em;text-shadow:0 2px 0 #f7f0c9,0 4px 8px rgba(0,0,0,.25)}
.badge{display:inline-block;padding:.1rem .55rem;border-radius:999px;font-size:.75rem;background:#f1e6c3}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:.55rem;border-bottom:1px dashed rgba(0,0,0,.2);vertical-align:top;text-align:left;word-break:break-word}
.table th{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}
.table-wrap{overflow-x:auto}
.help{font-size:.85rem;opacity:.85;margin-top:.25rem}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border:0;border-radius:999px;padding:.45rem 1rem;font-size:.85rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;text-decoration:none}
.btn-small{padding:.35rem .8rem;font-size:.75rem}
.btn-primary{background:linear-gradient(135deg,var(--primary),#e12848);color:#fff}
.btn-secondary{background:#fff;color:var(--primary-dark);border:1px solid rgba(0,0,0,.12)}
.btn-danger{background:#fff;color:#6b0014;border:1px solid rgba(107,0,20,.25)}
label{display:block;font-weight:800;font-size:.85rem;margin-bottom:.25rem}
input,textarea,select{width:100%;padding:.55rem .65rem;border-radius:10px;border:1px solid #c9bfa1;background:#fff;font-size:1rem}
textarea{min-height:110px;resize:vertical}
.flash{border-radius:12px;padding:.8rem .9rem;margin-bottom:.8rem;background:rgba(255,255,255,.92);box-shadow:0 10px 22px rgba(0,0,0,.1)}
.flash.error{border-left:6px solid #c1002f}.flash.success{border-left:6px solid #2f8c00}.flash.info{border-left:6px solid #005a8c}
footer{max-width:1200px;margin:0 auto 3rem;padding:0 1.25rem;opacity:.95}
.footer-links{display:flex;flex-wrap:wrap;gap:.75rem 1.2rem;font-size:.9rem}
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:999;max-width:1200px;margin:0 auto;background:rgba(255,255,255,.98);border-radius:18px;box-shadow:0 18px 35px rgba(0,0,0,.18);padding:1rem}
.cookie-banner .actions{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.6rem}

/* Sponsors marquee */
.sponsors-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}
.marquee{margin-top:.85rem;background:rgba(0,0,0,.04);border-radius:14px;overflow:hidden;position:relative;padding:.55rem 0}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:3.25rem;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,rgba(255,255,255,.95),rgba(255,255,255,0))}
.marquee::after{right:0;background:linear-gradient(270deg,rgba(255,255,255,.95),rgba(255,255,255,0))}
.marquee-track{display:flex;align-items:center;gap:1.5rem;width:max-content;will-change:transform;animation:marquee 26s linear infinite}
.marquee-dup{display:flex;align-items:center;gap:1.5rem}
.marquee.is-paused .marquee-track{animation-play-state:paused}
.sponsor-item{display:flex;align-items:center;justify-content:center;min-width:170px;padding:.2rem .75rem}
.sponsor-item a{display:flex;align-items:center;justify-content:center}
.sponsor-item img{max-height:46px;max-width:170px;object-fit:contain;filter:drop-shadow(0 6px 12px rgba(0,0,0,.12))}
.sponsor-text{font-weight:900;letter-spacing:.06em;text-transform:uppercase;font-size:.85rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){
  .marquee-track{animation:none;transform:none;flex-wrap:wrap;width:100%;justify-content:flex-start}
  .marquee::before,.marquee::after{display:none}
}

/* Screen-reader only */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media (max-width:860px){.grid-2{grid-template-columns:1fr}}
@media (max-width:720px){
  .nav-links,
  .nav-cta {
    display: none !important;
  }
  .menu-toggle {
    display: block !important;
  }
  .nav-links.mobile-open,
  .nav-cta.mobile-open {
    display: flex !important;
    flex-direction: column;
  }
  .nav-links {
    width: 100%;
    justify-content: center;
    padding: .5rem 0 .35rem;
    order: 3;
  }
  .nav-cta {
    width: 100%;
    justify-content: center;
    padding-bottom: .4rem;
    order: 2;
  }
  .nav {
    flex-wrap: wrap;
  }
  .nav-left {
    flex: 1;
    min-width: 0;
  }
}

/* ===== Design parity with original static pages ===== */

@font-face {
  font-family: "Racone";
  src: url("fonts/Racone-Italic.woff2") format("woff2"),
       url("fonts/Racone-Italic.woff") format("woff");
  font-style: italic;
  font-weight: 400;
  font-display: swap;
}

/* Use Racone where the static design expects it */
.nav-title span:first-child{font-family:"Racone",system-ui;font-size:1.25rem;letter-spacing:.04em;font-weight:400}
.hero h1,.hero-lineup h2,.day-title,.card h2,.card h1,h1,h2{font-family:"Racone",system-ui;font-style:italic}

/* HOME layout (index look) */
.main-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:1.5rem;align-items:start}
.hero{background:linear-gradient(160deg,rgba(255,247,223,.96),rgba(255,240,210,.94));border-radius:var(--r-xl);box-shadow:var(--shadow);padding:1.35rem 1.35rem 1.2rem;position:relative;overflow:hidden}
.hero-inner{display:flex;flex-direction:column;gap:1rem;align-items:center;text-align:center}
.hero-topline{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;color:var(--primary-dark);font-weight:700;opacity:.92}
.hero-logo-main{width:min(360px,70%);margin:.15rem auto 0}
.hero-logo-main img{width:100%;height:auto;display:block;filter:drop-shadow(0 12px 25px rgba(0,0,0,.18))}
.hero-layout{width:100%;display:flex;justify-content:center}
.hero-info{max-width:42rem}
.hero-info h1{margin:0;color:var(--primary-dark);letter-spacing:.05em;line-height:1.05;font-size:clamp(2.05rem,3vw,2.65rem)}
.hero-info h1 span{display:block;font-size:.62em;letter-spacing:.22em;text-transform:uppercase;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-style:normal;font-weight:800;color:#4c161a}
.hero-date{margin:.8rem 0 0 0;font-weight:700;color:var(--primary-dark)}
.hero-details{margin:.75rem auto 0;max-width:44rem;opacity:.92}

.countdown{width:100%;max-width:520px;background:rgba(255,255,255,.75);border-radius:22px;padding:.85rem .9rem;box-shadow:0 12px 24px rgba(0,0,0,.12)}
.countdown-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;font-weight:800;color:var(--primary-dark);margin-bottom:.55rem}
.countdown-units{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}
.countdown-unit{min-width:64px;text-align:center;padding:.35rem .6rem;border-radius:999px;background:var(--bg-dark);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;box-shadow:0 8px 18px rgba(0,0,0,.15)}
.countdown-unit span{display:block;font-size:1rem;font-weight:800;letter-spacing:0}

.sidebar{display:flex;flex-direction:column;gap:1.1rem}
.hero-lineup{background:rgba(255,247,223,.96);border-radius:var(--r-xl);box-shadow:var(--shadow);padding:1.2rem 1.2rem 1.05rem}
.hero-lineup h2{margin:0 0 .6rem 0;color:var(--primary-dark);font-size:1.35rem}
.lineup-day-hero{margin:.7rem 0 .35rem 0;font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:.75rem;color:var(--primary-dark);opacity:.92}
.hero-lineup ul{margin:.1rem 0 0 1.05rem;padding:0;font-size:.92rem;text-align:left}
.hero-lineup li{margin:.25rem 0}
.hero-lineup small{opacity:.85}

.ticket-card{background:rgba(255,247,223,.96);border-radius:var(--r-xl);box-shadow:var(--shadow);padding:1.2rem 1.15rem}
.ticket-card h2{margin:0;color:var(--primary-dark);font-size:1.35rem}
.ticket-price{margin:.65rem 0 0 0;font-weight:700}
.ticket-hint{margin:.55rem 0 0 0;font-size:.9rem;opacity:.9}
.ticket-buttons{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:.8rem;justify-content:flex-start}
.btn-logo{height:22px;width:auto;display:block}

/* Sponsors marquee (durchlaufend) */
.sponsor-marquee-section{margin-top:1.4rem;background:rgba(255,247,223,.75);border-radius:var(--r-xl);padding:1.5rem 1.2rem;box-shadow:var(--shadow);overflow:hidden}
.sponsor-marquee-wrapper{overflow:hidden;position:relative;width:100%}
.sponsor-marquee{display:flex;gap:2rem;animation:sponsor-marquee 30s linear infinite;will-change:transform}
.sponsor-marquee:hover{animation-play-state:paused}
.sponsor-marquee-item{flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:1rem 1.5rem;background:rgba(255,255,255,.9);border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.1);text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s;min-width:180px}
.sponsor-marquee-item:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.15)}
.sponsor-marquee-logo{max-width:140px;max-height:60px;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}
.sponsor-marquee-name{font-weight:700;color:var(--primary-dark);font-size:0.95rem}
.sponsor-marquee-link{text-align:center;margin-top:1rem}
@keyframes sponsor-marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@media (max-width:720px){
  .sponsor-marquee-item{min-width:150px;padding:0.75rem 1rem}
  .sponsor-marquee-logo{max-width:100px;max-height:50px}
}

/* LINEUP / PROGRAM layout (lineup.html look) */
.hero-lineup-topline{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;color:var(--primary-dark);font-weight:700;opacity:.9;margin-bottom:.4rem}
.hero-lineup-title{font-family:"Racone",system-ui;font-style:italic;font-size:clamp(2.1rem,3.2vw,2.7rem);letter-spacing:.05em;color:var(--primary-dark);display:inline-block;padding:.35rem 1.4rem;border-radius:999px;background:rgba(247,240,201,.94);box-shadow:0 10px 22px rgba(0,0,0,.18);text-shadow:0 2px 0 #fdf3c8}
.hero-lineup-sub{font-size:.92rem;margin-top:.6rem;max-width:620px}

/* Tickets Hero Highlight Box */
.hero-tickets-highlight{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:rgba(247,240,201,.94);border-radius:999px;box-shadow:0 10px 22px rgba(0,0,0,.18);width:fit-content}
.hero-tickets-logo{width:60px;height:auto;flex:0 0 auto;object-fit:contain}
.hero-tickets-title{font-family:"Racone",system-ui;font-style:italic;font-size:clamp(2.1rem,3.2vw,2.7rem);letter-spacing:.05em;color:var(--primary-dark);margin:0;text-shadow:0 2px 0 #fdf3c8}
.lineup-grid{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(0,1.1fr);gap:1.5rem;align-items:start;margin-top:1.25rem;max-width:1200px;margin-left:auto;margin-right:auto;padding:0 1.25rem}
.day-card{background:rgba(255,247,223,.96);border-radius:var(--r-xl);padding:1.3rem 1.3rem 1.1rem;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);margin-bottom:1rem}
.day-title{font-family:"Racone",system-ui;font-style:italic;font-size:1.3rem;color:var(--primary-dark);margin:0 0 .4rem 0;text-shadow:0 1px 0 #fdf3c8}
.day-subtitle{font-size:.85rem;opacity:.85;margin-bottom:.75rem}

/* Programm accordion toggle (Samstag/Sonntag) */
.day-toggle{background:transparent;border:0;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer !important;display:inline-flex;align-items:baseline;gap:.55rem;line-height:1.1;text-align:left;width:100%;position:relative;z-index:1}
.day-toggle{border-bottom:1px dashed rgba(139,0,26,.45);padding-bottom:2px}
.day-toggle:hover{border-bottom-style:solid;color:var(--primary)}
.day-toggle:active{opacity:.8}
.day-toggle::after{content:"▾";font-family:system-ui;font-style:normal;opacity:.75;transform:translateY(-1px) rotate(0deg);transition:transform .15s ease-out}
.day-toggle[aria-expanded="true"]::after{transform:translateY(-1px) rotate(180deg)}
.day-toggle:focus-visible{outline:3px solid var(--accent);outline-offset:4px;border-bottom-color:transparent}
.day-accordion > summary.day-toggle{list-style:none}
.day-accordion > summary.day-toggle::-webkit-details-marker{display:none}
.day-accordion > summary.day-toggle::marker{content:""}
.day-accordion[open] > .day-toggle::after{transform:translateY(-1px) rotate(180deg)}
.day-accordion:not([open]) > .day-toggle::after{transform:translateY(-1px) rotate(0deg)}
.day-panel{margin-top:.25rem}
.day-panel[hidden]{display:none}
.slot-list{list-style:none;display:grid;gap:.4rem;font-size:.9rem;padding:0;margin:0}
.slot{display:grid;grid-template-columns:70px minmax(0,1fr);gap:.6rem;align-items:baseline;padding:.35rem .55rem;border-radius:16px;transition:background .15s ease-out,transform .08s ease-out}
.slot:hover{background:rgba(255,255,255,.9);transform:translateY(-1px)}
.slot-time{font-weight:800;font-size:.86rem;color:var(--primary-dark);white-space:nowrap}
.slot-main{display:flex;flex-direction:column;min-width:0}
.slot-artist{font-weight:600;min-width:0}
.slot-artist a{font-weight:700;text-decoration:none;border-bottom:1px dashed rgba(139,0,26,.5);padding-bottom:1px}
.slot-artist a:hover{border-bottom-style:solid}
.slot-stage{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;opacity:.8}
.slot-note{font-size:.78rem;opacity:.85;margin-top:.1rem}
.info-column{display:flex;flex-direction:column;gap:1rem}
.countdown-card{background:rgba(255,247,223,.96);border-radius:var(--r-xl);padding:1.2rem 1.15rem;box-shadow:var(--shadow)}
.countdown-card h2{margin:0;color:var(--primary-dark);font-size:1.3rem}
.card-sub{font-size:.85rem;opacity:.85;margin:.5rem 0 .8rem 0}
.ticket-box{background:rgba(255,247,223,.96);border-radius:var(--r-xl);padding:1.2rem 1.15rem;box-shadow:var(--shadow)}
.ticket-box h2{margin:0;color:var(--primary-dark);font-size:1.3rem}
.ticket-legal{font-size:.72rem;opacity:.8}

/* Ticket page */
.ticket-form{margin-top:.9rem}
.ticket-fieldset{border:0;padding:0;margin:0;display:grid;gap:.6rem}
.ticket-fieldset legend{font-weight:800;color:var(--primary-dark);margin-bottom:.25rem}
.ticket-choice{display:flex;gap:.75rem;align-items:flex-start;background:rgba(255,255,255,.85);border-radius:16px;padding:.75rem .85rem;box-shadow:0 8px 18px rgba(0,0,0,.08);cursor:pointer}
.ticket-choice input{margin-top:.25rem;transform:scale(1.15)}
.ticket-choice strong{display:block;color:var(--primary-dark)}
.ticket-choice small{display:block;opacity:.86;margin-top:.15rem}
.ticket-row{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-top:.9rem}
.ticket-label{font-weight:800;color:var(--primary-dark)}
.ticket-select{padding:.55rem .7rem;border-radius:12px;border:1px solid rgba(0,0,0,.18);background:rgba(255,255,255,.9)}
.ticket-actions{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1rem;align-items:center}
.ticket-actions button{display:inline-flex;align-items:center;justify-content:center}

/* Band tiles (Line-Up) */
.band-grid{display:grid;grid-template-columns:1fr;gap:.85rem;margin-top:.85rem;align-items:stretch}
.band-card{display:flex;gap:.85rem;align-items:flex-start;background:rgba(255,255,255,.85);border-radius:18px;padding:.85rem .9rem;box-shadow:0 10px 20px rgba(0,0,0,.1);height:100%;min-width:0}
.band-card-expandable{cursor:pointer;transition:transform .15s ease-out,box-shadow .15s ease-out}
.band-card-expandable:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(0,0,0,.15)}
.band-card-expandable:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
.band-logo{width:70px;height:70px;border-radius:16px;object-fit:cover;background:#fff;flex:0 0 70px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06);pointer-events:none}
.band-logo--placeholder{display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--primary);background:rgba(247,240,201,.9)}
.band-body{min-width:0;flex:1}
.band-name{margin:0;color:var(--primary-dark);font-size:1.1rem;line-height:1.2;overflow-wrap:anywhere;pointer-events:auto}
.band-link{text-decoration:none;border-bottom:1px dashed rgba(139,0,26,.5);padding-bottom:1px;pointer-events:auto}
.band-link:hover{border-bottom-style:solid}
.band-info{margin:.35rem 0 0;font-size:.9rem;opacity:.92}
.band-info-text{display:-webkit-box;-webkit-line-clamp:5;line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.4;max-height:calc(1.4em * 5)}
.band-info--muted{opacity:.7;font-style:italic}

/* Band Info Modal */
.band-info-modal{
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  z-index:1000;
  display:none !important;
  align-items:center;
  justify-content:center;
  padding:1rem;
  visibility:hidden;
  opacity:0;
  transition:opacity 0.2s ease, visibility 0.2s ease
}
.band-info-modal[aria-hidden="false"]{
  display:flex !important;
  visibility:visible;
  opacity:1
}
.band-info-modal-overlay{
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:rgba(0,0,0,.6);
  -webkit-backdrop-filter:blur(2px);
  backdrop-filter:blur(2px)
}
.band-info-modal-content{
  position:relative;
  background:#fff;
  border-radius:20px;
  max-width:600px;
  width:90%;
  max-height:90vh;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
  box-shadow:0 20px 60px rgba(0,0,0,.3)
}
.band-info-modal-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:1.5rem;
  border-bottom:2px solid rgba(0,0,0,.1)
}
.band-info-modal-header h2{
  margin:0;
  color:var(--primary-dark);
  font-size:1.4rem
}
.band-info-modal-close{
  background:transparent;
  border:0;
  font-size:2rem;
  line-height:1;
  cursor:pointer;
  color:var(--text);
  opacity:.7;
  padding:.25rem;
  border-radius:8px;
  transition:opacity .2s,background .2s
}
.band-info-modal-close:hover{
  opacity:1;
  background:rgba(0,0,0,.05)
}
.band-info-modal-body{
  padding:1.5rem;
  overflow-y:auto
}
.band-info-modal-logo{
  text-align:center;
  margin-bottom:1.5rem
}
.band-info-modal-logo img{
  max-width:150px;
  max-height:150px;
  border-radius:16px;
  box-shadow:0 8px 16px rgba(0,0,0,.15)
}
.band-info-modal-text{
  font-size:1rem;
  line-height:1.6;
  color:var(--text);
  white-space:pre-wrap;
  word-wrap:break-word
}
@media (max-width: 600px){
  .band-info-modal-content{
    width:95%;
    max-height:95vh
  }
  .band-info-modal-header,.band-info-modal-body{
    padding:1rem
  }
}

/* ===== Sponsors slider page ===== */
.carousel{margin-top:.3rem}
.carousel-viewport{overflow:hidden;border-radius:18px;outline:none}
.carousel-track{display:flex;transition:transform .35s ease-out;will-change:transform}
.carousel-slide{min-width:100%;padding:.25rem 0;display:flex}
.carousel-card{width:100%;display:flex;gap:1.15rem;align-items:center;background:rgba(255,255,255,.85);border-radius:18px;padding:1.15rem 1.2rem;box-shadow:0 10px 22px rgba(0,0,0,.12)}
.carousel-logo{width:200px;height:140px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:16px;flex:0 0 200px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.carousel-logo img{max-width:88%;max-height:88%;object-fit:contain;display:block}
.carousel-logo--placeholder{font-family:"Racone",system-ui;font-style:italic;font-size:2rem;color:var(--primary)}
.carousel-body{min-width:0}
.carousel-title{margin:0;color:var(--primary-dark);font-size:1.35rem;line-height:1.1}
.carousel-link{text-decoration:none;border-bottom:1px dashed rgba(139,0,26,.5);padding-bottom:2px}
.carousel-link:hover{border-bottom-style:solid}
.carousel-info{margin:.5rem 0 .9rem 0;opacity:.92;max-width:46rem}
.carousel-info--muted{opacity:.72;font-style:italic}
.carousel-controls{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;justify-content:center;margin-top:.95rem}
.carousel-dots{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.75rem;justify-content:center}
.carousel-dot{width:12px;height:12px;border-radius:999px;border:1px solid rgba(0,0,0,.25);background:rgba(255,255,255,.7);cursor:pointer}
.carousel-dot.is-active{background:var(--primary);border-color:rgba(0,0,0,.2)}
@media (max-width:720px){
  .carousel-card{flex-direction:column;align-items:flex-start}
  .carousel-logo{width:100%;height:140px;flex:0 0 auto}
}
@media (prefers-reduced-motion: reduce){
  .carousel-track{transition:none}
}

@media (max-width: 720px){.band-grid{grid-template-columns:1fr}}

/* Responsive tweaks */
@media (max-width: 900px){
  .lineup-grid{
    grid-template-columns:1fr !important;
    padding: 0 1rem !important;
  }
}
@media (max-width: 860px){.main-grid{grid-template-columns:1fr}}
@media (max-width: 720px){
  .hero-inner{align-items:stretch;text-align:left}
  .hero-logo-main{width:min(280px,85%)}
  .hero-info{max-width:100%}
}

/* ===== Design parity with original static pages ===== */

@font-face {
  font-family: "Racone";
  src: url("fonts/Racone-Italic.woff2") format("woff2"),
       url("fonts/Racone-Italic.woff") format("woff");
  font-style: italic;
  font-weight: 400;
  font-display: swap;
}

.nav-title span:first-child{font-family:"Racone",system-ui;font-size:1.25rem;letter-spacing:.04em;font-weight:400}
.nav-links a{font-weight:500}
.ticket-pill{font-weight:700}


/* --- Tickets page refinements (retro layout) --- */
.ticket-hero{display:flex;gap:1rem;align-items:center;margin-bottom:.9rem}
.ticket-hero-logo{width:72px;flex:0 0 auto}
.ticket-hero-logo img{width:100%;height:auto;display:block}
.ticket-title{margin:0;color:var(--primary-dark);font-family:"Racone",system-ui,sans-serif;font-style:italic;font-size:1.8rem;letter-spacing:.02em}
.ticket-intro{margin:.25rem 0 0 0;opacity:.9;font-size:.95rem}

.ticket-fieldset{border:0;padding:0;margin:0;display:grid;gap:.75rem}
.ticket-fieldset legend{font-weight:800;color:var(--primary-dark);margin-bottom:.25rem}

.ticket-tile{display:grid;grid-template-columns:22px 1fr auto;gap:.85rem;align-items:center;background:rgba(255,255,255,.85);border-radius:20px;padding:1rem 1rem;box-shadow:0 14px 28px rgba(0,0,0,.10);cursor:pointer;min-height:92px}
.ticket-tile input{position:absolute;opacity:0;pointer-events:none}
.ticket-tile .tile-dot{width:18px;height:18px;border-radius:999px;border:2px solid rgba(120,46,50,.35);display:inline-block;align-self:center;justify-self:center;background:rgba(255,255,255,.65)}
.ticket-tile input:checked + .tile-dot{background:var(--primary);border-color:var(--primary);box-shadow:inset 0 0 0 4px rgba(255,255,255,.9)}
.ticket-tile .tile-body{display:flex;flex-direction:column;gap:.2rem;min-width:0}
.ticket-tile .tile-title{font-weight:900;color:var(--primary-dark)}
.ticket-tile .tile-desc{opacity:.86;font-size:.9rem;line-height:1.35}
.ticket-tile .tile-price{font-weight:900;color:var(--primary-dark);white-space:nowrap}

.ticket-tile:focus-within{outline:3px solid rgba(183,0,31,.35);outline-offset:4px}
.ticket-tile input:checked ~ .tile-body .tile-title{color:var(--primary)}

@media (max-width: 560px){
  .ticket-hero{align-items:flex-start}
  .ticket-hero-logo{width:60px}
  .ticket-tile{grid-template-columns:26px 1fr;grid-template-rows:auto auto;}
  .ticket-tile .tile-price{grid-column:2;justify-self:start;margin-top:.2rem}
}

/* Payment buttons: use original look from old static design */
.ticket-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem;align-items:center}
.ticket-actions .btn-pay{background:linear-gradient(135deg,#f7b731,#f7f0c9);border:none;color:#fff;box-shadow:0 8px 18px rgba(0,0,0,0.16);padding:.55rem 1.15rem;border-radius:999px}
.ticket-actions .btn-pay:active{transform:translateY(1px) scale(.99);box-shadow:0 4px 10px rgba(0,0,0,0.18)}
.ticket-actions .btn-logo{height:26px;width:auto;display:block}
.ticket-actions .btn-logo--paypal{height:22px}

/* Generic payment button (used also on success page) */
.btn-pay{background:linear-gradient(135deg,#f7b731,#f7f0c9);border:none;color:#fff;box-shadow:0 8px 18px rgba(0,0,0,0.16)}
.btn-pay:active{transform:translateY(1px) scale(.99);box-shadow:0 4px 10px rgba(0,0,0,0.18)}
/* ===== Einheitlicher Hero (wie Programm/LineUp) ===== */
.page-hero { padding: 1.2rem 1.4rem; }
.page-kicker { margin: 0 0 .9rem 0; letter-spacing: .12em; font-weight: 900; font-size: .78rem; opacity: .9; }
.page-hero-row { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }
.page-logo { width: 84px; height: auto; flex: 0 0 auto; }
.page-chip {
  display: inline-block;
  padding: .55rem 1rem;
  border-radius: 999px;
  background: rgba(255,255,255,.75);
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
  color: var(--primary-dark);
  font-weight: 900;
  font-style: italic;
  font-size: 2rem;
  line-height: 1;
}
.page-lead { margin: .7rem 0 0 0; max-width: 75ch; opacity: .95; }

/* ===== Tickets Layout ===== */
.tickets-page .tickets-form { display: flex; flex-direction: column; gap: 1rem; }

.tickets-page .ticket-choice { position: relative; }
.tickets-page .ticket-radio { position: absolute; opacity: 0; pointer-events: none; }

.tickets-page .ticket-tile {
  display: block;
  border: 1px solid rgba(0,0,0,.18);
  background: rgba(255,255,255,.70);
  border-radius: 18px;
  padding: 1rem 1.1rem;
  cursor: pointer;
  transition: transform .08s ease, box-shadow .12s ease, border-color .12s ease;
}
.tickets-page .ticket-tile:hover { transform: translateY(-1px); box-shadow: 0 12px 26px rgba(0,0,0,.12); }

.tickets-page .ticket-radio:checked + .ticket-tile {
  border-color: rgba(120,0,25,.45);
  box-shadow: 0 14px 30px rgba(120,0,25,.12);
  background: rgba(255,255,255,.86);
}

.tickets-page .ticket-top { display: flex; gap: 1rem; align-items: flex-start; justify-content: space-between; flex-wrap: wrap; }
.tickets-page .ticket-title { font-weight: 900; color: var(--primary-dark); font-size: 1.05rem; }
.tickets-page .ticket-price { font-weight: 900; color: var(--primary-dark); white-space: nowrap; }
.tickets-page .ticket-desc { margin: .45rem 0 0 0; opacity: .95; max-width: 80ch; line-height: 1.35; }

.tickets-page .ticket-meta { display: flex; align-items: center; }
.tickets-page .ticket-qty { display: flex; flex-direction: column; gap: .35rem; font-weight: 900; }
.tickets-page .ticket-qty select {
  padding: .6rem .7rem;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.18);
  background: rgba(255,255,255,.9);
  font: inherit;
  min-width: 200px;
}

/* PayPal/Stripe nebeneinander */
.tickets-page .pay-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: .8rem;
  align-items: stretch;
}
.tickets-page .pay-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  width: 100%;
  border-radius: 16px;
  padding: .85rem 1rem;
  border: 1px solid rgba(0,0,0,.18);
  background: rgba(255,255,255,.88);
  cursor: pointer;
  transition: transform .08s ease, box-shadow .12s ease;
}
.tickets-page .pay-btn:hover { transform: translateY(-1px); box-shadow: 0 12px 26px rgba(0,0,0,.12); }
.tickets-page .pay-btn:focus-visible { outline: 3px solid rgba(120,0,25,.35); outline-offset: 3px; }
.tickets-page .pay-logo { height: 34px; width: auto; display: block; }
.tickets-page .pay-text { font-weight: 900; color: var(--primary-dark); }

.tickets-page .ticket-hint { margin: .2rem 0 0 0; font-size: .92rem; opacity: .9; }

@media (max-width: 820px) {
  .page-chip { font-size: 1.75rem; }
  .page-logo { width: 74px; }
  .tickets-page .pay-actions { grid-template-columns: 1fr; }
}

/* ===== Einheitlicher Seiten-Hero (wie Screenshot) ===== */
.page-hero { padding: 1.2rem 1.4rem; }
.page-kicker { margin: 0 0 .9rem 0; letter-spacing: .12em; font-weight: 900; font-size: .78rem; opacity: .9; }

.page-hero-row { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }
.page-logo { width: 84px; height: auto; flex: 0 0 auto; }

.page-hero-text { min-width: 260px; }
.page-chip {
  display: inline-block;
  padding: .65rem 1.2rem;
  border-radius: 999px;
  background: rgba(255,255,255,.75);
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
  color: var(--primary-dark);
  font-weight: 900;
  font-style: italic;
  font-size: 2.35rem;
  line-height: 1;
}
.page-lead { margin: .8rem 0 0 0; max-width: 85ch; opacity: .95; line-height: 1.45; }

@media (max-width: 820px) {
  .page-logo { width: 74px; }
  .page-chip { font-size: 2rem; }
}
/* Tickets: Pay Buttons gleich groß */
.pay-actions{
  display:grid;
  grid-template-columns:repeat(2, minmax(180px, 1fr)); /* 2 für PayPal+Stripe */
  gap: .9rem;
  align-items: stretch;
}

.pay-actions.tickets-page {
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: .8rem;
}

.pay-btn{
  width: 100%;
  height: 64px;               /* gleiche Höhe */
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 0.75rem;
  border-radius: 16px;
  padding: 0.85rem 1rem;
  border: 1px solid rgba(0,0,0,.18);
  background: rgba(255,255,255,.88);
  cursor: pointer;
  transition: transform .08s ease, box-shadow .12s ease;
  font: inherit;
}

.pay-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(0,0,0,.12);
}

.pay-btn:focus-visible {
  outline: 3px solid rgba(120,0,25,.35);
  outline-offset: 3px;
}

.pay-logo{
  height: 34px;
  width: auto;
  display:block;
}

.pay-text {
  font-weight: 900;
  color: var(--primary-dark);
  font-size: 1rem;
  white-space: nowrap;
}

/* ===== WARENKORB MODAL BUTTONS - ABSOLUTE PRIORITÄT ===== */
/* Diese Regeln haben höchste Priorität und überschreiben ALLES */

/* Payment-Buttons Container im Modal */
#cart-modal-body .pay-actions,
#cart-modal-body .pay-actions.tickets-page,
.cart-modal-body .pay-actions,
.cart-modal-body .pay-actions.tickets-page,
.cart-modal .pay-actions,
.cart-modal .pay-actions.tickets-page,
.cart-section .pay-actions,
.cart-section .pay-actions.tickets-page {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(200px, 1fr)) !important;
  gap: 0.8rem !important;
  margin-top: 1rem !important;
  margin-bottom: 0 !important;
  align-items: stretch !important;
  visibility: visible !important;
  opacity: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  position: relative !important;
  z-index: 1 !important;
}

/* Payment-Buttons selbst */
#cart-modal-body .pay-actions .pay-btn,
#cart-modal-body .pay-actions.tickets-page .pay-btn,
.cart-modal-body .pay-actions .pay-btn,
.cart-modal-body .pay-actions.tickets-page .pay-btn,
.cart-modal .pay-actions .pay-btn,
.cart-modal .pay-actions.tickets-page .pay-btn,
.cart-section .pay-actions .pay-btn,
.cart-section .pay-actions.tickets-page .pay-btn {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.75rem !important;
  width: 100% !important;
  min-width: 200px !important;
  border-radius: 16px !important;
  padding: 0.85rem 1rem !important;
  border: 1px solid rgba(0,0,0,.18) !important;
  background: rgba(255,255,255,.88) !important;
  cursor: pointer !important;
  transition: transform .08s ease, box-shadow .12s ease !important;
  min-height: 64px !important;
  height: auto !important;
  visibility: visible !important;
  opacity: 1 !important;
  text-decoration: none !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  color: inherit !important;
  position: relative !important;
  z-index: 1 !important;
  margin: 0 !important;
}

#cart-modal-body .pay-actions .pay-btn:hover,
.cart-modal-body .pay-actions .pay-btn:hover,
.cart-modal .pay-actions .pay-btn:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 12px 26px rgba(0,0,0,.12) !important;
}

#cart-modal-body .pay-actions .pay-btn:focus-visible,
.cart-modal-body .pay-actions .pay-btn:focus-visible,
.cart-modal .pay-actions .pay-btn:focus-visible {
  outline: 3px solid rgba(120,0,25,.35) !important;
  outline-offset: 3px !important;
}

#cart-modal-body .pay-actions .pay-logo,
.cart-modal-body .pay-actions .pay-logo,
.cart-modal .pay-actions .pay-logo {
  height: 34px !important;
  width: auto !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  flex-shrink: 0 !important;
}

#cart-modal-body .pay-actions .pay-text,
.cart-modal-body .pay-actions .pay-text,
.cart-modal .pay-actions .pay-text {
  font-weight: 900 !important;
  color: var(--primary-dark) !important;
  font-size: 1rem !important;
  white-space: nowrap !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Mobile: untereinander */
@media (max-width: 820px){
  .pay-actions{ 
    grid-template-columns: 1fr !important; 
  }
  .pay-btn{ 
    height: 62px; 
  }
  .cart-modal .pay-actions {
    grid-template-columns: 1fr !important;
  }
}

/* Warenkorb Modal */
.cart-modal{
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  z-index:1000;
  display:none !important;
  align-items:center;
  justify-content:center;
  padding:1rem;
  visibility:hidden;
  opacity:0;
  transition:opacity 0.2s ease, visibility 0.2s ease
}
.cart-modal[aria-hidden="false"]{
  display:flex !important;
  visibility:visible;
  opacity:1
}
.cart-modal-overlay{
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:rgba(0,0,0,.6);
  -webkit-backdrop-filter:blur(2px);
  backdrop-filter:blur(2px)
}
.cart-modal-content{
  position:relative;
  background:#fff;
  border-radius:20px;
  max-width:600px;
  width:90%;
  max-height:90vh;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
  box-shadow:0 20px 60px rgba(0,0,0,.3)
}
.cart-modal-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:1.5rem;
  border-bottom:2px solid rgba(0,0,0,.1)
}
.cart-modal-header h2{
  margin:0;
  color:var(--primary-dark);
  font-size:1.5rem
}
.cart-modal-close{
  background:none;
  border:none;
  font-size:2rem;
  line-height:1;
  cursor:pointer;
  color:var(--text);
  padding:0;
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  transition:background .2s
}
.cart-modal-close:hover{
  background:rgba(0,0,0,.1)
}
.cart-modal-body{
  padding:1.5rem;
  overflow-y:auto;
  flex:1
}
.cart-items{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}
.cart-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:.75rem;
  background:rgba(255,255,255,.95);
  border-radius:8px;
  border:1px solid rgba(0,0,0,.1)
}
.cart-item-info{display:flex;flex-direction:column;gap:.25rem}
.btn-remove{
  background:rgba(200,0,0,.1);
  border:none;
  border-radius:50%;
  width:28px;
  height:28px;
  font-size:1.2rem;
  cursor:pointer;
  color:rgba(200,0,0,.8);
  transition:background .2s
}
.btn-remove:hover{background:rgba(200,0,0,.2)}
.cart-total{
  padding-top:1rem;
  border-top:2px solid rgba(0,0,0,.1);
  font-size:1.1rem;
  margin-bottom:1rem
}
/* Cart-Actions Buttons (Weiter einkaufen, Warenkorb leeren) */
#cart-modal-body .cart-actions,
.cart-modal-body .cart-actions,
.cart-modal .cart-actions,
.cart-section .cart-actions {
  display: flex !important;
  flex-direction: row !important;
  gap: 0.75rem !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  visibility: visible !important;
  opacity: 1 !important;
  margin-top: 1rem !important;
  margin-bottom: 0 !important;
  width: 100% !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  position: relative !important;
  z-index: 1 !important;
}

#cart-modal-body .cart-actions .btn,
.cart-modal-body .cart-actions .btn,
.cart-modal .cart-actions .btn,
.cart-section .cart-actions .btn {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.4rem !important;
  visibility: visible !important;
  opacity: 1 !important;
  flex-shrink: 0 !important;
  min-width: auto !important;
  width: auto !important;
  padding: 0.45rem 1rem !important;
  border-radius: 999px !important;
  font-size: 0.85rem !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  cursor: pointer !important;
  text-decoration: none !important;
  border: 0 !important;
  position: relative !important;
  z-index: 1 !important;
  margin: 0 !important;
}

#cart-modal-body .cart-actions .btn.btn-secondary,
.cart-modal-body .cart-actions .btn.btn-secondary,
.cart-modal .cart-actions .btn.btn-secondary {
  background: #fff !important;
  color: var(--primary-dark) !important;
  border: 1px solid rgba(0,0,0,.12) !important;
}
@media (max-width:720px){
  .cart-modal-content{
    max-height:95vh;
    border-radius:20px 20px 0 0;
    margin-top:auto;
    width:95%;
    max-width:95%;
    margin-left:auto;
    margin-right:auto;
  }
  
  .cart-modal .pay-actions {
    grid-template-columns: 1fr !important;
    gap: 0.6rem;
  }
  
  .cart-modal .pay-btn {
    min-height: 56px;
    padding: 0.7rem 0.9rem;
    font-size: 0.9rem;
  }
  
  .cart-modal .pay-logo {
    height: 28px;
  }
  
  .cart-modal .pay-text {
    font-size: 0.9rem;
  }
}
