/*
Theme Name: C&H Abriss & Demontage
Theme URI: https://cundh-abriss.de/
Author: Kayan Elektro- und Informationstechnik
Author URI: https://kayanelektro.de/
Description: Industrielles, SEO-optimiertes WordPress-Theme für die C&H Abriss und Demontage GmbH. Schnelles, semantisches Markup mit schema.org-Daten, individuellen Service-Templates und der bestehenden Slug-Struktur (abbruch, demontage, dekontamination, entkernung, ueber-uns, jobs-karriere, kontakt, impressum).
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cundh
*/

:root{
  --bg:#0c0d0f;
  --bg-2:#15171b;
  --steel:#1c1f24;
  --line:rgba(245,243,238,.10);
  --text:#f4f3ee;
  --muted:#9b9a92;
  --concrete:#c7c4ba;
  --accent:#ffcd00;
  --accent-ink:#0c0d0f;
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--text);
  font-family:"IBM Plex Sans",-apple-system,BlinkMacSystemFont,sans-serif;
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.hazard{height:8px;background:repeating-linear-gradient(45deg,var(--accent) 0 22px,#0c0d0f 22px 44px)}
h1,h2,h3,h4{line-height:1.04;font-weight:400}
.display{font-family:"Anton",sans-serif;text-transform:uppercase;letter-spacing:.5px}
.label{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.22em;font-weight:600;font-size:.78rem;color:var(--accent)}
.btn{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-weight:600;background:var(--accent);color:var(--accent-ink);padding:13px 24px;font-size:.9rem;display:inline-block;transition:transform .15s,box-shadow .2s;border:none;cursor:pointer}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,205,0,.25)}
.btn.ghost{background:transparent;color:var(--text);border:1.5px solid var(--line)}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent);box-shadow:none}

/* Top bar */
.topbar{background:var(--steel);border-bottom:1px solid var(--line);font-size:.84rem}
.topbar .wrap{display:flex;gap:28px;align-items:center;justify-content:flex-end;height:42px;flex-wrap:wrap}
.topbar a,.topbar span{color:var(--muted);display:inline-flex;align-items:center;gap:8px}
.topbar a:hover{color:var(--accent)}
.topbar .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}

/* Header */
header.site{position:sticky;top:0;z-index:60;background:rgba(12,13,15,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo{font-family:"Anton",sans-serif;font-size:1.7rem;letter-spacing:1px;text-transform:uppercase;display:flex;flex-direction:column;line-height:1}
.logo .amp{color:var(--accent)}
.logo small{font-family:"Oswald",sans-serif;font-size:.6rem;letter-spacing:.26em;color:var(--muted);font-weight:500;margin-top:3px}
nav.main{display:flex;gap:22px;align-items:center}
nav.main > a,nav.main .has-sub > a{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.92rem;font-weight:500;color:var(--concrete);padding:0;height:76px;position:relative;display:inline-flex;align-items:center;gap:6px}
nav.main > a::after,nav.main .has-sub > a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--accent);transition:width .25s}
nav.main > a:hover,nav.main .has-sub:hover > a{color:var(--text)}
nav.main > a:hover::after,nav.main .has-sub:hover > a::after{width:100%}
.has-sub{position:relative}
.has-sub .caret{font-size:.7rem;color:var(--accent)}
.submenu{position:absolute;top:100%;left:-18px;min-width:280px;background:var(--bg-2);border:1px solid var(--line);padding:10px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s;box-shadow:0 24px 50px rgba(0,0,0,.5)}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:none}
.submenu a{display:block;padding:11px 14px;font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;color:var(--concrete);border-left:2px solid transparent;transition:.18s}
.submenu a:hover{background:var(--steel);color:var(--accent);border-left-color:var(--accent)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.menu-toggle span{width:26px;height:2px;background:var(--text);transition:.3s}

nav.mobile{display:none}
@media(max-width:1040px){
  nav.main,.topbar .desk{display:none}
  .menu-toggle{display:flex}
  nav.mobile{position:fixed;inset:76px 0 auto;background:var(--bg);border-bottom:1px solid var(--line);flex-direction:column;padding:14px 24px 26px;z-index:59;max-height:calc(100vh - 76px);overflow:auto}
  nav.mobile.open{display:flex}
  nav.mobile a{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.06em;padding:14px 0;border-bottom:1px solid var(--line);color:var(--concrete)}
  nav.mobile .sub-label{color:var(--accent);font-size:.72rem;letter-spacing:.18em;padding:18px 0 4px;border:none}
  nav.mobile .btn{margin-top:18px;text-align:center}
}

/* Hero */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,13,15,.55),rgba(12,13,15,.8) 55%,var(--bg)),var(--hero-img) center/cover no-repeat;transform:scale(1.04)}
.hero .wrap{position:relative;padding:120px 24px 100px}
.hero .eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.hero .eyebrow .rule{height:1px;width:54px;background:var(--accent)}
.hero h1{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:clamp(2.6rem,8vw,7rem);letter-spacing:1px;max-width:16ch}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero p.lead{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--concrete);max-width:52ch;margin-top:26px}
.hero .cta{display:flex;gap:16px;margin-top:38px;flex-wrap:wrap}
.hero .stats{display:flex;gap:46px;margin-top:64px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:34px}
.hero .stats .n{font-family:"Anton",sans-serif;font-size:2.6rem;line-height:1}
.hero .stats .n span{color:var(--accent)}
.hero .stats .t{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;color:var(--muted);margin-top:6px}

/* Page hero (subpages) */
.page-hero{position:relative;border-bottom:1px solid var(--line);overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,13,15,.62),rgba(12,13,15,.86)),var(--hero-img,none) center/cover no-repeat}
.page-hero .wrap{position:relative;padding:96px 24px 72px}
.breadcrumb{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.76rem;color:var(--muted);margin-bottom:18px;display:flex;gap:10px;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{color:var(--accent)}
.page-hero h1{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:clamp(2.4rem,6vw,4.6rem);letter-spacing:1px}
.page-hero p.lead{color:var(--concrete);max-width:60ch;margin-top:20px;font-size:1.1rem}

/* Sections */
section{padding:96px 0}
.sec-head{max-width:780px;margin-bottom:56px}
.sec-head h2{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:clamp(2.2rem,5vw,3.6rem);margin-top:14px}
.sec-head p{color:var(--muted);margin-top:18px;font-size:1.05rem}

/* Services grid */
.grid-services{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.svc{background:var(--bg-2);padding:42px 38px;position:relative;transition:background .3s;min-height:270px;display:flex;flex-direction:column}
.svc:hover{background:var(--steel)}
.svc .num{font-family:"Anton",sans-serif;font-size:1.1rem;color:var(--accent);opacity:.85}
.svc h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.55rem;margin:16px 0 6px;letter-spacing:.02em}
.svc .sub{font-family:"Oswald",sans-serif;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:500;margin-bottom:16px}
.svc p{color:var(--muted);font-size:.96rem}
.svc .arrow{margin-top:auto;padding-top:20px;color:var(--concrete);font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;display:inline-flex;align-items:center;gap:10px;transition:gap .2s,color .2s}
.svc:hover .arrow{gap:16px;color:var(--accent)}

/* Two-column content */
.two-col{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.two-col.rev .media{order:-1}
.two-col h2{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:clamp(1.9rem,4.5vw,3rem);margin:14px 0 24px}
.two-col p{color:var(--concrete);margin-bottom:18px}
.two-col .media img{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--steel);filter:grayscale(.15) contrast(1.05)}
.two-col .media.tall img{aspect-ratio:4/5}
.media-badge{position:relative}
.media-badge .badge{position:absolute;bottom:-22px;left:-22px;background:var(--accent);color:var(--accent-ink);padding:20px 24px}
.media-badge .badge .n{font-family:"Anton",sans-serif;font-size:2.4rem;line-height:1}
.media-badge .badge .t{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;font-weight:600}

/* Feature list */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.feat{background:var(--bg-2);padding:32px 28px}
.feat .ic{font-family:"Anton",sans-serif;font-size:1.6rem;color:var(--accent)}
.feat h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.18rem;margin:12px 0 10px;letter-spacing:.02em}
.feat p{color:var(--muted);font-size:.94rem}

/* Process steps */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.step{border:1px solid var(--line);padding:36px 30px;background:var(--bg-2);transition:transform .25s,border-color .25s}
.step:hover{transform:translateY(-4px);border-color:var(--accent)}
.step .num{font-family:"Anton",sans-serif;font-size:3.2rem;color:var(--steel);-webkit-text-stroke:1px var(--accent);line-height:1}
.step h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.25rem;margin:14px 0 12px}
.step p{color:var(--muted);font-size:.96rem}

/* Numbered process list (decontamination) */
.proc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.proc{background:var(--bg-2);padding:30px 30px;display:flex;gap:20px}
.proc .n{font-family:"Anton",sans-serif;font-size:2rem;color:var(--accent);line-height:1;min-width:46px}
.proc h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.12rem;margin-bottom:8px}
.proc p{color:var(--muted);font-size:.93rem}

/* Certs */
.certs{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.cert{background:var(--bg-2);padding:30px 28px;display:flex;flex-direction:column;gap:8px}
.cert h3{font-family:"Oswald",sans-serif;font-weight:600;font-size:1.1rem;text-transform:uppercase}
.cert p{color:var(--muted);font-size:.9rem}
.cert a{margin-top:6px;font-family:"Oswald",sans-serif;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--concrete)}
.cert a:hover{color:var(--accent)}

/* CTA band */
.cta-band{background:var(--accent);color:var(--accent-ink)}
.cta-band .wrap{padding:64px 24px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.cta-band h2{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:clamp(1.8rem,4vw,3rem);max-width:18ch}
.cta-band p{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.06em;font-weight:500;margin-top:8px}
.cta-band .btn{background:var(--accent-ink);color:var(--accent)}
.cta-band .btn:hover{box-shadow:0 10px 30px rgba(0,0,0,.3)}

/* FAQ */
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:none;color:var(--text);cursor:pointer;font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.02em;font-weight:500;font-size:1.12rem;padding:26px 0;display:flex;justify-content:space-between;gap:20px;align-items:center}
.faq-q .ic{color:var(--accent);font-family:"Anton",sans-serif;font-size:1.6rem;transition:transform .3s;flex-shrink:0}
.faq-q[aria-expanded="true"] .ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--muted)}
.faq-a div{padding-bottom:26px;max-width:74ch}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px}
.contact-info .row{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.contact-info .row .k{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--accent);min-width:130px;padding-top:3px}
.contact-info .row .v{font-size:1.05rem}
.contact-info .row .v a:hover{color:var(--accent)}
.cform{background:var(--bg-2);border:1px solid var(--line);padding:36px}
.cform label{display:block;font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.76rem;color:var(--muted);margin:18px 0 7px}
.cform label.first{margin-top:0}
.cform input,.cform textarea,.cform select{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--text);padding:13px 14px;font-family:inherit;font-size:.98rem;transition:border-color .2s}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--accent)}
.cform .btn{margin-top:26px;width:100%}
.cform .types{display:flex;gap:22px;margin-top:6px}
.cform .types label{display:flex;align-items:center;gap:8px;margin:0;cursor:pointer;color:var(--concrete)}
.cform .types input{width:auto}

/* Generic prose (impressum, fallback) */
.prose{max-width:820px}
.prose h2{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.5rem;margin:32px 0 14px}
.prose h3{font-family:"Oswald",sans-serif;font-weight:600;font-size:1.2rem;margin:24px 0 10px}
.prose p{color:var(--concrete);margin-bottom:16px}
.prose ul{color:var(--concrete);margin:0 0 16px 20px}
.prose li{margin-bottom:8px}
.prose a{color:var(--accent)}

/* Jobs */
.job-list{display:grid;gap:1px;background:var(--line);border:1px solid var(--line)}
.job{background:var(--bg-2);padding:30px 34px;display:flex;justify-content:space-between;gap:24px;align-items:center;flex-wrap:wrap;transition:background .25s}
.job:hover{background:var(--steel)}
.job h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.35rem}
.job .meta{color:var(--muted);font-family:"Oswald",sans-serif;letter-spacing:.08em;text-transform:uppercase;font-size:.8rem;margin-top:6px}
.perks{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.perk{background:var(--bg-2);padding:28px 24px}
.perk .ic{font-family:"Anton",sans-serif;color:var(--accent);font-size:1.4rem}
.perk h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.05rem;margin:10px 0 8px}
.perk p{color:var(--muted);font-size:.9rem}

/* Cross-links */
.cross{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cross a{border:1px solid var(--line);padding:28px;background:var(--bg-2);transition:border-color .25s,transform .25s;display:block}
.cross a:hover{border-color:var(--accent);transform:translateY(-4px)}
.cross .label{margin-bottom:10px}
.cross h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.2rem}
.cross p{color:var(--muted);font-size:.92rem;margin-top:8px}

/* Footer */
footer.site{background:var(--bg-2);border-top:1px solid var(--line);padding:64px 0 0}
.foot-grid{display:grid;grid-template-columns:1.5fr 2.6fr 1.2fr;gap:48px}
.foot-grid h4{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.84rem;color:var(--accent);margin-bottom:18px}
.foot-grid ul{list-style:none}
.foot-grid li{margin-bottom:11px;color:var(--muted)}
.foot-grid a:hover{color:var(--accent)}
.foot-svc-cols{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 28px}
.foot-svc-h{display:block;font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--concrete);font-weight:600;margin-bottom:10px;opacity:.75}
.foot-svc-group ul li{margin-bottom:8px}
.foot-svc-group a{font-size:.94rem}
.foot-bottom{border-top:1px solid var(--line);margin-top:54px;padding:24px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:.85rem}
.foot-logo{font-family:"Anton",sans-serif;font-size:1.5rem;text-transform:uppercase;margin-bottom:14px}
.foot-logo .amp{color:var(--accent)}

/* Reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Responsive */
@media(max-width:900px){
  .two-col,.contact-grid{grid-template-columns:1fr;gap:40px}
  .two-col .media{order:-1}
  .feat-grid{grid-template-columns:1fr}
  .grid-3,.proc-list,.cross,.perks{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:40px}
}
@media(max-width:620px){
  .grid-services{grid-template-columns:1fr}
  section{padding:68px 0}
  .hero .wrap{padding:88px 24px 70px}
  .perks{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr;gap:30px}
  .foot-grid > div:first-child{grid-column:auto}
  .foot-svc-cols{grid-template-columns:1fr}
  footer.site{padding-top:52px}
  .foot-bottom{flex-direction:column;gap:8px}
}

/* ---------------------------------------------------------
 * Contact Form 7 integration (matches .cform design)
 * ------------------------------------------------------- */
.cform .wpcf7-form p{margin:0}
.cform .wpcf7 label{display:block;font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.76rem;color:var(--muted);margin:18px 0 7px}
.cform .wpcf7 .first label,.cform .wpcf7 p:first-child label{margin-top:0}
.cform .wpcf7-form-control-wrap{display:block}
.cform input[type=submit],.cform .wpcf7-submit{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-weight:600;background:var(--accent);color:var(--accent-ink);padding:14px 24px;font-size:.9rem;border:none;cursor:pointer;width:100%;margin-top:26px;transition:transform .15s,box-shadow .2s}
.cform input[type=submit]:hover,.cform .wpcf7-submit:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,205,0,.25)}
.cform .wpcf7-radio .wpcf7-list-item,.cform .wpcf7-checkbox .wpcf7-list-item{display:inline-flex;align-items:center;gap:8px;margin:6px 22px 0 0;color:var(--concrete)}
.cform .wpcf7-radio .wpcf7-list-item-label,.cform .wpcf7-checkbox .wpcf7-list-item-label{font-family:inherit;text-transform:none;letter-spacing:0;font-size:.95rem;color:var(--concrete);margin:0}
.cform .wpcf7-list-item input{width:auto}
.cform .wpcf7-acceptance .wpcf7-list-item{display:flex;align-items:flex-start;gap:10px;margin:6px 0 0}
.cform .wpcf7-acceptance .wpcf7-list-item-label{font-size:.82rem;color:var(--muted)}
.cform .wpcf7-not-valid-tip{color:#ff7a7a;font-size:.78rem;margin-top:6px;font-family:"Oswald",sans-serif;letter-spacing:.04em}
.cform .wpcf7-form-control.wpcf7-not-valid{border-color:#ff7a7a}
.cform .wpcf7-response-output{margin:22px 0 0 !important;padding:14px 16px !important;border:1px solid var(--line) !important;font-size:.9rem;color:var(--concrete);background:var(--bg)}
.cform .wpcf7-mail-sent-ok{border-color:var(--accent) !important;color:var(--text)}
.cform .wpcf7-validation-errors,.cform .wpcf7-mail-sent-ng{border-color:#ff7a7a !important}
.cform .wpcf7-spinner{background:var(--accent)}

/* ---------------------------------------------------------
 * Referenzen (Projekt-Galerie) & Einsatzgebiete
 * ------------------------------------------------------- */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.proj{border:1px solid var(--line);background:var(--bg-2);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,border-color .25s}
.proj:hover{transform:translateY(-4px);border-color:var(--accent)}
.proj .thumb{aspect-ratio:4/3;overflow:hidden;background:var(--steel)}
.proj .thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(.18) contrast(1.05);transition:transform .5s}
.proj:hover .thumb img{transform:scale(1.06)}
.proj .body{padding:24px;display:flex;flex-direction:column;flex:1}
.proj .cat{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--accent);font-weight:600}
.proj h3{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;font-size:1.2rem;margin:10px 0 8px;letter-spacing:.01em}
.proj p{color:var(--muted);font-size:.92rem}
.proj .facts{display:flex;gap:22px;flex-wrap:wrap;margin-top:auto;padding-top:16px;border-top:1px solid var(--line)}
.proj .facts dt{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.66rem;color:var(--muted)}
.proj .facts dd{font-family:"Oswald",sans-serif;text-transform:uppercase;font-size:.82rem;color:var(--concrete);margin-top:2px}

.area-tags{display:flex;flex-wrap:wrap;gap:10px}
.area-tags span{border:1px solid var(--line);padding:9px 15px;font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;color:var(--concrete);transition:.2s}
.area-tags span:hover{border-color:var(--accent);color:var(--accent)}
.area-cols{display:grid;grid-template-columns:1fr 1fr;gap:40px}

@media(max-width:900px){
  .proj-grid{grid-template-columns:1fr}
  .area-cols{grid-template-columns:1fr;gap:30px}
}
@media(min-width:621px) and (max-width:900px){
  .proj-grid{grid-template-columns:repeat(2,1fr)}
}

/* ---------------------------------------------------------
 * Mega menu (grouped Leistungen dropdown)
 * ------------------------------------------------------- */
.has-mega{position:static}
.mega{position:absolute;left:0;right:0;top:100%;background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 24px 50px rgba(0,0,0,.5);opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s;z-index:70}
.has-mega:hover .mega{opacity:1;visibility:visible;transform:none}
.mega-inner{max-width:var(--maxw);margin:0 auto;padding:26px 24px;display:grid;grid-template-columns:repeat(4,1fr);gap:6px 28px}
.mega-col{display:flex;flex-direction:column}
.mega-h{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--accent);font-weight:600;padding:2px 12px 10px;margin-bottom:6px;border-bottom:1px solid var(--line)}
.mega-col a{display:block;padding:9px 12px;font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;color:var(--concrete);border-left:2px solid transparent;transition:.18s}
.mega-col a:hover{background:var(--steel);color:var(--accent);border-left-color:var(--accent)}
