:root{--ocean: #1c6e9c;--ocean-dark: #12476b;--ocean-tint: #dcebf3;--sand: #e8d9b5;--bg: #f6f1e4;--surface: #ffffff;--surface-alt: #f7f0e1;--text: #16384c;--muted: #5f7280;--border: #e7dec9;--open: #5e8c4e;--filling: #d69a2e;--almost: #d06a3a;--full: #b23a2e;--closed: #9aa6ac;--track: #eee6d2;--sidebar: #0e3a56;--sidebar-deep: #0b2c42;--nav-inactive: #93b6cc;--nav-accent: #7fc6e8;--chrome: #eae0c9;--chrome-border: #d9cfb8;--from-app-bg: #dcebf3;--from-app-fg: #2e7cb0;--display: "Bricolage Grotesque", system-ui, sans-serif;--ui: "Hanken Grotesk", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--ui),-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--text)}h1,h2{font-family:var(--display);letter-spacing:-.01em}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit}.login-wrap{display:flex;align-items:center;justify-content:center;height:100%;padding:24px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;width:380px;box-shadow:0 10px 30px #0d243014}.login-card h1{font-size:22px;margin:0 0 4px}.login-card .sub{color:var(--muted);font-size:14px;margin:0 0 24px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field label{font-size:13px;color:var(--muted)}.field input{height:44px;border:1px solid var(--border);border-radius:10px;padding:0 14px;font-size:15px;background:var(--surface)}.field input:focus{outline:2px solid var(--ocean);border-color:var(--ocean)}.btn{height:44px;border:none;border-radius:10px;background:var(--ocean);color:#fff;font-size:15px;font-weight:600;padding:0 18px}.btn:hover{background:var(--ocean-dark)}.btn.secondary{background:var(--surface);color:var(--ocean);border:1px solid var(--ocean)}.btn.ghost{background:transparent;color:var(--muted)}.btn:disabled{opacity:.5;cursor:default}.error{color:var(--full);font-size:14px;margin-top:8px}.hint{color:var(--muted);font-size:12px;margin-top:14px;line-height:1.5}.shell{display:flex;flex-direction:column;height:100%}.chrome{flex:none;height:38px;display:flex;align-items:center;gap:14px;padding:0 14px;background:var(--chrome);border-bottom:1px solid var(--chrome-border)}.chrome .dots{display:flex;gap:7px}.chrome .dots span{width:11px;height:11px;border-radius:50%}.chrome .dots span:nth-child(1){background:#e0796b}.chrome .dots span:nth-child(2){background:#e7b14c}.chrome .dots span:nth-child(3){background:#7fb36a}.chrome-url{font-size:12.5px;color:#6b6048;font-weight:600}.workspace{flex:1;display:flex;min-height:0}.sidebar{flex:none;width:220px;background:var(--sidebar);display:flex;flex-direction:column;padding:16px 12px}.side-brand{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--display);font-weight:700;font-size:16px;padding:4px 8px 16px}.side-brand small{display:block;font-family:var(--ui);font-weight:600;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--nav-inactive);margin-top:2px}.side-nav{display:flex;flex-direction:column;gap:2px;flex:1}.nav-item{text-align:left;background:none;border:none;border-radius:9px;padding:10px 12px;font:600 14px var(--ui);color:var(--nav-inactive);border-left:3px solid transparent;cursor:pointer}.nav-item:hover{color:#fff;background:#ffffff0d}.nav-item.active{color:#fff;background:var(--sidebar-deep);border-left-color:var(--nav-accent)}.side-foot{border-top:1px solid rgba(255,255,255,.1);padding-top:12px;display:flex;align-items:center;justify-content:space-between;gap:8px}.side-who{display:flex;flex-direction:column;line-height:1.3}.side-who b{color:#fff;font-size:13px}.side-who span{color:var(--nav-inactive);font-size:11px;text-transform:capitalize}.side-out{background:#ffffff14;border:none;color:var(--nav-accent);font:600 12px var(--ui);border-radius:8px;padding:6px 10px;cursor:pointer}.side-out:hover{background:#ffffff29}.main{flex:1;overflow:auto}.content{padding:24px;max-width:1080px;width:100%;margin:0 auto}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.toolbar input[type=date]{height:38px;border:1px solid var(--border);border-radius:8px;padding:0 10px}.spacer{flex:1}.muted{color:var(--muted);font-size:13px}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--open);display:inline-block;margin-right:6px;animation:pulse 1.6s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px}.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:18px}.metric{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px}.metric .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.metric .value{font-family:var(--display);font-size:28px;font-weight:800;margin-top:4px;letter-spacing:-.01em}table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}th,td{text-align:left;padding:11px 14px;font-size:14px;border-bottom:1px solid var(--border)}th{background:var(--surface-alt);color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}tr:last-child td{border-bottom:none}.code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.pill .dot{width:7px;height:7px;border-radius:50%}.zone-row{display:grid;grid-template-columns:80px 1fr 160px;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border)}.zone-row:last-child{border-bottom:none}.zcode{font-weight:700}.bar-track{height:12px;background:var(--surface-alt);border-radius:999px;overflow:hidden}.bar-fill{height:100%;border-radius:999px}.znum{text-align:right;font-size:13px;color:var(--muted)}.checkin-box{display:flex;gap:10px;margin-bottom:18px}.checkin-box input{flex:1;height:52px;font-size:18px;border:2px solid var(--ocean);border-radius:10px;padding:0 16px;font-family:ui-monospace,monospace}.result{border-radius:14px;padding:18px;margin-bottom:18px;display:flex;gap:14px;align-items:center}.result.ok{background:#1ba6721a;border:1px solid var(--open)}.result.bad{background:#e0564b1a;border:1px solid var(--full)}.result .big{font-size:20px;font-weight:700}.result .icon{font-size:34px}h2{font-size:18px;margin:0 0 14px}.row-actions{display:flex;gap:8px}.input-sm{height:34px;width:90px;border:1px solid var(--border);border-radius:7px;padding:0 8px}.btn.danger{background:var(--full)}.btn.danger:hover{background:#c2453b}.note-input{width:100%;height:34px;border:1px solid var(--border);border-radius:7px;padding:0 10px;font-size:13px}.note-input:focus{outline:2px solid var(--ocean);border-color:var(--ocean)}.ann-text{width:100%;min-height:64px;border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:14px;font-family:inherit;resize:vertical}.ann-text:focus{outline:2px solid var(--ocean);border-color:var(--ocean)}.ann-row{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;align-items:center}.ann-row select,.ann-row input{height:40px;border:1px solid var(--border);border-radius:8px;padding:0 10px;font-size:14px}.ann-row input{flex:1;min-width:140px}.ann-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.ann-item:last-child{border-bottom:none}.ann-badge{text-transform:uppercase;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;letter-spacing:.5px}.ann-info{background:var(--ocean-tint);color:var(--ocean-dark)}.ann-warning{background:#f4a3401a;color:#8a5a12}.ann-alert{background:#e0564b1a;color:var(--full)}.reg-add{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.reg-add input{height:40px;border:1px solid var(--border);border-radius:8px;padding:0 12px;font-size:14px;flex:1;min-width:140px}.reg-add input:focus{outline:2px solid var(--ocean);border-color:var(--ocean)}.reg-add .btn{height:40px}.role-select{height:40px;border:1px solid var(--border);border-radius:8px;padding:0 10px;font-size:14px}.search{height:38px;flex:1;min-width:220px;border:1px solid var(--border);border-radius:8px;padding:0 12px;font-size:14px}.search:focus{outline:2px solid var(--ocean);border-color:var(--ocean)}.reg-hint{margin-top:10px;font-size:13px;color:var(--muted)}.reg-hint code{background:#00000010;padding:1px 5px;border-radius:4px;font-size:12px}.check{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.check input{width:16px;height:16px}.send-box{margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}.send-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px}.copy-row input:not([readonly]){background:var(--surface)}.copy-row input:focus{outline:2px solid var(--ocean);border-color:var(--ocean)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d243073;display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.modal{background:var(--surface);border-radius:16px;padding:24px;width:460px;max-width:100%;box-shadow:0 20px 60px #0d243040}.qr-wrap{display:flex;justify-content:center;padding:14px;background:#fff;border:1px solid var(--border);border-radius:12px;margin:12px 0 16px}.qr{width:200px;height:200px}.copy-row{display:flex;gap:8px}.copy-row input{flex:1;height:40px;border:1px solid var(--border);border-radius:8px;padding:0 12px;font-size:13px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--surface-alt)}.copy-row .btn{height:40px;white-space:nowrap}.warn{background:#f4a3401a;border:1px solid var(--filling);color:#8a5a12;border-radius:10px;padding:10px 12px;font-size:13px;line-height:1.5;margin-bottom:12px}.warn code{background:#00000010;padding:1px 5px;border-radius:4px;font-size:12px}
