/* =====================================================================
   ACKERSCHLAGKARTEI – Stylesheet
   Sachlich-landwirtschaftliche Farbwelt: Feldgrün, Erdton-Akzent.
   Mobile-first, hoher Kontrast für gute Lesbarkeit im Freien.
   Nur Systemschriften -> komplett offline-fähig, kein CDN.
   ===================================================================== */
:root{
  --gruen:        #2f6b3a;
  --gruen-dunkel: #234d2a;
  --gruen-hell:   #e7efe6;
  --erde:         #a8581f;
  --orange:       #e07020;
  --blau:         #1a6fa8;
  --bg:           #f4f5f2;
  --karte:        #ffffff;
  --text:         #1a1f1c;
  --text-grau:    #5a6560;
  --rand:         #d6dbd4;
  --rand-stark:   #b6bdb3;
  --rot:          #b3261e;
  --gelb:         #f4f0e2;
  --gelb-rand:    #e8d88a;
  --radius:       10px;
  --schatten:     0 1px 3px rgba(0,0,0,.10), 0 1px 2px rgba(0,0,0,.06);

  /* Kategorie-Farben */
  --k-boden:        #6b4f2a;
  --k-duengung:     #b07a12;
  --k-saat:         #2f6b3a;
  --k-pflanzschutz: #9a2b7c;
  --k-ernte:        #b3261e;
  --k-sonstiges:    #5a6560;
}

/* ===== Grundlayout ===== */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  background:var(--bg);color:var(--text);font-size:16px;line-height:1.45;
  -webkit-text-size-adjust:100%;padding-bottom:72px;
}
h1,h2,h3,h4{margin:0 0 .4em;line-height:1.2;}
a{color:var(--gruen);}
button{font-family:inherit;cursor:pointer;}

/* ===== Kopfzeile ===== */
header{
  position:sticky;top:0;z-index:30;background:var(--gruen-dunkel);
  color:#fff;padding:env(safe-area-inset-top,0) 14px 0;box-shadow:var(--schatten);
}
.kopf-inhalt{display:flex;align-items:center;gap:10px;height:56px;}
.kopf-titel{font-size:1.15rem;font-weight:700;letter-spacing:.2px;flex:1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.kopf-btn{
  background:rgba(255,255,255,.14);color:#fff;border:0;border-radius:8px;
  padding:9px 12px;font-size:.95rem;font-weight:600;display:inline-flex;
  align-items:center;gap:6px;min-height:42px;
}
.kopf-btn:active{background:rgba(255,255,255,.28);}

/* ===== Inhaltsbereich ===== */
main{max-width:960px;margin:0 auto;padding:16px 14px 24px;}
.seiten-titel{font-size:1.35rem;margin-bottom:14px;}
.muted{color:var(--text-grau);}
.klein{font-size:.85rem;}

/* ===== Werkzeugleiste (Suche/Filter) ===== */
.werkzeuge{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;}
.werkzeuge .feld{flex:1 1 160px;}

/* ===== Eingabefelder ===== */
label{display:block;font-weight:600;font-size:.92rem;margin-bottom:5px;}
label .pflicht{color:var(--rot);}
input,select,textarea{
  width:100%;font-family:inherit;font-size:1rem;color:var(--text);
  background:var(--karte);border:1.5px solid var(--rand-stark);
  border-radius:8px;padding:11px 12px;min-height:46px;
}
textarea{min-height:80px;resize:vertical;}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--gruen);box-shadow:0 0 0 3px rgba(47,107,58,.18);
}
input.invalid,select.invalid,textarea.invalid{
  border-color:var(--rot);box-shadow:0 0 0 3px rgba(179,38,30,.15);
}
.feld{margin-bottom:14px;}
.feld .fehler{color:var(--rot);font-size:.82rem;margin-top:4px;display:none;}
.feld.invalid .fehler{display:block;}
.feld-mit-einheit{display:flex;gap:8px;}
.feld-mit-einheit input{flex:2;}
.feld-mit-einheit select{flex:1;min-width:96px;}
.feld-reihe{display:flex;gap:12px;flex-wrap:wrap;}
.feld-reihe>.feld{flex:1 1 140px;}

/* ===== Schaltflächen ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--gruen);color:#fff;border:0;border-radius:9px;
  padding:13px 18px;font-size:1rem;font-weight:700;min-height:48px;
  text-decoration:none;
}
.btn:active{filter:brightness(.92);}
.btn.voll{width:100%;}
.btn.gross{font-size:1.2rem;padding:18px;min-height:62px;}
.btn-sekundaer,.btn-sek{background:var(--karte);color:var(--gruen);border:1.5px solid var(--rand-stark);}
.btn-sekundaer:active,.btn-sek:active{background:var(--gruen-hell);}
.btn-erde{background:var(--erde);}
.btn-orange{background:var(--orange);color:#fff;}
.btn-gefahr,.btn-rot{background:var(--karte);color:var(--rot);border:1.5px solid var(--rot);}
.btn-klein,.btn-sm{padding:7px 11px;font-size:.84rem;min-height:34px;}

/* ===== Schlag-Kacheln ===== */
.kachel-raster{display:grid;grid-template-columns:1fr;gap:12px;}
@media(min-width:560px){.kachel-raster{grid-template-columns:1fr 1fr;}}
@media(min-width:840px){.kachel-raster{grid-template-columns:1fr 1fr 1fr;}}
.kachel{
  background:var(--karte);border:1px solid var(--rand);border-radius:var(--radius);
  padding:0;box-shadow:var(--schatten);text-align:left;width:100%;
  display:block;cursor:pointer;overflow:hidden;
}
.kachel:active{border-color:var(--gruen);}
.kachel h3{font-size:1.1rem;}
.kachel-zeile{display:flex;justify-content:space-between;gap:10px;font-size:.9rem;
  color:var(--text-grau);margin-top:4px;}
.kachel-frucht{display:inline-block;background:var(--gruen-hell);color:var(--gruen-dunkel);
  font-weight:700;font-size:.82rem;padding:3px 9px;border-radius:20px;margin-top:8px;}
.kachel-farb-streifen{height:5px;width:100%;}
.kachel-body{padding:15px 16px;}
.kachel-schnellaktionen{display:flex;gap:6px;flex-wrap:wrap;padding:0 12px 12px;}
.kachel-schnellaktionen .btn-klein{flex:1 1 auto;padding:6px 8px;font-size:.8rem;
  border:1.5px solid var(--rand-stark);background:var(--karte);color:var(--gruen);border-radius:6px;}
.kachel-schnellaktionen .btn-klein:active{background:var(--gruen-hell);}
.schlaege-stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;}
.stat-pill{background:var(--gruen-hell);color:var(--gruen-dunkel);padding:6px 12px;
  border-radius:18px;font-size:.85rem;}
.stat-pill b{font-size:1rem;}

/* Sortier-Leiste */
.sort-leiste{display:flex;gap:6px;margin-bottom:12px;}
.sort-btn{background:var(--karte);border:1.5px solid var(--rand-stark);color:var(--text-grau);
  border-radius:20px;padding:6px 14px;font-size:.85rem;font-weight:600;}
.sort-btn.aktiv{background:var(--gruen);border-color:var(--gruen);color:#fff;}

/* ===== Detail-Kopf ===== */
.detail-kopf{
  background:var(--karte);border:1px solid var(--rand);border-radius:var(--radius);
  padding:16px;box-shadow:var(--schatten);margin-bottom:16px;
}
.kennzahlen{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px;}
@media(min-width:560px){.kennzahlen{grid-template-columns:repeat(3,1fr);}}
.kennzahlen .lab{display:block;font-size:.78rem;color:var(--text-grau);}
.kennzahlen b{font-size:.95rem;}

/* Koordinaten-Box im Schlag-Modal */
.koordinaten-box{background:var(--gelb);border:1px solid var(--gelb-rand);border-radius:8px;
  padding:10px 12px;margin-bottom:14px;}
.koordinaten-box h4{font-size:.9rem;margin-bottom:6px;color:var(--text-grau);}
.koordinaten-eingabe{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;}
.koordinaten-eingabe .feld{margin:0;flex:1 1 130px;}
.koord-standard{font-size:.78rem;color:var(--text-grau);margin-top:6px;}
.gps-btn{display:inline-flex;align-items:center;gap:5px;background:var(--blau);color:#fff;
  border:0;border-radius:8px;padding:9px 13px;font-size:.88rem;font-weight:700;min-height:42px;
  white-space:nowrap;}
.gps-btn:active{filter:brightness(.9);}

/* ===== Tabs ===== */
.tableiste{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;}
.tab{background:var(--karte);border:1px solid var(--rand-stark);color:var(--text-grau);
  border-radius:18px;padding:7px 14px;font-size:.88rem;font-weight:600;white-space:nowrap;}
.tab.aktiv{background:var(--gruen);border-color:var(--gruen);color:#fff;}

/* ===== Maßnahmen-Einträge ===== */
.eintrag{background:var(--karte);border:1px solid var(--rand);border-radius:var(--radius);
  padding:12px 14px;box-shadow:var(--schatten);margin-bottom:10px;border-left:5px solid;}
.eintrag-kopf{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px;}
.eintrag-datum{font-weight:700;}
.eintrag-aktion{font-weight:600;color:var(--text-grau);margin-left:6px;}
.badge{display:inline-block;color:#fff;font-weight:700;font-size:.75rem;padding:3px 9px;
  border-radius:20px;text-transform:uppercase;letter-spacing:.3px;}
.eintrag-detail{font-size:.92rem;margin-bottom:4px;}
.eintrag-detail .paar{display:inline-block;margin-right:14px;}
.eintrag-detail .paar span{color:var(--text-grau);}
.eintrag-fuss{display:flex;justify-content:space-between;font-size:.82rem;color:var(--text-grau);
  margin-top:6px;}
.eintrag-loeschen{background:none;border:0;color:var(--rot);font-size:.85rem;
  text-decoration:underline;padding:0;}

/* Wetter-Pille auf Eintrag */
.wetter-pill{display:inline-block;background:var(--gruen-hell);color:var(--gruen-dunkel);
  padding:2px 9px;border-radius:14px;font-size:.78rem;margin:4px 0;font-weight:600;}

/* Wetter-Box (groß) */
.wetter-box{background:var(--gruen-hell);border:1px solid var(--gruen);border-radius:8px;
  padding:10px 12px;margin-bottom:14px;}
.wetter-box h4{font-size:.88rem;margin-bottom:6px;color:var(--gruen-dunkel);}
.wetter-box.laden{background:var(--gelb);border-color:var(--gelb-rand);color:#7a4d00;}
.wetter-box.fehler{background:#fee;border-color:#fcc;color:#722;}
.wetter-reihe{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;font-size:.82rem;}
@media(min-width:480px){.wetter-reihe{grid-template-columns:repeat(3,1fr);}}
.wx-wert{display:flex;flex-direction:column;background:#fff;border-radius:6px;padding:5px 8px;}
.wx-wert b{font-size:.95rem;}
.wx-wert span{font-size:.72rem;color:var(--text-grau);}

/* Foto-Anhänge */
.foto-vorschau-mini{max-width:140px;max-height:100px;border-radius:6px;border:1px solid var(--rand);}
.foto-anhang-zeile{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.foto-del{background:none;border:0;color:var(--rot);font-size:1rem;cursor:pointer;}

/* ===== Fruchtfolge ===== */
.ff-zeile{display:flex;gap:14px;align-items:flex-start;border-bottom:1px solid var(--rand);
  padding:8px 0;}
.ff-jahr{font-weight:800;color:var(--gruen-dunkel);min-width:54px;}
.ff-frucht{font-weight:600;}

/* Timeline (Übersichts-Tab) */
.timeline{position:relative;padding-left:20px;}
.timeline::before{content:"";position:absolute;left:6px;top:0;bottom:0;width:2px;background:var(--rand);}
.tl-eintrag{position:relative;margin-bottom:10px;}
.tl-dot{position:absolute;left:-19px;top:14px;width:12px;height:12px;border-radius:50%;border:2px solid var(--karte);}

/* ===== Leerer Zustand ===== */
.leer{background:var(--karte);border:1px dashed var(--rand-stark);border-radius:var(--radius);
  padding:24px;text-align:center;color:var(--text-grau);}

/* ===== Modal ===== */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:50;
  display:flex;align-items:center;justify-content:center;padding:14px;}
.modal{background:var(--karte);border-radius:var(--radius);max-width:600px;width:100%;
  max-height:90vh;display:flex;flex-direction:column;overflow:hidden;}
.modal-kopf{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;
  border-bottom:1px solid var(--rand);}
.modal-kopf h2{font-size:1.05rem;}
.modal-x{background:none;border:0;font-size:1.5rem;color:var(--text-grau);padding:0 6px;}
.modal-koerper,.modal-body{padding:16px;overflow:auto;flex:1;}
.modal-fuss{padding:12px 16px;border-top:1px solid var(--rand);display:flex;
  gap:10px;justify-content:flex-end;flex-wrap:wrap;}

/* ===== Toast ===== */
.toast{position:fixed;left:50%;bottom:84px;transform:translateX(-50%);
  background:var(--text);color:#fff;padding:11px 18px;border-radius:24px;
  font-size:.92rem;opacity:0;pointer-events:none;transition:opacity .2s;z-index:60;
  max-width:90vw;text-align:center;}
.toast.an{opacity:1;}

/* ===== Untere Navigation ===== */
nav.unten{
  position:fixed;left:0;right:0;bottom:0;background:var(--karte);
  border-top:1px solid var(--rand);display:flex;
  padding-bottom:env(safe-area-inset-bottom,0);z-index:25;
}
nav.unten a{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:8px 0 7px;font-size:.7rem;color:var(--text-grau);text-decoration:none;
  font-weight:600;position:relative;
}
nav.unten a .ic{font-size:1.25rem;display:block;margin-bottom:2px;}
nav.unten a.aktiv{color:var(--gruen);}
.nav-badge{position:absolute;top:4px;right:18%;background:var(--rot);color:#fff;
  font-size:.65rem;font-weight:800;border-radius:10px;padding:1px 5px;display:none;}

/* ===== Login ===== */
.login-box{max-width:380px;margin:30px auto;background:var(--karte);
  border:1px solid var(--rand);border-radius:var(--radius);padding:24px;
  box-shadow:var(--schatten);}
.login-logo{text-align:center;font-size:3rem;margin-bottom:8px;}
.login-box h1{text-align:center;font-size:1.4rem;}
.login-box p.muted{text-align:center;}
.login-fehler{color:var(--rot);font-size:.88rem;margin-bottom:10px;min-height:1.2em;}

/* ===== Benutzerverwaltung ===== */
.user-zeile{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.rolle-badge{display:inline-block;background:var(--gruen-hell);color:var(--gruen-dunkel);
  font-weight:700;font-size:.78rem;padding:3px 9px;border-radius:18px;}
.user-tabelle{width:100%;border-collapse:collapse;}
.user-tabelle td{border-bottom:1px solid var(--rand);padding:9px 6px;font-size:.92rem;
  vertical-align:top;}
.user-tabelle td.akt{text-align:right;}
.mini-btn{background:var(--karte);border:1px solid var(--rand-stark);border-radius:6px;
  padding:5px 10px;font-size:.78rem;cursor:pointer;color:var(--text);margin-left:4px;}
.mini-btn.del{color:var(--rot);border-color:var(--rot);}
.mini-btn.pw{color:var(--gruen);border-color:var(--gruen);}

/* ===== Schnelleingabe Wizard ===== */
.schnell{max-width:520px;margin:0 auto;}
.schnell-wrap{max-width:680px;margin:0 auto;}
.schnell h2{font-size:1.4rem;}
.mitarbeiter-zeile{display:flex;justify-content:space-between;align-items:center;
  background:var(--gruen-hell);padding:10px 14px;border-radius:8px;margin-bottom:14px;}
.text-wechseln{background:none;border:0;color:var(--gruen);font-size:.85rem;
  text-decoration:underline;cursor:pointer;}

.wizard-fortschritt{display:flex;gap:6px;margin-bottom:18px;}
.wizard-schritt{flex:1;text-align:center;background:var(--karte);border:1px solid var(--rand);
  border-radius:8px;padding:8px 6px;font-size:.78rem;color:var(--text-grau);font-weight:600;}
.wizard-schritt.aktiv{background:var(--gruen);border-color:var(--gruen);color:#fff;}
.wizard-schritt.fertig{background:var(--gruen-hell);border-color:var(--gruen);color:var(--gruen-dunkel);}

.wizard-panel{display:none;}
.wizard-panel.aktiv{display:block;}
.wizard-nav{display:flex;gap:10px;justify-content:space-between;margin-top:14px;flex-wrap:wrap;}
.wizard-nav .btn{flex:1;}

.schlag-schnell-liste{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.schlag-schnell-item{display:flex;align-items:center;gap:10px;background:var(--karte);
  border:1.5px solid var(--rand);border-radius:10px;padding:10px 12px;cursor:pointer;
  text-align:left;width:100%;}
.schlag-schnell-item.sel{border-color:var(--gruen);background:var(--gruen-hell);}
.ssl-farb{width:8px;height:38px;border-radius:4px;}
.ssl-info{flex:1;}
.ssl-name{font-weight:700;}
.ssl-meta{font-size:.78rem;color:var(--text-grau);}
.ssl-frucht{background:var(--gruen-hell);color:var(--gruen-dunkel);font-size:.78rem;
  font-weight:700;padding:3px 9px;border-radius:14px;}

.kat-raster{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;}
@media(min-width:480px){.kat-raster{grid-template-columns:1fr 1fr 1fr;}}
.kat-kachel{background:var(--karte);border:1.5px solid var(--rand);border-radius:10px;
  padding:14px 10px;cursor:pointer;text-align:center;font-weight:600;font-size:.88rem;}
.kat-kachel.sel{border-color:var(--gruen);background:var(--gruen-hell);color:var(--gruen-dunkel);}
.kat-icon{font-size:1.7rem;display:block;margin-bottom:4px;}

.bestaetigung-box{background:var(--gruen-hell);border:1px solid var(--gruen);
  border-radius:8px;padding:12px;}
.best-zeile{display:flex;border-bottom:1px solid rgba(0,0,0,.06);padding:6px 0;}
.best-lab{flex:0 0 130px;color:var(--text-grau);font-size:.85rem;}
.best-val{flex:1;font-weight:600;}
.offline-badge{background:#fff4e5;border:1px solid #f0c060;color:#7a4d00;
  padding:8px 12px;border-radius:8px;font-size:.85rem;margin-bottom:10px;}

/* Warnungen */
.warn-box{background:#fff4e5;border:1px solid #f0c060;border-radius:var(--radius);
  padding:10px 13px;margin-bottom:10px;font-size:.88rem;color:#7a4d00;
  display:flex;gap:8px;align-items:flex-start;}
.warn-icon{font-size:1.1rem;flex:0 0 auto;margin-top:1px;}

/* ===== Übersicht / Dashboard ===== */
.dash-kennzahlen{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px;}
@media(min-width:560px){.dash-kennzahlen{grid-template-columns:repeat(4,1fr);}}
.kpi{background:var(--karte);border:1px solid var(--rand);border-radius:8px;padding:10px;
  text-align:center;box-shadow:var(--schatten);}
.kpi b{display:block;font-size:1.4rem;color:var(--gruen-dunkel);}
.kpi span{font-size:.78rem;color:var(--text-grau);}

.dash-block{background:var(--karte);border:1px solid var(--rand);border-radius:var(--radius);
  padding:14px;margin-bottom:14px;box-shadow:var(--schatten);}
.dash-block h3{font-size:1rem;margin-bottom:10px;}

.donut-wrap{display:flex;gap:14px;align-items:flex-start;flex-wrap:wrap;}
.donut-wrap svg{width:200px;height:200px;flex:0 0 200px;}
.legende{flex:1;min-width:150px;}
.leg-zeile{display:flex;align-items:center;gap:8px;font-size:.85rem;
  padding:4px 0;border-bottom:1px solid var(--rand);}
.leg-farbe{width:14px;height:14px;border-radius:3px;flex:0 0 auto;}
.leg-val{margin-left:auto;color:var(--text-grau);font-size:.78rem;}

.bar-zeile{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.bar-lab{flex:0 0 32%;font-size:.85rem;}
.bar-track{flex:1;background:var(--rand);border-radius:4px;height:14px;overflow:hidden;}
.bar-fill{height:100%;}
.bar-val{flex:0 0 60px;text-align:right;font-size:.82rem;color:var(--text-grau);}

/* ===== Plan / Wochen-Karten ===== */
.woche-kopf{display:flex;justify-content:space-between;align-items:center;
  background:var(--karte);border:1px solid var(--rand);border-radius:8px;
  padding:8px 14px;margin-bottom:10px;}
.woche-nav{background:var(--gruen-hell);border:0;color:var(--gruen-dunkel);
  font-size:1.3rem;font-weight:800;padding:4px 14px;border-radius:6px;cursor:pointer;}
.woche-kopf .titel{font-weight:700;}

.tag-karte{background:var(--karte);border:1px solid var(--rand);border-radius:8px;
  padding:10px 12px;margin-bottom:8px;}
.tag-karte.heute{border-color:var(--gruen);box-shadow:0 0 0 2px rgba(47,107,58,.18);}
.tag-kopf{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;
  font-size:.9rem;}
.tag-name{font-weight:700;}
.tag-datum{color:var(--text-grau);font-size:.82rem;}
.wx{color:var(--text-grau);font-size:.82rem;}
.slot{margin-bottom:6px;}
.slot label{font-size:.78rem;margin-bottom:3px;color:var(--text-grau);}
.slot textarea{min-height:44px;font-size:.92rem;}

.termin{display:flex;gap:8px;align-items:center;font-size:.85rem;margin-top:4px;}
.termin .zeit{background:var(--gruen-hell);color:var(--gruen-dunkel);padding:2px 8px;
  border-radius:14px;font-weight:700;font-size:.78rem;}
.termin-del{background:none;border:0;color:var(--rot);font-size:.95rem;cursor:pointer;
  margin-left:auto;}
.termin-add{display:flex;gap:8px;flex-wrap:wrap;}
.termin-add select,.termin-add input{min-height:42px;}
.termin-add select{flex:1 1 150px;}
.termin-add input[type=time]{flex:0 0 110px;}
.plan-gesperrt{color:var(--text-grau);background:var(--gelb);border:1px solid var(--gelb-rand);
  border-radius:8px;padding:10px;font-size:.85rem;margin-top:6px;}

/* Erinnerungs-Box (Wartungen) */
.reminder-box{background:#fff4e5;border:1px solid #f0c060;border-radius:8px;
  padding:10px 14px;margin-bottom:14px;color:#7a4d00;}
.reminder-box h3{color:#7a4d00;font-size:.95rem;}
.reminder-zeile{display:flex;justify-content:space-between;gap:8px;font-size:.88rem;
  padding:4px 0;border-bottom:1px solid rgba(112,80,0,.15);}
.reminder-zeile:last-child{border-bottom:0;}
.reminder-zeile.faellig{color:var(--rot);font-weight:700;}
.reminder-zeile .tage{color:var(--text-grau);font-size:.78rem;font-weight:400;}

/* ===== To-Do mit Drag&Drop ===== */
.haupt-raster{display:grid;grid-template-columns:1fr;gap:16px;}
@media(min-width:840px){.haupt-raster{grid-template-columns:340px 1fr;align-items:start;}}
.karte-titel{font-weight:800;font-size:1.05rem;margin-bottom:12px;}

.eingabe-zeile{display:flex;gap:8px;margin-bottom:10px;}
.eingabe-zeile input{flex:1;}
.eingabe-zeile select{flex:0 0 auto;}
.filter-zeile{display:flex;gap:8px;margin-bottom:10px;}
.filter-zeile select{flex:0 0 130px;}
.filter-zeile input{flex:1;}
.fort-zeile{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:.85rem;
  color:var(--text-grau);}
.fort-track{flex:1;background:var(--rand);border-radius:4px;height:8px;overflow:hidden;}
.fort-fill{height:100%;background:var(--gruen);transition:width .25s;}

.todo-liste{display:flex;flex-direction:column;gap:8px;}
.todo-item{display:flex;align-items:center;gap:10px;background:var(--karte);
  border:1px solid var(--rand);border-left:5px solid var(--rand);border-radius:8px;
  padding:9px 12px;touch-action:none;user-select:none;}
.todo-item.erledigt{opacity:.6;}
.todo-item.erledigt .todo-text-haupt{text-decoration:line-through;color:var(--text-grau);}
.todo-item.dragging{opacity:.4;}
.check-btn{flex:0 0 26px;width:26px;height:26px;border-radius:50%;
  border:2px solid var(--rand-stark);background:var(--karte);cursor:pointer;
  font-size:.9rem;color:var(--gruen);display:flex;align-items:center;justify-content:center;
  font-weight:800;}
.check-btn.checked{background:var(--gruen);color:#fff;border-color:var(--gruen);}
.todo-body{flex:1;min-width:0;}
.todo-text-haupt{font-weight:600;font-size:.95rem;}
.todo-meta{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-grau);
  margin-top:2px;flex-wrap:wrap;}
.prio-dot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.tag-chip{background:var(--gruen-hell);color:var(--gruen-dunkel);padding:1px 7px;
  border-radius:10px;font-weight:600;font-size:.7rem;}
.todo-del{background:none;border:0;font-size:1rem;cursor:pointer;color:var(--text-grau);}

/* Wochenplan-Slot mit Drag&Drop */
.tage-raster{display:flex;flex-direction:column;gap:8px;}
.tag-karte .tag-kopf-name{font-weight:800;}
.heute-badge{background:var(--gruen);color:#fff;font-size:.7rem;padding:1px 8px;
  border-radius:10px;font-weight:700;margin-left:auto;}
.slots-reihe{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.slot[data-datum]{background:var(--bg);border:1.5px dashed var(--rand-stark);
  border-radius:6px;padding:6px 8px;min-height:50px;transition:background .15s, border-color .15s;}
.slot.drop-aktiv{background:var(--gruen-hell);border-color:var(--gruen);border-style:solid;}
.slot-label{font-size:.72rem;color:var(--text-grau);font-weight:700;margin-bottom:3px;}
.slot-items{display:flex;flex-direction:column;gap:3px;}
.slot-leer{color:var(--text-grau);font-size:.75rem;font-style:italic;}
.slot-item{display:flex;align-items:center;gap:5px;background:var(--karte);
  border:1px solid var(--rand);border-radius:5px;padding:4px 6px;font-size:.78rem;
  touch-action:none;}
.slot-item.erledigt{opacity:.6;}
.slot-item.erledigt .slot-item-text{text-decoration:line-through;}
.slot-check-btn{flex:0 0 16px;width:16px;height:16px;border-radius:50%;
  border:1.5px solid var(--rand-stark);background:var(--karte);cursor:pointer;
  font-size:.6rem;color:var(--gruen);display:flex;align-items:center;justify-content:center;}
.slot-check-btn.checked{background:var(--gruen);color:#fff;border-color:var(--gruen);}
.slot-item-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.slot-item-del{background:none;border:0;font-size:.85rem;cursor:pointer;color:var(--text-grau);}

/* Ghost-Klon beim Dragging */
.drag-ghost{position:fixed;pointer-events:none;background:var(--gruen);color:#fff;
  padding:6px 12px;border-radius:6px;font-size:.85rem;font-weight:700;
  box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:100;max-width:200px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* ===== Maschinen ===== */
.masch-raster{display:grid;grid-template-columns:1fr;gap:12px;}
@media(min-width:560px){.masch-raster{grid-template-columns:1fr 1fr;}}
@media(min-width:860px){.masch-raster{grid-template-columns:1fr 1fr 1fr;}}
.masch-karte,.masch-kachel{
  background:var(--karte);border:1px solid var(--rand);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--schatten);cursor:pointer;text-align:left;
  width:100%;padding:0;display:block;
}
.masch-bild{width:100%;height:130px;object-fit:cover;display:block;}
.masch-bild-platz{width:100%;height:130px;background:var(--gruen-hell);
  display:flex;align-items:center;justify-content:center;font-size:3rem;}
.masch-body{padding:11px 13px;}
.masch-body h3{font-size:1rem;}
.masch-body .zeile{font-size:.82rem;color:var(--text-grau);}
.masch-body .sub{font-size:.78rem;color:var(--text-grau);margin-bottom:4px;}
.typ-badge{display:inline-block;font-size:.7rem;font-weight:700;padding:2px 8px;
  border-radius:12px;margin-bottom:5px;}
.rep-badge{display:inline-block;font-size:.75rem;padding:3px 8px;border-radius:12px;
  background:#fff4e5;color:#7a4d00;font-weight:600;margin-top:5px;}
.rep-badge.keine{background:var(--gruen-hell);color:var(--gruen-dunkel);}

/* Prüf-Chips */
.pruef-zeile{display:flex;gap:5px;flex-wrap:wrap;margin-top:5px;}
.pruef-chip{display:inline-block;font-size:.7rem;font-weight:700;padding:2px 8px;
  border-radius:10px;}
.pruef-chip.chip-ok{background:var(--gruen-hell);color:var(--gruen-dunkel);}
.pruef-chip.chip-bald{background:#fff3cd;color:#856404;}
.pruef-chip.chip-faellig{background:#f8d7da;color:#721c24;}

/* Fortschrittsbalken in der Maschinen-Kachel */
.progress-bar{background:var(--rand);border-radius:3px;height:6px;overflow:hidden;}
.progress-fill{height:100%;}

/* Maschinen-Detail */
.m-kopf{background:var(--karte);border:1px solid var(--rand);border-radius:var(--radius);
  padding:14px;box-shadow:var(--schatten);margin-bottom:14px;}
.m-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;}
@media(min-width:560px){.m-meta{grid-template-columns:repeat(4,1fr);}}
.m-meta .lab{font-size:.75rem;color:var(--text-grau);display:block;}
.m-aktionen{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap;}
.zurueck-btn{background:none;border:0;color:var(--gruen);font-size:.9rem;padding:6px 0;
  margin-bottom:8px;cursor:pointer;}

/* Reparaturen */
.rep-block{background:var(--karte);border:1px solid var(--rand);border-radius:var(--radius);
  padding:14px;margin-bottom:14px;}
.rep-block-ok{background:var(--gruen-hell);border:1px solid var(--gruen);
  border-radius:var(--radius);padding:10px 14px;margin-bottom:14px;
  display:flex;align-items:center;gap:10px;}
.rep-item{background:var(--bg);border-radius:8px;padding:10px 12px;margin-bottom:8px;
  border-left:4px solid var(--rot);}
.rep-item.prio-mittel{border-left-color:#b07a12;}
.rep-item.prio-niedrig{border-left-color:#8aab90;}
.rep-item.erledigt{opacity:.7;border-left-color:var(--gruen);}
.rep-item-kopf{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;}
.rep-item-titel{font-weight:700;font-size:.95rem;}
.rep-prio{font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:700;
  white-space:nowrap;}
.prio-hoch-chip{background:#f8d7da;color:#721c24;}
.prio-mittel-chip{background:#fff3cd;color:#856404;}
.prio-niedrig-chip{background:#d4edda;color:#155724;}
.rep-notiz{font-size:.85rem;margin:5px 0;}
.rep-meta{font-size:.75rem;color:var(--text-grau);margin-top:3px;}
.rep-fuss{display:flex;gap:6px;margin-top:8px;}
.rep-add-form{background:var(--gelb);border:1px solid var(--gelb-rand);
  border-radius:8px;padding:12px;margin-top:10px;}
.rep-add-form h4{margin-bottom:8px;font-size:.95rem;}

/* Prüftermine */
.pruef-block{background:var(--karte);border:1px solid var(--rand);border-radius:var(--radius);
  padding:14px;margin-bottom:14px;}
.pruef-tabelle{width:100%;border-collapse:collapse;font-size:.85rem;margin-bottom:8px;}
.pruef-tabelle th,.pruef-tabelle td{border-bottom:1px solid var(--rand);
  padding:6px 7px;text-align:left;vertical-align:top;}
.pruef-tabelle th{font-size:.72rem;color:var(--text-grau);text-transform:uppercase;}

/* Checklisten */
.cl-wrap{background:var(--karte);border:1px solid var(--rand);border-radius:var(--radius);
  padding:14px;margin-bottom:14px;}
.cl-tabs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px;}
.cl-tab{background:var(--karte);border:1.5px solid var(--rand-stark);color:var(--text-grau);
  border-radius:18px;padding:6px 12px;font-size:.82rem;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;}
.cl-tab.aktiv{background:var(--gruen);border-color:var(--gruen);color:#fff;}
.intervall-info{background:var(--gelb);border:1px solid var(--gelb-rand);
  border-radius:6px;padding:7px 10px;font-size:.8rem;color:#7a4d00;margin-bottom:8px;}
.cl-prog-zeile{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-grau);
  margin-bottom:4px;}
.cl-wer-zeile{display:flex;gap:8px;align-items:center;margin-bottom:10px;}
.cl-wer-zeile span{font-size:.85rem;color:var(--text-grau);white-space:nowrap;}
.cl-aktionen{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap;}

.cl-sektion{margin-bottom:12px;}
.cl-sektion-kopf{display:flex;justify-content:space-between;background:var(--bg);
  padding:6px 10px;border-radius:6px;font-weight:700;font-size:.85rem;margin-bottom:5px;}
.cl-sek-prog{color:var(--text-grau);font-weight:600;font-size:.78rem;}
.cl-item{display:flex;align-items:flex-start;gap:10px;background:var(--karte);
  border:1px solid var(--rand);border-radius:6px;padding:9px 11px;margin-bottom:4px;}
.cl-item.gecheckt{background:var(--gruen-hell);border-color:var(--gruen);}
.cl-check{flex:0 0 auto;width:22px;height:22px;margin-top:1px;cursor:pointer;accent-color:var(--gruen);}
.cl-text{flex:1;}
.cl-label{font-size:.92rem;cursor:pointer;display:block;}
.cl-geprueft{font-size:.72rem;color:var(--gruen-dunkel);display:block;margin-top:2px;}

/* Warnblock */
.warn-block{background:#fff4e5;border:1px solid #f0c060;border-radius:var(--radius);
  padding:12px 14px;margin-bottom:14px;color:#7a4d00;}
.warn-block h3{font-size:.95rem;color:#7a4d00;}
.warn-zeile{display:flex;justify-content:space-between;align-items:center;
  font-size:.85rem;padding:4px 0;gap:8px;border-bottom:1px solid rgba(112,80,0,.15);}
.warn-zeile:last-child{border-bottom:0;}

/* ===== Silos / Scheune ===== */
.silo-plan{width:100%;height:auto;background:var(--karte);border:1px solid var(--rand);
  border-radius:8px;}
.silo-plan .b-bldg{fill:var(--gruen-hell);stroke:#bcc8b2;stroke-width:2;}
.silo-plan .b-area{font-size:13px;fill:var(--gruen-dunkel);font-weight:700;text-anchor:middle;}
.silo-plan .b-dot{stroke:#bcc8b2;stroke-width:1.5;stroke-dasharray:3,3;}
.silo-plan .b-df{font-size:10px;fill:var(--text-grau);text-anchor:middle;}
.silo-plan .b-dash{fill:none;stroke:#a8b39c;stroke-width:1.5;stroke-dasharray:4,4;}
.silo-plan .b-silo{cursor:pointer;}
.silo-plan .b-silo text{font-size:18px;font-weight:800;fill:var(--text);text-anchor:middle;dominant-baseline:central;}
.kultur-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:6px 0 14px;}
@media(min-width:480px){.kultur-grid{grid-template-columns:1fr 1fr 1fr;}}
.kultur-card{border:1.5px solid var(--rand-stark);border-radius:8px;padding:9px;
  display:flex;align-items:center;gap:7px;font-size:.85rem;cursor:pointer;background:var(--karte);}
.kultur-card.sel{border-color:var(--gruen);background:var(--gruen-hell);}
.kultur-dot{display:inline-block;width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.2);}
.silo-dot{display:inline-block;width:20px;height:20px;border-radius:50%;border:1px solid rgba(0,0,0,.2);}
.karten-leiste{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.karten-leiste .btn{flex:1;}
.silo-chart{width:100%;height:auto;background:var(--karte);border:1px solid var(--rand);
  border-radius:8px;margin-bottom:10px;}
.silo-temp-item{display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--rand);padding:7px 2px;font-size:.9rem;}
.silo-ziel-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:6px 0 6px;}
@media(min-width:480px){.silo-ziel-grid{grid-template-columns:1fr 1fr 1fr;}}
.silo-ziel{border:1.5px solid var(--rand-stark);border-radius:8px;padding:9px;text-align:center;
  cursor:pointer;font-size:.82rem;background:var(--karte);}
.silo-ziel.sel{border-color:var(--gruen);background:var(--gruen-hell);}
.silo-ziel .zdot{width:18px;height:18px;border-radius:50%;margin:0 auto 4px;
  border:1px solid rgba(0,0,0,.2);}

/* ===== Karte (Satellit) ===== */
.karten-wrap{position:relative;background:#000;border-radius:var(--radius);overflow:hidden;
  margin-bottom:10px;}
.karten-wrap canvas{display:block;width:100%;cursor:crosshair;}
.karten-zoom{position:absolute;top:8px;right:8px;display:flex;flex-direction:column;gap:4px;}
.karten-zoom button{width:36px;height:36px;background:rgba(255,255,255,.92);border:0;
  border-radius:6px;font-size:1.3rem;font-weight:800;cursor:pointer;}
.karten-attr{position:absolute;bottom:4px;left:4px;background:rgba(0,0,0,.5);color:#fff;
  font-size:.65rem;padding:2px 6px;border-radius:4px;}
.modus-schalter{display:flex;gap:6px;margin-bottom:8px;}
.modus-btn{flex:1;background:var(--karte);border:1.5px solid var(--rand-stark);
  color:var(--text-grau);border-radius:8px;padding:8px;font-size:.85rem;font-weight:700;}
.modus-btn.aktiv{background:var(--gruen);border-color:var(--gruen);color:#fff;}
.karten-hilfe{font-size:.82rem;color:var(--text-grau);margin-bottom:8px;}
.karten-info{background:var(--gelb);border:1px solid var(--gelb-rand);border-radius:6px;
  padding:8px 10px;font-size:.85rem;color:#7a4d00;margin-bottom:8px;}
.toleranz-zeile{display:flex;align-items:center;gap:10px;margin-bottom:6px;font-size:.85rem;}
.toleranz-zeile input[type=range]{flex:1;min-height:auto;}
.ort-suche{display:flex;gap:6px;margin-bottom:6px;}
.ort-suche input{flex:1;}
.ort-treffer{margin-bottom:8px;}
.ort-zeile{display:block;width:100%;text-align:left;background:var(--karte);
  border:1px solid var(--rand);border-radius:6px;padding:7px 10px;font-size:.85rem;
  margin-bottom:4px;cursor:pointer;}
.ort-zeile.muted{color:var(--text-grau);cursor:default;}

/* ===== Wetter-Reiter ===== */
.wx-steuer{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px;}
.wx-steuer input,.wx-steuer select{flex:1 1 200px;}
.quellen-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;}
.qtab{background:var(--karte);border:1.5px solid var(--rand-stark);color:var(--text-grau);
  border-radius:20px;padding:7px 14px;font-size:.85rem;font-weight:600;cursor:pointer;
  white-space:nowrap;}
.qtab.aktiv{background:var(--gruen);border-color:var(--gruen);color:#fff;}
.konfidenz-leiste{display:flex;align-items:center;gap:8px;font-size:.85rem;margin-bottom:8px;}
.konfidenz-leiste .balken{flex:1;background:var(--rand);border-radius:4px;height:10px;overflow:hidden;}
.konfidenz-leiste .balken-fill{height:100%;transition:width .3s;}
.konfidenz-badge{display:inline-block;font-size:.75rem;font-weight:700;padding:2px 8px;
  border-radius:12px;}
.kf-hoch{background:#d4edda;color:#155724;}
.kf-mittel{background:#fff3cd;color:#856404;}
.kf-niedrig{background:#f8d7da;color:#721c24;}

.aktuell-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px;}
@media(min-width:560px){.aktuell-grid{grid-template-columns:repeat(3,1fr);}}
.wx-kpi{background:var(--gruen-hell);border-radius:8px;padding:10px;text-align:center;}
.wx-kpi .ic{font-size:1.5rem;display:block;}
.wx-kpi .val{display:block;font-weight:800;font-size:1rem;color:var(--gruen-dunkel);}
.wx-kpi .lab{font-size:.72rem;color:var(--text-grau);}

.stunden-wrap{overflow-x:auto;}
.stunden-reihe{display:flex;gap:4px;padding-bottom:6px;}
.std-zelle{flex:0 0 56px;background:var(--karte);border:1px solid var(--rand);
  border-radius:6px;padding:5px 4px;text-align:center;font-size:.72rem;}
.std-zelle.nacht{background:var(--bg);opacity:.7;}
.std-zelle.mittel{background:#fff3cd;}
.std-zelle.schlecht{background:#f8d7da;}
.std-ic{font-size:1.1rem;}
.std-temp{font-weight:800;}
.std-regen{color:var(--blau);}
.std-wind{color:var(--text-grau);}

.tag-tabelle{width:100%;border-collapse:collapse;font-size:.85rem;}
.tag-tabelle th,.tag-tabelle td{border-bottom:1px solid var(--rand);padding:7px 5px;text-align:center;}
.tag-tabelle th{background:var(--gruen-hell);color:var(--gruen-dunkel);font-size:.78rem;}
.tag-tabelle .tag-name{font-weight:700;}
.tag-tabelle .tag-datum{font-size:.72rem;color:var(--text-grau);}
.regen-bar{height:5px;background:var(--blau);border-radius:3px;margin:2px auto 0;}

.massn-balken-wrap{overflow-x:auto;}
.massn-balken-reihe{display:flex;gap:4px;}
.massn-tag{flex:0 0 90px;background:var(--karte);border:1px solid var(--rand);
  border-radius:6px;padding:6px 4px;}
.mt-datum{font-size:.72rem;text-align:center;color:var(--text-grau);margin-bottom:4px;}
.massn-chip{display:block;font-size:.7rem;padding:2px 5px;margin-bottom:2px;
  border-radius:4px;text-align:center;}
.massn-chip.gut{background:#d4edda;color:#155724;}
.massn-chip.mittel{background:#fff3cd;color:#856404;}
.massn-chip.schlecht{background:#f8d7da;color:#721c24;}
.legende-zeile{display:flex;gap:14px;align-items:center;flex-wrap:wrap;font-size:.78rem;
  color:var(--text-grau);margin-top:8px;}
.leg-item{display:flex;align-items:center;gap:5px;}
.leg-dot{width:10px;height:10px;border-radius:50%;display:inline-block;}

.zeitraum-gruppe{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;}
.zeitraum-btn{background:var(--karte);color:var(--text);border:1.5px solid var(--rand-stark);
  border-radius:8px;padding:7px 12px;font-size:.85rem;font-weight:600;cursor:pointer;}
.zeitraum-btn.aktiv{background:var(--gruen-hell);border-color:var(--gruen);color:var(--gruen-dunkel);}

.massnahme-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
@media(min-width:560px){.massnahme-grid{grid-template-columns:repeat(4,1fr);}}
.massnahme-card{background:var(--karte);border:1.5px solid var(--rand);
  border-radius:8px;padding:10px;text-align:center;cursor:pointer;font-weight:600;font-size:.85rem;}
.massnahme-card.sel{border-color:var(--gruen);background:var(--gruen-hell);color:var(--gruen-dunkel);}
.mc-ic{font-size:1.6rem;display:block;}

.score-chart-wrap{overflow-x:auto;margin-bottom:14px;}
.score-chart{display:flex;align-items:flex-end;gap:6px;padding:10px 4px 0;
  min-height:90px;border-bottom:1px solid var(--rand);}
.score-bar-wrap{flex:0 0 56px;text-align:center;display:flex;flex-direction:column;
  align-items:center;}
.score-bar{width:30px;border-radius:3px 3px 0 0;background:var(--rand);}
.score-bar.gut{background:var(--gruen);}
.score-bar.mittel{background:#b07a12;}
.score-bar.schlecht{background:var(--rot);}
.score-label{font-size:.72rem;color:var(--text-grau);margin-top:4px;}

.ergebnis-karte{background:var(--karte);border:1px solid var(--rand);border-radius:8px;
  padding:11px 14px;margin-bottom:8px;border-left:4px solid var(--rand);}
.ergebnis-karte.gut{border-left-color:var(--gruen);background:var(--gruen-hell);}
.ergebnis-karte.mittel{border-left-color:#b07a12;background:#fff8e1;}
.ergebnis-karte.schlecht{border-left-color:var(--rot);background:#fff5f4;}
.ergebnis-karte.dringend{box-shadow:0 0 0 2px var(--rot);}
.ergebnis-kopf{display:flex;gap:10px;align-items:center;font-size:.88rem;flex-wrap:wrap;}
.ampel{width:14px;height:14px;border-radius:50%;display:inline-block;}
.ampel.gut{background:var(--gruen);}
.ampel.mittel{background:#b07a12;}
.ampel.schlecht{background:var(--rot);}
.ergebnis-grund{font-size:.82rem;color:var(--text-grau);margin-top:4px;}
.dringend-hinweis{background:var(--rot);color:#fff;padding:3px 10px;border-radius:14px;
  font-size:.82rem;margin-left:6px;}

/* ===== Logs (Admin) ===== */
.logs-tabelle{width:100%;border-collapse:collapse;font-size:.82rem;}
.logs-tabelle th,.logs-tabelle td{border-bottom:1px solid var(--rand);padding:6px 8px;
  text-align:left;vertical-align:top;}
.logs-tabelle th{background:var(--gruen-hell);color:var(--gruen-dunkel);
  font-size:.72rem;text-transform:uppercase;position:sticky;top:0;}
.logs-aktion{display:inline-block;font-size:.7rem;padding:1px 7px;border-radius:10px;
  font-weight:700;}
.logs-aktion.create,.logs-aktion.put{background:var(--gruen-hell);color:var(--gruen-dunkel);}
.logs-aktion.delete{background:#f8d7da;color:#721c24;}
.logs-aktion.login{background:#d6e8ff;color:#0a3a6a;}
.logs-aktion[class*="backup"]{background:#fff3cd;color:#856404;}
.logs-aktion[class*="user"]{background:#e5d6ff;color:#3a0a6a;}
.logs-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;}
.logs-filter input,.logs-filter select{flex:1 1 130px;min-height:40px;}

/* ===== Backups (Admin) ===== */
.backup-zeile{display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--rand);padding:8px 0;font-size:.88rem;gap:8px;flex-wrap:wrap;}
.backup-name{font-family:ui-monospace,monospace;font-size:.82rem;}
.backup-meta{color:var(--text-grau);font-size:.78rem;}
.backup-aktionen{display:flex;gap:5px;}

/* Restore-Warnung */
.restore-warnung{background:#f8d7da;border:1px solid var(--rot);color:#721c24;
  border-radius:8px;padding:10px 12px;margin-bottom:10px;font-size:.88rem;}

/* ===== Ladekreis ===== */
.spinner{display:inline-block;width:14px;height:14px;border:3px solid var(--rand);
  border-top-color:var(--gruen);border-radius:50%;animation:spin .8s linear infinite;
  vertical-align:middle;margin-right:6px;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ===== Print-Hilfen ===== */
@media print{
  header,nav.unten,.kopf-btn,.btn,.werkzeuge,.sort-leiste{display:none !important;}
  body{padding:0;background:#fff;}
  main{max-width:none;padding:0;}
}
