@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-bg: #ffffff;--sidebar-hover: #f1f5f9;--sidebar-active: #6366f1;--sidebar-text: #64748b;--sidebar-text-active: #ffffff;--sidebar-width: 260px;--topbar-h: 64px;--bg: #f8fafc;--surface: #ffffff;--border: #e2e8f0;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--blue: #6366f1;--blue-light: #eef2ff;--green: #10b981;--green-light: #ecfdf5;--amber: #f59e0b;--amber-light: #fffbeb;--red: #ef4444;--red-light: #fef2f2;--gray: #64748b;--gray-light: #f8fafc;--radius: 12px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .05);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .08);--transition: .2s cubic-bezier(.4, 0, .2, 1)}body{font-family:Inter,sans-serif;background:var(--bg);color:var(--text-primary);line-height:1.5}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto;border-right:1px solid var(--border)}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:24px 20px;border-bottom:1px solid var(--border)}.sidebar-logo-icon{width:36px;height:36px;border-radius:8px;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.sidebar-logo-text{color:var(--text-primary);font-weight:700;font-size:14px;line-height:1.3}.sidebar-logo-sub{color:var(--text-muted);font-size:11px;font-weight:400}.sidebar-section-label{padding:24px 20px 8px;font-size:10px;font-weight:600;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase}.sidebar-item{display:flex;align-items:center;gap:12px;padding:12px 20px;color:var(--sidebar-text);font-size:14px;font-weight:500;margin:2px 12px;border-radius:var(--radius);transition:all var(--transition);cursor:pointer}.sidebar-item:hover{background:var(--sidebar-hover);color:var(--blue)}.sidebar-item.active{background:var(--blue);color:#fff;box-shadow:0 4px 12px #6366f14d}.sidebar-item svg{flex-shrink:0}.sidebar-item .badge-count{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-weight:700;border-radius:99px;padding:2px 6px}.main{margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;flex:1}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:50}.topbar-title{font-size:14px;font-weight:600;color:var(--text-primary);flex:1}.topbar-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);font-size:13px;font-weight:600;border:none;background:var(--blue);color:#fff;transition:opacity var(--transition)}.topbar-btn:hover{opacity:.88}.topbar-btn.secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.topbar-btn.secondary:hover{background:var(--bg)}.page-content{padding:24px;flex:1;max-width:1400px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;cursor:pointer;transition:box-shadow var(--transition),border-color var(--transition)}.kpi-card:hover{box-shadow:var(--shadow-md);border-color:var(--blue)}.kpi-card.active{border-color:var(--blue);background:var(--blue-light)}.kpi-info{display:flex;flex-direction:column;gap:2px}.kpi-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;display:block}.kpi-value{font-size:32px;font-weight:800;color:var(--text-primary);display:block;line-height:1;margin-top:4px}.kpi-value.blue{color:var(--blue)}.kpi-value.green{color:var(--green)}.kpi-value.amber{color:var(--amber)}.kpi-value.red{color:var(--red)}.kpi-sub{font-size:11px;color:var(--text-muted)}.filter-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px}.filter-search{display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:var(--radius);padding:7px 12px;background:var(--bg);flex:1;min-width:200px}.filter-search input{border:none;background:transparent;outline:none;font-size:13px;width:100%;color:var(--text-primary)}.filter-select{border:1px solid var(--border);border-radius:var(--radius);padding:7px 28px 7px 10px;background:var(--bg);font-size:13px;color:var(--text-primary);outline:none;min-width:140px;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='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.quick-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.chip{padding:4px 12px;border-radius:99px;font-size:12px;font-weight:500;border:1.5px solid transparent;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:5px}.chip-amber{background:var(--amber-light);color:var(--amber);border-color:#fcd34d}.chip-red{background:var(--red-light);color:var(--red);border-color:#fca5a5}.chip-amber.active,.chip-red.active{opacity:.7}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.asset-table{width:100%;border-collapse:collapse}.asset-table thead th{background:var(--gray-light);text-align:left;padding:10px 14px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap}.asset-table tbody tr{border-bottom:1px solid var(--border);transition:background var(--transition)}.asset-table tbody tr:last-child{border-bottom:none}.asset-table tbody tr:hover{background:#f8fafc}.asset-table td{padding:12px 14px;font-size:13px;vertical-align:middle}.asset-code-link{color:var(--blue);font-weight:600;font-size:13px;transition:opacity var(--transition)}.asset-code-link:hover{opacity:.75}.asset-name{font-size:12px;color:var(--text-secondary);margin-top:2px}.asset-serial{font-size:11px;color:var(--text-muted)}.location-text{font-size:12px;color:var(--text-secondary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:600;white-space:nowrap}.badge-green{background:var(--green-light);color:var(--green)}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-amber{background:var(--amber-light);color:var(--amber)}.badge-red{background:var(--red-light);color:var(--red)}.badge-gray{background:var(--gray-light);color:var(--gray)}.table-footer{padding:10px 16px;font-size:12px;color:var(--text-muted);border-top:1px solid var(--border);background:var(--gray-light)}.detail-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;box-shadow:var(--shadow-sm)}.detail-code{font-size:12px;font-weight:700;color:var(--blue);letter-spacing:.05em}.detail-name{font-size:20px;font-weight:700;margin:4px 0 6px}.detail-meta{display:flex;flex-wrap:wrap;gap:8px 16px;font-size:12px;color:var(--text-secondary)}.detail-actions{display:flex;gap:8px}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px}@media(max-width:900px){.detail-grid{grid-template-columns:1fr}}.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.info-card-header{padding:14px 18px;font-size:12px;font-weight:700;letter-spacing:.04em;border-bottom:1px solid var(--border);background:var(--gray-light);color:var(--text-secondary);text-transform:uppercase}.info-row{display:flex;padding:10px 18px;border-bottom:1px solid #f1f5f9;font-size:13px}.info-row:last-child{border-bottom:none}.info-label{width:160px;flex-shrink:0;color:var(--text-muted);font-size:12px}.info-value{color:var(--text-primary);font-weight:500}.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-muted)}.empty{display:flex;flex-direction:column;align-items:center;padding:60px;color:var(--text-muted);gap:8px}.error-box{padding:12px 16px;background:var(--red-light);color:var(--red);border-radius:var(--radius);font-size:13px}.login-container{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);top:-200px;right:-100px}.login-box{width:420px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:48px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;z-index:10}.login-header{text-align:center;margin-bottom:32px}.login-header h2{color:var(--text-primary);font-weight:800;font-size:26px;letter-spacing:-.02em}.login-form .form-group{margin-bottom:24px}.login-form label{display:block;color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:8px}.login-form input{width:100%;padding:12px 16px;background:#f8fafc;border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:15px;transition:all var(--transition)}.login-form input:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px #6366f11a}.login-btn{width:100%;padding:14px;background:var(--blue);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;margin-top:12px;transition:all var(--transition)}.login-btn:hover{background:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{background:var(--red-light);border:1px solid rgba(239,68,68,.2);color:var(--red);padding:12px;border-radius:10px;font-size:14px;margin-bottom:24px;text-align:center}.modal-overlay{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:90%;max-width:760px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;color:var(--text-primary);overflow:hidden}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:#f8fafc}.modal-header h3{margin:0;font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.close-btn{background:#fff;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;padding:6px;border-radius:10px;display:flex;transition:all var(--transition)}.close-btn:hover{background:#f1f5f9;color:var(--red)}.modal-form{padding:24px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.modal-form .form-group{margin-bottom:16px}.modal-form label{display:block;color:var(--text-secondary);font-size:13px;font-weight:500;margin-bottom:8px}.modal-form input,.modal-form select{width:100%;padding:11px 14px;background:#f8fafc;border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:14px;transition:all var(--transition)}.modal-form input:focus,.modal-form select:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px #6366f11a}.modal-footer{margin-top:8px;padding-top:20px;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:flex-end;gap:12px}.modal-error{margin:8px 0;padding:10px 14px;background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;color:#b91c1c;font-size:13px;white-space:pre-wrap;line-height:1.5}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:var(--radius);font-size:14px;font-weight:600;border:1.5px solid transparent;transition:all var(--transition);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-sm{padding:6px 12px;font-size:13px;border-radius:8px;gap:6px}.btn-lg{padding:14px 24px;font-size:16px}.btn-primary{background:var(--blue);color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary:hover{background:#4f46e5;box-shadow:0 6px 16px #6366f159;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0) scale(.97)}.btn-secondary{background:var(--blue-light);color:var(--blue)}.btn-secondary:hover{background:#e0e7ff;color:#4338ca}.btn-white{background:#fff;color:var(--text-primary);border-color:var(--border)}.btn-white:hover{border-color:var(--blue);color:var(--blue);background:var(--bg)}.btn-outline{background:transparent;border-color:var(--border);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}.btn-danger{background:var(--red-light);color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff;box-shadow:0 4px 12px #ef444440}.btn svg{flex-shrink:0}.admin-dashboard{max-width:1200px;margin:0 auto}.subtitle{color:var(--text-muted);font-size:14px;margin-top:4px}.kpi-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.w-full{width:100%}.kpi-icon.blue{background:var(--blue-light);color:var(--blue)}.kpi-icon.green{background:var(--green-light);color:var(--green)}.kpi-icon.orange{background:var(--amber-light);color:var(--amber)}.kpi-icon.red{background:var(--red-light);color:var(--red)}.dashboard-charts{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;margin-bottom:24px}@media(max-width:900px){.dashboard-charts{grid-template-columns:1fr}}.chart-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}.chart-container h3{font-size:15px;font-weight:700;margin-bottom:20px;color:var(--text-primary)}.dashboard-sections{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.dashboard-section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;gap:16px;align-items:flex-start;transition:all var(--transition)}.dashboard-section-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md)}.section-icon{width:40px;height:40px;border-radius:10px;background:var(--gray-light);color:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.section-content h4{font-size:15px;font-weight:700;margin-bottom:4px}.section-content p{font-size:13px;color:var(--text-muted)}.mt-10{margin-top:10px}.fade-in{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
