:root{
  --bg: #ffffff;
  --text: #0f172a;
  --muted: #475569;
  --muted2:#64748b;
  --line:#e5e7eb;
  --card:#ffffff;
  --shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  --shadow2: 0 18px 50px rgba(15, 23, 42, 0.10);
  --radius: 18px;
  --max: 1200px;
  --accent: #b91c1c;     /* rot ähnlich Screenshot */
  --accent2:#ef4444;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:var(--font);color:var(--text);background:var(--bg)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{width:min(100%,var(--max));margin:0 auto;padding:0 18px}
.small{font-size:.94rem;color:var(--muted2);line-height:1.6}
.kicker{display:inline-flex;align-items:center;gap:.6rem;color:var(--accent);font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:.78rem}
.kicker .bar{width:34px;height:2px;background:var(--accent);display:inline-block;border-radius:999px;opacity:.85}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:12px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.35);color:#fff;background:rgba(0,0,0,.10);backdrop-filter: blur(8px);transition:.18s transform,.18s background,.18s border-color;font-weight:650}
.btn:hover{transform:translateY(-1px);background:rgba(0,0,0,.18);border-color:rgba(255,255,255,.55)}
.btn.outline{background:transparent;border-color:rgba(15,23,42,.20);color:var(--text);backdrop-filter:none}
.btn.outline:hover{background:rgba(15,23,42,.04);border-color:rgba(15,23,42,.28)}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card .pad{padding:26px}
.card h3{margin:10px 0 10px 0;font-size:1.25rem}
.card p{margin:0;color:var(--muted);line-height:1.75}

.grid{display:grid;gap:26px}
.section{padding:76px 0}
.section h2{margin:10px 0 0 0;font-size: clamp(1.6rem, 2.4vw, 2.2rem)}
.section .lead{margin:12px 0 0 0;color:var(--muted);max-width:72ch;line-height:1.8}

header.site{
  position:sticky;top:0;z-index:50;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(229,231,235,.8);
}
.navbar{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:34px;width:auto}
nav ul{display:flex;gap:20px;list-style:none;margin:0;padding:0;align-items:center}
nav a{color:#111827;padding:10px 12px;border-radius:10px}
nav a:hover{background:rgba(15,23,42,.05)}
nav a.active{background:rgba(185,28,28,.10);color:var(--accent)}

.hamburger{display:none;border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px 12px}
.hamburger span{display:block;width:22px;height:2px;background:#111827;margin:4px 0;border-radius:2px}
.mobile{display:none;padding:10px 0 14px 0}
.mobile a{display:block;padding:12px 14px;border-radius:12px}
.mobile a:hover{background:rgba(15,23,42,.05)}
.mobile a.active{background:rgba(185,28,28,.10);color:var(--accent)}

.hero{
  position:relative;
  min-height: 78vh;
  display:flex;
  align-items:stretch;
  background:
    linear-gradient(90deg, rgba(0,0,0,.58) 0%, rgba(0,0,0,.34) 38%, rgba(0,0,0,.10) 60%, rgba(0,0,0,0) 100%),
    url('assets/img/hero.jpg');
  background-size: cover;
  background-position: center;
}
.hero .inner{display:grid;grid-template-columns: 1.15fr .85fr; gap:28px; align-items:center; padding: 76px 0}
.hero h1{margin:14px 0 0 0;color:#fff;font-size: clamp(2.3rem, 5vw, 4.2rem); line-height:1.03; letter-spacing:-.02em}
.hero p{margin:14px 0 0 0;color:rgba(255,255,255,.86);font-size:1.06rem;line-height:1.75;max-width:60ch}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}

.hero .badge{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:10px 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.10);
  color: rgba(255,255,255,.92);
  font-size:.92rem;
}

.hero .right{
  display:flex;justify-content:flex-end;
}
.cert{
  width:min(380px, 100%);
  background:#fff;border-radius:16px;box-shadow: var(--shadow2);
  overflow:hidden;border:1px solid rgba(229,231,235,.9);
}
.cert .top{padding:12px 14px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.cert .top .dots{display:flex;gap:7px}
.cert .top .dots i{width:10px;height:10px;border-radius:50%;background:rgba(148,163,184,.6)}
.cert img{width:100%;height:auto;display:block}

.features{grid-template-columns: repeat(3, 1fr)}
.feature-icon{
  width:54px;height:54px;border-radius:16px;
  background: rgba(185,28,28,.08);
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(185,28,28,.18);
}
.feature-icon svg{width:28px;height:28px;stroke: var(--accent);}

.pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;border:1px solid var(--line);background:#f8fafc;color:var(--muted);font-weight:650;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase}

.projects{grid-template-columns: repeat(3, 1fr)}
.project .thumb{
  height:210px;border-radius:16px;
  background:
    linear-gradient(135deg, rgba(185,28,28,.10), rgba(15,23,42,.05)),
    url('assets/img/project.jpg');
  background-size: cover;
  background-position:center;
  border:1px solid var(--line);
}
.project .meta{padding:14px 6px 0 6px}
.project .place{color:var(--muted2);font-size:.95rem}
.project h3{margin:8px 0 6px 0;font-size:1.15rem}
.project p{margin:0;color:var(--muted);line-height:1.75}

.split{display:grid;grid-template-columns: 1.05fr .95fr;gap:26px;align-items:start}
.form{display:grid;gap:14px}
.field label{display:block;font-weight:700;margin-bottom:6px}
.field input,.field textarea{
  width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--line);
  background:#fff;outline:none;font-size:1rem
}
.field input:focus,.field textarea:focus{border-color:rgba(185,28,28,.55);box-shadow:0 0 0 4px rgba(185,28,28,.12)}
.field textarea{min-height:140px;resize:vertical}
.form .hint{color:var(--muted2);font-size:.95rem;line-height:1.6}

footer{border-top:1px solid var(--line);padding:50px 0;background:#fff}
.footergrid{display:grid;grid-template-columns: 1.4fr 1fr 1fr;gap:22px}
footer h4{margin:0 0 10px 0}
footer a{color:var(--muted)}
footer a:hover{color:var(--text)}
.copy{margin-top:22px;color:var(--muted2);font-size:.92rem}

.pagehead{padding:44px 0 8px 0;background:#fff}
.breadcrumb{color:var(--muted2);font-size:.95rem}
.breadcrumb a{color:var(--muted);text-decoration:underline;text-decoration-color:rgba(185,28,28,.35)}
.breadcrumb a:hover{text-decoration-color:rgba(185,28,28,.65)}
.pagehead h1{margin:10px 0 0 0;font-size: clamp(2.0rem, 3.5vw, 2.8rem)}
.hr{height:1px;background:var(--line);margin:28px 0}

.table{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:16px;overflow:hidden}
.table th,.table td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.table th{background:#f8fafc}
.table tr:last-child td{border-bottom:none}

@media (max-width: 950px){
  .hero .inner{grid-template-columns: 1fr; padding: 54px 0}
  .hero{min-height: auto}
  .hero .right{justify-content:flex-start}
  .features,.projects{grid-template-columns: 1fr}
  .split{grid-template-columns: 1fr}
  nav ul{display:none}
  .hamburger{display:inline-block}
  .mobile{display:none}
  .mobile.open{display:block}
}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* Home page (FarbenKobold) */
.home-page{
  background:#f2f2f2;
  color:#1f2430;
}

.home-page .container{
  width:min(100%, 1500px);
  padding:0 28px;
}

.home-page header.site{
  background:rgba(245,245,245,.96);
  backdrop-filter:none;
  border-bottom:1px solid #e5e5e5;
}

.home-page .navbar{
  padding:14px 0;
}

.home-page .brand img{
  height:58px;
}

.home-page nav ul{
  gap:10px;
}

.home-page nav a{
  font-size:1.02rem;
  padding:10px 14px;
  border-radius:8px;
}

.home-page nav a:hover{
  background:rgba(15,23,42,.04);
}

.home-page .mobile{
  background:#f2f2f2;
}

.home-floating-cert{
  position:fixed;
  right:clamp(10px, 2vw, 34px);
  top:58%;
  transform:translateY(-50%);
  width:clamp(150px, 11vw, 205px);
  z-index:24;
  pointer-events:none;
}

.home-floating-cert img{
  width:100%;
  height:auto;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 20px 35px rgba(0,0,0,.14);
  background:#fff;
}

.home-hero{
  position:relative;
  min-height:calc(100vh - 88px);
  background-image:
    linear-gradient(90deg, rgba(0,0,0,.38) 0%, rgba(0,0,0,.30) 28%, rgba(0,0,0,.12) 52%, rgba(0,0,0,0) 78%),
    url('../img/homebackgorund.png');
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:center;
}

.home-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,0) 78%, rgba(242,242,242,.2) 100%);
  pointer-events:none;
}

.home-hero .container{
  position:relative;
  z-index:1;
}

.home-hero__content{
  width:min(640px, 100%);
  padding:clamp(46px, 7vh, 88px) 0;
}

.home-hero__line{
  display:block;
  width:56px;
  height:2px;
  background:#de3b38;
  margin-bottom:22px;
}

.home-hero__content h1{
  margin:0;
  color:#fff;
  font-size:clamp(2.2rem, 4.4vw, 4.4rem);
  line-height:.98;
  letter-spacing:-.045em;
  font-weight:600;
}

.home-hero__content p{
  margin:26px 0 0;
  color:rgba(255,255,255,.92);
  font-size:clamp(1rem, 1.2vw, 1.08rem);
  line-height:1.55;
  max-width:560px;
}

.home-hero__button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:162px;
  padding:14px 22px;
  margin-top:28px;
  border:1.5px solid rgba(255,255,255,.9);
  color:#fff;
  background:rgba(255,255,255,.03);
  border-radius:8px;
  font-size:1rem;
  transition:background .2s ease, color .2s ease;
}

.home-hero__button:hover{
  background:rgba(255,255,255,.14);
}

.home-intro{
  padding:72px 0 54px;
  background:#f2f2f2;
}

.home-intro__grid{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(0, 1fr);
  gap:clamp(34px, 5vw, 78px);
  align-items:center;
}

.home-intro__image{
  width:100%;
}

.home-intro__image img{
  width:100%;
  max-width:740px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.06);
}

.home-intro__content{
  max-width:700px;
}

.home-intro__content h2{
  margin:0 0 26px;
  color:#1c2230;
  font-size:clamp(2rem, 3.3vw, 4rem);
  line-height:1.15;
  letter-spacing:-.03em;
  font-weight:400;
}

.home-intro__content h2 strong{
  font-weight:700;
}

.home-intro__content p{
  margin:0 0 28px;
  color:#707684;
  font-size:1.05rem;
  line-height:1.75;
}

.home-intro__label{
  margin-bottom:12px;
  color:#757b88;
}

.home-intro__list{
  list-style:none;
  margin:0 0 34px;
  padding:0;
}

.home-intro__list li{
  position:relative;
  padding-left:18px;
  margin:6px 0;
  color:#6d7380;
  font-size:1.02rem;
  font-weight:700;
}

.home-intro__list li::before{
  content:"-";
  position:absolute;
  left:0;
  top:0;
  color:#7b818d;
}

.home-services{
  background:#f2f2f2;
  padding:54px 0 76px;
}

.home-services__grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(280px, 360px));
  justify-content:center;
  gap:24px;
  max-width:1180px;
  margin:0 auto;
}

.home-service-card{
  position:relative;
  min-height:410px;
  padding:26px 26px 24px;
  border:1px solid #d6d9df;
  border-radius:4px;
  background:rgba(255,255,255,.18);
}

.home-service-card__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  min-height:84px;
}

.home-service-card__head img{
  width:82px;
  height:82px;
  object-fit:contain;
  filter:brightness(0) opacity(.85);
}

.home-service-card__pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:9px 16px;
  background:#e6e7ea;
  border-radius:6px;
  color:#3a3f48;
  font-size:.78rem;
  letter-spacing:.11em;
  text-transform:uppercase;
}

.home-service-card h3{
  margin:10px 0 18px;
  font-size:clamp(1.15rem, 1.45vw, 1.55rem);
  line-height:1.15;
  font-weight:500;
  color:#232938;
  letter-spacing:-.02em;
}

.home-service-card p{
  margin:0;
  color:#6f7582;
  font-size:.92rem;
  line-height:1.5;
}

.home-service-card__highlight{
  margin-bottom:24px !important;
  font-weight:700;
  color:#6a707d !important;
}

.home-service-card sup{
  font-size:.65em;
  top:-.35em;
  position:relative;
}

.home-projects{
  background:#f2f2f2;
  padding:4px 0 84px;
}

.home-projects__lead{
  margin:0 auto 22px;
  max-width:720px;
  text-align:center;
  color:#7a7a7a;
  font-size:clamp(1rem, 1.5vw, 1.15rem);
  line-height:1.45;
}

.projects-gallery-page{
  background:#f2f2f2;
  padding:54px 0 56px;
}

.projects-gallery-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(260px, 1fr));
  gap:48px 46px;
  max-width:1360px;
  margin:0 auto;
}

.projects-gallery-card{
  min-width:0;
}

.projects-gallery-card > a{
  display:block;
  color:inherit;
  cursor:zoom-in;
}

.projects-gallery-card__image{
  overflow:hidden;
  background:#e9e9e9;
}

.projects-gallery-card__image picture,
.projects-gallery-card__image img{
  display:block;
  width:100%;
}

.projects-gallery-card__image img{
  aspect-ratio: 16 / 7;
  object-fit:cover;
}

.projects-gallery-card h2{
  margin:14px 0 4px;
  font-size:clamp(1.15rem, 1.45vw, 1.6rem);
  line-height:1.2;
  font-weight:500;
  letter-spacing:-.02em;
  color:#171b24;
}

.projects-gallery-card p{
  margin:0;
  color:#7b7b7b;
  font-size:clamp(.9rem, .95vw, 1rem);
  line-height:1.35;
}

.services-detail-main{
  background:#f2f2f2;
}

.services-detail-section{
  position:relative;
  background:#f2f2f2;
  padding:40px 0 70px;
  overflow:hidden;
}

.services-detail-section + .services-detail-section{
  padding-top:62px;
}

.services-detail-section::before{
  content:"";
  position:absolute;
  left:4%;
  right:4%;
  top:58px;
  bottom:24px;
  pointer-events:none;
  opacity:.28;
  background:
    repeating-linear-gradient(90deg, rgba(150,154,163,.16) 0 1px, transparent 1px 68px),
    repeating-linear-gradient(0deg, rgba(150,154,163,.10) 0 1px, transparent 1px 62px),
    linear-gradient(16deg, transparent 43%, rgba(150,154,163,.16) 43.2%, transparent 43.6%),
    linear-gradient(-17deg, transparent 58%, rgba(150,154,163,.13) 58.2%, transparent 58.6%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.9) 18%, rgba(0,0,0,.92) 82%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, rgba(0,0,0,.9) 18%, rgba(0,0,0,.92) 82%, transparent 100%);
}

.services-detail-section::after{
  content:"";
  position:absolute;
  left:22%;
  right:18%;
  bottom:10px;
  height:34%;
  pointer-events:none;
  opacity:.14;
  background:
    linear-gradient(0deg, rgba(150,154,163,.18), rgba(150,154,163,.18)) left 8% bottom 12% / 1px 58% no-repeat,
    linear-gradient(0deg, rgba(150,154,163,.18), rgba(150,154,163,.18)) left 32% bottom 0 / 1px 80% no-repeat,
    linear-gradient(0deg, rgba(150,154,163,.18), rgba(150,154,163,.18)) left 63% bottom 8% / 1px 68% no-repeat,
    linear-gradient(0deg, rgba(150,154,163,.18), rgba(150,154,163,.18)) left 90% bottom 4% / 1px 74% no-repeat,
    linear-gradient(90deg, rgba(150,154,163,.18), rgba(150,154,163,.18)) left 0 bottom 18% / 100% 1px no-repeat,
    linear-gradient(90deg, rgba(150,154,163,.16), rgba(150,154,163,.16)) left 0 bottom 46% / 84% 1px no-repeat;
}

.services-detail-section .container{
  position:relative;
  z-index:1;
}

.services-detail-row{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 620px);
  gap:clamp(32px, 6vw, 86px);
  align-items:start;
}

.services-detail-copy{
  max-width:720px;
  padding-top:8px;
}

.services-detail-copy h1,
.services-detail-copy h2{
  margin:0 0 26px;
  color:#1c222f;
  font-size:clamp(2.05rem, 3.4vw, 3.25rem);
  line-height:1.05;
  letter-spacing:-.03em;
  font-weight:400;
}

.services-detail-copy__grid{
  display:grid;
  grid-template-columns:110px minmax(0, 1fr);
  gap:22px 26px;
  align-items:start;
}

.services-detail-copy__line{
  display:block;
  width:102px;
  height:2px;
  margin-top:22px;
  background:#de3b38;
}

.services-detail-copy__text{
  max-width:560px;
}

.services-detail-copy__text p{
  margin:0;
  color:#727886;
  font-size:clamp(1rem, 1.1vw, 1.1rem);
  line-height:1.62;
}

.services-detail-copy__text p + p{
  margin-top:24px;
}

.services-detail-image{
  justify-self:end;
  width:100%;
  border-radius:8px;
  overflow:hidden;
  background:#ebebeb;
  box-shadow:0 12px 28px rgba(0,0,0,.06);
}

.services-detail-image img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.services-detail-image--landscape{
  max-width:640px;
  aspect-ratio: 16 / 10;
}

.services-detail-image--portrait{
  max-width:560px;
  aspect-ratio: 4 / 5;
}

.services-detail-section--trockenbau::before{
  left:2%;
  right:8%;
}

.services-detail-section--maler::before{
  left:6%;
  right:12%;
  opacity:.22;
}

.services-detail-section--geruest::before{
  left:5%;
  right:10%;
  opacity:.20;
}

.contact-showcase{
  background:#f2f2f2;
}

.contact-showcase__section{
  background:#f2f2f2;
  padding:66px 0 110px;
}

.contact-showcase__layout{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(340px, 520px);
  gap:clamp(28px, 4vw, 76px);
  align-items:start;
}

.contact-showcase__left{
  max-width:760px;
}

.contact-showcase__left h1{
  margin:0;
  color:#1c222f;
  font-size:clamp(2rem, 3.1vw, 3.05rem);
  line-height:1.08;
  letter-spacing:-.03em;
  font-weight:400;
}

.contact-showcase__divider{
  margin:26px 0 42px;
  height:1px;
  background:#e6e6e6;
}

.contact-showcase__info-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:26px 34px;
  margin-bottom:34px;
}

.contact-showcase__info-block h2{
  margin:0 0 22px;
  color:#de3b38;
  font-size:1.02rem;
  line-height:1.2;
  font-weight:500;
}

.contact-showcase__info-block p{
  margin:0;
  color:#6f7582;
  font-size:1.08rem;
  line-height:1.7;
}

.contact-showcase__info-block a{
  color:inherit;
}

.contact-showcase__info-block a:hover{
  color:#222938;
}

.contact-showcase__map{
  width:100%;
  max-width:660px;
  border:1px solid #e3e3e3;
  overflow:hidden;
  background:#ececec;
}

.contact-showcase__map iframe{
  display:block;
  width:100%;
  height:170px;
  border:0;
}

.contact-showcase__card{
  border:1px solid #dedede;
  background:#f3f3f3;
  min-height:518px;
  padding:46px 34px 32px;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}

.contact-showcase__card h2{
  margin:0;
  color:#1c222f;
  font-size:clamp(2rem, 2.3vw, 2.55rem);
  line-height:1.1;
  letter-spacing:-.03em;
  font-weight:400;
}

.contact-showcase__card > p{
  margin:26px 0 40px;
  color:#7a808d;
  font-size:1.05rem;
  line-height:1.45;
}

.contact-showcase__actions{
  width:100%;
  display:flex;
  flex-direction:column;
  gap:24px;
  margin-top:auto;
  margin-bottom:6px;
}

.contact-action{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:18px 12px;
  color:#111;
  border-radius:8px;
  transition:background .16s ease, transform .16s ease;
}

.contact-action:hover{
  background:rgba(0,0,0,.03);
  transform:translateY(-1px);
}

.contact-action__icon{
  width:74px;
  height:74px;
  display:grid;
  place-items:center;
  color:#0f1014;
}

.contact-action__icon svg{
  width:100%;
  height:100%;
}

.contact-action__label{
  font-size:1.05rem;
  font-weight:600;
  color:#181b22;
}

.legal-page{
  background:#f2f2f2;
}

.legal-page__section{
  background:#f2f2f2;
  padding:24px 0 68px;
}

.legal-page__article{
  max-width:1120px;
  margin:0 auto;
}

.legal-page__article h1{
  margin:0 0 34px;
  color:#1b212d;
  font-size:clamp(2.3rem, 3.8vw, 4.2rem);
  line-height:1.02;
  letter-spacing:-.035em;
  font-weight:400;
}

.legal-page__article p{
  margin:0 0 24px;
  color:#747a88;
  font-size:clamp(1.02rem, 1.06vw, 1.18rem);
  line-height:1.55;
  max-width:1100px;
}

.legal-page__article p strong{
  color:#686e7c;
  font-weight:700;
}

.legal-page__article a{
  color:#9ca0b4;
}

.legal-page__article a:hover{
  color:#7f8396;
}

body.projects-lightbox-open{
  overflow:hidden;
}

.projects-lightbox{
  position:fixed;
  inset:0;
  z-index:120;
  display:grid;
  place-items:center;
  padding:18px;
}

.projects-lightbox[hidden]{
  display:none !important;
}

.projects-lightbox__backdrop{
  position:absolute;
  inset:0;
  background:rgba(10,12,18,.78);
  backdrop-filter: blur(2px);
}

.projects-lightbox__dialog{
  position:relative;
  z-index:1;
  width:min(1200px, 100%);
  max-height:100%;
}

.projects-lightbox__figure{
  margin:0;
  background:#fff;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 24px 50px rgba(0,0,0,.3);
}

.projects-lightbox__figure img{
  display:block;
  width:100%;
  max-height:min(78vh, 900px);
  object-fit:contain;
  background:#f4f4f4;
}

.projects-lightbox__caption{
  display:flex;
  flex-direction:column;
  gap:3px;
  padding:14px 16px 16px;
}

.projects-lightbox__caption strong{
  color:#161b24;
  font-size:1.05rem;
  font-weight:600;
}

.projects-lightbox__caption span{
  color:#717782;
  font-size:.92rem;
}

.projects-lightbox__close{
  position:absolute;
  top:10px;
  right:10px;
  z-index:2;
  width:40px;
  height:40px;
  border:none;
  border-radius:999px;
  background:rgba(15,23,42,.76);
  color:#fff;
  font-size:1.8rem;
  line-height:1;
  cursor:pointer;
  display:grid;
  place-items:center;
}

.projects-lightbox__close:hover{
  background:rgba(15,23,42,.9);
}

.projects-lightbox__close:focus-visible{
  outline:2px solid #fff;
  outline-offset:2px;
}

.home-slider{
  display:grid;
  grid-template-columns:56px minmax(0, 620px) 56px;
  justify-content:center;
  align-items:center;
  gap:10px;
  max-width:760px;
  margin:0 auto;
}

.home-slider__arrow{
  position:relative;
  z-index:3;
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border:none;
  border-radius:999px;
  background:transparent;
  color:#1c7bf4;
  cursor:pointer;
  font-size:2.4rem;
  line-height:1;
  padding:0;
  transition:transform .15s ease, color .15s ease, background .15s ease;
}

.home-slider__arrow:hover{
  transform:scale(1.05);
  background:rgba(28,123,244,.06);
}

.home-slider__arrow:focus-visible{
  outline:2px solid #1c7bf4;
  outline-offset:3px;
}

.home-slider__viewport{
  position:relative;
  overflow:hidden;
  border-radius:2px;
  min-width:0;
}

.home-slider__track{
  display:flex;
  width:100%;
  transform:translateX(0);
  transition:transform .45s ease;
  will-change:transform;
}

.home-slider__slide{
  flex:0 0 100%;
  margin:0;
}

.home-slider__slide img{
  width:100%;
  aspect-ratio: 16 / 10;
  object-fit:cover;
  display:block;
}

.home-slider__sidepanel{
  position:absolute;
  top:26px;
  right:-64px;
  width:52px;
  height:calc(100% - 52px);
  background:linear-gradient(90deg, #9b9b9b 0%, #c4c4c4 100%);
  transform:skewY(-5deg);
  transform-origin:center;
  box-shadow:0 16px 34px rgba(0,0,0,.10);
  z-index:1;
}

.home-slider__footer{
  grid-column:1 / -1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  margin-top:18px;
}

.home-slider__progress{
  width:min(620px, 86%);
  height:6px;
  border-radius:999px;
  background:#d3d3d3;
  overflow:hidden;
}

.home-slider__progress span{
  display:block;
  width:33.333%;
  height:100%;
  background:#7f7f7f;
  border-radius:999px;
  transition:width .35s ease;
}

.home-slider__dots{
  display:flex;
  align-items:center;
  gap:8px;
}

.home-slider__dots button{
  width:10px;
  height:10px;
  border-radius:999px;
  border:none;
  background:#c6c6c6;
  padding:0;
  cursor:pointer;
  transition:transform .15s ease, background .15s ease;
}

.home-slider__dots button:hover{
  transform:scale(1.12);
}

.home-slider__dots button.is-active{
  background:#1c7bf4;
}

.home-slider__dots button:focus-visible{
  outline:2px solid #1c7bf4;
  outline-offset:2px;
}

.home-footer{
  border-top:none;
  background:linear-gradient(180deg, #383838 0%, #2f2f2f 100%);
  color:#fff;
  padding:72px 0 0;
}

.home-footer__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(24px, 4vw, 76px);
  padding-bottom:72px;
  align-items:start;
}

.home-footer__map{
  width:100%;
  height:300px;
  border-radius:8px;
  overflow:hidden;
}

.home-footer__map iframe{
  width:100%;
  height:100%;
  border:none;
}

.home-footer__info{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  height:100%;
}

.home-footer__content h2{
  margin:0 0 20px;
  font-size:clamp(1.85rem, 2vw, 3rem);
  line-height:1.02;
  font-weight:500;
  letter-spacing:-.02em;
  color:#fafafa;
}

.home-footer__content p{
  margin:0 0 28px;
  color:rgba(255,255,255,.62);
  font-size:clamp(1rem, 1.1vw, 1.15rem);
  line-height:1.55;
}

.home-footer__content a{
  color:inherit;
}

.home-footer__content a:hover{
  color:#fff;
}

.home-footer__logo{
  margin-top:40px;
}

.home-footer__logo img{
  max-width:200px;
  height:auto;
}

.home-footer__bottom{
  border-top:1px solid rgba(255,255,255,.10);
  padding:24px 0 30px;
}

.home-footer__copy{
  margin:0;
  color:rgba(255,255,255,.62);
  font-size:clamp(.95rem, 1vw, 1.1rem);
}

@media (max-width: 1400px){
  .home-slider{
    grid-template-columns:54px minmax(0, 560px) 54px;
    max-width:690px;
  }

  .home-slider__sidepanel{
    right:-54px;
    width:44px;
  }
}

@media (min-width: 1081px){
  .home-intro .container,
  .home-services .container,
  .home-projects .container,
  .contact-showcase__section .container,
  .services-detail-section .container,
  .home-footer > .container,
  .home-footer__bottom .container{
    padding-right:clamp(190px, 14vw, 250px);
  }

  .impressum-page .home-footer > .container,
  .impressum-page .home-footer__bottom .container{
    padding-right:28px;
  }
}

@media (max-width: 1200px){
  .home-floating-cert{
    width:150px;
    right:10px;
  }

  .home-service-card{
    min-height:390px;
    padding:22px;
  }

  .home-service-card__head img{
    width:72px;
    height:72px;
  }

  .home-footer__grid{
    grid-template-columns:1fr;
    gap:26px;
  }

  .home-footer__map{
    height:250px;
  }

  .home-footer__content p{
    margin-bottom:18px;
  }

  .projects-gallery-grid{
    gap:38px 28px;
  }
}

@media (max-width: 1080px){
  .home-floating-cert{
    display:none;
  }

  .home-intro__grid{
    grid-template-columns:1fr;
  }

  .home-intro{
    padding-top:56px;
  }

  .home-intro__image img{
    max-width:none;
  }

  .home-services__grid{
    grid-template-columns:1fr;
    max-width:unset;
  }

  .projects-gallery-page{
    padding-top:40px;
  }

  .projects-gallery-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:32px 20px;
  }

  .services-detail-section{
    padding:30px 0 44px;
  }

  .services-detail-section + .services-detail-section{
    padding-top:36px;
  }

  .services-detail-section::before,
  .services-detail-section::after{
    display:none;
  }

  .services-detail-row{
    grid-template-columns:1fr;
    gap:18px;
  }

  .services-detail-copy{
    max-width:none;
    padding-top:0;
  }

  .services-detail-copy__text{
    max-width:none;
  }

  .services-detail-image{
    justify-self:start;
    max-width:760px;
    width:100%;
  }

  .services-detail-image--landscape,
  .services-detail-image--portrait{
    aspect-ratio:auto;
    max-width:760px;
  }

  .contact-showcase__section{
    padding:34px 0 54px;
  }

  .contact-showcase__layout{
    grid-template-columns:1fr;
    gap:24px;
  }

  .contact-showcase__left{
    max-width:none;
  }

  .contact-showcase__card{
    min-height:auto;
    width:100%;
    max-width:760px;
    justify-self:start;
    align-items:center;
    padding:32px 22px 24px;
  }

  .contact-showcase__card > p{
    margin:16px 0 24px;
  }

  .contact-showcase__actions{
    margin-top:0;
    flex-direction:row;
    justify-content:center;
    gap:14px;
  }

  .contact-action{
    flex:1;
    min-width:0;
    max-width:240px;
    border:1px solid #e2e2e2;
    background:#f7f7f7;
  }

  .contact-showcase__map{
    max-width:760px;
  }

  .legal-page__section{
    padding:20px 0 44px;
  }

  .legal-page__article{
    max-width:none;
  }

  .home-service-card{
    min-height:auto;
  }

  .home-slider{
    grid-template-columns:42px minmax(0, 1fr) 42px;
    gap:8px;
    max-width:100%;
  }

  .home-slider__viewport{
    min-width:0;
  }

  .home-slider__sidepanel{
    display:none;
  }
}

@media (max-width: 950px){
  .home-page .brand img{
    height:46px;
  }

  .home-page .navbar{
    padding:12px 0;
  }

  .home-page .mobile{
    border-top:1px solid #e5e5e5;
  }

  .home-hero{
    min-height:auto;
    background-position:center;
  }

  .home-hero__content{
    padding:44px 0 54px;
  }

  .home-hero__content h1{
    line-height:1.02;
  }

  .home-hero__content p{
    line-height:1.6;
  }

  .home-intro__content h2{
    margin-bottom:18px;
  }
}

@media (max-width: 700px){
  .home-page .container{
    padding:0 16px;
  }

  .home-hero{
    background-image:
      linear-gradient(180deg, rgba(0,0,0,.48) 0%, rgba(0,0,0,.24) 52%, rgba(0,0,0,.20) 100%),
      url('../img/homebackgorund.png');
    background-position:56% center;
  }

  .home-hero__line{
    margin-bottom:16px;
  }

  .home-hero__button{
    width:100%;
    max-width:210px;
  }

  .home-intro{
    padding:42px 0 34px;
  }

  .home-services{
    padding:34px 0 54px;
  }

  .projects-gallery-page{
    padding:26px 0 34px;
  }

  .projects-gallery-grid{
    grid-template-columns:1fr;
    gap:24px;
  }

  .projects-gallery-card h2{
    margin-top:10px;
  }

  .services-detail-copy h1,
  .services-detail-copy h2{
    margin-bottom:16px;
    font-size:clamp(1.85rem, 7vw, 2.4rem);
  }

  .services-detail-copy__grid{
    grid-template-columns:1fr;
    gap:12px;
  }

  .services-detail-copy__line{
    width:84px;
    margin-top:0;
  }

  .services-detail-copy__text p{
    font-size:1rem;
    line-height:1.55;
  }

  .services-detail-copy__text p + p{
    margin-top:18px;
  }

  .services-detail-section{
    padding:22px 0 26px;
  }

  .services-detail-section + .services-detail-section{
    padding-top:18px;
  }

  .contact-showcase__left h1{
    font-size:clamp(1.7rem, 6vw, 2.3rem);
  }

  .legal-page__article h1{
    font-size:clamp(2rem, 11vw, 3rem);
    margin-bottom:20px;
  }

  .legal-page__article p{
    font-size:1rem;
    line-height:1.5;
    margin-bottom:18px;
  }

  .contact-showcase__divider{
    margin:18px 0 22px;
  }

  .contact-showcase__info-grid{
    grid-template-columns:1fr;
    gap:18px;
    margin-bottom:20px;
  }

  .contact-showcase__info-block h2{
    margin-bottom:8px;
    font-size:.98rem;
  }

  .contact-showcase__info-block p{
    font-size:1rem;
    line-height:1.55;
  }

  .contact-showcase__map iframe{
    height:210px;
  }

  .contact-showcase__card{
    padding:24px 18px 16px;
  }

  .contact-showcase__card h2{
    font-size:clamp(1.6rem, 8vw, 2rem);
  }

  .contact-showcase__card > p{
    font-size:.95rem;
    margin:12px 0 16px;
  }

  .contact-showcase__actions{
    flex-direction:column;
    gap:10px;
    width:100%;
  }

  .contact-action{
    max-width:none;
    flex-direction:row;
    justify-content:flex-start;
    text-align:left;
    gap:12px;
    padding:12px 14px;
  }

  .contact-action__icon{
    width:38px;
    height:38px;
  }

  .contact-action__label{
    font-size:1rem;
  }

  .home-service-card{
    padding:22px;
  }

  .home-service-card__head{
    min-height:auto;
  }

  .home-service-card__head img{
    width:74px;
    height:74px;
  }

  .home-service-card__pill{
    padding:7px 10px;
    font-size:.68rem;
  }

  .home-slider{
    grid-template-columns:42px minmax(0, 1fr) 42px;
    gap:4px;
  }

  .home-slider__arrow{
    width:38px;
    height:38px;
    font-size:2rem;
  }

  .home-slider__footer{
    margin-top:12px;
  }

  .home-slider__progress{
    width:94%;
  }

  .home-footer{
    padding-top:44px;
  }

  .home-footer__grid{
    padding-bottom:38px;
  }
}

@media (prefers-reduced-motion: reduce){
  .home-slider__track,
  .home-slider__progress span,
  .home-slider__dots button,
  .home-slider__arrow,
  .home-hero__button{
    transition:none !important;
  }
}
