:root{--bg:#f0f4f8;--surface:#fff;--primary:#0f766e;--primary-dark:#115e59;--danger:#b91c1c;--danger-soft:#fef2f2;--success:#15803d;--success-soft:#f0fdf4;--warning:#92400e;--warning-soft:#fffbeb;--text:#0f172a;--muted:#64748b;--line:#e2e8f0;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow:0 4px 12px #00000014;--radius:12px;--radius-lg:16px;--radius-full:9999px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{background:var(--bg);min-height:100dvh;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif}button{cursor:pointer;font:inherit;background:0 0;border:none}input,select{font:inherit}a{color:inherit;text-decoration:none}table{border-collapse:collapse;width:100%}.app{flex-direction:column;min-height:100dvh;display:flex}.appHeader{z-index:40;-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line);background:#fffffff5;align-items:center;gap:10px;padding:10px 14px;display:flex;position:sticky;top:0}.appHeader__brand{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.appHeader__icon{color:var(--primary);flex-shrink:0}.appHeader__title{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.appHeader__user{flex-shrink:0;display:none}@media (min-width:560px){.appHeader__user{flex-direction:column;align-items:flex-end;font-size:.8rem;display:flex}.appHeader__user strong{color:var(--text);font-weight:600}.appHeader__user span{color:var(--muted)}}.appHeader__actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.headerScanBtn{display:none}@media (min-width:768px){.appHeader{padding:12px 24px}.appHeader__title{font-size:1rem}.headerScanBtn{display:inline-flex}}.appMain{flex:1;align-content:start;gap:12px;width:100%;max-width:1200px;margin:0 auto;padding:14px 14px 96px;display:grid}@media (min-width:768px){.appMain{gap:16px;padding:24px 24px 40px}}.fab{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;z-index:30;justify-content:center;align-items:center;width:58px;height:58px;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:20px;left:20px;box-shadow:0 4px 20px #0f766e73}.fab:hover{transform:scale(1.06);box-shadow:0 6px 24px #0f766e8c}.fab:active{transform:scale(.94)}@media (min-width:768px){.fab{display:none}}.loadingState{color:var(--muted);flex:1;justify-content:center;align-items:center;gap:10px;font-size:.9rem;display:flex}.loginWrap{flex:1;justify-content:center;align-items:center;padding:20px 14px;display:flex}.loginCard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);width:min(100%,400px);box-shadow:var(--shadow);padding:28px 22px}.loginCard__brand{align-items:center;gap:10px;margin-bottom:20px;display:flex}.loginCard__brand svg{color:var(--primary);flex-shrink:0}.loginCard__brand h1{font-size:1rem;font-weight:700;line-height:1.3}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card__header{padding:14px 16px 0}.card__header--inline{justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.card__body{padding:14px 16px}.card__title{margin-bottom:12px;font-size:.9rem;font-weight:700}.banner{background:var(--warning-soft);border-radius:var(--radius);color:var(--warning);border:1px solid #fde68a;align-items:flex-start;gap:8px;padding:11px 14px;font-size:.825rem;display:flex}.banner strong{margin-bottom:2px;display:block}.banner code{background:#00000012;border-radius:4px;padding:1px 4px;font-family:monospace}.statsGrid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (min-width:768px){.statsGrid{grid-template-columns:repeat(4,1fr)}}.statCard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);gap:6px;padding:14px;display:grid}.statCard__icon{width:32px;height:32px;color:var(--primary);background:#ecfdf5;border-radius:8px;justify-content:center;align-items:center;display:flex}.statCard small{color:var(--muted);font-size:.78rem}.statCard strong{font-size:1.4rem;font-weight:700;line-height:1.1}.splitGrid{grid-template-columns:1fr;gap:12px;display:grid}@media (min-width:768px){.splitGrid{grid-template-columns:1fr 1fr}}.filtersGrid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.filterSection{gap:6px;display:grid}.filterSection__label{color:var(--muted);font-size:.8rem;font-weight:600}.filterChips{flex-wrap:wrap;gap:6px;display:flex}.filterChip{border-radius:var(--radius-full);border:1.5px solid var(--line);height:30px;color:var(--muted);background:var(--surface);white-space:nowrap;padding:0 12px;font-size:.8rem;font-weight:600;transition:border-color .12s,background .12s,color .12s}.filterChip:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.filterChip--active{background:var(--primary);border-color:var(--primary);color:#fff}.form{gap:12px;display:grid}.field{gap:5px;display:grid}.field>span,.field>label{color:var(--text);font-size:.82rem;font-weight:600}input,select{border:1px solid var(--line);background:var(--surface);width:100%;height:44px;color:var(--text);border-radius:8px;padding:0 12px;transition:border-color .15s,outline .15s}input:focus,select:focus{outline:2px solid var(--primary);outline-offset:-1px;border-color:#0000}.button{white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;height:40px;padding:0 14px;font-size:.85rem;font-weight:600;transition:opacity .15s,transform .15s;display:inline-flex}.button:hover:not(:disabled){opacity:.85}.button:active:not(:disabled){transform:scale(.97)}.button:disabled{opacity:.45;cursor:not-allowed}.button--primary{background:var(--primary);color:#fff}.button--ghost{color:var(--text);border:1px solid var(--line);background:0 0}.button--icon{flex-shrink:0;width:36px;height:36px;padding:0}.button--wide{width:100%}.demoBox{border-top:1px solid var(--line);margin-top:16px;padding-top:16px}.demoBox h3{color:var(--muted);margin-bottom:10px;font-size:.825rem}.demoBox__actions{gap:8px;display:flex}.tableWrap{-webkit-overflow-scrolling:touch;overflow-x:auto}th,td{text-align:right;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:10px 12px;font-size:.85rem}th{color:var(--muted);white-space:nowrap;font-size:.78rem;font-weight:600}tr:last-child td{border-bottom:none}.badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;padding:2px 9px;font-size:.75rem;font-weight:600;display:inline-flex}.badge--success{background:var(--success-soft);color:var(--success)}.badge--warning{background:var(--warning-soft);color:var(--warning)}.badge--danger{background:var(--danger-soft);color:var(--danger)}.message{border-radius:var(--radius);align-items:center;gap:10px;padding:11px 14px;font-size:.875rem;font-weight:500;display:flex}.message--danger{background:var(--danger-soft);color:var(--danger)}.message--success{background:var(--success-soft);color:var(--success)}.emptyRow{color:var(--muted);font-size:.875rem;text-align:center!important;padding:28px 12px!important}.modalBackdrop{z-index:50;background:#0000007a;justify-content:center;align-items:flex-end;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@media (min-width:520px){.modalBackdrop{align-items:center;padding:20px}}.modal{background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;gap:16px;width:100%;max-height:92dvh;padding:20px;animation:.22s slideUp;display:grid;overflow-y:auto}@media (min-width:520px){.modal{border-radius:var(--radius-lg);width:min(100%,440px);animation:.18s fadeIn}}.modal__topBar{justify-content:space-between;align-items:center;gap:12px;display:flex}.modal__topBar h2{font-size:1rem;font-weight:700}.scanResult{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:8px 0;display:flex}.scanResult__icon{border-radius:var(--radius-lg);justify-content:center;align-items:center;width:64px;height:64px;display:flex}.scanResult__icon--success{background:var(--success-soft);color:var(--success)}.scanResult__icon--warning{background:var(--warning-soft);color:var(--warning)}.scanResult__icon--danger{background:var(--danger-soft);color:var(--danger)}.scanResult h2{font-size:1.05rem;font-weight:700}.scanResult p{color:var(--muted);font-size:.875rem}.scanTabs{border:1px solid var(--line);border-radius:8px;grid-template-columns:1fr 1fr;display:grid;overflow:hidden}.scanTab{color:var(--muted);background:0 0;border:none;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:.85rem;font-weight:600;transition:background .15s,color .15s;display:flex}.scanTab:not(:last-child){border-left:1px solid var(--line)}.scanTab--active{background:var(--primary);color:#fff}.adminTabs{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);scrollbar-width:none;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-sm);gap:0;display:flex;overflow-x:auto}.adminTabs::-webkit-scrollbar{display:none}.adminTab{min-width:max-content;color:var(--muted);white-space:nowrap;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;padding:11px 14px;font-size:.85rem;font-weight:600;transition:color .15s,border-color .15s;display:flex}.adminTab--active{color:var(--primary);border-bottom-color:var(--primary)}.adminSection{gap:12px;display:grid}.adminSection__toolbar{justify-content:flex-end;gap:8px;display:flex}.adminSection__empty{color:var(--muted);justify-content:center;align-items:center;gap:8px;padding:32px;font-size:.875rem;display:flex}.qrCodeText{background:var(--bg);color:var(--text);border-radius:4px;padding:2px 6px;font-family:monospace;font-size:.8rem}.qrBig{background:var(--bg);border-radius:var(--radius);letter-spacing:.1em;color:var(--text);padding:20px 24px;font-family:monospace;font-size:1.1rem;font-weight:700;display:inline-block}.adminSection__locName{align-items:center;gap:6px;display:flex}.assignList{gap:8px;max-height:280px;padding:4px 0;display:grid;overflow-y:auto}.assignItem{border:1px solid var(--line);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:.875rem;display:flex}.assignItem input[type=checkbox]{width:18px;min-width:18px;height:18px;accent-color:var(--primary);flex-shrink:0}.assignItem span:first-of-type{flex:1;font-weight:600}.cameraPanel{border:1px solid var(--line);border-radius:var(--radius);background:#000;min-height:280px;position:relative;overflow:hidden}.cameraFeed{width:100%;min-height:280px}.cameraFeed>div,.cameraFeed video{border:none!important;width:100%!important}.cameraOverlay{background:var(--surface);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:24px 16px;display:flex;position:absolute;inset:0}.cameraError{color:var(--danger);font-size:.825rem}.manualPanel{gap:12px;display:grid}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:.9s linear infinite spin}.srOnly{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
