:root {
  --navy: #2d3470;
  --navy-dark: #1e2350;
  --gold: #c8a84b;
  --gray: #777;
  --light: #f5f6f8;
  --white: #fff;
  --text: #2d2d2d;
  --shadow: 0 18px 50px rgba(20, 24, 58, .14);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Arial, Helvetica, sans-serif; color: var(--text); background: var(--white); line-height: 1.6; }
a { color: inherit; }
.skip-link { position: absolute; left: -999px; top: 8px; background: var(--navy-dark); color: var(--white); padding: 10px 14px; z-index: 99; }
.skip-link:focus { left: 8px; }
.site-header { position: sticky; top: 0; z-index: 20; background: var(--white); box-shadow: 0 2px 20px rgba(0,0,0,.1); }
.topbar { display: flex; justify-content: space-between; align-items: center; gap: 22px; min-height: 42px; padding: 6px clamp(18px, 5vw, 60px); background: var(--navy-dark); color: #d9dced; font-size: 13px; }
.topbar-contact { display: flex; align-items: center; gap: 24px; min-width: 0; }
.topbar-contact a { white-space: nowrap; }
.topbar a, .brand, .nav-menu a, .btn, .breadcrumb a, .site-footer a { text-decoration: none; }
.navbar { min-height: 78px; padding: 0 clamp(18px, 5vw, 60px); display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: center; gap: 14px; }
.brand-logo { display: block; width: auto; height: 58px; background: transparent; }
.brand-text { display: grid; gap: 2px; }
.brand strong { display: block; color: var(--navy-dark); font-size: 18px; }
.brand small { display: block; color: var(--gray); font-size: 12px; }
.nav-menu { display: flex; align-items: center; gap: 4px; list-style: none; margin: 0; padding: 0; }
.nav-menu a { display: block; padding: 10px 14px; color: var(--navy); font-weight: 700; text-transform: uppercase; font-size: 14px; letter-spacing: .04em; border-bottom: 3px solid transparent; }
.nav-menu a:hover, .nav-menu a.active { border-bottom-color: var(--gold); }
.nav-menu .nav-cta { background: var(--navy); color: var(--white); border-radius: 2px; margin-left: 8px; }
.nav-toggle { display: none; border: 0; background: transparent; padding: 8px; }
.nav-toggle span { display: block; width: 26px; height: 2px; background: var(--navy); margin: 5px 0; }
.page { display: none; }
.page.active { display: block; }
.hero { position: relative; overflow: hidden; min-height: clamp(500px, 66vh, 660px); display: grid; grid-template-columns: minmax(0, 900px); align-items: center; justify-content: start; gap: clamp(34px, 6vw, 92px); padding: clamp(64px, 8vw, 104px) max(24px, calc((100vw - 1180px) / 2)) clamp(86px, 9vw, 120px); background: radial-gradient(circle at 74% 18%, rgba(200,168,75,.3), transparent 24%), radial-gradient(circle at 14% 88%, rgba(255,255,255,.1), transparent 26%), linear-gradient(100deg, rgba(18,22,55,.98) 0%, rgba(30,35,80,.9) 36%, rgba(45,52,112,.54) 60%, rgba(30,35,80,.08) 100%), url("https://images.unsplash.com/photo-1769284022654-66c6b07dae78?auto=format&fit=crop&w=1800&q=84") center 45% / cover no-repeat; color: var(--white); }
.hero::before { content: ""; position: absolute; inset: 24px; border: 1px solid rgba(255,255,255,.1); border-radius: 28px; background-image: linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px); background-size: 78px 78px; mask-image: linear-gradient(90deg, rgba(0,0,0,.8), transparent 72%); pointer-events: none; }
.hero::after { content: "BLS"; position: absolute; right: -34px; bottom: -72px; color: rgba(255,255,255,.035); font-size: clamp(150px, 22vw, 330px); font-weight: 900; line-height: .8; pointer-events: none; }
.hero-content { position: relative; z-index: 1; max-width: 900px; }
.hero-wave { position: absolute; left: -5%; right: -5%; bottom: -1px; height: clamp(56px, 7vw, 92px); background: var(--white); clip-path: ellipse(62% 72% at 50% 100%); z-index: 1; pointer-events: none; }
.eyebrow { margin: 0 0 14px; color: var(--gold); font-weight: 800; text-transform: uppercase; letter-spacing: .18em; font-size: 12px; }
h1, h2, h3 { margin: 0 0 16px; line-height: 1.08; color: var(--navy-dark); }
.hero h1 { color: var(--white); font-size: clamp(52px, 7vw, 96px); text-transform: uppercase; letter-spacing: -.045em; text-wrap: balance; }
.hero h1 span { color: var(--gold); }
.hero p { max-width: 620px; color: rgba(255,255,255,.82); font-size: clamp(17px, 1.45vw, 20px); }
.actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }
.hero-highlights { position: relative; z-index: 2; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; max-width: 1120px; margin: -36px auto 0; padding: 0 clamp(18px, 5vw, 60px); }
.hero-highlights span { display: grid; gap: 7px; padding: 22px 24px; border: 1px solid rgba(45,52,112,.1); border-left: 5px solid var(--gold); border-radius: 18px; background: linear-gradient(135deg, #fff 0%, #f8f9fd 100%); color: var(--navy-dark); box-shadow: 0 18px 48px rgba(30,35,80,.12); }
.hero-highlights strong { color: var(--gold); font-size: 12px; letter-spacing: .16em; }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 13px 25px; border: 0; border-radius: 999px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; cursor: pointer; transition: transform .2s, box-shadow .2s, background .2s; }
.btn:hover { transform: translateY(-2px); }
.btn.primary { background: linear-gradient(135deg, var(--gold), #d9bd69); color: var(--navy-dark); box-shadow: 0 14px 30px rgba(200,168,75,.26); }
.btn.ghost { color: var(--white); outline: 1px solid rgba(255,255,255,.46); background: rgba(255,255,255,.06); }
.btn.dark { background: var(--navy-dark); color: var(--white); }
.btn.full { width: 100%; }
.section { max-width: 1200px; margin: 0 auto; padding: clamp(56px, 8vw, 92px) clamp(18px, 5vw, 60px); }
.section-head { max-width: 720px; margin-bottom: 38px; }
.home-services { position: relative; max-width: none; margin: 0; padding-left: max(18px, calc((100vw - 1200px) / 2)); padding-right: max(18px, calc((100vw - 1200px) / 2)); background: linear-gradient(180deg, #fff 0%, #f5f6fb 100%); }
.home-services::before { content: ""; position: absolute; inset: 0 0 auto; height: 1px; background: linear-gradient(90deg, transparent, rgba(200,168,75,.55), transparent); }
.home-services .section-head { position: relative; max-width: 840px; padding-left: 22px; border-left: 5px solid var(--gold); }
.section-head h2, .page-hero h1, .legal h1, .detail h1 { font-size: clamp(38px, 5vw, 60px); text-transform: uppercase; }
.section-head p, .page-hero p { color: var(--gray); font-size: 17px; }
.service-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.service-grid.compact { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.service-card { border: 1px solid #e4e6ef; padding: 28px; background: var(--white); transition: transform .2s, box-shadow .2s; cursor: pointer; }
.service-card:hover, .service-card:focus { transform: translateY(-4px); box-shadow: var(--shadow); outline: none; }
.service-card span { color: var(--gold); font-weight: 900; letter-spacing: .14em; }
.service-card h2, .service-card h3 { margin-top: 10px; font-size: 24px; }
.service-card p { color: var(--gray); }
.service-card a { color: var(--navy); font-weight: 800; }
.services-list { align-items: stretch; }
.services-list .service-card { position: relative; overflow: hidden; display: grid; align-content: start; gap: 12px; min-height: 250px; padding: 30px; border: 1px solid rgba(45,52,112,.1); border-left: 5px solid var(--gold); border-radius: 22px; background: linear-gradient(135deg, #fff 0%, #f8f9fd 62%, #eef1fa 100%); box-shadow: 0 18px 48px rgba(30,35,80,.1); }
.services-list .service-card::after { content: ""; position: absolute; right: -54px; bottom: -16px; width: 250px; height: 82px; background: url("../img/bls-logo.svg") center top / 250px auto no-repeat; filter: grayscale(1) opacity(.55); opacity: .08; pointer-events: none; }
.services-list .service-card > * { position: relative; z-index: 1; }
.services-list .service-card span { justify-self: start; padding: 7px 12px; border-radius: 999px; background: rgba(200,168,75,.13); color: var(--gold); font-size: 12px; line-height: 1; }
.services-list .service-card h2, .services-list .service-card h3 { margin: 2px 0 0; color: var(--navy-dark); font-size: 26px; }
.services-list .service-card p { margin: 0; color: #4f566d; }
.services-list .service-card a { align-self: end; justify-self: start; margin-top: 6px; padding-bottom: 2px; color: var(--navy); text-decoration-color: rgba(200,168,75,.55); text-underline-offset: 4px; }
.services-list .service-card:hover, .services-list .service-card:focus { transform: translateY(-5px); box-shadow: 0 26px 70px rgba(30,35,80,.16); }
.home-references { max-width: none; padding-left: max(18px, calc((100vw - 1200px) / 2)); padding-right: max(18px, calc((100vw - 1200px) / 2)); background: linear-gradient(180deg, #f5f6fb 0%, #fff 100%); }
.home-reference-head { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 28px; }
.home-reference-head > div:first-child { max-width: 760px; padding-left: 22px; border-left: 5px solid var(--gold); }
.home-reference-head h2 { font-size: clamp(34px, 4.4vw, 54px); text-transform: uppercase; }
.home-reference-head p:last-child { color: var(--gray); font-size: 17px; }
.slider-controls { position: relative; z-index: 1; display: flex; gap: 10px; flex: 0 0 auto; }
.slider-controls button { min-height: 42px; padding: 10px 16px; border: 1px solid rgba(45,52,112,.12); border-radius: 999px; background: var(--white); color: var(--navy); font-weight: 800; cursor: pointer; box-shadow: 0 10px 24px rgba(30,35,80,.08); }
.slider-controls button:hover { border-color: var(--gold); color: var(--navy-dark); transform: translateY(-2px); }
.reference-slider { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(280px, 360px); gap: 20px; overflow-x: auto; overscroll-behavior-x: contain; scroll-snap-type: x mandatory; padding: 6px 2px 24px; scrollbar-width: thin; }
.reference-slide { position: relative; overflow: hidden; scroll-snap-align: start; border: 1px solid rgba(45,52,112,.1); border-left: 5px solid var(--gold); border-radius: 22px; background: linear-gradient(135deg, #fff 0%, #f8f9fd 62%, #eef1fa 100%); box-shadow: 0 18px 48px rgba(30,35,80,.1); }
.reference-slide::after { content: ""; position: absolute; right: -46px; bottom: -18px; width: 220px; height: 72px; background: url("../img/bls-logo.svg") center top / 220px auto no-repeat; filter: brightness(0) invert(1); opacity: .1; pointer-events: none; }
.reference-slide-image { min-height: 280px; border-bottom: 0; background: linear-gradient(135deg, rgba(30,35,80,.82), rgba(45,52,112,.48)), repeating-linear-gradient(45deg, #d7d9e8 0 14px, #eef0f7 14px 28px); }
.reference-slide span, .reference-slide h3, .reference-slide p { position: relative; z-index: 1; margin-left: 24px; margin-right: 24px; }
.reference-slide span { display: inline-flex; margin-top: 22px; padding: 7px 12px; border-radius: 999px; background: rgba(200,168,75,.13); color: var(--gold); font-size: 12px; font-weight: 900; letter-spacing: .14em; line-height: 1; }
.reference-slide h3 { margin-top: 14px; color: var(--navy-dark); font-size: 25px; }
.reference-slide p { margin-bottom: 28px; color: #4f566d; }
.ref-hochbau { background: linear-gradient(135deg, rgba(30,35,80,.72), rgba(200,168,75,.22)), url("https://images.unsplash.com/photo-1769284022654-66c6b07dae78?auto=format&fit=crop&w=900&q=78") center / cover no-repeat; }
.ref-schluessel { background: linear-gradient(135deg, rgba(30,35,80,.22), rgba(45,52,112,.04)), url("../img/referenz-schluesselfertig.png") center 48% / cover no-repeat; }
.ref-innen { background: linear-gradient(135deg, rgba(30,35,80,.28), rgba(45,52,112,.06)), url("../img/referenz-innenausbau.png") center 50% / cover no-repeat; }
.ref-sanierung { background: linear-gradient(135deg, rgba(30,35,80,.34), rgba(45,52,112,.08)), url("https://images.unsplash.com/photo-1768321902290-54497eeb9cf6?auto=format&fit=crop&w=900&q=78") center 52% / cover no-repeat; }
.ref-wdvs { background: linear-gradient(135deg, rgba(30,35,80,.24), rgba(45,52,112,.06)), url("../img/referenz-wdvs.png") center 50% / cover no-repeat; }
.ref-klinker { background: linear-gradient(135deg, rgba(30,35,80,.24), rgba(45,52,112,.05)), url("../img/referenz-klinker.png") center 50% / cover no-repeat; }
.ref-fenster { background: linear-gradient(135deg, rgba(30,35,80,.32), rgba(45,52,112,.08)), url("https://upload.wikimedia.org/wikipedia/commons/thumb/9/94/Fensterhandwerker_WesterwaldCIMG0360.JPG/960px-Fensterhandwerker_WesterwaldCIMG0360.JPG") center 50% / cover no-repeat; }
.home-references > .btn { margin-top: 8px; }
.cta-band { position: relative; overflow: hidden; margin: 0 auto 80px; max-width: 1200px; padding: 46px clamp(24px, 5vw, 60px); border-radius: 26px; background: radial-gradient(circle at 88% 18%, rgba(255,255,255,.36), transparent 22%), linear-gradient(135deg, var(--gold), #d9bd69); display: flex; justify-content: space-between; align-items: center; gap: 24px; box-shadow: 0 24px 70px rgba(200,168,75,.24); }
.cta-band::after { content: ""; position: absolute; right: -46px; bottom: -24px; width: 320px; height: 105px; background: url("../img/bls-logo.svg") center top / 320px auto no-repeat; filter: grayscale(1) opacity(.55); opacity: .14; pointer-events: none; }
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 { font-size: clamp(30px, 4vw, 48px); }
.cta-band .eyebrow { color: var(--navy-dark); }
.page-hero { padding: 72px clamp(18px, 5vw, 60px); background: linear-gradient(135deg, var(--navy-dark), var(--navy)); color: var(--white); }
.services-hero { position: relative; overflow: hidden; min-height: 320px; display: grid; align-content: center; background: linear-gradient(105deg, rgba(30,35,80,.97) 0%, rgba(45,52,112,.84) 44%, rgba(30,35,80,.24) 100%), radial-gradient(circle at 76% 18%, rgba(200,168,75,.3), transparent 24%), url("https://images.unsplash.com/photo-1768321917806-b4b6fbbef837?auto=format&fit=crop&w=1800&q=84") center 52% / cover no-repeat; }
.services-hero::after { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px); background-size: 64px 64px; mask-image: linear-gradient(90deg, transparent, #000 45%, #000); pointer-events: none; }
.services-hero > * { position: relative; z-index: 1; }
.services-hero .breadcrumb { display: inline-flex; align-items: center; width: fit-content; margin: 0 0 22px; padding: 8px 14px; border: 1px solid rgba(200,168,75,.38); border-radius: 999px; background: rgba(255,255,255,.08); backdrop-filter: blur(10px); color: #f6d674 !important; font-size: 13px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.services-hero .breadcrumb a { color: inherit; }
.services-hero h1 { max-width: 920px; margin: 0; color: var(--white); font-size: clamp(48px, 7vw, 88px); line-height: .95; letter-spacing: -.055em; text-shadow: 0 16px 44px rgba(0,0,0,.32); }
.services-hero h1::after { content: ""; display: block; width: clamp(90px, 16vw, 170px); height: 5px; margin-top: 24px; border-radius: 999px; background: linear-gradient(90deg, var(--gold), rgba(255,255,255,.18)); }
.services-hero p:not(.breadcrumb) { max-width: 680px; margin-top: 28px; color: rgba(255,255,255,.9); font-size: clamp(18px, 2vw, 22px); line-height: 1.65; font-weight: 500; text-shadow: 0 8px 28px rgba(0,0,0,.28); }
.about-hero { position: relative; overflow: hidden; min-height: 320px; display: grid; align-content: center; background: linear-gradient(105deg, rgba(30,35,80,.97) 0%, rgba(45,52,112,.82) 46%, rgba(30,35,80,.3) 100%), radial-gradient(circle at 74% 20%, rgba(200,168,75,.28), transparent 24%), url("https://images.unsplash.com/photo-1774599730806-61591b84280e?auto=format&fit=crop&w=1800&q=84") center 46% / cover no-repeat; }
.about-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px); background-size: 72px 72px; opacity: .45; pointer-events: none; }
.about-hero > * { position: relative; z-index: 1; }
.about-document { max-width: 1180px; }
.about-company-card { padding: clamp(30px, 5vw, 58px); }
.about-company-card .legal-company-head { max-width: 760px; padding-bottom: 26px; }
.about-copy { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(280px, .95fr); gap: clamp(22px, 4vw, 46px); align-items: start; }
.about-copy p { margin: 0; color: #4f566d; font-size: 17px; line-height: 1.8; }
.about-copy .about-lead { padding: 22px 0 22px 24px; border-left: 5px solid var(--gold); color: var(--navy-dark); font-size: clamp(20px, 2.4vw, 28px); font-weight: 900; line-height: 1.42; letter-spacing: -.03em; }
.about-service-tags { position: relative; z-index: 1; display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; padding-top: 28px; border-top: 1px solid rgba(45,52,112,.1); }
.about-service-tags span { padding: 10px 14px; border: 1px solid rgba(45,52,112,.1); border-radius: 999px; background: rgba(255,255,255,.82); color: var(--navy); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; box-shadow: 0 10px 24px rgba(30,35,80,.07); }
.about-info-grid { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-top: 24px; }
.about-region-card { position: relative; z-index: 1; display: grid; gap: 4px; min-height: 120px; margin-top: 0; padding: 20px 22px; border: 1px solid rgba(45,52,112,.1); border-left: 5px solid var(--gold); border-radius: 20px; background: rgba(255,255,255,.82); box-shadow: 0 14px 34px rgba(30,35,80,.08); }
.about-region-card span { color: var(--gold); font-size: 11px; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; }
.about-region-card strong { color: var(--navy-dark); font-size: clamp(18px, 2vw, 22px); line-height: 1.35; }
.about-region-card small { color: #68708a; font-size: 14px; }
.page-hero > * { position: relative; z-index: 1; }
.page-hero .breadcrumb { display: inline-flex; align-items: center; width: fit-content; margin: 0 0 22px; padding: 8px 14px; border: 1px solid rgba(200,168,75,.38); border-radius: 999px; background: rgba(255,255,255,.08); backdrop-filter: blur(10px); color: #f6d674 !important; font-size: 13px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.page-hero .breadcrumb a { color: inherit; }
.page-hero h1 { max-width: 980px; margin: 0; color: var(--white); font-size: clamp(44px, 6vw, 78px); line-height: .98; letter-spacing: -.055em; text-shadow: 0 16px 44px rgba(0,0,0,.32); }
.page-hero h1::after { content: ""; display: block; width: clamp(90px, 16vw, 170px); height: 5px; margin-top: 24px; border-radius: 999px; background: linear-gradient(90deg, var(--gold), rgba(255,255,255,.18)); }
.page-hero p:not(.breadcrumb) { max-width: 780px; margin-top: 28px; color: rgba(255,255,255,.9); font-size: clamp(18px, 2vw, 22px); line-height: 1.65; font-weight: 500; text-shadow: 0 8px 28px rgba(0,0,0,.28); }
.breadcrumb { font-size: 14px; color: var(--gold) !important; }
.references-hero { position: relative; overflow: hidden; background: radial-gradient(circle at 78% 16%, rgba(200,168,75,.28), transparent 24%), linear-gradient(105deg, rgba(30,35,80,.98) 0%, rgba(45,52,112,.88) 48%, rgba(30,35,80,.32) 100%), url("https://images.unsplash.com/photo-1771432998536-fea330a65c26?auto=format&fit=crop&w=1800&q=84") center 48% / cover no-repeat; }
.references-hero::after { content: ""; position: absolute; right: -58px; bottom: -22px; width: 360px; height: 118px; background: url("../img/bls-logo.svg") center top / 360px auto no-repeat; filter: brightness(0) invert(1); opacity: .08; pointer-events: none; }
.references-hero > * { position: relative; z-index: 1; }
.references-section { max-width: none; padding-left: max(18px, calc((100vw - 1200px) / 2)); padding-right: max(18px, calc((100vw - 1200px) / 2)); background: linear-gradient(180deg, #fff 0%, #f5f6fb 100%); }
.filter-row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 30px; padding: 16px; border: 1px solid rgba(45,52,112,.1); border-left: 5px solid var(--gold); border-radius: 18px; background: var(--white); box-shadow: 0 16px 44px rgba(30,35,80,.1); }
.filter { border: 1px solid rgba(45,52,112,.1); border-radius: 999px; padding: 11px 18px; background: var(--light); color: var(--navy); font-weight: 800; cursor: pointer; transition: transform .2s, background .2s, color .2s, border-color .2s; }
.filter:hover { transform: translateY(-2px); border-color: var(--gold); }
.filter.active { background: var(--navy); color: var(--white); border-color: var(--navy); }
.reference-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.reference-card { position: relative; overflow: hidden; border: 1px solid rgba(45,52,112,.1); border-left: 5px solid var(--gold); border-radius: 22px; background: linear-gradient(135deg, #fff 0%, #f8f9fd 62%, #eef1fa 100%); box-shadow: 0 18px 48px rgba(30,35,80,.1); transition: transform .2s, box-shadow .2s; }
.reference-card::after { content: ""; position: absolute; right: -52px; bottom: -18px; width: 250px; height: 82px; background: url("../img/bls-logo.svg") center top / 250px auto no-repeat; filter: grayscale(1) opacity(.55); opacity: .08; pointer-events: none; }
.reference-card:hover { transform: translateY(-5px); box-shadow: 0 26px 70px rgba(30,35,80,.16); }
.reference-card h2, .reference-card p { position: relative; z-index: 1; padding: 0 24px; }
.reference-card h2 { margin-top: 22px; color: var(--navy-dark); font-size: 25px; }
.reference-card p { padding-bottom: 28px; color: #4f566d; }
.image-placeholder { min-height: 220px; border-bottom: 1px solid rgba(45,52,112,.08); background: linear-gradient(135deg, rgba(30,35,80,.82), rgba(45,52,112,.48)), repeating-linear-gradient(45deg, #d7d9e8 0 14px, #eef0f7 14px 28px); }
.image-placeholder.alt { background: linear-gradient(135deg, #30364f, #9aa0b8); }
.image-placeholder.gold { background: linear-gradient(135deg, var(--gold), var(--navy)); }
.image-placeholder.rohbau { background: linear-gradient(135deg, rgba(30,35,80,.2), rgba(45,52,112,.04)), url("../img/referenz-rohbau.png") center 44% / cover no-repeat; }
.image-placeholder.house { background: linear-gradient(135deg, rgba(30,35,80,.22), rgba(45,52,112,.04)), url("../img/referenz-schluesselfertig.png") center 48% / cover no-repeat; }
.image-placeholder.innenausbau { background: linear-gradient(135deg, rgba(30,35,80,.28), rgba(45,52,112,.06)), url("../img/referenz-innenausbau.png") center 50% / cover no-repeat; }
.image-placeholder.kernsanierung { background: linear-gradient(135deg, rgba(30,35,80,.34), rgba(45,52,112,.08)), url("https://images.unsplash.com/photo-1768321902290-54497eeb9cf6?auto=format&fit=crop&w=900&q=78") center 52% / cover no-repeat; }
.image-placeholder.wdvs { background: linear-gradient(135deg, rgba(30,35,80,.24), rgba(45,52,112,.06)), url("../img/referenz-wdvs.png") center 50% / cover no-repeat; }
.image-placeholder.klinker { background: linear-gradient(135deg, rgba(30,35,80,.24), rgba(45,52,112,.05)), url("../img/referenz-klinker.png") center 50% / cover no-repeat; }
.image-placeholder.fenster { background: linear-gradient(135deg, rgba(30,35,80,.32), rgba(45,52,112,.08)), url("https://upload.wikimedia.org/wikipedia/commons/thumb/9/94/Fensterhandwerker_WesterwaldCIMG0360.JPG/960px-Fensterhandwerker_WesterwaldCIMG0360.JPG") center 50% / cover no-repeat; }
.two-col, .contact-layout, .detail-layout { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr); gap: 42px; }
.contact-hero { position: relative; overflow: hidden; background: linear-gradient(105deg, rgba(30,35,80,.97) 0%, rgba(45,52,112,.84) 46%, rgba(30,35,80,.22) 100%), radial-gradient(circle at 82% 12%, rgba(200,168,75,.32), transparent 28%), url("https://images.pexels.com/photos/6615233/pexels-photo-6615233.jpeg?auto=compress&cs=tinysrgb&w=1800") center 54% / cover no-repeat; }
.contact-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px); background-size: 72px 72px; opacity: .4; pointer-events: none; }
.contact-hero > * { position: relative; z-index: 1; }
.legal-hero { position: relative; overflow: hidden; min-height: 300px; display: grid; align-content: center; }
.impressum-hero { background: linear-gradient(105deg, rgba(30,35,80,.97) 0%, rgba(45,52,112,.84) 48%, rgba(30,35,80,.22) 100%), radial-gradient(circle at 78% 18%, rgba(200,168,75,.28), transparent 24%), url("https://images.pexels.com/photos/5668802/pexels-photo-5668802.jpeg?auto=compress&cs=tinysrgb&w=1800") center 52% / cover no-repeat; }
.datenschutz-hero { background: linear-gradient(105deg, rgba(30,35,80,.98) 0%, rgba(45,52,112,.86) 48%, rgba(30,35,80,.28) 100%), radial-gradient(circle at 78% 18%, rgba(200,168,75,.24), transparent 24%), url("https://images.pexels.com/photos/4973899/pexels-photo-4973899.jpeg?auto=compress&cs=tinysrgb&w=1800") center 50% / cover no-repeat; }
.agb-hero { background: linear-gradient(105deg, rgba(30,35,80,.97) 0%, rgba(45,52,112,.84) 48%, rgba(30,35,80,.24) 100%), radial-gradient(circle at 78% 18%, rgba(200,168,75,.28), transparent 24%), url("https://images.pexels.com/photos/7567600/pexels-photo-7567600.jpeg?auto=compress&cs=tinysrgb&w=1800") center 46% / cover no-repeat; }
.legal-hero::after { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px); background-size: 68px 68px; opacity: .45; pointer-events: none; }
.legal-hero > * { position: relative; z-index: 1; }
.contact-section { padding-top: 54px; }
.quick-contact-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-bottom: 34px; }
.quick-contact-card { display: grid; gap: 6px; padding: 22px; background: var(--white); border: 1px solid rgba(45,52,112,.1); border-top: 4px solid var(--gold); border-radius: 16px; box-shadow: 0 18px 44px rgba(30,35,80,.1); color: var(--text); text-decoration: none; transition: transform .2s, box-shadow .2s; }
.quick-contact-card:hover { transform: translateY(-3px); box-shadow: 0 22px 54px rgba(30,35,80,.16); }
.quick-contact-card span { color: var(--gold); font-weight: 900; font-size: 12px; letter-spacing: .16em; text-transform: uppercase; }
.quick-contact-card strong { color: var(--navy-dark); font-size: 20px; line-height: 1.25; }
.quick-contact-card small { color: var(--gray); font-size: 14px; }
.contact-layout { align-items: start; }
.values { display: grid; gap: 16px; }
.values article, .contact-panel, .contact-form, .detail-layout aside { background: var(--light); padding: 28px; border-left: 4px solid var(--gold); }
.contact-panel { position: sticky; top: 138px; overflow: hidden; border-radius: 18px; background: linear-gradient(160deg, var(--navy-dark), var(--navy)); color: rgba(255,255,255,.82); box-shadow: 0 24px 70px rgba(30,35,80,.18); }
.contact-panel::after { content: ""; position: absolute; right: -32px; bottom: -12px; width: 340px; height: 112px; background: url("../img/bls-logo.svg") center top / 340px auto no-repeat; filter: brightness(0) invert(1); opacity: .11; pointer-events: none; }
.contact-panel > * { position: relative; z-index: 1; }
.contact-panel h2 { color: var(--white); font-size: 32px; }
.contact-panel .eyebrow { color: var(--gold); }
.contact-lead { color: rgba(255,255,255,.76); margin-bottom: 24px; }
.contact-info-list { display: grid; gap: 16px; position: relative; z-index: 1; }
.contact-info-list p { display: grid; gap: 4px; margin: 0; padding-bottom: 16px; border-bottom: 1px solid rgba(255,255,255,.12); }
.contact-info-list p:last-child { border-bottom: 0; padding-bottom: 0; }
.contact-info-list strong { color: var(--gold); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; }
.contact-info-list span, .contact-info-list a { color: rgba(255,255,255,.9); }
.contact-panel a { color: rgba(255,255,255,.92); font-weight: 700; }
.contact-panel .social-block { position: relative; z-index: 1; margin-top: 28px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.12); color: var(--white); }
.contact-panel .social-links a { color: var(--navy); }
.social-block { margin-top: 24px; }
.social-links { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px; }
.social-links a { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; overflow: hidden; white-space: nowrap; font-size: 0; line-height: 0; border: 1px solid rgba(45,52,112,.18); border-radius: 999px; background: var(--white); color: var(--navy); text-decoration: none; }
.social-links a::before { content: ""; display: block; width: 18px; height: 18px; flex: 0 0 18px; background: currentColor; -webkit-mask: var(--social-icon) center / contain no-repeat; mask: var(--social-icon) center / contain no-repeat; }
.social-links a[href*="facebook"] { --social-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M24 12.07C24 5.4 18.63 0 12 0S0 5.4 0 12.07C0 18.1 4.39 23.1 10.13 24v-8.44H7.08v-3.49h3.05V9.41c0-3.02 1.79-4.69 4.53-4.69 1.31 0 2.69.24 2.69.24v2.97h-1.51c-1.49 0-1.96.93-1.96 1.88v2.26h3.33l-.53 3.49h-2.8V24C19.61 23.1 24 18.1 24 12.07z'/%3E%3C/svg%3E"); }
.social-links a[href*="instagram"] { --social-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2.16c3.2 0 3.58.01 4.85.07 3.25.15 4.77 1.69 4.92 4.92.06 1.27.07 1.65.07 4.85s-.01 3.58-.07 4.85c-.15 3.23-1.66 4.77-4.92 4.92-1.27.06-1.65.07-4.85.07s-3.58-.01-4.85-.07c-3.26-.15-4.77-1.7-4.92-4.92C2.17 15.58 2.16 15.2 2.16 12s.01-3.58.07-4.85c.15-3.23 1.66-4.77 4.92-4.92C8.42 2.17 8.8 2.16 12 2.16zM12 0C8.74 0 8.33.01 7.05.07 2.7.27.27 2.69.07 7.05.01 8.33 0 8.74 0 12s.01 3.67.07 4.95c.2 4.36 2.62 6.78 6.98 6.98C8.33 23.99 8.74 24 12 24s3.67-.01 4.95-.07c4.35-.2 6.78-2.62 6.98-6.98.06-1.28.07-1.69.07-4.95s-.01-3.67-.07-4.95c-.2-4.35-2.62-6.78-6.98-6.98C15.67.01 15.26 0 12 0zm0 5.84a6.16 6.16 0 1 0 0 12.32 6.16 6.16 0 0 0 0-12.32zM12 16a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm6.41-11.85a1.44 1.44 0 1 0 0 2.88 1.44 1.44 0 0 0 0-2.88z'/%3E%3C/svg%3E"); }
.social-links a[href*="linkedin"] { --social-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20.45 20.45h-3.55v-5.57c0-1.33-.03-3.04-1.85-3.04-1.85 0-2.14 1.45-2.14 2.94v5.67H9.35V9h3.41v1.56h.05c.48-.9 1.64-1.85 3.37-1.85 3.6 0 4.27 2.37 4.27 5.46v6.28zM5.34 7.43a2.06 2.06 0 1 1 0-4.13 2.06 2.06 0 0 1 0 4.13zm1.78 13.02H3.56V9h3.56v11.45zM22.23 0H1.77C.79 0 0 .77 0 1.73v20.54C0 23.23.79 24 1.77 24h20.46c.98 0 1.77-.77 1.77-1.73V1.73C24 .77 23.21 0 22.23 0z'/%3E%3C/svg%3E"); }
.social-links a[href*="tiktok"] { --social-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.53.02h3.91c.08 1.53.63 3.09 1.75 4.17 1.12 1.11 2.7 1.62 4.24 1.79v4.03c-1.44-.05-2.89-.35-4.2-.97-.57-.26-1.1-.59-1.62-.93v8.75c-.08 1.4-.54 2.79-1.35 3.94-1.31 1.92-3.58 3.17-5.91 3.21-1.43.08-2.86-.31-4.08-1.03-2.02-1.19-3.44-3.37-3.65-5.71-.02-.5-.03-1-.01-1.49.18-1.9 1.12-3.72 2.58-4.96 1.66-1.44 3.98-2.13 6.15-1.72v4.44c-.99-.32-2.15-.23-3.02.37-.63.41-1.11 1.04-1.36 1.75-.21.51-.15 1.07-.14 1.61.24 1.64 1.82 3.02 3.5 2.87 1.12-.01 2.19-.66 2.77-1.61.19-.33.4-.67.41-1.06.1-1.79.06-3.57.07-5.36V.02z'/%3E%3C/svg%3E"); }
.social-links a[href*="xing"] { --social-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M18.19 0c-.52 0-.74.33-.93.66L9.56 14.32l4.92 9.02c.17.31.44.66.97.66h3.45c.21 0 .38-.08.46-.22.09-.15.09-.35-.01-.54l-4.88-8.91L22.14.76c.1-.19.1-.39.01-.54C22.06.08 21.89 0 21.69 0h-3.5zM3.65 4.74c-.21 0-.39.07-.47.22-.09.15-.08.34.02.53l2.34 4.05-3.68 6.51c-.1.19-.09.38 0 .53.09.14.24.23.45.23h3.46c.52 0 .77-.35.95-.67l3.73-6.61-2.38-4.15c-.17-.32-.43-.66-.96-.66H3.65v.02z'/%3E%3C/svg%3E"); }
.social-links a:hover { border-color: var(--gold); color: var(--navy-dark); }
.contact-form { display: grid; gap: 20px; background: linear-gradient(180deg, #fff 0%, #fafbff 100%); padding: 34px; border: 1px solid rgba(45,52,112,.08); border-left: 5px solid var(--gold); border-radius: 18px; box-shadow: 0 24px 70px rgba(30,35,80,.16); }
.form-head { padding-bottom: 4px; }
.form-head h2 { font-size: 32px; margin-bottom: 8px; }
.form-head p:last-child { color: var(--gray); margin: 0; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
label { display: grid; gap: 9px; color: var(--navy-dark); font-weight: 800; letter-spacing: -.01em; }
input, select, textarea { width: 100%; border: 1px solid #d9deec; border-radius: 10px; padding: 15px 16px; font: inherit; color: var(--text); background: #fff; transition: border-color .2s, box-shadow .2s, transform .2s; }
select { appearance: auto; cursor: pointer; }
textarea { min-height: 150px; resize: vertical; }
input:hover, select:hover, textarea:hover { border-color: #c8cfe2; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 4px rgba(200,168,75,.18); transform: translateY(-1px); }
.contact-form .btn { min-height: 54px; border-radius: 10px; background: linear-gradient(135deg, var(--gold), #d8bb62); box-shadow: 0 12px 24px rgba(200,168,75,.26); }
.contact-form .btn:hover { transform: translateY(-2px); box-shadow: 0 16px 30px rgba(200,168,75,.34); }
.privacy-note { color: #68708a; font-size: 13px; margin: 0; line-height: 1.7; background: rgba(45,52,112,.04); padding: 12px 14px; border-radius: 10px; }
.map-card { margin-top: 42px; overflow: hidden; background: var(--white); border: 1px solid rgba(45,52,112,.1); border-radius: 18px; box-shadow: 0 24px 70px rgba(30,35,80,.14); }
.map-card-head { display: flex; align-items: end; justify-content: space-between; gap: 22px; padding: 28px 30px; border-left: 5px solid var(--gold); }
.map-card-head h2 { margin-bottom: 0; font-size: clamp(26px, 3vw, 38px); }
.map-card-head a { color: var(--navy); font-weight: 800; white-space: nowrap; }
.map-card iframe { display: block; width: 100%; height: 420px; border: 0; filter: saturate(.9) contrast(1.04); }
.hp-field { position: absolute; left: -10000px; height: 1px; overflow: hidden; }
.form-message { padding: 14px 16px; border-left: 4px solid var(--navy); background: var(--light); }
.form-message.success { border-color: #2e7d32; color: #1b5e20; background: #eaf6ed; }
.form-message.error { border-color: #c62828; color: #8a1f1f; background: #fff3f3; }
.detail { background: linear-gradient(180deg, #fff 0%, #f5f6fb 100%); }
.detail-layout { align-items: stretch; }
.detail-overview { grid-template-columns: 1fr; }
.detail-layout > div { position: relative; overflow: hidden; padding: clamp(30px, 4vw, 48px); border: 1px solid rgba(45,52,112,.1); border-left: 5px solid var(--gold); border-radius: 26px; background: linear-gradient(135deg, #fff 0%, #f8f9fd 68%, #eef1fa 100%); box-shadow: 0 24px 70px rgba(30,35,80,.12); }
.detail-layout > div::after { content: ""; position: absolute; right: -48px; bottom: -18px; width: 320px; height: 104px; background: url("../img/bls-logo.svg") center top / 320px auto no-repeat; filter: grayscale(1) opacity(.55); opacity: .08; pointer-events: none; }
.detail .breadcrumb, .detail h1, .detail h2, .detail h3, .detail-layout > div > p, .detail-layout ul { position: relative; z-index: 1; }
.detail h1 { margin-top: 10px; letter-spacing: -.035em; overflow-wrap: anywhere; hyphens: auto; }
.detail h1 + p { margin-top: 20px; max-width: 700px; color: #4f566d; font-size: 18px; line-height: 1.75; }
.detail-topic-page h1 { max-width: 880px; font-size: clamp(36px, 4.8vw, 60px); line-height: 1.05; }
.detail-topic-page h2 { max-width: 760px; margin: 18px 0 0; color: var(--gold); font-size: clamp(22px, 2.8vw, 34px); line-height: 1.2; letter-spacing: -.025em; }
.detail-topic-page h3 { max-width: 820px; margin: 30px 0 0; color: var(--navy-dark); font-size: clamp(21px, 2.4vw, 30px); line-height: 1.25; letter-spacing: -.025em; }
.detail-topic-page h2 + p { margin-top: 24px; }
.detail-topic-page h3 + p { margin-top: 12px; }
.detail-topic-page p { position: relative; z-index: 1; max-width: 860px; color: #4f566d; font-size: clamp(17px, 1.7vw, 20px); line-height: 1.8; }
.detail-topic-page p + p { margin-top: 18px; }
.detail-topic-page .topic-photo-placeholder { margin-top: 30px; min-height: 260px; }
.topic-image { position: relative; z-index: 1; overflow: hidden; margin: 30px 0 0; border: 1px solid rgba(45,52,112,.1); border-radius: 18px; background: var(--white); box-shadow: 0 16px 42px rgba(30,35,80,.1); }
.topic-image img { display: block; width: 100%; height: auto; }
.detail-topic-page { grid-template-columns: minmax(0, 1fr); gap: 0; }
.detail-topic-page > div { border-left: 0; }
.detail-topic-page aside { overflow: visible; min-height: 0; margin-top: 24px; padding: 0; border-left: 0; background: transparent; box-shadow: none; border-radius: 0; color: inherit; }
.detail-topic-page aside::before, .detail-topic-page aside::after { display: none; }
.detail-topic-page aside::selection { background: transparent; }
.detail-topic-page aside .btn { width: auto; min-width: 210px; justify-self: start; border-radius: 999px; }
.detail-layout ul { display: grid; gap: 12px; margin: 28px 0 0; padding: 0; list-style: none; }
.detail-layout li { position: relative; padding: 15px 18px 15px 44px; border: 1px solid rgba(45,52,112,.1); border-radius: 16px; background: rgba(255,255,255,.76); color: var(--navy-dark); font-weight: 700; box-shadow: 0 10px 24px rgba(30,35,80,.06); }
.detail-layout li::before { content: ""; position: absolute; left: 18px; top: 21px; width: 10px; height: 10px; border-radius: 999px; background: var(--gold); box-shadow: 0 0 0 5px rgba(200,168,75,.14); }
.detail-layout li strong { display: block; color: var(--navy-dark); }
.detail-layout li small { display: block; margin-top: 4px; color: #68708a; font-size: 14px; line-height: 1.55; font-weight: 500; }
.detail-topic-grid { position: relative; z-index: 1; display: grid; gap: 16px; margin-top: 28px; }
.detail-topic-card { position: relative; overflow: hidden; display: grid; grid-template-columns: minmax(0, 1fr) minmax(220px, 320px); gap: 22px; align-items: stretch; padding: 22px; border: 1px solid rgba(45,52,112,.1); border-left: 5px solid var(--gold); border-radius: 18px; background: rgba(255,255,255,.8); box-shadow: 0 14px 34px rgba(30,35,80,.08); cursor: pointer; transition: transform .2s, box-shadow .2s; }
.detail-topic-card::after { content: ""; position: absolute; right: -42px; bottom: -16px; width: 220px; height: 72px; background: url("../img/bls-logo.svg") center top / 220px auto no-repeat; filter: grayscale(1) opacity(.55); opacity: .08; pointer-events: none; }
.detail-topic-card:not([data-page]) { cursor: default; }
.detail-topic-card:hover, .detail-topic-card:focus { transform: translateY(-3px); box-shadow: 0 20px 52px rgba(30,35,80,.14); outline: none; }
.detail-topic-card > * { position: relative; z-index: 1; }
.detail-topic-copy { display: grid; align-content: start; gap: 10px; }
.detail-topic-media { display: grid; gap: 12px; align-content: start; }
.detail-topic-cta { position: relative; z-index: 1; display: flex; justify-content: flex-start; margin-top: 24px; }
.detail-topic-card span { justify-self: start; padding: 7px 12px; border-radius: 999px; background: rgba(200,168,75,.13); color: var(--gold); font-size: 12px; font-weight: 900; letter-spacing: .14em; line-height: 1; }
.detail-topic-card h2 { margin: 0; color: var(--navy-dark); font-size: clamp(22px, 2.5vw, 30px); }
.detail-topic-card p { margin: 0; color: #4f566d; }
.detail-topic-card a { justify-self: start; color: var(--navy); font-weight: 900; text-decoration-color: rgba(200,168,75,.55); text-underline-offset: 4px; }
.topic-photo-placeholder { position: relative; z-index: 1; display: grid; place-items: center; min-height: 190px; border: 1px dashed rgba(45,52,112,.25); border-radius: 18px; background: linear-gradient(135deg, rgba(30,35,80,.74), rgba(200,168,75,.2)), repeating-linear-gradient(45deg, #d7d9e8 0 14px, #eef0f7 14px 28px); color: var(--white); font-weight: 900; text-transform: uppercase; letter-spacing: .08em; text-align: center; }
.detail-layout aside { position: relative; overflow: hidden; display: grid; align-content: start; gap: 18px; min-height: 260px; border-radius: 26px; background: linear-gradient(160deg, var(--navy-dark), var(--navy)); color: rgba(255,255,255,.82); box-shadow: 0 24px 70px rgba(30,35,80,.18); }
.detail-layout aside::before { content: "Bereit für Ihr Projekt?"; position: relative; z-index: 1; color: var(--white); font-size: 28px; font-weight: 900; line-height: 1.1; }
.detail-layout aside::after { content: ""; position: absolute; right: -56px; bottom: -18px; width: 300px; height: 98px; background: url("../img/bls-logo.svg") center top / 300px auto no-repeat; filter: brightness(0) invert(1); opacity: .1; pointer-events: none; }
.detail-layout aside .btn { position: relative; z-index: 1; border-radius: 999px; }
.detail-topic-page aside { overflow: visible; min-height: 0; margin-top: 24px; padding: 0; background: transparent; box-shadow: none; border-radius: 0; color: inherit; }
.detail-topic-page aside::before, .detail-topic-page aside::after { display: none; }
.detail-topic-page aside .btn { width: auto; min-width: 210px; justify-self: start; border-radius: 999px; }
.legal h2 { margin-top: 28px; }
.legal-document { max-width: 980px; line-height: 1.75; }
.legal-document > p, .legal-document li, .legal-meta-grid { color: #4f566d; }
.legal-document a { color: var(--navy); font-weight: 800; text-decoration-color: rgba(200,168,75,.55); text-underline-offset: 3px; }
.legal-company-card { position: relative; overflow: hidden; display: grid; gap: 22px; margin: 0 0 42px; padding: clamp(28px, 4vw, 42px); border: 1px solid rgba(45,52,112,.1); border-top: 5px solid var(--gold); border-radius: 24px; background: linear-gradient(135deg, #fff 0%, #f8f9fd 62%, #eef1fa 100%); box-shadow: 0 26px 70px rgba(30,35,80,.14); }
.legal-company-card::after { content: ""; position: absolute; right: -42px; bottom: -14px; width: 360px; height: 118px; background: url("../img/bls-logo.svg") center top / 360px auto no-repeat; filter: grayscale(1) opacity(.55); opacity: .12; pointer-events: none; }
.legal-company-head, .legal-meta-grid, .legal-contact-row { position: relative; z-index: 1; }
.legal-kicker, .legal-meta-grid span, .legal-contact-row span { color: var(--gold); font-size: 11px; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; }
.legal-company-head { display: grid; gap: 8px; padding-bottom: 18px; border-bottom: 1px solid rgba(45,52,112,.1); }
.legal-company-head strong { color: var(--navy-dark); font-size: clamp(30px, 4vw, 44px); line-height: 1; letter-spacing: -.035em; }
.legal-meta-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 14px; }
.legal-meta-grid div { display: grid; gap: 8px; min-height: 112px; padding: 18px; border: 1px solid rgba(45,52,112,.09); border-radius: 16px; background: rgba(255,255,255,.72); box-shadow: 0 12px 30px rgba(30,35,80,.07); }
.legal-meta-grid strong { color: var(--navy-dark); font-size: 16px; line-height: 1.45; }
.legal-contact-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 12px; }
.legal-contact-row a { display: grid; gap: 4px; min-height: 64px; padding: 13px 16px; border: 1px solid rgba(45,52,112,.13); border-radius: 16px; background: var(--white); box-shadow: 0 10px 24px rgba(30,35,80,.08); text-decoration: none; }
.legal-contact-row a:hover { border-color: var(--gold); color: var(--navy-dark); }
.legal-document > h2 { display: flex; align-items: center; gap: 12px; margin: 34px 0 14px; padding: 18px 20px; border: 1px solid rgba(45,52,112,.1); border-left: 5px solid var(--gold); border-radius: 14px; background: linear-gradient(135deg, rgba(45,52,112,.06), rgba(200,168,75,.08)); color: var(--navy-dark); font-size: clamp(22px, 2.4vw, 30px); }
.legal-document > h2:first-of-type { margin-top: 0; }
.legal-document > ul { margin: 8px 0 18px; padding: 18px 22px 18px 42px; border-radius: 14px; background: rgba(45,52,112,.04); }
.legal-document > p { margin: 0 0 13px; }
.site-footer { position: relative; overflow: hidden; padding: 50px clamp(18px, 5vw, 60px) 24px; background: radial-gradient(circle at 82% 18%, rgba(200,168,75,.16), transparent 26%), linear-gradient(135deg, var(--navy-dark), #252b62); color: rgba(255,255,255,.78); }
.site-footer::after { content: ""; position: absolute; right: -70px; bottom: 34px; width: 420px; height: 138px; background: url("../img/bls-logo.svg") center top / 420px auto no-repeat; filter: brightness(0) invert(1); opacity: .06; pointer-events: none; }
.footer-main, .footer-bottom { position: relative; z-index: 1; max-width: 1200px; margin: 0 auto; }
.footer-main { display: grid; grid-template-columns: minmax(220px, 1.3fr) repeat(4, minmax(150px, 1fr)); gap: 34px; align-items: start; }
.site-footer strong { color: var(--white); }
.footer-brand { display: grid; align-content: start; gap: 18px; }
.footer-brand p { margin: 0; }
.footer-logo { display: block; width: auto; height: 64px; background: var(--white); padding: 8px 10px; border-radius: 4px; }
.footer-column { display: grid; gap: 12px; align-content: start; }
.footer-column h2 { margin: 0 0 4px; color: var(--gold); font-size: 13px; letter-spacing: .14em; text-transform: uppercase; }
.footer-column nav, .footer-contact { display: grid; gap: 9px; }
.footer-contact address { font-style: normal; }
.site-footer a { color: var(--white); }
.site-footer a:hover { color: var(--gold); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; gap: 18px; margin-top: 38px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.12); color: rgba(255,255,255,.62); font-size: 14px; }
.footer-bottom p { margin: 0; }
.footer-bottom a { font-weight: 800; }
.footer-social { justify-content: flex-start; margin-top: 0; gap: 10px; padding: 0; background: transparent; border: 0; border-radius: 0; }
.footer-social a { width: 34px; height: 34px; background: var(--white); border-color: var(--white); color: var(--navy); }
.footer-social a::before { width: 16px; height: 16px; flex-basis: 16px; }
.footer-social a:hover { color: var(--navy-dark); border-color: var(--gold); }
.topbar-social { margin-top: 0; gap: 8px; flex: 0 0 auto; }
.topbar-social a { width: 28px; height: 28px; background: var(--white); border-color: var(--white); color: var(--navy); box-shadow: 0 2px 8px rgba(0,0,0,.12); }
.topbar-social a::before { width: 14px; height: 14px; flex-basis: 14px; }
.topbar-social a:hover { color: var(--navy-dark); border-color: var(--gold); }
@media (max-width: 980px) {
  .hero, .two-col, .contact-layout, .detail-layout, .about-copy { grid-template-columns: 1fr; }
  .detail-topic-card { grid-template-columns: 1fr; }
  .service-grid, .service-grid.compact, .reference-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-highlights { grid-template-columns: 1fr; max-width: 560px; }
  .quick-contact-grid { grid-template-columns: 1fr; }
  .legal-meta-grid, .legal-contact-row { grid-template-columns: 1fr; }
  .about-info-grid { grid-template-columns: 1fr; }
  .home-reference-head { display: grid; align-items: start; }
  .footer-main { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .contact-panel { position: relative; top: auto; }
}
@media (max-width: 760px) {
  .topbar { justify-content: center; flex-wrap: wrap; overflow-x: visible; gap: 10px 16px; padding-top: 8px; padding-bottom: 8px; }
  .topbar-contact { justify-content: center; flex-wrap: wrap; gap: 10px 16px; }
  .topbar-social { justify-content: center; }
  .brand-logo { height: 48px; }
  .footer-logo { height: 56px; }
  .nav-toggle { display: block; }
  .nav-menu { position: absolute; left: 0; right: 0; top: 100%; display: none; flex-direction: column; align-items: stretch; background: var(--white); padding: 12px 18px 20px; box-shadow: var(--shadow); }
  .nav-menu.open { display: flex; }
  .nav-menu .nav-cta { margin-left: 0; }
  .service-grid, .service-grid.compact, .reference-grid, .form-row { grid-template-columns: 1fr; }
  .about-company-card { padding: 28px 22px; }
  .about-copy .about-lead { padding: 18px 0 18px 18px; }
  .detail-topic-page h1 { font-size: clamp(32px, 10vw, 46px); }
  .detail-topic-page .topic-photo-placeholder { min-height: 210px; }
  .map-card-head { display: grid; align-items: start; }
  .map-card iframe { height: 340px; }
  .hero { padding-top: 58px; }
  .cta-band { flex-direction: column; align-items: flex-start; }
  .footer-main { grid-template-columns: 1fr; }
  .footer-bottom { display: grid; justify-items: start; }
}
