:root{--mg-primary:#2E7D32;--mg-secondary:#424242;--mg-text:#212121;--mg-accent:#FF9800;--mg-primary-dark:#1B5E20;}
html{scroll-behavior:smooth}
body{font-family:Roboto,Arial,sans-serif;color:var(--mg-text);margin:0}
h1,h2,h3{font-family:Montserrat,Arial,sans-serif;font-weight:700;margin:0 0 10px}
h1{font-size:2.2rem}h2{font-size:1.6rem}
p{line-height:1.6;margin:0 0 14px}
ul{margin:0 0 14px 18px}
section{padding:40px 20px;max-width:1200px;margin:0 auto}
.container-narrow{max-width:880px;margin:0 auto}
.btn-primary{display:inline-block;background:var(--mg-primary);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;padding:12px 18px}
.btn-primary:hover{background:var(--mg-primary-dark);color:#fff}
a:focus,button:focus,.btn-primary:focus{outline:3px solid var(--mg-accent);outline-offset:2px}
::selection{background:var(--mg-accent);color:#000}

/* Header */
header{background:var(--mg-primary);position:sticky;top:0;z-index:50;box-shadow:0 2px 10px rgba(0,0,0,.06)}
header .nav{display:flex;justify-content:space-between;align-items:center;max-width:1140px;margin:0 auto;padding:12px 16px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:20px}
.brand img.logo{height:40px;width:auto}
nav.primary ul.site-menu{display:flex;gap:10px;list-style:none;margin:0;padding:0}
nav.primary a{color:#fff;text-decoration:none;padding:8px 10px;border-radius:8px}
nav.primary a:hover,nav.primary a:focus{background:rgba(255,255,255,.15);outline:none}
.menu-toggle{display:none;background:transparent;border:0;color:#fff;padding:8px;border-radius:8px}
.menu-toggle:focus{outline:3px solid var(--mg-accent);outline-offset:2px}
.call-btn{background:var(--mg-accent);color:#000;border-radius:8px;font-weight:600;padding:8px 14px;text-decoration:none}

/* Hero */
.hero{color:#fff;padding:90px 20px;min-height:340px;text-align:center;border-radius:12px;position:relative;background-position:center;background-size:cover;display:grid;place-items:center}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.15));border-radius:12px}
.hero > *{position:relative;z-index:1}
.hero h1{font-size:2.4rem;margin-bottom:8px}
.hero p{font-size:1.1rem;opacity:.95}

/* Tiles */
.kachel-grid{display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin-top:30px}
.kachel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.08);display:flex;flex-direction:column;transition:transform .15s ease, box-shadow .15s ease}
.kachel:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.kachel img{width:100%;aspect-ratio:4/3;height:auto;object-fit:cover;display:block}
.k-body{padding:14px;flex:1;display:flex;flex-direction:column}
.k-title{font-weight:700;margin-bottom:6px;font-size:1.05rem}
.k-desc{flex:1;color:#475569;margin-bottom:10px}

/* Maps */
iframe[src*="google.com/maps"]{border:0;border-radius:12px;width:100%;height:360px}

/* Footer */
footer{background:#f5f7f9;border-top:1px solid #e5e7eb;margin-top:40px}
.footer-wrap{max-width:1140px;margin:0 auto;padding:40px 16px 20px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:28px}
.footer h3{margin:0 0 10px;font-size:1.1rem}
.footer a{color:var(--mg-text);text-decoration:none}
.footer a:hover{color:var(--mg-primary);text-decoration:underline}
.footer .brand{color:var(--mg-text);font-size:18px}
.footer .brand img.logo{height:32px}
.footer-bottom{border-top:1px solid #e5e7eb;padding:12px 0;color:#6b7280;font-size:.95rem}

/* Responsive */
@media (max-width: 980px){
  .menu-toggle{display:inline-flex;align-items:center;gap:8px}
  nav.primary{display:none}
  nav.primary.open{display:block}
  nav.primary ul.site-menu{flex-direction:column;background:#1B5E20;margin-top:10px;padding:10px;border-radius:12px}
  .call-btn{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:2rem}
}
@media (max-width: 600px){
  .kachel-grid{grid-template-columns:1fr}
  .hero{min-height:280px;padding:70px 16px}
  .footer-grid{grid-template-columns:1fr}
}

/* Per-page hero mapping */
body.page-start   .hero{ background-image:url('/assets/hero_start.jpg'); }
body.page-rasen   .hero{ background-image:url('/assets/hero_rasenmaeher.jpg'); }
body.page-kette   .hero{ background-image:url('/assets/hero_saegekette.jpg'); }
body.page-uvv     .hero{ background-image:url('/assets/hero_uvv.jpg'); }
body.page-ego     .hero{ background-image:url('/assets/hero_ego.jpg'); }
body.page-granit  .hero{ background-image:url('/assets/hero_granit.jpg'); }
body.page-oregon  .hero{ background-image:url('/assets/hero_oregon.jpg'); }
body.page-robot   .hero{ background-image:url('/assets/hero_maehroboter.jpg'); }

img{max-width:100%;height:auto}