/* ====== VKU-LEU — Design Tokens ====== */
:root{
  --blue:#0a4fd6;
  --blue-bright:#1668ff;
  --blue-deep:#062c80;
  --ink:#0b0d12;
  --ink-soft:#161922;
  --paper:#ffffff;
  --paper-warm:#f4f6fb;
  --grey:#5a6275;
  --line:#e3e8f2;
  --gold:#f0a500;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 18px 50px -20px rgba(10,40,120,.35);
  --shadow-sm:0 6px 20px -8px rgba(10,40,120,.25);
  --maxw:1160px;
  --font-display:'Anton',Impact,sans-serif;
  --font-body:'Outfit',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.container-narrow{max-width:780px}
.center{text-align:center}

/* ====== Typography ====== */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:1.18;letter-spacing:.5px;text-transform:uppercase}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(2rem,4.2vw,3.2rem)}
h3{font-size:1.3rem;letter-spacing:.3px}
.eyebrow{display:inline-block;font-family:var(--font-body);font-weight:700;font-size:.8rem;letter-spacing:2px;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.lead{font-size:1.2rem;color:var(--grey);max-width:540px}
.section-intro{max-width:620px;margin:14px auto 0;color:var(--grey);font-size:1.08rem}

/* ====== Buttons ====== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-weight:700;font-size:1rem;padding:14px 28px;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s;white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--blue-bright);transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(22,104,255,.6)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-lg{padding:17px 36px;font-size:1.08rem}
.btn-block{display:flex;width:100%}

/* ====== Header ====== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-wrap{display:flex;align-items:center;gap:28px;padding-top:14px;padding-bottom:14px}
.logo{display:flex;align-items:center;gap:8px}
.logo-mark{font-size:1.7rem}
.logo-text{font-family:var(--font-display);font-size:1.5rem;letter-spacing:1px}
.logo-accent{color:var(--blue)}
.nav{display:flex;gap:26px;margin-left:auto;font-weight:600}
.nav a{color:var(--ink-soft);position:relative;padding:4px 0;transition:color .2s}
.nav a:hover,.nav a.active{color:var(--blue)}
.nav a.active::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;background:var(--blue)}
.nav-cta{padding:11px 22px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:26px;height:3px;background:var(--ink);border-radius:2px;transition:.3s}
.mobile-nav{display:none;flex-direction:column;gap:4px;padding:0 24px 18px}
.mobile-nav a{padding:12px 0;border-bottom:1px solid var(--line);font-weight:600}
.mobile-nav .btn{margin-top:10px}

/* ====== Hero ====== */
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,#fff 0%,var(--paper-warm) 100%)}
.hero-bg{position:absolute;inset:0;background:
  radial-gradient(circle at 85% 15%,rgba(22,104,255,.14),transparent 45%),
  radial-gradient(circle at 10% 90%,rgba(10,79,214,.1),transparent 40%);
  pointer-events:none}
.hero-bg::after{content:"";position:absolute;top:-60px;right:-40px;font-size:30rem;opacity:.04;line-height:1}
.hero-inner{position:relative;display:grid;grid-template-columns:1.3fr .9fr;gap:50px;align-items:center;padding:40px 24px 80px}
.badge{display:inline-block;background:var(--ink);color:#fff;font-weight:600;font-size:.85rem;padding:7px 16px;border-radius:50px;margin-bottom:22px}
.hero h1{margin-bottom:18px}
.hl{color:var(--blue);position:relative}
.hero-cta{display:flex;gap:14px;margin:30px 0 26px;flex-wrap:wrap}
.hero-points{list-style:none;display:flex;flex-wrap:wrap;gap:8px 22px;font-weight:600;color:var(--ink-soft)}
.hero-points li{font-size:.98rem}

.price-card{background:var(--ink);color:#fff;border-radius:var(--radius);padding:34px 30px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.price-card::before{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(22,104,255,.35),transparent 70%)}
.price-label{font-size:.9rem;letter-spacing:1px;text-transform:uppercase;color:#aab4cf;font-weight:600}
.price-amount{display:block;font-family:var(--font-display);font-size:3.6rem;line-height:1;margin:6px 0 2px}
.price-amount span{font-size:1.6rem;color:var(--blue-bright)}
.price-sub{color:#aab4cf;font-size:.92rem}
.price-divider{height:1px;background:rgba(255,255,255,.15);margin:22px 0}
.price-card ul{list-style:none;display:grid;gap:12px;margin-bottom:24px}
.price-card li{font-size:.96rem;color:#e6ebf7}
.price-list li{display:flex;align-items:flex-start;gap:10px}
.hero-banner-wrap{margin:16px auto 50px;max-width:880px}
.hero-banner{width:100%;height:auto;display:block;margin:0 auto}

/* ====== Trust bar ====== */
.trustbar{background:var(--blue);color:#fff}
.trustbar-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:26px 24px;text-align:center}
.trust-item strong{display:block;font-family:var(--font-display);font-size:1.9rem;line-height:1}
.trust-star{color:#ffd23f;margin-left:4px;font-family:var(--font-body)}
.trust-item span{font-size:.85rem;opacity:.85;font-weight:500}

/* ====== Sections ====== */
.section{padding:84px 0}
.section.alt{background:var(--paper-warm)}
.section-head{text-align:center;margin-bottom:48px}

/* Steps */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:42px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;position:relative;transition:transform .2s,box-shadow .2s}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.step-num{position:absolute;top:-18px;left:28px;width:44px;height:44px;background:var(--blue);color:#fff;font-family:var(--font-display);font-size:1.4rem;display:flex;align-items:center;justify-content:center;border-radius:12px;box-shadow:var(--shadow-sm)}
.step h3{margin:14px 0 8px}
.step p{color:var(--grey);font-size:.98rem}

/* Features */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:transform .2s,box-shadow .2s,border-color .2s}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.feature-icon{font-size:2rem;display:block;margin-bottom:14px}
.feature h3{margin-bottom:8px}
.feature p{color:var(--grey);font-size:.97rem}

/* Content cards */
.content-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:42px}
.content-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;border-top:4px solid var(--blue);transition:transform .2s,box-shadow .2s}
.content-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card-tag{display:inline-block;font-weight:700;font-size:.78rem;letter-spacing:1px;color:var(--blue);text-transform:uppercase;margin-bottom:10px}
.content-card h3{font-size:1.15rem;margin-bottom:8px}
.content-card p{color:var(--grey);font-size:.94rem}

/* Reviews */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:38px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.stars{color:var(--gold);font-size:1.1rem;letter-spacing:2px;margin-bottom:14px}
.review p{font-size:1rem;margin-bottom:16px}
.review cite{font-style:normal;font-size:.85rem;color:var(--grey)}
.rating-summary{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:16px;flex-wrap:wrap}
.rating-score{font-family:var(--font-display);font-size:1.8rem;color:var(--ink)}
.rating-stars{color:#ffd23f;font-size:1.3rem;letter-spacing:2px}
.rating-count{color:var(--grey);font-size:.95rem}

/* Booking iframe */
.iframe-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm);overflow:hidden}
.iframe-wrap iframe{border-radius:var(--radius-sm);display:block;width:100%;min-height:800px}

/* Location */
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.location-info address{font-style:normal;font-size:1.1rem;margin:18px 0;line-height:1.7}
.location-list{list-style:none;display:grid;gap:12px;margin-bottom:26px}
.location-list a{color:var(--blue);font-weight:600}
.location-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:380px}

/* FAQ */
.faq-list{display:grid;gap:12px}
.faq-list details{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:0 22px;transition:box-shadow .2s}
.faq-list details[open]{box-shadow:var(--shadow-sm)}
.faq-list summary{font-weight:700;font-size:1.05rem;padding:18px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-list summary::after{content:"+";font-size:1.5rem;color:var(--blue);font-weight:400}
.faq-list details[open] summary::after{content:"–"}
.faq-list p{padding:0 0 18px;color:var(--grey)}

/* Final CTA */
.final-cta{background:var(--ink);color:#fff;padding:74px 0;text-align:center;position:relative;overflow:hidden}
.final-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(22,104,255,.18),transparent 60%);pointer-events:none}
.final-cta .container{position:relative;z-index:1}
.final-cta h2{margin-bottom:12px}
.final-cta p{color:#aab4cf;margin-bottom:28px;font-size:1.15rem}

/* Footer */
.site-footer{background:var(--ink-soft);color:#cdd5e6;padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;padding-bottom:40px}
.footer-brand .logo-text{font-size:1.6rem;color:#fff}
.footer-brand p{margin:12px 0 18px;font-size:.95rem;max-width:280px}
.social{display:flex;gap:12px}
.social a{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border-radius:10px;font-size:1.1rem;transition:background .2s,transform .2s}
.social a:hover{background:var(--blue);transform:translateY(-3px)}
.footer-col h4{font-family:var(--font-body);font-size:.85rem;letter-spacing:1.5px;text-transform:uppercase;color:#fff;margin-bottom:16px}
.footer-col a{display:block;padding:6px 0;font-size:.95rem;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-col address{font-style:normal;font-size:.95rem;line-height:1.8}
.footer-col address a{display:inline;padding:0}
.footer-bottom{display:flex;justify-content:space-between;padding-top:24px;padding-bottom:24px;border-top:1px solid rgba(255,255,255,.08);font-size:.85rem;color:#8893ab}

/* ====== Icons (SVG) ====== */
.icon{width:26px;height:26px;display:inline-block;stroke:var(--blue);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round;vertical-align:middle}
.icon-box{width:52px;height:52px;border-radius:14px;background:#e6f1fb;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.icon-box .icon{width:26px;height:26px}
.li-icon{width:20px;height:20px;stroke:var(--blue);stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:3px}

/* ====== Bild-Platzhalter / Illustrationen ====== */
.illu{width:100%;border-radius:var(--radius);overflow:hidden;background:var(--paper-warm);display:block;border:1px solid var(--line)}
.illu svg{display:block;width:100%;height:auto}
.illu-tag{position:absolute;bottom:12px;right:12px;background:rgba(11,13,18,.78);color:#fff;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:5px 11px;border-radius:50px;backdrop-filter:blur(4px)}
.illu-wrap{position:relative}
.hero-illu{position:relative}

/* ====== Logo (neutral, ohne Emoji) ====== */
.logo-img{height:52px;width:auto;display:block;border-radius:10px}
@media(max-width:560px){.logo-img{height:42px}}

/* ====== Artikel / Ratgeber ====== */
.article{padding:54px 0 20px}
.article h1{margin:10px 0 22px}
.article-lead{font-size:1.25rem;color:var(--grey);margin-bottom:36px;line-height:1.6}
.article h2{font-size:1.7rem;margin:38px 0 14px}
.article p{font-size:1.1rem;color:var(--ink-soft);margin-bottom:16px}
.article a:not(.btn){color:var(--blue);font-weight:600}
.article a.btn-primary{color:#fff}
.article a.btn-ghost{color:var(--ink)}
.article-cta{margin:48px 0 30px;padding:34px;background:var(--paper-warm);border:1px solid var(--line);border-radius:var(--radius);text-align:center}
.article-cta h3{font-size:1.5rem;margin-bottom:10px}
.article-cta p{color:var(--grey);margin-bottom:22px}
.card-link{display:inline-block;margin-top:14px;color:var(--blue);font-weight:700;font-size:.95rem}
.legal-note{background:#e6f1fb;border:1px solid #b5d4f4;border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:32px;font-size:.95rem;color:#0c447c}
.article h2{font-size:1.7rem;margin:38px 0 14px}
.article h3{font-size:1.25rem;margin:26px 0 10px;color:var(--ink)}
.article ul{margin:0 0 16px;padding-left:22px}
.article ul li{font-size:1.1rem;color:var(--ink-soft);margin-bottom:8px}
.agb-stand{margin-top:40px;padding-top:20px;border-top:1px solid var(--line);font-size:.95rem;color:var(--grey)}
.ratgeber-card{display:flex;flex-direction:column}
.ratgeber-card .btn{margin-top:auto;align-self:flex-start}
.ratgeber-card h3{margin-bottom:10px}
.ratgeber-card p{margin-bottom:18px}

/* ====== Page hero (Unterseiten) ====== */
.page-hero{background:linear-gradient(160deg,#fff,var(--paper-warm));padding:62px 0 48px;text-align:center;border-bottom:1px solid var(--line)}
.page-hero h1{margin:8px 0 18px}
.center-lead{margin:0 auto;text-align:center}

/* ====== Lessons (Kursinhalt) ====== */
.lesson{padding:34px 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:0.85fr 1.15fr;gap:36px;align-items:center}
.lesson-reverse .lesson-illu{order:2}
.lesson:last-child{border-bottom:0}
.lesson-illu svg{width:100%;height:auto;display:block;border-radius:14px}
.lesson-illu img{width:100%;height:auto;display:block;border-radius:14px;box-shadow:var(--shadow-sm)}
.lesson-head{display:flex;align-items:center;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.lesson-num{background:var(--blue);color:#fff;font-family:var(--font-display);font-size:1rem;padding:6px 14px;border-radius:8px;letter-spacing:1px}
.lesson-head h2{font-size:1.8rem}
.lesson p{color:var(--ink-soft);font-size:1.08rem}
.lesson-points{margin:16px 0 0;padding-left:0;list-style:none;display:grid;gap:8px}
.lesson-points li{padding-left:30px;position:relative;color:var(--grey)}
.lesson-points li::before{content:"";position:absolute;left:0;top:9px;width:16px;height:10px;border-left:2.5px solid var(--blue);border-bottom:2.5px solid var(--blue);transform:rotate(-45deg)}
@media(max-width:760px){
  .lesson{grid-template-columns:1fr;gap:20px}
  .lesson-reverse .lesson-illu{order:0}
  .lesson-illu{max-width:340px}
}

/* ====== Reveal animation ====== */
.section-head,.step,.feature,.content-card,.review{opacity:0;transform:translateY(24px);animation:rise .6s ease forwards}
.steps-grid .step:nth-child(2){animation-delay:.1s}
.steps-grid .step:nth-child(3){animation-delay:.2s}
@keyframes rise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ====== Responsive ====== */
@media(max-width:900px){
  .nav,.nav-cta{display:none}
  .burger{display:flex;margin-left:auto}
  .site-header.open .mobile-nav{display:flex}
  .site-header.open .burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .site-header.open .burger span:nth-child(2){opacity:0}
  .site-header.open .burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .hero-inner{grid-template-columns:1fr;gap:36px;padding:48px 24px 56px}
  .location-grid{grid-template-columns:1fr;gap:28px}
  .steps-grid,.features-grid,.content-grid,.reviews-grid{grid-template-columns:1fr}
  .trustbar-inner{grid-template-columns:repeat(2,1fr);gap:24px 18px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .section{padding:60px 0}
}
@media(max-width:560px){
  body{font-size:16px}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
}

/* ===== Cookie-Banner ===== */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:9999;background:#0b0d12;color:#fff;box-shadow:0 -4px 24px rgba(0,0,0,.25);animation:cookieUp .3s ease}
@keyframes cookieUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.cookie-inner{max-width:1100px;margin:0 auto;padding:18px 22px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:space-between}
.cookie-text{font-size:.95rem;color:#d7dbe3;margin:0;flex:1;min-width:260px;line-height:1.5}
.cookie-text a{color:#7eb0ff;font-weight:600}
.cookie-actions{display:flex;gap:12px;flex-shrink:0}
.cookie-btn{padding:10px 22px;font-size:.95rem;cursor:pointer}
.cookie-banner .btn-ghost{background:transparent;border:1px solid #3a4150;color:#fff}
.cookie-banner .btn-ghost:hover{background:#1a1e27}
@media(max-width:600px){.cookie-inner{flex-direction:column;align-items:stretch;gap:14px}.cookie-actions{justify-content:stretch}.cookie-btn{flex:1}}

/* ===== WhatsApp-Button & Box ===== */
.btn-whatsapp{background:#25d366;color:#fff;border:none;display:inline-flex;align-items:center;justify-content:center}
.btn-whatsapp:hover{background:#1ebe5d;color:#fff}
.cta-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.whatsapp-box{background:#e8f8ee;border:1px solid #b5e8c9;border-radius:var(--radius);padding:30px 34px;display:flex;align-items:center;gap:34px;flex-wrap:wrap;justify-content:space-between}
.whatsapp-box-text{flex:1;min-width:280px}
.whatsapp-box-text h3{font-size:1.4rem;margin-bottom:10px;color:#0b0d12}
.whatsapp-box-text p{color:var(--ink-soft);margin-bottom:10px}
.whatsapp-list{margin:0 0 14px;padding-left:22px}
.whatsapp-list li{margin-bottom:6px;color:var(--ink-soft)}
.whatsapp-box-action{flex-shrink:0}
@media(max-width:680px){.whatsapp-box{padding:24px;gap:20px}.whatsapp-box-action{width:100%}.whatsapp-box-action .btn{width:100%}}

/* ====== Anmeldeformular & Kursliste ====== */
.form-error{background:#fde8e8;border:1px solid #f5b5b5;color:#a11;padding:14px 18px;border-radius:var(--radius-sm);margin-bottom:24px;font-weight:600}
.kurs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.kurs-card{text-align:left;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 22px;cursor:pointer;display:flex;flex-direction:column;gap:6px;font-family:var(--font-body);transition:transform .15s,box-shadow .2s,border-color .2s}
.kurs-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--blue)}
.kurs-card.selected{border-color:var(--blue);box-shadow:var(--shadow);border-width:2px}
.kurs-date{font-family:var(--font-display);font-size:1.5rem;color:var(--blue);letter-spacing:.5px}
.kurs-title{font-weight:700;font-size:1.02rem;color:var(--ink)}
.kurs-meta{font-size:.9rem;color:var(--grey)}
.kurs-seats{font-size:.85rem;color:#0a7c3a;font-weight:600}
.kurs-pick{margin-top:8px;font-weight:700;color:var(--blue);font-size:.95rem}
.anmeld-form-wrap{margin-top:40px;background:#fff;border:1px solid var(--line);border-top:4px solid var(--blue);border-radius:var(--radius);padding:34px 30px;box-shadow:var(--shadow-sm);max-width:680px}
.anmeld-form-wrap h3{margin-bottom:4px}
.form-kurs-info{color:var(--grey);margin-bottom:22px;font-weight:600}
.anmeld-form label{display:block;font-weight:600;font-size:.92rem;margin-bottom:14px;color:var(--ink-soft)}
.anmeld-form input[type=text],.anmeld-form input[type=email],.anmeld-form input[type=date]{width:100%;margin-top:6px;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:1rem;color:var(--ink)}
.anmeld-form input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(22,104,255,.15)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.consent{display:flex !important;gap:10px;align-items:flex-start;font-weight:500 !important;font-size:.9rem !important;color:var(--grey) !important;margin:6px 0 22px}
.consent input{margin-top:3px;flex-shrink:0}
.consent a{color:var(--blue);font-weight:600}
.form-hint{text-align:center;color:var(--grey);font-size:.88rem;margin-top:12px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}

/* ====== Ausweis-Info-Button & Modal, ausgebuchte Kurse ====== */
.optional{font-weight:500;color:var(--grey);font-size:.85rem}
.info-btn{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;border:0;background:var(--blue);color:#fff;font-weight:700;font-size:.8rem;cursor:pointer;margin-left:6px;vertical-align:middle;line-height:1;padding:0}
.info-btn:hover{background:var(--blue-bright)}
.info-modal{position:fixed;inset:0;background:rgba(11,13,18,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.info-modal[hidden]{display:none}
.info-modal-box{background:#fff;border-radius:var(--radius);padding:28px;max-width:480px;width:100%;position:relative;box-shadow:var(--shadow)}
.info-modal-box h3{margin-bottom:12px}
.info-modal-close{position:absolute;top:12px;right:14px;background:none;border:0;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--grey);margin:0;padding:0}
.kurs-card.ausgebucht{opacity:.55;cursor:not-allowed}
.kurs-card.ausgebucht:hover{transform:none;box-shadow:none;border-color:var(--line)}
.kurs-seats.voll{color:#c0392b;font-weight:700}

/* ====== Kursteile in Kachel ====== */
.kurs-teile{display:flex;flex-direction:column;gap:6px;margin:4px 0 2px}
.kurs-teil{display:flex;align-items:center;gap:10px}
.teil-label{flex-shrink:0;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff;background:var(--blue);border-radius:6px;padding:2px 8px}
.teil-zeit{font-weight:600;color:var(--ink);font-size:.95rem}

/* ====== Mobile-Optimierung Anmeldung & Kursliste ====== */
@media(max-width:600px){
  /* Kursliste: immer einspaltig, weniger Padding */
  .kurs-grid{grid-template-columns:1fr;gap:14px}
  .kurs-card{padding:18px 16px}
  .kurs-title{font-size:1rem}
  .kurs-teil{flex-wrap:wrap;gap:4px 8px}
  .teil-zeit{font-size:.9rem}

  /* Formular: volle Breite, kompaktes Padding */
  .anmeld-form-wrap{padding:22px 16px;margin-top:28px;border-radius:var(--radius-sm)}
  .form-row{grid-template-columns:1fr;gap:0}
  /* Inputs min. 16px gegen Auto-Zoom auf iOS */
  .anmeld-form input[type=text],
  .anmeld-form input[type=email],
  .anmeld-form input[type=date]{font-size:16px}
  .anmeld-form label{font-size:.9rem}

  /* Info-Button & Modal */
  .info-btn{width:22px;height:22px}
  .info-modal{padding:14px}
  .info-modal-box{padding:22px 18px}
}
