: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:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.55;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
a{color:var(--akzent);text-decoration:none}
a:hover{text-decoration:underline}
/* Icons (Inline-SVG) */
.ic{width:1.15em;height:1.15em;display:inline-block;vertical-align:-.18em;flex:none;
  fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
h2 .ic,.kopf .ic{color:var(--akzent)}
.status .ic,.kachel-warn .ic{width:1em;height:1em;vertical-align:-.13em}
.login-marke{display:flex;align-items:center;justify-content:center;gap:11px}
.login-marke .ic{width:1.05em;height:1.05em;color:var(--akzent)}

/* 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:800;font-size:1.18rem;color:var(--text);display:flex;align-items:center;gap:9px;letter-spacing:-.01em}
.marke:hover{text-decoration:none}
.marke .ic-logo{width:22px;height:22px;color:var(--akzent)}
.topbar nav{display:flex;gap:4px;flex:1}
.topbar nav a{padding:7px 13px;border-radius:9px;color:var(--grau);font-weight:500;font-size:.93rem;transition:.12s}
.topbar nav a:hover{background:color-mix(in srgb,var(--text) 8%,transparent);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);
  line-height:1;padding:7px 11px;border-radius:9px;cursor:pointer;margin-left:auto;box-shadow:none}
.burger .ic{width:22px;height:22px}
@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:1600px;margin:24px auto;padding:0 22px}
main.zentriert{display:flex;justify-content:center;align-items:center;min-height:90vh}
h1{margin:.1em 0 .55em;font-weight:800;letter-spacing:-.022em;font-size:1.75rem}
h2{font-size:1.12rem;margin:.2em 0 .8em;color:var(--text);font-weight:700;letter-spacing:-.012em;
  display:flex;align-items:center;gap:9px}
.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:16px;
  padding:20px 22px;margin:16px 0;box-shadow:0 1px 2px rgba(0,0,0,.16),0 6px 18px rgba(0,0,0,.10);
  overflow-x:auto}
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:16px;
  padding:20px;text-align:center;color:var(--text);transition:.15s;
  box-shadow:0 1px 2px rgba(0,0,0,.14)}
.kachel:hover{border-color:var(--akzent);text-decoration:none;transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(0,0,0,.18)}
.kachel .zahl{font-size:2.1rem;font-weight:800;color:var(--akzent);letter-spacing:-.02em}

/* 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 17px;border-radius:10px;
  font-size:.92rem;cursor:pointer;font-weight:600;font-family:inherit;letter-spacing:.01em;
  box-shadow:0 1px 2px rgba(0,0,0,.18);transition:.12s}
button:hover,.btn:hover{filter:brightness(1.07);text-decoration:none;transform:translateY(-1px)}
button:active,.btn:active{transform:none;filter:brightness(.97)}
.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;
  background:var(--karte);color:var(--text);font:inherit;font-weight:600;display:block}
.theme-card:hover{border-color:var(--akzent);filter:none}
.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)}

/* Lade-Overlay (z. B. PDF-Upload + KI-Verarbeitung) */
.lade-overlay{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;
  background:color-mix(in srgb, var(--bg) 72%, transparent);backdrop-filter:blur(3px)}
.lade-overlay.an{display:flex}
.lade-box{background:var(--karte);border:1px solid var(--rand);border-radius:18px;padding:30px 34px;
  text-align:center;max-width:380px;width:88%;box-shadow:0 12px 40px rgba(0,0,0,.35)}
.spinner{width:40px;height:40px;margin:0 auto;border:4px solid var(--rand);border-top-color:var(--akzent);
  border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ladebalken{height:8px;background:var(--feld);border-radius:99px;overflow:hidden;margin-top:16px}
.ladebalken span{display:block;height:100%;width:40%;background:var(--akzent);border-radius:99px;
  animation:laden 1.1s ease-in-out infinite}
@keyframes laden{0%{transform:translateX(-120%)}100%{transform:translateX(300%)}}
