
:root{
  --bg:#06110d;--panel:#0d2019;
  --line:rgba(232,255,244,.11);--line2:rgba(77,217,164,.22);
  --txt:#f4fff8;--muted:rgba(244,255,248,.58);
  --green:#4dd9a4;--green2:#53e1c6;--dark:#03100b;
  --amber:#f5c85b;--red:#ff7e8a;--blue:#78c7ff;
  --r:22px;--shadow:0 20px 70px rgba(0,0,0,.32);
}
*{box-sizing:border-box}html{height:100%}
body{min-height:100%;margin:0;color:var(--txt);font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;background:radial-gradient(900px 520px at 14% -8%,rgba(77,217,164,.18),transparent 55%),radial-gradient(600px 350px at 98% 10%,rgba(83,225,198,.1),transparent 52%),linear-gradient(180deg,#040b08,var(--bg));-webkit-font-smoothing:antialiased;overflow-x:hidden}
button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}
.hide{display:none!important}
body::after{content:"";position:fixed;inset:0;pointer-events:none;opacity:.022;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");z-index:9999}

/* ── loading bar ── */
.loadBar{position:fixed;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),var(--green2));z-index:9998;display:none}
.loadBar.on{display:block;animation:lbSlide 1.4s ease-in-out infinite}
@keyframes lbSlide{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* ── layout ── */
.appShell{display:grid;grid-template-columns:276px minmax(0,1fr);min-height:100vh}
.side{position:sticky;top:0;height:100vh;padding:18px 14px 14px;background:rgba(3,8,5,.9);border-right:1px solid var(--line);backdrop-filter:blur(20px);z-index:30;display:flex;flex-direction:column;overflow-y:auto}
.brand{display:flex;align-items:center;gap:11px;padding:4px 4px 16px;border-bottom:1px solid var(--line);margin-bottom:12px;flex-shrink:0}
.logo{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,var(--green),var(--green2));color:#02100a;display:grid;place-items:center;font-weight:950;font-size:16px;letter-spacing:-.03em;box-shadow:0 14px 36px rgba(77,217,164,.28);flex-shrink:0}
.brand b{display:block;font-size:18px;line-height:1}.brand span{display:block;color:var(--muted);font-size:11px;margin-top:2px}
.restBadge{display:flex;align-items:center;gap:8px;margin:0 0 11px;padding:9px 11px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.035);flex-shrink:0}
.sDot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 12px rgba(77,217,164,.9);flex-shrink:0;animation:dotP 3s ease-in-out infinite}
@keyframes dotP{0%,100%{opacity:1}50%{opacity:.4}}
.restBadge strong{font-size:12px;line-height:1.2}
.restBadge small{display:block;color:var(--muted);font-size:11px;margin-top:1px}

/* ── nav ── */
.navGroup{flex-shrink:0}
.navGroupLabel{font-size:10px;font-weight:900;letter-spacing:.15em;text-transform:uppercase;color:rgba(77,217,164,.5);padding:10px 10px 5px;display:block}
.navBtn{width:100%;border:0;background:transparent;color:rgba(244,255,248,.58);display:flex;align-items:center;gap:10px;text-align:left;border-radius:12px;padding:9px 10px;font-weight:700;font-size:13px;transition:.12s;cursor:pointer}
.navBtn:hover{background:rgba(255,255,255,.06);color:var(--txt)}
.navBtn.active{background:linear-gradient(135deg,var(--green),var(--green2));color:#02100a;box-shadow:0 8px 22px rgba(77,217,164,.22);font-weight:900}
.navIcon{width:18px;text-align:center;font-size:14px;flex-shrink:0}
.navLabel{flex:1}
.nBadge{background:var(--red);color:#fff;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:900;flex-shrink:0;min-width:18px;text-align:center}
.navBtn.active .nBadge{background:rgba(0,0,0,.2);color:#02100a}
.navSep{border:0;border-top:1px solid var(--line);margin:7px 0 4px;flex-shrink:0}

.sideTools{border-top:1px solid var(--line);padding-top:10px;margin-top:auto;display:grid;gap:3px;flex-shrink:0}
.miniBtn{border:0;background:transparent;color:var(--muted);text-align:left;padding:7px 9px;border-radius:10px;font-size:12px;transition:.11s;cursor:pointer}
.miniBtn:hover{background:rgba(255,255,255,.06);color:var(--txt)}
.ver{color:rgba(244,255,248,.22);font-size:10px;margin:7px 10px 0;flex-shrink:0}

/* ── top bar ── */
.main{min-width:0;display:flex;flex-direction:column}
.top{height:68px;position:sticky;top:0;z-index:20;border-bottom:1px solid var(--line);background:rgba(5,14,10,.88);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:space-between;padding:0 22px;gap:12px;flex-shrink:0}
.topLeft{display:flex;align-items:center;gap:11px;min-width:0;overflow:hidden}
.mobileMenu{display:none;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--txt);border-radius:12px;width:40px;height:40px;font-size:19px;flex-shrink:0}
.crumb{color:var(--green);letter-spacing:.2em;text-transform:uppercase;font-size:10px;font-weight:900;line-height:1}
.top h1{margin:1px 0 0;font-size:22px;letter-spacing:-.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topRight{display:flex;align-items:center;gap:8px;flex-shrink:0}
.chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:999px;padding:6px 11px;font-size:12px;font-weight:800;color:rgba(244,255,248,.68);white-space:nowrap}
.chip.good{border-color:rgba(77,217,164,.28);background:rgba(77,217,164,.09);color:#caffeb}
.liveClock{font-size:17px;font-weight:900;font-variant-numeric:tabular-nums;color:var(--green);letter-spacing:-.02em}

/* ── content ── */
.content{padding:20px 22px 36px;flex:1}

/* ── hero ── */
.heroCard{border:1px solid rgba(77,217,164,.22);background:linear-gradient(145deg,rgba(77,217,164,.14),rgba(255,255,255,.04));border-radius:26px;padding:24px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.heroCard::before{content:"";position:absolute;right:-120px;top:-120px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(77,217,164,.2),transparent 62%);pointer-events:none}
.kicker{color:var(--green);letter-spacing:.2em;text-transform:uppercase;font-size:10px;font-weight:950}
.heroCard h2{font-size:34px;line-height:.96;letter-spacing:-.055em;margin:9px 0 6px}
.heroCard p{color:var(--muted);font-size:15px;line-height:1.55;max-width:620px}
.heroActions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}

/* ── buttons ── */
.btn{border:1px solid var(--line);background:rgba(255,255,255,.07);color:var(--txt);border-radius:12px;padding:9px 13px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:background .12s,transform .12s,box-shadow .12s;min-height:40px;font-size:14px;line-height:1;white-space:nowrap}
.btn:hover{background:rgba(255,255,255,.11);transform:translateY(-1px)}
.btn:active{transform:none;transition:none}
.btn.pr{background:linear-gradient(135deg,var(--green),var(--green2));border:0;color:#02100a;box-shadow:0 10px 24px rgba(77,217,164,.2);font-weight:900}
.btn.pr:hover{box-shadow:0 14px 30px rgba(77,217,164,.32)}
.btn.red{border-color:rgba(255,126,138,.34);background:rgba(255,126,138,.09);color:#ffd0d4}
.btn.red:hover{background:rgba(255,126,138,.16)}
.btn.amber{border-color:rgba(245,200,91,.33);background:rgba(245,200,91,.09);color:#ffe1a2}
.btn.sm{padding:5px 10px;min-height:30px;border-radius:9px;font-size:13px}
.btn.xs{padding:3px 7px;min-height:24px;border-radius:7px;font-size:12px}
.btn.full{width:100%}
.btn:disabled{opacity:.45;pointer-events:none}

/* ── grids ── */
.grid{display:grid;gap:12px}
.g2{grid-template-columns:1.2fr .8fr}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}

/* ── cards ── */
.card{border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.058),rgba(255,255,255,.032));border-radius:var(--r);padding:16px;min-width:0}
.card h2{font-size:19px;margin:0 0 12px;letter-spacing:-.03em}
.stat small{color:var(--muted);font-weight:700;font-size:12px}
.stat strong{display:block;font-size:38px;letter-spacing:-.055em;line-height:1;margin:8px 0 4px;font-variant-numeric:tabular-nums}
.stat .sub{color:var(--muted);font-size:12px}
.stat.s1{border-color:rgba(77,217,164,.2)}.stat.s2{border-color:rgba(120,199,255,.2)}
.stat.s3{border-color:rgba(245,200,91,.2)}.stat.s4{border-color:rgba(185,156,255,.2)}

/* ── section head ── */
.sH{display:flex;justify-content:space-between;align-items:center;gap:11px;margin:20px 0 11px}
.sH h2{font-size:19px;margin:0;letter-spacing:-.04em}
.toolbar{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.actionLine{display:flex;gap:7px;align-items:center;flex-wrap:wrap;margin:0 0 12px}
.push{margin-left:auto}

/* ── inputs ── */
.input,.select,textarea{width:100%;border:1px solid var(--line);background:rgba(0,0,0,.24);color:var(--txt);border-radius:11px;padding:10px 12px;outline:0;min-height:42px;font-size:14px}
.input:focus,.select:focus,textarea:focus{border-color:rgba(77,217,164,.5);box-shadow:0 0 0 3px rgba(77,217,164,.07)}
.input.sm{min-height:32px;padding:5px 9px;font-size:13px;border-radius:9px}
.select option{color:#111;background:#1a2e22}
.field{display:block}.field>span{display:block;color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.04em;margin-bottom:5px}

/* ── table ── */
.tableWrap{border:1px solid var(--line);background:rgba(255,255,255,.025);border-radius:var(--r);overflow:auto}
.tfTable{width:100%;border-collapse:collapse}
.tfTable th,.tfTable td{padding:11px 13px;border-bottom:1px solid rgba(255,255,255,.065);text-align:left;vertical-align:middle;font-size:13px}
.tfTable th{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(244,255,248,.38);white-space:nowrap;background:rgba(0,0,0,.12)}
.tfTable tr:hover td{background:rgba(255,255,255,.022)}
.tfTable tr:last-child td{border-bottom:0}
.resAllergy td{background:rgba(255,126,138,.048)!important}

/* ── pills ── */
.pill{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:999px;padding:3px 8px;font-size:11px;font-weight:900;white-space:nowrap}
.pill.green{border-color:rgba(77,217,164,.28);background:rgba(77,217,164,.1);color:#caffeb}
.pill.amber{border-color:rgba(245,200,91,.32);background:rgba(245,200,91,.09);color:#ffe1a2}
.pill.red{border-color:rgba(255,126,138,.32);background:rgba(255,126,138,.09);color:#ffd0d4}
.pill.blue{border-color:rgba(120,199,255,.32);background:rgba(120,199,255,.09);color:#d6f0ff}

/* ── list / row cards ── */
.list{display:grid;gap:7px}
.rowCard{display:grid;grid-template-columns:64px 1fr auto;gap:10px;align-items:center;border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:14px;padding:11px 12px;transition:background .11s}
.rowCard:hover{background:rgba(255,255,255,.065)}
.rowCard.allergy{border-color:rgba(255,126,138,.3);background:rgba(255,126,138,.055)}
.timeBadge{text-align:center;border-radius:10px;background:rgba(77,217,164,.11);border:1px solid rgba(77,217,164,.2);padding:7px 5px;font-weight:950;color:#caffeb;font-size:13px;line-height:1.15}
.rowCard.allergy .timeBadge{background:rgba(255,126,138,.11);border-color:rgba(255,126,138,.28);color:#ffd0d4}
.rowCard b{display:block;font-size:13px}.rowCard .rc-sub{color:var(--muted);font-size:12px;margin-top:2px;line-height:1.3}
.rc-actions{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.resGuest{font-weight:900;font-size:14px;line-height:1.2}
.resMeta{color:var(--muted);font-size:12px;margin-top:3px;line-height:1.3}
.resNote{color:rgba(244,255,248,.75);font-size:12px;margin-top:4px;line-height:1.35}

/* ── kanban ── */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.kCol{border:1px solid var(--line);background:rgba(0,0,0,.14);border-radius:var(--r);padding:10px;min-height:180px}
.kCol h3{display:flex;justify-content:space-between;align-items:center;margin:0 0 9px;font-size:11px;color:rgba(244,255,248,.5);letter-spacing:.1em;font-weight:900;text-transform:uppercase}

/* ── ticket cards ── */
.ticket{border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:14px;padding:11px;margin-bottom:7px}
.ticket h4{margin:0 0 5px;font-size:13px;line-height:1.3;font-weight:800}
.ticket .tdesc{color:var(--muted);margin:5px 0;font-size:12px;line-height:1.4}
.ticketMeta{display:flex;gap:4px;flex-wrap:wrap;margin-top:7px}
.ticketActions{display:flex;gap:5px;margin-top:8px;flex-wrap:wrap}
.ticketAge{font-size:10px;color:var(--muted);margin-top:3px}
@keyframes spoedPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,126,138,.5)}60%{box-shadow:0 0 0 6px rgba(255,126,138,0)}}
.ticket.spoed{border-color:rgba(255,126,138,.4);background:rgba(255,126,138,.085);animation:spoedPulse 2s ease-in-out infinite}

/* ── allergie banner ── */
@keyframes bannerP{0%,100%{box-shadow:0 0 0 0 rgba(255,126,138,.4)}60%{box-shadow:0 0 0 6px rgba(255,126,138,0)}}
.allergieBanner{border:1px solid rgba(255,126,138,.44);background:rgba(255,126,138,.11);border-radius:14px;padding:12px 15px;margin-bottom:13px;display:flex;align-items:center;gap:10px;animation:bannerP 2s ease-in-out infinite}
.allergieBanner .ai{font-size:19px;flex-shrink:0}
.allergieBanner strong{display:block;color:#ffd0d4;font-size:13px;font-weight:900}
.allergieBanner span{color:rgba(255,208,212,.65);font-size:12px}

/* ── module cards ── */
.moduleGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.moduleCard{border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:18px;padding:14px;position:relative;cursor:pointer;transition:border-color .14s,transform .14s}
.moduleCard:hover{border-color:rgba(77,217,164,.28);transform:translateY(-1px)}
.moduleCard.on{border-color:rgba(77,217,164,.42);background:linear-gradient(175deg,rgba(77,217,164,.11),rgba(255,255,255,.03))}
.modIcon{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.08);display:grid;place-items:center;font-size:20px;margin-bottom:10px}
.moduleCard.on .modIcon{background:rgba(77,217,164,.13)}
.moduleCard h3{margin:0 0 4px;font-size:14px;font-weight:800}
.moduleCard p{color:var(--muted);font-size:11px;line-height:1.45;min-height:30px;margin:0 0 8px}
.sw{position:absolute;right:11px;top:11px;width:42px;height:24px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid var(--line);padding:2px;pointer-events:none}
.sw i{display:block;width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.38);transition:.18s}
.moduleCard.on .sw{background:rgba(77,217,164,.2);border-color:rgba(77,217,164,.38)}
.moduleCard.on .sw i{transform:translateX(18px);background:var(--green)}

/* ── employee clock tiles ── */
.empGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.empTile{border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:16px;padding:14px 10px;text-align:center;cursor:pointer;transition:background .12s,transform .12s;position:relative;user-select:none}
.empTile:hover{background:rgba(255,255,255,.075);transform:translateY(-1px)}
.empTile:active{transform:none}
.empTile.in{border-color:rgba(77,217,164,.36);background:rgba(77,217,164,.08)}
.empTile .eIcon{font-size:24px;margin-bottom:6px;line-height:1}
.empTile b{display:block;font-size:12px;margin-bottom:3px;line-height:1.2;font-weight:800}
.empTile .eMeta{font-size:11px;color:var(--muted)}
.empTile.in .eMeta{color:rgba(150,255,200,.65)}
.empInDot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px rgba(77,217,164,.9)}

/* ── PIN pad ── */
.pinWrap{display:flex;flex-direction:column;align-items:center;gap:13px;padding:4px 0}
.pinDots{display:flex;gap:12px;padding:8px}
.pinDot{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.25);background:transparent;transition:.13s}
.pinDot.filled{background:var(--green);border-color:var(--green);box-shadow:0 0 7px rgba(77,217,164,.5)}
.pinGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;width:240px}
.pinKey{height:64px;font-size:22px;font-weight:900;border:1px solid var(--line);background:rgba(255,255,255,.07);color:var(--txt);border-radius:14px;transition:background .1s,transform .08s}
.pinKey:hover{background:rgba(255,255,255,.12)}
.pinKey:active{transform:scale(.94)}
.pinKey.ok{background:linear-gradient(135deg,var(--green),var(--green2));color:#02100a;border:0}
.pinKey.ok:hover{box-shadow:0 8px 18px rgba(77,217,164,.3)}
.pinKey.clr{color:var(--red)}
.pinError{color:var(--red);font-size:13px;font-weight:700;min-height:18px;text-align:center}

/* ── date bar ── */
.dateBar{display:flex;align-items:center;gap:7px;margin-bottom:12px;border:1px solid var(--line);background:rgba(255,255,255,.03);border-radius:14px;padding:6px 8px;flex-wrap:wrap}
.dateBar strong{flex:1;text-align:center;font-size:14px;font-weight:800;min-width:140px}
.dateBar .dateTotal{font-size:12px;color:var(--muted);margin-left:4px}

/* ── search bar ── */
.searchWrap{position:relative;flex:1;max-width:240px}
.searchWrap .input{padding-left:30px}
.searchWrap::before{content:"🔍";position:absolute;left:9px;top:50%;transform:translateY(-50%);font-size:12px;pointer-events:none;opacity:.5}

/* ── quick tiles ── */
.quickGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.quickTile{border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:13px;padding:11px 12px;min-height:78px;text-align:left;transition:background .12s,border-color .12s,transform .12s;cursor:pointer}
.quickTile:hover{background:rgba(255,255,255,.07);border-color:rgba(77,217,164,.26);transform:translateY(-1px)}
.quickTile b{display:block;margin-top:6px;font-size:13px;font-weight:800}
.quickTile small{color:var(--muted);font-size:11px}

/* ── break grid ── */
.breakGrid{display:flex;gap:7px;flex-wrap:wrap;margin:9px 0}

/* ── kiosk ── */
body.kiosk .side{display:none!important}
body.kiosk .appShell{grid-template-columns:1fr}
body.kiosk .mobileMenu{display:none!important}
body.kiosk .content{padding:14px 16px 14px}
body.kiosk .top{height:52px;padding:0 16px}
body.kiosk .top h1{font-size:17px}
body.kiosk .kCol{min-height:calc(100vh - 180px)}
body.kiosk .ticket{padding:14px;margin-bottom:9px}
body.kiosk .ticket h4{font-size:16px;margin-bottom:6px}
body.kiosk .ticketActions .btn{min-height:40px;font-size:14px;padding:9px 14px}
body.kiosk .pill{font-size:12px;padding:4px 9px}
.kioskMeta{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--muted)}
.kioskCountdown{font-variant-numeric:tabular-nums;font-weight:900;color:var(--green)}

/* ── login ── */
.loginPage{min-height:100vh;display:grid;place-items:center;padding:20px}
.loginBox{width:min(520px,100%);border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.077),rgba(255,255,255,.04));border-radius:24px;padding:28px;box-shadow:var(--shadow)}
.loginBrand{display:flex;align-items:center;gap:13px;margin-bottom:22px}
.loginBrand h1{margin:0;font-size:28px;letter-spacing:-.05em}
.loginBrand p{margin:2px 0 0;color:var(--muted);font-size:13px}

/* ── modal ── */
.modalBg{position:fixed;inset:0;display:none;place-items:center;background:rgba(0,0,0,.8);z-index:80;padding:14px}
.modalBg.open{display:grid;animation:fadeIn .15s ease-out}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{width:min(760px,100%);max-height:90vh;overflow-y:auto;border:1px solid var(--line);background:#071110;border-radius:22px;box-shadow:0 28px 90px rgba(0,0,0,.6);padding:18px;animation:slideUp .15s ease-out}
@keyframes slideUp{from{transform:translateY(8px);opacity:.5}to{transform:none;opacity:1}}
.modalHead{display:flex;justify-content:space-between;align-items:center;gap:11px;margin-bottom:14px}
.modalHead h2{margin:0;font-size:20px;letter-spacing:-.03em;font-weight:900}

/* ── toast ── */
.toast{position:fixed;right:13px;top:78px;z-index:100;background:#0a1e14;border:1px solid rgba(77,217,164,.28);border-radius:13px;padding:11px 14px;color:#d6ffef;display:none;max-width:300px;font-size:13px;font-weight:700;line-height:1.3;animation:slideUp .2s ease-out}
.toast.err{background:#180a0c;border-color:rgba(255,126,138,.32);color:#ffd0d4}

/* ── empty state ── */
.empty{border:1px dashed rgba(255,255,255,.12);border-radius:14px;padding:22px 16px;text-align:center;color:var(--muted);font-size:13px}
.emptyIcon{font-size:26px;display:block;margin-bottom:7px;opacity:.42}

/* ── refresh bar ── */
.refreshBar{display:flex;align-items:center;justify-content:flex-end;gap:8px;font-size:11px;color:var(--muted);margin-bottom:12px}
.refreshBar button{font-size:11px;min-height:22px;padding:2px 7px}

/* ── sidebar quick ── */
.sideQ{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin:0 0 7px;flex-shrink:0}
.sideQ .quickTile{min-height:unset;padding:8px 9px;border-radius:11px}


/* ── productie actielijst ── */
.opsPanel{border:1px solid rgba(245,200,91,.24);background:linear-gradient(160deg,rgba(245,200,91,.075),rgba(255,255,255,.028));border-radius:20px;padding:14px;margin-top:12px}
.opsPanel h3{margin:0 0 10px;font-size:15px;letter-spacing:-.02em}
.taskGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.taskItem{border:1px solid var(--line);background:rgba(0,0,0,.16);border-radius:14px;padding:11px 12px;display:flex;gap:9px;align-items:flex-start;min-height:76px;cursor:pointer;transition:transform .12s,background .12s;text-align:left;width:100%}.taskItem:hover{transform:translateY(-1px);background:rgba(255,255,255,.06)}
.taskItem .ti{font-size:18px;line-height:1;flex-shrink:0}.taskItem b{display:block;font-size:13px}.taskItem span{display:block;color:var(--muted);font-size:11px;margin-top:3px;line-height:1.35}
.taskItem.red{border-color:rgba(255,126,138,.28);background:rgba(255,126,138,.065)}.taskItem.amber{border-color:rgba(245,200,91,.28);background:rgba(245,200,91,.06)}.taskItem.green{border-color:rgba(77,217,164,.25);background:rgba(77,217,164,.055)}
.formHint{grid-column:1/-1;border:1px solid rgba(77,217,164,.18);background:rgba(77,217,164,.06);border-radius:12px;padding:9px 11px;color:rgba(202,255,235,.78);font-size:12px;line-height:1.35}
.resNeeds td{background:rgba(245,200,91,.04)!important}

/* ── desktop/mobile toggle ── */
.deskOnly{display:block}.mobOnly{display:none}

/* ── print ── */
@media print{
  .side,.top,.btn,.toolbar,.actionLine,.dateBar,.searchWrap,.ticketActions,.rc-actions,.loadBar,.toast,.sH .toolbar{display:none!important}
  .content{padding:0!important}
  body{background:white;color:#111}
  .card,.tableWrap,.rowCard{border-color:#ddd;background:white;box-shadow:none;border-radius:4px}
  .pill{border-color:#ccc;background:white;color:#111}
  .heroCard{display:none}
  .sH{margin:12px 0 6px}
  .sH h2{font-size:16px;color:#111}
  .muted,.rc-sub,.resMeta{color:#555!important}
}

/* ── responsive ── */
@media(max-width:1200px){
  .g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(2,1fr)}
  .taskGrid{grid-template-columns:1fr}
  .moduleGrid{grid-template-columns:repeat(2,1fr)}.kanban{grid-template-columns:repeat(2,1fr)}
  .empGrid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:840px){
  .appShell{display:block}
  .side{position:fixed;left:0;top:0;bottom:0;width:min(82vw,300px);height:auto;transform:translateX(-110%);transition:.22s;z-index:90;padding:14px 12px}
  .side.open{transform:none;box-shadow:16px 0 40px rgba(0,0,0,.5)}
  .drawerOverlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:85}
  .drawerOverlay.open{display:block}
  .mobileMenu{display:flex;align-items:center;justify-content:center}
  .topRight{display:none}
  .top{height:auto;min-height:62px;padding:10px 13px;align-items:center}
  .top h1{font-size:20px}
  .content{padding:12px 13px 24px}
  .heroCard{padding:16px;border-radius:20px}.heroCard h2{font-size:26px}.heroCard p{font-size:14px}
  .g2,.g3,.g4,.moduleGrid,.empGrid,.quickGrid,.taskGrid{grid-template-columns:1fr}
  .kanban{grid-template-columns:1fr 1fr}
  .rowCard{grid-template-columns:1fr}
  .timeBadge{width:max-content}
  .deskOnly{display:none!important}.mobOnly{display:block!important}
  .mobList{display:grid!important;gap:7px}
  .card{border-radius:18px;padding:13px}
  .modal{border-radius:18px;padding:14px}.modalHead h2{font-size:18px}
  .loginBox{padding:18px;border-radius:20px}
  .pinGrid{width:228px}.pinKey{height:58px;font-size:20px}
  .dateBar strong{font-size:13px;min-width:100px}
  .searchWrap{max-width:100%;flex:1}
  .sH{margin:16px 0 9px;align-items:flex-start;flex-direction:column;gap:8px}
  .toolbar{width:100%}.toolbar .btn{flex:1}
}


/* ── vL109m mobile/readability upgrade ── */
:root{--txt:#f8fff9;--muted:rgba(248,255,249,.76);--soft:rgba(255,255,255,.085);--soft2:rgba(255,255,255,.13)}
body{font-size:16px;background:radial-gradient(1100px 620px at 15% -8%,rgba(77,217,164,.20),transparent 55%),radial-gradient(680px 440px at 102% 8%,rgba(83,225,198,.13),transparent 54%),linear-gradient(180deg,#020806,#06110d)}
body::after{opacity:.012}
.card,.heroCard,.tableWrap,.rowCard,.ticket,.kCol,.opsPanel,.loginBox,.modal{box-shadow:0 14px 46px rgba(0,0,0,.28)}
.quickTile,.quickTile b,.quickTile small,.taskItem,.taskItem b,.navBtn,.miniBtn,.card h2,.sH h2,.rowCard b,.ticket h4{color:var(--txt)!important}
.quickTile small,.taskItem span span,.stat small,.stat .sub,.rc-sub,.resMeta,.resNote,.miniBtn,.ver{color:var(--muted)!important}
.navBtn{color:rgba(248,255,249,.82)!important;font-weight:850}.navBtn:hover{background:var(--soft2)!important}.navBtn.active{color:#02100a!important}
.sideQ .quickTile{background:rgba(255,255,255,.08)!important;border-color:rgba(255,255,255,.16)!important;min-height:68px!important;color:var(--txt)!important}.sideQ .quickTile b{font-size:14px!important;color:var(--txt)!important}.sideQ .quickTile:hover{background:rgba(77,217,164,.16)!important;border-color:rgba(77,217,164,.36)!important}
.quickTile{background:rgba(255,255,255,.075)!important;border-color:rgba(255,255,255,.14)!important}.quickTile:hover{background:rgba(255,255,255,.12)!important;border-color:rgba(77,217,164,.34)!important}
.taskItem{background:rgba(255,255,255,.07)!important}.taskItem.red{background:rgba(255,126,138,.12)!important}.taskItem.amber{background:rgba(245,200,91,.10)!important}.taskItem.green{background:rgba(77,217,164,.10)!important}
.input::placeholder,textarea::placeholder{color:rgba(248,255,249,.48)!important}.field>span{color:rgba(248,255,249,.78)!important}.input,.select,textarea{background:rgba(0,0,0,.32)!important;border-color:rgba(248,255,249,.18)!important;color:var(--txt)!important}.input:focus,.select:focus,textarea:focus{border-color:rgba(77,217,164,.75)!important;box-shadow:0 0 0 4px rgba(77,217,164,.13)!important}
.btn{color:var(--txt)!important;border-color:rgba(248,255,249,.16)!important;background:rgba(255,255,255,.09)!important}.btn.pr{color:#02100a!important;background:linear-gradient(135deg,var(--green),var(--green2))!important;border:0!important}.btn.red{color:#ffd9dd!important;background:rgba(255,126,138,.14)!important}.btn.amber{color:#ffe8b5!important;background:rgba(245,200,91,.14)!important}
.tfTable th{color:rgba(248,255,249,.64)!important}.tfTable td{color:rgba(248,255,249,.90)!important}.resNeeds td{background:rgba(245,200,91,.055)!important}
.bottomNav{display:none}.fabAdd{display:none}
@media(max-width:840px){
  body{font-size:16px}.content{padding:12px 12px calc(104px + env(safe-area-inset-bottom))!important}.top{min-height:60px;background:rgba(3,12,8,.96)!important;border-bottom-color:rgba(77,217,164,.18)!important}.top h1{font-size:26px!important;line-height:1.05}.crumb{font-size:12px!important;letter-spacing:.22em}.mobileMenu{width:48px!important;height:48px!important;border-radius:16px!important;background:rgba(255,255,255,.10)!important;border-color:rgba(255,255,255,.16)!important;color:#f8fff9!important;font-size:24px!important}.side{width:min(88vw,340px)!important;background:#020a07!important;border-right-color:rgba(77,217,164,.22)!important;box-shadow:20px 0 60px rgba(0,0,0,.66)!important}.drawerOverlay.open{backdrop-filter:blur(2px)}
  .heroCard{padding:16px!important;border-radius:20px!important;margin-bottom:10px}.heroCard h2{font-size:25px!important;line-height:1.02;margin:7px 0 4px}.heroCard p{font-size:14px!important;color:rgba(248,255,249,.76)!important;margin:0}.heroActions .btn{flex:1;min-height:44px}
  .g4{grid-template-columns:1fr 1fr!important;gap:10px!important}.g3,.g2{grid-template-columns:1fr!important}.stat{padding:14px!important;border-radius:18px!important}.stat small{font-size:12px!important}.stat strong{font-size:34px!important;margin:6px 0 3px!important}.stat .sub{font-size:12px!important;line-height:1.25}.card{padding:14px!important}.opsPanel{padding:14px!important;border-radius:18px!important}.taskGrid{grid-template-columns:1fr!important}.taskItem{min-height:64px!important}.rowCard{border-radius:16px!important;padding:13px!important}.timeBadge{font-size:15px!important;padding:8px 9px!important}.btn{min-height:42px}.btn.xs{min-height:31px;font-size:13px}.btn.sm{min-height:36px;font-size:13px}.dateBar{position:sticky;top:61px;z-index:14;background:rgba(4,14,10,.96)!important;backdrop-filter:blur(16px);border-color:rgba(77,217,164,.18)!important}.searchWrap{min-width:100%}.modalBg{align-items:end!important;padding:10px!important}.modal{max-height:88vh!important;border-radius:22px 22px 16px 16px!important;background:#06110d!important;border-color:rgba(77,217,164,.18)!important}.loginBox{padding:22px!important;background:rgba(7,17,16,.88)!important}.loginBrand h1{font-size:34px!important}
  .bottomNav{position:fixed;left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom));z-index:70;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:7px;border:1px solid rgba(77,217,164,.22);background:rgba(2,10,7,.94);backdrop-filter:blur(18px);border-radius:22px;box-shadow:0 16px 50px rgba(0,0,0,.48)}
  .bottomNav button{position:relative;border:0;background:transparent;color:rgba(248,255,249,.70);border-radius:16px;padding:7px 3px 6px;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:900;min-height:54px}.bottomNav button .bi{font-size:18px;line-height:1}.bottomNav button.active{background:linear-gradient(135deg,var(--green),var(--green2));color:#02100a;box-shadow:0 8px 22px rgba(77,217,164,.22)}.bottomNav button.active .bottomBadge{background:rgba(0,0,0,.22);color:#02100a}.bottomBadge{position:absolute;top:4px;right:13px;background:var(--red);color:#fff;border-radius:999px;min-width:17px;height:17px;display:grid;place-items:center;font-size:10px;font-weight:950;padding:0 4px}.fabAdd{display:flex;position:fixed;right:18px;bottom:calc(78px + env(safe-area-inset-bottom));z-index:71;width:56px;height:56px;border-radius:20px;border:0;background:linear-gradient(135deg,var(--green),var(--green2));color:#02100a;align-items:center;justify-content:center;font-size:31px;font-weight:950;box-shadow:0 16px 40px rgba(77,217,164,.34)}
}
@media(max-width:390px){.top h1{font-size:23px!important}.g4{grid-template-columns:1fr!important}.heroActions .btn{flex:1 1 100%}.bottomNav button{font-size:9px}.bottomNav button .bi{font-size:17px}.fabAdd{width:52px;height:52px;bottom:calc(76px + env(safe-area-inset-bottom))}}
body.kiosk .bottomNav,body.kiosk .fabAdd{display:none!important}



/* ── vL109m modular readability layer ── */
:root{--txt-strong:#ffffff;--muted-strong:rgba(244,255,248,.78);--surface:rgba(255,255,255,.075)}
.quickTile,.taskItem,.navBtn,.miniBtn,.card,.rowCard,.ticket,.moduleCard,.empTile{color:var(--txt)!important}
.quickTile b,.taskItem b,.card h2,.sH h2,.opsPanel h3,.ticket h4,.rowCard b{color:var(--txt-strong)!important}
.quickTile small,.taskItem span span,.stat small,.stat .sub,.rc-sub,.resMeta,.tdesc,.field>span{color:var(--muted-strong)!important}
.sideQ .quickTile{background:rgba(255,255,255,.085)!important;border-color:rgba(255,255,255,.18)!important}
.sideQ .quickTile b{font-size:14px!important;color:#fff!important;text-shadow:0 1px 0 rgba(0,0,0,.22)}
.input::placeholder,textarea::placeholder{color:rgba(244,255,248,.48)!important}
.bottomNav{position:fixed;left:10px;right:10px;bottom:10px;z-index:50;display:none;grid-template-columns:repeat(5,1fr);gap:6px;padding:8px;border:1px solid rgba(232,255,244,.14);background:rgba(3,12,8,.88);backdrop-filter:blur(18px);border-radius:20px;box-shadow:0 16px 50px rgba(0,0,0,.35)}
.bottomNav .bNavBtn{border:0;background:transparent;color:rgba(244,255,248,.78);border-radius:14px;padding:7px 3px;font-size:10px;font-weight:900;display:grid;gap:2px;place-items:center;min-height:48px}
.bottomNav .bNavBtn span{font-size:18px;line-height:1}.bottomNav .bNavBtn.active{background:linear-gradient(135deg,var(--green),var(--green2));color:#02100a}
.fabAdd{position:fixed;right:18px;bottom:82px;z-index:55;width:54px;height:54px;border-radius:20px;border:0;background:linear-gradient(135deg,var(--green),var(--green2));color:#02100a;font-size:28px;font-weight:950;box-shadow:0 18px 40px rgba(77,217,164,.32);display:none;place-items:center}
@media(max-width:840px){.content{padding-bottom:92px!important}.bottomNav,.fabAdd{display:grid}.side{width:min(78vw,292px)}.heroCard{display:none}.stat strong{font-size:32px}.card,.stat,.rowCard,.ticket{background:rgba(255,255,255,.065)!important}.sH{position:relative}.top{background:rgba(5,14,10,.96)}}
