* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, sans-serif; background: #f4f4f2; color: #1a1a1a; }
#topbar { display: flex; align-items: center; gap: 10px; padding: 8px 12px;
  background: #14532d; color: #fff; position: sticky; top: 0; z-index: 20; }
#brand { font-weight: 700; }
#topbar input[type=date] { border: 0; border-radius: 6px; padding: 4px 6px; }
#rolle-badge { margin-left: auto; background: #ffffff22; padding: 2px 10px; border-radius: 10px; font-size: .85em; }
#topbar button { border: 0; background: #ffffff22; color: #fff; border-radius: 6px;
  padding: 4px 10px; font-size: 1em; cursor: pointer; }
#offline-banner { background: #b45309; color: #fff; text-align: center; padding: 6px; }

/* Login */
.login { max-width: 340px; margin: 18vh auto; background: #fff; padding: 24px;
  border-radius: 12px; box-shadow: 0 2px 12px #0002; }
.login input { width: 100%; padding: 10px; margin: 10px 0; border: 1px solid #ccc; border-radius: 8px; }
.login button { width: 100%; padding: 10px; background: #14532d; color: #fff; border: 0;
  border-radius: 8px; font-size: 1em; cursor: pointer; }
.login .hint { font-size: .8em; color: #666; margin-top: 10px; line-height: 1.5; }

/* Dispo-Layout */
.dispo { display: grid; grid-template-columns: 400px 1fr; height: calc(100vh - 46px); }
.sidebar { overflow-y: auto; padding: 10px; background: #fff; border-right: 1px solid #ddd; }
#map { width: 100%; height: 100%; }
.aktionen { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.aktionen button { flex: 1; padding: 8px; border: 0; border-radius: 8px; cursor: pointer; font-weight: 600; }
.btn-entwurf { background: #dbeafe; } .btn-final { background: #dcfce7; } .btn-tick { background: #fef9c3; }
.btn-ansicht { background: #e5e7eb; }

/* Plantafel */
.tafel { display: flex; gap: 10px; padding: 10px; overflow-x: auto; align-items: flex-start;
  background: #ececea; height: calc(100vh - 46px); }
.spalte { background: #fff; border-radius: 10px; border-top: 4px solid var(--tc, #888);
  min-width: 235px; max-width: 270px; flex: 1; padding: 8px; max-height: 100%; overflow-y: auto; }
.spalte-kopf { display: flex; align-items: center; gap: 6px; }
.spalte-kopf input[type=time] { margin-left: auto; border: 1px solid #ccc; border-radius: 6px; padding: 1px 3px; }
.spalte-kopf .sperr { border: 0; background: none; cursor: pointer; font-size: 1em; }
.spalte-meta { font-size: .72em; color: #666; margin: 4px 0 8px; }
.karte-stopp { border: 1px solid #e5e5e5; border-radius: 8px; padding: 6px 8px; margin: 6px 0;
  cursor: grab; display: grid; grid-template-columns: auto 1fr auto; gap: 2px 8px;
  font-size: .82em; background: #fafafa; }
.karte-stopp:active { cursor: grabbing; }
.karte-stopp .ks-pos { grid-row: span 2; align-self: center; background: var(--tc, #888);
  color: #fff; border-radius: 50%; width: 22px; height: 22px; display: flex;
  align-items: center; justify-content: center; font-weight: 700; }
.karte-stopp .ks-zeit { font-weight: 700; }
.karte-stopp .ks-fenster { grid-column: 2 / 4; color: #777; font-size: .9em; }
.karte-stopp.zu-spaet { background: #fee2e2; border-color: #fca5a5; }
.karte-stopp.geliefert { opacity: .5; }
.key-toggle { cursor: pointer; width: 16px; text-align: center; }
.karte-hinweis { font-size: .8em; color: #888; padding: 6px; }

.fzg-block { margin: 8px 0; font-size: .85em; }
.fzg-block summary { cursor: pointer; font-weight: 600; padding: 4px 0; }
.fzg-zeile { display: flex; align-items: center; gap: 6px; padding: 3px 0; }
.fzg-zeile .fzg-typ { color: #888; font-size: .85em; flex: 1; }
.fzg-zeile input[type=time] { border: 1px solid #ccc; border-radius: 6px; padding: 2px 4px; }
.fzg-zeile label { display: flex; align-items: center; gap: 3px; }

.tour-card { border: 1px solid #ddd; border-left: 6px solid var(--tc, #888); border-radius: 8px;
  margin: 8px 0; padding: 8px; background: #fff; }
.tour-card h3 { margin: 0 0 4px; font-size: .95em; display: flex; gap: 8px; align-items: center; }
.status-pill { font-size: .72em; padding: 1px 8px; border-radius: 8px; background: #eee; }
.status-entwurf { background: #dbeafe; } .status-final { background: #dcfce7; }
.tour-meta { font-size: .8em; color: #555; margin-bottom: 6px; }
.stopp { display: flex; align-items: center; gap: 6px; padding: 3px 0; font-size: .85em;
  border-top: 1px dashed #eee; }
.stopp .zeit { font-variant-numeric: tabular-nums; color: #333; min-width: 42px; }
.stopp .pin { cursor: pointer; opacity: .35; border: 0; background: none; font-size: 1em; }
.stopp .pin.aktiv { opacity: 1; }
.stopp select { margin-left: auto; font-size: .8em; max-width: 60px; }
.stopp.geliefert { text-decoration: line-through; color: #999; }
.stopp.problem { color: #b91c1c; }

.auftraege-block h3 { font-size: .9em; margin: 12px 0 4px; }
.auftrag { display: flex; gap: 6px; font-size: .82em; padding: 2px 0; align-items: center; }
.auftrag .kg { margin-left: auto; color: #666; }
.badge-erwartet { color: #92400e; } .badge-fehlt { color: #b91c1c; }

/* Fahrer */
.fahrer { max-width: 560px; margin: 0 auto; padding: 10px; }
.f-stopp { background: #fff; border-radius: 12px; padding: 12px; margin: 10px 0;
  box-shadow: 0 1px 4px #0001; }
.f-stopp .kopf { display: flex; gap: 10px; align-items: baseline; }
.f-stopp .nr { background: #14532d; color: #fff; border-radius: 50%; width: 26px; height: 26px;
  display: inline-flex; align-items: center; justify-content: center; flex: none; }
.f-stopp .eta { margin-left: auto; font-weight: 700; }
.f-stopp .adresse { color: #555; font-size: .9em; margin: 4px 0 8px 36px; }
.f-aktionen { display: flex; gap: 8px; margin-left: 36px; }
.f-aktionen a, .f-aktionen button { flex: 1; text-align: center; padding: 10px; border-radius: 8px;
  border: 0; font-size: .95em; cursor: pointer; text-decoration: none; color: #1a1a1a; }
.b-navi { background: #dbeafe; } .b-ok { background: #dcfce7; } .b-problem { background: #fee2e2; }
.f-stopp.geliefert { opacity: .55; } .f-stopp.geliefert .b-ok { outline: 2px solid #16a34a; }
.f-stopp.problem { border-left: 4px solid #b91c1c; }

/* Buero */
.buero { max-width: 720px; margin: 0 auto; padding: 12px; }
.b-karte { background: #fff; border-radius: 12px; padding: 14px; margin: 10px 0; box-shadow: 0 1px 4px #0001; }
.b-karte h3 { margin: 0 0 6px; }
.fortschritt { height: 10px; background: #eee; border-radius: 6px; overflow: hidden; margin: 6px 0; }
.fortschritt div { height: 100%; background: #16a34a; }
.b-status { display: flex; gap: 14px; font-size: .85em; color: #555; flex-wrap: wrap; }

@media (max-width: 800px) {
  .dispo { grid-template-columns: 1fr; grid-template-rows: 1fr 300px; }
  .sidebar { order: 2; } #map { order: 1; min-height: 300px; }
}
