*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f4f5f7;--surface: #ffffff;--surface2: #f8f9fb;--surface3: #edf0f4;--border: #e1e4e8;--border2: #d0d4da;--accent: #2563eb;--accent-h: #1d4ed8;--accent-l: #eff6ff;--accent-subtle: rgba(37,99,235,.06);--green: #16a34a;--green-l: #dcfce7;--green-bg: rgba(22,163,74,.08);--red: #dc2626;--red-l: #fee2e2;--red-bg: rgba(220,38,38,.08);--amber: #d97706;--amber-l: #fef3c7;--amber-bg: rgba(217,119,6,.08);--blue: #2563eb;--blue-l: #dbeafe;--gray: #6b7280;--gray-l: #f3f4f6;--text: #1a1d21;--text2: #5e6369;--text3: #8b9099;--font: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono: "DM Mono", "Menlo", "Consolas", monospace;--radius: 8px;--radius-sm: 5px;--radius-lg: 12px;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.03);--shadow-md: 0 4px 8px rgba(0,0,0,.06);--shadow-lg: 0 8px 24px rgba(0,0,0,.08);--shadow-xl: 0 16px 48px rgba(0,0,0,.1);--sidebar-w: 240px;--topbar-h: 48px;--transition: .15s ease}body{font-family:var(--font);font-size:13px;color:var(--text);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:20px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:36px;width:100%;max-width:380px}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px}.login-logo-icon{width:40px;height:40px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:20px;flex-shrink:0}.login-logo-title{font-size:18px;font-weight:700;color:var(--text)}.login-logo-sub{font-size:11px;font-family:var(--mono);color:var(--text3);margin-top:1px}.login-hint{font-size:13px;color:var(--text2);margin-bottom:16px}.login-footer{margin-top:20px;font-size:11px;font-family:var(--mono);color:var(--text3);text-align:center}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px}.form-input,.form-select,.form-textarea{width:100%;padding:7px 10px;font-family:var(--font);font-size:13px;color:var(--text);background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-sm);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px #2563eb1a}.form-input::placeholder{color:var(--text3)}.form-textarea{min-height:72px;resize:vertical}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-hint{font-size:11px;color:var(--text3);margin-top:3px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:6px 14px;font-family:var(--font);font-size:12px;font-weight:600;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer;transition:all var(--transition);white-space:nowrap;line-height:1.4}.btn:hover{background:var(--surface2);border-color:var(--border2)}.btn.primary,.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover,.btn-primary:hover{background:var(--accent-h)}.btn.danger{background:var(--red);color:#fff;border-color:var(--red)}.btn.danger:hover{background:#b91c1c}.btn.success{background:var(--green);color:#fff;border-color:var(--green)}.btn.sm{padding:4px 10px;font-size:11px}.btn.full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text2);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);font-size:14px}.icon-btn:hover{background:var(--surface3);color:var(--text)}#app{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:#1a1d21;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .25s ease}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 14px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo{display:flex;align-items:center;gap:10px;cursor:pointer;text-decoration:none}.sidebar-logo-icon{width:30px;height:30px;background:var(--accent);border-radius:7px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.sidebar-logo-text{font-weight:700;font-size:14px;color:#fff}.sidebar-collapse-btn{display:none;background:none;border:none;color:#ffffff80;cursor:pointer;padding:4px;border-radius:var(--radius-sm)}.sidebar-collapse-btn:hover{background:#ffffff1a}.sidebar-nav{flex:1;overflow-y:auto;padding:8px}.nav-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;padding:16px 10px 5px}.nav-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--radius-sm);color:#fff9;text-decoration:none;font-size:13px;font-weight:500;transition:all var(--transition)}.nav-item svg{stroke:#ffffff73;flex-shrink:0}.nav-item:hover{background:#ffffff0f;color:#ffffffe6}.nav-item:hover svg{stroke:#ffffffb3}.nav-item.active{background:#2563eb33;color:#93bbfc}.nav-item.active svg{stroke:#93bbfc}.sidebar-footer{padding:12px 14px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-footer-text{font-size:11px;font-family:var(--mono);color:#ffffff4d}.sidebar-user{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);margin-bottom:6px}.sidebar-user:hover{background:#ffffff0f}.sidebar-user-avatar{width:28px;height:28px;border-radius:50%;background:#2563eb4d;color:#93bbfc;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0;overflow:hidden}.sidebar-user-name{font-size:12px;font-weight:600;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:10px;color:#fff6;text-transform:uppercase;letter-spacing:.04em}#main{flex:1;margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column;transition:margin-left .25s ease}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:12px;padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.topbar-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap}.topbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.topbar-search{display:flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 10px;transition:all var(--transition)}.topbar-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px #2563eb1a;background:var(--surface)}.topbar-search svg{color:var(--text3);flex-shrink:0;width:14px;height:14px}.topbar-search-input{border:none;background:transparent;outline:none;font-family:var(--font);font-size:12px;color:var(--text);padding:5px 0;width:200px}.topbar-search-input::placeholder{color:var(--text3)}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text2);cursor:pointer;padding:4px}.view-container{flex:1;padding:20px;max-width:1400px;width:100%}.view{display:none;animation:viewIn .15s ease}.view.active{display:block}@keyframes viewIn{0%{opacity:0}to{opacity:1}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-xs)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.card-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text2)}.card-body{padding:16px}.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-xs)}.kpi-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3);margin-bottom:4px}.kpi-value{font-size:24px;font-weight:700;color:var(--text);line-height:1}.kpi-sub{font-size:11px;color:var(--text3);margin-top:4px}.badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;border-radius:3px;white-space:nowrap}.badge.available{background:var(--green-bg);color:var(--green)}.badge.deployed{background:#2563eb14;color:var(--accent)}.badge.maintenance{background:var(--amber-bg);color:var(--amber)}.badge.retired{background:var(--gray-l);color:var(--gray)}.badge.lost{background:var(--red-bg);color:var(--red)}.badge.disposed{background:var(--gray-l);color:var(--text3)}.badge.create{background:var(--green-bg);color:var(--green)}.badge.checkout{background:#2563eb14;color:var(--accent)}.badge.checkin{background:var(--amber-bg);color:var(--amber)}.badge.update{background:var(--gray-l);color:var(--text2)}.badge.dispose{background:var(--red-bg);color:var(--red)}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}table,.table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3);background:var(--surface2);border-bottom:1px solid var(--border);position:sticky;top:0;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}thead th:hover{color:var(--text2)}thead th.sorted{color:var(--accent)}thead th .sort-arrow{font-size:9px;margin-left:3px}tbody tr{border-bottom:1px solid var(--border);transition:background var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--accent-subtle)}tbody td{padding:7px 12px;vertical-align:middle}tbody td.mono{font-family:var(--mono);font-size:12px}.table-empty{text-align:center;padding:32px 16px;color:var(--text3);font-size:13px}.filter-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:12px}.filter-pill{padding:4px 12px;font-size:12px;font-weight:500;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text2);cursor:pointer;transition:all var(--transition);white-space:nowrap}.filter-pill:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}.filter-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 0;font-size:12px;color:var(--text3)}.pagination-btns{display:flex;gap:3px}.pagination-btns button{padding:4px 8px;font-size:12px;font-family:var(--mono);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text2);cursor:pointer;transition:all var(--transition)}.pagination-btns button:hover{background:var(--surface2)}.pagination-btns button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pagination-btns button:disabled{opacity:.4;cursor:not-allowed}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}.toolbar-left{display:flex;align-items:center;gap:8px}.toolbar-search{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 10px}.toolbar-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px #2563eb1a}.toolbar-search input{border:none;outline:none;background:transparent;font-family:var(--font);font-size:12px;color:var(--text);padding:6px 0;width:200px}.toolbar-search input::placeholder{color:var(--text3)}.toolbar-right{display:flex;align-items:center;gap:6px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}.modal-overlay.open{display:flex}.modal-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:85vh;overflow-y:auto;animation:modalIn .15s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border)}.modal-title{font-size:15px;font-weight:700}.modal-close{background:none;border:none;font-size:20px;color:var(--text3);cursor:pointer;line-height:1;padding:0 4px}.modal-close:hover{color:var(--text)}.modal-body{padding:16px 20px 20px}.confirm-card{max-width:360px;text-align:center;padding:24px}.confirm-body{font-size:14px;margin-bottom:16px;color:var(--text)}.confirm-actions{display:flex;gap:8px;justify-content:center}#toast-container{position:fixed;bottom:20px;right:20px;z-index:300;display:flex;flex-direction:column-reverse;gap:6px}.toast{padding:10px 16px;font-size:13px;font-weight:500;background:var(--text);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);animation:toastIn .2s ease;max-width:340px}.toast.success{background:var(--green)}.toast.error{background:var(--red)}.toast.warning{background:var(--amber);color:var(--text)}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast.out{animation:toastOut .15s ease forwards}@keyframes toastOut{to{opacity:0;transform:translateY(-6px)}}.view-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.view-placeholder-icon{font-size:40px;margin-bottom:12px;opacity:.3}.view-placeholder-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}.view-placeholder-sub{font-size:12px;color:var(--text3);max-width:320px}.skeleton{background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-line{height:12px;margin-bottom:8px}.skeleton-line.short{width:40%}.skeleton-line.med{width:65%}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:16px}.tab{padding:8px 16px;font-size:12px;font-weight:500;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition);background:none;border-top:none;border-left:none;border-right:none;font-family:var(--font)}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.detail-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}.detail-header-info{flex:1}.detail-header-tag{font-size:12px;font-family:var(--mono);color:var(--text3);margin-bottom:2px}.detail-header-name{font-size:20px;font-weight:700;margin-bottom:4px}.detail-header-actions{display:flex;gap:6px;flex-shrink:0}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:20px}.detail-field-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3);margin-bottom:2px}.detail-field-value{font-size:13px;color:var(--text)}.detail-field-value.empty{color:var(--text3);font-style:italic}@keyframes kpiPop{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.kbd{display:inline-flex;align-items:center;padding:1px 5px;font-size:10px;font-family:var(--mono);background:var(--surface3);border:1px solid var(--border);border-radius:3px;color:var(--text3);line-height:1.4}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:none;align-items:flex-start;justify-content:center;z-index:250;padding-top:12vh}.search-overlay.open{display:flex}.search-overlay-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:520px;animation:modalIn .12s ease}.search-overlay-input{width:100%;padding:14px 18px;font-size:15px;font-family:var(--font);border:none;outline:none;background:transparent;color:var(--text);border-bottom:1px solid var(--border)}.search-overlay-input::placeholder{color:var(--text3)}.search-overlay-results{max-height:320px;overflow-y:auto;padding:6px}.search-overlay-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition)}.search-overlay-item:hover{background:var(--surface2)}.search-overlay-empty{padding:20px;text-align:center;font-size:12px;color:var(--text3)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:99}.sidebar-overlay.active{display:block}@media print{.sidebar,.topbar,.toolbar,.pagination,.btn,.modal-overlay,#toast-container,.search-overlay,.sidebar-overlay,.filter-bar{display:none!important}#main{margin-left:0!important}.view-container{padding:0;max-width:100%}.table-wrap{border:none;box-shadow:none}table{font-size:11px}thead th{background:#f5f5f5;-webkit-print-color-adjust:exact;print-color-adjust:exact}tbody tr{page-break-inside:avoid}.badge{border:1px solid #ccc;-webkit-print-color-adjust:exact;print-color-adjust:exact}.kpi-card{break-inside:avoid;box-shadow:none;border:1px solid #ddd}.kpi-row{grid-template-columns:repeat(5,1fr)}.card{box-shadow:none;break-inside:avoid}@page{margin:1.5cm}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-xl)}.sidebar-collapse-btn,.mobile-menu-btn{display:flex}#main{margin-left:0}.topbar{padding:0 14px}.topbar-search{display:none}.view-container{padding:14px}.kpi-row{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}.detail-header{flex-direction:column}.detail-header-actions{width:100%;flex-wrap:wrap}.detail-grid{grid-template-columns:1fr 1fr}.toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right,.toolbar-search,.toolbar-search input{width:100%}#dash-grid{grid-template-columns:1fr!important}.modal-card{max-width:100%;border-radius:var(--radius) var(--radius) 0 0}.modal-overlay{align-items:flex-end;padding:0}.table-wrap{border-radius:var(--radius-sm)}}@media(max-width:480px){.kpi-row,.detail-grid{grid-template-columns:1fr}.detail-header-actions .btn{font-size:11px;padding:4px 8px}.filter-bar{gap:4px}.filter-pill{padding:3px 8px;font-size:11px}}
