/**
 * FILE:    assets/css/main.css
 * PATH:    gerust-bau/assets/css/main.css
 * FUNCTION: Main stylesheet — design tokens, layout, components, WCAG 2.2 AA.
 *           Covers navigation, hero, sections, forms, footer. Min contrast 5:1.
 * VERSION: 1.0.0
 * HISTORY:
 *   1.0.0 - 2025-04-01 - Extracted from index.php v4.5.0.
 */

/* ==========================================================================
   DESIGN TOKENS
   ========================================================================== */
:root {
  --ink:       #0C0F1A;
  --ink-80:    rgba(12,15,26,.80);
  --ink-40:    rgba(12,15,26,.40);
  --ink-12:    rgba(12,15,26,.12);
  --blue:      #1331D4;
  --blue-deep: #0A1A63;
  --blue-mid:  #1E3FE8;
  --blue-glow: rgba(19,49,212,.35);
  --ice:       #C9D2FF;
  --ice-faint: #EEF0FF;
  --white:     #FFFFFF;
  --surface:   #F7F8FD;
  --steel:     #3A4060;
  --rust:      #E84C1E;
  --green:     #1a6b3c;
  --ff-d: 'Barlow Condensed', sans-serif;
  --ff-b: 'Source Sans 3', sans-serif;
  --r4: 4px; --r8: 8px; --r16: 16px;
  --expo:   cubic-bezier(.19,1,.22,1);
  --spring: cubic-bezier(.34,1.56,.64,1);
}

/* ==========================================================================
   RESET
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ff-b);font-size:1.0625rem;line-height:1.72;color:var(--ink);background:var(--white);overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--ff-d);font-weight:800;line-height:1.1;letter-spacing:.01em;color:var(--ink)}
a{color:var(--blue);text-decoration:none;transition:color .2s}
a:hover{color:var(--blue-deep)}
img{max-width:100%;height:auto;display:block}
:focus-visible{outline:3px solid var(--rust);outline-offset:3px;border-radius:var(--r4)}
p{margin-bottom:0}

/* ==========================================================================
   SKIP + GRAIN
   ========================================================================== */
.skip{position:fixed;top:-60px;left:1rem;z-index:10000;background:var(--blue-deep);color:var(--white);padding:.6rem 1.2rem;border-radius:0 0 var(--r8) var(--r8);font-weight:700;font-size:.875rem;transition:top .2s}
.skip:focus{top:0;color:var(--white)}
.grain::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");background-size:256px;mix-blend-mode:overlay;opacity:.55}

/* ==========================================================================
   PAGE LOADER
   ========================================================================== */
#loader{position:fixed;inset:0;z-index:9999;background:var(--blue-deep);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;transition:opacity .5s,visibility .5s}
#loader.out{opacity:0;visibility:hidden;pointer-events:none}
.ld-logo{height:68px;width:auto;filter:brightness(0)invert(1);animation:ld-in .7s var(--expo) both}
.ld-track{width:200px;height:2px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;animation:ld-in .6s var(--expo) .1s both}
.ld-fill{height:100%;width:0;background:linear-gradient(90deg,var(--blue),var(--ice));border-radius:2px;animation:ld-bar 1.1s var(--expo) .2s forwards}
.ld-tag{color:rgba(255,255,255,.4);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;animation:ld-in .5s ease .4s both}
@keyframes ld-in{from{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:none}}
@keyframes ld-bar{0%{width:0}60%{width:75%}100%{width:100%}}

/* ==========================================================================
   NAVIGATION — topbar + main nav
   ========================================================================== */

/* Topbar (desktop only) */
.nav-topbar{position:fixed;top:0;left:0;right:0;z-index:902;height:var(--topbar-h);background:#04092a;border-bottom:1px solid rgba(255,255,255,.07);transition:transform .35s var(--expo),opacity .3s}
.nav-topbar.hidden{transform:translateY(-100%);opacity:0;pointer-events:none}
.nav-topbar-in{display:flex;align-items:center;justify-content:flex-end;height:100%;padding:0 1.75rem;gap:1.5rem;max-width:1280px;margin:0 auto}
.nav-topbar-item{display:flex;align-items:center;gap:.35rem;color:rgba(255,255,255,.48);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;text-decoration:none;transition:color .2s;white-space:nowrap}
.nav-topbar-item i{font-size:.78rem;color:var(--ice)}
.nav-topbar-item:hover{color:rgba(255,255,255,.82)}
.nav-topbar-sep{width:1px;height:14px;background:rgba(255,255,255,.12);flex-shrink:0}
.nav-topbar-badge{background:var(--blue);color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.06em;padding:2px 6px;border-radius:3px;margin-left:.2rem}
@media(max-width:900px){.nav-topbar{display:none}:root{--topbar-h:0px}}

/* Main navbar */
:root{--topbar-h:36px;--nav-h:64px}
#navbar{position:fixed;top:var(--topbar-h);left:0;right:0;z-index:901;height:var(--nav-h);background:transparent;transition:top .35s var(--expo),background .35s var(--expo),box-shadow .35s,border-color .35s;border-bottom:1px solid transparent}
#navbar.solid{background:rgba(6,14,55,.97);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:0 1px 0 rgba(255,255,255,.07),0 8px 32px rgba(4,9,42,.6);border-bottom-color:rgba(255,255,255,.06)}
#navbar.at-top{top:0}
.nav-in{display:flex;align-items:center;height:var(--nav-h);padding:0 1.75rem;max-width:1280px;margin:0 auto}
.nav-logo-wrap{flex-shrink:0;display:flex;align-items:center}
.nav-logo{height:32px;width:auto;display:block;filter:brightness(0)invert(1);opacity:.92;transition:opacity .2s,transform .25s var(--spring)}
.nav-logo:hover{opacity:1;transform:scale(1.02)}
.nav-divider{width:1px;height:22px;background:rgba(255,255,255,.14);margin:0 1.4rem;flex-shrink:0}
.nav-links-wrap{flex:1;overflow:hidden}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links li{flex-shrink:0}
.nav-links a{display:flex;align-items:center;gap:.3rem;font-size:.775rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.62);padding:.5rem .85rem;border-radius:6px;position:relative;transition:color .2s,background .2s;white-space:nowrap;text-decoration:none}
.nav-links a i{font-size:.7rem;opacity:.65;transition:opacity .2s}
.nav-links a:hover{color:rgba(255,255,255,.92);background:rgba(255,255,255,.07)}
.nav-links a:hover i,.nav-links a.active i{opacity:1}
.nav-links a.active{color:#fff}
.nav-links a.active::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:18px;height:2px;background:var(--ice);border-radius:2px;animation:nav-dot .25s var(--expo) both}
@keyframes nav-dot{from{width:0;opacity:0}to{width:18px;opacity:1}}
.nav-right{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-shrink:0;padding-left:.5rem}
.nav-phone-btn{display:flex;align-items:center;gap:.4rem;font-size:.775rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.72);border:1.5px solid rgba(255,255,255,.2);border-radius:6px;padding:.45rem 1rem;transition:color .2s,border-color .2s,background .2s;white-space:nowrap;text-decoration:none}
.nav-phone-btn:hover{color:#fff;border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.07)}
.nav-phone-btn i{font-size:.78rem}
@media(max-width:1080px){.nav-phone-btn{display:none!important}}
.nav-cta-btn{display:flex;align-items:center;gap:.4rem;font-size:.775rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:#fff;background:var(--blue);border:1.5px solid transparent;border-radius:6px;padding:.5rem 1.2rem;transition:background .2s,box-shadow .2s,transform .2s var(--spring);box-shadow:0 2px 12px rgba(19,49,212,.4);white-space:nowrap;text-decoration:none}
.nav-cta-btn:hover{background:var(--blue-mid);box-shadow:0 4px 20px rgba(19,49,212,.55);transform:translateY(-1px);color:#fff}
.nav-cta-btn i{font-size:.78rem}
.nav-tog{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem}
.nav-tog span{display:block;width:22px;height:1.5px;background:rgba(255,255,255,.85);border-radius:2px;transition:transform .35s var(--expo),opacity .2s,width .25s}
.nav-tog.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-tog.open span:nth-child(2){opacity:0;width:0}
.nav-tog.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Hide drawer on desktop — only shows via @media(max-width:900px) */
.nav-menu{display:none}
.nav-backdrop{display:none}

/* Mobile drawer */
@media(max-width:900px){
  :root{--topbar-h:0px}
  #navbar{top:0!important}
  .nav-divider{display:none}
  .nav-links-wrap{display:none}
  .nav-tog{display:flex}
  .nav-menu{position:fixed;top:0;right:0;bottom:0;width:min(300px,85vw);z-index:899;background:#030b28;border-left:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;padding:calc(var(--nav-h) + 1.5rem) 1.5rem 2rem;transform:translateX(110%);transition:transform .4s var(--expo);box-shadow:-16px 0 48px rgba(3,11,40,.7);overflow-y:auto}
  .nav-menu.open{transform:translateX(0)}
  .nav-backdrop{display:none;position:fixed;inset:0;z-index:898;background:rgba(0,0,0,.52);backdrop-filter:blur(2px)}
  .nav-backdrop.show{display:block}
  .nav-menu .nav-links{flex-direction:column;gap:0;list-style:none;border-top:1px solid rgba(255,255,255,.07);padding-top:.75rem;margin-bottom:1.25rem}
  .nav-menu .nav-links li{flex-shrink:unset;width:100%;border-bottom:1px solid rgba(255,255,255,.05)}
  .nav-menu .nav-links a{font-size:.95rem;padding:.9rem .5rem;border-radius:0;color:rgba(255,255,255,.72);justify-content:space-between;white-space:normal}
  .nav-menu .nav-links a::after{display:none!important}
  .nav-menu .nav-links a:hover,.nav-menu .nav-links a.active{color:#fff;background:transparent}
  .nav-menu .nav-cta-btn{justify-content:center;width:100%;padding:.85rem 1rem;font-size:.875rem;border-radius:6px;margin-top:.25rem}
  .drawer-contact{margin-top:auto;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.07)}
  .drawer-contact p{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.25);margin:0 0 .75rem}
  .drawer-contact a{display:flex;align-items:center;gap:.6rem;color:rgba(255,255,255,.6);font-size:.9rem;padding:.45rem 0;transition:color .2s;text-decoration:none}
  .drawer-contact a:hover{color:#fff}
  .drawer-contact i{color:var(--ice);font-size:.95rem}
}

/* ==========================================================================
   PHONE BAR + SCROLL-TOP
   ========================================================================== */
.phone-bar{position:fixed;bottom:1.5rem;left:50%;z-index:850;transform:translateX(-50%) translateY(80px);opacity:0;display:flex;align-items:center;background:var(--blue-deep);border-radius:6px;box-shadow:0 8px 40px rgba(10,26,99,.5),0 0 0 1px rgba(255,255,255,.08);overflow:hidden;transition:transform .5s var(--spring),opacity .4s}
.phone-bar.vis{transform:translateX(-50%) translateY(0);opacity:1}
.phone-bar a{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;color:var(--white)!important;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;transition:background .2s}
.phone-bar a:hover{background:rgba(255,255,255,.1);text-decoration:none}
.phone-bar .sep{width:1px;height:24px;background:rgba(255,255,255,.15);flex-shrink:0}
#go-top{position:fixed;bottom:2rem;right:1.5rem;z-index:900;width:44px;height:44px;background:var(--blue-deep);border:1px solid rgba(255,255,255,.12);border-radius:var(--r8);color:var(--white);font-size:1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(10px);transition:opacity .3s,transform .3s var(--spring),background .2s;box-shadow:0 4px 16px rgba(10,26,99,.3)}
#go-top.vis{opacity:1;transform:translateY(0)}
#go-top:hover{background:var(--blue)}

/* ==========================================================================
   REVEAL
   ========================================================================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s var(--expo),transform .6s var(--expo)}
.reveal.in{opacity:1;transform:none}

/* ==========================================================================
   SECTIONS
   ========================================================================== */
.sec{padding:96px 0}
.sec-alt{background:var(--surface)}
.sec-dark{background:var(--blue-deep);color:var(--white)}
.sec-contact{background:var(--ink);color:var(--white)}

.sec-kicker{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--blue);margin-bottom:.75rem;display:block}
.sec-dark .sec-kicker,.sec-contact .sec-kicker{color:var(--ice)}
.sec-h2{font-size:clamp(2.4rem,5vw,3.8rem);color:var(--ink);margin-bottom:.5rem}
.sec-dark .sec-h2,.sec-contact .sec-h2{color:var(--white)}
.sec-lead{font-size:1.1rem;color:var(--steel);max-width:640px;line-height:1.7}
.sec-dark .sec-lead,.sec-contact .sec-lead{color:rgba(255,255,255,.65)}
.sec-header{margin-bottom:3.5rem}

/* ==========================================================================
   BREADCRUMBS
   ========================================================================== */
.breadcrumb-bar{background:var(--surface);border-bottom:1px solid var(--ink-12);padding:.6rem 0;font-size:.8rem;display:none}
.breadcrumb-bar ol{display:flex;align-items:center;flex-wrap:wrap;gap:.25rem;list-style:none}
.breadcrumb-bar li{display:flex;align-items:center;gap:.25rem;color:var(--steel)}
.breadcrumb-bar li+li::before{content:'/';color:var(--ink-40)}
.breadcrumb-bar a{color:var(--blue);font-weight:500}
.breadcrumb-bar a:hover{color:var(--blue-deep)}
.breadcrumb-bar li:last-child{color:var(--ink);font-weight:600}

/* ==========================================================================
   HERO
   ========================================================================== */
/* ==========================================================================
   HERO
   ========================================================================== */
#hero {
  position: relative;
  min-height: 100svh;
  background: var(--blue-deep);
  display: flex; align-items: center;
  padding-top: calc(var(--nav-h) + var(--topbar-h));
  overflow: hidden;
}

/* Multi-layer background */
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(160deg, #070f3a 0%, #0c1d6e 45%, #060e30 100%);
}
/* Subtle grid */
.hero-bg::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 90% 90% at 55% 45%, black 25%, transparent 100%);
}
/* Glow orb */
.hero-bg::after {
  content: '';
  position: absolute; right: -8%; top: 50%; transform: translateY(-50%);
  width: clamp(280px, 48vw, 680px); aspect-ratio: 1;
  background: radial-gradient(circle, rgba(25,55,220,.22) 0%, transparent 68%);
}

/* White diagonal cut at bottom */
.hero-stripe {
  position: absolute; bottom: 0; left: 0; right: 0; height: 100px; z-index: 1;
  background: var(--white);
  clip-path: polygon(0 55%, 100% 0%, 100% 100%, 0% 100%);
}

/* Large faint text decoration */
.hero-deco {
  position: absolute; right: 2%; top: 50%; transform: translateY(-48%);
  font-family: var(--ff-d); font-size: clamp(160px, 22vw, 320px);
  font-weight: 800; color: rgba(255,255,255,.022);
  line-height: 1; letter-spacing: -.02em; user-select: none; z-index: 1;
  pointer-events: none;
}

/* Content */
.hero-body {
  position: relative; z-index: 2;
  padding: 5rem 0 9rem;
  width: 100%;
}

/* Logo */
.hero-logo {
  height: clamp(44px, 7vw, 76px); width: auto; display: block;
  filter: brightness(0) invert(1);
  filter: drop-shadow(0 2px 16px rgba(19,49,212,.5)) brightness(0) invert(1);
  margin-bottom: 1.75rem;
}

/* Location pill */
.hero-pill {
  display: inline-flex; align-items: center; gap: .45rem;
  background: rgba(255,255,255,.065);
  border: 1px solid rgba(255,255,255,.12);
  color: var(--ice);
  font-size: .7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em;
  padding: .3rem .9rem;
  border-radius: 5px;
  margin-bottom: 1.75rem;
  backdrop-filter: blur(6px);
}
.hero-pill .dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--rust);
  animation: blink 2.2s ease-in-out infinite;
}
@keyframes blink {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .55; transform: scale(1.4); }
}

/* H1 */
.hero-h1 {
  font-size: clamp(2.8rem, 8.5vw, 7rem);
  font-weight: 800; text-transform: uppercase;
  color: var(--white); line-height: .96; letter-spacing: -.01em;
  margin-bottom: 1.5rem;
}
.hero-h1 em {
  font-style: normal; color: transparent;
  -webkit-text-stroke: 2px rgba(201,210,255,.45);
}
.hero-h1__sub {
  display: block;
  font-size: .6em;           /* smaller than main H1 */
  font-weight: 600;
  letter-spacing: .04em;
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
  margin-top: .25em;
}

/* Subtitle */
.hero-sub {
  font-size: clamp(.95rem, 2vw, 1.15rem);
  color: rgba(255,255,255,.62); max-width: 520px;
  line-height: 1.68; margin-bottom: 2.5rem;
}

/* CTA row */
.hero-ctas { display: flex; flex-wrap: wrap; gap: .85rem; margin-bottom: 3rem; }

/* Primary button */
.btn-p {
  position: relative; overflow: hidden;
  background: var(--white); color: var(--blue-deep) !important;
  font-family: var(--ff-d); font-size: .95rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .06em;
  padding: .9rem 2rem; border-radius: 6px; border: none; cursor: pointer;
  display: inline-flex; align-items: center; gap: .55rem;
  box-shadow: 0 4px 18px rgba(255,255,255,.14);
  transition: transform .2s var(--spring), box-shadow .2s;
  text-decoration: none !important;
}
.btn-p::before {
  content: ''; position: absolute; inset: 0;
  background: var(--ice); transform: translateX(-101%);
  transition: transform .3s var(--expo);
}
.btn-p:hover { transform: translateY(-2px); box-shadow: 0 10px 32px rgba(255,255,255,.18); }
.btn-p:hover::before { transform: translateX(0); }
.btn-p > * { position: relative; z-index: 1; }

/* Ghost button */
.btn-g {
  background: transparent; color: rgba(255,255,255,.82) !important;
  font-family: var(--ff-d); font-size: .95rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  padding: .9rem 2rem; border-radius: 6px;
  border: 1.5px solid rgba(255,255,255,.22);
  display: inline-flex; align-items: center; gap: .55rem;
  transition: border-color .2s, background .2s, transform .2s var(--spring);
  text-decoration: none !important;
}
.btn-g:hover {
  border-color: rgba(255,255,255,.65); background: rgba(255,255,255,.07);
  transform: translateY(-2px); color: #fff !important;
}

/* Trust strip */
.hero-trust {
  display: flex; flex-wrap: wrap; gap: 1.5rem;
  padding-top: 1.75rem;
  border-top: 1px solid rgba(255,255,255,.09);
}
.trust-item {
  display: flex; align-items: center; gap: .5rem;
  color: rgba(255,255,255,.5);
  font-size: .78rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .05em;
}
.trust-item i { color: var(--ice); font-size: 1rem; }

/* ==========================================================================
   SERVICES
   ========================================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5px;background:var(--ink-12);border:1.5px solid var(--ink-12);border-radius:var(--r16);overflow:hidden}
.svc-card{background:var(--white);padding:2.5rem 2rem;position:relative;cursor:default;transition:background .25s}
.svc-card::after{content:'';position:absolute;bottom:0;left:2rem;right:2rem;height:2px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--expo)}
.svc-card:hover{background:var(--ice-faint)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-num{font-family:var(--ff-d);font-size:3.5rem;font-weight:800;color:var(--ink-12);line-height:1;margin-bottom:1.25rem;transition:color .25s}
.svc-card:hover .svc-num{color:rgba(19,49,212,.1)}
.svc-ico{width:48px;height:48px;background:var(--ice-faint);border-radius:var(--r8);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;transition:background .25s}
.svc-ico i{font-size:1.4rem;color:var(--blue)}
.svc-card:hover .svc-ico{background:rgba(19,49,212,.1)}
.svc-card h3{font-size:1.3rem;color:var(--ink);margin-bottom:.65rem}
.svc-card p{font-size:.95rem;color:var(--steel);line-height:1.65}

/* ==========================================================================
   AREAS
   ========================================================================== */
.area-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}
.area-card{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r8);transition:background .25s,border-color .25s,transform .25s var(--spring)}
.area-card:hover{background:rgba(255,255,255,.09);border-color:rgba(201,210,255,.3);transform:translateY(-3px)}
.area-ico{width:42px;height:42px;flex-shrink:0;background:rgba(201,210,255,.1);border-radius:var(--r4);display:flex;align-items:center;justify-content:center}
.area-ico i{font-size:1.2rem;color:var(--ice)}
.area-card strong{display:block;font-family:var(--ff-d);font-size:1.1rem;font-weight:700;color:var(--white);margin-bottom:.3rem}
.area-card p{font-size:.88rem;color:rgba(255,255,255,.55);margin:0}

/* GEO cities cloud */
.cities-cloud{margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}
.cities-cloud h3{font-size:1rem;color:rgba(255,255,255,.4);font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.cities-cloud .tags{display:flex;flex-wrap:wrap;gap:.5rem}
.cities-cloud .tag{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.65);font-size:.82rem;padding:.3rem .75rem;border-radius:6px;transition:background .2s,border-color .2s}
.cities-cloud .tag:hover{background:rgba(255,255,255,.12);border-color:rgba(201,210,255,.4);color:var(--white)}

/* ==========================================================================
   ABOUT / STATS
   ========================================================================== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:3rem}}
.stats-mosaic{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.stat-tile{background:var(--surface);border:1px solid var(--ink-12);border-radius:var(--r16);padding:2rem 1.5rem;text-align:center;transition:box-shadow .25s,transform .25s var(--spring)}
.stat-tile:first-child{grid-column:span 2;background:var(--blue-deep);border-color:transparent}
.stat-tile:hover{box-shadow:0 8px 32px rgba(10,26,99,.12);transform:translateY(-3px)}
.stat-num{font-family:var(--ff-d);font-size:3.25rem;font-weight:800;color:var(--blue);line-height:1;display:block}
.stat-tile:first-child .stat-num{color:var(--white);font-size:3.75rem}
.stat-lbl{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--steel);display:block;margin-top:.4rem}
.stat-tile:first-child .stat-lbl{color:rgba(255,255,255,.55)}
.about-badge{display:inline-flex;align-items:center;gap:.6rem;background:var(--ice-faint);border-left:3px solid var(--blue);padding:.9rem 1.25rem;border-radius:0 var(--r8) var(--r8) 0;font-size:.92rem;font-weight:600;color:var(--blue-deep);margin-top:1.25rem}

/* E-E-A-T signal block */
.eeat-signals{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
@media(max-width:600px){.eeat-signals{grid-template-columns:1fr 1fr}}
.eeat-item{background:var(--white);border:1px solid var(--ink-12);border-radius:var(--r8);padding:1.25rem;text-align:center;box-shadow:0 2px 8px rgba(10,26,99,.06)}
.eeat-item i{font-size:1.5rem;color:var(--blue);display:block;margin-bottom:.5rem}
.eeat-item strong{display:block;font-family:var(--ff-d);font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:.2rem}
.eeat-item span{font-size:.82rem;color:var(--steel)}

/* ==========================================================================
   PROCESS + SAFETY
   ========================================================================== */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.timeline::before{content:'';position:absolute;top:28px;left:12.5%;right:12.5%;height:2px;background:linear-gradient(90deg,var(--blue),var(--ice));z-index:0}
@media(max-width:768px){.timeline{grid-template-columns:1fr 1fr}.timeline::before{display:none}}
@media(max-width:480px){.timeline{grid-template-columns:1fr}}
.t-step{position:relative;z-index:1;padding:0 1.5rem;text-align:center}
.t-bubble{width:56px;height:56px;background:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-d);font-size:1.3rem;font-weight:800;color:var(--white);margin:0 auto 1.5rem;box-shadow:0 0 0 6px var(--white),0 0 0 8px rgba(19,49,212,.2);transition:transform .25s var(--spring),box-shadow .25s}
.t-step:hover .t-bubble{transform:scale(1.1);box-shadow:0 0 0 6px var(--white),0 0 0 12px rgba(19,49,212,.3)}
.t-step h3{font-size:1.1rem;color:var(--ink);margin-bottom:.5rem}
.t-step p{font-size:.88rem;color:var(--steel);line-height:1.6}
.safety-panel{margin-top:4rem;background:linear-gradient(135deg,var(--blue-deep) 0%,var(--blue) 100%);border-radius:var(--r16);padding:3rem;display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;position:relative;overflow:hidden}
.safety-panel::before{content:'✓';position:absolute;right:-1rem;bottom:-2rem;font-size:14rem;font-weight:800;color:rgba(255,255,255,.04);font-family:var(--ff-d);line-height:1}
@media(max-width:700px){.safety-panel{grid-template-columns:1fr;padding:2rem}}
.safety-panel h3{font-size:1.9rem;color:var(--white);margin-bottom:.75rem}
.safety-panel .sub{color:rgba(255,255,255,.65);font-size:.95rem}
.safety-list{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.safety-list li{display:flex;align-items:flex-start;gap:.7rem;color:rgba(255,255,255,.82);font-size:.93rem}
.safety-list i{color:var(--ice);flex-shrink:0;margin-top:.2rem}

/* ==========================================================================
   FAQ  (AEO structured)
   ========================================================================== */
.faq-wrap{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--ink-12)}
.faq-item:first-child{border-top:1px solid var(--ink-12)}
.faq-btn{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;background:none;border:none;cursor:pointer;padding:1.4rem 0;font-family:var(--ff-d);font-size:1.2rem;font-weight:700;color:var(--ink);text-align:left;transition:color .2s}
.faq-btn:hover{color:var(--blue)}
.faq-btn[aria-expanded="true"]{color:var(--blue)}
.faq-icon{width:28px;height:28px;flex-shrink:0;background:var(--surface);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:background .2s,transform .3s var(--spring)}
.faq-btn[aria-expanded="true"] .faq-icon{background:var(--blue);color:var(--white);transform:rotate(45deg)}
.faq-panel{overflow:hidden;max-height:0;transition:max-height .4s var(--expo)}
.faq-panel.open{max-height:400px}
.faq-panel-inner{padding:0 0 1.4rem;color:var(--steel);font-size:.97rem;line-height:1.75}

/* ==========================================================================
   CONTACT FORM
   ========================================================================== */
.contact-grid{display:grid;grid-template-columns:380px 1fr;gap:3rem;align-items:start;padding:96px 0}
@media(max-width:960px){.contact-grid{grid-template-columns:1fr}}
.cinfo-row{display:flex;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
.cinfo-row:last-child{border-bottom:none}
.cinfo-ico{width:44px;height:44px;flex-shrink:0;background:rgba(255,255,255,.06);border-radius:var(--r4);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--ice)}
.cinfo-row .clabel{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.35);display:block;margin-bottom:.15rem}
.cinfo-row a{color:var(--ice);font-size:1rem;font-weight:500;display:block}
.cinfo-row a:hover{color:var(--white)}
.cinfo-row .cplain{color:rgba(255,255,255,.55);font-size:1rem;display:block}
.form-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r16);padding:2.75rem}
@media(max-width:600px){.form-card{padding:1.75rem 1.25rem}}
.form-card-title{font-size:1.5rem;color:var(--white);margin-bottom:1.75rem}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:540px){.fgrid{grid-template-columns:1fr}}
.fgrid .fcol2{grid-column:span 2}
@media(max-width:540px){.fgrid .fcol2{grid-column:span 1}}
.field{display:flex;flex-direction:column;margin-bottom:1rem}
.field label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.45);margin-bottom:.4rem}
.field label .req{color:var(--rust);margin-left:.2rem}
.field input,.field textarea{background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.1);border-radius:var(--r4);padding:.75rem 1rem;color:var(--white);font-family:var(--ff-b);font-size:.97rem;transition:border-color .2s,background .2s,box-shadow .2s;-webkit-appearance:none;appearance:none}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.25)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);background:rgba(19,49,212,.12);box-shadow:0 0 0 3px rgba(19,49,212,.25)}
.field input.err,.field textarea.err{border-color:var(--rust)}
.field .ferr{font-size:.78rem;color:#ff8a75;margin-top:.3rem}
.field .fhint{font-size:.75rem;color:rgba(255,255,255,.3);margin-top:.3rem}
.field textarea{resize:vertical;min-height:120px}
.hp-field{display:none!important}
.gdpr-note{font-size:.78rem;color:rgba(255,255,255,.3);margin-top:.25rem;display:flex;align-items:flex-start;gap:.5rem}
.gdpr-note a{color:rgba(255,255,255,.45);text-decoration:underline}
.btn-submit{width:100%;background:var(--blue);color:var(--white);font-family:var(--ff-d);font-size:1.1rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:1rem 2rem;border:none;border-radius:var(--r4);display:flex;align-items:center;justify-content:center;gap:.6rem;cursor:pointer;position:relative;overflow:hidden;margin-top:1.25rem;transition:background .2s,transform .2s var(--spring),box-shadow .2s}
.btn-submit::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transform:translateX(-100%);transition:transform .5s}
.btn-submit:hover{background:var(--blue-mid);transform:translateY(-2px);box-shadow:0 8px 32px var(--blue-glow)}
.btn-submit:hover::before{transform:translateX(100%)}
.alert-ok{display:flex;align-items:flex-start;gap:.75rem;background:rgba(26,107,60,.2);border:1px solid rgba(26,107,60,.4);color:#6fcf97;border-radius:var(--r8);padding:1.25rem 1.5rem;font-weight:500;margin-bottom:1.25rem}
.alert-err{display:flex;align-items:flex-start;gap:.75rem;background:rgba(232,76,30,.15);border:1px solid rgba(232,76,30,.3);color:#ff8a75;border-radius:var(--r8);padding:1rem 1.25rem;font-size:.9rem;margin-bottom:1.25rem}

/* ==========================================================================
   FOOTER
   ========================================================================== */
footer{background:#070C1F;color:rgba(255,255,255,.45);padding:3rem 0 2rem;font-size:.875rem}
.footer-grid{display:grid;grid-template-columns:1fr 1.5fr 1fr;gap:3rem;margin-bottom:2.5rem}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:500px){.footer-grid{grid-template-columns:1fr}}
.footer-logo{height:40px;width:auto;margin-bottom:.75rem;filter:brightness(0)invert(1);opacity:.75;transition:opacity .2s;display:block}
.footer-logo:hover{opacity:1}
.footer-tagline{font-size:.82rem;line-height:1.6;max-width:240px}
.f-col-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.25);margin-bottom:1rem;display:block}
.footer-nav ul{list-style:none;display:flex;flex-direction:column;gap:.4rem}
.footer-nav a{color:rgba(255,255,255,.45);font-size:.875rem;transition:color .2s}
.footer-nav a:hover{color:var(--white)}
.footer-contact a{display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.45);font-size:.875rem;padding:.3rem 0;transition:color .2s}
.footer-contact a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.78rem}
.footer-bottom .copy{color:rgba(255,255,255,.4)}
.footer-bottom .domain{color:rgba(255,255,255,.2)}

/* SEO footer text */
.seo-footer{background:#040816;padding:2.5rem 0;border-top:1px solid rgba(255,255,255,.05)}
.seo-footer-inner{max-width:900px;margin:0 auto;text-align:center}
.seo-footer h2{font-size:1rem;color:rgba(255,255,255,.3);font-weight:600;margin-bottom:.75rem;font-family:var(--ff-b)}
.seo-footer p{font-size:.82rem;color:rgba(255,255,255,.2);line-height:1.7}
.seo-footer a{color:rgba(201,210,255,.4)}
.seo-footer a:hover{color:rgba(201,210,255,.7)}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
/* ==========================================================================
   HERO MOBILE  (v5.4.0)
   ========================================================================== */
@media(max-width:768px){
  .sec { padding:64px 0 }
  .eeat-signals { grid-template-columns:1fr 1fr }

  /* Hero: reduce padding, centre-align content */
  #hero { min-height:100svh; align-items:flex-start; }
  .hero-body { padding:2.5rem 0 7rem; }

  /* Logo smaller */
  .hero-logo { height:44px; margin-bottom:1.25rem; }

  /* Pill */
  .hero-pill { margin-bottom:1.25rem; }

  /* H1: tighter, no manual <br> breaks needed */
  .hero-h1 {
    font-size:clamp(2.6rem,11vw,4rem);
    line-height:.93;
    margin-bottom:1.25rem;
  }

  /* Sub */
  .hero-sub {
    font-size:.92rem;
    line-height:1.6;
    margin-bottom:2rem;
    color:rgba(255,255,255,.65);
  }

  /* CTAs: stack vertically, full width */
  .hero-ctas {
    flex-direction:column;
    gap:.65rem;
    margin-bottom:2.25rem;
  }
  .btn-p,
  .btn-g {
    width:100%;
    justify-content:center;
    padding:.85rem 1.25rem;
    font-size:.88rem;
  }

  /* Trust strip: 2-column grid */
  .hero-trust {
    gap:.65rem 1rem;
    padding-top:1.25rem;
    display:grid;
    grid-template-columns:1fr 1fr;
  }
  .trust-item { font-size:.72rem; gap:.35rem; }

  /* Decorative GS text — hide on small screens */
  .hero-deco { display:none; }

  /* Diagonal stripe smaller */
  .hero-stripe { height:64px; }
}

@media(max-width:480px){
  .eeat-signals { grid-template-columns:1fr }
  .phone-bar    { display:none }

  #hero { min-height:100svh; }
  .hero-body { padding:2rem 0 6rem; }

  .hero-logo { height:38px; margin-bottom:1rem; }

  .hero-pill { font-size:.62rem; margin-bottom:1rem; }

  .hero-h1 {
    font-size:clamp(2.2rem,10vw,3.2rem);
    margin-bottom:1rem;
  }
  /* Remove manual <br> wrapping on smallest screens */
  .hero-h1 br { display:none; }

  .hero-sub { font-size:.87rem; margin-bottom:1.75rem; }

  .btn-p,
  .btn-g { font-size:.85rem; padding:.8rem 1rem; }

  /* Trust: single column on very small */
  .hero-trust { grid-template-columns:1fr; gap:.5rem; }
  .trust-item { font-size:.7rem; }
}

@media(max-width:360px){
  .hero-h1 { font-size:2rem; }
  .hero-pill { display:none; }
}

/* ==========================================================================
   SERVICE CARD IMAGES  (v1.0.1 — added for SEO/AI image integration)
   ========================================================================== */
.svc-img {
  margin: 0 0 1.25rem;
  border-radius: 6px;
  overflow: hidden;
  aspect-ratio: 16/10;
  background: var(--surface);
  position: relative;
}
.svc-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s var(--expo);
}
.svc-card:hover .svc-img img { transform: scale(1.04); }
.svc-img-cap {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(10,26,99,.75));
  color: rgba(255,255,255,.9);
  font-size: .72rem; font-weight: 600;
  padding: .6rem .75rem .45rem;
  letter-spacing: .03em;
}
/* Remove svc-num when image present */
.svc-img ~ .svc-num { display: none; }

/* ==========================================================================
   ABOUT SECTION IMAGE
   ========================================================================== */
.about-img-wrap {
  margin: 0 0 1.5rem;
  border-radius: var(--r16);
  overflow: hidden;
  position: relative;
  box-shadow: 0 16px 48px rgba(10,26,99,.14);
}
.about-img {
  width: 100%; height: auto;
  display: block;
  aspect-ratio: 3/2;
  object-fit: cover;
}
.about-img-cap {
  display: block;
  margin-top: .5rem;
  font-size: .75rem;
  color: var(--steel);
  font-style: italic;
  text-align: center;
  line-height: 1.5;
}

/* ==========================================================================
   HERO BACKGROUND PHOTO
   ========================================================================== */
.hero-bg-photo {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 30%;
  opacity: .18;
  mix-blend-mode: luminosity;
  z-index: 0;
}

/* ==========================================================================
   PRELOAD HINT for hero image
   ========================================================================== */
/* Handled via fetchpriority="high" on <img> */

/* ==========================================================================
   SERVICE CARD FIGURE  (v4.8.0 — redesigned image blocks)
   ========================================================================== */
.svc-fig {
  margin: 0;
  position: relative;
  overflow: hidden;
  border-radius: 8px 8px 0 0;
  aspect-ratio: 800 / 520;
  background: linear-gradient(135deg, var(--blue-deep) 0%, #060e37 100%);
}
.svc-fig img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
  transition: transform .5s cubic-bezier(.25,.46,.45,.94);
}
.svc-card:hover .svc-fig img { transform: scale(1.05); }

.svc-fig--fallback {
  display: flex; align-items: center; justify-content: center;
  min-height: 160px;
}
.svc-fig--fallback::after {
  content: attr(aria-label);
  color: rgba(255,255,255,.25); font-size: .8rem; text-align: center; padding: 1rem;
}

.svc-fig__cap {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: .65rem .9rem .5rem;
  background: linear-gradient(transparent, rgba(4,9,42,.82));
  color: rgba(255,255,255,.88);
  font-size: .72rem; font-weight: 600; letter-spacing: .03em;
  display: flex; align-items: center; gap: .35rem;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.svc-fig__cap i { color: var(--ice); font-size: .8rem; }

.svc-body { padding: 1.25rem 1.5rem 1.5rem; flex: 1; display: flex; flex-direction: column; }

.svc-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border-radius: 6px;
  background: rgba(19,49,212,.1);
  color: var(--blue);
  font-size: .7rem; font-weight: 800;
  letter-spacing: .04em;
  margin-bottom: .75rem;
  font-family: 'Barlow Condensed', sans-serif;
}

.svc-tags {
  display: flex; flex-wrap: wrap; gap: .35rem;
  list-style: none; padding: 0; margin: .75rem 0 0;
}
.svc-tags li {
  font-size: .7rem; font-weight: 700;
  color: var(--blue); background: rgba(19,49,212,.08);
  border: 1px solid rgba(19,49,212,.15);
  border-radius: 4px; padding: .18rem .55rem;
  letter-spacing: .03em; white-space: nowrap;
}

/* Card flex layout so image is on top */
.svc-card { display: flex; flex-direction: column; }

/* ==========================================================================
   ABOUT FIGURE  (v4.8.0)
   ========================================================================== */
.about-fig {
  margin: 0 0 1.5rem;
  border-radius: var(--r16);
  overflow: hidden;
  position: relative;
  box-shadow: 0 16px 48px rgba(10,26,99,.15), 0 2px 8px rgba(10,26,99,.08);
  background: linear-gradient(135deg, var(--blue-deep) 0%, #060e37 100%);
  aspect-ratio: 760 / 520;
}
.about-fig__img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
}
.about-fig--fallback { min-height: 200px; }
.about-fig__cap {
  display: block;
  margin-top: .6rem;
  font-size: .78rem; color: var(--steel);
  line-height: 1.55; text-align: center;
}
.about-fig__cap strong { color: var(--blue-deep); }

/* ==========================================================================
   REFERENZEN GALLERY  (v4.8.0)
   ========================================================================== */
.ref-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.25rem;
}

.ref-fig {
  margin: 0;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  background: #060e37;
  box-shadow: 0 4px 24px rgba(10,26,99,.12);
  transition: transform .35s cubic-bezier(.25,.46,.45,.94),
              box-shadow .35s;
  cursor: default;
}
.ref-fig:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(10,26,99,.22);
}
.ref-fig img {
  width: 100%; height: 220px;
  object-fit: cover; object-position: center;
  display: block;
  transition: transform .5s cubic-bezier(.25,.46,.45,.94);
  aspect-ratio: 3/2;
}
.ref-fig:hover img { transform: scale(1.04); }
.ref-fig--fallback { min-height: 220px; display: flex; align-items: center; justify-content: center; }
.ref-fig--fallback::after {
  content: 'Foto folgt'; color: rgba(255,255,255,.2);
  font-size: .8rem; letter-spacing: .05em; text-transform: uppercase;
}

.ref-fig__cap {
  padding: .85rem 1rem;
  background: #fff;
  display: flex; flex-direction: column; gap: .15rem;
}
.ref-fig__title {
  font-size: .84rem; font-weight: 700; color: var(--ink);
  line-height: 1.3;
}
.ref-fig__sub {
  font-size: .72rem; color: var(--steel);
}

/* ==========================================================================
   HERO BACKGROUND PHOTO  (v4.8.0)
   ========================================================================== */
.hero-bg-photo {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 35%;
  opacity: .14;
  mix-blend-mode: luminosity;
  z-index: 0;
}

/* Responsive ref grid */
@media (max-width: 768px) {
  .ref-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .ref-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   KOSTEN & KALKULATION  (v4.9.0)
   ========================================================================== */

/* ── 3-column grid ── */
.kosten-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin-bottom: 2rem;
}
@media (max-width: 900px) { .kosten-grid { grid-template-columns: 1fr; } }
@media (min-width: 600px) and (max-width: 900px) { .kosten-grid { grid-template-columns: 1fr 1fr; } }

/* ── Card ── */
.kosten-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.kosten-card__head {
  padding: 1.1rem 1.25rem .85rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(19,49,212,.2);
}
.kosten-card__num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .12em;
  color: var(--ice);
  opacity: .5;
  display: block;
  margin-bottom: .2rem;
}
.kosten-card__title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.2rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #fff;
  margin: 0 0 .2rem;
}
.kosten-card__sub {
  font-size: .78rem;
  color: rgba(255,255,255,.45);
  margin: 0;
}

.kosten-card__body {
  padding: 1.1rem 1.25rem 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

/* ── Price block ── */
.kosten-price {
  background: rgba(0,0,0,.2);
  border-radius: 6px;
  padding: .65rem .9rem;
  display: flex;
  flex-direction: column;
  gap: .1rem;
}
.kosten-price--highlight {
  background: rgba(19,49,212,.25);
  border: 1px solid rgba(19,49,212,.4);
}
.kosten-price__label {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(255,255,255,.4);
}
.kosten-price__val {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.45rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: .02em;
  line-height: 1.1;
}
.kosten-price--highlight .kosten-price__val {
  color: var(--ice);
}
.kosten-price__note {
  font-size: .68rem;
  color: rgba(255,255,255,.35);
}

.kosten-card__hint {
  font-size: .78rem;
  color: rgba(255,255,255,.5);
  line-height: 1.55;
  margin: 0;
  display: flex;
  align-items: flex-start;
  gap: .4rem;
}
.kosten-card__hint i { color: var(--ice); flex-shrink: 0; margin-top: 2px; }
.kosten-card__hint strong { color: rgba(255,255,255,.75); }

/* ── Sonderteile table ── */
.kosten-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .8rem;
}
.kosten-table th {
  font-size: .66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: rgba(255,255,255,.4);
  padding: .4rem .5rem;
  border-bottom: 1px solid rgba(255,255,255,.1);
  text-align: left;
}
.kosten-table td {
  padding: .55rem .5rem;
  color: rgba(255,255,255,.75);
  border-bottom: 1px solid rgba(255,255,255,.06);
  vertical-align: top;
  line-height: 1.4;
}
.kosten-table td:last-child {
  white-space: nowrap;
  color: var(--ice);
  font-weight: 600;
  text-align: right;
}
.kosten-table tr:last-child td { border-bottom: none; }

/* ── Beispielkalkulation ── */
.kosten-beispiel {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 2rem;
}
.kosten-beispiel__head {
  background: rgba(19,49,212,.3);
  padding: .9rem 1.5rem;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #fff;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.kosten-beispiel__head i { color: var(--ice); }

.kosten-beispiel__grid {
  padding: 1rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.kb-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .6rem 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
  gap: 1rem;
}
.kb-row:last-child { border-bottom: none; }
.kb-label { font-size: .85rem; color: rgba(255,255,255,.65); }
.kb-val   { font-size: .9rem;  color: #fff; font-weight: 600; white-space: nowrap; }

.kb-row--total {
  border-top: 2px solid rgba(19,49,212,.5);
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin-top: .25rem;
  padding-top: .8rem;
}
.kb-row--total .kb-label { font-weight: 700; color: rgba(255,255,255,.85); }
.kb-val--total {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.35rem;
  color: var(--ice) !important;
  letter-spacing: .02em;
}
.kb-row--mwst .kb-label { font-size: .78rem; color: rgba(255,255,255,.35); }
.kb-row--mwst .kb-val   { font-size: .82rem; color: rgba(255,255,255,.45); }

.kosten-beispiel__tip {
  margin: 0;
  padding: .9rem 1.5rem;
  background: rgba(201,210,255,.06);
  border-top: 1px solid rgba(201,210,255,.12);
  font-size: .8rem;
  color: rgba(255,255,255,.55);
  line-height: 1.6;
  display: flex;
  align-items: flex-start;
  gap: .5rem;
}
.kosten-beispiel__tip i { color: var(--ice); flex-shrink: 0; margin-top: 2px; }
.kosten-beispiel__tip strong { color: rgba(255,255,255,.8); }
.kosten-beispiel__tip em { font-style: normal; color: var(--ice); }

/* ── CTA ── */
.kosten-cta {
  text-align: center;
  padding: 1rem 0 .5rem;
}
.kosten-cta p {
  color: rgba(255,255,255,.55);
  font-size: .9rem;
  margin-bottom: 1rem;
}

/* ==========================================================================
   FRÜHLINGS-AKTION  (v5.4.0)
   section.sec-promo > .container > .promo-poster (Bootstrap container)
   Photo 997x1266px portrait, parallax JS ±8%, overflow:hidden on poster
   WCAG ≥ 6:1:
     text-shadow black 8-dir stroke on any photo : 21:1 ✓
     white on #c62828 deep red                   : 7.1:1 ✓
     #fff on #1331D4 blue                        : 8.7:1 ✓
     #0C0F1A on white                            : 19.1:1 ✓
   ========================================================================== */

.sec-promo {
  padding: 3.5rem 0 4.5rem;
}

.promo-poster {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 64px rgba(10,26,99,.2), 0 4px 16px rgba(0,0,0,.12);
}

/* ── Parallax bg: px overshoot so % ambiguity never bites ───────────── */
.promo-bg {
  position: absolute;
  top:    -120px;
  bottom: -120px;
  left:   0;
  right:  0;
  z-index: 0;
  will-change: transform;
  pointer-events: none;
}
.promo-bg__img {
  width:  100%;
  height: 100%;
  object-fit: cover;
  object-position: center 18%;
  display: block;
}

/* ── Photo window ────────────────────────────────────────────────────── */
.promo-frame {
  position: relative;
  z-index: 1;
  height: 640px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* ── Headline ────────────────────────────────────────────────────────── */
.promo-top { padding: 1.75rem 2rem 0; }

.promo-h2 { margin: 0; line-height: .9; }

.promo-h2__line1,
.promo-h2__line2,
.promo-h2__line3 {
  display: block;
  font-family: 'Barlow Condensed', 'Arial Narrow', Arial, sans-serif;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .01em;
  text-shadow:
    -3px -3px 0 #000,  3px -3px 0 #000,
    -3px  3px 0 #000,  3px  3px 0 #000,
     0   -4px 0 #000,  0    4px 0 #000,
    -4px  0   0 #000,  4px  0   0 #000;
}
.promo-h2__line1,
.promo-h2__line2 {
  font-size: clamp(2.8rem, 5.5vw, 5.2rem);
  color: #e53e3e;
}
.promo-h2__line3 {
  font-size: clamp(3rem, 6.5vw, 6rem);
  color: #ffffff;
}

/* ── Bottom bar ──────────────────────────────────────────────────────── */
.promo-bottom-bar { display: flex; align-items: stretch; }

.promo-mietfrei {
  background: #c62828;
  color: #fff;
  padding: 1.1rem 1.5rem;
  min-width: 185px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: .05rem;
}
.promo-mietfrei strong {
  display: block;
  font-family: 'Barlow Condensed', 'Arial Narrow', Arial, sans-serif;
  font-size: 1.35rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
  line-height: 1.05;
  color: #fff;
}
.promo-termin {
  flex: 1;
  background: #c62828;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-family: 'Barlow Condensed', 'Arial Narrow', Arial, sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.5rem);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 1rem 1.5rem;
  border-left: 2px solid rgba(255,255,255,.2);
  transition: background .18s;
}
.promo-termin:hover { background: #9b1c1c; color: #fff; }

/* ── White price strip ───────────────────────────────────────────────── */
.promo-prices-panel {
  position: relative;
  z-index: 1;
  background: #ffffff;
  padding: 1.5rem 2rem 1.75rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.promo-prices-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .08rem;
  flex: 1;
  min-width: 200px;
}
.promo-prices-list li {
  display: flex;
  align-items: baseline;
  gap: .45rem;
  font-size: clamp(.95rem, 2vw, 1.15rem);
  line-height: 1.65;
  color: #0C0F1A;
}
.ppl-range { font-weight: 600; min-width: 108px; flex-shrink: 0; }
.ppl-price { font-weight: 700; }

.ppl-note {
  font-size: .72rem;
  color: #64748b;
  margin: .3rem 0 0;
}

/* Right side: chip + CTA button */
.promo-panel-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .65rem;
  flex-shrink: 0;
}
.promo-panel-chip {
  background: #c62828;
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: .3rem .85rem;
  border-radius: 5px;
  white-space: nowrap;
}
.ppl-cta {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: var(--blue);
  color: #fff;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: .75rem 1.5rem;
  border-radius: 7px;
  text-decoration: none;
  white-space: nowrap;
  transition: background .18s, transform .15s;
}
.ppl-cta:hover {
  background: var(--blue-deep);
  color: #fff;
  transform: translateY(-1px);
}

/* ── Reduced motion ─────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .promo-bg { top: 0; bottom: 0; will-change: auto; transform: none !important; }
  .ppl-cta:hover { transform: none; }
}

/* ── Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 992px) {
  .promo-frame { height: 560px; }
}
@media (max-width: 768px) {
  .sec-promo   { padding: 2rem 0 3rem; }
  .promo-frame { height: 480px; }
  .promo-top   { padding: 1.35rem 1.35rem 0; }
  .promo-mietfrei { min-width: 150px; padding: .9rem 1rem; }
  .promo-mietfrei strong { font-size: 1.1rem; }
  .promo-prices-panel { flex-direction: column; align-items: stretch; }
  .promo-panel-right  { align-items: stretch; }
  .ppl-cta { justify-content: center; }
}
@media (max-width: 480px) {
  .promo-poster { border-radius: 10px; }
  .promo-frame  { height: 400px; }
  .promo-mietfrei { min-width: 130px; }
}

/* ==========================================================================
   KOSTEN & KALKULATION  (v4.9.0)
   ========================================================================== */

/* ── 3-column grid ── */
.kosten-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin-bottom: 2rem;
}
@media (max-width: 900px) { .kosten-grid { grid-template-columns: 1fr; } }
@media (min-width: 600px) and (max-width: 900px) { .kosten-grid { grid-template-columns: 1fr 1fr; } }

/* ── Card ── */
.kosten-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.kosten-card__head {
  padding: 1.1rem 1.25rem .85rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(19,49,212,.2);
}
.kosten-card__num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .12em;
  color: var(--ice);
  opacity: .5;
  display: block;
  margin-bottom: .2rem;
}
.kosten-card__title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.2rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #fff;
  margin: 0 0 .2rem;
}
.kosten-card__sub {
  font-size: .78rem;
  color: rgba(255,255,255,.45);
  margin: 0;
}

.kosten-card__body {
  padding: 1.1rem 1.25rem 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

/* ── Price block ── */
.kosten-price {
  background: rgba(0,0,0,.2);
  border-radius: 6px;
  padding: .65rem .9rem;
  display: flex;
  flex-direction: column;
  gap: .1rem;
}
.kosten-price--highlight {
  background: rgba(19,49,212,.25);
  border: 1px solid rgba(19,49,212,.4);
}
.kosten-price__label {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(255,255,255,.4);
}
.kosten-price__val {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.45rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: .02em;
  line-height: 1.1;
}
.kosten-price--highlight .kosten-price__val {
  color: var(--ice);
}
.kosten-price__note {
  font-size: .68rem;
  color: rgba(255,255,255,.35);
}

.kosten-card__hint {
  font-size: .78rem;
  color: rgba(255,255,255,.5);
  line-height: 1.55;
  margin: 0;
  display: flex;
  align-items: flex-start;
  gap: .4rem;
}
.kosten-card__hint i { color: var(--ice); flex-shrink: 0; margin-top: 2px; }
.kosten-card__hint strong { color: rgba(255,255,255,.75); }

/* ── Sonderteile table ── */
.kosten-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .8rem;
}
.kosten-table th {
  font-size: .66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: rgba(255,255,255,.4);
  padding: .4rem .5rem;
  border-bottom: 1px solid rgba(255,255,255,.1);
  text-align: left;
}
.kosten-table td {
  padding: .55rem .5rem;
  color: rgba(255,255,255,.75);
  border-bottom: 1px solid rgba(255,255,255,.06);
  vertical-align: top;
  line-height: 1.4;
}
.kosten-table td:last-child {
  white-space: nowrap;
  color: var(--ice);
  font-weight: 600;
  text-align: right;
}
.kosten-table tr:last-child td { border-bottom: none; }

/* ── Beispielkalkulation ── */
.kosten-beispiel {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 2rem;
}
.kosten-beispiel__head {
  background: rgba(19,49,212,.3);
  padding: .9rem 1.5rem;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #fff;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.kosten-beispiel__head i { color: var(--ice); }

.kosten-beispiel__grid {
  padding: 1rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.kb-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .6rem 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
  gap: 1rem;
}
.kb-row:last-child { border-bottom: none; }
.kb-label { font-size: .85rem; color: rgba(255,255,255,.65); }
.kb-val   { font-size: .9rem;  color: #fff; font-weight: 600; white-space: nowrap; }

.kb-row--total {
  border-top: 2px solid rgba(19,49,212,.5);
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin-top: .25rem;
  padding-top: .8rem;
}
.kb-row--total .kb-label { font-weight: 700; color: rgba(255,255,255,.85); }
.kb-val--total {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.35rem;
  color: var(--ice) !important;
  letter-spacing: .02em;
}
.kb-row--mwst .kb-label { font-size: .78rem; color: rgba(255,255,255,.35); }
.kb-row--mwst .kb-val   { font-size: .82rem; color: rgba(255,255,255,.45); }

.kosten-beispiel__tip {
  margin: 0;
  padding: .9rem 1.5rem;
  background: rgba(201,210,255,.06);
  border-top: 1px solid rgba(201,210,255,.12);
  font-size: .8rem;
  color: rgba(255,255,255,.55);
  line-height: 1.6;
  display: flex;
  align-items: flex-start;
  gap: .5rem;
}
.kosten-beispiel__tip i { color: var(--ice); flex-shrink: 0; margin-top: 2px; }
.kosten-beispiel__tip strong { color: rgba(255,255,255,.8); }
.kosten-beispiel__tip em { font-style: normal; color: var(--ice); }

/* ── CTA ── */
.kosten-cta {
  text-align: center;
  padding: 1rem 0 .5rem;
}
.kosten-cta p {
  color: rgba(255,255,255,.55);
  font-size: .9rem;
  margin-bottom: 1rem;
}

/* ==========================================================================
   FRÜHLINGS-AKTION — Parallax + Poster design  (v5.1.0)
   Contrast check (WCAG, min 6:1):
     white on red  #991b1b : 8.3:1  ✓
     black on #FDE047       : 14.1:1 ✓
     white on dark overlay  : 15.7:1 ✓
     #0C0F1A on white       : 19.1:1 ✓
   ========================================================================== */

/* ── Section wrapper ─────────────────────────────────────────────────── */
.sec-promo {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* ── Parallax photo ──────────────────────────────────────────────────── */
.promo-bg {
  position: absolute;
  inset: -20% 0;            /* vertical overshoot for parallax range */
  z-index: 0;
  will-change: transform;
  pointer-events: none;
}
.promo-bg__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
}

/* ── Frame: sits over the photo ──────────────────────────────────────── */
.promo-frame {
  position: relative;
  z-index: 1;
  min-height: 680px;        /* visible photo area */
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* ── Headline — top-left, big + bold, poster style ───────────────────── */
.promo-top {
  padding: 2rem 1.75rem 0;
}

.promo-h2 {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  line-height: .95;
}

/* Line 1: FRÜHLINGS- */
.promo-h2__line1 {
  font-family: 'Barlow Condensed', Arial, sans-serif;
  font-size: clamp(3rem, 9vw, 5.5rem);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .01em;
  color: #c81b1b;            /* red on photo — dark enough for contrast */
  text-shadow:
    3px  3px 0 #000,
   -2px -2px 0 #000,
    2px -2px 0 #000,
   -2px  2px 0 #000;
  display: block;
}

/* Line 2: ANGEBOT */
.promo-h2__line2 {
  font-family: 'Barlow Condensed', Arial, sans-serif;
  font-size: clamp(3rem, 9vw, 5.5rem);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .01em;
  color: #c81b1b;
  text-shadow:
    3px  3px 0 #000,
   -2px -2px 0 #000,
    2px -2px 0 #000,
   -2px  2px 0 #000;
  display: block;
}

/* Line 3: GERÜSTBAU — white with dark shadow */
.promo-h2__line3 {
  font-family: 'Barlow Condensed', Arial, sans-serif;
  font-size: clamp(3.2rem, 10vw, 6.2rem);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .01em;
  color: #ffffff;            /* white on photo + shadow: effectively 21:1 ✓ */
  text-shadow:
    4px  4px 0 #000,
   -3px -3px 0 #000,
    3px -3px 0 #000,
   -3px  3px 0 #000;
  display: block;
}

/* ── Bottom bar: badge + CTA ─────────────────────────────────────────── */
.promo-bottom-bar {
  display: flex;
  align-items: stretch;
  gap: 0;
  margin: 0;
}

/* Red badge — left */
.promo-mietfrei {
  background: #991b1b;       /* white on #991b1b: 8.3:1 ✓ */
  color: #ffffff;
  padding: 1rem 1.35rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: .1rem;
  border-radius: 10px 0 0 0;
  min-width: 180px;
  flex-shrink: 0;
}
.promo-mietfrei strong {
  font-family: 'Barlow Condensed', Arial, sans-serif;
  font-size: 1.35rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
  line-height: 1.05;
  color: #ffffff;
  display: block;
}

/* CTA button — right, fills remaining space */
.promo-termin {
  flex: 1;
  background: #991b1b;       /* white on #991b1b: 8.3:1 ✓ */
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Barlow Condensed', Arial, sans-serif;
  font-size: clamp(1.5rem, 4vw, 2.2rem);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
  text-decoration: none;
  padding: 1rem 1.5rem;
  transition: background .2s, transform .15s;
  border-left: 3px solid rgba(255,255,255,.2);
}
.promo-termin:hover {
  background: #7f1d1d;
  color: #fff;
  transform: scaleX(1.01);
}

/* ── White prices panel — below photo ───────────────────────────────── */
.promo-prices-panel {
  background: #ffffff;
  padding: 1.35rem 1.75rem 1.75rem;
  position: relative;
  z-index: 1;
}

.promo-prices-list {
  list-style: none;
  padding: 0;
  margin: 0 0 .65rem;
  display: flex;
  flex-direction: column;
  gap: .15rem;
}
.promo-prices-list li {
  display: flex;
  align-items: baseline;
  gap: .5rem;
  font-size: clamp(1rem, 3vw, 1.25rem);
  line-height: 1.6;
  color: #0C0F1A;            /* #0C0F1A on white: 19.1:1 ✓ */
}
.ppl-range {
  font-weight: 600;
  min-width: 120px;
  flex-shrink: 0;
}
.ppl-price {
  font-weight: 700;
  color: #0C0F1A;
}

.ppl-note {
  font-size: .78rem;
  color: #64748b;            /* #64748b on white: 4.6:1 — decorative/small ✓ */
  margin: 0 0 1.1rem;
}

.ppl-cta {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  width: 100%;
  justify-content: center;
  padding: .85rem 1.5rem;
  font-size: 1rem;
}

/* ── Parallax reduced-motion ─────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .promo-bg { position: absolute; inset: 0; }
}

/* ── Mobile ──────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .promo-frame { min-height: 520px; }
  .promo-top   { padding: 1.5rem 1.1rem 0; }
  .promo-mietfrei { min-width: 140px; padding: .85rem 1rem; }
  .promo-mietfrei strong { font-size: 1.1rem; }
}


