:root{
  /* Softer dark warm background and palette from image */
  --bg-900:#131017;
  --bg-800:#1a1516;
  --glass-900: rgba(255,255,255,0.04);
  --bordeaux-700:#4a1320;
  --bordeaux-500:#7a313c;
  --warm-gold:#d4a25a;
  --muted:#cfc7bf;
  --surface-contrast:#111213;
  --text:#f6efe9;
  --max-width:1100px;
  --radius:14px;
  --gap:18px;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  color-scheme: dark;
}

/* Reset */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background: linear-gradient(180deg,var(--bg-900) 0%, var(--bg-800) 100%);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
  padding-bottom:0;
}

.container{max-width:var(--max-width);margin:0 auto;padding:24px}

/* Glass surface utility */
.glass-surface{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.06));
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: var(--radius);
  box-shadow:
    0 8px 30px rgba(0,0,0,0.5),
    inset 0 1px 0 rgba(255,255,255,0.02);
  backdrop-filter: blur(10px) saturate(120%) contrast(0.98);
  -webkit-backdrop-filter: blur(10px) saturate(120%) contrast(0.98);
  transition: box-shadow .25s ease, transform .18s ease;
}

/* Fallback for no backdrop-filter */
@supports not ((-webkit-backdrop-filter: blur(10px)) or (backdrop-filter: blur(10px))) {
  .glass-surface{
    background: linear-gradient(180deg, rgba(74,19,32,0.6), rgba(17,12,14,0.7));
  }
}

/* Header */
.site-header .header-top{padding:12px 0}
.header-inner{display:flex;align-items:center;gap:16px}
.brand{display:flex;align-items:center;gap:12px}
.site-title{font-weight:700;display:block}
.site-sub{display:block;font-size:12px;color:var(--muted)}

.main-nav{margin-left:auto;position:relative}
.nav-toggle{display:none;background:none;border:none;color:var(--text);font-size:20px}
.nav-toggle i{font-size:20px}
.nav-list{list-style:none;margin:0;padding:0;display:flex;gap:16px;align-items:center}
.nav-list a{color:var(--muted);text-decoration:none;padding:8px;border-radius:8px}
.nav-list a:hover{color:var(--text);background:linear-gradient(90deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01))}

.header-actions{display:flex;gap:8px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:10px;padding:10px 14px;font-weight:700;text-decoration:none;cursor:pointer;border:1px solid transparent;background:transparent;color:var(--text)}
.btn-outline{border:1px solid rgba(255,255,255,0.06);color:var(--muted);background:transparent}
.btn-primary{background: linear-gradient(180deg,var(--warm-gold), #c79044);color:#111;border:none}
.btn.small{padding:6px 10px;font-size:14px}
.btn.large{padding:14px 20px;font-size:16px}

/* Hero */
.header-hero{position:relative;padding:28px 0 48px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.45) saturate(.9);transform:scale(1.02);will-change:transform;z-index:0}
.hero-inner{position:relative;display:flex;gap:24px;align-items:stretch;z-index:1}
.hero-panel{padding:24px;max-width:640px}
.hero-left h1{font-size:36px;margin:0 0 12px}
.lead{color:var(--muted);margin-bottom:16px}

.hero-right{width:420px;max-width:40%}
.hero-slider{position:relative;border-radius:12px;overflow:hidden;height:260px;background:linear-gradient(180deg, rgba(0,0,0,0.35), rgba(0,0,0,0.55))}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;transition:opacity .5s ease,transform .6s ease;padding:18px;display:flex;align-items:flex-end}
.slide[aria-hidden="true"]{opacity:0;transform:translateY(10px) scale(1.02);pointer-events:none}
.slide-caption{background:linear-gradient(180deg,transparent 0%, rgba(0,0,0,0.6) 50%);padding:12px;border-radius:8px;color:var(--text)}

/* Controls */
.slider-prev,.slider-next{position:absolute;top:50%;transform:translateY(-50%);background:linear-gradient(180deg, rgba(0,0,0,0.45), rgba(0,0,0,0.6));border:none;color:var(--text);width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(0,0,0,0.6)}
.slider-prev{left:12px}
.slider-next{right:12px}

/* Ticker */
.news-ticker{display:flex;align-items:center;gap:12px;padding:12px 24px;background:transparent;border-top:1px solid rgba(255,255,255,0.02);border-bottom:1px solid rgba(255,255,255,0.02);z-index:1;position:relative}
.ticker-label{font-weight:800;color:var(--warm-gold);margin-right:8px}
.ticker-track{overflow:hidden;flex:1;white-space:nowrap}
.ticker-item{display:inline-block;padding-right:40px;color:var(--muted);font-weight:600;opacity:.95}

/* Section & grid */
.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.filters label{color:var(--muted);margin-left:8px;font-size:14px}

.events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.event-card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.02));border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease, box-shadow .18s ease}
.event-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,0.6)}
.event-card img{width:100%;height:160px;object-fit:cover;display:block}
.event-body{padding:14px;flex:1;display:flex;flex-direction:column}
.event-body h3{margin:0 0 6px}
.meta{color:var(--muted);font-size:14px;margin-bottom:8px}
.excerpt{flex:1;color:var(--muted);margin-bottom:12px}
.event-actions{display:flex;gap:8px;align-items:center}

/* Calendar & ticketing */
.calendar{margin-top:28px}
.calendar-controls{display:flex;gap:12px;align-items:center;margin-bottom:12px}
.month-label{font-weight:700}
.calendar-grid{display:flex;gap:12px}
.cal-day{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.02));padding:10px;border-radius:10px;min-width:120px}
.cal-event{margin-top:6px;color:var(--muted);font-size:14px}

.ticket-row{display:flex;gap:18px;align-items:center}
.ticket-info{flex:1;padding:18px}
.ticket-actions{min-width:220px;display:flex;flex-direction:column;gap:10px}

.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:28px}
.info-card{padding:16px;border-radius:12px}

/* Footer */
.site-footer{border-top:1px solid rgba(255,255,255,0.03);padding:24px 0;margin-top:28px;position:relative}
.footer-columns{display:flex;justify-content:space-between;gap:20px}
.footer-columns h4{margin:0 0 8px}
.footer-bottom{margin-top:16px;color:var(--muted)}

.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}

/* Mobile nav: vertical list without expanding page width */
@media (max-width:980px){
  .nav-toggle{display:block;margin-left:auto}
  .nav-list{
    display:flex;flex-direction:column;position:absolute;top:64px;right:16px;left:16px;background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.06));border-radius:12px;padding:12px;box-shadow:0 12px 40px rgba(0,0,0,0.6);z-index:60;backdrop-filter:blur(8px);
  }
  .nav-list a{display:block;padding:12px;border-radius:8px}
  .events-grid{grid-template-columns:repeat(2,1fr)}
  .hero-inner{flex-direction:column}
  .hero-right{width:100%;max-width:none}
  .header-inner{flex-wrap:wrap}
}

/* Bottom navbar (mobile only) */
.bottom-nav{position:fixed;left:12px;right:12px;bottom:12px;z-index:70;border-radius:63px;padding:8px;background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(0,0,0,0.18));backdrop-filter:blur(10px) saturate(120%);box-shadow:0 12px 30px rgba(0,0,0,0.6);display:none}
.bottom-nav ul{display:flex;justify-content:space-between;gap:8px;margin:0;padding:6px 10px;list-style:none;align-items:center}
.bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);text-decoration:none;font-size:12px;padding:6px 8px;border-radius:10px}
.bottom-nav a .fa-solid, .bottom-nav a .fa-regular{font-size:18px;margin-bottom:4px;color:var(--muted)}
.bottom-nav a:active, .bottom-nav a:focus{color:var(--text)}

@media (max-width:640px){
  .bottom-nav{display:block}
  .header-actions{display:none}
  body{padding-bottom:92px}
  .events-grid{grid-template-columns:1fr}
  .info-grid{grid-template-columns:1fr}
  .footer-columns{flex-direction:column}
  .ticket-row{flex-direction:column}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .hero-bg, .slide, .event-card, .glass-surface { transition: none !important; animation: none !important; transform: none !important; }
}
