/* ═══════════════════════════════════════════════════
   FAHRSCHULE SCHMITT & SCHWAN · DESIGN SYSTEM
   Concept: Asphalt × Signal · Editorial × Automotive
   ═══════════════════════════════════════════════════ */

:root{
  /* Colors */
  --ink:#0A0E1A;          /* Asphalt / night sky */
  --ink2:#131826;         /* Slightly lifted */
  --ink3:#1F2937;         /* Line color */
  --paper:#FAFAF7;        /* Warm off-white */
  --paper2:#F2F1EC;       /* Cream surface */
  --paper3:#E8E7E0;       /* Border on light */
  --signal:#FCD116;       /* Traffic-sign yellow — the signature */
  --signal-dk:#E6BC00;
  --signal-glow:rgba(252,209,22,.25);
  --red:#DC2626;
  --green:#059669;
  --mute:#6B7280;
  --mute-dk:rgba(255,255,255,.55);

  /* Type */
  --display:'Anton',Impact,sans-serif;
  --body:'Figtree',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',Consolas,monospace;

  /* Layout */
  --max:1280px;
  --pad:28px;
  --pad-sm:20px;
  --gap:24px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-size:16px;
}

/* Subtle grain texture */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  opacity:.7;
}

img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}

/* ─── Selection ─── */
::selection{background:var(--signal);color:var(--ink)}

/* ═══════════════════════════════════════════════════
   TOP BAR
   ═══════════════════════════════════════════════════ */
.topbar{
  background:var(--ink);color:var(--paper);
  font-size:.75rem;font-family:var(--mono);letter-spacing:.05em;
  border-bottom:1px solid rgba(255,255,255,.08);
  position:relative;z-index:40;
}
.topbar-inner{
  max-width:var(--max);margin:0 auto;padding:10px var(--pad);
  display:flex;justify-content:space-between;align-items:center;gap:20px;
}
.topbar-left{display:flex;gap:24px;flex-wrap:wrap;color:rgba(255,255,255,.7)}
.topbar-left a{color:var(--paper);transition:color .2s}
.topbar-left a:hover{color:var(--signal)}
.topbar-left .tb-icon{display:inline-block;margin-right:6px;color:var(--signal)}
.topbar-right{display:flex;gap:14px;align-items:center}
.topbar-right a{
  color:rgba(255,255,255,.55);transition:color .2s;
  width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;
}
.topbar-right a:hover{color:var(--signal)}

@media(max-width:720px){
  .topbar-left{font-size:.7rem;gap:14px}
  .topbar-right{display:none}
}

/* ═══════════════════════════════════════════════════
   HEADER / NAV
   ═══════════════════════════════════════════════════ */
header.site{
  background:var(--paper);
  position:sticky;top:0;z-index:30;
  border-bottom:1px solid var(--paper3);
  transition:box-shadow .3s;
}
header.site.scrolled{box-shadow:0 2px 24px -12px rgba(10,14,26,.15)}
.hdr{
  max-width:var(--max);margin:0 auto;padding:18px var(--pad);
  display:flex;justify-content:space-between;align-items:center;gap:20px;
}
.logo{
  display:flex;align-items:center;gap:14px;
  font-family:var(--display);text-transform:uppercase;
  font-size:1.55rem;letter-spacing:.02em;line-height:1;
  position:relative;
}
.logo-mark{
  width:42px;height:42px;
  background:var(--ink);color:var(--signal);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:1.6rem;
  position:relative;flex-shrink:0;
}
.logo-mark::after{
  content:'';position:absolute;inset:3px;border:1px solid var(--signal);
}
.logo-text small{
  display:block;font-family:var(--mono);font-size:.55rem;
  letter-spacing:.2em;color:var(--mute);margin-top:2px;font-weight:400;
  text-transform:uppercase;
}

nav.main{display:flex;align-items:center;gap:4px}
nav.main a{
  padding:12px 18px;font-size:.85rem;font-weight:500;
  letter-spacing:.02em;color:var(--ink);
  position:relative;transition:color .2s;
}
nav.main a:hover,nav.main a.active{color:var(--ink)}
nav.main a::after{
  content:'';position:absolute;left:18px;right:18px;bottom:4px;
  height:2px;background:var(--signal);
  transform:scaleX(0);transform-origin:center;transition:transform .25s;
}
nav.main a:hover::after,nav.main a.active::after{transform:scaleX(1)}

.hdr-cta{
  padding:13px 22px;background:var(--ink);color:var(--paper);
  font-family:var(--body);font-weight:600;font-size:.82rem;
  letter-spacing:.1em;text-transform:uppercase;
  transition:all .2s;position:relative;overflow:hidden;
}
.hdr-cta:hover{background:var(--signal);color:var(--ink)}

.burger{display:none;width:40px;height:40px;position:relative}
.burger span{
  position:absolute;left:8px;right:8px;height:2px;background:var(--ink);
  transition:.3s;
}
.burger span:nth-child(1){top:13px}
.burger span:nth-child(2){top:19px}
.burger span:nth-child(3){top:25px}
.burger.open span:nth-child(1){top:19px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:19px;transform:rotate(-45deg)}

@media(max-width:960px){
  nav.main,.hdr-cta{display:none}
  .burger{display:block}
  nav.main.open{
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    position:fixed;top:72px;left:0;right:0;bottom:0;
    background:var(--ink);padding:32px var(--pad);z-index:29;
  }
  nav.main.open a{color:var(--paper);font-size:1.4rem;font-family:var(--display);text-transform:uppercase;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08)}
  nav.main.open a::after{display:none}
  nav.main.open .hdr-cta{display:block;margin-top:24px;text-align:center}
}

/* ═══════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════ */
.hero{
  background:var(--ink);color:var(--paper);
  padding:90px var(--pad) 100px;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 15% 30%, rgba(252,209,22,.12) 0%, transparent 50%),
    radial-gradient(ellipse 50% 60% at 85% 70%, rgba(252,209,22,.06) 0%, transparent 50%);
}
.hero::after{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, black 40%, transparent 80%);
}
.hero-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:2}

.hero-label{
  display:inline-flex;align-items:center;gap:12px;
  padding:8px 18px;background:rgba(252,209,22,.08);
  border:1px solid rgba(252,209,22,.25);
  color:var(--signal);
  font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;
  text-transform:uppercase;margin-bottom:32px;
}
.hero-label .dot{width:6px;height:6px;background:var(--signal);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 var(--signal-glow)}50%{opacity:.6;box-shadow:0 0 0 8px transparent}}

.hero h1{
  font-family:var(--display);font-weight:400;
  font-size:clamp(3rem,9vw,7.5rem);
  line-height:.9;letter-spacing:-.01em;text-transform:uppercase;
  margin-bottom:36px;
}
.hero h1 .highlight{color:var(--signal);position:relative;display:inline-block}
.hero h1 .slash{
  display:inline-block;color:var(--signal);margin:0 .1em;
  transform:skewX(-12deg);
}

.hero-sub{
  font-size:clamp(1.05rem,1.5vw,1.3rem);
  color:rgba(255,255,255,.75);max-width:640px;
  line-height:1.65;margin-bottom:48px;
}
.hero-sub strong{color:var(--paper);font-weight:600}

.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:64px}
.btn-primary{
  padding:18px 32px;background:var(--signal);color:var(--ink);
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.82rem;
  transition:all .25s;position:relative;overflow:hidden;
}
.btn-primary:hover{background:var(--paper);transform:translateY(-2px)}
.btn-primary .arrow{display:inline-block;margin-left:10px;transition:transform .2s}
.btn-primary:hover .arrow{transform:translateX(4px)}

.btn-ghost{
  padding:17px 30px;background:transparent;color:var(--paper);
  border:1px solid rgba(255,255,255,.25);
  font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.82rem;
  transition:all .25s;
}
.btn-ghost:hover{border-color:var(--signal);color:var(--signal)}

.hero-stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:1px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
  max-width:920px;
}
.stat{background:var(--ink);padding:22px 26px;position:relative}
.stat-label{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.15em;
  text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:8px;
}
.stat-value{font-family:var(--display);font-size:1.8rem;color:var(--paper);line-height:1}
.stat-value .unit{font-size:.9rem;margin-left:4px;color:rgba(255,255,255,.5);font-family:var(--body);font-weight:400}

/* Scroll hint */
.scroll-hint{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:.65rem;letter-spacing:.25em;
  text-transform:uppercase;color:rgba(255,255,255,.35);
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.scroll-hint::after{
  content:'';width:1px;height:40px;background:rgba(255,255,255,.2);
  animation:line 2s ease-in-out infinite;transform-origin:top;
}
@keyframes line{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}

@media(max-width:720px){
  .hero{padding:60px var(--pad-sm) 70px}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .btn-primary,.btn-ghost{text-align:center}
}

/* ═══════════════════════════════════════════════════
   MARQUEE STRIP (between hero and sections)
   ═══════════════════════════════════════════════════ */
.marquee{
  background:var(--signal);color:var(--ink);
  padding:20px 0;overflow:hidden;
  border-top:1px solid var(--signal-dk);
  border-bottom:1px solid var(--signal-dk);
  position:relative;z-index:2;
}
.marquee-track{
  display:flex;gap:48px;white-space:nowrap;
  animation:scroll 40s linear infinite;
  font-family:var(--display);font-size:1.5rem;letter-spacing:.02em;
  text-transform:uppercase;
}
.marquee-track span{display:inline-flex;align-items:center;gap:48px}
.marquee-track span::after{
  content:'✦';color:var(--ink);
}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════════════════
   SECTIONS
   ═══════════════════════════════════════════════════ */
section.sec{padding:100px var(--pad)}
section.sec.dark{background:var(--ink);color:var(--paper)}
section.sec.cream{background:var(--paper2)}

.sec-inner{max-width:var(--max);margin:0 auto}

.sec-head{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  align-items:end;margin-bottom:60px;
}
@media(max-width:720px){.sec-head{grid-template-columns:1fr;gap:24px}}

.sec-tag{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.25em;
  text-transform:uppercase;color:var(--mute);margin-bottom:18px;
}
.sec.dark .sec-tag{color:rgba(255,255,255,.5)}
.sec-tag::before{
  content:'';display:inline-block;width:28px;height:1px;background:var(--ink);
}
.sec.dark .sec-tag::before{background:var(--signal)}

.sec-h{
  font-family:var(--display);font-weight:400;
  font-size:clamp(2.2rem,5vw,4rem);line-height:.95;
  letter-spacing:-.01em;text-transform:uppercase;
}
.sec-h em{font-style:normal;color:var(--signal)}

.sec-intro{
  font-size:1.05rem;line-height:1.7;color:var(--mute);
  max-width:520px;
}
.sec.dark .sec-intro{color:rgba(255,255,255,.65)}

/* ═══════════════════════════════════════════════════
   VALUE PROPS
   ═══════════════════════════════════════════════════ */
.vp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;background:var(--paper3);border:1px solid var(--paper3)}
.vp{
  background:var(--paper);padding:40px 32px;position:relative;
  transition:background .3s;
}
.vp:hover{background:var(--paper2)}
.vp-num{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;
  color:var(--mute);margin-bottom:28px;
}
.vp-icon{
  width:56px;height:56px;margin-bottom:24px;
  background:var(--ink);color:var(--signal);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:1.8rem;
}
.vp h3{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:1.4rem;line-height:1.05;margin-bottom:12px;
}
.vp p{font-size:.92rem;color:var(--mute);line-height:1.65}

/* ═══════════════════════════════════════════════════
   CLASSES (Führerscheinklassen)
   ═══════════════════════════════════════════════════ */
.classes{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.class-card{
  background:var(--ink2);color:var(--paper);padding:36px 32px;
  position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  transition:transform .3s, border-color .3s;
  display:flex;flex-direction:column;gap:16px;
  min-height:280px;
}
.class-card:hover{border-color:var(--signal);transform:translateY(-4px)}
.class-card::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:200px;height:200px;background:var(--signal);opacity:.04;
  border-radius:50%;transition:all .4s;
}
.class-card:hover::before{opacity:.1;transform:scale(1.2)}
.class-badge{
  display:inline-block;padding:6px 14px;background:var(--signal);color:var(--ink);
  font-family:var(--display);font-size:1.3rem;letter-spacing:.04em;
  width:fit-content;position:relative;z-index:2;
}
.class-card h3{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:1.3rem;line-height:1.1;position:relative;z-index:2;
}
.class-card p{color:rgba(255,255,255,.7);font-size:.88rem;line-height:1.6;position:relative;z-index:2;flex-grow:1}
.class-meta{
  display:flex;gap:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);
  font-family:var(--mono);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.5);position:relative;z-index:2;
}
.class-meta strong{color:var(--signal);font-weight:400}

/* ═══════════════════════════════════════════════════
   LOCATIONS
   ═══════════════════════════════════════════════════ */
.locs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.loc{
  background:var(--paper);padding:32px 28px;
  border:1px solid var(--paper3);
  position:relative;transition:all .25s;
}
.loc:hover{border-color:var(--ink);box-shadow:0 20px 40px -20px rgba(10,14,26,.15);transform:translateY(-2px)}
.loc-tag{
  position:absolute;top:-1px;right:24px;
  padding:6px 14px;background:var(--signal);color:var(--ink);
  font-family:var(--mono);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;
  font-weight:600;
}
.loc h3{
  font-family:var(--display);font-weight:400;font-size:1.8rem;
  text-transform:uppercase;line-height:1;margin-bottom:8px;
  padding-right:80px;
}
.loc-addr{font-size:.88rem;color:var(--mute);margin-bottom:20px;line-height:1.5}
.loc-info{display:flex;flex-direction:column;gap:8px;font-size:.88rem}
.loc-info-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:8px 0;border-bottom:1px dashed var(--paper3)}
.loc-info-row:last-child{border-bottom:none}
.loc-info-label{font-family:var(--mono);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--mute)}
.loc-info-val{font-weight:500;color:var(--ink);text-align:right}
.loc-info-val a{color:var(--ink);border-bottom:1px solid var(--signal);transition:color .2s}
.loc-info-val a:hover{color:var(--signal-dk)}

/* ═══════════════════════════════════════════════════
   TEAM
   ═══════════════════════════════════════════════════ */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.member{
  position:relative;overflow:hidden;
  aspect-ratio:3/4;background:var(--ink2);
  transition:transform .4s;
}
.member:hover{transform:translateY(-4px)}
.member img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(100%) contrast(1.05);
  transition:all .5s;
}
.member:hover img{filter:grayscale(0%) contrast(1.05)}
.member-overlay{
  position:absolute;left:0;right:0;bottom:0;
  padding:24px 22px 22px;
  background:linear-gradient(to top, rgba(10,14,26,.95) 0%, rgba(10,14,26,.6) 60%, transparent 100%);
  color:var(--paper);
}
.member-name{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:1.5rem;line-height:1;margin-bottom:4px;
}
.member-role{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--signal);
}

/* Placeholder (no real photo) */
.member.placeholder{
  background:var(--ink2);display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.15);font-family:var(--display);font-size:4rem;
}
.member.placeholder .member-overlay{background:linear-gradient(to top, rgba(10,14,26,.95) 0%, rgba(10,14,26,.4) 80%)}

/* ═══════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════ */
.faqs{max-width:880px;margin:0 auto;display:flex;flex-direction:column}
.faq{
  border-bottom:1px solid var(--paper3);
  padding:4px 0;
}
.sec.dark .faq{border-color:rgba(255,255,255,.08)}
.faq-q{
  width:100%;text-align:left;padding:24px 48px 24px 0;
  font-family:var(--display);font-weight:400;font-size:1.35rem;
  letter-spacing:.01em;line-height:1.2;text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  transition:color .2s;
}
.faq-q:hover{color:var(--signal-dk)}
.sec.dark .faq-q{color:var(--paper)}
.sec.dark .faq-q:hover{color:var(--signal)}
.faq-plus{
  flex-shrink:0;width:32px;height:32px;
  border:1px solid var(--ink3);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--body);font-size:1.2rem;transition:all .3s;
}
.sec.dark .faq-plus{border-color:rgba(255,255,255,.2)}
.faq.open .faq-plus{background:var(--signal);border-color:var(--signal);color:var(--ink);transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .4s ease;
}
.faq.open .faq-a{max-height:500px}
.faq-a-inner{padding:0 48px 28px 0;color:var(--mute);line-height:1.7;font-size:1rem}
.sec.dark .faq-a-inner{color:rgba(255,255,255,.7)}

/* ═══════════════════════════════════════════════════
   BIG CTA BAND
   ═══════════════════════════════════════════════════ */
.cta-band{
  background:var(--signal);color:var(--ink);
  padding:80px var(--pad);position:relative;overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;right:-80px;top:-80px;
  font-family:var(--display);font-size:30rem;line-height:1;
  color:rgba(10,14,26,.04);
  content:'GO';
}
.cta-inner{
  max-width:var(--max);margin:0 auto;position:relative;z-index:2;
  display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;
}
@media(max-width:720px){.cta-inner{grid-template-columns:1fr;text-align:left}}
.cta-band h2{
  font-family:var(--display);font-weight:400;font-size:clamp(2.4rem,5vw,4.5rem);
  line-height:.9;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:16px;
}
.cta-band p{font-size:1.1rem;line-height:1.6;max-width:520px}
.cta-actions{display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.cta-actions .btn-primary{
  background:var(--ink);color:var(--paper);font-size:.9rem;padding:22px 36px;
}
.cta-actions .btn-primary:hover{background:var(--paper);color:var(--ink)}
.cta-phone{
  font-family:var(--display);font-size:2.2rem;line-height:1;
  color:var(--ink);text-decoration:none;border-bottom:3px solid var(--ink);padding-bottom:4px;
}

/* ═══════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════ */
footer.site{background:var(--ink);color:var(--paper);padding:80px var(--pad) 32px;position:relative}
footer.site::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--signal)}
.foot-inner{max-width:var(--max);margin:0 auto}
.foot-top{
  display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);
}
@media(max-width:860px){.foot-top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:520px){.foot-top{grid-template-columns:1fr}}
.foot-brand{
  font-family:var(--display);font-size:2rem;text-transform:uppercase;
  letter-spacing:.02em;line-height:1;margin-bottom:16px;
}
.foot-brand span{color:var(--signal)}
.foot-desc{color:rgba(255,255,255,.55);font-size:.9rem;line-height:1.6;max-width:280px;margin-bottom:20px}
.foot-col h4{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--signal);margin-bottom:20px;
}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{color:rgba(255,255,255,.65);font-size:.9rem;transition:color .2s}
.foot-col a:hover{color:var(--signal)}
.foot-bot{
  padding-top:28px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;color:rgba(255,255,255,.4);
}
.foot-bot a{color:rgba(255,255,255,.55);transition:color .2s}
.foot-bot a:hover{color:var(--signal)}
.foot-credit{
  text-align:center;padding-top:20px;margin-top:20px;
  border-top:1px solid rgba(255,255,255,.05);
  font-family:var(--mono);font-size:.62rem;letter-spacing:.15em;
  color:rgba(255,255,255,.3);
}
.foot-credit a{color:rgba(255,255,255,.45);transition:color .2s}
.foot-credit a:hover{color:var(--signal)}

/* ═══════════════════════════════════════════════════
   REVEAL ANIMATION
   ═══════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════════════════
   PAGE HEADER (for sub-pages)
   ═══════════════════════════════════════════════════ */
.page-hero{
  background:var(--ink);color:var(--paper);
  padding:70px var(--pad) 80px;
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 20% 50%, rgba(252,209,22,.08) 0%, transparent 60%);
}
.page-hero-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:2}
.page-crumbs{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:20px;
}
.page-crumbs a{color:var(--signal)}
.page-hero h1{
  font-family:var(--display);font-weight:400;
  font-size:clamp(2.5rem,6vw,5rem);line-height:.95;
  text-transform:uppercase;letter-spacing:-.01em;margin-bottom:16px;
}
.page-hero h1 em{font-style:normal;color:var(--signal)}
.page-hero-sub{font-size:1.1rem;color:rgba(255,255,255,.7);max-width:640px;line-height:1.6}

/* ═══════════════════════════════════════════════════
   PROSE (Impressum, Datenschutz etc.)
   ═══════════════════════════════════════════════════ */
.prose{max-width:780px;margin:0 auto;padding:80px var(--pad) 100px}
.prose h2{font-family:var(--display);font-weight:400;font-size:2rem;text-transform:uppercase;letter-spacing:-.01em;line-height:1.1;margin:48px 0 18px;color:var(--ink)}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:var(--display);font-weight:400;font-size:1.25rem;text-transform:uppercase;margin:32px 0 12px;color:var(--ink)}
.prose p{margin-bottom:18px;color:var(--ink3);line-height:1.75;font-size:1rem}
.prose ul,.prose ol{margin:0 0 18px 24px;color:var(--ink3)}
.prose li{margin-bottom:8px;line-height:1.7}
.prose a{color:var(--ink);border-bottom:1px solid var(--signal);transition:color .2s}
.prose a:hover{color:var(--signal-dk)}
.prose strong{color:var(--ink);font-weight:600}
.prose hr{border:none;border-top:1px solid var(--paper3);margin:40px 0}
