:root{
  --bg:#0f1320; --karte:#1a2032; --rand:#2a3350; --text:#e7ebf5;
  --grau:#9aa6c4; --akzent:#5b8cff; --akzent2:#7c5cff; --feld:#0e1424;
  --ok:#2ecc71; --warn:#e8b84b; --fehler:#ff5d6c;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.5}
a{color:var(--akzent);text-decoration:none}
a:hover{text-decoration:underline}

/* Topbar */
.topbar{display:flex;align-items:center;gap:20px;padding:12px 22px;
  background:var(--karte);border-bottom:1px solid var(--rand);
  position:sticky;top:0;z-index:10;flex-wrap:wrap}
.marke{font-weight:700;font-size:1.15rem;color:var(--text)}
.topbar nav{display:flex;gap:6px;flex:1}
.topbar nav a{padding:6px 12px;border-radius:8px;color:var(--grau)}
.topbar nav a:hover{background:var(--karte);color:var(--text);text-decoration:none}
.user{font-size:.9rem;color:var(--grau)}
.burger{display:none;background:none;border:1px solid var(--rand);color:var(--text);
  font-size:1.4rem;line-height:1;padding:4px 13px;border-radius:8px;cursor:pointer;margin-left:auto}
@media(max-width:760px){
  .topbar{gap:10px}
  .burger{display:block}
  .topbar nav{display:none;flex-basis:100%;flex-direction:column;gap:3px;flex:none}
  .topbar nav.offen{display:flex}
  .topbar nav a{padding:11px 12px;background:var(--karte)}
  .user{flex-basis:100%}
}

main{max-width:1100px;margin:24px auto;padding:0 22px}
main.zentriert{display:flex;justify-content:center;align-items:center;min-height:90vh}
h1{margin:.2em 0 .6em}
h2{font-size:1.1rem;margin:.2em 0 .8em;color:var(--text)}
.hinweis{color:var(--grau);font-size:.9rem}
.anzahl{color:var(--grau);font-weight:400;font-size:1rem}

/* Karten & Kacheln */
.karte{background:var(--karte);border:1px solid var(--rand);border-radius:14px;
  padding:18px 20px;margin:16px 0}
dialog{color:var(--text);background:var(--karte);border:1px solid var(--rand);border-radius:14px;padding:18px 20px}
dialog::backdrop{background:rgba(0,0,0,.6)}
.pro-bar{font-size:.8rem;color:var(--grau);margin-top:3px}
.pro-bar .bad{color:var(--fehler);font-weight:700}
table.sortier tr[data-aid]{cursor:move}
table.sortier input{pointer-events:none;opacity:.55}
table.sortier tr[data-aid] td:first-child::before{content:"≡ ";color:var(--akzent);font-weight:700}
tr.zieht{opacity:.4;background:var(--karte)}
.kacheln{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}
.kachel{background:var(--karte);border:1px solid var(--rand);border-radius:14px;
  padding:20px;text-align:center;color:var(--text);transition:.15s}
.kachel:hover{border-color:var(--akzent);text-decoration:none;transform:translateY(-2px)}
.kachel .zahl{font-size:2rem;font-weight:700;color:var(--akzent)}

/* Tabellen */
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--rand);vertical-align:middle}
th{color:var(--grau);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
tr:hover td{background:color-mix(in srgb, var(--text) 5%, transparent)}
table.kompakt th,table.kompakt td{padding:3px 5px;font-size:.82rem}
table.kompakt th{font-size:.68rem;letter-spacing:0}

.tag{background:var(--feld);color:var(--grau);padding:2px 8px;border-radius:20px;font-size:.78rem}
.zutat{background:var(--feld);padding:2px 8px;border-radius:6px;font-size:.85rem;display:inline-block;margin:2px 0}
.rezeptzelle{max-width:520px}

/* Formulare */
.kopf{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.formular{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.feld{display:flex;flex-direction:column;gap:5px}
.feld.breit{grid-column:1/-1}
.feld label{font-size:.82rem;color:var(--grau)}
.feld small{color:var(--grau)}
.trenner{grid-column:1/-1;border-top:1px solid var(--rand);padding-top:12px;margin:6px 0 0;
  font-size:.85rem;color:var(--grau);text-transform:uppercase;letter-spacing:.04em}
.checkbox label{flex-direction:row;display:flex;gap:8px;align-items:center;color:var(--text)}
input,select{background:var(--feld);border:1px solid var(--rand);color:var(--text);
  padding:9px 11px;border-radius:9px;font-size:.95rem;width:100%}
input:focus,select:focus{outline:none;border-color:var(--akzent)}
.zeile{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.zeile input,.zeile select{width:auto;flex:1;min-width:120px}
.filter{display:flex;gap:10px;margin:10px 0 16px;flex-wrap:wrap}
.filter input{max-width:280px}.filter select,.filter button{width:auto}

button,.btn{background:var(--akzent);color:#fff;border:none;padding:9px 16px;border-radius:9px;
  font-size:.92rem;cursor:pointer;font-weight:600}
button:hover,.btn:hover{filter:brightness(1.1);text-decoration:none}
.btn{display:inline-block}
.btn-link{color:var(--grau)}
button.gefahr{background:transparent;color:var(--fehler);border:1px solid var(--fehler)}
button.klein{padding:4px 10px;font-size:.8rem}
.aktionsleiste{display:flex;gap:10px;margin-top:8px}
.aktionen form{display:inline}

/* Login */
.login-box{background:var(--karte);border:1px solid var(--rand);border-radius:18px;
  padding:34px 32px;width:340px;display:flex;flex-direction:column;gap:14px}
.login-box h1{text-align:center;margin:0}
.login-box label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--grau)}
.login-box button{margin-top:6px;padding:12px}

/* Rollen-Badge */
.rolle{font-size:.72rem;padding:2px 8px;border-radius:20px;font-weight:700;text-transform:uppercase}
.rolle-admin{background:rgba(255,93,108,.18);color:var(--fehler)}
.rolle-chef{background:rgba(124,92,255,.18);color:#b3a3ff}
.rolle-user{background:rgba(46,204,113,.18);color:var(--ok)}

/* Flash */
.flash{padding:11px 16px;border-radius:10px;margin:10px 0;font-size:.92rem}
.flash-ok{background:rgba(46,204,113,.14);border:1px solid var(--ok);color:#aef0c8}
.flash-fehler{background:rgba(255,93,108,.14);border:1px solid var(--fehler);color:#ffc4ca}

.zwei-spalten{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
@media(max-width:760px){.formular,.zwei-spalten{grid-template-columns:1fr}}

/* Eingabe-Tabellen (Standkontrolle, Kassa) */
table.eingabe input{padding:3px 4px;width:46px;font-size:.85rem}
table.eingabe td:first-child{min-width:0;max-width:200px}
table.eingabe td,table.eingabe th{white-space:nowrap}
/* Sonderwünsche-Bezeichnung darf breiter sein */
table#sondertabelle input[name^="sp_bez_"]{width:100%;min-width:140px}
input[type=date]{width:auto}
#suche{max-width:240px}

/* Kontrolle / Firma B */
.firmab-pos{color:var(--warn);font-weight:700}
.firmab-neg{color:var(--grau)}
.spirit-zeile td{opacity:.8}
.grau{color:var(--grau);font-size:.85rem}
.legende{padding:1px 8px;border-radius:6px;background:rgba(232,184,75,.15)}
td small,th small{color:var(--grau);font-weight:400;font-size:.72rem}

/* Status-Badges in der Kontrolle */
.status{font-size:.74rem;padding:2px 9px;border-radius:20px;font-weight:700;white-space:nowrap}
.ok-status{background:rgba(46,204,113,.16);color:var(--ok)}
.b-status{background:rgba(232,184,75,.18);color:var(--warn)}
.warn-status{background:rgba(255,93,108,.16);color:var(--fehler)}
.korr-status{background:rgba(240,193,75,.18);color:#f0c14b;margin-left:6px}

/* POS / Bonierkassa Firma B */
.pos{display:grid;grid-template-columns:1fr 340px;gap:16px;align-items:start}
.pos-filter{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.kat{background:var(--karte);border:1px solid var(--rand);color:var(--grau);padding:6px 12px;font-weight:600}
.kat.aktiv{background:var(--akzent);color:#fff;border-color:var(--akzent)}
.pos-filter #suche{flex:1;min-width:140px;width:auto}
.produktgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}
.produkt{display:flex;flex-direction:column;gap:4px;align-items:flex-start;text-align:left;
  background:var(--karte);border:1px solid var(--rand);color:var(--text);padding:11px 12px;
  border-radius:11px;min-height:62px;justify-content:space-between;font-weight:600}
.produkt:hover{border-color:var(--akzent);filter:none}
.produkt .p-name{font-size:.86rem;line-height:1.2}
.produkt .p-preis{font-size:.8rem;color:var(--akzent)}
.pos-bon{background:var(--karte);border:1px solid var(--rand);border-radius:14px;padding:16px;
  position:sticky;top:78px}
.bonliste{max-height:46vh;overflow:auto;margin-bottom:10px}
.bonzeile{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;
  padding:7px 0;border-bottom:1px solid var(--rand)}
.bz-name{font-size:.86rem}.bz-name small{display:block;color:var(--grau)}
.bz-steuer{display:flex;align-items:center;gap:6px}
.bz-steuer button{padding:2px 9px;background:var(--feld);color:var(--text)}
.bz-steuer span{min-width:20px;text-align:center}
.bz-sub{font-weight:700;min-width:64px;text-align:right}
.bon-summe{display:flex;justify-content:space-between;font-size:1.25rem;font-weight:700;
  padding:10px 0;border-top:2px solid var(--rand)}
.bon-aktionen{display:flex;gap:8px}.bon-aktionen #bonieren{flex:1;padding:13px;font-size:1rem}
.bon-meldung{margin-top:10px;font-weight:600}
.bon-meldung.ok{color:var(--ok)}.bon-meldung.fehler{color:var(--fehler)}
tr.storniert td{opacity:.45;text-decoration:line-through}
@media(max-width:760px){.pos{grid-template-columns:1fr}.pos-bon{position:static}}

/* Modus-Umschalter (Kontrolle) */
.modus-box{background:var(--karte);border:1px solid var(--rand);border-radius:12px;
  padding:12px 16px;margin:8px 0 4px}
.modus-box form{display:flex;align-items:center;gap:12px}
.modus-text{font-size:.92rem}
.switch{position:relative;display:inline-block;width:46px;height:26px;flex:none}
.switch input{display:none}
.slider{position:absolute;inset:0;background:#39435f;border-radius:26px;cursor:pointer;transition:.2s}
.slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;
  background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + .slider{background:var(--ok)}
.switch input:checked + .slider:before{transform:translateX(20px)}

/* CSV-Import Vorschau */
tr.unmatched td{background:rgba(232,184,75,.06)}
tr.unmatched select{border-color:var(--warn)}

/* Reihenfolge (Drag&Drop) */
.sortliste{list-style:none;margin:0;padding:0}
.sortliste li{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--rand);
  border-radius:9px;margin-bottom:6px;background:var(--feld);cursor:grab}
.sortliste li.zieht{opacity:.4;border-color:var(--akzent)}
.sortliste .griff{color:var(--grau);font-size:1.2rem;cursor:grab}
.sortliste .s-name{flex:1}

/* Benutzer-Bearbeiten-Zeile */
.benutzerzeile{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:9px 0;border-bottom:1px solid var(--rand)}
.benutzerzeile .bz-name{min-width:200px}
.benutzerzeile form{display:flex;gap:8px;align-items:center}
/* Nav-Badge (offene Korrekturen) */
.badge{background:var(--fehler);color:#fff;border-radius:20px;padding:0 7px;font-size:.72rem;font-weight:700}

/* Minus-Umsatz / Fehler rot */
.fehler-rot{color:var(--fehler) !important}

/* Übertrag vom Vortag – grün markiert */
input.uebertrag{border-color:var(--ok);background:rgba(46,204,113,.07)}
input.gesperrt{background:var(--feld);color:var(--grau);border-style:dashed;cursor:not-allowed;opacity:.75}
input.gesperrt.uebertrag{border-color:var(--ok)}

/* Orts-Banner (FunBar/Beachbar/Lager farbig) */
.ort-banner{display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:16px 22px;border-radius:14px;margin:4px 0 12px;
  border:1px solid var(--ort);border-left:12px solid var(--ort);
  background:color-mix(in srgb, var(--ort) 14%, var(--karte))}
.ort-name{font-size:1.7rem;font-weight:800;color:var(--ort)}
.ort-datum{font-size:1.05rem;color:var(--text);font-weight:600}
.ort-auswahl{font-size:1.05rem;font-weight:700;color:var(--ort);
  border:2px solid var(--ort) !important;min-width:200px;
  background:color-mix(in srgb, var(--ort) 12%, var(--feld)) !important}

/* Umsatz im Orts-Banner */
.ort-umsatz{font-size:1.15rem;font-weight:800;color:var(--ort);margin-top:4px}
/* Design-Panel (System) */
.theme-cards{display:flex;gap:12px;flex-wrap:wrap}
.theme-card{cursor:pointer;border:2px solid var(--rand);border-radius:12px;padding:8px;width:120px;text-align:center;transition:.12s}
.theme-card:hover{border-color:var(--akzent)}
.theme-card.aktiv{border-color:var(--akzent);box-shadow:0 0 0 2px color-mix(in srgb,var(--akzent) 35%,transparent)}
.theme-prev{height:46px;border-radius:8px;background:var(--c-bg);display:flex;align-items:center;gap:6px;padding:8px;margin-bottom:6px}
.theme-prev .tp-bar{flex:1;height:14px;border-radius:4px;background:var(--c-karte)}
.theme-prev .tp-dot{width:14px;height:14px;border-radius:50%;background:var(--c-akz)}
.theme-name{font-size:.85rem;font-weight:600;color:var(--text)}
.datumsleiste{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
  padding:12px;background:var(--karte);border-bottom:1px solid var(--rand)}
.datum-gross{font-size:1.5rem;font-weight:800;color:var(--text);letter-spacing:.02em}
.datum-ctrl{display:inline-flex;align-items:center;gap:8px;flex-wrap:nowrap}
.datum-pfeil{font-size:1.1rem;font-weight:700;padding:8px 16px}
.datumsleiste input[type=date]{font-size:1.05rem}
.ort-kacheln{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.ort-kachel{flex:1;min-width:120px;text-align:center;padding:16px 14px;border-radius:12px;
  border:2px solid var(--rand);background:var(--karte);color:var(--grau);
  font-size:1.1rem;font-weight:700;cursor:pointer;transition:.12s}
.ort-kachel:hover{border-color:var(--ort);color:var(--text);text-decoration:none}
.ort-kachel small{font-weight:600;opacity:.8}
.ort-kachel.aktiv{border-color:var(--ort);color:#fff;
  background:color-mix(in srgb, var(--ort) 28%, var(--karte))}
.ort-kachel.hat-fehler{border-color:var(--fehler)}
.kachel-warn{display:inline-block;background:var(--fehler);color:#fff;font-size:.8rem;
  font-weight:800;padding:1px 9px;border-radius:20px;margin-left:6px;vertical-align:middle}
.euro2{min-width:64px}

/* Kontrolle: Fehler-Zeile hervorheben */
.fehler-zeile td{background:rgba(255,93,108,.09)}
