/* ── CSS VARIABLEN ─────────────────────────────────────── */
:root {
  --blue:#1a6fba; --blue-l:#e8f2fb; --blue-m:#cce1f5; --blue-d:#0d4a80;
  --bg:#ffffff; --bg2:#f6f8fa; --bg3:#eef2f7;
  --text:#1a1f2e; --text2:#4a5568; --text3:#718096;
  --border:#dde3ed;
  --green:#0e7a4a; --green-bg:#e6f7ef;
  --accent:#e85d26;
  --shadow-sm:0 1px 3px rgba(26,111,186,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 12px rgba(26,111,186,.10),0 2px 6px rgba(0,0,0,.06);
  --r:16px; --r-sm:12px;
}
@media(prefers-color-scheme:dark){
  :root{
    --blue:#4d9fde; --blue-l:#0d2a42; --blue-m:#1a3a55; --blue-d:#7ec2f0;
    --bg:#111827; --bg2:#1a2333; --bg3:#222d3f;
    --text:#f0f4f9; --text2:#b0bdd0; --text3:#7a8fa8;
    --border:#2d3d52;
    --green:#3dd68c; --green-bg:#0a2e1e;
    --accent:#ff7a47;
    --shadow-sm:0 1px 3px rgba(0,0,0,.3);
    --shadow-md:0 4px 12px rgba(0,0,0,.4);
  }
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;font-size:16px;line-height:1.7;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

/* TOPBAR */
.topbar{background:var(--blue);color:#fff;font-size:13.5px;padding:8px 0}
.topbar-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.topbar a{color:#d5eaff}.topbar a:hover{color:#fff;text-decoration:none}
.open-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.18);border-radius:20px;padding:2px 12px 2px 8px;font-weight:500}
.dot{width:8px;height:8px;border-radius:50%;background:#6ee7a7;display:inline-block}

/* NAV */
nav{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}
.nav-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{font-family:'DM Serif Display',serif;font-size:1.2rem;color:var(--text)}
.logo span{color:var(--blue)}
.nav-links{display:flex;gap:0;list-style:none}
.nav-links a{display:block;padding:.4rem .9rem;font-size:14px;font-weight:500;color:var(--text2);border-radius:var(--r-sm);transition:color .2s,background .2s}
.nav-links a:hover{color:var(--blue);background:var(--blue-l);text-decoration:none}
.nav-cta{background:var(--blue)!important;color:#fff!important;padding:.4rem 1.1rem!important}
.nav-cta:hover{background:var(--blue-d)!important}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--text);font-size:1.4rem;min-width:44px;min-height:44px;align-items:center;justify-content:center}
@media(max-width:820px){
  .hamburger{display:flex}
  .nav-links{
    display:none;
    position:absolute;
    top:56px;left:0;right:0;
    background:var(--bg);
    border-bottom:1px solid var(--border);
    box-shadow:0 4px 12px rgba(0,0,0,.12);
    flex-direction:column;
    padding:.5rem 1rem .8rem;
    z-index:99;
    max-height:calc(100vh - 56px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .nav-links.open{display:flex}
  .nav-links li{border-bottom:1px solid var(--border)}
  .nav-links li:last-child{border-bottom:none}
  .nav-links a{
    padding:.75rem .8rem;
    font-size:15px;
    min-height:48px;
    display:flex;
    align-items:center;
    border-radius:0;
  }
  .nav-cta{
    margin:.4rem 0 0;
    justify-content:center !important;
    border-radius:var(--r-sm) !important;
  }
}

/* HERO */
.hero{background:var(--bg2);padding:4.5rem 1.5rem 4rem;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(26,111,186,.07) 0%,transparent 70%);pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--blue-l);color:var(--blue);font-size:13px;font-weight:600;border-radius:20px;padding:4px 14px;margin-bottom:1.1rem;border:1px solid var(--blue-m)}
.hero h1{font-family:'DM Serif Display',serif;font-size:clamp(2rem,5vw,3rem);font-weight:400;line-height:1.2;color:var(--text);max-width:700px;margin:0 auto .9rem}
.hero h1 em{color:var(--blue);font-style:normal}
.hero-sub{font-size:1.05rem;color:var(--text2);max-width:560px;margin:0 auto 2.2rem}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* BUTTONS */
.btn-p{background:var(--blue);color:#fff;padding:.75rem 2rem;border-radius:var(--r);font-weight:600;font-size:15px;display:inline-flex;align-items:center;gap:8px;transition:background .2s,transform .1s;box-shadow:var(--shadow-sm)}
.btn-p:hover{background:var(--blue-d);text-decoration:none;transform:translateY(-1px)}
.btn-s{background:var(--bg);color:var(--text);padding:.75rem 2rem;border-radius:var(--r);font-weight:500;font-size:15px;display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--border);transition:border-color .2s,background .2s}
.btn-s:hover{border-color:var(--blue);color:var(--blue);text-decoration:none;background:var(--blue-l)}
.btn-w{background:#fff;color:var(--blue-d);padding:.75rem 2rem;border-radius:var(--r);font-weight:600;font-size:15px;display:inline-flex;align-items:center;gap:8px;transition:background .2s}
.btn-w:hover{background:#dce9f5;text-decoration:none}

/* TRUST BAR */
.trust-bar{background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1.3rem 1.5rem}
.trust-inner{max-width:1100px;margin:0 auto;display:flex;justify-content:center;gap:2.2rem;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text2);font-weight:500}
.ti-icon{width:32px;height:32px;border-radius:8px;background:var(--blue-l);display:flex;align-items:center;justify-content:center;font-size:16px}

/* SECTIONS */
section{padding:4rem 1.5rem}
.sec-inner{max-width:1100px;margin:0 auto}
.sec-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--blue);margin-bottom:.4rem}
.sec-title{font-family:'DM Serif Display',serif;font-size:clamp(1.5rem,3vw,2rem);font-weight:400;color:var(--text);margin-bottom:.4rem;line-height:1.25}
.sec-sub{font-size:1rem;color:var(--text2);max-width:580px;margin-bottom:2rem}
.svc-bg{background:var(--bg2)}

/* SERVICE GRID */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.1rem}
.svc-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:1.4rem;transition:box-shadow .2s,border-color .2s,transform .2s}
.svc-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.svc-icon{width:46px;height:46px;border-radius:10px;background:var(--blue-l);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:.9rem}
.svc-card h3{font-size:15px;font-weight:600;color:var(--text);margin-bottom:.35rem}
.svc-card p{font-size:13.5px;color:var(--text2);line-height:1.55}

/* WHY GRID */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:2rem}
.why-item{display:flex;flex-direction:column;gap:.4rem}
.why-num{font-family:'DM Serif Display',serif;font-size:2.2rem;color:var(--blue-m);line-height:1}
@media(prefers-color-scheme:dark){.why-num{color:var(--blue-d);opacity:.5}}
.why-item h3{font-size:15px;font-weight:600;color:var(--text)}
.why-item p{font-size:14px;color:var(--text2)}

/* PRICE GRID */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.price-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:1.4rem}
.price-card-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text3);margin-bottom:1rem;padding-bottom:.6rem;border-bottom:1px solid var(--border)}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;border-bottom:1px solid var(--border);font-size:14px}
.price-row:last-child{border-bottom:none}
.price-row .label{color:var(--text2)}
.price-row .price{font-weight:700;color:var(--text);white-space:nowrap}

/* CTA BAND */
.cta-band{background:var(--blue);color:#fff;padding:3.5rem 1.5rem;text-align:center}
.cta-band h2{font-family:'DM Serif Display',serif;font-size:clamp(1.4rem,3vw,1.9rem);font-weight:400;margin-bottom:.6rem}
.cta-band p{font-size:14.5px;opacity:.85;max-width:520px;margin:0 auto 1.6rem}

/* INFO / CONTACT */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media(max-width:640px){.info-grid{grid-template-columns:1fr}}
.info-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:1.6rem}
.info-card-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);margin-bottom:1.1rem}
.crow{display:flex;align-items:flex-start;gap:11px;padding:.6rem 0;border-bottom:1px solid var(--border);font-size:14.5px}
.crow:last-child{border-bottom:none}
.cicon{width:34px;height:34px;border-radius:7px;background:var(--blue-l);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;margin-top:1px}
.crow strong{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text3);font-weight:600;margin-bottom:1px}
.crow a,.crow span{color:var(--text);font-weight:500}
.crow a:hover{color:var(--blue)}
.hrow{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:14.5px}
.hrow:last-child{border-bottom:none}
.hrow .day{color:var(--text2)}.hrow .time{font-weight:500}.hrow .closed{color:var(--text3)}

/* CONTACT FORM */
.form-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:2rem}
.fi{display:flex;flex-direction:column;gap:5px;margin-bottom:1rem}
.fi label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text2)}
.fi input,.fi textarea,.fi select{padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.fi input:focus,.fi textarea:focus,.fi select:focus{border-color:var(--blue)}
.fi textarea{resize:vertical;min-height:100px}
.fi-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:500px){.fi-row{grid-template-columns:1fr}}
.form-success{background:var(--green-bg);color:var(--green);padding:1rem 1.2rem;border-radius:var(--r-sm);margin-bottom:1.2rem;font-weight:500}

/* FOOTER */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:2.5rem 1.5rem 1.5rem}
.foot-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem}
@media(max-width:680px){.foot-inner{grid-template-columns:1fr;gap:1.5rem}}
.foot-logo{font-family:'DM Serif Display',serif;font-size:1.1rem;color:var(--text);margin-bottom:.5rem}
.foot-logo span{color:var(--blue)}
footer p{font-size:13.5px;color:var(--text2)}
.foot-col h4{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text3);margin-bottom:.8rem}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:.35rem}
.foot-col a{font-size:13.5px;color:var(--text2)}
.foot-col a:hover{color:var(--blue);text-decoration:none}
.foot-bottom{max-width:1100px;margin:1.5rem auto 0;padding-top:1rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;font-size:12.5px;color:var(--text3)}
.foot-bottom a{color:var(--text3)}.foot-bottom a:hover{color:var(--blue)}

/* ── ANFAHRT ───────────────────────────────────────────────────────── */
.anfahrt-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-bottom: 1.5rem;
}
@media(max-width: 820px) { .anfahrt-grid { grid-template-columns: 1fr; } }

.anfahrt-map {
  border-radius: var(--r);
  overflow: hidden;
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  min-height: 340px;
}
.anfahrt-map iframe {
  width: 100%; flex: 1; border: none; display: block; min-height: 300px;
}
.map-cta {
  display: block;
  background: var(--blue);
  color: #fff;
  text-align: center;
  padding: .7rem 1rem;
  font-size: 14px;
  font-weight: 600;
  transition: background .2s;
}
.map-cta:hover { background: var(--blue-d); text-decoration: none; }

.anfahrt-wege {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.anfahrt-block {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 1rem 1.2rem;
}
.anfahrt-block-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: .7rem;
}
.verkehr-icon {
  width: 28px; height: 28px; border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800; color: #fff; flex-shrink: 0;
}
.verkehr-icon.sbahn  { background: #168e3b; }
.verkehr-icon.tram   { background: #c0121b; }
.verkehr-icon.bus    { background: #7a3798; }
.verkehr-icon.auto   { background: var(--blue); font-size: 16px; }
.verkehr-icon.rad    { background: var(--text3); font-size: 16px; }

.anfahrt-route { font-size: 14px; color: var(--text2); }
.anfahrt-step {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: .35rem;
}
.anfahrt-step-text { margin-bottom: .4rem; }
.anfahrt-linie {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 2px 8px; border-radius: 4px;
  font-size: 12px; font-weight: 800; color: #fff; min-width: 30px;
}
.anfahrt-linie.sbahn  { background: #168e3b; }
.anfahrt-linie.tram   { background: #c0121b; }
.anfahrt-linie.bus    { background: #7a3798; }
.anfahrt-gehweg {
  font-size: 13px; color: var(--text3); margin-top: .3rem;
  padding-left: .5rem; border-left: 2px solid var(--border);
}
.anfahrt-parking {
  display: flex; gap: 8px; align-items: flex-start;
  background: var(--green-bg); color: var(--green);
  padding: .6rem .9rem; border-radius: var(--r-sm);
  font-size: 13.5px; margin-top: .5rem;
}

.anfahrt-adresse {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 1.4rem 1.6rem;
}
.anfahrt-adresse-item {
  display: flex; gap: 10px; align-items: flex-start; font-size: 14px;
}
.anfahrt-adresse-icon { font-size: 20px; flex-shrink: 0; margin-top: 1px; }
.anfahrt-adresse-item strong { display: block; font-size: 12px; color: var(--text3); font-weight: 700; text-transform: uppercase; letter-spacing: .4px; margin-bottom: 2px; }
.anfahrt-adresse-item span { color: var(--text2); }

/* Anklickbare Service-Karten */
a.svc-card { color: inherit; }
a.svc-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: var(--blue);
}

@media(prefers-color-scheme:dark){:root{--orange-bg:#2d1f08;--orange:#f5a623}}

/* ════════════════════════════════════════════════════════════
   MOBILE OPTIMIERUNG – Samsung Browser / Android / alle Phones
   ════════════════════════════════════════════════════════════ */

/* ── Basis-Touch-Optimierungen ──────────────────────────────── */
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
* { -webkit-tap-highlight-color: transparent; }
a, button { touch-action: manipulation; }
input, select, textarea { font-size: 16px !important; } /* verhindert Auto-Zoom auf iOS/Android */

/* ── Topbar auf Phones kompakter ────────────────────────────── */
@media(max-width:640px){
  .topbar { padding: 5px 0; font-size: 12.5px; }
  .topbar-inner {
    padding: 0 .9rem;
    flex-wrap: nowrap;
    justify-content: space-between;
    gap: .5rem;
  }
  .topbar-inner > span:last-child { display: none; } /* E-Mail ausblenden */
  .open-pill { padding: 2px 8px 2px 6px; font-size: 11px; white-space: nowrap; flex-shrink:0; }
}

/* ── Nav / Hamburger-Menü ───────────────────────────────────── */
@media(max-width:820px){
  .nav-inner { padding: 0 1rem; height: 56px; }
  .logo { font-size: 1.05rem; }
}

/* ── Sections: weniger padding auf Phone ────────────────────── */
@media(max-width:640px){
  section { padding: 2.5rem 1rem; }
  .sec-inner { padding: 0; }
  .sec-title { font-size: 1.4rem; }
  .sec-sub { font-size: .95rem; margin-bottom: 1.4rem; }
}
@media(max-width:380px){
  section { padding: 2rem .8rem; }
}

/* ── Hero ───────────────────────────────────────────────────── */
@media(max-width:640px){
  .hero { padding: 2.8rem 1rem 2.5rem; }
  .hero h1 { font-size: 1.75rem; line-height: 1.25; margin-bottom: .7rem; }
  .hero-sub { font-size: .95rem; margin-bottom: 1.6rem; }
  .hero-actions { flex-direction: column; align-items: stretch; gap: .7rem; }
  .hero-actions .btn-p, .hero-actions .btn-s { justify-content: center; padding: .85rem 1.2rem; font-size: 15px; width: 100%; }
  .hero-badge { font-size: 12px; padding: 3px 10px; }
}

/* ── Trust Bar ──────────────────────────────────────────────── */
@media(max-width:640px){
  .trust-inner { gap: .8rem 1.4rem; justify-content: flex-start; }
  .trust-item { font-size: 13px; }
  .ti-icon { width: 28px; height: 28px; font-size: 14px; }
}

/* ── Service Grid ───────────────────────────────────────────── */
@media(max-width:640px){
  .svc-grid { grid-template-columns: 1fr 1fr; gap: .75rem; }
  .svc-card, a.svc-card { padding: 1rem .9rem; }
  .svc-icon { width: 38px; height: 38px; font-size: 18px; margin-bottom: .6rem; }
  .svc-card h3 { font-size: 13px; margin-bottom: .25rem; }
  .svc-card p { font-size: 12.5px; line-height: 1.45; }
  .svc-card span[style*="Mehr erfahren"] { font-size: 11px !important; }
}
@media(max-width:360px){
  .svc-grid { grid-template-columns: 1fr; }
}

/* ── Price Cards ────────────────────────────────────────────── */
@media(max-width:640px){
  .price-grid { grid-template-columns: 1fr; gap: .75rem; }
  .price-card { padding: 1.1rem; }
  .price-row { font-size: 13.5px; }
}

/* ── Why Grid ───────────────────────────────────────────────── */
@media(max-width:640px){
  .why-grid { grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1.2rem; }
  .why-num { font-size: 1.8rem; }
  .why-item h3 { font-size: 14px; }
  .why-item p { font-size: 13px; }
}
@media(max-width:380px){
  .why-grid { grid-template-columns: 1fr; }
}

/* ── Info / Kontakt Grid ────────────────────────────────────── */
@media(max-width:640px){
  .info-grid { grid-template-columns: 1fr; gap: .75rem; }
  .info-card { padding: 1.2rem; }
  .crow { font-size: 14px; }
  .cicon { width: 30px; height: 30px; font-size: 14px; }
}

/* ── Anfahrt Grid ───────────────────────────────────────────── */
@media(max-width:820px){
  .anfahrt-grid { grid-template-columns: 1fr; gap: 1rem; }
  .anfahrt-map { min-height: 260px; }
  .anfahrt-map iframe { min-height: 240px; }
}
@media(max-width:640px){
  .anfahrt-adresse { grid-template-columns: 1fr; gap: .6rem; padding: 1rem; }
}

/* ── CTA Band ───────────────────────────────────────────────── */
@media(max-width:640px){
  .cta-band { padding: 2.5rem 1rem; }
  .cta-band h2 { font-size: 1.3rem; }
  .cta-band .hero-actions { flex-direction: column; align-items: stretch; }
  .cta-band .btn-p, .cta-band .btn-w { justify-content: center; width: 100%; }
}

/* ── Kontaktformular ────────────────────────────────────────── */
@media(max-width:640px){
  .form-card { padding: 1.2rem 1rem; }
  .fi-row { grid-template-columns: 1fr; gap: 0; }
  .fi input, .fi textarea, .fi select { padding: 10px 11px; }
}

/* ── Footer ─────────────────────────────────────────────────── */
@media(max-width:680px){
  footer { padding: 2rem 1rem 1.2rem; }
  .foot-inner { grid-template-columns: 1fr; gap: 1.2rem; }
  .foot-bottom { flex-direction: column; align-items: center; text-align: center; }
}

/* ── Service-Landingpages ───────────────────────────────────── */
@media(max-width:820px){
  .svc-grid2 { grid-template-columns: 1fr !important; }
  .svc-hero { padding: 2rem 1rem; }
  .svc-hero h1 { font-size: 1.5rem !important; }
  .svc-icon-big { font-size: 2.5rem; }
}
@media(max-width:640px){
  .svc-hero-inner { flex-direction: column; gap: .5rem; }
  .svc-icon-big { align-self: flex-start; }
}

/* ── Ortsseiten Hero (bb + berlin) ─────────────────────────── */
@media(max-width:640px){
  .hero-bb, .hero-bl { padding: 1.8rem 1rem; }
  .hero-bb-inner, .hero-bl-inner { flex-direction: column; gap: .8rem; }
  .hero-bb h1, .hero-bl h1 { font-size: 1.35rem !important; }
  .pills { gap: 5px; }
  .pill { font-size: 11px; padding: 2px 9px; }
  .main-grid { grid-template-columns: 1fr !important; }
  .anfahrt-grid { grid-template-columns: 1fr !important; }
}

/* ── Produkte-Seite ─────────────────────────────────────────── */
@media(max-width:640px){
  .prod-grid { grid-template-columns: 1fr !important; gap: 1rem; }
  .prod-img-wrap { height: 200px; }
  .filter-bar { gap: .4rem; }
  .filter-btn { font-size: 12.5px; padding: 5px 12px; }
}
@media(min-width:400px) and (max-width:640px){
  .prod-grid { grid-template-columns: 1fr 1fr !important; }
  .prod-img-wrap { height: 160px; }
}

/* ── Aktuelles-Seite ────────────────────────────────────────── */
@media(max-width:640px){
  .artikel-grid { grid-template-columns: 1fr !important; }
  .artikel-card-img { height: 160px; }
}

/* ── Artikel-Detail ─────────────────────────────────────────── */
@media(max-width:640px){
  .artikel-wrap { max-width: 100%; }
  .artikel-h1 { font-size: 1.35rem !important; line-height: 1.3; }
  .artikel-lead { font-size: .95rem; }
  .artikel-body { font-size: 14.5px; }
  .cta-box { padding: 1.5rem 1rem; }
  .cta-box div[style*="flex"] { flex-direction: column; }
  .cta-box div[style*="flex"] a { width: 100%; text-align: center; }
}

/* ── Breadcrumb ─────────────────────────────────────────────── */
@media(max-width:480px){
  div[style*="padding:.7rem 1.5rem"] { padding: .5rem .9rem !important; font-size: 12px; }
}

/* ── Buttons allgemein: Touch-Größe ─────────────────────────── */
@media(max-width:640px){
  .btn-p, .btn-s, .btn-w { min-height: 44px; padding: .7rem 1.2rem; }
}

/* ── Aside-Boxen (Ortsseiten Sidebar) ──────────────────────── */
@media(max-width:720px){
  .aside-box { margin-top: 1.5rem; }
}

/* ── Schließungs-Banner ─────────────────────────────────────── */
@media(max-width:480px){
  #schliessungBanner { font-size: 13px; padding: .7rem 1rem; gap: 8px; }
  #schliessungBanner span[style*="22px"] { font-size: 18px !important; }
}

/* ── Fernwartungsseite ──────────────────────────────────────── */
@media(max-width:640px){
  .browser-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; white-space: nowrap; }
  .btab { padding: .45rem .8rem; font-size: 12.5px; }
  .btab-content { font-size: 13px; }
  .anydesk-dl { display: flex; justify-content: center; width: 100%; margin: .4rem 0; }
  .id-box { flex-direction: column; gap: 8px; }
}

/* ── Admin-Backend ──────────────────────────────────────────── */
@media(max-width:820px){
  .sidebar { width: 0; overflow: hidden; position: fixed; z-index: 200; transition: width .25s; }
  .sidebar.open { width: 260px; overflow-y: auto; }
  .main { margin-left: 0 !important; }
  .top-bar { padding: 0 1rem; }
}

/* ── Globale Hilfeklassen für Mobile ────────────────────────── */
@media(max-width:480px){
  .hide-xs { display: none !important; }
}

/* ── Bilder nie über Container ──────────────────────────────── */
img { max-width: 100%; height: auto; }

/* ── Overflow Prevention ────────────────────────────────────── */
body { overflow-x: hidden; }
.sec-inner { overflow-x: hidden; }

/* ── Topbar Mobile Fixes ────────────────────────────────────── */
.topbar-tel{color:#d5eaff;font-weight:600;text-decoration:none;white-space:nowrap}
.topbar-tel:hover{color:#fff;text-decoration:none}
@media(max-width:640px){
  .topbar-inner{flex-wrap:nowrap;justify-content:space-between;align-items:center}
  .topbar-inner .hide-xs{display:none!important}
  .open-pill .hide-xs{display:none!important}
}

/* ── Footer Mobile ──────────────────────────────────────────── */
@media(max-width:680px){
  .foot-inner{grid-template-columns:1fr 1fr;gap:1.2rem}
  .foot-inner>div:first-child{grid-column:1/-1} /* Logo-Bereich volle Breite */
  footer{padding:1.8rem 1rem 1.2rem}
  .foot-logo{font-size:1rem}
  .foot-bottom{flex-direction:column;align-items:center;text-align:center;gap:.3rem}
}
@media(max-width:400px){
  .foot-inner{grid-template-columns:1fr}
}
