/* ============================================================
   IMKERVEREIN MALCHIN · Design v2.0
   Eigenständige Identität: Natur, Wiese, Vereinsleben.
   Bewusst getrennt vom Honeykeeper-Dark/Gold-Look der Imkerei.

   Palette:  Waldgrün #166534 / Tannengrün #14532d
             Rapsgelb #f4c430 / Creme #fdfaf0
   Schrift:  Lora (Überschriften) + Inter (Text)
             → werden in includes/header.php geladen
   Alle Klassennamen der v1 bleiben erhalten – kein PHP-Eingriff nötig.
   ============================================================ */

:root{
  --green:#166534;
  --green2:#14532d;
  --green-soft:#eaf6ee;
  --yellow:#f4c430;
  --yellow-soft:#fff7d6;
  --cream:#fdfaf0;
  --text:#1d241f;
  --muted:#5f6d64;
  --line:#e2ece5;
  --card:#fff;
  --radius:18px;
  --shadow:0 14px 38px rgba(0,43,17,.08);
  --shadow-soft:0 8px 22px rgba(0,43,17,.06);
  --font-display:"Lora",Georgia,"Times New Roman",serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:#f7faf8;
  line-height:1.6;
}
a{color:inherit;text-decoration:none}
img{max-width:100%}

h1,h2,h3,.invoice-title{
  font-family:var(--font-display);
  line-height:1.15;
}
h2{font-size:clamp(28px,3.4vw,38px);color:var(--green2);margin:0 0 18px}
h3{margin-top:0;color:var(--green2)}
.muted{color:var(--muted)}

/* ---------- Fokus & Bewegung (Barrierefreiheit) ---------- */
a:focus-visible,button:focus-visible,
.input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid var(--yellow);
  outline-offset:2px;
  border-radius:6px;
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{transition-duration:.01ms!important;animation-duration:.01ms!important}
}

/* ---------- Topbar ---------- */
.topbar{
  height:76px;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;
  position:sticky;top:0;z-index:50;
  border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.brand{
  display:flex;gap:11px;align-items:center;
  font-weight:800;color:var(--green2);line-height:1.05;
  font-family:var(--font-display);
}
.logo{
  width:44px;height:44px;border-radius:14px;
  background:var(--yellow-soft);
  border:2px solid var(--yellow);
  display:grid;place-items:center;font-size:24px;
}
.topbar nav{display:flex;gap:26px;align-items:center;font-size:15px;font-weight:500}
.topbar nav a{position:relative;padding:6px 0;transition:color .18s}
.topbar nav a:hover{color:var(--green)}
.topbar nav a:not(.btn)::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;
  background:var(--yellow);transition:right .22s ease;
}
.topbar nav a:not(.btn):hover::after{right:0}

/* ---------- Buttons ---------- */
.btn{
  background:var(--green);color:#fff!important;
  border:0;border-radius:12px;padding:13px 20px;
  font-weight:700;font-family:var(--font-body);font-size:15px;
  display:inline-block;cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
  box-shadow:0 6px 16px rgba(22,101,52,.22);
}
.btn:hover{background:var(--green2);transform:translateY(-2px);box-shadow:0 10px 22px rgba(22,101,52,.28)}
.btn:active{transform:translateY(0)}
.btn.yellow{background:var(--yellow);color:#1d241f!important;box-shadow:0 6px 16px rgba(244,196,48,.35)}
.btn.yellow:hover{background:#ffd34d}
.btn.ghost,.btn.secondary{background:var(--green-soft);color:var(--green)!important;box-shadow:none}
.btn.ghost:hover,.btn.secondary:hover{background:#dff0e5}
.btn.small{padding:10px 14px;font-size:14px}
.menuBtn{display:none;background:none;border:0;font-size:28px;cursor:pointer}

/* ---------- Hero ---------- */
.hero{
  min-height:540px;
  display:grid;grid-template-columns:1fr 1fr;align-items:center;
  padding:70px 8vw;
  background:linear-gradient(90deg,#1e3a14e0,#1c3d0e80),url('../img/hero_bees.svg');
  background-size:cover;background-position:center;
  color:#fff;
}
.hero h1{
  font-size:clamp(42px,6vw,72px);
  line-height:1.02;margin:12px 0;
  text-shadow:0 2px 18px rgba(0,0,0,.25);
}
.hero p{font-size:21px;max-width:520px;line-height:1.55}

.landing-hero{
  background:linear-gradient(90deg,#22320de6 0%,#2b3d0e9e 38%,#24430a30 72%),url('../img/landing-hero-bee.png');
  background-size:cover;background-position:center;color:#fff;
}
.landing-hero .eyebrow{
  font-size:13px;font-weight:800;letter-spacing:.14em;
  color:var(--yellow);
}

/* ---------- Sektionen & Karten ---------- */
.section{padding:74px 8vw}
.section.alt{background:var(--cream)}
.grid{display:grid;gap:24px}
.grid.cards{grid-template-columns:repeat(4,1fr)}
.grid.two{grid-template-columns:1fr 1fr}
.grid.three{grid-template-columns:repeat(3,1fr)}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px;
  box-shadow:var(--shadow);
  transition:transform .2s ease,box-shadow .2s ease;
}
.feature{text-align:center}
.feature:hover{transform:translateY(-5px);box-shadow:0 20px 46px rgba(0,43,17,.12)}
.feature .icon{
  font-size:30px;
  width:64px;height:64px;margin:0 auto 6px;
  display:grid;place-items:center;
  background:var(--green-soft);
  border-radius:50%;
}
.card img{width:100%;border-radius:14px;display:block;object-fit:cover}
.newsimg{height:155px;background:linear-gradient(135deg,#ffe98a,var(--green))}

.value-strip{background:#fff;padding-top:38px;padding-bottom:38px}
.value-strip .card{box-shadow:none;border:0}
.landing-about .grid.two{align-items:center}
.landing-photo{width:100%;aspect-ratio:16/7;object-fit:cover}

.news-section{background:linear-gradient(180deg,var(--cream),#fff6da)}
.news-card{padding:0;overflow:hidden;border-radius:var(--radius)}
.news-card:hover{transform:translateY(-5px);box-shadow:0 20px 46px rgba(0,43,17,.12)}
.news-card img{height:170px;border-radius:0;object-fit:cover}
.news-card-body{padding:20px}
.readmore{
  display:inline-block;margin-top:10px;
  color:var(--green);font-weight:800;font-size:14px;
  border-bottom:2px solid transparent;transition:border-color .18s;
}
.readmore:hover{border-color:var(--yellow)}

/* ---------- Footer ---------- */
.footer{
  background:linear-gradient(135deg,#0d3b1a,var(--green));
  color:#fff;padding:54px 8vw;
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;
}
.footer h4{font-family:var(--font-display);margin-top:0;color:var(--yellow)}
.footer a{display:block;margin:8px 0;opacity:.92;transition:opacity .15s}
.footer a:hover{opacity:1;text-decoration:underline;text-underline-offset:3px}
.footerbrand{color:#fff}

/* ---------- Login ---------- */
.loginwrap{
  min-height:calc(100vh - 76px);
  display:grid;place-items:center;padding:40px;
  background:linear-gradient(135deg,#f6fdf7,#fff6d4);
}
.form{display:grid;gap:14px}
.input,select,textarea{
  width:100%;padding:13px 14px;
  border:1px solid var(--line);border-radius:12px;
  background:#fff;font:inherit;
  transition:border-color .15s,box-shadow .15s;
}
.input:focus,select:focus,textarea:focus{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(22,101,52,.12);
  outline:none;
}

/* ---------- Mitglieder-/Vorstandsbereich (App-Layout) ---------- */
.app{display:grid;grid-template-columns:270px 1fr;min-height:100vh}
.sidebar{
  background:#fff;border-right:1px solid var(--line);
  padding:24px;display:flex;flex-direction:column;gap:20px;
}
.sideNav a{
  display:block;padding:13px 14px;border-radius:12px;margin:6px 0;
  transition:background .15s,color .15s;
}
.sideNav a.active,.sideNav a:hover{
  background:var(--green-soft);color:var(--green);font-weight:700;
}
.sideNav a.active{box-shadow:inset 3px 0 0 var(--green)}
.content{padding:34px}
.dashhero{
  background:linear-gradient(135deg,#fff,#fff3c4);
  border:1px solid var(--line);border-radius:22px;
  padding:30px;margin-bottom:24px;
}
.stats{grid-template-columns:repeat(4,1fr)}

/* ---------- Tabellen ---------- */
table{
  width:100%;border-collapse:collapse;
  background:#fff;border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-soft);
}
th,td{padding:14px;border-bottom:1px solid var(--line);text-align:left}
th{
  background:#f1f7f2;color:var(--green2);
  font-size:13px;text-transform:uppercase;letter-spacing:.05em;
}
tbody tr:hover{background:#fafdfb}
tbody tr:last-child td{border-bottom:0}
td input.input{padding:8px 10px}
.table-scroll{overflow:auto}

/* ---------- Badges & Hinweise ---------- */
.badge{
  padding:6px 11px;border-radius:99px;
  background:var(--green-soft);color:var(--green);
  font-weight:700;font-size:12px;
}
.badge.danger{background:#fdecec;color:#9b1c1c}
.notice{padding:14px 16px;border-radius:14px;margin:12px 0;border:1px solid var(--line)}
.notice.success{background:#ecf9ef;color:var(--green);border-color:#cdeed7}
.notice.error{background:#fdecec;color:#9b1c1c;border-color:#f5ccca}

/* ---------- Rechnungen / Druck ---------- */
.invoice-page{
  background:#fff;max-width:900px;margin:30px auto;padding:55px;
  box-shadow:0 20px 60px rgba(0,0,0,.12);border-radius:6px;
}
.invoice-title{font-size:30px}
.invoice-total{font-size:22px;font-weight:900}
.printbar{text-align:center;margin:20px}
.legal{max-width:920px;margin:auto;line-height:1.7}
.preview{border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.12)}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:900px){
  .topbar{padding:0 16px}
  .menuBtn{display:block}
  .topbar nav{
    display:none;position:absolute;top:76px;left:0;right:0;
    background:#fff;flex-direction:column;align-items:stretch;
    padding:20px;border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);
  }
  .menu-open .topbar nav{display:flex}
  .hero,.grid.two,.footer,.app{grid-template-columns:1fr}
  .grid.cards,.grid.three,.stats{grid-template-columns:1fr}
  .sidebar{border-right:0}
  .section{padding:42px 18px}
  .content{padding:18px}
  .invoice-page{padding:24px;margin:0}
  .hide-mobile{display:none}
  .landing-photo{aspect-ratio:16/10}
  .news-card img{height:190px}
}

@media(max-width:900px){
  .app{display:block;min-height:100vh}
  .sidebar{
    position:sticky;top:0;z-index:60;
    border-right:0;border-bottom:1px solid var(--line);
    padding:12px 14px;gap:10px;
    box-shadow:var(--shadow-soft);
  }
  .sidebar .brand{gap:8px}
  .sidebar .logo{width:36px;height:36px;border-radius:12px;font-size:20px}
  .sidebar>.card{display:none}
  .sideNav{
    display:flex;gap:8px;overflow-x:auto;
    padding:2px 0 8px;margin:0 -4px;scrollbar-width:thin;
  }
  .sideNav a{
    flex:0 0 auto;margin:0;padding:10px 12px;
    border:1px solid var(--line);background:#f7faf8;
    white-space:nowrap;font-size:14px;
  }
  .sideNav hr{display:none}
  .sidebar>div:last-child{margin-top:0!important;font-size:14px}
  .content{padding:18px 14px 28px}
  .content h1{font-size:30px;line-height:1.1;margin-top:6px}
  .content h2{font-size:24px}
  .dashhero{padding:20px;border-radius:18px}
  .card{border-radius:14px;padding:16px}
  .stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .content table{
    display:block;max-width:100%;overflow-x:auto;
    border-radius:12px;-webkit-overflow-scrolling:touch;
  }
  .content th,.content td{white-space:nowrap;padding:11px 12px}
  .content td .muted{white-space:normal}
  .content form[style*="display:flex"]{align-items:stretch!important}
  .content .btn{padding:11px 14px}
  .table-scroll{margin-left:-2px;margin-right:-2px}
  .grid{gap:16px}
}

@media(max-width:520px){
  .stats{grid-template-columns:1fr}
  .content{padding:14px 10px 24px}
  .sidebar{padding:10px}
  .sideNav a{font-size:13px;padding:9px 10px}
  .content h1{font-size:27px}
  .btn{width:auto}
  .content .grid.two,.content .grid.three{gap:12px}
}

@media(max-width:900px){
  .member-area .appTop,.board-area .appTop{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
  }
  .member-area .appTop .menuBtn,.board-area .appTop .menuBtn{
    display:block;border:1px solid var(--line);border-radius:12px;
    background:#f7faf8;color:var(--green2);
    width:42px;height:42px;font-size:24px;line-height:1;
  }
  .member-area .sideNav,.board-area .sideNav{
    display:none;overflow:visible;margin:0;padding:8px 0 4px;
    gap:8px;flex-direction:column;
  }
  .member-area.menu-open .sideNav,.board-area.menu-open .sideNav{display:flex}
  .member-area .sideNav a,.board-area .sideNav a{width:100%;white-space:normal}
  .member-area .sidebar>div:last-child,.board-area .sidebar>div:last-child{display:none}
  .member-area.menu-open .sidebar>div:last-child,
  .board-area.menu-open .sidebar>div:last-child{display:block;padding-top:4px}
}
@media(min-width:901px){.appTop{display:contents}}

/* ---------- Druck ---------- */
@media print{
  .topbar,.footer,.printbar,.sidebar{display:none!important}
  .app{display:block}
  .content{padding:0}
  .invoice-page{box-shadow:none;margin:0;max-width:none;border-radius:0}
  .no-print{display:none!important}
}
