: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}
[hidden]{display:none !important}   /* sonst überschreibt display:flex das hidden-Attribut */
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;text-rendering:optimizeLegibility}
a{color:var(--akzent);text-decoration:none}
a:hover{text-decoration:underline}

/* Topbar */
.topbar{display:flex;align-items:center;gap:18px;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.15rem;color:var(--text)}
.marke:hover{text-decoration:none}
.topbar nav{display:flex;gap:4px;flex:1;flex-wrap:wrap}
.topbar nav a{padding:7px 13px;border-radius:9px;color:var(--grau);font-weight:500;font-size:.93rem}
.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);
  padding:7px 11px;border-radius:9px;cursor:pointer;margin-left:auto;box-shadow:none}
@media(max-width:820px){
  .burger{display:block}
  .topbar nav{display:none;flex-basis:100%;flex-direction:column;gap:3px}
  .topbar nav.offen{display:flex}
  .user{flex-basis:100%}
}

main{max-width:1500px;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:-.02em;font-size:1.7rem}
h2{font-size:1.1rem;margin:.2em 0 .8em;font-weight:700}
h3{margin:.1em 0 .6em}
.hinweis{color:var(--grau);font-size:.9rem}
.anzahl{color:var(--grau);font-weight:400;font-size:1rem}
.grau{color:var(--grau)}
.r{text-align:right}
.c{text-align:center}
.klein-text{font-size:.82rem}

.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);overflow-x:auto}
.kacheln{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:14px 0}
.kachel{background:var(--karte);border:1px solid var(--rand);border-radius:16px;
  padding:16px;text-align:center;color:var(--grau);font-size:.85rem}
.kachel .zahl{font-size:1.5rem;font-weight:800;color:var(--akzent);letter-spacing:-.02em;color:var(--text)}

table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--rand);vertical-align:middle}
th{color:var(--grau);font-size:.76rem;text-transform:uppercase;letter-spacing:.04em}
th.r{text-align:right}
tr:hover td{background:color-mix(in srgb,var(--text) 4%,transparent)}
table.kompakt th,table.kompakt td{padding:4px 6px;font-size:.84rem}
tr.total td{font-weight:800;border-top:2px solid var(--rand)}
tr.inaktiv td,tr.inaktiv input,tr.inaktiv select{opacity:.45}
tr.storno-zeile td{color:var(--grau);text-decoration:none}
.status-ok{color:var(--ok);font-weight:600;font-size:.85rem}
.status-storno{color:var(--fehler);font-weight:600;font-size:.85rem}
.tag{background:var(--feld);color:var(--grau);padding:2px 8px;border-radius:20px;font-size:.76rem}

/* 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)}
.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)}
input[type=color]{padding:2px;height:40px;width:56px}
input[type=checkbox]{width:20px;height:20px}
.zeile{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.zeile input,.zeile select{width:auto;flex:1;min-width:110px}
.filter{display:flex;gap:10px;margin:10px 0 16px;flex-wrap:wrap;align-items:center}
.filter input{max-width:260px}.filter select,.filter button{width:auto}
.feld-inline{display:flex;align-items:center;gap:6px;color:var(--grau);font-size:.9rem}
.feld-inline input{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}
button:hover,.btn:hover{filter:brightness(1.08);text-decoration:none}
.btn{display:inline-block}
.btn-zweit{background:var(--feld);border:1px solid var(--rand);color:var(--text)}
button.gefahr{background:transparent;color:var(--fehler);border:1px solid var(--fehler)}
button.klein,.btn.klein{padding:4px 10px;font-size:.8rem}
button:disabled{opacity:.5;cursor:default}

.flash{padding:11px 16px;border-radius:10px;margin:0 0 14px;font-size:.92rem;
  background:var(--karte);border:1px solid var(--rand)}
.flash.ok{border-color:var(--ok);color:var(--ok)}
.flash.fehler{border-color:var(--fehler);color:var(--fehler)}

/* 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)}

/* Sortier-Tabelle (Drag&Drop) */
table.sortier tr[data-aid],table.sortier tr[data-wid]{cursor:grab}
.sichtbar-check{display:inline-flex;align-items:center;gap:4px;margin-right:12px;font-size:.85rem;color:var(--text);white-space:nowrap}
.sichtbar-check input{width:17px;height:17px}
table.sortier .zieh-zelle{position:relative;padding-left:26px}
table.sortier .zieh-zelle::before{content:"≡";position:absolute;left:8px;color:var(--akzent);font-weight:700}
tr.zieht{opacity:.4}

/* Bericht */
.bericht-spalten{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
@media(max-width:900px){.bericht-spalten{grid-template-columns:1fr}}
.kompakt-bericht th,.kompakt-bericht td{padding:5px 8px;font-size:.88rem}
tr.gruppen-kopf td{background:color-mix(in srgb,var(--akzent) 12%,transparent);border-top:2px solid var(--rand)}
.eingerueckt{padding-left:26px}
.schnell a{margin:0 3px}

dialog{color:var(--text);background:var(--karte);border:1px solid var(--rand);
  border-radius:16px;padding:20px 22px;min-width:320px}
dialog::backdrop{background:rgba(0,0,0,.65)}
.dialog-zu{background:var(--feld);border:1px solid var(--rand);color:var(--grau);margin-top:10px}

/* ============================================================ POS (iPad) */
body.pos{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden;
  touch-action:manipulation;-webkit-user-select:none;user-select:none}
.pos-kopf{display:flex;gap:8px;align-items:center;padding:8px 10px;
  background:var(--karte);border-bottom:1px solid var(--rand);flex-wrap:nowrap}
.pos-marke{font-weight:800;white-space:nowrap}
.pos-kopf select{width:auto;min-width:110px;padding:10px}
.pos-kopf #suche{flex:1;min-width:80px;padding:10px}
.pos-chip{background:var(--feld);border:1px solid var(--rand);color:var(--text);
  padding:10px 13px;border-radius:10px;white-space:nowrap;font-size:.9rem}
.pos-chip.kein-kellner{border-color:var(--warn);color:var(--warn)}
.training-badge{background:var(--warn);color:#000;font-weight:800;padding:4px 10px;border-radius:8px;font-size:.8rem}

.pos-haupt{flex:1;display:flex;min-height:0}
.pos-links{flex:1;display:flex;flex-direction:column;min-width:0}
.gruppen-leiste{display:flex;gap:7px;padding:9px 10px;overflow-x:auto;flex:none;
  border-bottom:1px solid var(--rand);-webkit-overflow-scrolling:touch}
.gruppe-chip{background:var(--feld);border:1px solid var(--rand);color:var(--text);
  padding:10px 15px;border-radius:12px;white-space:nowrap;font-size:.95rem;font-weight:600;
  border-left:4px solid var(--gfarbe,var(--rand))}
.gruppe-chip.aktiv{background:var(--gfarbe,var(--akzent));border-color:transparent;color:#fff}

.artikel-raster{flex:1;overflow-y:auto;display:grid;gap:9px;padding:10px;
  grid-template-columns:repeat(auto-fill,minmax(128px,1fr));align-content:start;
  -webkit-overflow-scrolling:touch}
.artikel-knopf{display:flex;flex-direction:column;justify-content:space-between;gap:4px;
  min-height:74px;padding:9px 10px;border-radius:13px;text-align:left;
  background:var(--karte);border:1px solid var(--rand);color:var(--text);
  border-left:5px solid var(--gfarbe,var(--rand))}
.artikel-knopf:active{filter:brightness(1.35)}
.artikel-knopf .an{font-weight:600;font-size:.92rem;line-height:1.25;word-break:break-word}
.artikel-knopf .ap{color:var(--grau);font-size:.85rem}

.pos-bon{width:330px;flex:none;display:flex;flex-direction:column;
  background:var(--karte);border-left:1px solid var(--rand)}
.bon-liste{flex:1;overflow-y:auto;padding:8px;-webkit-overflow-scrolling:touch}
.bon-leer{color:var(--grau);text-align:center;margin-top:30px}
.bon-zeile{display:flex;align-items:center;gap:6px;padding:7px 4px;border-bottom:1px solid var(--rand)}
.bz-name{flex:1;font-size:.92rem;line-height:1.2;min-width:0;word-break:break-word}
.bz-minus,.bz-plus{width:40px;height:40px;padding:0;font-size:1.25rem;border-radius:10px;
  background:var(--feld);border:1px solid var(--rand);color:var(--text);flex:none}
.bz-anzahl{width:26px;text-align:center;font-weight:800;flex:none}
.bz-summe{width:58px;text-align:right;font-size:.9rem;flex:none}
.bon-fuss{border-top:2px solid var(--rand);padding:10px}
.bon-summe{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;
  font-size:1.05rem;color:var(--grau)}
.bon-summe strong{font-size:1.9rem;color:var(--text);letter-spacing:-.02em}
.bon-aktionen{display:flex;gap:8px}
.zahl-knopf{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:13px 6px;font-size:1.3rem;border-radius:14px}
.zahl-knopf small{font-size:.8rem;font-weight:700}
.zahl-knopf.bar{background:#1e9e54}
.zahl-knopf.karte{background:var(--akzent)}
.zahl-knopf.leeren{flex:.6;background:var(--feld);border:1px solid var(--rand);color:var(--grau)}
.zahl-knopf.teilen{flex:.8;background:var(--feld);border:1px solid var(--akzent2);color:var(--text)}
.ts-summe{font-size:1.1rem;margin-bottom:12px}
.ts-feld{display:flex;align-items:center;gap:10px;margin:8px 0;font-size:1.05rem}
.ts-feld input{font-size:1.3rem;text-align:right;max-width:160px}
.ts-info{margin:10px 0;font-weight:700;min-height:1.4em}
.ts-info.ts-tg{color:var(--ok)}
.ts-info.ts-fehlt{color:var(--fehler)}
.tisch-banner{display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:9px 10px;background:color-mix(in srgb,var(--akzent2) 18%,transparent);
  border-bottom:2px solid var(--akzent2);font-weight:700}
.tische-grid{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:10px;margin:8px 0 14px}
.tisch-knopf{display:flex;flex-direction:column;gap:4px;padding:14px 10px;border-radius:13px;
  background:var(--feld);border:1px solid var(--rand);color:var(--text);font-weight:700}
.tisch-knopf small{color:var(--grau);font-weight:400}
.tisch-knopf.belegt{border-color:var(--akzent2);background:color-mix(in srgb,var(--akzent2) 14%,transparent)}

/* PIN-Dialog */
.pin-anzeige{text-align:center;font-size:1.9rem;letter-spacing:.35em;margin:6px 0 12px;min-height:1.4em}
.pin-feld{display:grid;grid-template-columns:repeat(3,84px);gap:9px;justify-content:center}
.pin-feld button{height:66px;font-size:1.5rem;border-radius:14px;background:var(--feld);
  border:1px solid var(--rand);color:var(--text)}
.pin-feld .pin-ok{background:var(--ok);border:none;color:#fff}
.pin-feld .pin-c{color:var(--fehler)}

/* Letzter Bon */
.letzter-inhalt{min-width:300px;margin-bottom:12px}
.lb-kopf{font-weight:700;margin-bottom:8px}
.lb-zeile{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px solid var(--rand);font-size:.92rem}
.lb-summe{margin-top:8px;text-align:right}

/* Toast */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:99;
  padding:14px 22px;border-radius:14px;font-weight:700;font-size:1.05rem;
  box-shadow:0 8px 30px rgba(0,0,0,.45)}
.toast-ok{background:#1e9e54;color:#fff}
.toast-fehler{background:var(--fehler);color:#fff}

/* Druck */
.nur-druck{display:none}
@media print{
  body{background:#fff;color:#000}
  .topbar,.filter,.kopf .zeile,.kopf button,.flash,.bericht-kacheln{display:none !important}
  .karte{border:none;box-shadow:none;padding:6px 0;margin:6px 0;background:#fff;color:#000}
  .nur-druck{display:block;margin-bottom:10px}
  th,td{border-color:#bbb;color:#000;padding:3px 6px;font-size:11px}
  h1,h2{color:#000}
  a{color:#000}
  .bericht-spalten{display:block}
}

/* ============================================================ Helles Design */
:root{color-scheme:dark}
:root[data-theme="hell"],
:root[data-theme="auto"].system-hell{color-scheme:light}
:root[data-theme="hell"]{
  --bg:#eef1f7; --karte:#ffffff; --rand:#d7dde9; --text:#1b2334;
  --grau:#5d6a85; --akzent:#3b6ceb; --akzent2:#6a4de0; --feld:#f2f5fa;
  --ok:#188a4c; --warn:#a87e15; --fehler:#d63a4c;
}
@media (prefers-color-scheme: light){
  :root:not([data-theme="dunkel"]):not([data-theme="hell"]){
    color-scheme:light;
    --bg:#eef1f7; --karte:#ffffff; --rand:#d7dde9; --text:#1b2334;
    --grau:#5d6a85; --akzent:#3b6ceb; --akzent2:#6a4de0; --feld:#f2f5fa;
    --ok:#188a4c; --warn:#a87e15; --fehler:#d63a4c;
  }
}
.theme-knopf{background:var(--feld);border:1px solid var(--rand);color:var(--text);
  padding:7px 11px;border-radius:9px;font-size:1rem;line-height:1}
