/* ============================================================
   Maß Überdachung — Inner-page components (extends styles.css)
   ============================================================ */

/* Shorter hero for inner pages */
.hero--page{min-height:440px}
.hero--page .hero__content{padding-top:70px;padding-bottom:70px;max-width:720px}
.hero--page .hero__title{font-size:clamp(2.2rem,4.6vw,3.4rem)}

.breadcrumb{display:flex;gap:8px;font-size:.82rem;color:rgba(255,255,255,.75);margin-bottom:18px;letter-spacing:.04em}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{opacity:.5}

/* Active nav state */
.nav a[aria-current="page"]{color:var(--accent)}
.nav a[aria-current="page"]::after{width:100%}

/* Prose / intro */
.prose{max-width:760px}
.prose p{color:var(--muted);font-size:1.12rem;margin-bottom:18px}
.prose p:last-child{margin-bottom:0}

/* Option blocks (materials, variants) */
.opts{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.opt{border:1px solid var(--line);border-radius:var(--radius);padding:32px;background:#fff}
.opt h3{margin-bottom:14px;font-size:1.3rem}
.opt__list{list-style:none;display:grid;gap:11px;margin-top:16px}
.opt__list li{position:relative;padding-left:30px;color:var(--ink);font-weight:500}
.opt__list li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;background:var(--accent);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'><path d='M5 12l4 4 10-10'/></svg>") center/12px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'><path d='M5 12l4 4 10-10'/></svg>") center/12px no-repeat;}

/* Spec table */
.spec{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.spec tr{border-bottom:1px solid var(--line)}
.spec tr:last-child{border-bottom:none}
.spec th,.spec td{text-align:left;padding:16px 22px;font-size:1rem}
.spec th{background:var(--soft);font-weight:700;width:38%}
.spec td{color:var(--muted)}

/* FAQ */
.faq{max-width:820px;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:22px 0;font-weight:700;font-size:1.1rem;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-weight:600;font-size:1.5rem;color:var(--accent);transition:.2s;flex-shrink:0}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 0 24px;color:var(--muted);max-width:680px}

/* Simple page intro band (legal / über uns) */
.pagehead{background:var(--soft);border-bottom:1px solid var(--line);padding:70px 0}
.pagehead .eyebrow{margin-bottom:12px}
.pagehead h1{font-size:clamp(2rem,4vw,2.9rem);font-weight:800;letter-spacing:-.02em}
.pagehead p{color:var(--muted);font-size:1.12rem;margin-top:14px;max-width:680px}

/* Legal / long-form text */
.longform{max-width:820px}
.longform h2{font-size:1.5rem;margin:36px 0 12px}
.longform h3{font-size:1.15rem;margin:24px 0 8px}
.longform p,.longform li{color:var(--muted);margin-bottom:12px}
.longform ul{padding-left:22px;margin-bottom:12px}
.longform a{color:var(--accent);font-weight:600}
.longform strong{color:var(--ink)}

/* Contact layout */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.contact__info{display:grid;gap:24px}
.infocard{display:flex;gap:16px;align-items:flex-start}
.infocard svg{width:26px;height:26px;color:var(--accent);flex-shrink:0;margin-top:2px}
.infocard strong{display:block;font-size:1.02rem;margin-bottom:2px}
.infocard span,.infocard a{color:var(--muted);font-size:.98rem}
.infocard a:hover{color:var(--accent)}

.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.form .field{margin-bottom:18px}
.form label{display:block;font-weight:600;font-size:.9rem;margin-bottom:7px}
.form input,.form textarea,.form select{
  width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  font-family:inherit;font-size:1rem;background:#fff;transition:.15s;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(74,141,201,.12)}
.form textarea{min-height:130px;resize:vertical}
.form .btn{width:100%;margin-top:4px}
.form__hint{font-size:.82rem;color:var(--muted);margin-top:14px;text-align:center}
.check-field{margin-bottom:18px}
.check-label{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:var(--muted);cursor:pointer;line-height:1.5}
.check-label input{margin-top:3px;width:16px;height:16px;flex-shrink:0;accent-color:var(--accent)}
.check-label a{color:var(--accent);font-weight:600}

/* ---------- Referenzen: filter + galerij ---------- */
.ref-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px}
.ref-btn{font-family:inherit;font-weight:600;font-size:.9rem;padding:9px 18px;border-radius:9999px;border:1.5px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;transition:.15s}
.ref-btn:hover{border-color:var(--accent);color:var(--accent)}
.ref-btn.is-active{background:var(--accent);border-color:var(--accent);color:#fff}
.refgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.refitem{position:relative;margin:0;border-radius:10px;overflow:hidden;aspect-ratio:4/3;background:var(--soft);cursor:pointer;outline:none}
.refitem img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.refitem::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(16,24,36,.6),rgba(16,24,36,0) 50%);opacity:0;transition:opacity .25s}
.refitem:hover img,.refitem:focus-visible img{transform:scale(1.06)}
.refitem:hover::after,.refitem:focus-visible::after{opacity:1}
.refitem:focus-visible{box-shadow:0 0 0 3px var(--accent)}
.refitem__cat{position:absolute;left:12px;bottom:11px;z-index:1;color:#fff;font-size:.78rem;font-weight:700;letter-spacing:.02em;opacity:0;transform:translateY(6px);transition:.25s}
.refitem:hover .refitem__cat,.refitem:focus-visible .refitem__cat{opacity:1;transform:none}
.refitem__zoom{position:absolute;top:10px;right:10px;z-index:1;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--ink);display:grid;place-items:center;opacity:0;transform:scale(.8);transition:.25s}
.refitem__zoom svg{width:17px;height:17px}
.refitem:hover .refitem__zoom,.refitem:focus-visible .refitem__zoom{opacity:1;transform:scale(1)}

/* Lightbox */
.lb{position:fixed;inset:0;z-index:1000;background:rgba(14,17,21,.94);display:flex;align-items:center;justify-content:center;padding:24px;animation:lb-in .2s ease}
.lb[hidden]{display:none}
@keyframes lb-in{from{opacity:0}to{opacity:1}}
.lb__fig{margin:0;display:flex;flex-direction:column;align-items:center;gap:14px}
.lb__img{max-width:92vw;max-height:80vh;width:auto;height:auto;border-radius:8px;box-shadow:0 24px 70px rgba(0,0,0,.55)}
.lb__cap{color:#e7e7e3;font-size:.95rem;text-align:center;max-width:680px;padding:0 12px}
.lb__close{position:absolute;top:18px;right:22px;width:46px;height:46px;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:1.9rem;line-height:1;border-radius:50%;cursor:pointer;transition:.15s}
.lb__close:hover{background:rgba(255,255,255,.24)}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:2rem;line-height:1;border-radius:50%;cursor:pointer;transition:.15s;display:grid;place-items:center}
.lb__nav:hover{background:rgba(255,255,255,.24)}
.lb__prev{left:20px}
.lb__next{right:20px}
.lb__count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:#cfcfca;font-size:.85rem;letter-spacing:.05em}

/* ---------- Referenzen: procesblok ---------- */
.proc{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.proc__step{margin:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.proc__media{aspect-ratio:4/3;overflow:hidden}
.proc__media img{width:100%;height:100%;object-fit:cover}
.proc__step figcaption{padding:24px;position:relative}
.proc__num{position:absolute;top:-22px;left:24px;width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.15rem;box-shadow:0 4px 12px rgba(0,0,0,.15)}
.proc__step h3{margin:10px 0 8px;color:var(--ink)}
.proc__step p{color:var(--muted);font-size:.96rem}

/* ---------- Montage-galerij ---------- */
.montgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.montgrid figure{margin:0;border-radius:10px;overflow:hidden;aspect-ratio:4/3;background:var(--soft)}
.montgrid img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.montgrid figure:hover img{transform:scale(1.05)}

/* ---------- Blog ---------- */
.post-meta{color:var(--muted);font-size:.95rem;margin-top:10px}
.post-wrap{max-width:820px;margin:0 auto}
.post-hero{margin:0 0 28px;border-radius:var(--radius);overflow:hidden}
.post-hero img{width:100%;height:auto;display:block}
.post-body p{font-size:1.08rem;line-height:1.75;color:var(--ink)}
.post-body .lead{font-size:1.2rem;line-height:1.7;color:var(--ink);font-weight:500;margin-bottom:8px}
.post-body a{color:var(--accent-dark,#3a73a8);text-decoration:underline;text-underline-offset:2px}
.post-body a:hover{color:var(--accent,#4a8dc9)}
.post-body h2{font-size:1.55rem;margin:34px 0 12px}
.post-body h3{font-size:1.2rem;margin:24px 0 8px}
.post-body ul,.post-body ol{padding-left:22px;margin-bottom:16px}
.post-body li{margin-bottom:8px}
.post-body img{border-radius:var(--radius);margin:20px 0}
.post-cta{margin-top:40px;background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:30px;text-align:center}
.post-cta h3{margin-bottom:10px}
.post-cta p{color:var(--muted);margin:0 auto 18px;max-width:520px}
.post-cta .btn{margin:4px}

@media(max-width:980px){
  .opts{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr;gap:40px}
  .refgrid{grid-template-columns:repeat(3,1fr)}
  .montgrid{grid-template-columns:repeat(2,1fr)}
  .proc{grid-template-columns:1fr;max-width:460px;margin:0 auto}
}
@media(max-width:560px){
  .refgrid{grid-template-columns:repeat(2,1fr);gap:9px}
  .montgrid{grid-template-columns:repeat(2,1fr);gap:9px}
  .lb__nav{width:44px;height:44px;font-size:1.6rem}
  .lb__prev{left:10px}
  .lb__next{right:10px}
}

/* Standorte-Übersicht (lokale interne links) */
.section--alt{background:var(--soft)}
.standorte-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:10px;margin-top:6px}
.standorte-grid a{display:block;padding:11px 14px;background:#fff;border:1px solid var(--line);border-radius:9px;font-weight:600;font-size:.92rem;color:var(--ink);transition:.15s}
.standorte-grid a:hover{border-color:var(--accent);color:var(--accent-dark,#3a73a8)}
