/* ============================================================
   APRO STADE – Hauptstylesheet
   Design: Dunkel, Rot-Akzent, Playfair Display + Inter
   DSGVO: Alle Ressourcen lokal – keine externen Anfragen
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0a0a0a;--bg2:#111;--bg3:#1a1a1a;--surface:#1e1e1e;
  --border:#2a2a2a;--text:#f0ede8;--dim:#888;
  --red:#c0392b;--red-h:#e74c3c;
  --font-d:'Playfair Display',Georgia,serif;
  --font-b:'Inter',system-ui,-apple-system,sans-serif;
  --r:4px;--t:.2s ease;--max:1200px;
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-b);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}

/* Barrierefreiheit */
.skip-link{position:absolute;top:-100px;left:1rem;background:var(--red);color:#fff;padding:.75rem 1.5rem;border-radius:var(--r);font-weight:700;z-index:9999;text-decoration:none;transition:top .2s}
.skip-link:focus{top:1rem}
*:focus-visible{outline:3px solid var(--red);outline-offset:3px}

/* Typografie */
.display{font-family:var(--font-d);font-weight:900;line-height:1.05;letter-spacing:-.02em}
.mono{font-family:var(--font-b);font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.accent{color:var(--red)}
h1{font-size:clamp(2.5rem,8vw,5.5rem)}
h2{font-size:clamp(2rem,5vw,3.5rem)}
h3{font-size:1.25rem;font-family:var(--font-d);font-weight:700;margin-bottom:.5rem}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
a{color:var(--red);text-decoration:none}
a:hover{color:var(--red-h);text-decoration:underline}
blockquote{border-left:3px solid var(--red);padding-left:1.25rem;margin:1.5rem 0;font-style:italic;color:var(--dim)}
address{font-style:normal}

/* Layout */
.container{max-width:var(--max);margin:0 auto;padding:0 1.5rem}
section{padding:5rem 0}
.section-label{color:var(--red);margin-bottom:1rem;display:block}

/* Buttons */
.btn-primary{display:inline-block;background:var(--red);color:#fff;padding:.875rem 2rem;border-radius:var(--r);font-weight:700;font-size:.875rem;letter-spacing:.05em;text-transform:uppercase;border:2px solid var(--red);cursor:pointer;transition:background var(--t),transform var(--t);text-decoration:none}
.btn-primary:hover{background:var(--red-h);border-color:var(--red-h);color:#fff;text-decoration:none;transform:translateY(-1px)}
.btn-outline{display:inline-block;background:transparent;color:var(--text);padding:.875rem 2rem;border-radius:var(--r);font-weight:700;font-size:.875rem;letter-spacing:.05em;text-transform:uppercase;border:2px solid var(--border);cursor:pointer;transition:border-color var(--t),color var(--t);text-decoration:none}
.btn-outline:hover{border-color:var(--text);color:var(--text);text-decoration:none}
.btn-full{width:100%;text-align:center}

/* Banner */
.banner{background:var(--red);color:#fff;text-align:center;padding:.625rem 3rem;font-size:.875rem;font-weight:600;position:relative;z-index:100}
.banner__close{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1}
.banner__close:hover{opacity:.8}

/* Navigation */
.nav{position:sticky;top:0;background:rgba(10,10,10,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);z-index:90}
.nav__inner{display:flex;align-items:center;gap:2rem;height:64px}
.nav__logo img{height:36px;width:auto;display:block}
.nav__links{display:flex;gap:1.5rem;flex:1}
.nav__links a{color:var(--dim);font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;transition:color var(--t);text-decoration:none}
.nav__links a:hover{color:var(--text)}
.nav__cta{margin-left:auto}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;margin-left:auto}
.nav__burger span{display:block;width:24px;height:2px;background:var(--text);transition:transform var(--t),opacity var(--t)}

@media(max-width:900px){
  .nav__links{display:none;position:absolute;top:64px;left:0;right:0;background:var(--bg2);flex-direction:column;padding:1rem 1.5rem;gap:0;border-bottom:1px solid var(--border)}
  .nav__links.open{display:flex}
  .nav__links a{padding:.75rem 0;border-bottom:1px solid var(--border)}
  .nav__cta{display:none}
  .nav__burger{display:flex}
}

/* Hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;padding-bottom:5rem;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center top;background-repeat:no-repeat}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.5) 50%,rgba(0,0,0,.2) 100%)}
.hero__content{position:relative;z-index:1;max-width:800px}
.hero__label{color:var(--red);margin-bottom:1rem}
.hero__headline{color:#fff;margin-bottom:1.5rem}
.hero__sub{font-size:1.125rem;color:rgba(255,255,255,.8);max-width:540px;margin-bottom:2rem}
.hero__ctas{display:flex;gap:1rem;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:-3rem;right:0;background:none;border:none;color:rgba(255,255,255,.5);cursor:pointer;padding:.5rem;transition:color var(--t)}
.hero__scroll:hover{color:#fff}

/* Stats */
.stats{background:var(--bg2)}
.stats h2{margin-bottom:2.5rem}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:2rem}
.stats__card{background:var(--surface);padding:2rem 1.5rem}
.stats__card--highlight{background:var(--bg3)}
.stats__number{font-size:clamp(2rem,4vw,3rem);margin-bottom:.25rem}
.stats__label{font-weight:700;font-size:.875rem}
.stats__sub{color:var(--dim);font-size:.75rem}
.progress-bar-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;margin-bottom:2rem}
.progress-bar-header{display:flex;justify-content:space-between;font-weight:700;margin-bottom:.25rem}
.progress-bar-sub{color:var(--dim);font-size:.875rem;margin-bottom:1rem}
.progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:.75rem}
.progress-bar__fill{height:100%;background:var(--red);border-radius:4px;transition:width 1.5s ease}
.progress-bar-footer{display:flex;justify-content:space-between;font-size:.75rem;color:var(--dim)}
.stats__cta-text{margin-bottom:1rem;font-size:1.125rem}

@media(max-width:768px){.stats__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.stats__grid{grid-template-columns:1fr}}

/* About */
.about__inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.about__badge{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--red);color:#fff;width:80px;height:80px;border-radius:50%;font-size:1.5rem;line-height:1;margin-bottom:1.5rem;text-align:center;font-family:var(--font-d);font-weight:900}
.about__badge-sub{font-size:.6rem;font-family:var(--font-b);text-transform:uppercase;letter-spacing:.1em}
.about h2{margin-bottom:1.5rem}
.about__img{width:100%;border-radius:var(--r);display:block}
.about__img--1{margin-bottom:1rem}
.about__img--2{width:70%;margin-left:auto}

@media(max-width:768px){
  .about__inner{grid-template-columns:1fr}
  .about__images{order:-1}
  .about__img--2{width:60%}
}

/* Genossenschaft */
.geno{background:var(--bg2)}
.geno__intro{font-size:1.125rem;max-width:640px;margin-bottom:3rem}
.geno__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:3rem}
.geno__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem}
.geno__icon{width:48px;height:48px;background:rgba(192,57,43,.15);border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--red)}
.geno__konkret{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2rem}
.geno__konkret h3{margin-bottom:1rem}
.geno__konkret ul{list-style:none}
.geno__konkret li{padding:.5rem 0 .5rem 1.5rem;border-bottom:1px solid var(--border);position:relative}
.geno__konkret li::before{content:'✓';position:absolute;left:0;color:var(--red);font-weight:700}
.geno__konkret li:last-child{border-bottom:none}

@media(max-width:900px){.geno__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.geno__grid{grid-template-columns:1fr}}

/* Anteil */
.anteil{background:var(--bg3)}
.anteil__inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.anteil__text h2{margin-bottom:1.5rem}
.anteil__hinweis{color:var(--dim);font-size:.875rem}
.anteil__direkt{margin:1.5rem 0}
.anteil__mail{display:inline-block;color:var(--red);font-weight:600;font-size:1rem;margin-top:.25rem}
.anteil__info-text{color:var(--dim);font-size:.875rem;margin-top:1rem}
.form{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2rem}
.form__group{margin-bottom:1.25rem}
.form__group label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}
.form__group input,.form__group select,.form__group textarea{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);color:var(--text);padding:.75rem 1rem;font-family:var(--font-b);font-size:1rem;transition:border-color var(--t)}
.form__group input:focus,.form__group select:focus,.form__group textarea:focus{border-color:var(--red);outline:none}
.form__group select{appearance:none;cursor:pointer}
.form__group textarea{resize:vertical;min-height:100px}
.form__group--check{display:flex;gap:.75rem;align-items:flex-start}
.form__group--check input[type="checkbox"]{width:18px;height:18px;flex-shrink:0;margin-top:2px;accent-color:var(--red)}
.form__group--check label{font-size:.8rem;text-transform:none;letter-spacing:0;font-weight:400}
.form__feedback{margin-top:1rem;font-size:.875rem;min-height:1.5rem}
.form__feedback.success{color:#27ae60}
.form__feedback.error{color:var(--red)}

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

/* Vorbeikommen */
.vorbei{background:var(--bg2)}
.vorbei__intro{font-size:1.125rem;max-width:640px;margin-bottom:3rem}
.vorbei__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3rem}
.vorbei__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2rem}
.vorbei__card h3{margin-bottom:1rem}
.oeffnungszeiten{display:grid;grid-template-columns:auto 1fr;gap:.25rem 1rem;margin-bottom:1rem}
.oeffnungszeiten dt{color:var(--dim);font-size:.875rem}
.oeffnungszeiten dd{font-weight:600;font-size:.875rem}
.vorbei__hinweis{color:var(--dim);font-size:.8rem;margin-top:.5rem}
.vorbei__card--event{border-color:var(--red)}
.event-badge{display:inline-block;background:var(--red);color:#fff;padding:.2rem .6rem;border-radius:var(--r);font-size:.65rem;margin-bottom:.75rem;font-family:var(--font-b);font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.event-item{margin-bottom:1rem}
.event-title{display:block;font-size:1.125rem;font-family:var(--font-d);font-weight:700;margin-bottom:.25rem}
.event-meta{display:block;color:var(--dim);font-size:.8rem}
.vorbei__cta-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.vorbei__cta-btns{display:flex;gap:1rem;flex-shrink:0}

@media(max-width:900px){
  .vorbei__grid{grid-template-columns:1fr}
  .vorbei__cta-row{flex-direction:column}
}

/* Mitmachen */
.mitmachen{background:var(--bg)}
.mitmachen__intro{font-size:1.125rem;max-width:640px;margin-bottom:3rem}
.mitmachen__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:3rem}
.mitmachen__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem}
.mitmachen__badge{display:inline-block;background:var(--red);color:#fff;padding:.15rem .5rem;border-radius:var(--r);font-size:.65rem;margin-bottom:.75rem;font-family:var(--font-b);font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.mitmachen__cta{text-align:center}
.mitmachen__cta p{margin-bottom:1rem;font-size:1.125rem}
.mitmachen__kein-geld{color:var(--dim);margin-top:1rem;display:block}

@media(max-width:900px){.mitmachen__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.mitmachen__grid{grid-template-columns:1fr}}

/* Teilen */
.teilen{background:var(--bg2);text-align:center}
.teilen h2{margin-bottom:1rem}
.teilen p{max-width:600px;margin:0 auto 2rem}
.teilen__btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-share{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--r);font-weight:700;font-size:.875rem;cursor:pointer;border:none;text-decoration:none;transition:opacity var(--t)}
.btn-share:hover{opacity:.85;text-decoration:none}
.btn-share--wa{background:#25D366;color:#fff}
.btn-share--fb{background:#1877F2;color:#fff}
.btn-share--copy{background:var(--surface);color:var(--text);border:1px solid var(--border)}

/* Kontakt */
.kontakt{background:var(--bg)}
.kontakt h2{margin-bottom:1.5rem}
.kontakt__info{display:flex;flex-direction:column;gap:1.5rem;max-width:640px}
.kontakt__item{display:flex;flex-direction:column;gap:.25rem}
.kontakt__label{color:var(--dim)}
.kontakt__value{font-size:1.125rem;font-weight:600;color:var(--text)}
a.kontakt__value{color:var(--red)}
a.kontakt__value:hover{color:var(--red-h)}
.kontakt__quote{font-size:clamp(1.25rem,3vw,2rem);color:var(--text);font-style:normal;border-left:4px solid var(--red);padding-left:1.5rem;margin:1.5rem 0}
.kontakt__ctas{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}

/* Footer */
.footer{background:#000;border-top:1px solid var(--border);padding:2.5rem 0;text-align:center}
.footer__copy{font-size:.875rem;color:var(--dim);margin-bottom:.5rem}
.footer__disclaimer{font-size:.75rem;color:var(--dim);margin-bottom:1rem}
.footer__nav{display:flex;gap:1.5rem;justify-content:center;margin-bottom:1rem}
.footer__nav a{color:var(--dim);font-size:.875rem}
.footer__nav a:hover{color:var(--text)}
.footer__credit{font-size:.75rem;color:var(--dim)}
.footer__credit a{color:var(--dim)}
.footer__credit a:hover{color:var(--text)}

/* Unterseiten */
.page-header{background:var(--bg2);padding:4rem 0 3rem;border-bottom:1px solid var(--border)}
.page-header h1{font-size:clamp(2rem,5vw,3rem)}
.page-content{padding:4rem 0;max-width:800px}
.page-content h2{font-size:1.5rem;margin:2.5rem 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.page-content h3{font-size:1.125rem;margin:1.5rem 0 .5rem}
.page-content p{margin-bottom:1rem}
.page-content ul,.page-content ol{padding-left:1.5rem;margin-bottom:1rem}
.page-content li{margin-bottom:.5rem}
.page-content a{color:var(--red)}
.page-back{display:inline-flex;align-items:center;gap:.5rem;color:var(--dim);font-size:.875rem;margin-bottom:2rem;text-decoration:none}
.page-back:hover{color:var(--text)}
