:root {
  --container: 1100px;
  --scrollbar-inline: calc(100vw - 100%);
  --space-1: .375rem; --space-2: .75rem; --space-3: 1.25rem; --space-4: 2rem; --space-5: 3rem; --space-6: 5rem;
  --brand: #d90429; /* fire brigade red */
  --ink: #0f172a;  /* text on light */
  --ink-2: #475569; /* muted on light */
  --bg: #eef2f8;   /* light base with tint */
  --card: #f9fbff; /* soft surfaces */
  --card-rgb: 249, 251, 255;
  --glass-rgb: 244, 248, 255;
  --glass-strong-rgb: 233, 239, 252;
  --header-h: 64px;
}
* { box-sizing: border-box; }
html, body { height: 100%; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Inter, system-ui, Arial, sans-serif; color: var(--ink); background: var(--bg); }

.container { width: min(100% - 2rem, var(--container)); margin-inline: auto; }

/* Header */
.site-header { position: fixed; inset: 0 0 auto 0; height: var(--header-h); z-index: 1500; background: rgba(var(--glass-rgb), .55); border-bottom: 1px solid rgba(var(--glass-strong-rgb), .65); box-shadow: 0 18px 60px rgba(15,23,42,.12), inset 0 1px 0 rgba(var(--glass-strong-rgb), .7); backdrop-filter: blur(18px) saturate(180%); -webkit-backdrop-filter: blur(18px) saturate(180%); isolation: isolate; transition: background .2s ease, border-color .2s ease, box-shadow .2s ease; }
.site-header::before { content:""; position:absolute; inset:0; background: radial-gradient(130% 150% at 15% -45%, rgba(var(--glass-rgb), .65), transparent 58%), radial-gradient(80% 140% at 80% 140%, rgba(217,4,41,.16), transparent 65%), linear-gradient(120deg, rgba(var(--glass-rgb), .35), rgba(var(--glass-rgb), .08)); opacity:.95; pointer-events:none; z-index:0; }
.header-inner { display:flex; align-items:center; justify-content:space-between; min-height: var(--header-h); padding: 0; position: relative; z-index: 1; }
.logo { color: var(--ink); text-decoration:none; font-weight:800; letter-spacing:.2px; display:inline-flex; align-items:center; gap:.7rem }
.logo-img { height: 48px; width: auto; display:block }
.logo-title { font-weight: 800; font-size: 1.05rem; letter-spacing: .2px; color: var(--ink) }
@media (max-width: 480px) { .logo-img { height: 40px } }
.nav { display:flex; gap: 1.25rem; align-items:center; padding: 0; background: transparent; border:0; box-shadow: none; }
.nav a { color:#0f172a; text-decoration:none; opacity:.9; transition: color .18s ease, opacity .18s ease, background-color .18s ease, border-color .18s ease, box-shadow .18s ease; }
.nav a:hover { opacity:1; color:#111827; }
/* Subtle underline indicator for nav links (B2B-friendly) */
.nav a { position: relative }
.nav a:not(.btn) { padding:.35rem .85rem; border-radius: 10px; transition: color .18s ease; }
.nav a:not(.btn):hover,
.nav a:not(.btn):focus-visible { color: #0c1120; }
.nav a:not(.btn)::after { content:""; position:absolute; left:.85rem; right:.85rem; bottom:.25rem; height: 2px; border-radius:999px; background: currentColor; opacity: 0; transform: scaleX(.3); transform-origin: left; transition: transform .18s ease, opacity .18s ease; }
.nav a:not(.btn):hover::after,
.nav a:not(.btn):focus-visible::after { opacity: .7; transform: scaleX(1); }

.site-footer { border-top:1px solid #d7e2f0; background:#e6ecf7; }
.footer-inner { display:flex; align-items:center; justify-content:space-between; padding: 1.25rem 0; font-size:.95rem; color:#475569 }
.footer-brand { display:flex; align-items:center; gap:.6rem }
.logo-small { height: 24px; width:auto; display:block }
.footer-links a { color:#9eaec6; text-decoration:none; margin-left:1rem }
.footer-links a:hover { color:#0f172a }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:.5rem; padding:.7rem 1.1rem; border-radius:.6rem; text-decoration:none; font-weight:600; }
.btn-primary { background: linear-gradient(135deg, #ef233c, #d90429); color:#fff; box-shadow: 0 6px 18px rgba(217,4,41,.25); }
.btn-primary:hover { filter: brightness(1.06); }
.btn-secondary { background: transparent; color:#0f172a; border:1px solid #cbd5e1 }
.btn-secondary:hover { background: rgba(0,0,0,.04); }
.btn-cta-ghost { font-weight: 800; border-radius: 12px; padding: .9rem 1.2rem; border-width: 1.5px; }
.btn-cta-ghost:hover { background: rgba(255,255,255,.12); }
.muted { color:#94a3b8; font-size:.9rem }

/* Focus states for accessibility */
.btn:focus, input:focus, textarea:focus { outline: 2px solid var(--brand); outline-offset: 2px; }

/* Sections */
.section { position: relative; padding: var(--space-6) 0; }
.section.alt { padding: calc(var(--space-6) + 2rem) 0; }
.page-hero { padding: calc(var(--space-6) + 3rem) 0; }

/* Fixed background utility */
.bg-fixed {
  background-image: var(--bg);
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  isolation: isolate;
  color: #fff; /* ensure readable text on images */
}
.overlay { position:absolute; inset:0; background: linear-gradient(180deg, rgba(6,9,18,.55), rgba(6,9,18,.8)); z-index:-1; }

/* Fancy side shadow for the hero */
.hero > .overlay {
  background:
    /* base vertical darkening */
    linear-gradient(180deg, rgba(6,9,18,.56), rgba(6,9,18,.84)),
    /* deep right-side vignette */
    radial-gradient(70% 120% at 115% 50%, rgba(6,9,18,.86), transparent 55%),
    /* angular sweep from right */
    conic-gradient(from 260deg at 110% 50%, rgba(6,9,18,.52), rgba(6,9,18,0) 70%),
    /* subtle brand glow edge */
    radial-gradient(40% 60% at 105% 55%, rgba(217,4,41,.16), transparent 60%),
    /* soft left balance */
    radial-gradient(85% 100% at -15% 50%, rgba(6,9,18,.22), transparent 60%);
}
@media (min-width: 900px) {
  .hero > .overlay {
    background:
      linear-gradient(180deg, rgba(6,9,18,.56), rgba(6,9,18,.86)),
      /* stronger right vignette */
      radial-gradient(60% 120% at 114% 50%, rgba(6,9,18,.9), transparent 58%),
      /* angled side shadow sweep */
      linear-gradient(74deg, rgba(6,9,18,.46) 0%, rgba(6,9,18,0) 48%),
      /* brand accent a touch stronger on desktop */
      radial-gradient(38% 58% at 105% 55%, rgba(217,4,41,.19), transparent 60%),
      radial-gradient(80% 100% at -12% 50%, rgba(6,9,18,.24), transparent 60%);
  }
}

/* Mobile fallback: disable attachment: fixed for smoother scroll */
@media (max-width: 1024px) {
  .bg-fixed { background-attachment: scroll; }
}

/* Hero */
.hero { min-height: 100vh; min-height: 100svh; display:grid; place-items:center; text-align:center; }
.hero-inner { display:grid; gap: 1.5rem; max-width: 960px; margin-inline:auto; position: relative }
.hero h1 { font-size: clamp(2rem, 4vw + 1rem, 3rem); margin:0; line-height: 1.15; }
.hero p { color:#eef2f6; margin: .25rem auto 0; max-width: 60ch; }
.cta { display:flex; gap: .9rem; justify-content:center; margin-top: .5rem; flex-wrap:wrap }
.hero .cta { margin-top: 1.25rem; }

/* Main layout offset for fixed header */
.site-main { padding-top: var(--header-h); }
.site-main .hero:first-child { margin-top: calc(-1 * var(--header-h)); }

/* Header scroll-state polish */
.site-header.scrolled { background: rgba(var(--glass-rgb), .85); box-shadow: 0 22px 55px rgba(15,23,42,.18), inset 0 1px 0 rgba(var(--glass-strong-rgb), .95); border-bottom-color: rgba(var(--glass-strong-rgb), .9); }
.site-header.scrolled::before { opacity: 1; }

/* Hero glass box */
.hero-box { position: relative; z-index: 1; padding: 1.9rem 1.9rem 2.1rem; border-radius: 18px; background: rgba(var(--glass-rgb), .12); border: 1px solid rgba(var(--glass-strong-rgb), .32); backdrop-filter: blur(12px) saturate(120%); box-shadow: 0 24px 60px rgba(2,6,23,.55), 0 0 0 1px rgba(var(--glass-strong-rgb), .2) inset, 0 0 48px rgba(217,4,41,.12); display:grid; gap: .9rem }
.hero .tagline { margin-top: .25rem; }
.badge-glass { position:absolute; top: -12px; left: -12px; padding:.35rem .65rem; border-radius:999px; font-weight:800; letter-spacing:.3px; color:#fff; background: rgba(217,4,41,.18); border:1px solid rgba(217,4,41,.5); box-shadow: 0 6px 18px rgba(0,0,0,.25) }

/* Spotlight behind hero content */
.hero-inner { position: relative }
.hero-inner::before { content:""; position: absolute; left: 50%; top: 46%; transform: translate(-50%, -50%); width: min(92vw, 980px); height: min(60vh, 520px); pointer-events: none; z-index: 0; filter: blur(12px);
  background:
    radial-gradient(closest-side, rgba(var(--glass-rgb), .24), rgba(var(--glass-rgb), 0) 70%),
    radial-gradient(35% 35% at 56% 38%, rgba(217,4,41,.14), transparent 72%);
}
.hero-box h1 { text-shadow: 0 2px 14px rgba(0,0,0,.35), 0 1px 2px rgba(0,0,0,.6) }
.hero-box p { text-shadow: 0 1px 2px rgba(0,0,0,.45) }

/* Hero split: content left, logo right */
.hero-box.hero-split { grid-template-columns: 1.2fr .8fr; align-items: center; }
.hero-box.hero-split .hero-content { display: grid; gap: .9rem; }
.hero-box.hero-split .hero-visual { display: grid; place-items: center; }
.brand-mark { width: clamp(140px, 26vw, 280px); height: auto; opacity: .25; filter: drop-shadow(0 6px 18px rgba(0,0,0,.3)); user-select: none; pointer-events: none; }
@media (max-width: 900px) {
  .hero-box.hero-split { grid-template-columns: 1fr; }
  .hero-box.hero-split .hero-visual { order: 2; }
  .hero-box.hero-split .hero-content { order: 1; }
  .brand-mark { width: clamp(120px, 44vw, 220px); opacity: .25; }
}

@media (min-width: 900px) {
  .hero { text-align: left }
  .hero p { margin-left: 0 }
  .cta { justify-content: flex-start }
}

/* Hero decorative logo */
.hero-logo {
  position: absolute;
  left: 50%;
  top: 46%;
  transform: translate(-50%, -50%);
  width: clamp(260px, 42vw, 560px);
  height: auto;
  opacity: .08;
  filter: blur(1.5px) drop-shadow(0 8px 24px rgba(0,0,0,.25));
  mix-blend-mode: multiply;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
@media (max-width: 600px) {
  .hero-logo { opacity: .06; width: min(64vw, 360px); top: 48%; }
}

/* Kicker & tagline */
.pill { display:inline-block; background: var(--brand); color:#fff; padding:.3rem .6rem; border-radius:999px; font-weight:700; font-size:.85rem; letter-spacing:.3px }
.tagline { font-weight:800; color: var(--brand) }

/* CTA Tiles (Kachel-CTA) */
.cta-tiles { padding: 0; }
.cta-tile { position: relative; overflow: hidden; background:
  radial-gradient(1000px 500px at 85% 0%, rgba(255,255,255,.06), transparent 60%),
  linear-gradient(180deg, #0d1322 0%, #0a0f1d 100%);
  color:#fff; border-radius: 0; border-top:1px solid #101826; border-bottom:1px solid #101826; box-shadow: inset 0 1px 0 rgba(255,255,255,.04); padding: 2rem 0; }
.cta-tile::before { content:""; position:absolute; inset:0; pointer-events:none; background: linear-gradient(180deg, rgba(255,255,255,.06), transparent 30%); }
.cta-tile-head { display:grid; gap:.35rem; text-align:left; }
.cta-tile-head h2 { margin: 0; font-size: clamp(1.4rem, 1.4vw + 1rem, 1.9rem) }
.cta-tile-head p { margin:.1rem 0 0; color:#dbe3f3 }

/* New split layout: left text box, right dominant CTA */
.cta-split { display:grid; grid-template-columns: 1.2fr .8fr; align-items:center; gap: 1.25rem; }
.cta-left { display:block }
.cta-right { display:grid; gap:.35rem; justify-items:end; justify-self:end; align-self:center; text-align:right; max-width: 520px; }
.btn-cta-lg { padding: .95rem 1.3rem; font-size: 1.05rem; font-weight: 800; border-radius: 12px; box-shadow: 0 16px 44px rgba(217,4,41,.35); line-height: 1.05; }
.cta-sub { color:#dbe3f3; font-size: .92rem; line-height: 1.35; max-width: 34ch; }
@media (max-width: 900px) {
  .cta-split { grid-template-columns: 1fr; }
  .cta-right { justify-items: start; justify-self: start; text-align: left; max-width: none }
  .btn-cta-lg { width: 100%; text-align: center }
}

/* Feature band (Praxis statt Theorie) */
.feature-band { display:grid; justify-items:start; padding: 1rem 0; }
.glass-panel { color:#fff; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.22); border-radius: 16px; padding: 1.25rem 1.5rem; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); box-shadow: 0 16px 40px rgba(0,0,0,.35); max-width: 900px }
.feature-band .chips { display:flex; gap:.5rem; flex-wrap:wrap; margin-top:.35rem }
.feature-band .chip { display:inline-flex; align-items:center; padding:.35rem .6rem; border-radius: 999px; border:1px solid rgba(255,255,255,.35); background: rgba(255,255,255,.06); color:#fff; font-weight:700; font-size:.85rem }
@media (max-width: 900px) { .feature-band { justify-items:center; text-align:center } .glass-panel { text-align: left; max-width: 100% } }

/* Feature band split layout */
.glass-panel.glass-split { display:grid; grid-template-columns: 1.2fr .8fr; align-items:center; gap: 1rem }
.gp-right { justify-self: start; display:grid; gap:.4rem; }
@media (max-width: 900px) {
  .glass-panel.glass-split { grid-template-columns: 1fr }
  .gp-right { justify-self: start }
}

/* Checklist in feature band */
.checklist { list-style:none; padding:0; margin:.6rem 0 0; display:grid; gap:.35rem }
.checklist li { display:flex; align-items:flex-start; gap:.5rem; color:#e6edf7; font-weight:600 }
.checklist li::before { content:"✓"; color:#22c55e; font-weight:800; margin-top:.05rem }
.assure { color:#dbe3f3; font-weight:700; font-size:.95rem }
@media (max-width: 520px) { .gp-right .btn-cta-lg { width:100%; justify-content:center } }
@media (max-width: 520px) { .gp-right .btn-cta-ghost { width:100%; justify-content:center } }

/* Generic chips (light surfaces) */
.chips { display:flex; gap:.5rem; flex-wrap:wrap; margin-top:.35rem }
.chip { display:inline-flex; align-items:center; gap:.35rem; padding:.35rem .6rem; border-radius:999px; background: var(--card); border:1px solid rgba(var(--glass-strong-rgb), .55); color:#0f172a; font-weight:700; font-size:.85rem }
.chip svg { opacity:.8 }

/* Button contrast on dark surfaces */
.bg-fixed .btn-secondary,
.cta-tile .btn-secondary {
  color: #fff;
  border-color: rgba(255,255,255,.5);
}
.bg-fixed .btn-secondary:hover,
.cta-tile .btn-secondary:hover {
  background: rgba(255,255,255,.12);
}
.bg-fixed .btn-cta-ghost:hover { border-color: rgba(217,4,41,.75); box-shadow: 0 10px 28px rgba(0,0,0,.25); }

/* Floating CTA */
.fab-cta {
  position: fixed; right: 1rem; bottom: 1rem; z-index: 50;
  background: linear-gradient(135deg, #ef233c, #d90429); color:#fff;
  padding:.85rem 1rem; border-radius: 999px; text-decoration:none; font-weight:700;
  box-shadow: 0 10px 30px rgba(217,4,41,.35);
}
.fab-cta:hover { filter: brightness(1.06); }

/* Footer contact section */
.footer-contact { background: linear-gradient(180deg, #eef3fb, #e3eaf5); border-top: 1px solid #d5e0f0; border-bottom: 1px solid #d5e0f0; padding: calc(var(--space-6) - .5rem) 0; }
.footer-contact { scroll-margin-top: var(--header-h); }
.footer-contact-inner { display:grid; }
.footer-card { background: var(--card); border:1px solid rgba(var(--glass-strong-rgb), .6); border-radius: 16px; padding: 1rem; box-shadow: 0 16px 40px rgba(2,6,23,.08) }
.footer-card-head { display:flex; align-items:flex-start; justify-content:space-between; gap: 1rem; margin-bottom: 1rem }
.footer-card-head h2 { margin: .2rem 0 .25rem; font-size: clamp(1.25rem, 1vw + 1rem, 1.5rem) }
.footer-card-head p { margin: 0; color: var(--ink-2) }
.badge.brand { display:inline-block; font-weight:800; color:#fff; background: var(--brand); border-radius: 999px; padding: .25rem .55rem; font-size:.8rem; letter-spacing:.3px }

.footer-card-grid { display:grid; grid-template-columns: 1.2fr .8fr; gap: 1rem; align-items: start }
.footer-left { display:grid; gap: 1rem }
.footer-form { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; align-items:start }
.footer-form .full { grid-column: 1 / -1 }
.footer-form .form-actions { grid-column: 1 / -1; display:flex; align-items:center; gap:.75rem }
@media (max-width: 900px) { .footer-card-grid { grid-template-columns: 1fr } }
@media (max-width: 720px) { .footer-form { grid-template-columns: 1fr } }

.footer-map { height: 100%; min-height: 460px; display:grid; gap:.5rem; align-content:stretch }
.map-frame { width:100%; height: 100%; min-height: 460px; border: 0; border-radius: 12px; box-shadow: 0 12px 30px rgba(2,6,23,.08); border:1px solid rgba(var(--glass-strong-rgb), .55) }
.map-note { font-size:.9rem }
.map-note a { color: var(--brand); text-decoration: none }
.map-note a:hover { text-decoration: underline }
.embed-placeholder { border:1px dashed #cbd5e1; border-radius: 12px; padding: 1.25rem; background: var(--bg); color: var(--ink-2); display:grid; gap:.9rem; align-content:start; min-height: 460px; box-shadow: inset 0 0 0 1px rgba(var(--glass-rgb), .6) }
.embed-actions { display:flex; flex-wrap:wrap; gap:.75rem }
.embed-content[hidden] { display:none !important; }
.embed-placeholder[hidden] { display:none !important; }
.embed-placeholder .btn { width: fit-content; }

/* Content blocks */
.grid-3 { display:grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 900px) { .grid-3 { grid-template-columns: 1fr; } }
.grid-2 { display:grid; gap: 1rem; grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 900px) { .grid-2 { grid-template-columns: 1fr; } }
.card { background: var(--card); border:1px solid rgba(var(--glass-strong-rgb), .55); border-radius: .9rem; padding: 1.25rem; box-shadow: 0 8px 24px rgba(15,23,42,.08) }
.card h3 { margin-top:0 }

/* Unified subtle hover for boxes/containers (B2B-friendly) */
.card,
.footer-card,
.review-card,
.photo-card,
.service-panel,
.glass-panel,
.hero-box {
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background-color .18s ease;
}
.card:hover,
.footer-card:hover,
.review-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 40px rgba(2,6,23,.12);
  border-color: #e2e8f0;
}
.photo-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 46px rgba(2,6,23,.16);
}
.service-panel:hover,
.glass-panel:hover,
.hero-box:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 60px rgba(0,0,0,.42), 0 0 0 2px rgba(217,4,41,.22) inset;
  border-color: rgba(255,255,255,.38);
}
@media (prefers-reduced-motion: reduce) {
  .card, .footer-card, .review-card, .photo-card, .service-panel, .glass-panel, .hero-box { transition: none !important; }
}

/* Home features (3 Karten) */
.features { background: linear-gradient(180deg, #eef3fb, #e7edf6); border-top:1px solid #d5e0f0; border-bottom:1px solid #d5e0f0 }
.feature-card { background: var(--card); border:1px solid rgba(var(--glass-strong-rgb), .6); border-radius: 16px; padding: 1.1rem 1.1rem 1.1rem; box-shadow: 0 10px 26px rgba(2,6,23,.06); display:grid; grid-template-rows: auto auto 1fr auto; gap:.6rem; transition: box-shadow .2s ease, transform .2s ease }
.feature-card:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(2,6,23,.12); border-color:#e2e8f0 }

/* Brand accent lines on hover (subtle, B2B) */
.card, .feature-card, .review-card, .footer-card, .photo-card { position: relative }
.card::after,
.feature-card::after,
.review-card::after,
.footer-card::after,
.photo-card::after {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--brand), rgba(217,4,41,0) 70%);
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity .18s ease, transform .18s ease;
}
.card:hover::after,
.feature-card:hover::after,
.review-card:hover::after,
.footer-card:hover::after,
.photo-card:hover::after { opacity: 1; transform: translateY(0); }
.feature-card h3 { margin:.25rem 0 0; font-size:1.12rem }
.feature-card p { margin:0; color: var(--ink-2) }
.feature-icon { width: 48px; height: 48px; display:grid; place-items:center; border-radius: 12px; background: rgba(217,4,41,.08); color: var(--brand); border:1px solid rgba(217,4,41,.22) }
.feature-list { margin:.2rem 0 0; padding-left: 1.1rem; color: #475569 }
.feature-list li { margin:.2rem 0 }
.feature-cta { margin-top:.6rem }

/* Feature cards with subtle background image */
.feature-card.has-bg { position: relative; overflow: hidden }
.feature-card.has-bg::before { content:""; position:absolute; inset:0; background-image: var(--feature-bg); background-size: cover; background-position: center; opacity:.35; transform: scale(1.06); filter: saturate(110%) contrast(95%); }
.feature-card.has-bg::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,255,255,.78)); }
.feature-card.has-bg > * { position: relative; z-index: 1 }

.two-col { display:grid; gap: 2rem; grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 900px) { .two-col { grid-template-columns: 1fr; } }

.text-center { text-align:center }
.stack { display:grid; gap: 2rem; }
.prose { color: var(--ink); line-height: 1.75 }
.prose p { margin: .9rem 0 }
.prose h2 { margin: .2rem 0 .4rem; color: #0f172a; font-size: clamp(1.25rem, 1vw + 1rem, 1.6rem) }
.prose h3 { margin: .2rem 0 .2rem; color: #111827; font-size: clamp(1.05rem, .6vw + .9rem, 1.25rem) }

/* Leistungen: Service-Abschnitte als Karten */
.service.prose { background: var(--card); border:1px solid rgba(var(--glass-strong-rgb), .55); border-radius: 14px; padding: 1.2rem 1.25rem 1.35rem; box-shadow: 0 10px 26px rgba(2,6,23,.06) }
.service.prose h2 { display:flex; align-items:center; gap:.5rem }
.service.prose h2::after { content:""; flex:1; height: 2px; background: linear-gradient(90deg, var(--brand), transparent); opacity:.35 }
.service.prose .cta { margin-top: .75rem }

/* Über uns */
.about { background: linear-gradient(180deg, #eef3fb, #e7edf6); border-top:1px solid #d5e0f0; border-bottom:1px solid #d5e0f0 }
.about-grid { display:grid; gap: 1.25rem; grid-template-columns: 1.1fr .9fr; align-items: center }
@media (max-width: 960px) { .about-grid { grid-template-columns: 1fr; } }
.about-photo { display:grid; }
.photo-card { position: relative; border-radius: 16px; overflow: hidden; border:1px solid rgba(var(--glass-strong-rgb), .55); box-shadow: 0 14px 36px rgba(2,6,23,.12) }
.photo-card::after { content:""; position:absolute; inset:0; background: radial-gradient(400px 200px at 80% 10%, rgba(255,255,255,.3), transparent 60%); pointer-events:none }
.about-img { display:block; width:100%; height:100%; object-fit: cover }

.about-gallery { padding-top: calc(var(--space-6) - 1rem); padding-bottom: calc(var(--space-6) - 1rem) }
.gallery-grid { display:grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0,1fr)); }
@media (max-width: 900px) { .gallery-grid { grid-template-columns: 1fr; } }
.gallery-item { position: relative; border-radius: 16px; border:1px solid rgba(var(--glass-strong-rgb), .55); background-image: var(--src); background-size: cover; background-position: center; min-height: 220px; box-shadow: 0 12px 30px rgba(2,6,23,.08); overflow: hidden; transition: transform .2s ease, box-shadow .2s ease }
.gallery-item::after { content:""; position:absolute; inset:0; background: radial-gradient(300px 160px at 85% 10%, rgba(255,255,255,.25), transparent 60%); opacity:.3; transition: opacity .2s ease }
.gallery-item:hover { transform: translateY(-2px) scale(1.01); box-shadow: 0 16px 38px rgba(2,6,23,.12); cursor: zoom-in }
.gallery-item:hover::after { opacity:.5 }

/* Lightbox */
.lightbox { position: fixed; inset: 0; background: rgba(3,7,18,.85); display: none; place-items: center; z-index: 100; padding: 1rem }
.lightbox.open { display: grid }
.lightbox-img { max-width: min(96vw, 1200px); max-height: 86vh; border-radius: 12px; box-shadow: 0 30px 80px rgba(0,0,0,.6); border:1px solid rgba(255,255,255,.15) }
.lightbox-close { position: absolute; top: .75rem; right: .75rem; background: rgba(255,255,255,.1); color:#fff; border:1px solid rgba(255,255,255,.3); border-radius: 8px; padding:.3rem .5rem; cursor:pointer }

/* Leistungen full-width bands */
.service-band { padding: calc(var(--space-6) + .5rem) 0; }
.service-band .overlay { background: linear-gradient(180deg, rgba(6,9,18,.62), rgba(6,9,18,.78)); }
.service-panel { background: rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.28); border-radius: 16px; padding: 1.1rem 1.2rem 1.25rem; box-shadow: 0 18px 44px rgba(0,0,0,.35); backdrop-filter: blur(10px) saturate(115%); -webkit-backdrop-filter: blur(10px) saturate(115%); }
.service-panel.prose { color:#fff }
.service-panel.prose h2, .service-panel.prose h3 { color:#fff }
.service-panel .muted { color:#dbe3f3 }
.service-panel .chips { margin-top:.5rem }
.service-panel .chip { background: rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.35); color:#fff }

.contact-grid { display:grid; gap: 2rem; grid-template-columns: 1.2fr .8fr; }
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-form { display:grid; gap: 1rem; }
.contact-form label, .footer-form label { color: var(--ink-2); }
.form-check { display:flex; align-items:flex-start; gap:.6rem }
.form-check input[type="checkbox"] { width: 18px; height: 18px; margin-top:.2rem; accent-color: var(--brand); }
.form-check label { margin:0; font-weight:500; color: var(--ink-2); }
[class*="form-row"].consent-row,
.form-row.consent-row { display:flex; flex-wrap:nowrap; align-items:center; gap:1rem; }
.form-row.consent-row .bubble-note { flex:1 1 auto; min-width:260px; }
.turnstile-inline { flex:0 0 auto; min-width: 310px; min-height:70px; display:flex; align-items:center; justify-content:center; }
[data-turnstile] { min-height:70px; }
@media (max-width: 640px) {
  .form-row.consent-row { flex-direction:column; gap:.75rem; }
  .turnstile-inline { width:100%; }
}
.footer-form .form-actions, .contact-form .form-actions { display:flex; align-items:center; gap:.75rem; flex-wrap: wrap }
.footer-form .btn.btn-primary, .contact-form .btn.btn-primary { border-radius: 12px; padding: .85rem 1.2rem; box-shadow: 0 8px 22px rgba(217,4,41,.22); }
@media (max-width: 520px) {
  .footer-form .btn.btn-primary, .contact-form .btn.btn-primary { width: 100%; justify-content: center; }
}

/* Inline form alerts */
.form-alert { font-weight: 600; }
.form-alert.is-success { color: #16a34a; }
.form-alert.is-error { color: #dc2626; }

/* Bubble note (glass) for privacy consent */
.bubble-note { background: rgba(var(--glass-rgb), .58); border: 1px solid rgba(var(--glass-strong-rgb), .45); backdrop-filter: blur(8px) saturate(120%); -webkit-backdrop-filter: blur(8px) saturate(120%); border-radius: 12px; padding: .6rem .75rem; box-shadow: 0 8px 22px rgba(2,6,23,.08); }
.bubble-note a { color: var(--brand); font-weight: 700; text-decoration: none; }
.bubble-note a:hover { text-decoration: underline; text-underline-offset: 2px; }

/* Top site alert (glass) */
.site-alert { position: fixed; top: calc(var(--header-h) + .5rem); left: 50%; transform: translateX(-50%); width: min(100% - 2rem, 760px); padding: .75rem 1rem; border-radius: 12px; background: rgba(var(--glass-rgb), .6); border:1px solid rgba(var(--glass-strong-rgb), .45); backdrop-filter: blur(10px) saturate(120%); -webkit-backdrop-filter: blur(10px) saturate(120%); box-shadow: 0 14px 36px rgba(2,6,23,.14); display:flex; align-items:center; justify-content: space-between; gap:.75rem; z-index: 2000; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .18s ease, visibility .18s ease }
.site-alert .msg { color:#0f172a; font-weight: 600; }
.site-alert .close { background: rgba(var(--glass-rgb), .75); border:1px solid rgba(var(--glass-strong-rgb), .55); color:#0f172a; border-radius: 8px; padding:.2rem .5rem; cursor:pointer }
.site-alert.open { opacity: 1; visibility: visible; pointer-events: auto; }
.site-alert.is-error { background: rgba(220,38,38,.16); border-color: rgba(220,38,38,.3); }
.site-alert.is-success { background: rgba(34,197,94,.16); border-color: rgba(34,197,94,.3); }
.success-toast { position: fixed; bottom: 1.25rem; right: 1.25rem; display:flex; align-items:center; gap:.75rem; padding:.9rem 1.1rem; border-radius: 14px; background: linear-gradient(120deg, #16a34a, #22c55e); color:#fff; box-shadow: 0 18px 45px rgba(22,163,74,.35); border:1px solid rgba(var(--glass-strong-rgb), .45); opacity:0; visibility:hidden; transform: translateY(20px); transition: opacity .18s ease, visibility .18s ease, transform .18s ease; z-index: 2100; pointer-events:none; }
.success-toast.open { opacity:1; visibility:visible; transform: translateY(0); pointer-events:auto; }
.success-toast__msg { font-weight:600; }
.success-toast__close { background: rgba(var(--glass-rgb), .25); border:1px solid rgba(var(--glass-strong-rgb), .55); color:#fff; border-radius: 999px; width:28px; height:28px; font-size:1rem; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; }
@media (max-width: 640px) {
  .success-toast { left: 50%; right:auto; transform: translate(-50%, 20px); width: calc(100% - 2rem); justify-content: space-between; }
  .success-toast.open { transform: translate(-50%, 0); }
}
.form-row { display:grid; gap:.4rem }
input, textarea { width:100%; background: var(--card); color:#0f172a; border:1px solid rgba(var(--glass-strong-rgb), .7); border-radius:.6rem; padding:.7rem .9rem; }
::placeholder { color:#94a3b8 }
label { color:#cbd5e1; font-weight:600; font-size:.95rem }
.contact-list { list-style:none; padding:0; margin:0; color: var(--ink); }
.contact-list li { margin:.4rem 0; color: inherit; }
.contact-list li strong { color: var(--ink); }

/* Reviews */
.reviews { background: linear-gradient(180deg, #eef3fb, #e7edf6); border-top: 1px solid #d5e0f0; border-bottom: 1px solid #d5e0f0; }
.reviews-head { text-align:center; margin-bottom: 1rem }
.reviews-grid { display:grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 900px) { .reviews-grid { grid-template-columns: 1fr } }
.review-card { background: var(--card); border:1px solid rgba(var(--glass-strong-rgb), .55); border-radius: 14px; padding: 1rem; box-shadow: 0 10px 28px rgba(2,6,23,.08); display:grid; gap:.5rem }
.review-card .author { color:#475569; font-size:.95rem; display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.author-name { font-weight:700; color:#0f172a; }
.author-link { font-size: .83rem; color: var(--brand); text-transform: uppercase; letter-spacing:.3px; text-decoration:none; }
.author-link:hover { text-decoration: underline; }
.stars { color: #f59e0b; display:flex; gap:.1rem }
.stars svg { opacity:.4; }
.stars svg.is-active { opacity: 1; }
.review-meta { margin-top:.25rem; font-size:.85rem; color: var(--ink-2); display:flex; justify-content:space-between; gap:.35rem; flex-wrap:wrap; }
.review-meta a { color: var(--brand); font-weight:600; text-decoration:none; }
.review-meta a:hover { text-decoration: underline; }
.instagram-feed { background: linear-gradient(180deg, #eef3fb, #e7edf6); border-top: 1px solid #d5e0f0; border-bottom: 1px solid #d5e0f0; }
.instagram-feed .instagram-grid { margin: 1.5rem auto 0; display:block; width: calc(100vw - var(--scrollbar-inline, 0px)); }
.instagram-facts ul { list-style:none; padding:0; margin: 0; display:flex; flex-wrap:wrap; gap:.75rem; justify-content:center; }
.instagram-facts li { padding:.4rem 1rem; border-radius: 999px; font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; color: #0f172a; border:1px solid rgba(var(--glass-strong-rgb), .45); background: rgba(var(--glass-rgb), .6); box-shadow: 0 8px 20px rgba(15,23,42,.08); }
.instagram-card { position:relative; overflow:hidden; display:flex; flex-direction:column; width: 100%; height: 100%; border-radius: 0; border:0; background: transparent; }
.instagram-card__info { position:absolute; left:1rem; right:1rem; bottom:1rem; background: linear-gradient(180deg, rgba(15,23,42,0), rgba(15,23,42,.85)); color:#fff; padding:.6rem .9rem; border-radius: 1rem; font-size:.8rem; letter-spacing:.02em; text-transform:uppercase; box-shadow: 0 12px 24px rgba(0,0,0,.35); opacity:0; transform: translateY(6px); transition: opacity .3s ease, transform .3s ease; pointer-events:none; }
.instagram-card:hover .instagram-card__info { opacity:1; transform: translateY(0); }
.instagram-card img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .35s ease; }
.instagram-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.45));
  opacity: 0;
  transition: opacity .3s ease;
}
.instagram-card:hover::after {
  opacity: 1;
}
.instagram-card:hover img {
  transform: scale(1.08);
}
.instagram-card--highlight::after { display:none; }
.instagram-card__eyebrow { margin:0; font-size:.62rem; letter-spacing:.35em; text-transform:uppercase; color: rgba(255,255,255,.88); display:inline-flex; align-items:center; padding:.25rem .9rem; border-radius:999px; background: rgba(255,255,255,.12); box-shadow: inset 0 0 0 1px rgba(255,255,255,.2); }
.instagram-card__stat { margin:.35rem 0; font-size: clamp(2.1rem, 5vw, 2.9rem); font-weight:700; line-height:1; display:flex; flex-direction:column; gap:.15rem; letter-spacing:-.04em; }
.instagram-card__stat span { display:block; }
.instagram-card__stat small { font-size:.75rem; text-transform:uppercase; letter-spacing:.25em; color: rgba(255,255,255,.65); }
.instagram-card__note { margin-top:auto; font-size:.75rem; letter-spacing:.18em; text-transform:uppercase; color: rgba(255,255,255,.7); }
.instagram-card--highlight {
  padding: 0;
  color:#fff;
  background: radial-gradient(circle at 15% 20%, rgba(255,255,255,.25), rgba(255,255,255,0) 60%), linear-gradient(150deg, rgba(217,4,41,.95), rgba(131,58,180,.9));
  text-decoration:none;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  position:relative;
  overflow:hidden;
  border-radius: 0;
  min-height: clamp(220px, 40vw, 320px);
  grid-column: span 2;
  box-shadow: 0 20px 55px rgba(15,23,42,.25);
}
.instagram-card--highlight::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(20,20,20,.1), rgba(10,10,10,.55) 55%, rgba(10,10,10,.85));
  z-index: 0;
}
.instagram-card--highlight .instagram-card__highlight {
  position:relative;
  display:flex;
  flex-direction:column;
  gap:.65rem;
  padding: 1.75rem 2rem;
  max-width: 420px;
  width: 100%;
  height: 100%;
  justify-content:center;
  align-items:flex-start;
  text-align:left;
}
.instagram-card--highlight h3 { margin: .25rem 0; font-size: clamp(1.1rem, 3vw, 1.6rem); }
.instagram-card--highlight p { margin:0; color: rgba(255,255,255,.9); font-size: .9rem; line-height:1.4; }
.instagram-diorama { margin-top: 1rem; }
.instagram-diorama__grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); grid-auto-rows: minmax(180px, auto); gap: 0; align-items:stretch; }
.instagram-card--highlight .btn-instagram { margin-top: 1rem; }
.instagram-card--edge img { border-radius: 0; }
.instagram-grid--flush .instagram-card { border-radius: 0; }
.instagram-grid--flush { margin: 1rem 0 0; }
.instagram-feed .container { width: 100%; max-width: var(--container); }
.btn-instagram {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .85rem 1.35rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #f5852b, #c13584, #833ab4);
  color: #fff;
  font-weight:700;
  box-shadow: 0 12px 32px rgba(131,58,180,.35);
  border: 0;
  transition: transform .3s ease, box-shadow .3s ease;
}
.btn-instagram span { letter-spacing:.3px; }
.btn-instagram svg { width: 22px; height: 22px; }
.btn-instagram:hover { transform: translateY(-2px); box-shadow: 0 18px 36px rgba(131,58,180,.35); }
@media (max-width: 900px) {
  .instagram-diorama__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); grid-auto-rows: minmax(160px, auto); }
}
@media (max-width: 640px) {
  .instagram-diorama__grid { grid-template-columns: 1fr; }
  .instagram-card--highlight { grid-column: span 1; }
}

/* ProvenExpert (removed) */

/* --- Responsive Navigation (Burger Menu) --- */
/* Toggle button (hidden on desktop) */
.nav-toggle { display:none; position: relative; width: 42px; height: 42px; border-radius: 12px; border:1px solid rgba(var(--glass-strong-rgb), .8); background: var(--card); align-items:center; justify-content:center; cursor:pointer; box-shadow: 0 6px 18px rgba(15,23,42,.12); flex-direction: column; gap: 5px }
.nav-toggle:hover { background: rgba(var(--glass-rgb), .95) }
.nav-toggle .bar { display:block; width: 22px; height: 2px; background:#0f172a; border-radius: 2px; transition: transform .2s ease, opacity .2s ease, background-color .2s ease }
.nav-toggle:focus { outline: 2px solid var(--brand); outline-offset: 2px; }
.nav-toggle.active .bar { background: var(--brand); }
.nav-toggle.active .bar:nth-child(1) { transform: translateY(7px) rotate(45deg) }
.nav-toggle.active .bar:nth-child(2) { opacity: 0 }
.nav-toggle.active .bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg) }

@media (max-width: 900px) {
  .nav-toggle { display:inline-flex; }
  /* Mobile top-sheet menu with animation */
  .nav { position: fixed; top: var(--header-h); left: 0; right: 0; background: rgba(var(--glass-strong-rgb), .92); border:1px solid rgba(var(--glass-strong-rgb), .65); border-top: 0; border-radius: 0 0 18px 18px; flex-direction: column; gap: .25rem; padding: .9rem 1.1rem 1.15rem; z-index: 1001; box-shadow: 0 28px 65px rgba(15,23,42,.22); backdrop-filter: blur(18px) saturate(180%); -webkit-backdrop-filter: blur(18px) saturate(180%); transform: translateY(-8px); opacity: 0; visibility: hidden; pointer-events: none; transition: transform .18s ease, opacity .18s ease, visibility .18s ease; }
  .nav.open { transform: translateY(0); opacity: 1; visibility: visible; pointer-events: auto; }
  .nav a { display:block; padding: .7rem .5rem; border-radius: 10px; font-weight: 600; color:#0f172a }
  .nav a:hover { background: rgba(148,163,184,.12); text-decoration: none; }
  .nav a:not(.btn) { border: 0; box-shadow: none; padding: .7rem .5rem; border-radius: 10px; }
  .nav a:not(.btn):hover,
  .nav a:not(.btn):focus-visible { background: rgba(148,163,184,.12); border: 0; box-shadow: none; }
  .nav a:not(.btn)::after { content: none; }
  .nav .btn { margin-top: .25rem }

  /* Dim background when menu is open */
  body.menu-open::before { content:""; position: fixed; top: var(--header-h); left: 0; right: 0; bottom: 0; background: rgba(2,6,23,.2); z-index: 800; }
}

/* --- Subtle scroll-reveal animations (respect reduced motion) --- */
.reveal { opacity: 0; transform: translateY(12px); transition: opacity .28s ease, transform .28s ease; }
.reveal.show { opacity: 1; transform: none; }
.reveal.delay-1 { transition-delay: .06s }
.reveal.delay-2 { transition-delay: .12s }
.reveal.delay-3 { transition-delay: .18s }

@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.show { opacity: 1 !important; transform: none !important; transition: none !important; }
  .nav a:not(.btn)::after { transition: none; }
}

/* --- Cookie banner & consent controls --- */
.link-button { background: none; border: 0; padding: 0; color: #0f172a; font: inherit; cursor: pointer; text-decoration: underline; }
.link-button:hover { color: var(--brand); }
.sr-only { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.badge.muted { background: #e2e8f0; color: #475569; border-radius: 999px; padding: .2rem .55rem; font-size: .75rem; text-transform: none; letter-spacing: normal; }

.cookie-banner { position: fixed; bottom: 1.2rem; left: 50%; transform: translateX(-50%); width: min(920px, calc(100% - 1.5rem)); background: rgba(255,255,255,.95); border-radius: 18px; box-shadow: 0 28px 80px rgba(15,23,42,.25); border:1px solid rgba(var(--glass-strong-rgb), .45); z-index: 2200; backdrop-filter: blur(28px) saturate(160%); -webkit-backdrop-filter: blur(28px) saturate(160%); }
.cookie-banner[hidden] { display: none !important; }
.cookie-banner__inner { padding: 1.25rem 1.75rem; display:flex; flex-wrap:wrap; gap: 1.5rem; align-items:flex-start; color: #0f172a; }
.cookie-banner__content { flex: 1 1 auto; display:flex; flex-wrap:wrap; gap:.6rem 1rem; align-items:flex-start; }
.cookie-banner__content h2,
.cookie-banner__content p { flex: 1 1 100%; margin: 0; }
.cookie-banner__content h2 { font-size: 1.1rem; font-weight: 700; }
.cookie-banner__content p { color: #475569; font-size:1rem; line-height:1.5; }
.cookie-option { flex: 1 1 210px; min-width: 200px; display:flex; align-items:flex-start; justify-content:space-between; gap:.75rem; padding:.65rem .75rem; border:1px solid rgba(var(--glass-strong-rgb), .6); border-radius: 14px; background: rgba(var(--glass-rgb), .45); box-shadow: inset 0 1px 0 rgba(var(--glass-rgb), .35); }
.cookie-option:first-of-type { border-top: 1px solid rgba(var(--glass-strong-rgb), .45); padding-top:.65rem; }
.cookie-option strong { display:block; margin-bottom:.1rem; font-size:.95rem; }
.cookie-banner__actions { display:flex; flex-wrap:nowrap; gap:.5rem; min-width: 220px; align-items:center; }
.btn-secondary.ghost { background: rgba(15,23,42,.04); border-color: #cbd5e1; color: #0f172a; }
.btn-secondary.ghost:hover { background: rgba(15,23,42,.08); }
.cookie-banner__legal { font-size: .85rem; margin: .25rem 0 0; color:#475569; flex: 1 1 100%; }
.cookie-banner__legal a { color: var(--brand); }
.cookie-banner__close { position:absolute; top: .5rem; right: .75rem; background: none; border: 0; font-size: 1.5rem; line-height: 1; cursor: pointer; color:#94a3b8; }
.cookie-banner__close:hover { color: #0f172a; }

.toggle { display: inline-flex; align-items: center; gap: .4rem; cursor: pointer; font-weight: 600; color: #0f172a; }
.toggle input { width: 18px; height: 18px; margin: 0; }
.toggle-label { font-size: .9rem; color: #475569; }
.toggle input:checked + .toggle-label { color: var(--brand); }

.embed-placeholder .btn-secondary { border-color: #cbd5e1; background: transparent; }

@media (max-width: 900px) {
  .cookie-banner { width: calc(100% - 1rem); }
  .cookie-banner__inner { flex-direction: column; align-items:flex-start; }
  .cookie-banner__actions { width: 100%; flex-wrap:wrap; }
}
@media (max-width: 700px) {
  .form-row.consent-row { flex-direction:column; align-items:flex-start; }
  .turnstile-inline { width: 100%; min-width: 0; justify-content:flex-start; }
}
@media (max-width: 640px) {
  .cookie-option { width: 100%; }
  .cookie-banner__actions .btn { width: 100%; justify-content: center; }
}
.instagram-diorama__grid .instagram-card { transition: transform .3s ease; }
.instagram-diorama__grid .instagram-card:hover { transform: translateY(-4px); }
