:root{
  --bg:#fffaf1;
  --bg-soft:#f8f1df;
  --card:#ffffff;
  --text:#2f2a22;
  --muted:#6c6458;
  --accent:#d08b14;
  --accent-dark:#9c6500;
  --accent-soft:#f4e1a8;
  --border:#ead9b0;
  --warning:#fff2dc;
  --success:#eaf7e5;
  --danger:#ffe4df;
  --shadow:0 10px 30px rgba(80, 60, 20, 0.08);
  --radius:22px;
}

*{box-sizing:border-box}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
}

a{
  color:var(--accent-dark);
}

.wrap{
  max-width:1180px;
  margin:0 auto;
  padding:0 24px;
}

.site-header{
  position:sticky;
  top:0;
  z-index:30;
  background:rgba(255,250,241,0.94);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(234,217,176,0.9);
}

.header-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  min-height:78px;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.brand-mark{
  width:48px;
  height:48px;
  border-radius:16px;
  background:linear-gradient(135deg, #f0c552, #f8e6a8);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  box-shadow:var(--shadow);
}

.brand-title{
  font-weight:700;
  font-size:1.05rem;
}

.brand-subtitle{
  font-size:0.9rem;
  color:var(--muted);
}

.main-nav{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}

.main-nav a{
  text-decoration:none;
  color:var(--text);
  font-weight:600;
  font-size:0.95rem;
}

.main-nav a:hover{
  color:var(--accent-dark);
}

.main-nav .nav-cta{
  background:var(--accent);
  color:#fff;
  padding:11px 16px;
  border-radius:999px;
  box-shadow:var(--shadow);
}

.main-nav .nav-cta:hover{
  background:var(--accent-dark);
  color:#fff;
}

.hero{
  padding:86px 0 70px;
  background:
    radial-gradient(circle at top right, rgba(240,197,82,0.22), transparent 28%),
    radial-gradient(circle at left center, rgba(195,213,120,0.12), transparent 24%),
    linear-gradient(180deg, #fff6de 0%, #fffaf1 100%);
}

.hero-grid{
  display:grid;
  grid-template-columns:1.25fr 0.75fr;
  gap:32px;
  align-items:center;
}

.eyebrow{
  margin:0 0 10px;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  font-weight:700;
  color:var(--accent-dark);
}

h1,h2,h3{
  line-height:1.2;
  margin-top:0;
}

h1{
  font-size:clamp(2.3rem, 5vw, 4.4rem);
  margin-bottom:20px;
}

h2{
  font-size:clamp(1.7rem, 3vw, 2.5rem);
  margin-bottom:14px;
}

h3{
  font-size:1.2rem;
  margin-bottom:10px;
}

.lead{
  font-size:1.14rem;
  max-width:760px;
  color:var(--muted);
}

.hero-buttons{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:28px;
}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:13px 20px;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  text-decoration:none;
  font-weight:700;
  box-shadow:var(--shadow);
}

.button:hover{
  background:var(--accent-dark);
  color:#fff;
}

.button-light{
  background:#fff;
  color:var(--accent-dark);
  border:1px solid var(--border);
}

.button-light:hover{
  background:#f8f0dd;
}

.hero-card{
  background:rgba(255,255,255,0.82);
  border:1px solid rgba(234,217,176,0.85);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--shadow);
}

.hero-list{
  margin:18px 0 24px;
  padding-left:18px;
}

.hero-list li{
  margin-bottom:10px;
}

.section{
  padding:80px 0;
}

.section-alt{
  background:var(--bg-soft);
}

.section-cta{
  padding-top:30px;
  padding-bottom:30px;
}

.section-heading{
  max-width:760px;
  margin-bottom:34px;
}

.section-heading p:last-child{
  color:var(--muted);
}

.content-grid{
  display:grid;
  gap:24px;
}

.two-equal{
  grid-template-columns:repeat(2, minmax(0,1fr));
}

.split{
  grid-template-columns:1.2fr 0.8fr;
}

.card-grid{
  display:grid;
  gap:24px;
}

.card-grid.three{
  grid-template-columns:repeat(3, minmax(0,1fr));
}

.feature-card,
.info-card,
.map-placeholder-card,
.cta-box{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

.feature-card,
.info-card,
.map-placeholder-card{
  padding:28px;
}

.large-card{
  padding:34px;
}

.highlight-soft{
  background:linear-gradient(180deg, #fbf6e6 0%, #fff 100%);
}

.warning-soft{
  background:linear-gradient(180deg, #fff4df 0%, #fff 100%);
}

.card-tag{
  display:inline-block;
  margin-bottom:14px;
  font-size:.78rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--accent-dark);
  background:#f8e9bc;
  border-radius:999px;
  padding:7px 10px;
}

.strong-line{
  font-weight:700;
  color:var(--accent-dark);
}

.clean-list{
  padding-left:18px;
  margin:0;
}

.clean-list li{
  margin-bottom:10px;
}

.map-placeholder-card{
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.placeholder-title{
  font-weight:700;
  margin-bottom:14px;
}

.placeholder-box{
  border:2px dashed var(--border);
  border-radius:18px;
  min-height:220px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:var(--muted);
  background:#fffaf0;
  padding:20px;
}

.cta-box{
  padding:32px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  background:linear-gradient(135deg, #fff0c9 0%, #fff9eb 100%);
}

.site-footer{
  border-top:1px solid var(--border);
  background:#fffdf8;
}

.footer-inner{
  padding-top:24px;
  padding-bottom:24px;
}

.footer-inner p{
  margin:0;
  color:var(--muted);
}

.alert{
  border-radius:14px;
  padding:16px 18px;
  margin:24px 0;
  border:1px solid var(--border);
}

.alert.success{background:var(--success)}
.alert.error{background:var(--danger)}

.form label{
  display:block;
  margin:0 0 8px;
  font-weight:700;
}

.form input,
.form textarea,
.form select{
  width:100%;
  padding:12px 14px;
  border:1px solid #cfc4af;
  border-radius:12px;
  background:#fff;
  font:inherit;
}

.form button{
  margin-top:18px;
  border:0;
  background:var(--accent);
  color:#fff;
  padding:14px 20px;
  border-radius:12px;
  font-weight:700;
  cursor:pointer;
}

.form button:hover{
  background:var(--accent-dark);
}

.grid{
  display:grid;
  gap:24px;
}

.grid.two{
  grid-template-columns:repeat(2, minmax(0,1fr));
}

.hidden{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}

.status-badge{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  font-size:.9rem;
  font-weight:700;
  border:1px solid var(--border);
  background:#f3efe6;
}

.status-neu{background:#eef5ff;border-color:#bcd3ff;}
.status-in_pruefung{background:#fff4db;border-color:#f0cf7a;}
.status-bestaetigt{background:#ffe7e1;border-color:#efb0a1;}
.status-falscher_verdacht{background:#efefef;border-color:#cccccc;}
.status-entfernung_geplant{background:#f8ebff;border-color:#d7b8f3;}
.status-erledigt{background:#e8f7e8;border-color:#a8d5a8;}

@media (max-width: 980px){
  .header-inner,
  .hero-grid,
  .two-equal,
  .split,
  .card-grid.three,
  .grid.two,
  .cta-box{
    grid-template-columns:1fr;
    display:grid;
  }

  .header-inner{
    padding-top:14px;
    padding-bottom:14px;
  }

  .main-nav{
    gap:14px;
  }

  .cta-box{
    align-items:flex-start;
  }
}

@media (max-width: 700px){
  .site-header{
    position:static;
  }

  .main-nav{
    display:flex;
    flex-wrap:wrap;
    gap:10px 14px;
  }

  .brand{
    align-items:flex-start;
  }

  .hero{
    padding:60px 0 44px;
  }

  .feature-card,
  .info-card,
  .map-placeholder-card,
  .hero-card,
  .cta-box{
    padding:22px;
  }

  .wrap{
    padding:0 18px;
  }
}
/* =========================================================
   SPEZIALSTYLES HORNISSEN-SEITE
   ========================================================= */

.page-hornisse .hero{
  padding:72px 0 54px;
}

.page-hornisse .hero .lead{
  max-width:900px;
}

.page-hornisse main.wrap{
  padding-top:28px;
  padding-bottom:60px;
}

.page-hornisse .card{
  background:#ffffff;
  border:1px solid var(--border);
  border-radius:24px;
  padding:28px;
  box-shadow:var(--shadow);
  margin:24px 0;
}

.page-hornisse .card h2{
  margin-bottom:12px;
}

.page-hornisse .card h3{
  margin-top:22px;
  margin-bottom:10px;
}

.page-hornisse .warning{
  background:linear-gradient(180deg, #fff1d8 0%, #fff9ef 100%);
  border-color:#f0d39b;
}

.page-hornisse .grid.two{
  align-items:start;
}

.page-hornisse ul{
  padding-left:20px;
}

.page-hornisse li{
  margin-bottom:8px;
}

.page-hornisse .form{
  margin-top:18px;
}

.page-hornisse .form input,
.page-hornisse .form textarea,
.page-hornisse .form select{
  border:1px solid #d8ccb4;
  border-radius:14px;
  background:#fffdfa;
  padding:13px 14px;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.page-hornisse .form input:focus,
.page-hornisse .form textarea:focus,
.page-hornisse .form select:focus{
  outline:none;
  border-color:#d08b14;
  box-shadow:0 0 0 4px rgba(208,139,20,0.12);
  background:#fff;
}

.page-hornisse .form input[type="file"]{
  padding:10px 12px;
  background:#fff;
}

.page-hornisse .form button{
  border-radius:999px;
  padding:14px 22px;
  box-shadow:var(--shadow);
}

.page-hornisse .cf-turnstile{
  margin-top:18px;
}

.page-hornisse .alert{
  border-radius:18px;
  box-shadow:var(--shadow);
}

.page-hornisse .alert.success{
  background:linear-gradient(180deg, #edf9e9 0%, #f7fcf5 100%);
}

.page-hornisse .alert.error{
  background:linear-gradient(180deg, #ffe9e4 0%, #fff7f5 100%);
}

.page-hornisse a{
  text-decoration-thickness:1.5px;
  text-underline-offset:3px;
}


/* =========================================================
   SPEZIALSTYLES ADMIN-SEITE
   ========================================================= */

.page-admin .hero{
  padding:56px 0 42px;
}

.page-admin main.wrap{
  padding-top:24px;
  padding-bottom:50px;
}

.page-admin .card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:22px;
  padding:26px;
  box-shadow:var(--shadow);
  margin:22px 0;
}

.page-admin hr{
  border:none;
  border-top:1px solid #eadfca;
  margin:22px 0;
}

.page-admin h2 small{
  display:inline-block;
  margin-left:8px;
  font-weight:400;
  color:var(--muted);
}

.page-admin ul{
  padding-left:20px;
}

.page-admin li{
  margin-bottom:8px;
}

.page-admin .form{
  margin-top:14px;
}

.page-admin .form textarea{
  min-height:120px;
}

.page-admin .form button{
  border-radius:999px;
  padding:13px 20px;
}

.page-admin .alert{
  box-shadow:var(--shadow);
}


/* =========================================================
   GENERISCHE CARD-STYLES FÜR ALTE SEITEN
   ========================================================= */

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:22px;
  padding:24px;
  box-shadow:var(--shadow);
}

.warning{
  background:linear-gradient(180deg, #fff1d8 0%, #fff9ef 100%);
  border-color:#f0d39b;
}