:root{--ink:#10242c;--muted:#64727a;--gold:#c99536;--gold2:#e6bc71;--cream:#f6f0e7;--paper:#fffdf9;--line:rgba(16,36,44,.12);--shadow:0 24px 80px rgba(16,36,44,.16);--radius:28px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Manrope,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--paper);color:var(--ink);line-height:1.6}img{max-width:100%;display:block}a{color:inherit}.container{width:min(1180px,calc(100% - 40px));margin-inline:auto}.skip-link{position:absolute;left:-999px}.skip-link:focus{left:20px;top:20px;background:#fff;padding:12px;z-index:9999}.site-header{position:sticky;top:0;z-index:50;background:rgba(255,253,249,.84);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.nav-wrap{height:88px;display:flex;align-items:center;gap:28px}.brand{display:flex;align-items:center;gap:12px;text-decoration:none}.brand img{width:58px;height:58px;object-fit:contain}.brand strong{display:block;font-weight:800;letter-spacing:.08em}.brand small{display:block;color:var(--muted);font-size:.78rem}.site-nav{margin-left:auto;display:flex;gap:22px;align-items:center}.nav-link{text-decoration:none;color:var(--muted);font-weight:700;font-size:.95rem}.nav-link:hover,.nav-link.active{color:var(--gold)}.nav-phone{text-decoration:none;border:1px solid var(--line);padding:10px 14px;border-radius:999px;font-weight:800}.menu-toggle{display:none}.hero{position:relative;min-height:760px;display:grid;align-items:end;overflow:hidden;background:var(--ink);color:white}.hero__bg{position:absolute;inset:0}.hero__bg img{width:100%;height:100%;object-fit:cover;opacity:.58;filter:saturate(.92)}.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(9,24,30,.90),rgba(9,24,30,.34),rgba(9,24,30,.22))}.hero__content{position:relative;z-index:2;padding:170px 0 90px;max-width:820px}.eyebrow{margin:0 0 16px;color:var(--gold2);font-weight:800;letter-spacing:.16em;text-transform:uppercase;font-size:.78rem}.hero h1,.section-title h2,.split h2,.cta-band h2{font-family:'Playfair Display',serif;line-height:1.04}.hero h1{font-size:clamp(3rem,7vw,6.7rem);margin:0 0 24px;letter-spacing:-.05em}.lead{font-size:clamp(1.08rem,2vw,1.35rem);color:rgba(255,255,255,.84);max-width:690px}.actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:54px;padding:0 24px;border-radius:999px;text-decoration:none;font-weight:900;border:1px solid transparent}.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#14242b;box-shadow:0 18px 50px rgba(201,149,54,.28)}.btn-ghost{border-color:rgba(255,255,255,.35);color:#fff;background:rgba(255,255,255,.08)}.btn-dark{background:var(--ink);color:#fff}.btn-light{background:#fff;color:var(--ink)}.hero__stats{position:relative;z-index:3;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.22);border-radius:var(--radius);overflow:hidden;margin-bottom:34px;backdrop-filter:blur(14px)}.hero__stats div{padding:26px;background:rgba(8,23,29,.28)}.hero__stats strong{display:block;font-size:1.6rem}.hero__stats span{color:rgba(255,255,255,.76);font-size:.92rem}.section{padding:112px 0}.section-alt{background:var(--cream)}.section-title{max-width:760px;margin-bottom:54px}.section-title.center{text-align:center;margin-inline:auto}.section-title h2{font-size:clamp(2.2rem,4vw,4rem);margin:0 0 18px}.section-title p,.split p{color:var(--muted);font-size:1.08rem}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 14px 44px rgba(16,36,44,.08)}.card img{height:260px;width:100%;object-fit:cover}.card__body{padding:28px}.card h3{font-size:1.35rem;margin:0 0 10px}.card p{color:var(--muted);margin:0}.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}.split h2{font-size:clamp(2.1rem,4vw,4.7rem);margin:0 0 20px}.split figure{margin:0;position:relative}.split figure img{border-radius:var(--radius);box-shadow:var(--shadow)}.badge{position:absolute;right:24px;bottom:24px;background:rgba(255,253,249,.92);backdrop-filter:blur(12px);padding:18px 20px;border-radius:18px;font-weight:900;border:1px solid rgba(255,255,255,.55)}.process{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.step{padding:28px;border-radius:var(--radius);background:#fff;border:1px solid var(--line)}.step span{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--ink);color:#fff;font-weight:900}.step h3{margin:18px 0 8px}.step p{color:var(--muted);margin:0}.gallery{display:grid;grid-template-columns:1.2fr .8fr;gap:22px}.gallery img{border-radius:var(--radius);height:100%;object-fit:cover}.list{display:grid;gap:14px;margin:28px 0;padding:0;list-style:none}.list li{padding:16px 18px;background:#fff;border:1px solid var(--line);border-radius:16px;font-weight:700}.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px}.contact-box,.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 14px 44px rgba(16,36,44,.08);padding:34px}.form-grid{display:grid;gap:16px}.field label{display:block;font-weight:800;margin-bottom:7px}.field input,.field textarea,.field select{width:100%;border:1px solid var(--line);border-radius:16px;padding:15px 16px;font:inherit;background:#fff}.field textarea{min-height:150px;resize:vertical}.notice{padding:14px 16px;border-radius:14px;margin-bottom:18px}.notice.ok{background:#eaf7ee;color:#17552b}.notice.error{background:#fff0f0;color:#7d1e1e}.cta-band{background:linear-gradient(135deg,var(--ink),#203943);color:#fff;padding:58px 0}.cta-band__grid{display:flex;align-items:center;justify-content:space-between;gap:24px}.cta-band h2{font-size:clamp(2rem,3.5vw,3.5rem);margin:0}.site-footer{background:#07151a;color:rgba(255,255,255,.72);padding:70px 0 24px}.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px}.footer-logo{width:78px;margin-bottom:18px;filter:brightness(1.2)}.site-footer h3{color:#fff}.site-footer a{color:rgba(255,255,255,.78);text-decoration:none}.site-footer a:hover{color:var(--gold2)}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:42px;padding-top:22px;font-size:.9rem}.legal{max-width:860px}.legal h1{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,5vw,5rem)}@media(max-width:920px){.nav-phone{display:none}.menu-toggle{display:inline-flex;margin-left:auto;background:var(--ink);color:#fff;border:0;border-radius:999px;padding:10px 15px;font-weight:900}.site-nav{position:absolute;left:20px;right:20px;top:76px;display:none;flex-direction:column;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow)}.site-nav.open{display:flex}.hero{min-height:720px}.hero__stats,.cards,.process,.split,.gallery,.contact-grid,.footer-grid{grid-template-columns:1fr}.cta-band__grid{display:block}.cta-band .btn{margin-top:24px}}@media(max-width:540px){.container{width:min(100% - 28px,1180px)}.nav-wrap{height:76px}.brand small{display:none}.hero__content{padding-top:120px}.hero__stats div{padding:18px}.section{padding:76px 0}.cards{gap:16px}.card img{height:220px}}

/* Premium logo handling */
.brand img{width:52px;height:46px;object-fit:contain;filter:drop-shadow(0 8px 18px rgba(16,36,44,.14))}.brand strong{line-height:1}.footer-brand-block{max-width:330px}.footer-brand{display:flex;align-items:center;gap:16px;text-decoration:none;margin-bottom:22px}.footer-brand__mark{display:grid;place-items:center;width:84px;height:76px;border-radius:22px;background:linear-gradient(145deg,rgba(255,255,255,.10),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 48px rgba(0,0,0,.22)}.footer-brand__mark img{width:58px;height:auto;object-fit:contain;filter:drop-shadow(0 10px 18px rgba(0,0,0,.35))}.footer-brand__text strong{display:block;color:#fff;font-size:1.35rem;letter-spacing:.12em;line-height:1}.footer-brand__text small{display:block;margin-top:7px;color:rgba(255,255,255,.62);font-size:.86rem;line-height:1.35}.footer-logo{display:none}@media(max-width:540px){.footer-brand{align-items:flex-start}.footer-brand__mark{width:72px;height:68px}.footer-brand__mark img{width:50px}.footer-brand__text strong{font-size:1.2rem}}

/* v16: use the 3D MPJ logo consistently across the public website */
.brand-3d{gap:0;min-width:118px}.brand-3d img{width:112px;height:76px;object-fit:contain;filter:drop-shadow(0 10px 22px rgba(16,36,44,.16))}.footer-brand-3d{display:inline-flex;margin-bottom:22px}.footer-brand-3d img{width:170px;height:auto;object-fit:contain;filter:drop-shadow(0 16px 26px rgba(0,0,0,.45))}.footer-brand__mark,.footer-brand__text{display:none}@media(max-width:540px){.brand-3d img{width:92px;height:64px}.footer-brand-3d img{width:150px}}

/* v17: tighter inner-page spacing for Leistungen, Projekte and Kontakt */
.page-intro{padding:72px 0 76px}
.page-intro .section-title{margin-bottom:0}
.page-intro .section-title h1{font-size:clamp(2.2rem,3.3vw,3.4rem);max-width:820px;margin-inline:auto}
.page-intro .section-title p:not(.eyebrow){max-width:760px;margin:20px auto 0}
.section-after-intro{padding-top:70px}
@media(max-width:920px){.page-intro{padding:54px 0 58px}.section-after-intro{padding-top:54px}}
@media(max-width:540px){.page-intro{padding:42px 0 46px}.page-intro .section-title h1{font-size:2rem}.section-after-intro{padding-top:42px}}

/* v18: photographic intro backgrounds for Leistungen and Projekte */
.page-intro--image{position:relative;overflow:hidden;color:#fff;background:#10242c;padding:96px 0 98px}
.page-intro--image:before{content:"";position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.03);filter:saturate(.95) contrast(1.02)}
.page-intro--image:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,21,26,.82),rgba(7,21,26,.54)),linear-gradient(0deg,rgba(7,21,26,.20),rgba(7,21,26,.20))}
.page-intro--image .container{position:relative;z-index:2}.page-intro--image .section-title p:not(.eyebrow){color:rgba(255,255,255,.84)}.page-intro--image .section-title h1{color:#fff;text-shadow:0 14px 40px rgba(0,0,0,.26)}.page-intro--leistungen:before{background-image:url('../img/tlo-leistungen.png')}.page-intro--projekte:before{background-image:url('../img/tlo-projekte.png')}
.gallery>img{min-height:560px;box-shadow:var(--shadow)}
@media(max-width:920px){.page-intro--image{padding:76px 0 78px}.gallery>img{min-height:360px}}
@media(max-width:540px){.page-intro--image{padding:58px 0 62px}.gallery>img{min-height:280px}}
