
:root{
  --bg:#0f172a; --card:#111827; --card2:#1f2937; --text:#f8fafc; --muted:#94a3b8;
  --line:rgba(255,255,255,.09); --accent:#f59e0b; --accent2:#fde68a; --green:#22c55e; --red:#ef4444; --blue:#38bdf8;
  --shadow:0 18px 50px rgba(0,0,0,.28); --radius:24px;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
*{box-sizing:border-box} html{min-height:100%;background:var(--bg)} body{margin:0;color:var(--text);min-height:100%;background:radial-gradient(circle at top left,rgba(245,158,11,.22),transparent 34rem),linear-gradient(135deg,#0f172a,#111827 55%,#0b1120)}
a{color:inherit;text-decoration:none} button,input,select,textarea{font:inherit} button{cursor:pointer}
.login-body{display:grid;place-items:center;min-height:100vh;padding:18px}.login-shell{width:min(1040px,100%);display:grid;grid-template-columns:0.9fr 1.1fr;gap:22px}.brand-card,.login-card,.panel,.order-card,.stat{border:1px solid var(--line);background:rgba(17,24,39,.86);backdrop-filter:blur(16px);border-radius:var(--radius);box-shadow:var(--shadow)}.brand-card{padding:42px}.brand-icon{width:72px;height:72px;border-radius:24px;background:linear-gradient(135deg,#f59e0b,#fbbf24);display:grid;place-items:center;font-size:38px;margin-bottom:22px}.eyebrow{margin:0 0 6px;color:var(--accent2);font-size:.78rem;text-transform:uppercase;letter-spacing:.11em;font-weight:800}.brand-card h1,.topbar h1{margin:0;font-size:clamp(2rem,5vw,4rem);line-height:.95}.muted,.hint{color:var(--muted)}.login-card{padding:28px}.login-card h2{margin:0 0 18px}.employee-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.employee-card{border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);padding:18px;border-radius:20px;text-align:left;min-height:96px}.employee-card strong{display:block;font-size:1.25rem}.employee-card small{color:var(--muted)}.employee-dot{width:16px;height:16px;border-radius:50%;background:var(--emp);display:inline-block;margin-bottom:12px}.employee-card:hover{background:rgba(245,158,11,.13);border-color:rgba(245,158,11,.45)}
.pin-dialog{border:0;border-radius:28px;background:transparent;padding:0}.pin-dialog::backdrop{background:rgba(2,6,23,.72);backdrop-filter:blur(8px)}.pin-box{width:min(390px,calc(100vw - 28px));background:#111827;color:var(--text);border:1px solid var(--line);border-radius:28px;padding:26px;box-shadow:var(--shadow);position:relative}.pin-box .x{position:absolute;right:14px;top:14px;border:0;background:rgba(255,255,255,.08);color:#fff;border-radius:50%;width:36px;height:36px}.pin-input{width:100%;font-size:2rem;text-align:center;letter-spacing:.3em;border:1px solid var(--line);border-radius:18px;background:#0b1120;color:#fff;padding:14px;margin:14px 0}.error{color:#fecaca;background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.25);padding:12px;border-radius:14px}
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;background:rgba(15,23,42,.88);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}.topbar.compact h1{font-size:1.5rem}.top-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.ghost,.primary,.danger,.pay,.chip,.cat{border:1px solid var(--line);border-radius:999px;padding:10px 14px;color:var(--text);background:rgba(255,255,255,.05)}.primary{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#111827;border:0;font-weight:900}.primary.big,.primary.send{width:100%;font-size:1.1rem;padding:16px}.danger{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.25);color:#fecaca}.small{font-size:.9rem;padding:8px 12px}.full{width:100%}.connection{border-radius:999px;padding:8px 11px;background:rgba(34,197,94,.13);color:#bbf7d0;font-weight:800;font-size:.85rem}.connection.offline{background:rgba(239,68,68,.14);color:#fecaca}
.waiter-layout{padding:18px 18px 240px;max-width:1120px;margin:0 auto}.panel{padding:18px}.panel-head,.section-head,.cart-head,.order-head{display:flex;align-items:center;justify-content:space-between;gap:14px}.panel h2,.panel h3{margin:0 0 12px}.table-chips{display:flex;gap:8px;flex-wrap:wrap}.chip.active,.cat.active,.pay.active{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.7);color:#fde68a}.text-input{width:100%;border:1px solid var(--line);background:rgba(2,6,23,.5);color:var(--text);border-radius:16px;padding:12px 14px;margin-top:10px}.category-strip{display:flex;overflow:auto;gap:10px;padding:14px 2px;position:sticky;top:82px;z-index:4;background:linear-gradient(180deg,rgba(15,23,42,.97),rgba(15,23,42,.72))}.cat{white-space:nowrap}.product-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.product-card{position:relative;min-height:112px;text-align:left;padding:16px;border-radius:22px;border:1px solid var(--line);background:rgba(255,255,255,.055);color:var(--text);box-shadow:0 10px 22px rgba(0,0,0,.12)}.product-card strong{display:block;font-size:1.08rem;margin-bottom:12px}.product-card span{color:#fde68a;font-weight:800}.product-card em{position:absolute;right:10px;top:10px;min-width:30px;height:30px;border-radius:50%;background:#f59e0b;color:#111827;display:grid;place-items:center;font-style:normal;font-weight:900}.cart-drawer{position:fixed;left:50%;bottom:14px;transform:translateX(-50%);width:min(760px,calc(100% - 22px));z-index:8;background:rgba(17,24,39,.97);border:1px solid var(--line);border-radius:28px;padding:16px;box-shadow:var(--shadow)}.cart-head h2{margin:0}.cart-head strong{font-size:1.6rem;color:#fde68a}.cart-items{max-height:170px;overflow:auto}.cart-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}.cart-row span{display:block;color:var(--muted);font-size:.9rem}.qty{display:flex;align-items:center;gap:9px}.qty button{width:34px;height:34px;border-radius:50%;border:0;background:rgba(255,255,255,.09);color:#fff;font-weight:900}.payment-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0}.note{margin-top:12px;resize:vertical}.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:99;background:#f8fafc;color:#111827;padding:13px 18px;border-radius:999px;font-weight:900;box-shadow:var(--shadow)}
.bar-layout{padding:18px;max-width:1400px;margin:0 auto}.bar-toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.stat-pill{border:1px solid var(--line);border-radius:999px;padding:10px 14px;background:rgba(255,255,255,.05);font-weight:900}.orders-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.order-card{padding:18px;border-top:5px solid #f59e0b}.order-card.in_progress{border-top-color:#38bdf8}.order-head h2{font-size:1.6rem;margin:.2rem 0 0}.order-head strong{font-size:1.6rem;color:#fde68a}.order-no{color:var(--muted);font-weight:900}.order-meta{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}.order-meta span{font-size:.85rem;padding:6px 9px;border-radius:999px;background:rgba(255,255,255,.07);color:#dbeafe}.order-items{list-style:none;margin:0;padding:0}.order-items li{padding:9px 0;border-bottom:1px solid var(--line);font-size:1.25rem}.order-items b{color:#fde68a}.order-note{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.22);padding:10px;border-radius:14px;color:#fffbeb}.order-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:14px}.empty-state{text-align:center;color:var(--muted);padding:70px 20px}.empty-state div{font-size:4rem}.empty-state[hidden]{display:none}
.admin-shell{display:grid;grid-template-columns:240px 1fr;gap:18px;padding:18px;max-width:1480px;margin:0 auto}.admin-nav{position:sticky;top:92px;align-self:start;border:1px solid var(--line);background:rgba(17,24,39,.88);border-radius:24px;padding:12px;display:grid;gap:8px}.navbtn{border:0;background:transparent;color:var(--muted);text-align:left;padding:12px 14px;border-radius:16px}.navbtn.active{background:rgba(245,158,11,.16);color:#fde68a;font-weight:900}.tab{display:none}.tab.active{display:block}.notice{padding:14px 16px;border-radius:16px;margin-bottom:12px}.notice.ok{background:rgba(34,197,94,.13);color:#bbf7d0;border:1px solid rgba(34,197,94,.24)}.notice.error{background:rgba(239,68,68,.13);color:#fecaca;border:1px solid rgba(239,68,68,.25)}.stats-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-bottom:16px}.stat{padding:18px}.stat span{display:block;color:var(--muted);font-size:.9rem}.stat strong{font-size:1.5rem;color:#fde68a}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}.mini-table>div{display:grid;grid-template-columns:1fr auto auto;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}.mini-table em{font-style:normal;color:#fde68a}.admin-list{display:grid;gap:12px}.admin-list.slim{gap:8px}.inline-edit{display:grid;grid-template-columns:2fr 1.2fr .8fr .7fr .7fr auto auto auto;gap:10px;align-items:end}.inline-edit label{font-size:.82rem;color:var(--muted)}.inline-edit .text-input{margin-top:5px}.check{display:flex!important;gap:8px;align-items:center;color:var(--text)!important}.slim-form{grid-template-columns:2fr .6fr auto auto}.compact-form{padding:14px}.form-grid{display:grid;gap:12px;max-width:600px}.summary-box{display:grid;grid-template-columns:1fr auto;gap:8px;background:rgba(255,255,255,.04);padding:14px;border-radius:16px}.summary-box strong{color:#fde68a} code{background:rgba(255,255,255,.07);padding:2px 6px;border-radius:6px}
@media (max-width:1050px){.orders-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stats-grid{grid-template-columns:repeat(3,1fr)}.inline-edit{grid-template-columns:1fr 1fr}.login-shell{grid-template-columns:1fr}.product-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){.topbar{align-items:flex-start;flex-direction:column}.top-actions{width:100%}.login-body{place-items:start}.brand-card{padding:28px}.employee-grid{grid-template-columns:1fr}.waiter-layout{padding:12px 12px 330px}.category-strip{top:116px}.product-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.product-card{min-height:96px;padding:13px}.cart-drawer{bottom:8px;border-radius:22px}.payment-grid{grid-template-columns:1fr 1fr 1fr}.orders-grid{grid-template-columns:1fr}.order-actions{grid-template-columns:1fr}.admin-shell{grid-template-columns:1fr;padding:12px}.admin-nav{position:static;display:flex;overflow:auto}.navbtn{white-space:nowrap}.stats-grid{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr}.mini-table>div{grid-template-columns:1fr auto}.mini-table em{grid-column:1/-1}.inline-edit,.slim-form{grid-template-columns:1fr}.admin-topbar h1{font-size:1.5rem}.pin-box{padding:22px}}
@media (max-width:390px){.product-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr}.cart-items{max-height:130px}}

/* === v1.2 Mobile-First Update: bessere Handy-/Tablet-Bedienung + sichtbarer Kellner an der Theke === */
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body.app-body{min-height:100dvh;overflow-x:hidden}.topbar{padding:calc(12px + env(safe-area-inset-top)) 14px 12px}.topbar h1{line-height:1.05}.top-actions .ghost,.top-actions .primary{min-height:42px;display:inline-flex;align-items:center;justify-content:center}.waiter-layout,.bar-layout{width:100%;padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}

/* Kellner: auf dem Handy nimmt der Warenkorb leer kaum Platz weg */
.cart-drawer{max-height:calc(100dvh - 96px);overflow:auto;overscroll-behavior:contain;padding-bottom:calc(16px + env(safe-area-inset-bottom))}.cart-drawer.cart-empty{padding:12px 14px calc(12px + env(safe-area-inset-bottom));border-radius:20px}.cart-drawer.cart-empty .cart-items,.cart-drawer.cart-empty .note,.cart-drawer.cart-empty .payment-grid,.cart-drawer.cart-empty .send,.cart-drawer.cart-empty #clearCart{display:none}.cart-drawer.cart-empty .cart-head strong{font-size:1.15rem}.cart-row strong{font-size:1rem}.qty button,.pay,.product-card,.chip,.cat{touch-action:manipulation}.product-card:active,.chip:active,.cat:active,.pay:active{transform:scale(.985)}.send{position:sticky;bottom:0;z-index:2;box-shadow:0 -10px 24px rgba(17,24,39,.85)}

/* Theke: Kellner wird prominent auf jeder Bestellkarte angezeigt */
.bar-toolbar{position:sticky;top:86px;z-index:4;background:linear-gradient(180deg,rgba(15,23,42,.98),rgba(15,23,42,.82));padding:10px 0 12px;margin:-4px 0 14px;border-bottom:1px solid rgba(255,255,255,.06)}.bar-live-row{display:flex;align-items:center;gap:10px;overflow:auto;padding-bottom:8px}.bar-live-row .ghost,.bar-live-row .stat-pill{flex:0 0 auto}.employee-filter{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 4px;scrollbar-width:none}.employee-filter::-webkit-scrollbar,.category-strip::-webkit-scrollbar{display:none}.employee-filter-chip{--waiter-color:#f59e0b;display:flex;align-items:center;gap:8px;white-space:nowrap;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.05);color:var(--text);padding:9px 12px;min-height:42px}.employee-filter-chip.active{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.65);color:#fde68a}.employee-filter-chip em{font-style:normal;min-width:24px;height:24px;border-radius:999px;background:rgba(255,255,255,.1);display:grid;place-items:center;font-size:.82rem}.waiter-dot{width:13px;height:13px;border-radius:50%;background:var(--waiter-color);box-shadow:0 0 0 4px color-mix(in srgb,var(--waiter-color) 22%,transparent)}.waiter-badge{--waiter-color:#f59e0b;display:grid;grid-template-columns:auto auto 1fr;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;border-radius:16px;background:linear-gradient(135deg,color-mix(in srgb,var(--waiter-color) 26%,transparent),rgba(255,255,255,.045));border:1px solid color-mix(in srgb,var(--waiter-color) 42%,rgba(255,255,255,.08))}.waiter-badge .waiter-label{font-size:.76rem;text-transform:uppercase;letter-spacing:.09em;color:#e5e7eb;font-weight:900}.waiter-badge strong{font-size:1.25rem;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.order-card{display:flex;flex-direction:column;gap:2px}.order-head{align-items:flex-start}.order-head h2{font-size:clamp(1.35rem,5vw,1.95rem);line-height:1.05}.order-head>strong{font-size:clamp(1.25rem,5vw,1.8rem);white-space:nowrap}.order-meta{margin:8px 0 10px}.status-chip{background:rgba(56,189,248,.14)!important;color:#bae6fd!important}.order-items li{display:flex;gap:8px;align-items:baseline;font-size:clamp(1.08rem,4.6vw,1.38rem);line-height:1.25}.order-items li b{min-width:44px;font-size:1.15em}.order-actions button{min-height:48px;font-weight:900}.order-card.new-pop{animation:kpPop .32s ease-out}@keyframes kpPop{from{transform:scale(.985);box-shadow:0 0 0 3px rgba(245,158,11,.35)}to{transform:scale(1)}}

@media (max-width:760px){
  .topbar{gap:10px}.topbar.compact{display:grid;grid-template-columns:1fr;align-items:start}.topbar.compact h1{font-size:1.35rem}.top-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.top-actions .ghost{width:100%;padding:10px 8px}.waiter-layout{padding-top:12px;padding-bottom:150px}.panel{padding:14px;border-radius:20px}.panel-head{align-items:flex-start}.category-strip{top:112px;margin-left:-12px;margin-right:-12px;padding:10px 12px}.cat{padding:10px 13px}.product-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.product-card{min-height:104px;border-radius:18px;padding:13px}.product-card strong{font-size:1rem;line-height:1.15}.cart-drawer:not(.cart-empty){width:100%;left:0;right:0;bottom:0;transform:none;border-radius:24px 24px 0 0;border-left:0;border-right:0}.cart-drawer.cart-empty{left:50%;width:min(520px,calc(100% - 18px))}.cart-head strong{font-size:1.3rem}.cart-items{max-height:34dvh}.payment-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.pay{padding:12px 8px}.bar-layout{padding-top:10px}.bar-toolbar{top:126px;margin-left:-12px;margin-right:-12px;padding-left:12px;padding-right:12px}.bar-live-row{gap:8px}.orders-grid{grid-template-columns:1fr;gap:12px}.order-card{padding:14px;border-radius:20px}.order-meta span{font-size:.8rem}.order-actions{grid-template-columns:1fr;gap:8px}.empty-state{padding:44px 14px}.stat-pill{padding:10px 12px}.employee-filter-chip{padding:9px 11px}
}
@media (min-width:761px){
  .topbar{flex-direction:row;align-items:center}.bar-toolbar{top:78px}.top-actions{width:auto}.orders-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.order-actions{grid-template-columns:1fr 1fr 1fr}
}
@media (min-width:1180px){.orders-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.product-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}


/* === v1.3 Mobile-Warenkorb-Fix: Getränkekacheln bleiben auswählbar === */
:root{--cart-space:260px}
.waiter-layout{padding-bottom:var(--cart-space,260px)!important}
.cart-toggle{display:none;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.07);color:var(--text);font-weight:900;padding:8px 12px;min-height:38px}
@media (max-width:760px){
  .waiter-layout{padding-bottom:var(--cart-space,180px)!important}
  .cart-head{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:8px}
  .cart-toggle{display:inline-flex;align-items:center;justify-content:center}
  .cart-drawer:not(.cart-empty){max-height:72dvh;overflow:auto}
  .cart-drawer.cart-collapsed{padding:10px 12px calc(10px + env(safe-area-inset-bottom));max-height:none}
  .cart-drawer.cart-collapsed .cart-items,
  .cart-drawer.cart-collapsed .note,
  .cart-drawer.cart-collapsed .payment-grid,
  .cart-drawer.cart-collapsed #clearCart{display:none}
  .cart-drawer.cart-collapsed .send{margin-top:10px;padding:13px 14px;position:static;box-shadow:none}
  .cart-drawer.cart-collapsed .cart-head strong{font-size:1.22rem}
  .cart-items{max-height:28dvh}
}
@media (max-width:390px){
  .cart-head{grid-template-columns:1fr auto;grid-template-areas:'title total' 'toggle toggle'}
  .cart-head>div{grid-area:title}.cart-head>strong{grid-area:total}.cart-toggle{grid-area:toggle;width:100%}
}

/* === v1.4 echter Mobile-First-Warenkorb-Fix ===
   Der Warenkorb liegt auf Handys nicht mehr als Overlay über den Getränken.
   Stattdessen bekommt die Kellnerseite ein festes App-Layout: oben Kopfbereich,
   in der Mitte eine eigene scrollbare Getränkeliste, unten der Warenkorb als echte Fußleiste.
   Dadurch können Getränkebuttons nicht mehr vom Warenkorb verdeckt werden. */
@media (max-width:760px){
  body.waiter-body{
    height:100dvh;
    min-height:100dvh;
    overflow:hidden;
    display:flex;
    flex-direction:column;
  }
  body.waiter-body > .topbar{
    position:relative;
    top:auto;
    flex:0 0 auto;
    z-index:10;
  }
  body.waiter-body .waiter-layout{
    flex:1 1 auto;
    min-height:0;
    width:100%;
    max-width:none;
    overflow-y:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
    margin:0;
    padding:12px 12px 18px!important;
  }
  body.waiter-body .category-strip{
    position:sticky;
    top:0;
    z-index:6;
    margin-left:-12px;
    margin-right:-12px;
    padding:10px 12px;
    background:linear-gradient(180deg,rgba(15,23,42,.99),rgba(15,23,42,.88));
  }
  body.waiter-body .product-grid{
    padding-bottom:18px;
  }
  body.waiter-body .cart-drawer,
  body.waiter-body .cart-drawer:not(.cart-empty),
  body.waiter-body .cart-drawer.cart-empty{
    position:relative!important;
    left:auto!important;
    right:auto!important;
    bottom:auto!important;
    transform:none!important;
    flex:0 0 auto;
    width:100%!important;
    max-width:none!important;
    max-height:45dvh;
    overflow:auto;
    border-radius:22px 22px 0 0;
    border-left:0;
    border-right:0;
    border-bottom:0;
    margin:0;
    z-index:20;
    padding:12px 12px calc(12px + env(safe-area-inset-bottom));
  }
  body.waiter-body .cart-drawer.cart-collapsed{
    max-height:none;
    overflow:visible;
  }
  body.waiter-body .cart-head{
    display:grid;
    grid-template-columns:1fr auto auto;
    align-items:center;
    gap:8px;
  }
  body.waiter-body .cart-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
  body.waiter-body .cart-items{
    max-height:22dvh;
  }
  body.waiter-body .send{
    position:static;
    box-shadow:none;
  }
  body.waiter-body .toast{
    bottom:calc(16px + env(safe-area-inset-bottom));
    max-width:calc(100% - 24px);
    border-radius:18px;
    text-align:center;
  }
}
@media (max-width:390px){
  body.waiter-body .cart-head{
    grid-template-columns:1fr auto;
    grid-template-areas:'title total' 'toggle toggle';
  }
  body.waiter-body .cart-head>div{grid-area:title}
  body.waiter-body .cart-head>strong{grid-area:total}
  body.waiter-body .cart-toggle{grid-area:toggle;width:100%}
}

/* === v1.5 Kellner-Bestellverlauf === */
.history-drawer{position:fixed;inset:0;z-index:80;display:none}.history-drawer.open{display:block}.history-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.72);backdrop-filter:blur(7px)}.history-panel{position:absolute;right:0;top:0;bottom:0;width:min(520px,100%);background:rgba(15,23,42,.98);border-left:1px solid var(--line);box-shadow:var(--shadow);padding:calc(18px + env(safe-area-inset-top)) 16px calc(16px + env(safe-area-inset-bottom));overflow:auto;overscroll-behavior:contain}.history-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.history-head h2{margin:0;font-size:1.8rem}.history-head .muted{margin:5px 0 0}.history-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:12px}.history-summary>div{border:1px solid var(--line);background:rgba(255,255,255,.045);border-radius:16px;padding:10px}.history-summary span{display:block;color:var(--muted);font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.history-summary strong{display:block;margin-top:4px;color:#fde68a;font-size:1.05rem}.history-actions{display:grid;grid-template-columns:1fr auto;gap:8px;margin-bottom:12px}.history-list{display:grid;gap:10px}.history-order{border:1px solid var(--line);background:rgba(255,255,255,.045);border-radius:18px;padding:13px;border-left:5px solid #f59e0b}.history-order.in_progress{border-left-color:#38bdf8}.history-order.done{border-left-color:#22c55e}.history-order.cancelled{border-left-color:#ef4444;opacity:.82}.history-order-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.history-order-top b{display:block;color:var(--muted);font-size:.82rem}.history-order-top strong{font-size:1.18rem}.history-order-top em{font-style:normal;color:#fde68a;font-weight:900;white-space:nowrap;font-size:1.1rem}.history-order-meta{display:flex;gap:6px;flex-wrap:wrap;margin:9px 0}.history-order-meta span{font-size:.8rem;border-radius:999px;background:rgba(255,255,255,.07);padding:6px 8px;color:#e5e7eb}.history-status{background:rgba(245,158,11,.15)!important;color:#fde68a!important;font-weight:900}.history-order p{margin:6px 0 0;color:#f8fafc;line-height:1.35}.history-order small{display:block;margin-top:8px;color:#fde68a}.empty-history{border:1px dashed var(--line);border-radius:18px;padding:22px;text-align:center;color:var(--muted)}.empty-history strong{display:block;color:#fff;margin-bottom:6px}body.history-open{overflow:hidden}
@media (max-width:760px){.history-panel{width:100%;border-left:0;border-radius:0;padding:calc(14px + env(safe-area-inset-top)) 12px calc(14px + env(safe-area-inset-bottom))}.history-head{align-items:center}.history-head h2{font-size:1.45rem}.history-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.history-actions{grid-template-columns:1fr 1fr}.history-order{border-radius:16px;padding:12px}.history-order-top strong{font-size:1.08rem}.history-order-top em{font-size:1rem}.top-actions{grid-template-columns:repeat(auto-fit,minmax(84px,1fr))}}

/* === v1.6 Zahlungsworkflow über Kellner-Verlauf === */
.pay-later{margin:12px 0 10px;padding:10px 12px;border:1px solid rgba(56,189,248,.22);background:rgba(56,189,248,.10);border-radius:14px;color:#bae6fd;font-weight:800}
.history-filters{display:flex;gap:8px;overflow-x:auto;margin:-2px 0 12px;padding-bottom:2px;scrollbar-width:none}.history-filters::-webkit-scrollbar{display:none}.history-filters button{flex:0 0 auto;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.05);color:var(--text);padding:9px 11px;font-weight:900}.history-filters button.active{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.65);color:#fde68a}.history-order.collect{border-left-color:#f59e0b;background:linear-gradient(135deg,rgba(245,158,11,.13),rgba(255,255,255,.045))}.history-order.paid{border-left-color:#22c55e}.payment-status{font-weight:900!important}.payment-status.paid{background:rgba(34,197,94,.15)!important;color:#bbf7d0!important}.payment-status.collect{background:rgba(245,158,11,.18)!important;color:#fde68a!important}.payment-status.open{background:rgba(148,163,184,.12)!important;color:#cbd5e1!important}.history-pay-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-top:12px}.history-pay-actions .primary{border-radius:16px;min-height:48px}.order-card.done{border-top-color:#22c55e}.status-chip{font-weight:900}.stat.warn strong{color:#fdba74}.mini-table .unpaid-row em{color:#fdba74}
@media (max-width:760px){.history-pay-actions{grid-template-columns:1fr}.history-pay-actions .primary{min-height:52px}.pay-later{font-size:.9rem}.history-filters{margin-left:-2px;margin-right:-2px}}
.cart-drawer.cart-empty .pay-later,.cart-drawer.cart-collapsed .pay-later{display:none}

/* Version 1.7: Kassierhilfe mit Rückgeld & Trinkgeld */
.pay-modal{position:fixed;inset:0;z-index:110;display:none}.pay-modal.open{display:block}.pay-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.76);backdrop-filter:blur(8px)}.pay-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(480px,calc(100% - 22px));max-height:calc(100dvh - 22px);overflow:auto;background:rgba(15,23,42,.98);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:18px}.pay-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.pay-head h2{margin:0;font-size:1.65rem}.pay-head .muted{margin:4px 0 0}.pay-total-card{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid rgba(245,158,11,.26);background:linear-gradient(135deg,rgba(245,158,11,.14),rgba(255,255,255,.045));border-radius:20px;padding:14px 16px;margin-bottom:14px}.pay-total-card span,.pay-result-grid span{display:block;color:var(--muted);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.pay-total-card strong{font-size:1.8rem;color:#fde68a}.pay-mode-box label{display:block;margin-bottom:10px;font-weight:900;color:#e5e7eb}.pay-mode-box .text-input{margin-top:7px;font-size:1.25rem;font-weight:900}.quick-pay-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:-2px 0 12px}.pay-result-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.pay-result-grid>div{border:1px solid var(--line);background:rgba(255,255,255,.045);border-radius:18px;padding:12px}.pay-result-grid strong{display:block;margin-top:4px;color:#fde68a;font-size:1.18rem}.pay-actions{display:grid;grid-template-columns:1fr 1.3fr;gap:10px;margin-top:14px}.pay-actions button{min-height:50px;border-radius:16px}.error-text{color:#fecaca!important;font-weight:900}body.pay-open{overflow:hidden}.pay-modal .primary:disabled{opacity:.55;filter:grayscale(.4);cursor:not-allowed}
@media (max-width:760px){.pay-panel{left:0;right:0;bottom:0;top:auto;transform:none;width:100%;max-height:92dvh;border-radius:26px 26px 0 0;padding:16px 12px calc(14px + env(safe-area-inset-bottom))}.pay-head h2{font-size:1.42rem}.pay-total-card strong{font-size:1.5rem}.pay-result-grid,.pay-actions{grid-template-columns:1fr}.quick-pay-buttons{grid-template-columns:1fr 1fr}.pay-mode-box .text-input{font-size:1.15rem}}


/* v1.9 - mittige Kontrollabfrage und Kellner-Storno */
.send-confirm-modal,.cancel-modal{position:fixed;inset:0;z-index:120;display:none}
.send-confirm-modal.open,.cancel-modal.open{display:block}
.send-confirm-backdrop,.cancel-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.78);backdrop-filter:blur(8px)}
.send-confirm-panel,.cancel-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(500px,calc(100% - 22px));max-height:calc(100dvh - 22px);overflow:auto;background:rgba(15,23,42,.98);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:18px}
.send-confirm-head,.cancel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.send-confirm-head h2,.cancel-head h2{margin:0;font-size:1.55rem}
.confirm-total-card{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:stretch;margin-bottom:12px}
.confirm-total-card>div{border:1px solid rgba(245,158,11,.26);background:linear-gradient(135deg,rgba(245,158,11,.14),rgba(255,255,255,.045));border-radius:18px;padding:12px 14px}
.confirm-total-card span{display:block;color:var(--muted);font-size:.76rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em}
.confirm-total-card strong{display:block;margin-top:4px;color:#fde68a;font-size:1.2rem}
.confirm-items{display:grid;gap:8px;margin:10px 0 12px}
.confirm-item{display:flex;justify-content:space-between;gap:10px;border:1px solid var(--line);background:rgba(255,255,255,.045);border-radius:15px;padding:10px 12px}
.confirm-item b{color:#f8fafc}.confirm-item span{color:var(--muted)}
.confirm-note{border:1px dashed rgba(245,158,11,.45);border-radius:16px;padding:10px 12px;color:#fde68a;margin:0 0 12px}
.confirm-actions,.cancel-actions{display:grid;grid-template-columns:1fr 1.35fr;gap:10px;margin-top:14px}
.confirm-actions button,.cancel-actions button{min-height:50px;border-radius:16px}
.cancel-warning{border:1px solid rgba(239,68,68,.35);background:rgba(239,68,68,.12);color:#fecaca;border-radius:18px;padding:12px 14px;line-height:1.35;margin-bottom:12px}
.cancel-label{display:block;font-weight:900;color:#e5e7eb}.cancel-label .text-input{margin-top:7px}
.history-cancel-action .danger{width:100%;min-height:48px;border-radius:16px}
.history-order.cancelled .history-status{background:rgba(239,68,68,.16)!important;color:#fecaca!important}
body.send-confirm-open,body.cancel-open{overflow:hidden}
@media (max-width:760px){.send-confirm-panel,.cancel-panel{width:calc(100% - 18px);border-radius:24px;padding:16px}.send-confirm-head h2,.cancel-head h2{font-size:1.35rem}.confirm-total-card{grid-template-columns:1fr}.confirm-actions,.cancel-actions{grid-template-columns:1fr}.confirm-actions .primary,.cancel-actions .danger{order:-1}}

/* v1.10 Schichtstart, Hamburger-Menü und Kellner-Abrechnung */
.menu-button{width:44px;height:44px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.06);color:#fff;font-size:1.45rem;font-weight:900;display:grid;place-items:center;line-height:1}.menu-button:hover{background:rgba(245,158,11,.16);border-color:rgba(245,158,11,.45)}
.shift-start-shell{width:min(1080px,100%);display:grid;grid-template-columns:.85fr 1.15fr;gap:22px}.shift-brand h1{font-size:clamp(1.9rem,4.5vw,3.3rem)}.shift-start-card h2{margin:0 0 14px}.shift-subtitle{margin-top:22px!important}.time-choice-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px;max-height:45vh;overflow:auto;padding:1px}.time-choice-grid.compact{grid-template-columns:repeat(4,minmax(0,1fr));max-height:260px;margin-bottom:12px}.time-choice,.task-choice{border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--text);border-radius:18px;padding:12px;min-height:66px}.time-choice strong{display:block;font-size:1.25rem;color:#fff}.time-choice span{display:block;margin-top:3px;color:var(--muted);font-size:.82rem}.time-choice.active,.task-choice.active{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.7);color:#fde68a}.task-choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}.task-choice{font-weight:900;font-size:1.08rem}.time-input-card{display:grid;gap:8px;border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:22px;padding:16px;margin-bottom:8px}.time-input-card span{font-weight:900;color:#fff}.time-input-card input{width:100%;border:1px solid var(--line);background:rgba(15,23,42,.86);color:#fff;border-radius:18px;padding:16px;font-size:1.55rem;font-weight:900;letter-spacing:.04em}.time-input-card small{color:var(--muted);line-height:1.35}
.side-menu,.shift-accounting-modal{position:fixed;inset:0;z-index:130;display:none}.side-menu.open,.shift-accounting-modal.open{display:block}.side-menu-backdrop,.shift-accounting-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.72);backdrop-filter:blur(8px)}.side-menu-panel{position:absolute;right:0;top:0;bottom:0;width:min(390px,100%);background:rgba(15,23,42,.98);border-left:1px solid var(--line);box-shadow:var(--shadow);padding:calc(18px + env(safe-area-inset-top)) 16px calc(16px + env(safe-area-inset-bottom));overflow:auto}.side-menu-head,.shift-accounting-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.side-menu-head h2,.shift-accounting-head h2{margin:0;font-size:1.55rem}.side-menu-list{display:grid;gap:10px}.side-menu-item{display:block;text-align:left;border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:20px;padding:15px;color:var(--text);width:100%}.side-menu-item strong{display:block;font-size:1.08rem}.side-menu-item span{display:block;color:var(--muted);font-size:.9rem;margin-top:4px}.side-menu-item:hover{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.35)}.logout-item{margin-top:4px}.shift-accounting-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(560px,calc(100% - 22px));max-height:calc(100dvh - 22px);overflow:auto;background:rgba(15,23,42,.98);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:18px}.shift-accounting-actions{display:grid;grid-template-columns:1fr;margin:10px 0}.shift-summary-box{margin-top:12px;border:1px solid rgba(245,158,11,.26);background:linear-gradient(135deg,rgba(245,158,11,.12),rgba(255,255,255,.045));border-radius:22px;padding:14px}.summary-title{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:10px}.summary-title strong{font-size:1.22rem}.summary-title span{color:#fde68a;font-weight:900}.shift-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.shift-summary-grid>div{border:1px solid var(--line);background:rgba(2,6,23,.25);border-radius:16px;padding:10px}.shift-summary-grid span{display:block;color:var(--muted);font-size:.75rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.shift-summary-grid strong{display:block;color:#fde68a;font-size:1.1rem;margin-top:4px}.shift-warning{border:1px solid rgba(245,158,11,.36);background:rgba(245,158,11,.12);border-radius:16px;padding:10px 12px;color:#fde68a;font-weight:800}body.side-menu-open,body.shift-accounting-open{overflow:hidden}
@media (max-width:760px){.shift-start-shell{grid-template-columns:1fr;gap:14px}.shift-brand{padding:26px}.shift-start-card{padding:18px}.time-choice-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-height:none}.time-choice-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr));max-height:45vh}.side-menu-panel{width:88%;border-radius:26px 0 0 26px}.shift-accounting-panel{left:0;right:0;bottom:0;top:auto;transform:none;width:100%;max-height:92dvh;border-radius:26px 26px 0 0;padding:16px 12px calc(14px + env(safe-area-inset-bottom))}.shift-summary-grid{grid-template-columns:1fr}.top-actions .ghost[href="logout.php"]{display:none}.menu-button{width:42px;height:42px}}
/* v2.0 Master-Admin / Multi-Kneipe */
.as-link{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.public-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.slug-form{display:grid;gap:14px}.public-home-shell{align-items:stretch}.public-hero h1{font-size:clamp(2.1rem,5vw,4.4rem)}
@media (max-width:760px){.public-actions .primary{width:100%}.login-shell.public-home-shell{grid-template-columns:1fr}.form-grid[style]{grid-template-columns:1fr!important}}

/* v2.2 Mitarbeiter-Erstlogin-PIN und Systemfarben */
.field-hint{display:block;margin-top:6px;color:var(--muted);font-size:.78rem;line-height:1.25;font-weight:700}.employee-edit-form{align-items:end}.employee-system-color{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:rgba(255,255,255,.045);border-radius:16px;padding:10px 12px;min-height:54px}.employee-system-color .employee-dot{width:18px;height:18px;border-radius:999px;background:var(--emp);box-shadow:0 0 0 5px color-mix(in srgb,var(--emp) 20%,transparent);flex:0 0 auto}.employee-system-color strong{display:block;color:#f8fafc}.employee-system-color small{display:block;color:var(--muted);font-weight:700;font-size:.78rem;line-height:1.25}.employee-pin-state{border-radius:999px;padding:9px 11px;font-size:.8rem;font-weight:900;text-align:center;white-space:nowrap}.employee-pin-state.needs{background:rgba(245,158,11,.16);color:#fde68a;border:1px solid rgba(245,158,11,.35)}.employee-pin-state.ready{background:rgba(34,197,94,.14);color:#bbf7d0;border:1px solid rgba(34,197,94,.32)}.pin-box .hint{margin:8px 0 10px;color:#cbd5e1}.pin-box #pinConfirmInput{margin-top:9px}.employee-card small{line-height:1.25}
@media(max-width:760px){.employee-system-color{grid-column:1/-1}.employee-pin-state{grid-column:1/-1;white-space:normal}.field-hint{font-size:.76rem}}

/* v2.4: schnellere Schichtzeit-Auswahl über -15/+15 statt normalem Uhrzeitfeld */
.shift-time-stepper{display:grid;grid-template-columns:minmax(92px,.78fr) minmax(0,1.4fr) minmax(92px,.78fr);gap:10px;align-items:stretch;margin:4px 0 12px}.stepper-btn{border:1px solid rgba(245,158,11,.34);background:rgba(245,158,11,.12);color:#fde68a;border-radius:22px;padding:14px 10px;font-weight:950;font-size:1rem;min-height:92px}.stepper-btn:disabled{opacity:.42;filter:grayscale(.35)}.stepper-display{border:1px solid rgba(245,158,11,.28);background:linear-gradient(135deg,rgba(245,158,11,.16),rgba(255,255,255,.055));border-radius:26px;padding:15px 12px;text-align:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}.stepper-display span{display:block;color:var(--muted);font-size:.78rem;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.stepper-display strong{display:block;color:#fff;font-size:clamp(2.05rem,8vw,3.35rem);line-height:1.02;margin:6px 0 6px;letter-spacing:.01em}.stepper-display small{display:block;color:#fde68a;font-weight:800;line-height:1.28}.stepper-now{margin:0 0 8px;min-height:46px;border-radius:18px}.shift-start-form .error{margin-top:12px}
@media (max-width:520px){.shift-time-stepper{grid-template-columns:1fr 1fr;grid-template-areas:"display display" "minus plus";gap:9px}.stepper-display{grid-area:display}.stepper-btn{min-height:58px}.stepper-btn#shiftMinus{grid-area:minus}.stepper-btn#shiftPlus{grid-area:plus}.stepper-display strong{font-size:3rem}.stepper-display small{font-size:.84rem}}

/* v2.6 – Mitarbeiter-PIN-Reset */
.form-actions-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:4px}.danger-soft{border-color:rgba(239,68,68,.35)!important;color:#b91c1c!important;background:rgba(254,226,226,.65)!important}.danger-soft:hover{background:rgba(254,202,202,.9)!important}

/* === v2.7 Rollen/Aufgaben + Drag-&-Drop Admin === */
.task-choice-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:560px){.task-choice-grid{grid-template-columns:1fr}.task-choice{min-height:58px}}
.role-switch-link{position:relative;gap:7px}.switch-badge{min-width:22px;height:22px;border-radius:999px;background:#ef4444;color:#fff;display:inline-grid;place-items:center;font-size:.78rem;font-weight:1000;padding:0 7px;box-shadow:0 0 0 3px rgba(239,68,68,.18)}.switch-badge[hidden]{display:none!important}.switch-badge.pulse{animation:badgePulse .9s ease-in-out infinite alternate}@keyframes badgePulse{from{transform:scale(1)}to{transform:scale(1.08)}}
.employee-role-form{grid-template-columns:1.6fr 1fr .8fr 1fr auto auto}.product-edit-form{grid-template-columns:1.7fr 1.1fr .7fr .7fr auto auto auto}.category-edit-form,.table-edit-form{grid-template-columns:1fr auto auto}.admin-help-card{margin-bottom:12px}.admin-help-card strong{display:block;margin-bottom:4px;color:#fde68a}.sortable-list{display:grid;gap:10px;margin-top:12px}.sort-item{display:grid;grid-template-columns:44px 1fr;gap:10px;align-items:stretch}.sort-item>.panel{margin:0}.drag-handle{border:1px solid var(--line);background:rgba(255,255,255,.07);color:#fde68a;border-radius:16px;font-size:1.25rem;font-weight:1000;cursor:grab;touch-action:none;min-height:50px}.drag-handle:active{cursor:grabbing}.sort-item.dragging{opacity:.55}.sortable-list.saving{opacity:.72}.sortable-list.saved::after{content:'Reihenfolge gespeichert';display:block;color:#bbf7d0;font-weight:900;padding:8px 4px}.category-product-groups{display:grid;gap:18px}.product-group{border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:12px;background:rgba(255,255,255,.025)}
@media (max-width:1050px){.employee-role-form,.product-edit-form{grid-template-columns:1fr 1fr}.category-edit-form,.table-edit-form{grid-template-columns:1fr auto}.sort-item{grid-template-columns:38px 1fr}.drag-handle{min-height:44px}}
@media (max-width:760px){.employee-role-form,.product-edit-form,.category-edit-form,.table-edit-form{grid-template-columns:1fr}.sort-item{grid-template-columns:42px minmax(0,1fr);align-items:start}.drag-handle{position:sticky;top:8px}.top-actions .role-switch-link{width:100%}}

/* === v2.9 Schichtenübersicht & Admin-Abschlusszeit === */
.shift-admin-list{display:grid;gap:10px}.shift-admin-card{border:1px solid var(--line);background:rgba(255,255,255,.045);border-radius:20px;overflow:hidden}.shift-admin-card.active{border-color:rgba(245,158,11,.38);background:linear-gradient(135deg,rgba(245,158,11,.10),rgba(255,255,255,.04))}.shift-admin-card summary{list-style:none;display:grid;grid-template-columns:30px minmax(0,1.3fr) minmax(110px,.8fr) minmax(96px,.7fr) minmax(90px,.7fr);gap:10px;align-items:center;padding:13px 14px;cursor:pointer}.shift-admin-card summary::-webkit-details-marker{display:none}.shift-admin-card summary strong{font-size:1.02rem}.shift-admin-card summary em{font-style:normal;color:#e5e7eb;font-weight:800}.shift-admin-card summary b{color:#fde68a}.shift-admin-card summary small{color:var(--muted);font-weight:900}.shift-admin-card .employee-dot{width:18px;height:18px;border-radius:999px;background:var(--emp);box-shadow:0 0 0 5px color-mix(in srgb,var(--emp) 20%,transparent)}.shift-admin-detail{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px;padding:0 14px 14px}.shift-admin-detail>div{border:1px solid var(--line);background:rgba(2,6,23,.22);border-radius:16px;padding:10px}.shift-admin-detail span{display:block;color:var(--muted);font-size:.74rem;font-weight:950;text-transform:uppercase;letter-spacing:.06em}.shift-admin-detail strong{display:block;margin-top:4px;color:#fde68a;font-size:1.06rem}.admin-close-time{grid-column:1/-1;border:1px solid rgba(245,158,11,.22);background:rgba(245,158,11,.075);border-radius:22px;padding:14px}.admin-close-time>span{display:block;color:#fff;font-weight:950;margin-bottom:10px}.admin-close-stepper{margin-bottom:10px}.admin-close-stepper .stepper-btn{min-height:70px}.admin-close-stepper .stepper-display strong{font-size:clamp(1.9rem,6vw,2.8rem)}
@media (max-width:900px){.shift-admin-card summary{grid-template-columns:26px 1fr;grid-template-areas:"dot name" "dot time" "dot work" "dot task";gap:4px 10px}.shift-admin-card .employee-dot{grid-area:dot}.shift-admin-card summary strong{grid-area:name}.shift-admin-card summary em{grid-area:time}.shift-admin-card summary b{grid-area:work}.shift-admin-card summary small{grid-area:task}.shift-admin-detail{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:560px){.shift-admin-detail{grid-template-columns:1fr}.admin-close-time{padding:12px}.admin-close-stepper .stepper-btn{min-height:56px}}

/* === v2.14 Thekenstatus, Verlauf-Aktionen, Abschlussübersicht/Historie === */
.order-card.in_progress{background:linear-gradient(135deg,rgba(56,189,248,.20),rgba(17,24,39,.90));border-color:rgba(56,189,248,.42);box-shadow:0 18px 40px rgba(14,165,233,.10)}
.order-card.in_progress .status-chip{background:rgba(56,189,248,.22)!important;color:#bae6fd!important}
.order-actions button[disabled]{opacity:.72;cursor:not-allowed;background:rgba(56,189,248,.12);border-color:rgba(56,189,248,.28);color:#bae6fd}
.history-order.in_progress{background:linear-gradient(135deg,rgba(56,189,248,.15),rgba(255,255,255,.045));border-left-color:#38bdf8}
.history-order.done.collect{background:linear-gradient(135deg,rgba(34,197,94,.16),rgba(255,255,255,.045));border-left-color:#22c55e}
.history-status.in-work{background:rgba(56,189,248,.20)!important;color:#bae6fd!important;border:1px solid rgba(56,189,248,.28)}
.history-status.ready{background:rgba(34,197,94,.20)!important;color:#bbf7d0!important;border:1px solid rgba(34,197,94,.28)}
.history-pay-actions.collect-actions{grid-template-columns:4fr 1fr;align-items:stretch}
.history-pay-actions.collect-actions .pay-main{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#111827;border:0;font-weight:1000}
.history-pay-actions.collect-actions .cancel-small{border-radius:16px;min-height:48px;font-weight:1000;background:#dc2626;border-color:#ef4444;color:#fff;padding-left:10px;padding-right:10px}
.closure-preview-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:14px 0}
.closure-preview-grid>div{border:1px solid var(--line);background:rgba(255,255,255,.045);border-radius:16px;padding:12px}
.closure-preview-grid span{display:block;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;font-weight:900}.closure-preview-grid strong{display:block;margin-top:4px;color:#fde68a;font-size:1.1rem}.closure-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}.history-closure-list{display:grid;gap:10px}.closure-card{border:1px solid var(--line);background:rgba(255,255,255,.045);border-radius:18px;padding:14px}.closure-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.closure-card-top strong{font-size:1.15rem}.closure-downloads{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.closure-table{display:grid;gap:8px;margin-top:10px}.closure-table-row{display:grid;grid-template-columns:1.25fr .8fr .8fr .8fr .8fr;gap:8px;align-items:center;padding:9px;border-radius:12px;background:rgba(255,255,255,.04);font-size:.92rem}.closure-table-row b{color:#fff}.closure-table-row span{color:#dbeafe}
@media (max-width:760px){.history-pay-actions.collect-actions{grid-template-columns:4fr 1fr}.history-pay-actions.collect-actions .cancel-small{font-size:.86rem}.closure-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.closure-actions{grid-template-columns:1fr}.closure-card-top{display:block}.closure-table-row{grid-template-columns:1fr 1fr}.closure-table-row b{grid-column:1/-1}}

/* KneipenPilot 2.0: Slug-Struktur, Betriebssuche und Theken-Direktverkauf */
.top-subline{margin:.25rem 0 0;color:var(--muted,#64748b);font-size:.86rem}.top-subline strong{color:var(--text,#0f172a)}
.tenant-search-card .tenant-quick-list{display:grid;gap:.65rem;margin-top:1rem}.tenant-result{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;border:1px solid rgba(148,163,184,.35);border-radius:18px;text-decoration:none;color:inherit;background:rgba(255,255,255,.75)}.tenant-result:hover{border-color:rgba(245,158,11,.55);transform:translateY(-1px)}.tenant-result span{color:var(--muted,#64748b);font-size:.9rem}.bar-hub-layout{display:block}.bar-tabs{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:1fr 1fr;gap:.6rem;padding:.75rem max(1rem,env(safe-area-inset-left)) .5rem;background:linear-gradient(180deg,rgba(248,250,252,.98),rgba(248,250,252,.88));backdrop-filter:blur(12px)}.bar-tab{border:1px solid rgba(148,163,184,.35);background:#fff;border-radius:18px;padding:.9rem .8rem;font-weight:800;color:#0f172a;box-shadow:0 10px 28px rgba(15,23,42,.06)}.bar-tab.active{background:#111827;color:#fff;border-color:#111827}.bar-tab span{display:inline-grid;place-items:center;min-width:1.6rem;margin-left:.35rem;border-radius:999px;background:rgba(245,158,11,.18);color:#f59e0b;padding:.1rem .35rem}.bar-tab.active span{background:rgba(255,255,255,.18);color:#fff}.bar-pane{display:none}.bar-pane.active{display:block}.bar-direct-shell{display:grid;grid-template-columns:minmax(0,1fr) minmax(310px,390px);gap:1rem;padding:1rem}.bar-direct-products,.bar-direct-cart{min-width:0}.price-list-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .7rem;border-radius:999px;background:#f8fafc;border:1px solid rgba(148,163,184,.35);font-size:.85rem;color:#64748b}.price-list-pill strong{color:#0f172a}.category-strip.compact{margin:.75rem 0}.direct-product-grid{padding-bottom:1rem}.direct-product-card{min-height:96px}.cart-head.static{position:static}.direct-pay-box{display:grid;gap:.75rem;margin:.85rem 0}.direct-pay-box label{display:grid;gap:.35rem;font-weight:700;color:#334155}.bar-direct-cart .send{width:100%;margin-top:.35rem}.bar-direct-cart{position:sticky;top:5rem;align-self:start}.error{color:#b91c1c;font-weight:700}.danger-soft{color:#b91c1c!important;border-color:rgba(185,28,28,.2)!important;background:rgba(254,226,226,.6)!important}
@media (max-width: 900px){.bar-direct-shell{grid-template-columns:1fr;padding:.75rem}.bar-direct-cart{position:static}.bar-tabs{grid-template-columns:1fr}.tenant-result{align-items:flex-start;flex-direction:column}}
.price-list-form{display:grid;gap:.9rem}.price-list-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin:.75rem 0}.price-list-grid label{display:grid;gap:.35rem;font-weight:700;color:#334155}.price-list-card{border-left:5px solid rgba(245,158,11,.65)}


/* Update 24-06-2026: Bestellungen-Badges und Aufgabenwechsel */
.history-tab-button{display:inline-flex!important;align-items:center;gap:7px;white-space:nowrap}.history-badge{min-width:22px;height:22px;border-radius:999px;color:#fff;display:inline-grid;place-items:center;font-size:.78rem;font-weight:1000;padding:0 7px;line-height:1}.history-badge[hidden]{display:none!important}.history-badge-open{background:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.16)}.history-badge-ready{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.16)}.history-status.in-work{background:rgba(56,189,248,.18)!important;color:#7dd3fc!important}.history-status.ready{background:rgba(34,197,94,.18)!important;color:#86efac!important}.task-switch-modal{position:fixed;inset:0;z-index:140;display:none}.task-switch-modal.open{display:block}.task-switch-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.72);backdrop-filter:blur(8px)}.task-switch-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(520px,calc(100% - 22px));max-height:calc(100dvh - 22px);overflow:auto;background:rgba(15,23,42,.98);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:18px}.task-switch-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.task-switch-head h2{margin:0;font-size:1.55rem}.task-switch-grid{display:grid;gap:10px}.task-choice{text-align:left;border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:20px;padding:15px;color:var(--text);width:100%}.task-choice strong{display:block;font-size:1.1rem}.task-choice span{display:block;color:var(--muted);font-size:.9rem;margin-top:4px}.task-choice:hover,.task-choice.active{background:rgba(245,158,11,.13);border-color:rgba(245,158,11,.45)}.task-choice.active strong:after{content:' · aktuell';color:#fde68a;font-size:.9rem}body.task-switch-open{overflow:hidden}@media(max-width:520px){.history-tab-button{gap:5px}.history-badge{min-width:20px;height:20px;font-size:.72rem;padding:0 6px}}

/* Update 24-06-2026: Kellner-Sonderwünsche pro Warenkorbposition + Long-Press */
.cart-row-note{align-items:flex-start;flex-wrap:wrap}.cart-row-main{min-width:0;flex:1}.cart-item-name{display:block;width:100%;text-align:left;border:0;background:transparent;color:inherit;padding:0;margin:0;cursor:pointer}.cart-item-name strong{display:block}.cart-item-name small{display:block;margin-top:2px;color:var(--muted);font-size:.74rem;font-weight:800}.line-note,.order-item-note,.confirm-item-note{display:block;margin-top:5px;font-style:normal;color:#fde68a;font-size:.84rem;font-weight:850}.item-note-editor{flex:0 0 100%;margin-top:10px;padding:10px;border:1px solid rgba(245,158,11,.22);background:rgba(245,158,11,.08);border-radius:16px}.item-note-editor .hint{margin:0 0 8px}.item-note-input{margin-top:0;resize:vertical}.item-note-chips{display:flex;gap:7px;overflow-x:auto;padding:9px 1px 4px;scrollbar-width:none}.item-note-chips::-webkit-scrollbar{display:none}.item-note-chips button{flex:0 0 auto;border:1px solid rgba(148,163,184,.35);background:rgba(255,255,255,.07);color:var(--text);border-radius:999px;padding:8px 10px;font-weight:850}.item-note-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-top:8px}.item-note-actions .small{min-height:42px;padding:9px 11px}.mix-sheet{position:fixed;inset:0;z-index:150;display:none}.mix-sheet.open{display:block}.mix-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.72);backdrop-filter:blur(8px)}.mix-panel{position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:min(560px,100%);max-height:calc(100dvh - 20px);overflow:auto;background:rgba(15,23,42,.98);border:1px solid var(--line);border-bottom:0;border-radius:28px 28px 0 0;box-shadow:var(--shadow);padding:18px calc(16px + env(safe-area-inset-right)) calc(18px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left))}.mix-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.mix-head h2{margin:0;font-size:1.45rem}.mix-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.mix-option{min-height:52px;border:1px solid rgba(245,158,11,.28);background:rgba(245,158,11,.12);color:#fffbeb;border-radius:16px;padding:12px;font-weight:950;text-align:left}.mix-custom{margin-top:12px;display:grid;gap:10px}.mix-custom label{font-weight:900;color:#e5e7eb}body.mix-open{overflow:hidden}.order-items li{flex-wrap:wrap}.order-item-note{flex-basis:100%;margin-left:52px;color:#fef3c7;background:rgba(245,158,11,.10);border:1px solid rgba(245,158,11,.20);border-radius:10px;padding:6px 8px}.confirm-item-note{color:#fef3c7;font-size:.82rem}@media(max-width:520px){.cart-row-note{gap:8px}.cart-row-note .qty{margin-left:auto}.item-note-editor{padding:9px}.mix-options{grid-template-columns:1fr}.mix-panel{border-radius:24px 24px 0 0}.cart-item-name small{font-size:.7rem}}


/* Update 2.5: Bereichsauswahl für Tisch/Bereich per langem Druck */
.table-longpress-target{cursor:pointer;touch-action:manipulation}
.area-reset-chip{background:rgba(245,158,11,.14)!important;border-color:rgba(245,158,11,.45)!important;color:#fde68a!important;font-weight:900}.table-empty-hint{width:100%;margin:4px 0 0}.table-area-sheet{position:fixed;inset:0;z-index:155;display:none}.table-area-sheet.open{display:block}.table-area-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.72);backdrop-filter:blur(8px)}.table-area-panel{position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:min(560px,100%);max-height:calc(100dvh - 20px);overflow:auto;background:rgba(15,23,42,.98);border:1px solid var(--line);border-bottom:0;border-radius:28px 28px 0 0;box-shadow:var(--shadow);padding:18px calc(16px + env(safe-area-inset-right)) calc(18px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left))}.table-area-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.table-area-head h2{margin:0;font-size:1.45rem}.table-area-options{display:flex;gap:8px;overflow-x:auto;padding:1px 1px 10px;scrollbar-width:none}.table-area-options::-webkit-scrollbar{display:none}.table-area-option{flex:0 0 auto;border:1px solid rgba(148,163,184,.35);background:rgba(255,255,255,.07);color:var(--text);border-radius:999px;padding:10px 12px;font-weight:900}.table-area-option.active{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.65);color:#fde68a}.table-area-list{display:grid;gap:9px}.table-area-list-title{margin:2px 0 0;color:#cbd5e1;font-size:.84rem;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.table-area-table{width:100%;min-height:54px;text-align:left;border:1px solid rgba(148,163,184,.28);background:rgba(255,255,255,.055);color:var(--text);border-radius:16px;padding:12px 13px}.table-area-table strong{display:block;font-size:1rem}.table-area-table span{display:block;margin-top:3px;color:var(--muted);font-size:.82rem;font-weight:800}.table-area-table.active{background:rgba(245,158,11,.16);border-color:rgba(245,158,11,.55);color:#fde68a}body.table-area-open{overflow:hidden}@media(max-width:520px){.table-area-panel{border-radius:24px 24px 0 0}.table-area-head{gap:8px}.table-area-options{margin-left:-2px;margin-right:-2px}.table-area-table{min-height:58px}}


/* Update 2.6: Tische nicht mehr dauerhaft auf der Seite anzeigen */
.waiter-body .table-panel.compact-table-selector{padding:14px 18px}
.waiter-body .table-panel.compact-table-selector .panel-head{align-items:center}
.waiter-body .table-panel.compact-table-selector .panel-head h2{margin:0;display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(245,158,11,.28);background:rgba(245,158,11,.10);border-radius:999px;padding:9px 13px;color:#fde68a;max-width:100%;min-height:44px;line-height:1.1;touch-action:manipulation}
.waiter-body .table-panel.compact-table-selector .panel-head h2::after{content:'gedrückt halten';font-size:.72rem;color:#cbd5e1;font-weight:850;background:rgba(255,255,255,.06);border-radius:999px;padding:4px 7px;white-space:nowrap}
.waiter-body .table-panel.compact-table-selector .panel-head h2.has-selection::after{content:'ändern'}
.waiter-body .table-panel .table-chips,
.waiter-body .table-panel #customTable{display:none!important}
@media(max-width:520px){.waiter-body .table-panel.compact-table-selector{padding:12px 14px}.waiter-body .table-panel.compact-table-selector .panel-head{gap:10px}.waiter-body .table-panel.compact-table-selector .panel-head h2{font-size:1.05rem;padding:8px 11px}.waiter-body .table-panel.compact-table-selector .panel-head h2::after{font-size:.66rem;padding:3px 6px}}

/* Update 2.7: Detailansicht für Kellner-Bestellungen wie Kontrollseite */
.history-order{cursor:pointer}
.history-order .history-pay-actions button{cursor:pointer}
.order-detail-modal{position:fixed;inset:0;z-index:125;display:none}
.order-detail-modal.open{display:block}
.order-detail-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.78);backdrop-filter:blur(8px)}
.order-detail-panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(500px,calc(100% - 22px));max-height:calc(100dvh - 22px);overflow:auto;background:rgba(15,23,42,.98);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:18px}
.order-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.order-detail-head h2{margin:0;font-size:1.55rem}
.order-detail-total-card{grid-template-columns:1fr 1fr auto}
.order-detail-actions{grid-template-columns:1fr 1.35fr}
.order-detail-actions [hidden]{display:none!important}
body.order-detail-open{overflow:hidden}
@media(max-width:760px){.order-detail-panel{width:calc(100% - 18px);border-radius:24px;padding:16px}.order-detail-head h2{font-size:1.35rem}.order-detail-total-card{grid-template-columns:1fr}.order-detail-actions{grid-template-columns:1fr}.order-detail-actions .primary{order:-1}}
