/* Meyer Baumaschinen — Look-alike statische Site
 * Akzent-Grün vom Original-Joomla-Template übernommen.
 */
:root{
  --mb-green:#659f13;
  --mb-green-dark:#4f7f0c;
  --mb-text:#222;
  --mb-text-muted:#666;
  --mb-bg:#f5f5f5;
  --mb-card:#fff;
  --mb-border:#e3e3e3;
  --mb-red:#cc3333;
  --mb-shadow:0 2px 8px rgba(0,0,0,0.08);
  --mb-radius:6px;
  --mb-container:1200px;
  --mb-gap:24px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font:15px/1.7 Verdana,Arial,sans-serif;
  color:var(--mb-text);
  background:var(--mb-bg);
  -webkit-font-smoothing:antialiased;
}

a{color:var(--mb-green);text-decoration:none}
a:hover{color:var(--mb-green-dark);text-decoration:underline}

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

.container{max-width:var(--mb-container);margin:0 auto;padding:0 20px}

/* ───── Header ───── */
header.site-header{
  background:#fff;
  border-bottom:3px solid var(--mb-green);
  box-shadow:var(--mb-shadow);
  position:sticky;top:0;z-index:50;
}
.site-header .bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 20px;gap:20px;
  max-width:var(--mb-container);margin:0 auto;
}
.site-header .logo img{height:48px;width:auto}
.site-header .phone{
  font-weight:700;font-size:16px;color:var(--mb-green);
  white-space:nowrap;
}
.site-header .phone a{color:inherit}

/* ───── Nav ───── */
nav.main-nav{background:var(--mb-green)}
nav.main-nav ul{
  list-style:none;margin:0;padding:0;
  display:flex;flex-wrap:wrap;
  max-width:var(--mb-container);margin-inline:auto;
}
nav.main-nav a{
  display:block;color:#fff;padding:12px 18px;
  text-decoration:none;font-weight:600;font-size:14px;
  border-right:1px solid rgba(255,255,255,0.15);
}
nav.main-nav a:hover,nav.main-nav a.active{
  background:var(--mb-green-dark);color:#fff;text-decoration:none;
}

/* ───── Hero ───── */
.hero{
  position:relative;
  background:#222 center 20% / cover no-repeat;
  min-height:480px;
  display:flex;align-items:center;
  color:#fff;
}
@media(max-width:768px){
  .hero{min-height:380px}
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(0,0,0,0.55) 0%,rgba(0,0,0,0.15) 60%,rgba(0,0,0,0) 100%);
}
.hero .container{position:relative;z-index:2;padding:60px 20px}
.hero h1{
  font-size:clamp(24px,3vw,38px);font-weight:700;
  margin:0 0 12px;line-height:1.2;
  text-shadow:0 2px 8px rgba(0,0,0,0.6);
  max-width:680px;
}
.hero p.lead{
  font-size:clamp(15px,1.6vw,18px);
  margin:0 0 24px;max-width:560px;
  text-shadow:0 1px 4px rgba(0,0,0,0.6);
}
.btn{
  display:inline-block;background:var(--mb-red);color:#fff;
  padding:12px 22px;border-radius:var(--mb-radius);
  font-weight:600;text-decoration:none;font-size:15px;
  transition:transform .15s, background .15s;
}
.btn:hover{background:#a82828;color:#fff;text-decoration:none;transform:translateY(-1px)}
.btn.btn-green{background:var(--mb-green)}
.btn.btn-green:hover{background:var(--mb-green-dark)}

/* ───── Main layout ───── */
main{padding:40px 0}
.page-title{
  font-size:28px;font-weight:700;
  color:var(--mb-green);
  margin:0 0 20px;
  border-bottom:2px solid var(--mb-border);
  padding-bottom:12px;
}
.content-row{
  display:grid;grid-template-columns:1fr 320px;gap:32px;
  align-items:start;
}
@media(max-width:880px){.content-row{grid-template-columns:1fr}}

.card{
  background:var(--mb-card);
  border-radius:var(--mb-radius);
  box-shadow:var(--mb-shadow);
  padding:24px;
  margin-bottom:var(--mb-gap);
}
.card h2,.card h3{
  color:var(--mb-green);
  margin:0 0 12px;font-weight:700;
}
.card h2{font-size:22px}
.card h3{font-size:18px}

/* Sidebar */
.sidebar .card{padding:20px}
.sidebar .card h3{font-size:16px;border-bottom:1px solid var(--mb-border);padding-bottom:8px}
.sidebar .openhours{font-size:14px;line-height:1.6}
.sidebar .openhours strong{color:var(--mb-text)}

/* ───── Categories grid ───── */
.categories{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:var(--mb-gap);
  margin-top:24px;
}
.cat{
  background:var(--mb-card);
  border-radius:var(--mb-radius);
  box-shadow:var(--mb-shadow);
  overflow:hidden;
  transition:transform .2s;
}
.cat:hover{transform:translateY(-4px)}
.cat img{width:100%;aspect-ratio:3/2;object-fit:cover}
.cat .body{padding:16px}
.cat .body h3{margin:0 0 6px;font-size:17px;color:var(--mb-green)}
.cat .body p{margin:0;color:var(--mb-text-muted);font-size:14px}

/* ───── Badges row (Fachbetrieb + Spenden) ───── */
.badges{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--mb-gap);
  margin-top:24px;
}
@media(max-width:600px){.badges{grid-template-columns:1fr}}
.badge-box{
  background:var(--mb-card);
  border-radius:var(--mb-radius);
  box-shadow:var(--mb-shadow);
  padding:20px;
  text-align:center;
}
.badge-box img{margin:0 auto 12px;max-height:200px;width:auto}
.badge-box h3{color:var(--mb-green);font-size:16px;margin:0 0 8px}
.badge-box p{margin:0;font-size:14px;color:var(--mb-text-muted)}

/* ───── Tables ───── */
table.list{
  width:100%;border-collapse:collapse;
  background:var(--mb-card);box-shadow:var(--mb-shadow);
  border-radius:var(--mb-radius);overflow:hidden;
  font-size:15px;
}
table.list th,table.list td{
  padding:11px 16px;
  border-bottom:1px solid var(--mb-border);
  text-align:left;vertical-align:top;
}
table.list thead{background:var(--mb-green);color:#fff}
table.list thead th{font-weight:600}
table.list tbody tr:nth-child(even){background:#fafafa}
table.list tbody tr:hover{background:#f0f7e6}
table.list td.num,table.list th.num{text-align:right;font-variant-numeric:tabular-nums}

/* ───── PDF download buttons ───── */
.dl-row{
  display:flex;flex-wrap:wrap;gap:16px;margin:24px 0;
}
.dl-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--mb-green);color:#fff;
  padding:14px 22px;border-radius:var(--mb-radius);
  text-decoration:none;font-weight:600;font-size:15px;
  transition:background .15s;
}
.dl-btn:hover{background:var(--mb-green-dark);color:#fff;text-decoration:none}
.dl-btn::before{content:"📄";font-size:20px}

/* ───── Footer ───── */
footer.site-footer{
  background:#2b2b2b;color:#aaa;
  padding:32px 0 20px;
  margin-top:40px;
  font-size:13px;line-height:1.7;
}
footer.site-footer a{color:#ccc}
footer.site-footer a:hover{color:#fff}
footer.site-footer .row{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:28px;
  padding-bottom:24px;border-bottom:1px solid #444;
}
footer.site-footer h4{
  color:#fff;margin:0 0 12px;font-size:14px;text-transform:uppercase;letter-spacing:0.5px;
}
footer.site-footer .copyright{padding-top:16px;text-align:center;font-size:12px;color:#888}

/* ───── Misc text content ───── */
.prose h2{color:var(--mb-green);font-size:20px;margin:28px 0 12px}
.prose h3{color:var(--mb-text);font-size:17px;margin:22px 0 8px}
.prose p{margin:0 0 12px}
.prose ul,.prose ol{margin:0 0 12px 24px;padding:0}
.prose li{margin-bottom:4px}
.prose strong{color:var(--mb-text)}
