/* ============================================================
   MPH GmbH — "CareSuite" design system
   Extracted from mph-website-v2.html during the Eleventy migration.
   Changes vs. the original <style> block:
     - Removed the Google Fonts @import (GDPR); Poppins is self-hosted below.
     - Removed the SPA .page / .page.active / fadeIn rules (real pages now).
     - Added .mapconsent / .map-consent for click-to-load Google Maps.
   Tokens & component classes are unchanged — see .mex/context/design-system.md.
   ============================================================ */

/* ---------- Poppins, self-hosted (woff2 under /assets/fonts/, see assets/fonts/README.md) ---------- */
@font-face{font-family:'Poppins';font-style:normal;font-weight:200;font-display:swap;src:url('/assets/fonts/poppins-200.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:300;font-display:swap;src:url('/assets/fonts/poppins-300.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/poppins-400.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/poppins-500.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/poppins-600.woff2') format('woff2')}

:root{
  --teal-950:#0A2E33;
  --teal-900:#0E3D43;
  --teal-800:#145359;   /* CareSuite Markenfarbe */
  --teal-700:#1A6B70;
  --teal-600:#188A8D;
  --teal-500:#1FA3A3;
  --green-400:#3BC4A0;
  --green-300:#7FDFC2;
  --ink:#1C3A41;
  --ink-soft:#52707A;
  --bg:#FFFFFF;
  --bg-soft:#F3FAF9;
  --line:#DFECEA;
  --glass:rgba(255,255,255,.10);
  --glass-border:rgba(255,255,255,.28);
  --radius:22px;
  --shadow:0 10px 40px rgba(10,46,51,.14);
  --shadow-soft:0 2px 14px rgba(10,46,51,.07);
  --grad:linear-gradient(115deg,var(--teal-600),var(--green-400));
  --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
/* Offset in-page anchor jumps (e.g. /kontakt/#anfrage, #kunden) so the fixed header doesn't cover the target */
main [id],#main{scroll-margin-top:96px}
body{font-family:'Poppins',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg);line-height:1.7;font-size:16.5px;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:var(--teal-600)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--teal-800);color:#fff;padding:10px 18px;z-index:300;border-radius:0 0 10px 0}
.skip-link:focus{left:0}

/* ---------- Typografie: groß, leicht, luftig (Coloplast-Stil) ---------- */
h1{font-size:clamp(38px,5.4vw,68px);font-weight:300;line-height:1.12;letter-spacing:-1px}
h2{font-size:clamp(30px,3.8vw,48px);font-weight:300;line-height:1.18;letter-spacing:-.8px;color:var(--teal-900);margin:12px 0 18px}
h3{font-weight:400}
.kicker{color:var(--teal-600);font-weight:500;text-transform:uppercase;letter-spacing:.22em;font-size:12.5px}
.light .kicker{color:var(--green-300)}

/* ---------- Glas ---------- */
.glass{background:var(--glass);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:0 12px 48px rgba(0,0,0,.22)}

/* ---------- Header (fixed, Glas, wechselt beim Scrollen) ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,box-shadow .3s,border-color .3s;border-bottom:1px solid transparent}
header .navwrap{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:84px}
header{background:rgba(10,46,51,.45)}
header.scrolled{background:rgba(255,255,255,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom-color:var(--line);box-shadow:var(--shadow-soft)}
.logo{flex-shrink:0;display:flex;align-items:center}
.logo img{height:48px;width:auto;max-width:260px;object-fit:contain;filter:brightness(0) invert(1);transition:filter .3s}
header.scrolled .logo img{filter:none}
nav.main{display:flex;align-items:center;gap:2px}
nav.main a{color:#fff;text-decoration:none;font-weight:500;font-size:15px;padding:9px 14px;border-radius:999px;transition:background .18s,color .18s;letter-spacing:.015em;white-space:nowrap}
nav.main a:hover{background:rgba(255,255,255,.14)}
nav.main a.active{background:rgba(255,255,255,.18)}
header.scrolled nav.main a{color:var(--ink)}
header.scrolled nav.main a:hover{background:var(--bg-soft);color:var(--teal-700)}
header.scrolled nav.main a.active{background:var(--bg-soft);color:var(--teal-700)}
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--grad);color:#fff;text-decoration:none;font-weight:500;padding:14px 30px;border-radius:999px;border:none;cursor:pointer;font-size:15.5px;letter-spacing:.02em;box-shadow:var(--shadow-soft);transition:.22s}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn.outline-light{background:rgba(255,255,255,.10);border:1.5px solid rgba(255,255,255,.7);backdrop-filter:blur(8px)}
.btn.outline-dark{background:transparent;color:var(--teal-700);border:1.5px solid var(--teal-600);box-shadow:none}
.btn.small{padding:10px 22px;font-size:14px}
.btn.white{background:#fff;color:var(--teal-800)}
.header-cta{white-space:nowrap;flex-shrink:0}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.menu-toggle svg{width:30px;height:30px;stroke:#fff;transition:stroke .3s}
header.scrolled .menu-toggle svg{stroke:var(--teal-800)}

/* ---------- Fullscreen-Video-Hero ---------- */
.vhero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;color:#fff;text-align:center}
.vhero video,.vhero .vposter{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.vhero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,40,45,.45),rgba(8,40,45,.25) 45%,rgba(8,40,45,.55));z-index:1}
.vhero .inner{position:relative;z-index:2;max-width:1160px;width:100%;padding:130px 28px 90px;text-align:left}
.vhero .glass{display:grid;grid-template-columns:1.15fr .85fr;align-items:stretch;padding:0;overflow:hidden}
.vhero .gcontent{padding:48px 52px}
.vhero .gimage{position:relative}
.vhero .gimage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;-webkit-mask-image:linear-gradient(90deg,transparent,#000 55%);mask-image:linear-gradient(90deg,transparent,#000 55%)}
.vhero h1{color:#fff;margin:16px 0 18px;font-size:clamp(30px,3.6vw,46px)}
.vhero h1 b{font-weight:500}
.vhero p{color:rgba(255,255,255,.88);font-size:17.5px;font-weight:300;max-width:560px}
.vhero .ctas{display:flex;gap:16px;justify-content:flex-start;margin-top:30px;flex-wrap:wrap}
.scrollhint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.8);font-size:12px;letter-spacing:.25em;text-transform:uppercase;text-decoration:none;display:flex;flex-direction:column;align-items:center;gap:8px}
.scrollhint::after{content:"";width:1px;height:36px;background:linear-gradient(rgba(255,255,255,.9),transparent);animation:drip 2s infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- Stats ---------- */
.stats{background:var(--teal-950);color:#fff}
.stats .container{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:44px 28px;text-align:center}
.stat b{display:block;font-size:38px;font-weight:200;letter-spacing:-1px;background:linear-gradient(120deg,#9FE8D2,#fff);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{font-size:13.5px;color:#A8D5CD;font-weight:300;letter-spacing:.04em}

/* ---------- Sections ---------- */
section{padding:96px 0}
section.tint{background:var(--bg-soft)}
.section-head{max-width:760px;margin-bottom:54px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.muted{color:var(--ink-soft);font-weight:300;font-size:17.5px}

/* ---------- Karten ---------- */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);transition:.25s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card img{height:230px;object-fit:cover;width:100%;transition:transform .5s}
.card:hover img{transform:scale(1.04)}
.card .body{padding:30px 30px 32px;display:flex;flex-direction:column;gap:10px;flex:1}
.card h3{font-size:24px;font-weight:400;color:var(--teal-900)}
.card .sub{font-size:12px;font-weight:500;color:var(--teal-600);text-transform:uppercase;letter-spacing:.18em}
.card p{color:var(--ink-soft);font-size:15.5px;font-weight:300;flex:1}
.card .link{font-weight:500;text-decoration:none;color:var(--teal-700);display:inline-flex;align-items:center;gap:8px}
.card .link::after{content:"→";transition:.18s}
.card .link:hover::after{transform:translateX(5px)}

/* ---------- Feature-Reihen ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:42px 0}
.feature.rev .media{order:2}
.feature .media img{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover;width:100%}
.feature h3{font-size:clamp(26px,3vw,36px);font-weight:300;color:var(--teal-900);margin:10px 0 8px;letter-spacing:-.5px;line-height:1.2}
.feature .tagline{font-weight:400;color:var(--teal-600);font-size:16.5px;margin-bottom:14px}
.feature p{color:var(--ink-soft);font-weight:300;margin-bottom:13px}
.feature ul{list-style:none;margin:16px 0 22px;display:grid;gap:11px}
.feature li{display:flex;gap:12px;align-items:flex-start;font-weight:300}
.feature li b{font-weight:500}
.feature li svg{width:21px;height:21px;flex:none;margin-top:4px;stroke:var(--green-400)}

/* ---------- Icon-Kacheln ---------- */
.icongrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.itile{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-soft);transition:.22s}
.itile:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.itile .ic{width:80px;height:80px;border-radius:50%;background:#E9F5F3;display:grid;place-items:center;margin-bottom:20px}
.itile .ic svg{width:42px;height:42px;stroke:var(--teal-800);stroke-width:1.3;fill:none}
.itile h3{font-size:20px;font-weight:400;color:var(--teal-900);margin-bottom:8px}
.itile p{color:var(--ink-soft);font-size:15px;font-weight:300}

/* ---------- Fullscreen-Showcase (Häuslicher Katheterwechsel) ---------- */
.showcase{position:relative;min-height:74vh;display:flex;align-items:center;background-size:cover;background-position:center;background-attachment:fixed;padding:100px 0}
.showcase::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,40,45,.7) 0%,rgba(8,40,45,.45) 55%,rgba(8,40,45,.2))}
.showcase .container{position:relative;z-index:2}
.showcase .glass{max-width:100%;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:48px 54px;color:#fff}
.showcase .badge{display:inline-flex;align-items:center;gap:9px;background:var(--grad);color:#fff;font-weight:500;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;padding:8px 18px;border-radius:999px;margin-bottom:22px}
.showcase h2{color:#fff;margin:0 0 16px}
.showcase p{color:rgba(255,255,255,.85);font-weight:300;margin-bottom:14px}
.showcase ul{list-style:none;margin:0 0 26px;display:grid;gap:13px}
.showcase li{display:flex;gap:12px;align-items:flex-start;font-weight:300;color:rgba(255,255,255,.92)}
.showcase li svg{width:21px;height:21px;flex:none;margin-top:4px;stroke:var(--green-300)}

/* ---------- Full-Bleed-Bildband ---------- */
.bleed{position:relative;min-height:64vh;display:flex;align-items:center;justify-content:center;background-size:cover;background-position:center;background-attachment:fixed;text-align:center;padding:90px 0}
.bleed::before{content:"";position:absolute;inset:0;background:rgba(8,40,45,.45)}
.bleed .glass{position:relative;z-index:2;max-width:860px;margin:0 28px;padding:46px 52px;color:#fff}
.bleed blockquote{font-size:clamp(22px,3vw,34px);font-weight:300;line-height:1.45;letter-spacing:-.3px}
.bleed cite{display:block;margin-top:16px;font-style:normal;color:var(--green-300);font-size:14px;letter-spacing:.12em;text-transform:uppercase}

/* ---------- Seiten-Hero (Unterseiten, Full-Bleed-Bild) ---------- */
.pagehero{position:relative;min-height:62vh;display:flex;align-items:flex-end;background-size:cover;background-position:center;color:#fff;padding:160px 0 70px;overflow:hidden}
.pagehero::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,40,45,.5),rgba(8,40,45,.25) 50%,rgba(8,40,45,.72))}
.pagehero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.pagehero .container{position:relative;z-index:2;width:100%}
.hero-logo{height:64px;width:auto;margin:0 auto 20px;filter:brightness(0) invert(1);opacity:.96}
.mapwrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid var(--line);margin-top:48px}
.pagehero .glass{max-width:760px;padding:40px 46px;margin:0 auto}
.pagehero h1{color:#fff;margin:12px 0 14px;font-size:clamp(34px,4.6vw,56px)}
.pagehero p{color:rgba(255,255,255,.86);font-size:17.5px;font-weight:300;max-width:640px}

/* ---------- Karte: statisches Bild, Klick öffnet Google Maps (GDPR – kein Google-Request beim Seitenaufruf) ---------- */
.maplink{position:relative;display:block;text-decoration:none}
.maplink img{width:100%;height:430px;object-fit:cover;display:block;transition:transform .4s}
.maplink:hover img{transform:scale(1.03)}
.maplink .map-marker{position:absolute;top:50%;left:50%;transform:translate(-50%,-100%);width:42px;height:42px;display:grid;place-items:center;pointer-events:none;filter:drop-shadow(0 3px 5px rgba(8,40,45,.4))}
.maplink .map-marker svg{width:42px;height:42px;stroke:var(--teal-700);fill:#fff}
.maplink .map-open{position:absolute;right:16px;bottom:16px;background:var(--grad);color:#fff;font-weight:500;font-size:14px;padding:10px 18px;border-radius:999px;box-shadow:var(--shadow-soft)}
.maplink .map-attr{position:absolute;left:8px;bottom:8px;font-size:11px;color:var(--ink-soft);background:rgba(255,255,255,.78);padding:1px 7px;border-radius:6px}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;counter-reset:step}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:36px;position:relative;box-shadow:var(--shadow-soft)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-size:52px;font-weight:200;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:10px;letter-spacing:-2px;line-height:1}
.step h3{font-size:20px;font-weight:400;color:var(--teal-900);margin-bottom:8px}
.step p{color:var(--ink-soft);font-size:15.5px;font-weight:300}

/* ---------- FAQ ---------- */
.faq{max-width:840px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:16px;margin-bottom:14px;box-shadow:var(--shadow-soft);overflow:hidden}
.faq summary{cursor:pointer;font-weight:400;font-size:17px;padding:21px 26px;color:var(--teal-900);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:26px;color:var(--teal-500);font-weight:200;transition:.2s;flex:none}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .answer{padding:0 26px 23px;color:var(--ink-soft);font-weight:300}

/* ---------- CTA-Band ---------- */
.ctaband{position:relative;overflow:hidden;background:linear-gradient(115deg,var(--teal-900),var(--teal-700));color:#fff;padding:96px 0}
.ctaband .container{display:grid;grid-template-columns:1.3fr .7fr;gap:40px;align-items:center;position:relative;z-index:2}
.ctaband h2{color:#fff}
.ctaband p{color:#C9E8E2;font-weight:300;font-size:17.5px}
.ctaband .actions{display:flex;flex-direction:column;gap:14px}
.ctaband .actions .btn{justify-content:center}
.ctaband::before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(59,196,160,.25),transparent 65%);top:-200px;right:-120px}

/* ---------- Kontakt ---------- */
.contactgrid{display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:start}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:40px;box-shadow:var(--shadow-soft)}
.panel h3{color:var(--teal-900);font-size:26px;font-weight:300;margin-bottom:22px;letter-spacing:-.4px}
.formrow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{font-weight:400;font-size:13.5px;color:var(--teal-800);display:block;margin-bottom:6px;letter-spacing:.03em}
input,textarea,select{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;font:inherit;font-size:15px;font-weight:300;color:var(--ink);background:#FBFEFD;margin-bottom:16px;transition:.15s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--teal-500);box-shadow:0 0 0 3px rgba(31,163,163,.13)}
.contact-item{display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line)}
.contact-item:last-child{border-bottom:none}
.contact-item .ic{width:46px;height:46px;border-radius:13px;background:var(--bg-soft);display:grid;place-items:center;flex:none}
.contact-item .ic svg{width:22px;height:22px;stroke:var(--teal-600)}
.contact-item b{display:block;color:var(--teal-900);font-weight:500;font-size:15px}
.contact-item a{text-decoration:none;font-weight:400}
.contact-item span,.contact-item a{color:var(--ink-soft);font-size:15.5px;font-weight:300}
.hours{width:100%;border-collapse:collapse;font-size:15px}
.hours td{padding:9px 0;border-bottom:1px solid var(--line);color:var(--ink-soft);font-weight:300}
.hours td:first-child{font-weight:500;color:var(--teal-900)}
.form-note{font-size:13px;color:var(--ink-soft);font-weight:300;margin-top:4px}

/* ---------- Bonago ---------- */
.bonago{position:relative;overflow:hidden;background:linear-gradient(115deg,var(--teal-800),var(--teal-600));padding:96px 0;color:#fff}
.bonago::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(127,223,194,.28),transparent 60%);bottom:-180px;left:-100px}
.bonago .container{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.bonago h2{color:#fff}
.bonago p{color:rgba(255,255,255,.85);font-weight:300}
.bonago .glass{padding:40px 42px}
.bonago .reward{display:flex;gap:16px;align-items:flex-start;padding:14px 0}
.bonago .reward svg{width:26px;height:26px;flex:none;stroke:var(--green-300);margin-top:3px}
.bonago .reward b{font-weight:500;display:block}
.bonago .reward span{font-weight:300;color:rgba(255,255,255,.8);font-size:15px}

/* ---------- Footer ---------- */
footer{background:var(--teal-950);color:#A8CFC9;padding:72px 0 30px;font-size:15px;font-weight:300}
.footgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:44px;margin-bottom:48px}
footer h4{color:#fff;font-size:15px;font-weight:500;letter-spacing:.06em;margin-bottom:18px}
footer a{color:#A8CFC9;text-decoration:none}
footer a:hover{color:#fff}
footer ul{list-style:none;display:grid;gap:10px}
.footer-logo{height:38px;width:auto;margin-bottom:16px;filter:brightness(0) invert(1);opacity:.95}
.footbottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;font-size:13.5px}
.iso{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.07);padding:8px 16px;border-radius:999px;font-size:13px;color:#CDEFE6}
.iso svg{width:16px;height:16px;stroke:var(--green-300)}

/* ---------- Legal ---------- */
.legal{max-width:780px}
.legal h2{margin-top:36px;font-size:28px}
.legal p{margin-bottom:14px;color:var(--ink-soft);font-weight:300}

/* ---------- Responsive ---------- */
/* The full desktop nav needs ~1220px. Compact it below that so it still fits
   down to ~1120px, then collapse it into the mobile menu below 1120px. */
@media(max-width:1240px){
  header .navwrap{gap:14px}
  nav.main a{padding:8px 10px;font-size:14px}
  .logo img{height:42px}
  .btn.small.header-cta{padding:9px 16px;font-size:13.5px}
}
@media(max-width:1120px){
  nav.main{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(10,46,51,.96);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);flex-direction:column;align-items:stretch;padding:16px;box-shadow:var(--shadow)}
  nav.main.open{display:flex}
  nav.main a,header.scrolled nav.main a{color:#fff;padding:15px 18px;font-size:17px}
  header.scrolled nav.main a:hover{background:rgba(255,255,255,.12);color:#fff}
  .menu-toggle{display:block}
  /* nav is hidden here, so group the CTA with the hamburger on the right instead of letting space-between strand it in the middle */
  .header-cta{margin-left:auto}
}
@media(max-width:1020px){
  .cards3,.icongrid,.steps{grid-template-columns:1fr 1fr}
  .feature{grid-template-columns:1fr;gap:30px}
  .feature.rev .media{order:0}
  .contactgrid{grid-template-columns:1fr}
  .vhero .glass,.showcase .glass{grid-template-columns:1fr}
  .vhero .gimage{display:none}
  .ctaband .container,.bonago .container{grid-template-columns:1fr}
  .footgrid{grid-template-columns:1fr 1fr}
  .stats .container{grid-template-columns:1fr 1fr;gap:24px}
  .showcase,.bleed{background-attachment:scroll}
}
@media(max-width:780px){
  .header-cta{display:none}
  .cards3,.icongrid,.steps{grid-template-columns:1fr}
  .footgrid{grid-template-columns:1fr}
  .formrow{grid-template-columns:1fr}
  .vhero .glass{padding:38px 26px}
  .showcase .glass,.pagehero .glass{padding:34px 28px}
  section{padding:72px 0}
}

/* ============================================================
   Bewegung — dezente Scroll-Reveals + Hero-Einblendung
   Progressive Enhancement: jeder versteckte Zustand ist hinter
   `html.js` gegated (Inline-Script im <head> von base.njk). Ohne JS
   bleibt also alles sichtbar. Animiert wird ausschließlich transform +
   opacity (GPU-freundlich, kein Layout-Shift). Unter
   prefers-reduced-motion wird alles sofort und ohne Bewegung gezeigt.
   ============================================================ */
:root{--ease-out:cubic-bezier(.22,.61,.36,1)}

/* Einzelelemente: faden + steigen leicht ein, sobald sie ins Bild scrollen */
html.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
html.js .reveal.is-visible{opacity:1;transform:none}

/* Gruppen: direkte Kinder erscheinen gestaffelt. Keyframe statt transition,
   damit die bestehenden Hover-Übergänge der Karten/Kacheln (inkl. box-shadow)
   unangetastet bleiben. `.is-done` (per JS nach dem Eintritt gesetzt) entfernt
   die Animation wieder, sodass der Hover-Lift sofort reagiert. Der
   animation-delay je Kind wird in app.js inline gesetzt (gekappt). */
@keyframes reveal-rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
html.js .reveal-group:not(.is-visible) > *{opacity:0;transform:translateY(16px)}
html.js .reveal-group.is-visible > *{animation:reveal-rise .6s var(--ease-out) both}
html.js .reveal-group.is-visible.is-done > *{animation:none}

/* Hero: Glas-Inhalt blendet beim Laden ein (JS triggert nach dem ersten Paint,
   Video/Hintergrundbild bleiben sofort sichtbar) */
html.js .hero-reveal{opacity:0;transform:translateY(14px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
html.js .hero-reveal.is-visible{opacity:1;transform:none}
/* Startseiten-Hero: sanfte Kaskade der Glas-Inhalte (Logo, Kicker, H1, Text, Buttons) */
html.js .vhero .gcontent .hero-reveal:nth-child(2){transition-delay:.07s}
html.js .vhero .gcontent .hero-reveal:nth-child(3){transition-delay:.14s}
html.js .vhero .gcontent .hero-reveal:nth-child(4){transition-delay:.21s}
html.js .vhero .gcontent .hero-reveal:nth-child(5){transition-delay:.28s}
/* Seitenbild im Hero: nur faden (kein Versatz), leicht verzögert */
html.js .vhero .gimage.hero-reveal{transform:none;transition-delay:.12s}

/* Reduced Motion: keine Bewegung, Inhalte sofort sichtbar */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  html.js .reveal,
  html.js .hero-reveal,
  html.js .reveal-group > *{opacity:1!important;transform:none!important;transition:none!important;animation:none!important}
  .scrollhint::after{animation:none}
  .showcase,.bleed{background-attachment:scroll}
}
