:root{
  --ink:#12151C;
  --ink-soft:#1B2029;
  --cream:#FBF3E7;
  --cream-soft:#F3E6D2;
  --orange:#F2790C;
  --coral:#E94B6B;
  --teal:#0B8A82;
  --gold:#F4B740;
  --text-on-dark:#F3EEE3;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Space Grotesk', sans-serif;
  background:var(--cream);
  color:var(--ink);
  overflow-x:hidden;
}
h1,h2,h3{font-family:'Anton', sans-serif; font-weight:400; text-transform:uppercase; letter-spacing:0.01em;}
a{color:inherit; text-decoration:none;}
.wrap{max-width:1080px; margin:0 auto; padding:0 24px;}

/* NAV */
nav{
  position:sticky; top:0; z-index:50;
  background:rgba(251,243,231,0.9); backdrop-filter:blur(6px);
  border-bottom:1px solid rgba(18,21,28,0.08);
}
nav .wrap{display:flex; align-items:center; justify-content:space-between; height:72px;}
.brand{display:flex; align-items:center; gap:12px;}
.brand img{width:42px; height:42px; border-radius:50%;}
.brand span{font-family:'Anton', sans-serif; font-size:18px; letter-spacing:0.03em;}
.navlinks{display:flex; gap:24px; font-size:14px; font-weight:500; align-items:center;}
.navlinks a{padding:6px 0; border-bottom:2px solid transparent; transition:border-color .2s;}
.navlinks a:hover, .navlinks a.active{border-color:var(--orange);}
.navtoggle{display:none; flex-direction:column; gap:4px; background:none; border:none; cursor:pointer;}
.navtoggle span{width:22px; height:2px; background:var(--ink);}

/* HERO (used on subpages as a smaller page header) */
.pagehead{
  position:relative; padding:80px 0 60px;
  background:
    radial-gradient(ellipse 60% 50% at 78% 18%, rgba(242,121,12,0.30), transparent 60%),
    radial-gradient(ellipse 50% 40% at 15% 85%, rgba(233,75,107,0.18), transparent 60%),
    var(--cream);
}
.eyebrow{
  font-family:'Space Mono', monospace; font-size:13px; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--coral); margin-bottom:18px; display:inline-block;
  border:1px solid var(--coral); padding:5px 12px; border-radius:100px;
}
.pagehead h1{font-size:clamp(38px, 6vw, 64px); line-height:1; margin-bottom:14px;}
.pagehead p.lead{font-size:18px; max-width:560px; line-height:1.6; color:#3a3530;}

.hero{
  position:relative; min-height:92vh; display:flex; align-items:center;
  background:
    radial-gradient(ellipse 60% 50% at 78% 18%, rgba(242,121,12,0.35), transparent 60%),
    radial-gradient(ellipse 50% 40% at 15% 85%, rgba(233,75,107,0.22), transparent 60%),
    var(--cream);
  overflow:hidden;
}
.hero .wrap{position:relative; z-index:2; padding-top:60px; padding-bottom:60px;}
.hero h1{font-size:clamp(52px, 9vw, 108px); line-height:0.94; margin-bottom:22px;}
.hero h1 .line2{color:var(--orange);}
.hero p.lead{font-size:19px; max-width:520px; line-height:1.6; margin-bottom:34px; color:#3a3530;}
.btnrow{display:flex; gap:16px; flex-wrap:wrap;}
.btn{
  font-family:'Space Grotesk',sans-serif; font-weight:700; font-size:15px;
  padding:15px 28px; border-radius:100px; display:inline-block; transition:transform .15s ease;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--ink); color:var(--cream);}
.btn-ghost{border:2px solid var(--ink); color:var(--ink);}

.sundial{
  position:fixed; right:18px; top:0; height:100vh; width:14px; z-index:40;
  display:flex; justify-content:center; pointer-events:none;
}
.sundial-track{position:relative; width:2px; height:100%; background:rgba(18,21,28,0.12); border-radius:2px;}
.sundial-marker{
  position:absolute; left:50%; top:0; width:16px; height:16px; border-radius:50%;
  transform:translate(-50%,-50%); background:var(--gold);
  box-shadow:0 0 0 4px rgba(244,183,64,0.25);
  transition:background .15s linear, box-shadow .15s linear;
}

/* SECTION GENERIC */
section{padding:100px 0;}
.kicker{font-family:'Space Mono', monospace; font-size:13px; letter-spacing:0.1em; text-transform:uppercase; color:var(--teal); margin-bottom:14px;}
.sec-head{max-width:640px; margin-bottom:56px;}
.sec-head h2{font-size:clamp(32px,4.5vw,48px); line-height:1.02; margin-bottom:18px;}
.sec-head p{font-size:17px; line-height:1.7; color:#3a3530;}

/* WER WIR SIND */
.about{background:var(--cream);}
.about p{font-size:17px; line-height:1.75; margin-bottom:20px; color:#3a3530; max-width:640px;}

/* WAS WIR MACHEN / PILLARS / CARDS */
.pillars{background:var(--cream-soft);}
.pillar-grid, .card-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.pillar, .card{
  background:var(--cream); border:1px solid rgba(18,21,28,0.08); border-radius:20px;
  padding:32px 26px; transition:transform .2s ease;
}
.pillar:hover, .card:hover{transform:translateY(-6px);}
.pillar-num{font-family:'Space Mono',monospace; font-size:13px; color:#8a8377; margin-bottom:18px;}
.pillar h3, .card h3{font-size:21px; margin-bottom:12px; font-family:'Space Grotesk',sans-serif; font-weight:700; text-transform:none;}
.pillar p, .card p{font-size:15px; line-height:1.6; color:#4a453e;}
.dot{width:10px; height:10px; border-radius:50%; display:inline-block; margin-bottom:14px;}

/* EVENTS - NIGHT SECTION */
.events{
  background:
    radial-gradient(1px 1px at 10% 20%, rgba(255,255,255,0.5), transparent),
    radial-gradient(1px 1px at 80% 10%, rgba(255,255,255,0.4), transparent),
    radial-gradient(1px 1px at 60% 70%, rgba(255,255,255,0.35), transparent),
    radial-gradient(1px 1px at 30% 85%, rgba(255,255,255,0.4), transparent),
    radial-gradient(1px 1px at 90% 60%, rgba(255,255,255,0.3), transparent),
    radial-gradient(ellipse 60% 40% at 20% 0%, rgba(233,75,107,0.18), transparent 60%),
    radial-gradient(ellipse 50% 40% at 90% 100%, rgba(11,138,130,0.25), transparent 60%),
    var(--ink);
  color:var(--text-on-dark);
}
.events .kicker{color:var(--gold);}
.events .sec-head p{color:#c9c2b3;}
.event-list{display:flex; flex-direction:column; gap:2px;}
.event-row{
  display:grid; grid-template-columns:140px 1fr auto; gap:28px; align-items:center;
  padding:26px 8px; border-top:1px solid rgba(255,255,255,0.12);
}
.event-row:last-child{border-bottom:1px solid rgba(255,255,255,0.12);}
.event-date{font-family:'Space Mono',monospace; font-size:14px; color:var(--gold);}
.event-info h3{font-family:'Space Grotesk',sans-serif; font-weight:700; text-transform:none; font-size:22px; margin-bottom:6px;}
.event-info p{font-size:14px; color:#c9c2b3; line-height:1.5;}
.event-tag{
  font-family:'Space Mono',monospace; font-size:12px; letter-spacing:0.06em; text-transform:uppercase;
  padding:7px 14px; border-radius:100px; border:1px solid rgba(255,255,255,0.3); white-space:nowrap;
}

/* DJ CARDS */
.dj-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.dj-card{
  background:var(--cream); border:1px solid rgba(18,21,28,0.08); border-radius:20px;
  padding:28px 24px; text-align:left;
}
.dj-avatar{
  width:64px; height:64px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-family:'Anton',sans-serif; font-size:22px; color:var(--cream); margin-bottom:18px;
}
.dj-card h3{font-size:20px; margin-bottom:6px; font-family:'Space Grotesk',sans-serif; font-weight:700; text-transform:none;}
.dj-tag{font-family:'Space Mono',monospace; font-size:12px; text-transform:uppercase; letter-spacing:0.05em; color:var(--coral); margin-bottom:12px; display:inline-block;}
.dj-card p{font-size:14px; line-height:1.6; color:#4a453e;}

/* PLACEHOLDER / EMPTY STATE */
.placeholder-box{
  border:2px dashed rgba(18,21,28,0.18); border-radius:20px; padding:48px 32px; text-align:center;
}
.placeholder-box h3{font-size:20px; margin-bottom:12px; font-family:'Space Grotesk',sans-serif; font-weight:700; text-transform:none;}
.placeholder-box p{font-size:15px; color:#4a453e; max-width:440px; margin:0 auto 24px;}

/* GALLERY / RECAP */
.recap{background:var(--cream-soft);}
.recap-block{margin-bottom:64px;}
.recap-block:last-child{margin-bottom:0;}
.recap-head{display:flex; align-items:baseline; gap:16px; margin-bottom:20px; flex-wrap:wrap;}
.recap-head h3{font-family:'Space Grotesk',sans-serif; font-weight:700; text-transform:none; font-size:24px;}
.recap-date{font-family:'Space Mono',monospace; font-size:13px; color:var(--teal);}
.recap p{font-size:16px; line-height:1.7; color:#3a3530; max-width:680px; margin-bottom:24px;}
.gallery-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px;}
.gallery-tile{
  aspect-ratio:4/3; border-radius:14px; border:1.5px dashed rgba(18,21,28,0.18);
  display:flex; align-items:center; justify-content:center; background:rgba(18,21,28,0.03);
  font-family:'Space Mono',monospace; font-size:12px; color:#8a8377; text-align:center; padding:10px;
}

/* LEGAL PAGES */
.legal{max-width:760px; margin:0 auto; padding:80px 24px 120px;}
.legal h1{font-size:clamp(30px,5vw,44px); margin-bottom:32px;}
.legal h2{font-family:'Space Grotesk',sans-serif; font-weight:700; text-transform:none; font-size:19px; margin:36px 0 12px;}
.legal p, .legal li{font-size:15px; line-height:1.75; color:#3a3530; margin-bottom:14px;}
.legal ul{padding-left:22px; margin-bottom:14px;}
.legal strong{color:var(--ink);}
.legal .note{
  background:var(--cream-soft); border-radius:14px; padding:18px 20px; font-size:13px; color:#5a544a; margin-bottom:32px;
}

/* KONTAKT / FOOTER */
footer{background:var(--ink-soft); color:var(--text-on-dark); padding:80px 0 40px;}
.foot-grid{display:grid; grid-template-columns:1.2fr 1fr; gap:40px; margin-bottom:60px;}
footer h2{font-size:clamp(30px,4vw,44px); margin-bottom:18px;}
footer p{color:#c9c2b3; font-size:15px; line-height:1.7;}
.foot-contact{font-size:15px; display:flex; flex-direction:column; gap:12px;}
.foot-contact a{border-bottom:1px solid transparent;}
.foot-contact a:hover{border-color:var(--orange); color:var(--orange);}
.foot-bottom{border-top:1px solid rgba(255,255,255,0.12); padding-top:24px; display:flex; justify-content:space-between; font-size:13px; color:#8a8377; flex-wrap:wrap; gap:14px;}
.foot-legal{display:flex; gap:18px; flex-wrap:wrap;}
.foot-legal a:hover{color:var(--orange);}

@media (max-width:760px){
  .navlinks{position:fixed; top:72px; left:0; right:0; background:var(--cream); flex-direction:column; padding:20px 24px; gap:18px; border-bottom:1px solid rgba(18,21,28,0.08); display:none; align-items:flex-start;}
  .navlinks.open{display:flex;}
  .navtoggle{display:flex;}
  .pillar-grid, .card-grid, .dj-grid{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:1fr 1fr;}
  .event-row{grid-template-columns:1fr; gap:10px;}
  .sundial{display:none;}
  .foot-grid{grid-template-columns:1fr;}
}
