@import"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&family=Inter:wght@400;500;700&family=Open+Sans:wght@400;600;700&family=Lato:wght@400;700&family=Montserrat:wght@400;500;700&family=Nunito:wght@400;600;700&family=Raleway:wght@400;500;700&family=Poppins:wght@400;500;700&family=Merriweather:wght@400;700&family=PT+Sans:wght@400;700&family=JetBrains+Mono:wght@400;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f4f6f9;--bg2: #ffffff;--bg3: #f0f3f7;--border: #e2e7ef;--text: #2d3748;--text2: #718096;--accent: #e53e3e;--accent2: #c53030;--accent-bg: #fff5f5;--accent-blue: #1e88e5;--accent-blue2: #1565c0;--accent-blue-bg: #e3f0fc;--danger: #e53e3e;--danger-bg: #fff5f5;--warn: #d97706;--warn-bg: #fffbeb;--success: #38a169;--success-bg:#f0fff4;--sidebar-bg:#1a1f2e;--sidebar-text: #a0aec0;--sidebar-active: #ffffff;--header-bg: #1a1f2e;--mono: "JetBrains Mono", monospace;--sans: "Roboto", -apple-system, BlinkMacSystemFont, sans-serif;--font-current: var(--sans);--radius: 4px;--radius-lg: 6px;--shadow: 0 1px 4px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(0,0,0,.12)}body{font-family:var(--font-current, var(--sans));background:var(--bg);color:var(--text);font-size:13px;line-height:1.5;min-height:100vh}a{color:var(--accent-blue);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:var(--sans)}.layout{display:flex;min-height:100vh}.sidebar{width:220px;flex-shrink:0;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;box-shadow:2px 0 8px #00000026}.sidebar-logo{padding:0 20px;height:60px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.08);background:#00000026}.sidebar-logo .logo-icon{width:34px;height:34px;background:var(--accent);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.sidebar-logo h1{font-size:13px;font-weight:700;color:#fff;line-height:1.2}.sidebar-logo p{font-size:10px;color:var(--sidebar-text);margin-top:1px}.sidebar-section-title{font-size:10px;font-weight:700;color:#a0aec080;text-transform:uppercase;letter-spacing:.1em;padding:18px 20px 6px}.sidebar nav{padding:8px 0;flex:1;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--sidebar-text);font-size:13px;font-weight:500;transition:all .15s;cursor:pointer;text-decoration:none;border-radius:0;position:relative}.nav-item:hover{color:#fff;background:#ffffff12;text-decoration:none}.nav-item.active{color:#fff;background:#e53e3e33}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.nav-item .icon{font-size:15px;width:18px;text-align:center;flex-shrink:0}.sidebar-footer{padding:14px 20px;border-top:1px solid rgba(255,255,255,.08)}.main{flex:1;margin-left:220px;display:flex;flex-direction:column;min-height:100vh;position:relative}.topbar{height:60px;background:var(--header-bg);border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;padding:0 24px;gap:12px;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px #00000026}.topbar-title{font-size:15px;font-weight:500;color:#fff;flex:1}.page{padding:24px;max-width:1400px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}.page-title{font-size:18px;font-weight:700;color:var(--text)}.page-subtitle{font-size:12px;color:var(--text2);margin-top:2px}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;margin-bottom:20px}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow);border-top:3px solid var(--accent-blue);transition:box-shadow .15s}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-card .label{font-size:11px;color:var(--text2);font-weight:500;margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}.stat-card .value{font-size:28px;font-weight:700;color:var(--text);line-height:1}.stat-card .sub{font-size:11px;color:var(--text2);margin-top:4px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead tr{background:#e8f0fb}th{text-align:left;padding:11px 14px;color:#3a5a8a;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #c5d8f0;white-space:nowrap;-webkit-user-select:none;user-select:none}td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text)}tbody tr:hover{background:#f5f9ff}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;border:1px solid transparent}.badge-guard{background:#fff1f0;color:#cf1322;border-color:#ffa39e}.badge-employee{background:#fffbe6;color:#ad6800;border-color:#ffe58f}.badge-tech{background:#e6f7ff;color:#0050b3;border-color:#91d5ff}.badge-unknown{background:#f5f5f5;color:#595959;border-color:#d9d9d9}.badge-contractor{background:#f9f0ff;color:#531dab;border-color:#d3adf7}.badge-new{background:#e6f7ff;color:#0050b3;border-color:#91d5ff}.badge-investigating{background:#fffbe6;color:#ad6800;border-color:#ffe58f}.badge-resolved{background:#f6ffed;color:#135200;border-color:#b7eb8f}.badge-closed{background:#f5f5f5;color:#595959;border-color:#d9d9d9}.badge-critical{background:#fff1f0;color:#cf1322;border-color:#ffa39e}.badge-high{background:#fff7e6;color:#ad4e00;border-color:#ffd591}.badge-medium{background:#e6f7ff;color:#0050b3;border-color:#91d5ff}.badge-low{background:#f6ffed;color:#135200;border-color:#b7eb8f}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius);font-size:13px;font-weight:700;border:1px solid transparent;transition:all .15s;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent2);border-color:var(--accent2);box-shadow:0 2px 8px #e53e3e4d}.btn-secondary{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.btn-secondary:hover{background:var(--accent-blue2);border-color:var(--accent-blue2);box-shadow:0 2px 8px #1e88e54d}.btn-ghost{background:var(--bg2);color:var(--text);border-color:var(--border);text-transform:none;font-weight:500}.btn-ghost:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:var(--accent-blue-bg)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#fca5a5;text-transform:none;font-weight:500}.btn-danger:hover{background:#fee2e2}.btn-sm{padding:4px 12px;font-size:12px}.filters-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:16px;box-shadow:var(--shadow)}.filters-bar select,.filters-bar input{width:auto;min-width:150px;height:32px;padding:0 10px;font-size:12px}.filter-label{font-size:12px;color:var(--text2);font-weight:500;margin-right:4px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid.cols-1{grid-template-columns:1fr}.form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.field{display:flex;flex-direction:column;gap:5px}.field.full{grid-column:1 / -1}label{font-size:12px;font-weight:600;color:var(--text2)}input,select,textarea{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--sans);font-size:13px;padding:7px 10px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #1e88e51a}textarea{resize:vertical;min-height:76px}.empty{text-align:center;padding:48px 20px;color:var(--text2)}.empty .icon{font-size:36px;margin-bottom:10px}.empty .title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f142399;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:720px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--sidebar-bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-title{font-size:14px;font-weight:700;color:#fff}.modal-body{padding:20px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border);background:#f7f9fc;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.modal-section-title{font-size:11px;font-weight:700;color:var(--accent-blue);text-transform:uppercase;letter-spacing:.07em;margin:18px 0 10px;padding-bottom:7px;border-bottom:2px solid var(--accent-blue-bg)}.modal-section-title:first-child{margin-top:0}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg2);background-image:radial-gradient(ellipse at 60% 40%,rgba(30,136,229,.06) 0%,transparent 60%)}.login-box{background:var(--sidebar-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 40px;width:100%;max-width:380px;box-shadow:0 8px 32px #00000073}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:24px}.login-logo .logo-icon{width:40px;height:40px;background:var(--accent);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:20px}.login-logo h1{font-size:16px;font-weight:700;color:var(--sidebar-text, #f1f5f9)}.login-logo p{font-size:12px;color:var(--sidebar-text2, #94a3b8)}.error-msg{background:var(--danger-bg);border:1px solid #fca5a5;color:var(--danger);padding:9px 12px;border-radius:var(--radius);font-size:13px;margin-bottom:12px}.report-section{margin-bottom:24px}.report-section h3{font-size:12px;color:var(--text2);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.bar-row{display:flex;align-items:center;gap:12px;margin-bottom:8px;font-size:13px}.bar-label{width:220px;flex-shrink:0}.bar-track{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}.bar-fill{height:100%;border-radius:3px;background:var(--accent-blue);transition:width .4s}.bar-count{width:28px;text-align:right;font-weight:600;font-size:12px;color:var(--text2)}.report-table td,.report-table th{vertical-align:top}.report-table .col-date{width:80px;white-space:nowrap}.report-table .col-type{width:130px}.report-table .col-desc{min-width:160px}.report-table .col-emp{min-width:140px}.report-table .col-guard{min-width:150px}.report-table .col-time{width:75px;text-align:center}.report-table .col-fix{min-width:150px}.report-table .col-status{width:110px}.flag-warn{display:inline-block;background:var(--warn-bg);color:var(--warn);border:1px solid #fcd34d;border-radius:20px;font-size:10px;font-weight:600;padding:1px 6px;margin-top:3px}.flag-ok{display:inline-block;background:var(--success-bg);color:var(--success);border:1px solid #86efac;border-radius:20px;font-size:10px;font-weight:600;padding:1px 6px;margin-top:3px}.violation-card{background:#fff8f8;border:1px solid #fca5a5;border-left:4px solid var(--danger);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:10px}.violation-card .v-title{font-size:13px;font-weight:700;color:var(--danger);margin-bottom:6px}.violation-card .v-body{font-size:13px;color:var(--text);line-height:1.7}.violation-card ul{margin-top:8px;padding-left:18px}.violation-card li{margin-bottom:4px}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.card .table-wrap table,.card>table{width:100%;min-width:900px}.report-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.report-table-wrap table{width:100%;table-layout:fixed;min-width:860px}.card{width:100%;box-sizing:border-box}.page{width:100%;box-sizing:border-box;max-width:100%}.report-page-table{width:100%;overflow-x:auto}.plan-page{display:flex;flex-direction:column;position:absolute;top:0;right:0;bottom:0;left:0;background:#0e1117;overflow:hidden}.plan-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 18px;background:var(--sidebar-bg);border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;flex-wrap:wrap}.plan-toolbar-title{font-size:14px;font-weight:700;color:#fff;white-space:nowrap}.plan-toolbar-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.plan-scale-badge{font-size:12px;font-weight:600;color:#a0aec0cc;min-width:40px;text-align:center}.plan-canvas{flex:1;min-height:0;position:relative;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.plan-canvas.dragging{cursor:grabbing}.plan-canvas-empty{cursor:default;display:flex;align-items:center;justify-content:center}.plan-image{position:absolute;top:50%;left:50%;max-width:none;max-height:none;transform-origin:center center;display:block;pointer-events:none;border-radius:2px;box-shadow:0 4px 32px #0009}.plan-drop-hint{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;border:2px dashed rgba(255,255,255,.15);border-radius:12px;cursor:pointer;transition:border-color .2s,background .2s;max-width:380px;text-align:center}.plan-drop-hint:hover{border-color:#1e88e599;background:#1e88e50f}.plan-drop-icon{font-size:48px;line-height:1}.plan-drop-text{font-size:15px;font-weight:600;color:#ffffffb3;line-height:1.5}.plan-drop-sub{font-size:12px;color:#ffffff59}.plan-save-warn{background:#7c4a00;color:#ffd97d;font-size:12px;padding:8px 16px;flex-shrink:0;border-bottom:1px solid #a06000}.topbar-menu-btn{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:6px;cursor:pointer;padding:7px 8px;flex-shrink:0}.topbar-menu-btn span{display:block;width:100%;height:2px;background:#ffffffbf;border-radius:2px;transition:background .15s}.topbar-menu-btn:hover span{background:#fff}.sidebar-close{display:none;background:none;border:none;color:#a0aec099;font-size:16px;cursor:pointer;padding:4px;margin-left:auto;line-height:1}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:99}@media (max-width: 768px){.topbar-menu-btn{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:240px;transform:translate(-100%);transition:transform .25s ease;z-index:200}.sidebar.open{transform:translate(0)}.sidebar-close,.sidebar-overlay{display:block}.main{margin-left:0}.topbar{padding:0 14px;gap:10px}.topbar-title{font-size:14px}.page{padding:12px}.stat-grid{grid-template-columns:1fr 1fr;gap:10px}.form-grid,.form-grid.cols-3{grid-template-columns:1fr}.card{padding:14px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.page-header{flex-direction:column;align-items:flex-start;gap:8px}.filters-bar{flex-direction:column;align-items:stretch}.filters-bar select,.filters-bar input{min-width:0;width:100%}.plan-toolbar{padding:8px 12px}.plan-toolbar-title{font-size:13px}.plan-toolbar-actions{gap:4px}.btn.btn-sm{padding:4px 8px;font-size:11px}}
