@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Mono:wght@300;400;500&family=DM+Sans:wght@300;400;500;600&display=swap";:root{--bg:#0a0c0f;--bg-2:#0f1215;--bg-3:#151a1e;--bg-4:#1c2228;--border:#1f2830;--border-2:#2a3540;--text:#e8edf2;--text-2:#8fa0b0;--text-3:#556070;--accent:#00d4ff;--accent-dim:#00d4ff1f;--accent-glow:#00d4ff0a;--green:#00e5a0;--green-dim:#00e5a01f;--red:#ff4757;--red-dim:#ff47571f;--amber:#ffb300;--amber-dim:#ffb3001f;--font-display:"Syne", sans-serif;--font-mono:"DM Mono", monospace;--font-body:"DM Sans", sans-serif;--r:6px;--r-lg:10px;--r-xl:16px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh}.app-shell{grid-template-rows:56px 1fr;grid-template-columns:220px 1fr;min-height:100vh;display:grid}.topbar{background:var(--bg-2);border-bottom:1px solid var(--border);z-index:100;grid-column:1/-1;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.topbar-brand{font-family:var(--font-display);letter-spacing:.04em;color:var(--text);align-items:center;gap:10px;font-size:1.1rem;font-weight:700;display:flex}.topbar-brand .dot{background:var(--accent);width:8px;height:8px;box-shadow:0 0 8px var(--accent);border-radius:50%;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.topbar-right{align-items:center;gap:16px;display:flex}.user-chip{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);color:var(--text-2);align-items:center;gap:8px;padding:6px 12px;font-size:.85rem;display:flex}.user-chip .role-badge{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;border-radius:3px;padding:2px 6px;font-size:.7rem}.role-badge.superadmin,.role-badge.admin{background:var(--accent-dim);color:var(--accent)}.role-badge.guard{background:var(--green-dim);color:var(--green)}.role-badge.tenant{background:var(--amber-dim);color:var(--amber)}.sidebar{background:var(--bg-2);border-right:1px solid var(--border);flex-direction:column;gap:4px;padding:20px 12px;display:flex}.nav-section{font-family:var(--font-mono);color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;padding:12px 10px 6px;font-size:.65rem}.nav-item{border-radius:var(--r);color:var(--text-2);cursor:pointer;border:1px solid #0000;align-items:center;gap:10px;padding:9px 10px;font-size:.88rem;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-3);color:var(--text)}.nav-item.active{background:var(--accent-dim);color:var(--accent);border-color:#00d4ff26}.nav-item .nav-icon{text-align:center;width:18px;font-size:1rem}.main{background:var(--bg);padding:24px;overflow-y:auto}.page-header{margin-bottom:24px}.page-title{font-family:var(--font-display);color:var(--text);margin-bottom:4px;font-size:1.5rem;font-weight:700}.page-sub{color:var(--text-3);font-size:.85rem;font-family:var(--font-mono)}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{font-family:var(--font-display);color:var(--text);font-size:.95rem;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;position:relative;overflow:hidden}.stat-card:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.stat-card.blue:before{background:var(--accent)}.stat-card.green:before{background:var(--green)}.stat-card.red:before{background:var(--red)}.stat-card.amber:before{background:var(--amber)}.stat-card.purple:before{background:#a78bfa}.stat-value{font-family:var(--font-display);margin-bottom:6px;font-size:2rem;font-weight:800;line-height:1}.stat-card.blue .stat-value{color:var(--accent)}.stat-card.green .stat-value{color:var(--green)}.stat-card.red .stat-value{color:var(--red)}.stat-card.amber .stat-value{color:var(--amber)}.stat-card.purple .stat-value{color:#a78bfa}.stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-family:var(--font-mono)}.btn{border-radius:var(--r);cursor:pointer;font-size:.85rem;font-weight:500;font-family:var(--font-body);white-space:nowrap;border:1px solid #0000;align-items:center;gap:7px;padding:8px 16px;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#000;font-weight:600}.btn-primary:hover{filter:brightness(1.1)}.btn-secondary{background:var(--bg-3);border-color:var(--border);color:var(--text-2)}.btn-secondary:hover{border-color:var(--border-2);color:var(--text)}.btn-danger{background:var(--red-dim);color:var(--red);border-color:#ff475733}.btn-danger:hover{background:#ff475733}.btn-success{background:var(--green-dim);color:var(--green);border-color:#00e5a033}.btn-sm{padding:5px 10px;font-size:.8rem}.btn:disabled{opacity:.4;cursor:not-allowed}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-grid.cols-1{grid-template-columns:1fr}.form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.field{flex-direction:column;gap:6px;display:flex}.field.span-2{grid-column:span 2}label{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-family:var(--font-mono)}input,select,textarea{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);color:var(--text);font-size:.88rem;font-family:var(--font-body);outline:none;width:100%;padding:9px 12px;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent)}input::placeholder,textarea::placeholder{color:var(--text-3)}select option{background:var(--bg-3)}.table-wrap{border-radius:var(--r-lg);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.85rem}thead th{text-align:left;font-family:var(--font-mono);color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;background:var(--bg-3);border-bottom:1px solid var(--border);padding:10px 14px;font-size:.72rem}tbody tr{border-bottom:1px solid var(--border);transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-3)}tbody td{color:var(--text-2);vertical-align:middle;padding:12px 14px}tbody td strong{color:var(--text)}.badge{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;border-radius:3px;align-items:center;padding:3px 8px;font-size:.72rem;font-weight:500;display:inline-flex}.badge-green{background:var(--green-dim);color:var(--green)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-blue{background:var(--accent-dim);color:var(--accent)}.badge-gray{background:var(--bg-4);color:var(--text-3)}.search-wrap{position:relative}.search-wrap input{padding-left:36px}.search-icon{color:var(--text-3);pointer-events:none;font-size:.9rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-dropdown{background:var(--bg-3);border:1px solid var(--border-2);border-radius:var(--r-lg);z-index:200;max-height:320px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 32px #0006}.search-item{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 14px;transition:background .1s;display:flex}.search-item:last-child{border-bottom:none}.search-item:hover{background:var(--bg-4)}.search-thumb{object-fit:cover;border:1px solid var(--border);background:var(--bg-4);border-radius:50%;width:36px;height:36px}.search-thumb-placeholder{background:var(--bg-4);border:1px solid var(--border);width:36px;height:36px;color:var(--text-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.visitor-card{background:var(--bg-3);border:1px solid var(--border-2);border-radius:var(--r-xl);margin-top:16px;padding:20px}.visitor-header{border-bottom:1px solid var(--border);align-items:center;gap:16px;margin-bottom:20px;padding-bottom:20px;display:flex}.visitor-avatar{object-fit:cover;border:2px solid var(--border-2);border-radius:50%;width:64px;height:64px}.visitor-avatar-placeholder{background:var(--bg-4);border:2px solid var(--border-2);width:64px;height:64px;color:var(--text-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;display:flex}.visitor-name{font-family:var(--font-display);color:var(--text);font-size:1.15rem;font-weight:700}.visitor-id{font-family:var(--font-mono);color:var(--text-3);margin-top:3px;font-size:.8rem}.visitor-meta{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.active-visit-row{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-lg);justify-content:space-between;align-items:center;margin-bottom:8px;padding:14px 16px;transition:border-color .15s;display:flex}.active-visit-row:hover{border-color:var(--border-2)}.visit-info{flex:1}.visit-name{color:var(--text);margin-bottom:3px;font-weight:500}.visit-meta{color:var(--text-3);font-size:.8rem;font-family:var(--font-mono)}.visit-timer{font-family:var(--font-mono);color:var(--accent);text-align:right;margin-right:16px;font-size:.8rem}.login-page{background:var(--bg);background-image:radial-gradient(at 20%,#00d4ff0a 0%,#0000 60%),radial-gradient(at 80% 20%,#00e5a008 0%,#0000 50%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:380px;padding:40px;box-shadow:0 24px 64px #00000080}.login-logo{text-align:center;margin-bottom:32px}.login-logo-text{font-family:var(--font-display);letter-spacing:.05em;color:var(--text);font-size:1.8rem;font-weight:800}.login-logo-sub{font-family:var(--font-mono);color:var(--text-3);text-transform:uppercase;letter-spacing:.12em;margin-top:4px;font-size:.72rem}.login-form{flex-direction:column;gap:14px;display:flex}.error-box{background:var(--red-dim);border-radius:var(--r);color:var(--red);border:1px solid #ff475733;padding:10px 14px;font-size:.85rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--r-xl);width:100%;max-width:520px;max-height:90vh;padding:28px;overflow-y:auto;box-shadow:0 32px 80px #0009}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700}.modal-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;padding:4px;font-size:1.2rem;transition:color .15s}.modal-close:hover{color:var(--text)}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:24px;padding-top:20px;display:flex}.blacklist-alert{background:var(--red-dim);border-radius:var(--r-lg);border:1px solid #ff47574d;align-items:flex-start;gap:12px;padding:16px;display:flex}.blacklist-icon{flex-shrink:0;font-size:1.3rem}.blacklist-text .title{color:var(--red);margin-bottom:4px;font-weight:600}.blacklist-text .reason{color:var(--text-2);font-size:.85rem}.empty-state{text-align:center;color:var(--text-3);padding:48px 24px}.empty-icon{margin-bottom:12px;font-size:2.5rem}.empty-text{font-size:.9rem}.loading{color:var(--text-3);font-family:var(--font-mono);justify-content:center;align-items:center;gap:10px;padding:48px;font-size:.85rem;display:flex}.spinner{border:2px solid var(--border-2);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.bar-chart{align-items:flex-end;gap:4px;height:100px;padding:0 4px;display:flex}.bar-col{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.bar{background:var(--accent-dim);border-top:1px solid #00d4ff4d;border-radius:2px 2px 0 0;width:100%;min-height:2px;transition:height .3s}.bar-label{font-family:var(--font-mono);color:var(--text-3);font-size:.6rem}.divider{background:var(--border);height:1px;margin:20px 0}.method-toggle{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);gap:2px;margin-bottom:16px;padding:3px;display:flex}.method-btn{cursor:pointer;color:var(--text-3);font-size:.82rem;font-family:var(--font-body);background:0 0;border:none;border-radius:4px;flex:1;justify-content:center;align-items:center;gap:6px;padding:7px 12px;transition:all .15s;display:flex}.method-btn.active{background:var(--bg-4);color:var(--text);border:1px solid var(--border-2)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}@media (width<=768px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.form-grid{grid-template-columns:1fr}.form-grid .span-2{grid-column:span 1}}
