/* SHARED BASE CSS for dachwartung-hamburg.de subpages */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'DM Sans',sans-serif;color:#1A1A1A;background:#fff;line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
:root{
  --navy:#0C2340;--navy-mid:#1B3A5C;--navy-light:#E8EFF7;
  --orange:#D97B2A;--orange-l:#FFF3E6;
  --white:#fff;--off-white:#F7F7F5;
  --gray-100:#F2F2F0;--gray-200:#E4E4E0;--gray-400:#A0A0A0;
  --gray-600:#666660;--gray-800:#333330;--text:#1A1A1A;
  --radius:6px;
  --shadow-sm:0 2px 8px rgba(0,0,0,.07);
  --shadow-md:0 6px 24px rgba(0,0,0,.10);
  --shadow-lg:0 16px 48px rgba(0,0,0,.14);
  --t:.25s ease;
}
.container{max-width:1200px;margin:0 auto;padding:0 32px}
.btn-primary{display:inline-block;background:var(--orange);color:white;padding:14px 28px;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;border:none;transition:background var(--t),box-shadow var(--t),transform var(--t);box-shadow:0 4px 16px rgba(217,123,42,.35);letter-spacing:.2px}
.btn-primary:hover{background:#C0691A;box-shadow:0 6px 24px rgba(217,123,42,.45);transform:translateY(-1px)}
.btn-secondary{display:inline-block;background:transparent;color:var(--navy);padding:14px 28px;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;border:2px solid var(--navy);transition:all var(--t)}
.btn-secondary:hover{background:var(--navy);color:white}
.section-label{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--orange);margin-bottom:12px;display:block}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(28px,3.5vw,44px);color:var(--navy);line-height:1.15;margin-bottom:16px}
.icon-box{width:52px;height:52px;background:var(--orange-l);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.icon-box svg{width:26px;height:26px;stroke:var(--orange);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
/* NAV */
.nav-wrapper{position:sticky;top:0;z-index:500;background:var(--navy);box-shadow:0 2px 20px rgba(0,0,0,.25)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:700;color:white;letter-spacing:.5px;line-height:1}
.nav-logo span{color:var(--orange)}
.nav-logo small{display:block;font-size:10px;font-weight:400;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:2px;font-family:'DM Sans',sans-serif}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{color:rgba(255,255,255,.75);font-size:14px;font-weight:500;padding:8px 14px;border-radius:4px;transition:color var(--t),background var(--t)}
.nav-links a:hover,.nav-links a.active{color:white;background:rgba(255,255,255,.08)}
.nav-cta{background:var(--orange);color:white!important;padding:10px 20px!important;border-radius:var(--radius)!important;font-weight:600!important}
.nav-cta:hover{background:#C0691A!important}
.nav-phone{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.7);font-size:14px;font-weight:500;margin-right:8px}
.nav-phone svg{width:15px;height:15px;stroke:var(--orange);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
/* FOOTER */
footer{background:var(--navy);color:rgba(255,255,255,.6)}
.footer-main{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding:64px 0 48px}
.footer-logo{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:700;color:white;margin-bottom:12px;letter-spacing:.5px}
.footer-logo span{color:var(--orange)}
.footer-brand p{font-size:14px;line-height:1.7;max-width:280px}
.footer-contact{margin-top:20px;display:flex;flex-direction:column;gap:6px}
.footer-contact a{display:flex;align-items:center;gap:8px;font-size:14px;color:rgba(255,255,255,.8);transition:color var(--t)}
.footer-contact a:hover{color:white}
.footer-contact svg{width:14px;height:14px;stroke:var(--orange);fill:none;stroke-width:2;flex-shrink:0}
.footer-col h4{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col ul a{font-size:14px;color:rgba(255,255,255,.6);transition:color var(--t);display:flex;align-items:center;gap:6px}
.footer-col ul a:hover{color:white}
.footer-col ul svg{width:12px;height:12px;stroke:var(--orange);fill:none;stroke-width:2;flex-shrink:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0;display:flex;align-items:center;justify-content:space-between;font-size:13px}
.footer-bottom a{color:rgba(255,255,255,.5);transition:color var(--t)}
.footer-bottom a:hover{color:white}
.footer-legal{display:flex;gap:24px}
/* BREADCRUMB */
.breadcrumb{background:var(--off-white);border-bottom:1px solid var(--gray-200);padding:12px 0}
.breadcrumb ol{list-style:none;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-400)}
.breadcrumb li a{color:var(--gray-600);transition:color var(--t)}
.breadcrumb li a:hover{color:var(--orange)}
.breadcrumb li:not(:last-child)::after{content:'›';margin-left:8px}
.breadcrumb li:last-child{color:var(--navy);font-weight:500}
/* HERO LEISTUNG */
.hero-leistung{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 60%,#0F2D52 100%);padding:80px 0 70px;position:relative;overflow:hidden}
.hero-leistung::before{content:'';position:absolute;top:-160px;right:-160px;width:600px;height:600px;background:radial-gradient(circle,rgba(217,123,42,.12) 0%,transparent 65%);border-radius:50%;pointer-events:none}
.hero-leistung .inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.hero-leistung h1{font-family:'Playfair Display',serif;font-size:clamp(32px,4vw,52px);color:white;line-height:1.12;margin-bottom:18px;font-weight:700}
.hero-leistung h1 em{color:var(--orange);font-style:normal}
.hero-leistung p{color:rgba(255,255,255,.7);font-size:17px;line-height:1.75;margin-bottom:32px;max-width:460px}
.hero-leistung .hero-btns{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.hero-tel{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.85);font-size:15px;font-weight:500}
.hero-tel svg{width:16px;height:16px;stroke:var(--orange);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.hero-leistung .info-box{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:28px;display:flex;flex-direction:column;gap:16px}
.info-row{display:flex;align-items:flex-start;gap:14px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.info-row:last-child{border-bottom:none;padding-bottom:0}
.info-row svg{width:20px;height:20px;stroke:var(--orange);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:2px}
.info-row strong{display:block;color:white;font-size:14px;margin-bottom:2px}
.info-row span{color:rgba(255,255,255,.6);font-size:13.5px;line-height:1.5}
/* CONTENT SECTIONS */
.content-section{padding:80px 0}
.content-section.bg-off{background:var(--off-white)}
.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.check-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-top:24px}
.check-list li{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--gray-800);line-height:1.5}
.check-list li svg{width:18px;height:18px;stroke:var(--orange);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:2px}
.price-box{background:var(--navy);border-radius:14px;padding:32px;color:white}
.price-box h3{font-family:'Playfair Display',serif;font-size:22px;margin-bottom:6px;color:white}
.price-box .sub{color:rgba(255,255,255,.55);font-size:14px;margin-bottom:24px}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:15px}
.price-row:last-of-type{border-bottom:none}
.price-row .label{color:rgba(255,255,255,.75)}
.price-row .val{font-weight:700;color:var(--orange);font-size:16px}
.price-note{font-size:12px;color:rgba(255,255,255,.4);margin-top:16px;line-height:1.6}
/* FAQ */
.faq-section{padding:80px 0;background:var(--off-white)}
.faq-inner-l{display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:start}
.faq-list{display:flex;flex-direction:column;gap:2px}
.faq-item{background:white;border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);transition:box-shadow var(--t)}
.faq-item:hover{box-shadow:var(--shadow-sm)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;cursor:pointer;font-weight:600;font-size:14.5px;color:var(--navy);user-select:none}
.faq-q svg{width:17px;height:17px;stroke:var(--orange);fill:none;stroke-width:2.5;flex-shrink:0;transition:transform .3s}
.faq-item.open .faq-q svg{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;padding:0 18px;font-size:14.5px;color:var(--gray-600);line-height:1.7}
.faq-item.open .faq-a{max-height:400px;padding:0 18px 16px}
/* CTA BAND */
.cta-band{background:var(--navy);padding:72px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:-100px;left:50%;transform:translateX(-50%);width:600px;height:400px;background:radial-gradient(circle,rgba(217,123,42,.1) 0%,transparent 65%);border-radius:50%}
.cta-band h2{font-family:'Playfair Display',serif;font-size:clamp(26px,3.5vw,40px);color:white;margin-bottom:14px;position:relative}
.cta-band p{color:rgba(255,255,255,.65);font-size:17px;max-width:520px;margin:0 auto 36px;line-height:1.7;position:relative}
.cta-band .actions{display:flex;justify-content:center;align-items:center;gap:20px;flex-wrap:wrap;position:relative}
.cta-band .tel{color:rgba(255,255,255,.8);font-size:16px;font-weight:500;display:flex;align-items:center;gap:8px}
.cta-band .tel svg{width:16px;height:16px;stroke:var(--orange);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
/* CONTACT MINI */
.contact-mini{padding:80px 0;background:white}
.contact-mini-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.form-wrapper{background:var(--off-white);border-radius:16px;padding:36px;border:1px solid var(--gray-200)}
.form-title{font-family:'Playfair Display',serif;font-size:22px;color:var(--navy);margin-bottom:6px}
.form-subtitle{font-size:14px;color:var(--gray-600);margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--gray-800);margin-bottom:6px;letter-spacing:.2px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:white;border:1.5px solid var(--gray-200);border-radius:var(--radius);padding:11px 14px;font-size:14.5px;font-family:'DM Sans',sans-serif;color:var(--text);transition:border-color var(--t),box-shadow var(--t);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(217,123,42,.15)}
.form-group textarea{resize:vertical;min-height:100px}
.ohnohoney{opacity:0;position:absolute;top:0;left:0;height:0;width:0;z-index:-1}
.form-submit{width:100%;padding:15px;font-size:16px;margin-top:8px}
.form-note{font-size:12px;color:var(--gray-400);text-align:center;margin-top:12px;line-height:1.5}
.form-note a{color:var(--orange)}
/* RESPONSIVE */
@media(max-width:1024px){
  .hero-leistung .inner{grid-template-columns:1fr;gap:40px}
  .content-grid{grid-template-columns:1fr;gap:40px}
  .faq-inner-l{grid-template-columns:1fr;gap:32px}
  .contact-mini-inner{grid-template-columns:1fr;gap:40px}
  .footer-main{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:768px){
  .container{padding:0 20px}
  .nav-links,.nav-phone{display:none}
  .nav-inner{height:60px}
  .footer-main{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .form-row{grid-template-columns:1fr}
  .content-section{padding:56px 0}
}
@media(max-width:500px){
  .footer-main{grid-template-columns:1fr}
}
