/* =========================================================
   Lärmschutz Montage Bralic & Dekic — Stylesheet
   Mobile-first · zero CLS · self-contained
   ========================================================= */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
body,h1,h2,h3,h4,h5,h6,p,figure,blockquote,dl,dd,ul,ol,address{margin:0}
ul,ol{padding:0;list-style:none}
img,svg,video,canvas,picture{display:block;max-width:100%;height:auto}
img{font-style:italic}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
input,textarea,select{font:inherit;color:inherit}
:focus-visible{outline:2px solid var(--c-accent);outline-offset:3px;border-radius:4px}

:root{
  --c-bg:#f7f5f0;
  --c-surface:#ffffff;
  --c-ink:#0a1628;
  --c-ink-soft:#3a4654;
  --c-muted:#6e7782;
  --c-line:#e3ddd2;
  --c-line-strong:#c9bfae;
  --c-accent:#ff6b1a;
  --c-accent-hover:#e55600;
  --c-accent-soft:#fff0e6;
  --c-dark:#0a1628;
  --c-dark-2:#0f1d35;
  --c-success:#0e7a3f;
  --c-error:#b91c1c;

  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:24px;
  --shadow-sm:0 1px 2px rgba(10,22,40,.06), 0 2px 8px rgba(10,22,40,.05);
  --shadow-md:0 4px 12px rgba(10,22,40,.08), 0 12px 32px rgba(10,22,40,.08);
  --shadow-lg:0 12px 24px rgba(10,22,40,.12), 0 24px 60px rgba(10,22,40,.12);

  --container:1240px;
  --gutter:24px;

  --font-sans: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
  --font-display: "Segoe UI",-apple-system,BlinkMacSystemFont,Roboto,"Helvetica Neue",Arial,sans-serif;

  --t-fast:160ms;
  --t-base:260ms;
  --ease:cubic-bezier(.2,.8,.2,1);
}

html,body{background:var(--c-bg);color:var(--c-ink);font-family:var(--font-sans);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{overflow-x:hidden}

h1,h2,h3,h4{font-family:var(--font-display);line-height:1.15;font-weight:800;letter-spacing:-.01em;color:var(--c-ink);overflow-wrap:break-word;word-wrap:break-word}
h1{font-size:clamp(2.1rem,4.6vw + .5rem,3.85rem)}
h2{font-size:clamp(1.55rem,2.4vw + .5rem,2.5rem)}
h3{font-size:clamp(1.15rem,1vw + .6rem,1.4rem)}
p{color:var(--c-ink-soft);overflow-wrap:break-word}

.skip-link{position:fixed;top:-40px;left:8px;background:var(--c-accent);color:#fff;padding:8px 12px;z-index:9999;border-radius:4px;font-weight:600}
.skip-link:focus{top:8px}

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

.muted{color:var(--c-muted)}
.text-center{text-align:center}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.95rem 1.6rem;border-radius:var(--r-md);
  font-weight:700;letter-spacing:.01em;font-size:.95rem;line-height:1;
  transition:transform var(--t-fast) var(--ease),background var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease),color var(--t-fast) var(--ease);
  white-space:nowrap;text-align:center;justify-content:center;will-change:transform}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--c-accent);color:#fff;box-shadow:0 4px 14px rgba(255,107,26,.35)}
.btn--primary:hover{background:var(--c-accent-hover);box-shadow:0 8px 22px rgba(255,107,26,.45)}
.btn--ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.55)}
.btn--ghost:hover{background:#fff;color:var(--c-ink);border-color:#fff}
.btn--dark{background:var(--c-ink);color:#fff}
.btn--dark:hover{background:#172238}
.btn--lg{padding:1.1rem 2rem;font-size:1rem}
.btn--block{display:flex;width:100%}
.btn--whatsapp{background:#25d366;color:#fff;box-shadow:0 4px 14px rgba(37,211,102,.35)}
.btn--whatsapp:hover{background:#1da851;box-shadow:0 8px 22px rgba(37,211,102,.45);color:#fff}

/* WhatsApp inline link (next to phone number) */
.wa-link{display:inline-flex;align-items:center;gap:.3rem;color:#25d366;font-weight:600;font-size:.85rem;transition:color var(--t-fast);margin-left:.5rem}
.wa-link:hover{color:#1da851}
.wa-link svg{flex-shrink:0}
.wa-stack{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem .6rem}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:#fff;box-shadow:0 1px 0 var(--c-line)}
.header-bar{background:var(--c-dark);color:#cfd4dd;font-size:.825rem}
.header-bar__inner{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:.5rem 1rem;flex-wrap:wrap;padding:.3rem 0}
.header-bar__contact{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;min-width:0}
.header-bar__link{display:inline-flex;align-items:center;gap:.4rem;color:#cfd4dd;transition:color var(--t-fast);white-space:nowrap}
.header-bar__link:hover{color:var(--c-accent)}
.header-bar__link svg{flex-shrink:0}
.header-bar__link--wa{color:#fff;font-weight:600}
.header-bar__link--wa:hover{color:#25d366}
.header-bar__lang{display:flex;gap:.4rem;align-items:center;font-weight:600;flex-shrink:0}
.lang-toggle{display:inline-flex;align-items:center;gap:.35rem;padding:.15rem .4rem;border-radius:4px;
  color:#7a8595;letter-spacing:.04em;font-size:.78rem;transition:color var(--t-fast),background var(--t-fast)}
.lang-toggle img{width:18px;height:13px;border-radius:2px;object-fit:cover;display:block;
  box-shadow:0 0 0 1px rgba(255,255,255,.12);opacity:.7;transition:opacity var(--t-fast),transform var(--t-fast)}
.lang-toggle:hover{color:#fff;background:rgba(255,255,255,.05)}
.lang-toggle:hover img{opacity:1}
.lang-toggle.is-active{color:var(--c-accent)}
.lang-toggle.is-active img{opacity:1}
.lang-toggle__sep{color:#3d4858;user-select:none}
@media (max-width:560px){
  .header-bar__link--hide-sm{display:none}
  .header-bar__inner{gap:.4rem .8rem;padding:.4rem 0}
  .header-bar__contact{gap:.8rem;font-size:.78rem}
  .lang-toggle{font-size:.74rem;padding:.1rem .3rem}
  .lang-toggle img{width:16px;height:11px}
  .header-main__inner{min-height:64px}
  .brand__mark{width:38px;height:38px}
  .brand__text strong{font-size:.95rem}
  .brand__text small{display:none}
}
@media (max-width:380px){
  .header-bar__contact{gap:.6rem}
  .lang-toggle span{display:none}
  .header-bar__link svg{width:13px;height:13px}
}

.header-main__inner{display:flex;align-items:center;justify-content:space-between;min-height:78px;gap:1rem}
.brand{display:inline-flex;align-items:center;gap:.7rem}
.brand__mark{display:inline-grid;place-items:center;width:44px;height:44px;background:var(--c-bg);border-radius:10px;flex-shrink:0}
.brand__text{display:flex;flex-direction:column;line-height:1.1}
.brand__text strong{font-size:1.05rem;font-weight:800;letter-spacing:-.01em;color:var(--c-ink)}
.brand__text small{font-size:.7rem;color:var(--c-muted);letter-spacing:.06em;text-transform:uppercase;margin-top:2px}

.primary-nav{display:flex;align-items:center;gap:1.4rem}
.primary-nav__list{display:flex;gap:.2rem;align-items:center}
.primary-nav__close{display:none;position:absolute;top:14px;right:18px;font-size:2rem;color:#fff;line-height:1;width:40px;height:40px}
.nav-link{position:relative;padding:.65rem .9rem;border-radius:6px;font-weight:600;font-size:.95rem;color:var(--c-ink);transition:color var(--t-fast)}
.nav-link::after{content:"";position:absolute;left:.9rem;right:.9rem;bottom:.4rem;height:2px;background:var(--c-accent);transform:scaleX(0);transform-origin:left;transition:transform var(--t-base) var(--ease)}
.nav-link:hover,.nav-link.is-active{color:var(--c-accent)}
.nav-link:hover::after,.nav-link.is-active::after{transform:scaleX(1)}

.nav-toggle{display:none;width:44px;height:44px;border-radius:8px;border:1px solid var(--c-line);flex-direction:column;justify-content:center;align-items:center;gap:5px;background:#fff}
.nav-toggle span{width:22px;height:2px;background:var(--c-ink);border-radius:2px;transition:transform var(--t-fast),opacity var(--t-fast)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:1023px){
  .nav-toggle{display:inline-flex}
  .header-main{position:relative}
  .primary-nav{position:absolute;top:100%;left:0;right:0;background:#fff;
    flex-direction:column;align-items:stretch;justify-content:flex-start;padding:.5rem 1rem 1rem;gap:0;
    transform:translateY(-10px);opacity:0;pointer-events:none;
    transition:transform var(--t-fast) var(--ease),opacity var(--t-fast) var(--ease);
    box-shadow:0 12px 24px rgba(10,22,40,.1);border-top:1px solid var(--c-line);
    z-index:60;max-height:calc(100dvh - 120px);overflow-y:auto}
  .primary-nav.is-open{transform:translateY(0);opacity:1;pointer-events:auto}
  .primary-nav__list{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .primary-nav__list .nav-link{display:block;padding:.9rem .6rem;border-radius:0;border-bottom:1px solid var(--c-line);font-size:1rem;color:var(--c-ink)}
  .primary-nav__list li:last-child .nav-link{border-bottom:0}
  .primary-nav__list .nav-link::after{display:none}
  .primary-nav__list .nav-link:hover,.primary-nav__list .nav-link.is-active{color:var(--c-accent);background:transparent}
  .primary-nav__cta{margin-top:.8rem}
}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden;isolation:isolate;background:var(--c-dark)}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,22,40,.85) 0%,rgba(10,22,40,.65) 50%,rgba(10,22,40,.45) 100%)}
.hero__inner{position:relative;padding:7rem 0 5.5rem;display:grid;gap:3rem;grid-template-columns:1.3fr 1fr;align-items:center}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.6rem;padding:.45rem 1rem;border-radius:999px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;color:#fff;margin-bottom:1.2rem}
.hero__eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--c-accent);box-shadow:0 0 0 4px rgba(255,107,26,.25)}
.hero h1{color:#fff;margin-bottom:1.2rem}
.hero h1 span{color:var(--c-accent)}
.hero p{color:rgba(255,255,255,.85);font-size:1.08rem;max-width:55ch;margin-bottom:2rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem}
.hero__stats{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);
  padding:1.6rem;display:grid;gap:1rem;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.hero__stat{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.1)}
.hero__stat:last-child{border-bottom:0}
.hero__stat-num{font-family:var(--font-display);font-size:2.4rem;font-weight:800;color:var(--c-accent);line-height:1}
.hero__stat-label{color:rgba(255,255,255,.85);font-weight:500}

@media (max-width:880px){
  .hero__inner{grid-template-columns:1fr;padding:5rem 0 4rem;gap:2.4rem}
  .hero__stat-num{font-size:2rem}
}

/* ---------- Page header (sub pages) ---------- */
.page-hero{position:relative;color:#fff;background:var(--c-dark);overflow:hidden;isolation:isolate}
.page-hero__bg{position:absolute;inset:0;z-index:-2}
.page-hero__bg img{width:100%;height:100%;object-fit:cover}
.page-hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,22,40,.92) 0%,rgba(10,22,40,.7) 100%)}
.page-hero__inner{position:relative;padding:6rem 0 4rem;text-align:left}
.page-hero h1{color:#fff;margin-bottom:1rem}
.breadcrumbs{display:flex;flex-wrap:wrap;gap:.5rem;color:rgba(255,255,255,.75);font-size:.9rem}
.breadcrumbs a:hover{color:var(--c-accent)}
.breadcrumbs li::after{content:"›";margin-left:.5rem;color:rgba(255,255,255,.5)}
.breadcrumbs li:last-child::after{content:""}
.breadcrumbs li[aria-current]{color:var(--c-accent)}

/* ---------- Sections ---------- */
.section{padding:5.5rem 0;position:relative}
.section--alt{background:#fff}
.section--dark{background:var(--c-dark);color:#fff}
.section--dark h2,.section--dark h3{color:#fff}
.section--dark p{color:rgba(255,255,255,.75)}
.section--narrow{padding:3.5rem 0}
.section-head{max-width:760px;margin:0 auto 3rem;text-align:center}
.section-head--left{text-align:left;margin-inline:0}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  font-weight:700;color:var(--c-accent);margin-bottom:.9rem}
.eyebrow::before,.eyebrow::after{content:"";width:24px;height:2px;background:var(--c-accent);border-radius:2px}
.eyebrow--start::after{display:none}
.section-head__title{margin-bottom:1rem}
.section-head__text{font-size:1.05rem;max-width:65ch;margin:0 auto}

/* ---------- Service cards ---------- */
.service-grid{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.service-card{position:relative;background:#fff;border-radius:var(--r-lg);padding:2rem 1.6rem;
  box-shadow:var(--shadow-sm);border:1px solid var(--c-line);overflow:hidden;
  transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease)}
.service-card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--c-accent);transform:scaleX(0);transform-origin:left;transition:transform var(--t-base) var(--ease)}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.service-card:hover::before{transform:scaleX(1)}
.service-card__icon{display:grid;place-items:center;width:60px;height:60px;border-radius:14px;background:var(--c-accent-soft);color:var(--c-accent);margin-bottom:1.1rem}
.service-card__icon svg{width:32px;height:32px}
.service-card h3{margin-bottom:.55rem}
.service-card p{font-size:.95rem;line-height:1.55}
.service-card__num{position:absolute;top:1.4rem;right:1.4rem;font-family:var(--font-display);font-size:2.4rem;font-weight:800;color:var(--c-line);line-height:1}

/* ---------- About + image split ---------- */
.split{display:grid;gap:3rem;grid-template-columns:1fr 1fr;align-items:center}
.split--reverse .split__media{order:2}
.split__media{position:relative}
.split__media img{width:100%;border-radius:var(--r-xl);box-shadow:var(--shadow-md);aspect-ratio:5/4;object-fit:cover}
.split__media-tag{position:absolute;left:-12px;bottom:-18px;background:var(--c-accent);color:#fff;padding:1rem 1.4rem;border-radius:var(--r-md);font-weight:700;box-shadow:var(--shadow-md);font-size:.95rem;line-height:1.2}
.split__media-tag strong{display:block;font-size:1.6rem;font-weight:800}
.split__content h2{margin-bottom:1.1rem}
.split__content > p{font-size:1.05rem;margin-bottom:1.4rem}
.checklist{display:grid;gap:.8rem;margin:1.4rem 0 1.8rem}
.checklist li{display:flex;gap:.8rem;align-items:flex-start;font-weight:500;color:var(--c-ink)}
.checklist li::before{content:"";flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--c-accent-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='none' stroke='%23ff6b1a' stroke-width='3' stroke-linecap='round' stroke-linejoin='round' d='M5 13l4 4L19 7'/></svg>") center/14px no-repeat}

@media (max-width:880px){
  .split{grid-template-columns:1fr;gap:2.4rem}
  .split--reverse .split__media{order:0}
}

/* ---------- Why cards ---------- */
.why-grid{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.why-card{position:relative;padding:2.4rem 1.8rem 2.2rem;background:#fff;border-radius:var(--r-lg);text-align:center;border:1px solid var(--c-line);transition:transform var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}
.why-card:hover{transform:translateY(-4px);border-color:var(--c-accent)}
.why-card__icon{display:inline-grid;place-items:center;width:80px;height:80px;border-radius:50%;background:linear-gradient(140deg,var(--c-accent),#ffa468);color:#fff;margin-bottom:1.2rem;box-shadow:0 10px 24px rgba(255,107,26,.3)}
.why-card__icon svg{width:38px;height:38px}
.why-card h3{margin-bottom:.55rem}
.why-card p{font-size:.95rem}

/* ---------- CTA banner ---------- */
.cta-banner{position:relative;color:#fff;background:linear-gradient(135deg,var(--c-dark) 0%,#152647 100%);border-radius:var(--r-xl);padding:3.5rem 2.5rem;overflow:hidden;isolation:isolate}
.cta-banner::before{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle at center,rgba(255,107,26,.35),transparent 70%);z-index:-1}
.cta-banner__inner{display:grid;gap:1.6rem;grid-template-columns:1.4fr auto;align-items:center}
.cta-banner h2{color:#fff;margin-bottom:.5rem}
.cta-banner p{color:rgba(255,255,255,.8);max-width:55ch;margin:0}
.cta-banner__btns{display:flex;gap:.8rem;flex-wrap:wrap}
@media (max-width:760px){.cta-banner__inner{grid-template-columns:1fr}.cta-banner{padding:2.4rem 1.6rem}}

/* ---------- Stats ---------- */
.stats{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));text-align:center}
.stat{padding:1.5rem;border-radius:var(--r-lg);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1)}
.stat__num{font-family:var(--font-display);font-size:clamp(2rem,3vw,3rem);font-weight:800;color:var(--c-accent);line-height:1;margin-bottom:.4rem}
.stat__label{color:rgba(255,255,255,.85);font-weight:500}

/* ---------- Service list (services page) ---------- */
.service-list{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.service-item{display:flex;gap:1rem;padding:1.4rem;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.service-item:hover{border-color:var(--c-accent);box-shadow:var(--shadow-sm)}
.service-item__icon{flex-shrink:0;width:46px;height:46px;border-radius:10px;background:var(--c-accent-soft);color:var(--c-accent);display:grid;place-items:center}
.service-item__icon svg{width:24px;height:24px}
.service-item h3{font-size:1.05rem;margin-bottom:.35rem}
.service-item p{font-size:.92rem;line-height:1.55}

/* ---------- Process ---------- */
.process{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));counter-reset:step}
.process-step{position:relative;padding:2.2rem 1.6rem 1.8rem;background:#fff;border-radius:var(--r-lg);border:1px solid var(--c-line);counter-increment:step}
.process-step::before{content:counter(step,decimal-leading-zero);position:absolute;top:1rem;right:1.2rem;font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:var(--c-line-strong);line-height:1}
.process-step h3{margin-bottom:.5rem;padding-right:2.5rem}

/* ---------- Values ---------- */
.values{display:grid;gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.value{padding:1.6rem;background:#fff;border-radius:var(--r-md);border-left:4px solid var(--c-accent);box-shadow:var(--shadow-sm)}
.value h3{margin-bottom:.5rem}
.value p{font-size:.95rem}

/* ---------- Project gallery ---------- */
.gallery{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.gallery__item{position:relative;border-radius:var(--r-md);overflow:hidden;background:var(--c-line);aspect-ratio:4/3;cursor:zoom-in;transition:transform var(--t-base) var(--ease)}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform 600ms var(--ease)}
.gallery__item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(10,22,40,.7));opacity:0;transition:opacity var(--t-base)}
.gallery__item:hover img{transform:scale(1.06)}
.gallery__item:hover::after{opacity:1}
.gallery__icon{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.8);
  width:54px;height:54px;border-radius:50%;background:var(--c-accent);color:#fff;display:grid;place-items:center;
  opacity:0;transition:opacity var(--t-base),transform var(--t-base);z-index:1}
.gallery__item:hover .gallery__icon{opacity:1;transform:translate(-50%,-50%) scale(1)}
.gallery__icon svg{width:24px;height:24px}

/* ---------- Baustellen list (compact cards, max 2 per row) ---------- */
.baustellen-grid{display:grid;gap:1.4rem;grid-template-columns:1fr;max-width:920px;margin:0 auto}
@media (min-width:640px){.baustellen-grid{grid-template-columns:1fr 1fr;gap:1.5rem}}

.baustelle-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--c-line);border-radius:14px;overflow:hidden;
  color:var(--c-ink);box-shadow:0 1px 2px rgba(10,22,40,.04);
  transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}
.baustelle-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(10,22,40,.1);border-color:var(--c-accent);color:var(--c-ink)}

.baustelle-card__media{position:relative;aspect-ratio:3/2;background:var(--c-line);overflow:hidden}
.baustelle-card__media img{width:100%;height:100%;object-fit:cover;transition:transform 600ms var(--ease)}
.baustelle-card:hover .baustelle-card__media img{transform:scale(1.05)}
.baustelle-card__placeholder{position:absolute;inset:0;display:grid;place-items:center;color:var(--c-line-strong);background:var(--c-bg)}
.baustelle-card__badge{position:absolute;top:.7rem;left:.7rem;background:rgba(255,255,255,.95);color:var(--c-ink);
  padding:.28rem .65rem;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 2px 8px rgba(10,22,40,.12)}

.baustelle-card__body{padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.baustelle-card h3{font-size:1.02rem;line-height:1.35;margin:0;font-weight:700;color:var(--c-ink);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.baustelle-card__meta{display:flex;flex-wrap:wrap;gap:.55rem .85rem;font-size:.74rem;color:var(--c-muted);margin-top:auto;padding-top:.4rem;border-top:1px solid var(--c-line)}
.baustelle-card__meta span{display:inline-flex;align-items:center;gap:.25rem}
.baustelle-card__meta svg{flex-shrink:0;color:var(--c-accent);opacity:.85}

/* ---------- Pagination ---------- */
.pagination{display:flex;justify-content:center;align-items:center;gap:.4rem;margin:3rem 0 0;flex-wrap:wrap}
.pagination__link{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 .8rem;
  border-radius:8px;background:#fff;border:1px solid var(--c-line);color:var(--c-ink);font-weight:600;font-size:.92rem;
  transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}
.pagination__link:hover{border-color:var(--c-accent);color:var(--c-accent)}
.pagination__link.is-active{background:var(--c-accent);border-color:var(--c-accent);color:#fff;cursor:default;pointer-events:none}
.pagination__link.is-disabled{opacity:.4;pointer-events:none}
.pagination__ellipsis{display:inline-flex;align-items:center;justify-content:center;width:32px;color:var(--c-muted)}
.pagination__edge{padding:0 1rem}

/* ---------- Baustelle detail ---------- */
.baustelle-meta-list{display:flex;flex-wrap:wrap;gap:1.6rem;padding:1.2rem 1.4rem;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--r-md);margin-bottom:2rem;font-size:.95rem;list-style:none}
.baustelle-meta-list li{color:var(--c-ink-soft)}
.baustelle-meta-list strong{color:var(--c-ink);font-weight:700;margin-right:.3rem}
.baustelle-detail__body{font-size:1.05rem;line-height:1.75;color:var(--c-ink-soft);margin-bottom:2.5rem}
.baustelle-detail__body p{margin:0 0 1rem}
.baustelle-detail__body p:last-child{margin-bottom:0}
.baustelle-detail__body h2{font-size:1.55rem;color:var(--c-ink);margin:2rem 0 .8rem;font-weight:800;line-height:1.25}
.baustelle-detail__body h3{font-size:1.25rem;color:var(--c-ink);margin:1.5rem 0 .6rem;font-weight:700;line-height:1.3}
.baustelle-detail__body h4{font-size:1.1rem;color:var(--c-ink);margin:1.2rem 0 .5rem;font-weight:700}
.baustelle-detail__body h2:first-child,.baustelle-detail__body h3:first-child,.baustelle-detail__body h4:first-child{margin-top:0}
.baustelle-detail__body ul,.baustelle-detail__body ol{margin:.8rem 0 1.2rem;padding-left:1.6rem}
.baustelle-detail__body li{margin-bottom:.4rem}
.baustelle-detail__body strong{color:var(--c-ink);font-weight:700}
.baustelle-detail__body em{font-style:italic}
.baustelle-detail__body a{color:var(--c-accent);text-decoration:underline;font-weight:500}
.baustelle-detail__body a:hover{color:var(--c-accent-hover)}
.baustelle-detail__body blockquote{margin:1.5rem 0;padding:.6rem 0 .6rem 1.2rem;border-left:4px solid var(--c-accent);color:var(--c-ink);font-style:italic}
.baustelle-detail__gallery-title{margin:2.5rem 0 1.5rem;font-size:1.5rem}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;background:rgba(10,22,40,.95);z-index:200;display:none;align-items:center;justify-content:center;padding:2rem}
.lightbox.is-open{display:flex}
.lightbox__img{max-width:min(96vw,1400px);max-height:88vh;border-radius:var(--r-md);box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox__btn{position:absolute;background:rgba(255,255,255,.1);color:#fff;width:50px;height:50px;border-radius:50%;display:grid;place-items:center;transition:background var(--t-fast)}
.lightbox__btn:hover{background:var(--c-accent)}
.lightbox__close{top:1.5rem;right:1.5rem;font-size:1.6rem;line-height:1}
.lightbox__prev{left:1.5rem;top:50%;transform:translateY(-50%)}
.lightbox__next{right:1.5rem;top:50%;transform:translateY(-50%)}
.lightbox__btn svg{width:24px;height:24px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;gap:2.5rem;grid-template-columns:1fr 1.4fr;align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr}}
.contact-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:1.4rem;display:flex;gap:1rem;align-items:flex-start;margin-bottom:1rem;transition:border-color var(--t-fast);min-width:0}
.contact-card:hover{border-color:var(--c-accent)}
.contact-card__icon{flex-shrink:0;width:46px;height:46px;border-radius:10px;background:var(--c-accent-soft);color:var(--c-accent);display:grid;place-items:center}
.contact-card__icon svg{width:22px;height:22px}
.contact-card>div:not(.contact-card__icon){min-width:0;flex:1}
.contact-card h3{font-size:1rem;margin-bottom:.25rem}
.contact-card p,.contact-card a{font-size:.95rem;color:var(--c-ink-soft);display:block;overflow-wrap:anywhere;word-break:break-word}
.contact-card a:hover{color:var(--c-accent)}

.contact-form{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:2rem;box-shadow:var(--shadow-sm)}
.form-grid{display:grid;gap:1.2rem;grid-template-columns:1fr 1fr}
@media (max-width:600px){.form-grid{grid-template-columns:1fr}}
.field{position:relative}
.field--full{grid-column:1/-1}
.field input,.field textarea{width:100%;padding:1.05rem 1rem .55rem;border:1.5px solid var(--c-line);background:#fff;
  border-radius:var(--r-sm);transition:border-color var(--t-fast);font-size:1rem;color:var(--c-ink);font-family:inherit}
.field textarea{min-height:160px;resize:vertical;padding-top:1.5rem}
.field input:focus,.field textarea:focus{border-color:var(--c-accent);outline:none}
.field label{position:absolute;left:1rem;top:1rem;color:var(--c-muted);pointer-events:none;transition:transform var(--t-fast),color var(--t-fast),font-size var(--t-fast);background:#fff;padding:0 .25rem}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{transform:translateY(-1.45rem) scale(.85);color:var(--c-accent)}
.field input::placeholder,.field textarea::placeholder{color:transparent}

.checkbox{display:flex;gap:.75rem;align-items:flex-start;font-size:.9rem;color:var(--c-ink-soft);line-height:1.5}
.checkbox input{margin-top:.2rem;accent-color:var(--c-accent);width:18px;height:18px;flex-shrink:0}
.checkbox a{color:var(--c-accent);text-decoration:underline}

.form-status{padding:1rem;border-radius:var(--r-sm);font-size:.95rem;display:none}
.form-status.is-success{display:block;background:#e7f6ec;color:var(--c-success);border:1px solid #b8e0c2}
.form-status.is-error{display:block;background:#fde7e7;color:var(--c-error);border:1px solid #f5b7b7}

/* ---------- Legal pages (Impressum, Datenschutz) ---------- */
.legal{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:clamp(1.6rem,4vw,3rem);box-shadow:var(--shadow-sm)}
.legal h2{font-size:1.4rem;margin:1.8rem 0 .8rem}
.legal h2:first-of-type{margin-top:0}
.legal h3{font-size:1.1rem;margin:1.4rem 0 .5rem}
.legal p,.legal li{font-size:.97rem;line-height:1.7;color:var(--c-ink-soft)}
.legal ul{padding-left:1.2rem;list-style:disc;margin:.6rem 0 1rem}
.legal ul li{margin-bottom:.3rem}
.legal a{color:var(--c-accent);text-decoration:underline}

/* ---------- Footer ---------- */
.site-footer{background:var(--c-dark);color:rgba(255,255,255,.75);padding:4rem 0 1.5rem}
.site-footer__grid{display:grid;gap:2rem;grid-template-columns:1.4fr 1fr 1fr 1.4fr;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
.brand--footer .brand__text strong{color:#fff}
.brand--footer .brand__text small{color:rgba(255,255,255,.6)}
.brand--footer .brand__mark{background:rgba(255,255,255,.06)}
.site-footer__about{margin-top:1.2rem;font-size:.92rem;line-height:1.7;color:rgba(255,255,255,.7)}
.site-footer__title{font-size:1rem;color:#fff;margin-bottom:1.1rem;font-weight:700}
.site-footer__list li{margin-bottom:.55rem}
.site-footer__list a{color:rgba(255,255,255,.7);transition:color var(--t-fast)}
.site-footer__list a:hover{color:var(--c-accent)}
.site-footer__address{font-style:normal;line-height:1.7;font-size:.92rem;margin-bottom:1rem}
.site-footer__contact{font-size:.92rem;line-height:1.6}
.site-footer__contact li{margin-bottom:.6rem}
.site-footer__contact a{color:#fff;font-weight:600;display:block}
.site-footer__contact a:hover{color:var(--c-accent)}
.site-footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.8rem;padding-top:1.3rem;font-size:.85rem;color:rgba(255,255,255,.55)}
.site-footer__bottom p{color:inherit}

@media (max-width:880px){
  .site-footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .site-footer__grid{grid-template-columns:1fr}
}

/* ---------- Back to top ---------- */
.back-to-top{position:fixed;right:1.4rem;bottom:1.4rem;z-index:40;width:46px;height:46px;border-radius:50%;
  background:var(--c-accent);color:#fff;display:grid;place-items:center;box-shadow:0 6px 20px rgba(255,107,26,.4);
  opacity:0;pointer-events:none;transform:translateY(20px);transition:opacity var(--t-base),transform var(--t-base),background var(--t-fast)}
.back-to-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.back-to-top:hover{background:var(--c-accent-hover)}

/* ---------- Helpers ---------- */
.pt-0{padding-top:0!important}
.pb-0{padding-bottom:0!important}

/* ---------- Reveal animations (scroll) ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(24px);transition:opacity 600ms var(--ease),transform 600ms var(--ease)}
  .reveal.is-visible{opacity:1;transform:none}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:0.01ms!important;animation-duration:0.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important}
}

/* ---------- Ultra-narrow viewports (<420px) — Z Fold cover, etc. ---------- */
@media (max-width:420px){
  :root{--gutter:14px}
  .contact-card{padding:1rem;gap:.7rem}
  .contact-card__icon{width:40px;height:40px}
  .contact-card__icon svg{width:20px;height:20px}
  .contact-card h3{font-size:.95rem}
  .contact-card p,.contact-card a{font-size:.88rem}
  .legal{padding:1.2rem 1.1rem}
  .legal h2{font-size:1.2rem}
  .legal h3{font-size:1.02rem}
  .cta-banner{padding:2rem 1.2rem}
  .cta-banner__btns{flex-direction:column;align-items:stretch}
  .cta-banner__btns .btn{width:100%}
  .baustelle-meta-list{gap:.6rem;padding:1rem}
  .baustelle-detail__body{font-size:1rem}
  .service-card,.why-card{padding:1.4rem 1.2rem}
  .why-card__icon{width:64px;height:64px}
  .process-step{padding:1.8rem 1.2rem 1.5rem}
  .contact-form{padding:1.4rem 1.2rem}
}

/* ---------- Long-string safety net (emails, URLs, slugs) ---------- */
.contact-card a,
.contact-card p,
.site-footer__contact a,
.site-footer__contact li,
.site-footer__address,
.site-footer__about,
.legal a,
.legal p,
.legal li,
.baustelle-meta-list li,
.baustelle-detail__body a,
.baustelle-detail__body p,
.baustelle-detail__body li{
  overflow-wrap:anywhere;
  word-break:break-word;
}

/* Footer columns must shrink properly inside grid */
.site-footer__col{min-width:0}
.site-footer__contact a{display:block}

/* Block runaway elements */
img,svg,video{max-width:100%}
pre,code{max-width:100%;overflow-x:auto}

/* ---------- Print ---------- */
@media print{
  .site-header,.site-footer,.back-to-top,.nav-overlay,.lightbox{display:none!important}
  body{background:#fff;color:#000}
  a{color:#000;text-decoration:underline}
}
