/*  =============================================================
    Wasser Walta e.K. — Meisterbetrieb Sanitär · Heizung · Klima
    Aachen · Seit 2008
    =============================================================  */

:root{
  --bg:        #07090C;
  --bg-raised: #0D1218;
  --bg-card:   #10161E;
  --line:      rgba(255,255,255,0.07);
  --line-2:    rgba(255,255,255,0.12);
  --ink:       #F4F6FA;
  --ink-2:     rgba(244,246,250,0.72);
  --ink-3:     rgba(244,246,250,0.48);
  --ink-4:     rgba(244,246,250,0.28);

  --amber:     #E8B863;
  --amber-d:   #D4A574;
  --amber-bg:  rgba(232,184,99,0.08);
  --copper:    #D97A44;
  --teal:      #5EEAD4;

  --g-amber:   linear-gradient(135deg,#E8B863 0%,#D97A44 100%);
  --mono-fs:   11.5px;

  --container: 1380px;
}

/* RESET */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter Tight',-apple-system,system-ui,'Segoe UI',sans-serif;
  font-size:15.5px;line-height:1.55;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}
summary{cursor:pointer}

/* Grain overlay */
body::before{
  content:'';position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.22;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
}

/* =========== NAV ============ */
.nav-wrap{
  position:sticky;top:0;z-index:40;
  background:rgba(7,9,12,.88);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.nav{
  max-width:var(--container);margin:0 auto;
  padding:18px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav-logo{display:flex;align-items:center;gap:18px;flex-shrink:0}
.nav-logo img{height:64px;width:auto;display:block}
.nav-logo-meta{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--ink-3);
  display:flex;flex-direction:column;gap:3px;
  padding-left:18px;border-left:1px solid var(--line-2);
  line-height:1.3;
}
.nav-logo-meta b{color:var(--ink);font-weight:500;font-size:10.5px}

.nav-links{display:flex;align-items:center;gap:30px;font-size:14px}
.nav-links a{
  color:var(--ink-2);font-weight:500;
  transition:color .2s;position:relative;
  padding:4px 0;
}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{
  content:'';position:absolute;left:0;right:0;bottom:-2px;height:1.5px;
  background:var(--amber);
}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--ink);color:var(--bg)!important;
  padding:11px 20px;border-radius:999px;
  font-weight:600;font-size:13.5px;
  font-variant-numeric:tabular-nums;
  transition:transform .15s, background .15s;
}
.nav-cta:hover{transform:translateY(-1px);background:var(--amber)}
.nav-cta svg{width:14px;height:14px}
.burger{
  display:none;width:40px;height:40px;color:var(--ink);
  align-items:center;justify-content:center;
}
@media(max-width:960px){
  .nav-links,.nav-logo-meta,.nav-cta{display:none}
  .burger{display:inline-flex}
  .nav{padding:14px 20px}
  .nav-logo img{height:50px}
}
.mobile-menu{
  display:none;position:fixed;inset:0;z-index:50;
  background:rgba(7,9,12,.97);backdrop-filter:blur(20px);
  padding:90px 24px 40px;flex-direction:column;gap:4px;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  padding:16px 12px;font-size:19px;
  border-bottom:1px solid var(--line);
  color:var(--ink);
  font-family:'Bricolage Grotesque',serif;
  font-weight:500;
}
.mobile-menu a.active{color:var(--amber)}
.mobile-close{
  position:absolute;top:20px;right:20px;
  width:40px;height:40px;color:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;
}

/* =========== BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  font-size:14.5px;font-weight:600;
  transition:all .2s;
  font-variant-numeric:tabular-nums;
  font-family:inherit;
}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--amber);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--amber);color:var(--amber)}
.btn-amber{background:var(--amber);color:var(--bg)}
.btn-amber:hover{background:var(--amber-d);transform:translateY(-1px)}
.btn svg{width:16px;height:16px;flex-shrink:0}

/* =========== SECTION HEAD ============ */
.section{padding:120px 32px;max-width:var(--container);margin:0 auto}
@media(max-width:960px){.section{padding:80px 20px}}

.sec-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:40px;margin-bottom:60px;flex-wrap:wrap;
}
.sec-eyebrow{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:var(--mono-fs);letter-spacing:.14em;
  text-transform:uppercase;color:var(--amber-d);
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:18px;
}
.sec-eyebrow::before{
  content:'';width:24px;height:1px;background:var(--amber);
}
.sec-title{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:clamp(2rem,4vw,3.4rem);
  font-weight:500;letter-spacing:-0.025em;line-height:1.04;
  max-width:22ch;
  font-variation-settings:"opsz" 48;
}
.sec-title em{font-style:italic;color:var(--amber);font-weight:400}
.sec-note{
  font-size:14px;color:var(--ink-3);
  max-width:36ch;line-height:1.6;
}

/* =========== HERO ============ */
.hero{
  padding:100px 32px 80px;
  position:relative;overflow:hidden;
}
.hero-inner{max-width:var(--container);margin:0 auto;position:relative}
.hero-grid{
  display:grid;grid-template-columns:1fr auto;
  gap:40px;align-items:end;position:relative;z-index:2;
}
.hero-meta-line{
  display:flex;align-items:center;gap:14px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:var(--mono-fs);letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-3);
  margin-bottom:28px;
}
.hero-meta-line::before{
  content:'';width:40px;height:1px;background:var(--amber);
}
.hero-meta-line span{color:var(--amber-d)}
.hero h1{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:clamp(2.6rem, 6.4vw, 5.8rem);
  line-height:.94;letter-spacing:-0.035em;
  font-weight:500;
  font-variation-settings:"opsz" 72;
  color:var(--ink);
  max-width:14ch;margin-bottom:36px;
}
.hero h1 .accent{color:var(--amber);font-style:italic;font-weight:400}
.hero-sub{
  font-size:17px;line-height:1.55;
  color:var(--ink-2);max-width:52ch;
  margin-bottom:40px;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* Hero Logo Kachel */
.hero-logo-block{
  position:relative;
  padding:28px 32px;
  background:linear-gradient(145deg,rgba(232,184,99,.04) 0%,rgba(255,255,255,.015) 100%);
  border:1px solid var(--line-2);
  border-radius:8px;
  max-width:520px;
}
.hero-logo-block::before{
  content:'';position:absolute;top:-1px;left:-1px;right:-1px;height:2px;
  background:var(--g-amber);border-radius:8px 8px 0 0;
}
.hero-logo-block img{
  width:100%;height:auto;display:block;
  max-width:440px;margin:0 auto;
  filter:drop-shadow(0 8px 24px rgba(232,184,99,.12));
}
.hero-logo-caption{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-3);
  margin-top:20px;display:flex;justify-content:space-between;
  padding-top:16px;border-top:1px solid var(--line);
}
.hero-logo-caption b{color:var(--amber-d);font-weight:500}
@media(max-width:960px){
  .hero{padding:60px 20px 60px}
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .hero-logo-block{max-width:none}
}

.hero-numeral{
  position:absolute;
  font-family:'Bricolage Grotesque',serif;
  font-weight:700;color:rgba(232,184,99,.03);
  font-size:clamp(14rem,28vw,26rem);
  line-height:1;letter-spacing:-0.08em;
  right:-4vw;top:-8vh;
  pointer-events:none;z-index:1;user-select:none;
}
@media(max-width:960px){.hero-numeral{display:none}}

/* Compact Hero (untere Seiten) */
.hero-compact{
  padding:80px 32px 60px;
  border-bottom:1px solid var(--line);
}
.hero-compact-inner{max-width:var(--container);margin:0 auto}
.hero-compact h1{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:clamp(2.4rem,5vw,4.4rem);
  font-weight:500;letter-spacing:-0.03em;line-height:1;
  margin-bottom:24px;max-width:18ch;
  font-variation-settings:"opsz" 60;
}
.hero-compact h1 em{color:var(--amber);font-style:italic;font-weight:400}
.hero-compact p{
  font-size:17px;color:var(--ink-2);
  max-width:56ch;line-height:1.55;
}
@media(max-width:960px){.hero-compact{padding:50px 20px 40px}}

/* =========== TRUST ROW ============ */
.trust{
  margin-top:60px;display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;border:1px solid var(--line);border-radius:4px;overflow:hidden;
}
.trust-item{
  padding:22px 24px;border-right:1px solid var(--line);
  display:flex;align-items:center;gap:14px;
}
.trust-item:last-child{border-right:none}
.trust-icon{
  width:32px;height:32px;flex-shrink:0;
  border-radius:50%;background:var(--amber-bg);
  display:inline-flex;align-items:center;justify-content:center;color:var(--amber);
}
.trust-label{font-size:12px;color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;letter-spacing:.06em;text-transform:uppercase}
.trust-value{font-size:14px;color:var(--ink);font-weight:500;margin-top:2px}
@media(max-width:960px){
  .trust{grid-template-columns:repeat(2,1fr)}
  .trust-item:nth-child(2){border-right:none}
  .trust-item:nth-child(-n+2){border-bottom:1px solid var(--line)}
}

/* =========== STATS ============ */
.stats{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:40px 32px;background:var(--bg-raised);
}
.stats-inner{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:40px;
}
.stat{position:relative;padding-left:22px}
.stat::before{
  content:'';position:absolute;left:0;top:8px;
  width:6px;height:6px;border-radius:50%;background:var(--amber);
}
.stat-n{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:42px;font-weight:600;letter-spacing:-0.025em;
  line-height:1;color:var(--ink);
  display:flex;align-items:baseline;gap:8px;
  font-variation-settings:"opsz" 48;
}
.stat-n small{font-size:14px;font-weight:500;color:var(--amber-d);letter-spacing:0}
.stat-l{
  margin-top:10px;font-size:13px;color:var(--ink-3);
  font-family:'JetBrains Mono',ui-monospace,monospace;
  letter-spacing:.08em;text-transform:uppercase;
}
@media(max-width:760px){
  .stats-inner{grid-template-columns:repeat(2,1fr);gap:28px}
}

/* =========== BENTO (Leistungen Overview auf Start) ============ */
.bento{
  display:grid;gap:2px;
  grid-template-columns:repeat(6,1fr);
  background:var(--line);
  border:1px solid var(--line);
  border-radius:4px;overflow:hidden;
}
.bento-card{
  background:var(--bg);padding:36px 32px;
  display:flex;flex-direction:column;
  position:relative;transition:background .3s;
  min-height:240px;
}
.bento-card:hover{background:var(--bg-raised)}
.bc-3x2{grid-column:span 3;grid-row:span 2}
.bc-3{grid-column:span 3}
.bc-2{grid-column:span 2}
.bc-4{grid-column:span 4}
.bc-6{grid-column:span 6}
.bc-num{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;color:var(--ink-4);letter-spacing:.14em;margin-bottom:24px}
.bc-title{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:28px;font-weight:500;letter-spacing:-0.02em;
  line-height:1.15;margin-bottom:14px;
  font-variation-settings:"opsz" 32;
}
.bc-desc{color:var(--ink-2);font-size:14.5px;line-height:1.6;flex-grow:1}
.bc-tags{
  display:flex;gap:6px;flex-wrap:wrap;margin-top:20px;
  padding-top:18px;border-top:1px solid var(--line);
}
.bc-tag{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10.5px;color:var(--ink-3);letter-spacing:.06em;
  padding:4px 10px;border:1px solid var(--line-2);border-radius:999px;
}
.bc-more{
  display:inline-flex;align-items:center;gap:8px;margin-top:22px;
  color:var(--amber);font-weight:600;font-size:13.5px;
  transition:gap .2s;
}
.bc-more:hover{gap:12px}
.bc-feature{
  background:linear-gradient(145deg,rgba(232,184,99,.06),rgba(217,122,68,.03));
  border:none;
}
.bc-feature .bc-title{font-size:36px;color:var(--amber);font-variation-settings:"opsz" 48}

.bc-notdienst{
  background:linear-gradient(135deg,#D97A44 0%,#B05A2C 100%);
  color:#fff;text-decoration:none;
}
.bc-notdienst .bc-num{color:rgba(255,255,255,.55)}
.bc-notdienst .bc-title{color:#fff;font-size:34px}
.bc-notdienst .bc-desc{color:rgba(255,255,255,.85)}
.bc-notdienst .bc-cta{
  margin-top:20px;display:inline-flex;gap:10px;align-items:center;
  color:#fff;font-weight:600;font-variant-numeric:tabular-nums;
}
.bc-notdienst .bc-cta svg{transition:transform .2s}
.bc-notdienst:hover .bc-cta svg{transform:translateX(4px)}

@media(max-width:960px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .bc-3x2,.bc-3,.bc-2,.bc-4,.bc-6{grid-column:span 2;grid-row:span 1}
  .bento-card{padding:28px 24px;min-height:auto}
}

/* =========== LEISTUNGS-DETAILS (leistungen.html) ============ */
.leistung-block{
  padding:100px 32px;max-width:var(--container);margin:0 auto;
  border-bottom:1px solid var(--line);
}
.leistung-block:last-child{border-bottom:none}
.leistung-grid{
  display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start;
}
.leistung-head h2{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:clamp(1.8rem,3.2vw,2.6rem);
  font-weight:500;letter-spacing:-0.025em;line-height:1.1;
  margin-bottom:20px;
  font-variation-settings:"opsz" 36;
}
.leistung-head h2 em{color:var(--amber);font-style:italic;font-weight:400}
.leistung-head .sec-eyebrow{margin-bottom:14px}
.leistung-head .mini-meta{
  margin-top:28px;padding-top:20px;border-top:1px solid var(--line);
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:12px;color:var(--ink-3);letter-spacing:.06em;line-height:1.8;
}
.leistung-head .mini-meta b{color:var(--amber-d);font-weight:500}
.leistung-body p{
  font-size:16px;line-height:1.7;color:var(--ink-2);
  margin-bottom:16px;
}
.leistung-body p:first-child{
  font-size:18px;color:var(--ink);font-weight:400;
}
.leistung-body ul{
  list-style:none;padding:0;margin:20px 0;
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px 24px;
}
.leistung-body li{
  padding-left:20px;position:relative;
  font-size:14.5px;color:var(--ink-2);
  line-height:1.5;
}
.leistung-body li::before{
  content:'';position:absolute;left:0;top:10px;
  width:8px;height:1px;background:var(--amber);
}
.leistung-cta{
  margin-top:32px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;gap:14px;flex-wrap:wrap;align-items:center;
}
.leistung-cta .small-note{
  font-size:13px;color:var(--ink-3);
}
@media(max-width:900px){
  .leistung-grid{grid-template-columns:1fr;gap:30px}
  .leistung-body ul{grid-template-columns:1fr}
  .leistung-block{padding:60px 20px}
}

/* =========== REVIEWS (Referenzen) ============ */
.reviews-section{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-raised);padding:120px 32px;
}
.reviews-inner{max-width:var(--container);margin:0 auto}
.reviews-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin-top:40px;
}
.review-card{
  background:var(--bg-card);border:1px solid var(--line);
  padding:32px 28px;border-radius:4px;
  display:flex;flex-direction:column;
}
.review-stars{color:var(--amber);letter-spacing:4px;font-size:14px;margin-bottom:18px}
.review-quote{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:19px;line-height:1.45;font-weight:400;
  letter-spacing:-0.01em;color:var(--ink);
  flex-grow:1;margin-bottom:24px;
  font-variation-settings:"opsz" 24;
}
.review-quote::before{
  content:'\201C';font-family:serif;font-size:60px;line-height:0;
  color:var(--amber);opacity:.4;
  margin-right:4px;vertical-align:-18px;
}
.review-author{
  display:flex;align-items:center;gap:12px;
  padding-top:20px;border-top:1px solid var(--line);
}
.review-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--g-amber);color:var(--bg);
  font-weight:700;font-size:14px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Bricolage Grotesque',Georgia,serif;
  letter-spacing:-0.02em;
}
.review-name{font-size:14px;font-weight:500;color:var(--ink)}
.review-context{font-size:11.5px;color:var(--ink-3);font-family:'JetBrains Mono',ui-monospace,monospace;letter-spacing:.06em}
@media(max-width:960px){.reviews-grid{grid-template-columns:1fr;gap:16px}.reviews-section{padding:70px 20px}}

.google-pill{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--bg-card);border:1px solid var(--line-2);
  padding:10px 18px;border-radius:999px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11.5px;letter-spacing:.1em;color:var(--ink-2);
  margin-top:24px;
}
.google-pill b{color:var(--amber);font-size:14px;letter-spacing:0;font-family:'Inter Tight',sans-serif}
.google-pill .stars{color:var(--amber);letter-spacing:2px}

/* =========== TEAM ============ */
.team-photo{
  position:relative;margin:0;
  border:1px solid var(--line);border-radius:4px;overflow:hidden;
  background:var(--bg-raised);
}
.team-photo img{width:100%;height:auto;display:block;filter:saturate(.94)}
.team-photo figcaption{
  padding:32px 40px;border-top:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg-card),var(--bg));
  display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center;
}
.team-caption-label{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;color:var(--amber-d);
  letter-spacing:.22em;text-transform:uppercase;
  white-space:nowrap;padding-right:40px;border-right:1px solid var(--line-2);
}
.team-caption-names{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:10px 40px;font-size:13.5px;color:var(--ink-2);
}
.team-caption-names b{color:var(--ink);font-weight:600}
@media(max-width:880px){
  .team-photo figcaption{grid-template-columns:1fr;gap:20px;padding:24px 22px}
  .team-caption-label{border:none;padding:0 0 12px;border-bottom:1px solid var(--line-2)}
  .team-caption-names{grid-template-columns:1fr;gap:8px}
}

/* Über uns (Ronny) */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.about-visual{
  aspect-ratio:4/5;position:relative;overflow:hidden;
  background:var(--bg-raised);
  border:1px solid var(--line);border-radius:4px;
}
.about-visual img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  filter:saturate(.96) contrast(1.02);
}
.about-visual::after{
  content:'RONNY WALTA';
  position:absolute;top:24px;left:24px;z-index:3;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10.5px;color:var(--amber);letter-spacing:.2em;
  text-transform:uppercase;font-weight:500;
  padding:6px 10px;background:rgba(7,9,12,.55);
  backdrop-filter:blur(6px);
  border:1px solid rgba(232,184,99,.3);border-radius:3px;
}
.about-visual-sig{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  background:linear-gradient(0deg,rgba(7,9,12,.92) 0%,rgba(7,9,12,.5) 60%,rgba(7,9,12,0) 100%);
  padding:48px 24px 22px;text-align:right;
  color:var(--ink);font-size:13px;letter-spacing:.02em;
  text-shadow:0 1px 6px rgba(0,0,0,.5);
}
.about-content h3{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:clamp(2rem,3.6vw,3rem);
  font-weight:500;letter-spacing:-0.025em;line-height:1.05;
  margin-bottom:28px;
}
.about-content h3 em{font-style:italic;color:var(--amber);font-weight:400}
.about-content p{color:var(--ink-2);font-size:15.5px;line-height:1.65;margin-bottom:18px}
.about-cv{
  margin-top:32px;padding-top:28px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:auto 1fr;gap:12px 24px;font-size:13.5px;
}
.about-cv dt{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11.5px;letter-spacing:.06em;color:var(--amber-d);font-weight:500;
}
.about-cv dd{color:var(--ink-2)}
@media(max-width:960px){.about-grid{grid-template-columns:1fr;gap:40px}}

/* =========== KONTAKT ============ */
.contact-split{
  display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start;
}
.contact-info h4{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:13px;color:var(--amber-d);letter-spacing:.12em;text-transform:uppercase;
  font-weight:600;margin-bottom:16px;
}
.contact-info-block{padding:24px 0;border-bottom:1px solid var(--line)}
.contact-info-block:first-of-type{border-top:1px solid var(--line)}
.contact-info-label{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:6px;
}
.contact-info-value{
  font-size:20px;font-weight:500;color:var(--ink);
  font-variant-numeric:tabular-nums;
  font-family:'Bricolage Grotesque',Georgia,serif;
  letter-spacing:-0.01em;
}
.contact-info-value a:hover{color:var(--amber)}
.contact-info-extra{font-size:13px;color:var(--ink-3);margin-top:4px}

.hours{
  width:100%;border-collapse:collapse;
  margin-top:6px;font-size:14px;font-variant-numeric:tabular-nums;
}
.hours th{text-align:left;font-weight:500;color:var(--ink-2);padding:8px 0;font-family:'Inter Tight',sans-serif}
.hours td{text-align:right;color:var(--ink);font-weight:500;padding:8px 0}
.hours td.muted{color:var(--ink-4);font-weight:400}
.hours-notdienst{border-top:1px solid var(--line)}
.hours-notdienst th{color:var(--amber)!important;padding-top:14px!important}
.hours-notdienst td{color:var(--amber)!important;font-weight:600;padding-top:14px!important}

.social-strip{margin-top:28px;display:flex;gap:10px;flex-wrap:wrap}
.soc{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;background:var(--bg-card);
  border:1px solid var(--line-2);border-radius:999px;
  font-size:12.5px;color:var(--ink-2);font-weight:500;
  transition:all .2s;
}
.soc:hover{border-color:var(--amber);color:var(--ink);transform:translateY(-1px)}
.soc svg{width:14px;height:14px}
.soc.wa{color:#25D366;border-color:rgba(37,211,102,.3)}
.soc.wa:hover{background:#25D366;color:#fff}
.soc.fb{color:#4F8CF8;border-color:rgba(79,140,248,.3)}
.soc.fb:hover{background:#1877F2;color:#fff}
.soc.gg:hover{background:var(--ink);color:var(--bg)}

.contact-form{
  background:var(--bg-raised);border:1px solid var(--line);
  padding:40px;border-radius:4px;
}
.form-eyebrow{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--amber-d);margin-bottom:10px;
}
.contact-form h3{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:28px;font-weight:500;letter-spacing:-0.02em;
  margin-bottom:8px;font-variation-settings:"opsz" 32;
}
.form-sub{color:var(--ink-3);font-size:13.5px;margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field label{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-3);font-weight:500;
}
.form-field input,.form-field select,.form-field textarea{
  background:var(--bg);border:1px solid var(--line-2);
  color:var(--ink);font-family:inherit;font-size:14.5px;
  padding:12px 14px;border-radius:3px;transition:border-color .2s;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--amber);
}
.form-field textarea{min-height:110px;resize:vertical;font-family:inherit}
.form-consent{
  display:flex;gap:10px;align-items:flex-start;
  font-size:12.5px;color:var(--ink-3);line-height:1.5;
  margin:18px 0 22px;
}
.form-consent input{margin-top:3px;accent-color:var(--amber)}
.form-consent a{color:var(--amber);text-decoration:underline;text-underline-offset:2px}
.btn-submit{
  width:100%;padding:14px 22px;
  background:var(--ink);color:var(--bg);
  border-radius:3px;font-weight:600;font-size:14.5px;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:background .2s;
  font-family:inherit;
}
.btn-submit:hover{background:var(--amber)}
.btn-submit svg{width:16px;height:16px}
@media(max-width:960px){
  .contact-split{grid-template-columns:1fr;gap:40px}
  .contact-form{padding:28px 22px}
  .form-row{grid-template-columns:1fr}
}

/* =========== STANDORT KARTE ============ */
.map-section{border-top:1px solid var(--line);background:var(--bg-raised)}
.map-wrap{position:relative;height:440px;overflow:hidden}
.map-wrap iframe{
  width:100%;height:100%;border:0;
  filter:grayscale(.5) invert(.88) hue-rotate(180deg) brightness(.92) contrast(.85);
}
.map-overlay{
  position:absolute;left:40px;top:50%;transform:translateY(-50%);
  background:rgba(7,9,12,.92);backdrop-filter:blur(14px);
  border:1px solid var(--line-2);padding:28px 32px;border-radius:4px;
  max-width:380px;box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.map-overlay::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--g-amber);
}
.map-overlay-label{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:19px;font-weight:600;letter-spacing:-0.015em;
  color:var(--ink);margin-bottom:8px;
}
.map-overlay-meta{font-size:13px;color:var(--ink-3);line-height:1.55;margin-bottom:18px}
.map-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--amber);color:var(--bg);
  padding:10px 16px;border-radius:999px;
  font-size:13px;font-weight:600;transition:transform .15s;
}
.map-cta:hover{transform:translateY(-1px)}
@media(max-width:760px){
  .map-wrap{height:500px}
  .map-overlay{left:16px;right:16px;top:auto;bottom:16px;transform:none;max-width:none;padding:20px 22px}
}

/* =========== FAQ ============ */
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line);transition:background .25s}
.faq-item[open]{background:var(--bg-raised)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:28px 4px;
  display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-num{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:12.5px;color:var(--amber-d);
  letter-spacing:.12em;font-weight:500;
}
.faq-q{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:clamp(1.25rem,2.2vw,1.7rem);
  font-weight:500;letter-spacing:-0.015em;
  font-variation-settings:"opsz" 28;
  color:var(--ink);line-height:1.25;
}
.faq-icon{
  width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Bricolage Grotesque',serif;
  font-size:20px;color:var(--amber);font-weight:400;
  transition:all .25s;line-height:1;
}
.faq-item[open] .faq-icon{transform:rotate(45deg);background:var(--amber);color:var(--bg);border-color:var(--amber)}
.faq-a{padding:0 4px 32px 76px;color:var(--ink-2);font-size:15.5px;line-height:1.65;max-width:78ch}
@media(max-width:700px){
  .faq-item summary{grid-template-columns:auto 1fr auto;gap:14px;padding:22px 4px}
  .faq-a{padding:0 4px 24px 0;font-size:14.5px}
}

/* =========== FOOTER ============ */
.footer{border-top:1px solid var(--line);padding:70px 32px 30px;background:#05070A}
.footer-inner{max-width:var(--container);margin:0 auto}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;
  padding-bottom:50px;border-bottom:1px solid var(--line);
}
.footer-brand img{height:52px;margin-bottom:20px}
.footer-brand p{color:var(--ink-3);font-size:13.5px;line-height:1.6;max-width:40ch}
.footer-col h5{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10.5px;color:var(--ink-4);letter-spacing:.18em;text-transform:uppercase;
  font-weight:500;margin-bottom:18px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:13.5px}
.footer-col a{color:var(--ink-2)}
.footer-col a:hover{color:var(--amber)}
.footer-mono{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;color:var(--ink-3);
  font-variant-numeric:tabular-nums;
}
.footer-social{display:flex;gap:8px;margin-top:16px}
.footer-social a{
  width:32px;height:32px;border-radius:6px;
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;text-decoration:none;transition:transform .15s;
}
.footer-social a:hover{transform:translateY(-2px)}
.footer-bar{
  padding-top:24px;display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:var(--ink-4);flex-wrap:wrap;gap:16px;
}
@media(max-width:960px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:span 2}
}
@media(max-width:600px){
  .footer-grid{grid-template-columns:1fr}
  .footer-brand{grid-column:span 1}
}

/* =========== FLOATS ============ */
.notfall-float{
  position:fixed;left:22px;bottom:22px;z-index:100;
  display:inline-flex;align-items:center;gap:12px;
  background:linear-gradient(135deg,#D97A44 0%,#B54A22 100%);
  color:#fff;padding:14px 22px 14px 18px;border-radius:999px;
  box-shadow:0 10px 30px rgba(217,122,68,.4),0 3px 10px rgba(0,0,0,.3);
  font-weight:600;font-size:14px;text-decoration:none;
  font-variant-numeric:tabular-nums;transition:transform .2s;
}
.notfall-float::before{
  content:'';position:absolute;inset:-8px;border-radius:999px;
  background:#D97A44;opacity:.2;
  animation:pulseNF 2.2s ease-out infinite;z-index:-1;
}
@keyframes pulseNF{0%{transform:scale(1);opacity:.3}100%{transform:scale(1.12);opacity:0}}
.notfall-float:hover{transform:translateY(-2px)}
.notfall-float-icon{
  width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.16);
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
}
.notfall-float-icon svg{width:15px;height:15px}
.notfall-label{display:flex;flex-direction:column;gap:2px;line-height:1.1}
.notfall-label small{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:9.5px;letter-spacing:.12em;
  text-transform:uppercase;font-weight:500;opacity:.85;
}
@media(max-width:700px){
  .notfall-float{padding:11px 16px 11px 14px;font-size:13px;left:14px;bottom:14px}
  .notfall-label small{font-size:9px}
  .notfall-float-icon{width:26px;height:26px}
}
@media(max-width:400px){.notfall-label small{display:none}}

.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:100;
  width:60px;height:60px;border-radius:50%;
  background:#25D366;color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(37,211,102,.4),0 3px 10px rgba(0,0,0,.25);
  transition:transform .2s;
}
.wa-float::before{
  content:'';position:absolute;inset:-8px;border-radius:50%;
  background:#25D366;opacity:.25;
  animation:pulseWA 2.4s ease-out infinite;z-index:-1;
}
@keyframes pulseWA{0%{transform:scale(1);opacity:.35}100%{transform:scale(1.6);opacity:0}}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px}
@media(max-width:500px){.wa-float{right:14px;bottom:14px;width:54px;height:54px}}

/* =========== LEGAL PAGES (Impressum, Datenschutz, 404) ============ */
.legal{
  max-width:880px;margin:0 auto;padding:60px 32px 120px;
  font-size:15px;line-height:1.7;color:var(--ink-2);
}
.legal h1{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:clamp(2rem,4.5vw,3.4rem);
  font-weight:500;letter-spacing:-0.03em;line-height:1.05;
  color:var(--ink);margin-bottom:16px;
  font-variation-settings:"opsz" 48;
}
.legal h1 em{color:var(--amber);font-style:italic;font-weight:400}
.legal .lead{
  font-size:17px;color:var(--ink-3);margin-bottom:48px;
  padding-bottom:28px;border-bottom:1px solid var(--line);
}
.legal h2{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:1.5rem;font-weight:500;letter-spacing:-0.015em;
  color:var(--ink);margin:44px 0 18px;
  font-variation-settings:"opsz" 24;
}
.legal h3{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:1.15rem;font-weight:500;letter-spacing:-0.01em;
  color:var(--ink);margin:32px 0 12px;
}
.legal p{margin-bottom:14px}
.legal ul{margin:12px 0 20px;padding-left:20px}
.legal li{margin-bottom:6px}
.legal a{color:var(--amber);text-decoration:underline;text-underline-offset:3px}
.legal a:hover{color:var(--amber-d)}
.legal-meta{
  margin-top:60px;padding-top:24px;border-top:1px solid var(--line);
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:12px;color:var(--ink-4);letter-spacing:.08em;
}
.legal-block{
  background:var(--bg-raised);border:1px solid var(--line);
  padding:24px 28px;border-radius:4px;margin:20px 0;
}
.legal-block dt{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;color:var(--amber-d);letter-spacing:.1em;
  text-transform:uppercase;font-weight:500;
  margin-top:14px;
}
.legal-block dt:first-child{margin-top:0}
.legal-block dd{color:var(--ink);font-size:14.5px;margin-top:4px}

/* 404 */
.page-404{
  min-height:70vh;display:flex;align-items:center;
  padding:80px 32px;text-align:center;
}
.page-404-inner{max-width:520px;margin:0 auto}
.page-404 .code{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:10rem;line-height:1;color:var(--amber);
  font-weight:600;letter-spacing:-0.05em;opacity:.4;
}
.page-404 h1{
  font-family:'Bricolage Grotesque',Georgia,serif;
  font-size:2.2rem;font-weight:500;letter-spacing:-0.02em;
  color:var(--ink);margin:16px 0 16px;
}
.page-404 p{color:var(--ink-2);margin-bottom:32px}

/* =========== UTILITIES ============ */
.container{max-width:var(--container);margin:0 auto;padding:0 32px}
@media(max-width:960px){.container{padding:0 20px}}
.text-amber{color:var(--amber)}
.mt-4{margin-top:40px}
