/* ===== Fahrschule Deisinger · Frisch & Hell ===== */
:root{
  --bg:#f9fbf6;            /* frisches Off-White */
  --tint:#edf6e5;          /* heller Grün-Hauch */
  --card:#ffffff;
  --ink:#1a2b1e;
  --ink-soft:#4d6352;
  --ink-dim:#7d917f;
  --green:#3aa424;         /* Brand-Grün, satt (aus Logo abgeleitet) */
  --green-bright:#60d830;  /* Original-Logo-Neon für Flächen-Akzente */
  --green-dark:#1c5a12;
  --green-tint:rgba(96,216,48,.14);
  --red:#d04a3a;           /* Logo-Rot fürs Wordmark */
  --line:rgba(26,43,30,.1);
  --shadow:0 14px 38px -18px rgba(26,43,30,.22);
  --shadow-sm:0 6px 18px -10px rgba(26,43,30,.18);
  --r:20px;
  --maxw:1180px;
  --disp:'Bricolage Grotesque',sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --mono:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);background:var(--bg);color:var(--ink);line-height:1.65;font-size:16.5px;overflow-x:hidden}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px;width:100%}
img{display:block;max-width:100%}
h1,h2,h3{font-family:var(--disp);font-weight:800;line-height:1.06;letter-spacing:-.015em;color:var(--ink)}
section h2{font-size:clamp(2rem,5vw,3.3rem);margin-bottom:.55em}
.neon{color:var(--green)}
.strike{position:relative;color:var(--ink-dim)}
.strike::after{content:"";position:absolute;left:-4%;right:-4%;top:52%;height:4px;background:var(--green-bright);transform:rotate(-4deg);border-radius:2px}
.hud-chip{font-family:var(--body);font-weight:700;font-size:.74rem;letter-spacing:.16em;color:var(--green);margin-bottom:1.1rem;text-transform:uppercase}
section{padding:clamp(3.6rem,7vw,6.5rem) 0;position:relative}

/* Reveal (nur mit JS aktiv, sonst alles sichtbar) */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease}
.js .reveal.on{opacity:1;transform:none}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--disp);font-weight:700;font-size:.98rem;line-height:1;
  padding:.95rem 1.6rem;border-radius:999px;text-decoration:none;cursor:pointer;border:2px solid transparent;
  transition:.18s ease;white-space:nowrap}
.btn-lg{padding:1.15rem 2rem;font-size:1.05rem}
.btn-block{width:100%}
.btn-neon{background:var(--green);color:#fff;box-shadow:var(--shadow-sm)}
.btn-neon:hover{background:var(--green-dark);transform:translateY(-2px)}
.btn-out{background:rgba(255,255,255,.85);color:var(--ink);border-color:var(--ink)}
.btn-out:hover{background:var(--ink);color:#fff}
.btn-wa{background:#22b558;color:#fff}
.btn-wa:hover{background:#1a9a49;transform:translateY(-2px)}

/* Preview-Bar */
.preview-bar{background:var(--green-dark);color:#eaf6e2;text-align:center;font-size:.78rem;padding:.5rem 1rem}
.preview-bar strong{color:var(--green-bright)}
.pdot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--green-bright);margin-right:.5rem;vertical-align:middle;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* Header */
.hd{position:sticky;top:0;z-index:50;background:rgba(249,251,246,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.hd-in{display:flex;align-items:center;gap:1.4rem;padding-top:.6rem;padding-bottom:.6rem}
.brand{display:flex;flex-direction:column;text-decoration:none;line-height:1;gap:2px}
.brand-script{font-family:'Caveat',cursive;font-weight:700;font-size:1.05rem;color:var(--red);letter-spacing:.02em}
.brand-word{font-family:var(--disp);font-weight:800;font-size:1.45rem;color:var(--green);text-transform:uppercase;letter-spacing:.04em}
.brand-inh{font-size:.6rem;font-weight:600;color:var(--ink-dim);letter-spacing:.16em;text-transform:uppercase}
.nav{margin-left:auto;display:flex;gap:1.5rem}
.nav a{color:var(--ink-soft);text-decoration:none;font-size:.94rem;font-weight:600;transition:.15s}
.nav a:hover{color:var(--green)}
.hd-wa{font-size:.85rem;padding:.7rem 1.15rem}
.burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:none;border:0;cursor:pointer;min-width:44px;min-height:44px}
.burger span{width:24px;height:2px;background:var(--green);border-radius:2px}

/* Hero */
.hero{padding:clamp(10rem,24vw,15rem) 0 0;overflow:hidden;position:relative}
.hero-img,.hero-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-img img{object-position:center 26%}
.hero-img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,32,16,.16) 0%,rgba(249,251,246,0) 30%,rgba(249,251,246,.72) 62%,var(--bg) 96%)}
.hero-in{position:relative;z-index:2}
.hero h1{font-size:clamp(3rem,9vw,5.8rem);margin-bottom:1rem}
.hero-sub{max-width:54ch;color:var(--ink-soft);font-size:clamp(1.05rem,2vw,1.22rem);margin-bottom:1.9rem}
.hero-sub strong{color:var(--ink)}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2.4rem}
.hero-stats{display:flex;gap:2.8rem;flex-wrap:wrap;padding-bottom:2.6rem}
.stat{display:flex;flex-direction:column;gap:.15rem}
.stat-wrap{display:flex;align-items:baseline}
.stat-n,.stat-plus{font-family:var(--disp);font-weight:800;font-size:2.2rem;color:var(--green)}
.stat-l{font-size:.84rem;color:var(--ink-soft);max-width:16ch;font-weight:500}

/* Straßenlinie (verspieltes Detail) */
.road{height:34px;background:var(--bg);display:flex;align-items:center}
.road-line{width:100%;height:4px;
  background-image:linear-gradient(90deg,var(--green-bright) 0 42px,transparent 42px 84px);
  background-size:84px 4px;animation:roadmove 1.1s linear infinite;opacity:.7;border-radius:2px}
@keyframes roadmove{to{background-position:-84px 0}}

/* Marquee */
.marquee-clip{overflow:hidden;margin:.4rem 0 1rem}
.marquee{overflow:hidden;background:var(--green-bright);padding:.66rem 0;transform:rotate(-1.2deg) scale(1.04)}
.marquee-track{display:flex;width:max-content;animation:marq 26s linear infinite}
.marquee-track span{font-family:var(--disp);font-weight:800;font-size:.95rem;letter-spacing:.12em;color:#11380a;white-space:nowrap}
@keyframes marq{to{transform:translateX(-50%)}}

/* Klassen */
.classes{background:var(--bg)}
.cls-tabs{display:flex;gap:.6rem;flex-wrap:wrap;margin:1.8rem 0 1.4rem}
.cls-tab{font-family:var(--disp);font-weight:700;font-size:.98rem;
  background:var(--card);color:var(--ink-soft);border:2px solid var(--line);
  border-radius:999px;padding:.8rem 1.3rem;cursor:pointer;transition:.18s;min-height:44px;box-shadow:var(--shadow-sm)}
.cls-tab:hover{border-color:var(--green);color:var(--ink)}
.cls-tab.active{background:var(--green);color:#fff;border-color:var(--green)}
.cls-panels{position:relative}
.cls-panel{display:none;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;animation:fadein .35s ease;box-shadow:var(--shadow)}
.cls-panel.active{display:grid;grid-template-columns:1fr 1.15fr;align-items:stretch}
.cls-panel.no-img.active{display:block}
.cls-img{min-height:260px}
.cls-img img{width:100%;height:100%;object-fit:cover;display:block}
.cls-body{padding:2.1rem 2.2rem}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.cls-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.1rem}
.cls-badges span{font-family:var(--disp);font-weight:700;font-size:.85rem;color:var(--green-dark);
  border-radius:999px;padding:.34rem .8rem;background:var(--green-tint)}
.cls-panel h3{font-size:1.5rem;margin-bottom:.5rem}
.cls-panel p{color:var(--ink-soft);max-width:68ch}
.cls-note{margin-top:1.4rem;font-size:.92rem;color:var(--ink-dim)}

/* Tech */
.tech{background:var(--tint)}
.tech-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:2.2rem}
.tech-card{background:var(--card);border-radius:var(--r);padding:1.8rem 1.6rem;transition:.2s;box-shadow:var(--shadow-sm)}
.tech-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.tc-ico{font-size:2.1rem;display:block;margin-bottom:.9rem}
.tech-card h3{font-size:1.12rem;margin-bottom:.45rem}
.tech-card p{font-size:.92rem;color:var(--ink-soft)}

/* Schule */
.school{background:var(--bg)}
.school-in{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.school-img{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.school-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3.1}
.school-txt p{color:var(--ink-soft);margin-bottom:1rem;max-width:56ch}
.host-row{display:flex;align-items:center;gap:1rem;margin-top:1.7rem}
.host-ava{width:78px;height:78px;border-radius:50%;object-fit:cover;object-position:center 18%;border:3px solid var(--green-bright);flex-shrink:0;box-shadow:var(--shadow-sm)}
.host-name{font-family:var(--disp);font-weight:800;font-size:1.12rem;color:var(--ink);display:block;line-height:1.2}
.host-role{font-size:.86rem;color:var(--ink-dim)}
.quote{border-left:4px solid var(--green-bright);padding:.4rem 0 .4rem 1.2rem;margin-top:1.6rem;background:var(--tint);border-radius:0 14px 14px 0;padding:1rem 1.2rem}
.quote p{font-family:var(--disp);font-weight:700;font-size:1.12rem;color:var(--ink);margin-bottom:.4rem}
.quote-src{font-size:.78rem;font-weight:600;color:var(--ink-dim);letter-spacing:.08em;text-transform:uppercase}

/* Galerie */
.gallery{background:var(--tint)}
.gal-strip{display:flex;gap:1rem;overflow-x:auto;padding:2rem 22px .8rem;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;max-width:calc(var(--maxw) + 44px);margin:0 auto}
.gal-strip::-webkit-scrollbar{height:8px}
.gal-strip::-webkit-scrollbar-thumb{background:var(--green);border-radius:4px}
.gal-strip::-webkit-scrollbar-track{background:rgba(26,43,30,.08)}
.gal-strip figure{flex:0 0 460px;scroll-snap-align:start}
.gal-strip img{width:100%;aspect-ratio:16/9.5;object-fit:cover;border-radius:var(--r);box-shadow:var(--shadow-sm)}
.gal-strip figcaption{font-size:.8rem;font-weight:600;color:var(--ink-soft);margin-top:.6rem}

/* Anmeldung */
.signup{background:linear-gradient(160deg,var(--green) 0%,var(--green-dark) 100%);color:#fff}
.signup .hud-chip{color:var(--green-bright)}
.signup h2{color:#fff}
.signup h2 .neon{color:var(--green-bright)}
.signup-in{display:grid;grid-template-columns:1fr .9fr;gap:3rem;align-items:start}
.signup-txt>p{color:rgba(255,255,255,.88);max-width:46ch}
.signup-facts{list-style:none;margin:1.7rem 0 1.9rem;display:flex;flex-direction:column;border-radius:var(--r);overflow:hidden;background:rgba(255,255,255,.1);backdrop-filter:blur(4px)}
.signup-facts li{display:flex;align-items:center;gap:1.2rem;padding:.9rem 1.2rem;border-bottom:1px solid rgba(255,255,255,.14);font-size:.95rem;color:#fff}
.signup-facts li:last-child{border-bottom:0}
.sf-k{font-size:.7rem;font-weight:700;letter-spacing:.12em;color:var(--green-bright);flex:0 0 96px}
.signup-facts a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.5)}
.signup .btn-wa{background:#fff;color:var(--green-dark)}
.signup .btn-wa:hover{background:var(--green-bright);color:#11380a}
.signup-form{background:var(--card);border-radius:var(--r);padding:2rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem;color:var(--ink)}
.form-title{font-family:var(--disp);font-weight:800;font-size:1.2rem}
.signup-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.74rem;font-weight:700;letter-spacing:.08em;color:var(--ink-soft);text-transform:uppercase}
.signup-form input,.signup-form select{font-family:var(--body);font-size:16px;padding:.85rem .95rem;
  background:var(--bg);border:2px solid var(--line);border-radius:12px;color:var(--ink);width:100%;transition:.15s}
.signup-form input:focus,.signup-form select:focus{outline:0;border-color:var(--green)}
.form-hint{font-size:.74rem;color:var(--ink-dim);text-align:center}
.form-ok{display:none;background:var(--green-tint);color:var(--green-dark);padding:.9rem;border-radius:12px;text-align:center;font-weight:700;font-size:.9rem}
.form-ok.show{display:block}

/* FAQ */
.faq{background:var(--bg)}
.faq-list{margin-top:1.8rem;display:flex;flex-direction:column;gap:.7rem;max-width:820px}
.faq-list details{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.faq-list details[open]{border-color:var(--green)}
.faq-list summary{cursor:pointer;list-style:none;padding:1.05rem 1.25rem;font-family:var(--disp);font-weight:700;font-size:1.02rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:44px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";color:var(--green);font-size:1.4rem;font-weight:600;flex-shrink:0}
.faq-list details[open] summary::after{content:"–"}
.faq-list details p{padding:0 1.25rem 1.15rem;color:var(--ink-soft);font-size:.95rem}

/* Standorte */
.loc{background:var(--tint)}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:2rem}
.loc-card{background:var(--card);border-radius:var(--r);padding:1.9rem 1.8rem;box-shadow:var(--shadow-sm)}
.loc-tag{font-size:.68rem;font-weight:700;letter-spacing:.14em;color:var(--green-dark);background:var(--green-tint);border-radius:999px;padding:.3rem .75rem;display:inline-block;margin-bottom:.9rem}
.loc-card h3{font-size:1.45rem;margin-bottom:.5rem}
.loc-card p{color:var(--ink-soft);font-size:.95rem}
.loc-meta{margin-top:.8rem;font-size:.84rem;color:var(--ink-dim)}
.loc-link{display:inline-block;margin-top:1rem;color:var(--green);text-decoration:none;font-family:var(--disp);font-weight:700}
.loc-link:hover{color:var(--green-dark)}
.map{margin-top:1.6rem;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);line-height:0}
.map iframe{width:100%;height:330px;border:0}

/* Footer */
.ft{background:var(--green-dark);padding:3.2rem 0 1.6rem;color:rgba(255,255,255,.82)}
.ft-in{display:grid;grid-template-columns:1.4fr 1fr 1fr .9fr;gap:2rem}
.ft .brand-script{color:#ff8a76}
.ft .brand-word{color:var(--green-bright)}
.ft .brand-inh{color:rgba(255,255,255,.6)}
.brand-ft{margin-bottom:.9rem}
.ft-brand p{font-size:.9rem;max-width:36ch}
.ft-col h4{font-size:.72rem;font-weight:700;letter-spacing:.14em;color:var(--green-bright);text-transform:uppercase;margin-bottom:.9rem;font-family:var(--body)}
.ft-col p{font-size:.9rem;line-height:1.85}
.ft-col a{color:rgba(255,255,255,.82);text-decoration:none}
.ft-col a:hover{color:var(--green-bright)}
.ft-btm{display:flex;justify-content:space-between;align-items:center;margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.16);font-size:.78rem;flex-wrap:wrap;gap:.5rem}
.ft-demo strong{color:var(--green-bright)}

/* Mobile CTA */
.mcta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);
  border-top:1px solid var(--line);box-shadow:0 -8px 24px -14px rgba(26,43,30,.3);padding:.7rem;gap:.6rem}
.mcta .btn{flex:1;padding:1rem}
.mcta .btn-out{background:#fff}

/* ===== Responsive ===== */
@media(max-width:960px){
  .nav,.hd-wa{display:none}
  .burger{display:flex}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:.4rem 0;box-shadow:var(--shadow)}
  .nav.open a{padding:.95rem 22px;border-bottom:1px solid var(--line);color:var(--ink)}
  .tech-grid{grid-template-columns:1fr 1fr}
  .cls-panel.active{grid-template-columns:1fr}
  .cls-img{min-height:200px;max-height:280px}
  .school-in,.signup-in{grid-template-columns:1fr;gap:2rem}
  .loc-grid{grid-template-columns:1fr}
  .signup-in>*,.school-in>*,.loc-grid>*,.tech-grid>*{min-width:0}
}
@media(max-width:640px){
  body{font-size:16px}
  .preview-bar{font-size:.7rem}
  .hero{padding-top:15rem}
  .hero-img::after{background:linear-gradient(180deg,rgba(20,32,16,.18) 0%,rgba(249,251,246,.05) 26%,rgba(249,251,246,.86) 52%,var(--bg) 88%)}
  .hero h1{font-size:clamp(2.7rem,12vw,3.4rem)}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%;white-space:normal;text-align:center}
  .hero-stats{gap:1.1rem;flex-direction:column}
  .stat{flex-direction:row;align-items:baseline;gap:.8rem}
  .stat-l{max-width:none}
  .tech-grid{grid-template-columns:1fr}
  .cls-tab{flex:1 1 calc(50% - .6rem);text-align:center}
  .cls-body{padding:1.6rem 1.4rem}
  .gal-strip figure{flex:0 0 82vw}
  .signup-facts li{flex-direction:column;align-items:flex-start;gap:.25rem}
  .signup-txt .btn{white-space:normal;width:100%}
  .ft-in{grid-template-columns:1fr 1fr}
  .ft-brand{grid-column:1/-1}
  .mcta{display:flex}
  body{padding-bottom:78px}
  .ft-btm{justify-content:center;text-align:center}
  .signup-facts a,.ft-col a,.loc-link{display:inline-block;padding:.7rem 0;margin:-.35rem 0}
}
