/* ═══════════════════════════════════════════════════════════
   SVH BASE — Geteiltes Design-System (Single Source)
   Gehostet auf der Landingpage, von allen Subdomains per
   <link href="https://landingpage.sv-heimstetten.de/assets/svh-base.css">
   eingebunden. Hier 1× ändern → überall.
   Werte sind die Marken-Baukasten-Tokens der Landingpage.
   ═══════════════════════════════════════════════════════════ */

:root{
  /* Marke */
  --svh-rot:#AE1520; --svh-rot-dunkel:#8E1019; --svh-rot-hell:#F3C9CC;
  /* Dunkelflächen & Akzent */
  --svh-anthrazit:#2A2D31; --svh-anthrazit-900:#23262A;
  --svh-sand:#C26B45; --svh-sand-hell:#F2B79E;
  /* Neutrale */
  --svh-text:#1A1A1A; --svh-text-2:#41464C; --svh-text-sek:#6B7077;
  --svh-grau:#9499A0; --svh-grau-300:#C7CBD0;
  --svh-bg:#F5F6F7; --svh-linie:#E2E4E7; --svh-linie-2:#EFF0F2;
  --svh-erfolg:#1E8E3E; --svh-weiss:#FFFFFF;
  /* Aliase für Subdomain-Komponenten (MS-Partner etc.) */
  --svh-sandplatz:#C26B45; --svh-hintergrund:#F5F6F7;
  --svh-text-ter:#9499A0; --svh-body:#E9EAEC; --svh-footer-text:#C7CBD0;
  /* Schriften */
  --font-display:'Archivo','Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --font-text:'Inter',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  /* Radien */
  --r-sm:8px; --r-btn:10px; --r-md:12px; --r-lg:18px; --r-xl:20px; --r-2xl:20px;
  /* Spacing */
  --section-pad:88px 24px; --maxw:1180px;
  /* Schatten */
  --shadow-sm:0 2px 8px rgba(26,26,26,0.06);
  --shadow-md:0 12px 36px rgba(26,26,26,0.10);
  --shadow-lg:0 24px 64px rgba(26,26,26,0.16);
}

/* ═══════════════ RESET & BASE ═══════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-text);background:var(--svh-weiss);color:var(--svh-text-2);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
::selection{background:var(--svh-rot);color:#fff}
:focus-visible{outline:3px solid var(--svh-rot);outline-offset:2px;border-radius:4px}

/* ═══════════════ UTILITIES ═══════════════ */
.container,.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

.eyebrow{display:inline-block;font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--svh-rot);margin-bottom:16px}
.eyebrow--light{color:var(--svh-sand-hell)}
.eyebrow--sand{color:var(--svh-sandplatz)}
.eyebrow--mute{color:var(--svh-text-ter)}

h1,h2,h3{font-family:var(--font-display);text-transform:uppercase;line-height:1.02;letter-spacing:-0.02em}
.h-display{font-weight:900;font-size:clamp(40px,7vw,64px);line-height:.98}
.h2{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:900;line-height:1.04;letter-spacing:-0.02em;text-transform:uppercase;color:var(--svh-text);margin-bottom:18px}
h2{font-weight:900;font-size:clamp(28px,4.4vw,40px)}
h3{font-weight:800;font-size:21px;letter-spacing:-.01em}
.lead{font-size:17px;color:var(--svh-text-sek);max-width:62ch;line-height:1.7}
.lead--light{color:#B9BDC2}

/* ═══════════════ BUTTONS ═══════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:14px 26px;border-radius:var(--r-btn);font-family:var(--font-display);font-size:14px;font-weight:800;letter-spacing:0.04em;text-transform:uppercase;cursor:pointer;border:1.5px solid transparent;transition:transform 0.15s ease,background 0.2s ease,box-shadow 0.2s ease,border-color 0.2s ease;white-space:nowrap}
.btn svg{width:16px;height:16px}
.btn--primary{background:var(--svh-rot);color:#fff;border-color:var(--svh-rot)}
.btn--primary:hover{background:var(--svh-rot-dunkel);border-color:var(--svh-rot-dunkel);transform:translateY(-1px);box-shadow:0 8px 22px rgba(174,21,32,0.32)}
.btn--ghost{background:#fff;color:var(--svh-text);border-color:var(--svh-linie)}
.btn--ghost:hover{background:var(--svh-bg);border-color:var(--svh-rot);color:var(--svh-rot)}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,0.35)}
.btn--ghost-light:hover{background:rgba(255,255,255,0.10);border-color:#fff}
.btn--white{background:#fff;color:var(--svh-rot);border-color:#fff}
.btn--white:hover{background:var(--svh-bg);transform:translateY(-1px);box-shadow:0 8px 22px rgba(0,0,0,0.18)}
.btn--sm{min-height:42px;padding:11px 20px;font-size:13px}

/* ═══════════════ LOGO-BADGE ═══════════════ */
.svh-badge{height:44px;width:auto;max-width:60px;flex-shrink:0;object-fit:contain;display:block}

/* ═══════════════ NAV — weiß, fixed ═══════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,0.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--svh-linie)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.1}
.nav-logo-name{font-family:var(--font-display);font-size:15px;font-weight:800;letter-spacing:0.02em;text-transform:uppercase;color:var(--svh-text)}
.nav-logo-sub{font-family:var(--font-display);font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--svh-rot)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-family:var(--font-display);font-size:12px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--svh-text-2);transition:color 0.2s}
.nav-links a:hover{color:var(--svh-rot)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-hamburger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer;background:none;border:none}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--svh-text);border-radius:2px;transition:all 0.3s}
.nav.menu-open .nav-hamburger span:nth-child(1),.nav.open .nav-hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.menu-open .nav-hamburger span:nth-child(2),.nav.open .nav-hamburger span:nth-child(2){opacity:0}
.nav.menu-open .nav-hamburger span:nth-child(3),.nav.open .nav-hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;border-top:1px solid var(--svh-linie);background:#fff;padding:12px 24px 20px;max-height:calc(100vh - 72px);max-height:calc(100dvh - 72px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.nav.menu-open .nav-mobile,.nav.open .nav-mobile{display:block}
.nav-mobile a{display:block;font-family:var(--font-display);font-size:14px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--svh-text-2);padding:14px 4px;border-bottom:1px solid var(--svh-linie-2)}
.nav-mobile .btn{width:100%;margin-top:16px;justify-content:center}

/* ═══════════════ FOOTER ═══════════════ */
.footer{background:var(--svh-anthrazit-900);padding:56px 24px 0;color:var(--svh-grau-300)}
.footer-inner{max-width:var(--maxw);margin:0 auto}
.footer-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:36px}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.footer-brand-name{font-family:var(--font-display);font-size:14px;font-weight:800;letter-spacing:0.02em;text-transform:uppercase;color:#fff;line-height:1.2}
.footer-desc{font-size:12.5px;line-height:1.6;color:var(--svh-grau);margin-bottom:18px;max-width:34ch}
.footer-social{display:flex;gap:8px}
.footer-social a{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--svh-grau-300);padding:8px 12px;border-radius:var(--r-sm);background:rgba(255,255,255,0.06);transition:background 0.2s,color 0.2s}
.footer-social a:hover{background:var(--svh-rot);color:#fff}
.footer-col-title{font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:0.14em;text-transform:uppercase;color:#fff;margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:13px;color:var(--svh-grau-300);transition:color 0.2s}
.footer-links a:hover{color:#fff}
.footer-contact{font-size:13px;line-height:1.7;color:var(--svh-grau-300)}
.footer-contact strong{color:#fff;font-weight:600}
.footer-contact a{color:#fff;font-weight:600}
.footer-vr{font-size:11px;line-height:1.5;color:#7E848B;margin-top:12px}
.footer-depts{padding:26px 0;border-top:1px solid #34383E}
.footer-depts-title{font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:0.14em;text-transform:uppercase;color:#fff;margin-bottom:14px}
.footer-depts-list{display:flex;flex-wrap:wrap;gap:11px 26px;font-size:13px}
.footer-depts-list a,.footer-depts-list span{color:var(--svh-grau-300);white-space:nowrap;transition:color 0.2s}
.footer-depts-list a:hover{color:#fff}
.footer-depts-list a.is-active,.footer-depts-list span.is-active{color:#fff;font-weight:700}
.footer-bottom{border-top:1px solid #34383E;padding:18px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px}
.footer-copy{color:#7E848B}
.footer-legal{display:flex;gap:18px}
.footer-legal a{color:var(--svh-grau);transition:color 0.2s}
.footer-legal a:hover{color:#fff}

/* ═══════════════ SCROLL REVEAL ═══════════════ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.visible,.reveal.in{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}

/* ═══════════════ RESPONSIVE (Nav + Footer) ═══════════════ */
@media (max-width:940px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-hamburger{display:flex}
}
@media (max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:768px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-hamburger{display:flex}
  .footer{padding:44px 20px 0}
  .footer-top{grid-template-columns:1fr;gap:26px}
  .footer-social{flex-wrap:wrap}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-legal{flex-wrap:wrap;justify-content:center;gap:10px 18px}
}
@media (max-width:380px){
  .nav-inner{padding:0 16px}
  .nav-logo-name{font-size:14px}
  .nav-logo-sub{font-size:9px;letter-spacing:0.16em}
}
