/* =========================================================
   DiscoTech-Events — Design-System
   Token-Basis: gleiche Bildsprache wie das Musikwunsch-Tool
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Anton&family=Space+Mono:wght@400;700&family=Work+Sans:wght@400;500;600;700&display=swap');

:root{
  --ink:#16102B;
  --ink-light:#241A3F;
  --paper:#F3ECDD;
  --pink:#FF3E6C;
  --pink-deep:#E22357;
  --yellow:#F4FF6B;
  --line:rgba(243,236,221,0.14);
  --max:1140px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--ink);
  color:var(--paper);
  font-family:'Work Sans', sans-serif;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
.container{ max-width:var(--max); margin:0 auto; padding:0 24px; }

.display{
  font-family:'Anton', sans-serif;
  text-transform:uppercase;
  letter-spacing:0.01em;
  line-height:0.95;
  margin:0;
}
.mono{ font-family:'Space Mono', monospace; }
.eyebrow{
  font-family:'Space Mono', monospace;
  font-size:12px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--pink);
  margin:0 0 10px;
}

/* ---------- Header ---------- */
header.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(22,16,43,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.header-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px; max-width:var(--max); margin:0 auto; gap:16px;
}
.logo-link{ display:flex; align-items:center; gap:10px; text-decoration:none; }
.logo-link img{ height:40px; width:auto; }
nav.main-nav{ display:flex; gap:26px; align-items:center; }
nav.main-nav a{
  text-decoration:none; font-size:14px; font-weight:600; opacity:0.85;
  padding:6px 0; border-bottom:2px solid transparent; transition:opacity .15s, border-color .15s;
}
nav.main-nav a:hover, nav.main-nav a.active{ opacity:1; border-color:var(--pink); }
.header-actions{ display:flex; align-items:center; gap:12px; }
.call-btn{
  display:flex; align-items:center; gap:8px; background:var(--pink); color:var(--paper);
  text-decoration:none; font-weight:700; font-size:13px; padding:9px 16px; border-radius:30px;
  white-space:nowrap;
}
.call-btn:hover{ background:var(--pink-deep); }
.burger{ display:none; background:none; border:none; color:var(--paper); font-size:26px; cursor:pointer; }

@media (max-width:860px){
  nav.main-nav{
    position:absolute; top:100%; left:0; right:0; background:var(--ink);
    flex-direction:column; align-items:flex-start; gap:0; max-height:0; overflow:hidden;
    border-bottom:1px solid var(--line); transition:max-height .25s ease;
  }
  nav.main-nav.open{ max-height:340px; }
  nav.main-nav a{ width:100%; padding:14px 24px; border-bottom:1px solid var(--line); border-bottom-width:1px !important; }
  .burger{ display:block; }
}

/* ---------- Quick-Access bar ---------- */
.quickbar{
  background:var(--ink-light);
  border-bottom:1px solid var(--line);
}
.quickbar .container{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--line);
}
.quickbar a{
  background:var(--ink-light); text-decoration:none; color:var(--paper);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:4px; padding:14px 8px; font-size:12.5px; font-weight:600; text-align:center;
  transition:background .15s;
}
.quickbar a:hover{ background:var(--ink); color:var(--pink); }
.quickbar .ico{ font-size:18px; }
@media (max-width:700px){
  .quickbar .container{ grid-template-columns:repeat(2,1fr); padding:0; }
}

/* ---------- Hero ---------- */
.hero{ padding:72px 0 64px; }
.hero h1{ font-size:clamp(40px,7vw,76px); }
.hero p.lead{ font-size:17px; opacity:0.75; max-width:54ch; margin:18px 0 30px; }
.cta-row{ display:flex; gap:14px; flex-wrap:wrap; }

.btn{
  font-family:'Anton', sans-serif; text-transform:uppercase; letter-spacing:0.02em;
  font-size:15px; border:none; border-radius:4px; padding:14px 26px; cursor:pointer;
  background:var(--pink); color:var(--paper); text-decoration:none; display:inline-flex;
  align-items:center; gap:8px; transition:transform .12s ease, background .15s ease;
}
.btn:hover{ background:var(--pink-deep); transform:translateY(-1px); }
.btn.outline{
  background:transparent; color:var(--paper); border:1.5px solid rgba(243,236,221,0.4);
}
.btn.outline:hover{ border-color:var(--pink); background:transparent; color:var(--pink); }
.btn.dark{ background:var(--ink); color:var(--paper); }
.btn.full{ width:100%; justify-content:center; }
.btn:disabled{ opacity:0.5; cursor:not-allowed; transform:none; }

/* ---------- Sections / Cards ---------- */
section{ padding:64px 0; }
section.alt{ background:var(--ink-light); }
.section-head{ margin-bottom:38px; max-width:64ch; }
.section-head h2{ font-size:clamp(28px,4.5vw,42px); }
.section-head p{ opacity:0.7; font-size:15.5px; margin-top:10px; }

.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
@media (max-width:860px){ .grid-3{ grid-template-columns:1fr; } .grid-2{ grid-template-columns:1fr; } }

.card{
  background:var(--paper); color:var(--ink); border-radius:6px; padding:28px 24px;
  display:flex; flex-direction:column; gap:10px;
}
.card .num{ font-family:'Space Mono',monospace; font-size:13px; color:var(--pink-deep); font-weight:700; }
.card h3{ font-family:'Anton',sans-serif; text-transform:uppercase; font-size:22px; margin:0; }
.card p{ font-size:14.5px; opacity:0.75; margin:0; line-height:1.5; }
.card a.card-link{ margin-top:8px; font-size:13px; font-weight:700; color:var(--pink-deep); text-decoration:none; }
.card a.card-link:hover{ text-decoration:underline; }

.card.on-dark{ background:var(--ink-light); color:var(--paper); border:1px solid var(--line); }
.card.on-dark p{ opacity:0.7; }

.badge-soon{
  display:inline-block; font-family:'Space Mono',monospace; font-size:11px; letter-spacing:0.08em;
  text-transform:uppercase; background:var(--yellow); color:var(--ink); padding:3px 10px; border-radius:20px;
}

/* ---------- Scale steps (klein -> Zeltfest) ---------- */
.scale-row{ display:flex; flex-wrap:wrap; gap:0; counter-reset:step; }
.scale-step{
  flex:1; min-width:220px; padding:22px 20px; border-left:2px dashed var(--line); position:relative;
}
.scale-step:first-child{ border-left:none; }
.scale-step .step-num{
  font-family:'Space Mono',monospace; font-size:13px; color:var(--pink); margin-bottom:8px;
}
.scale-step h4{ font-family:'Anton',sans-serif; text-transform:uppercase; font-size:18px; margin:0 0 6px; }
.scale-step p{ font-size:13.5px; opacity:0.7; margin:0; }
@media (max-width:860px){ .scale-step{ border-left:none; border-top:2px dashed var(--line); } .scale-step:first-child{ border-top:none; } }

/* ---------- Gallery ---------- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.gallery img{ border-radius:5px; aspect-ratio:1/1; object-fit:cover; width:100%; }
@media (max-width:760px){ .gallery{ grid-template-columns:repeat(2,1fr); } }

/* ---------- Tool teaser (ticket motif) ---------- */
.tool-teaser{
  background:var(--paper); color:var(--ink); border-radius:6px; padding:34px 28px;
  display:flex; gap:30px; align-items:center; flex-wrap:wrap;
}
.tool-teaser .ticket-mock{
  flex:none; width:170px; background:var(--ink); color:var(--paper); border-radius:5px; padding:16px;
  font-family:'Space Mono',monospace; font-size:11px;
}
.ticket-mock .line{ background:rgba(243,236,221,0.16); height:8px; border-radius:3px; margin-bottom:8px; }
.ticket-mock .line.short{ width:60%; }
.ticket-mock .stamp-mini{
  display:inline-block; margin-top:10px; border:1.5px solid var(--pink); color:var(--pink);
  padding:2px 6px; border-radius:3px; transform:rotate(-6deg); font-size:9px; letter-spacing:0.05em;
}
.tool-teaser .copy{ flex:1; min-width:240px; }
.tool-teaser h3{ font-family:'Anton',sans-serif; text-transform:uppercase; font-size:24px; margin:0 0 8px; }
.tool-teaser p{ opacity:0.75; margin:0 0 16px; font-size:14.5px; }

/* ---------- Forms ---------- */
.form-card{
  background:var(--paper); color:var(--ink); border-radius:6px; padding:30px 26px;
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:600px){ .form-row{ grid-template-columns:1fr; } }
.field{ margin-bottom:18px; }
.field label{
  display:block; font-family:'Space Mono',monospace; font-size:11.5px; letter-spacing:0.06em;
  text-transform:uppercase; opacity:0.6; margin-bottom:7px;
}
.field input, .field select, .field textarea{
  width:100%; font-family:'Work Sans',sans-serif; font-size:15.5px; border:none;
  border-bottom:2px solid rgba(22,16,43,0.25); background:transparent; padding:9px 2px;
  outline:none; color:var(--ink);
}
.field input:focus, .field select:focus, .field textarea:focus{ border-bottom-color:var(--pink); }
.field textarea{ min-height:110px; resize:vertical; }
.checkbox-row{ display:flex; gap:10px; align-items:flex-start; font-size:13px; opacity:0.8; margin-bottom:22px; }
.checkbox-row input{ margin-top:3px; }
.checkbox-row a{ color:var(--pink-deep); text-decoration:underline; }
.checkgroup{ display:flex; gap:18px; flex-wrap:wrap; }
.checkgroup label{ display:flex; align-items:center; gap:6px; font-size:14px; text-transform:none; letter-spacing:0; opacity:1; font-family:'Work Sans',sans-serif; }
.hp-field{ position:absolute; left:-9999px; top:-9999px; }

.banner{
  border-radius:5px; padding:14px 18px; font-size:14px; margin-bottom:24px; font-weight:600;
}
.banner.ok{ background:var(--yellow); color:var(--ink); }
.banner.err{ background:var(--pink); color:var(--paper); }

/* ---------- Contact info side ---------- */
.contact-info{ display:flex; flex-direction:column; gap:18px; }
.info-item{ display:flex; gap:14px; align-items:flex-start; }
.info-item .ico{
  width:38px; height:38px; flex:none; border-radius:50%; background:var(--ink-light);
  display:flex; align-items:center; justify-content:center; font-size:16px;
}
.info-item h4{ margin:0 0 3px; font-size:14px; }
.info-item p, .info-item a{ margin:0; font-size:14px; opacity:0.75; text-decoration:none; }
.info-item a:hover{ color:var(--pink); }

/* ---------- Footer ---------- */
footer{
  border-top:1px solid var(--line); padding:40px 0 26px; font-size:13px; opacity:0.7;
}
.footer-row{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; align-items:center; }
footer a{ text-decoration:none; }
footer a:hover{ color:var(--pink); }
.legal-links{ display:flex; gap:18px; }

/* ---------- Legal pages ---------- */
.legal h2{ font-family:'Anton',sans-serif; text-transform:uppercase; font-size:32px; margin-bottom:4px; }
.legal h5{ font-family:'Space Mono',monospace; font-size:12px; letter-spacing:0.1em; text-transform:uppercase; color:var(--pink); margin:30px 0 8px; }
.legal p{ font-size:14.5px; line-height:1.7; opacity:0.85; max-width:74ch; }

@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
