@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;margin:0;padding:0}body{font-family:DM Sans,sans-serif;background:#f8fafc}#root{display:flex;flex-direction:column;min-height:100vh}.app{display:flex;min-height:100vh;background:#f8fafc}.app-body{flex:1;display:flex;flex-direction:column;overflow:hidden}.app-main{flex:1;overflow-y:auto}.sidebar{min-height:100vh;background:#0f172a;color:#fff;display:flex;flex-direction:column;transition:width .25s cubic-bezier(.4,0,.2,1);flex-shrink:0;position:sticky;top:0;height:100vh;overflow:hidden}.sidebar--open{width:240px}.sidebar--closed{width:72px}.sidebar-header{height:64px;display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-header--open{justify-content:space-between;padding:0 1rem 0 1.5rem}.sidebar-header--closed{justify-content:center;padding:0}.sidebar-logo{font-family:Space Mono,monospace;font-weight:700;font-size:.9rem;color:#3b82f6;letter-spacing:.05em}.sidebar-toggle{background:#ffffff0f;border:none;border-radius:8px;width:36px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar-nav{flex:1;padding:1rem .5rem;overflow-y:auto}.nav-item-wrap{display:block}.nav-btn{width:100%;display:flex;align-items:center;gap:.75rem;background:transparent;border:none;border-radius:8px;color:#94a3b8;cursor:pointer;margin-bottom:2px;transition:all .15s;font-size:.875rem;font-weight:400;font-family:DM Sans,sans-serif}.nav-btn--open{padding:.65rem 1rem;justify-content:flex-start}.nav-btn--closed{padding:.65rem;justify-content:center}.nav-btn--active{background:#3b82f62e;color:#3b82f6;font-weight:600}.nav-btn:hover:not(.nav-btn--active){background:#ffffff0d;color:#e2e8f0}.nav-btn--active:hover{background:#3b82f62e;color:#3b82f6}.nav-btn-icon{flex-shrink:0}.nav-btn-label{white-space:nowrap;flex:1;text-align:left}.nav-chevron{flex-shrink:0;transition:transform .2s}.nav-chevron--open{transform:rotate(180deg)}.nav-chevron--closed{transform:rotate(0)}.nav-submenu{margin-left:1rem;margin-bottom:4px;border-left:1px solid rgba(255,255,255,.1);padding-left:.75rem}.subnav-btn{width:100%;display:flex;align-items:center;padding:.5rem .75rem;gap:.5rem;background:transparent;border:none;border-radius:6px;color:#64748b;cursor:pointer;margin-bottom:2px;font-size:.825rem;font-weight:400;font-family:DM Sans,sans-serif;transition:all .15s}.subnav-btn--active{background:#3b82f624;color:#3b82f6;font-weight:600}.subnav-btn:hover:not(.subnav-btn--active){background:#ffffff0a;color:#e2e8f0}.subnav-btn--active:hover{background:#3b82f624;color:#3b82f6}.subnav-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.subnav-dot--active{background:#3b82f6}.subnav-dot--inactive{background:#475569}.subnav-label{white-space:nowrap}.sidebar-footer{padding:.75rem .5rem;border-top:1px solid rgba(255,255,255,.08)}.logout-btn{width:100%;background:#ef44441f;border:none;border-radius:8px;color:#ef4444;cursor:pointer;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.5rem;transition:background .15s}.logout-btn--open{padding:.6rem 1rem;justify-content:flex-start}.logout-btn--closed{padding:.6rem;justify-content:center}.logout-btn:hover{background:#ef444438}.topbar{height:64px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;position:sticky;top:0;z-index:10;font-family:DM Sans,sans-serif}.topbar-title-wrap{display:flex;align-items:center;gap:.5rem}.topbar-title{margin:0;font-size:1.1rem;font-weight:600;color:#0f172a}.topbar-subtitle{font-size:1.1rem;font-weight:600;color:#3b82f6}.topbar-actions{display:flex;align-items:center;gap:1rem}.search-wrap{position:relative}.search-input{background:#f1f5f9;border:none;border-radius:9999px;padding:.45rem 1rem .45rem 2.25rem;font-size:.83rem;width:200px;outline:none;color:#0f172a}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#94a3b8}.notif-btn{position:relative;background:transparent;border:none;cursor:pointer;padding:.4rem;border-radius:9999px;color:#64748b}.notif-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:#ef4444;border:2px solid #fff}.user-info{display:flex;align-items:center;gap:.75rem;padding-left:.75rem;border-left:1px solid #e2e8f0}.user-name-wrap{text-align:right}.user-name{margin:0;font-size:.83rem;font-weight:600;color:#0f172a}.user-role{margin:0;font-size:.72rem;color:#94a3b8}.topbar-user{font-size:.9rem;color:#0f172a;font-weight:500;font-family:Space Mono,monospace}.page{padding:2rem;font-family:DM Sans,sans-serif}.page-header{margin-bottom:2rem}.page-header--flex{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.page-header--flex-center{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-title{font-family:Space Mono,monospace;font-size:1.6rem;font-weight:700;color:#0f172a;margin:0}.page-title--sm{font-family:Space Mono,monospace;font-size:1.4rem;font-weight:700;color:#0f172a;margin:0}.page-desc{color:#64748b;margin-top:.25rem;font-size:.875rem}.btn-primary{background:#0f172a;color:#fff;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.85rem;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif}.card{background:#fff;border-radius:12px;border:1px solid #e2e8f0}.card--padded{padding:1.5rem}.card--overflow{overflow:hidden}.table-wrap{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden}.table{width:100%;border-collapse:collapse}.table th{padding:.9rem 1.25rem;text-align:left;font-size:.72rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid #e2e8f0;background:#f8fafc}.table td{padding:.9rem 1.25rem}.table tbody tr{transition:background .15s}.table tbody tr:hover{background:#f8fafc}.table-footer-row{background:#f8fafc;border-top:2px solid #e2e8f0}.table-count{padding:.75rem 1.25rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:#e2e8f0}.login-card{width:min(380px,100%);background:#fff;border-radius:16px;border:1px solid #cbd5e1;box-shadow:0 12px 24px #0f172a1f;padding:2rem}.login-card h1{margin-bottom:.5rem;font-family:Space Mono,monospace}.login-card p{margin-bottom:1rem;color:#64748b}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:#334155}.login-form input{border:1px solid #cbd5e1;border-radius:8px;padding:.65rem .85rem;font-size:.9rem;outline:none}.login-form input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.login-error{color:#dc2626;font-size:.84rem;margin-top:-.25rem}.table-empty{padding:2.5rem;text-align:center;color:#94a3b8;font-size:.875rem;font-style:italic}.table-id{font-family:Space Mono,monospace;font-size:.78rem;color:#3b82f6}.table-id--bold{font-family:Space Mono,monospace;font-size:.8rem;color:#3b82f6;font-weight:700}.table-name{font-weight:600;color:#0f172a;font-size:.875rem}.table-muted{color:#64748b;font-size:.875rem}.table-muted-italic{color:#cbd5e1;font-style:italic}.table-mono{font-family:Space Mono,monospace;color:#0f172a}.table-date{color:#64748b;font-size:.85rem}.badge{padding:3px 10px;border-radius:9999px;font-size:.75rem;font-weight:600}.badge--green{color:#22c55e;background:#f0fdf4}.badge--red{color:#ef4444;background:#fef2f2}.badge--yellow{color:#f59e0b;background:#fffbeb}.badge--blue{color:#3b82f6;background:#eff6ff}.badge--gray{color:#94a3b8;background:#f8fafc}.qty-badge{font-family:Space Mono,monospace;font-weight:700;font-size:.9rem;padding:3px 10px;border-radius:8px}.qty-badge--normal{color:#0f172a;background:#f8fafc}.qty-badge--low{color:#ef4444;background:#fef2f2}.qty-badge--total{color:#3b82f6;background:#eff6ff}.delete-btn{background:transparent;border:none;cursor:pointer;color:#94a3b8;padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .15s,background .15s}.delete-btn:hover{color:#ef4444;background:#fef2f2}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.25rem 1.5rem;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000f}.stat-card-top{display:flex;justify-content:space-between;align-items:flex-start}.stat-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8}.stat-change{font-size:.7rem;font-weight:700;padding:2px 7px;border-radius:9999px}.stat-change--up{color:#22c55e;background:#f0fdf4}.stat-change--down{color:#ef4444;background:#fef2f2}.stat-value{margin-top:.75rem;font-size:2.25rem;font-weight:700;font-family:Space Mono,monospace}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.activity-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 0}.activity-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.activity-text{font-size:.83rem;color:#475569}.progress-row{margin-bottom:.85rem}.progress-header{display:flex;justify-content:space-between;margin-bottom:4px}.progress-label{font-size:.8rem;color:#475569}.progress-value{font-size:.8rem;font-weight:600}.progress-track{background:#f1f5f9;border-radius:9999px;height:6px}.progress-fill{height:100%;border-radius:9999px;transition:width .5s ease}.card-title{margin:0 0 1rem;font-size:.9rem;font-weight:600;color:#0f172a}.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.catalog-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden;transition:transform .15s,box-shadow .15s;cursor:pointer}.catalog-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001a}.catalog-card-thumb{height:120px;background:linear-gradient(135deg,#0f172a,#1e40af);display:flex;align-items:center;justify-content:center;font-size:2.5rem}.catalog-card-body{padding:1rem}.catalog-card-cat{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8}.catalog-card-name{margin:.3rem 0 .6rem;font-size:.95rem;font-weight:700;color:#0f172a}.catalog-card-footer{display:flex;justify-content:space-between;align-items:center}.catalog-card-price{font-family:Space Mono,monospace;font-weight:700;color:#3b82f6;font-size:1rem}.catalog-card-btn{background:#0f172a;color:#fff;border:none;border-radius:6px;padding:.35rem .8rem;font-size:.75rem;font-weight:600;cursor:pointer}.location-grid{display:grid;grid-template-columns:1fr 320px;gap:1rem}.map-canvas{background:linear-gradient(135deg,#0f172a,#1e3a5f,#0f172a);border-radius:12px;min-height:420px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.map-grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(59,130,246,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.1) 1px,transparent 1px);background-size:40px 40px}.map-label{color:#fff3;font-size:.85rem;font-family:Space Mono,monospace;z-index:1}.map-pin{position:absolute;cursor:pointer;transform:translate(-50%,-100%)}.map-pin-dot{width:14px;height:14px;border-radius:50%;transition:all .2s}.map-pin-dot--active{border:3px solid #fff;box-shadow:0 0 0 6px #3b82f64d;background:#3b82f6}.map-pin-dot--maintenance{border:3px solid rgba(255,255,255,.4);background:#f59e0b}.map-pin-dot--active-loc{border:3px solid rgba(255,255,255,.4);background:#22c55e}.location-list{display:flex;flex-direction:column;gap:.75rem}.location-card{background:#fff;border-radius:12px;padding:1rem 1.25rem;cursor:pointer;transition:all .15s}.location-card--active{border:1px solid #3b82f6;box-shadow:0 0 0 3px #3b82f626}.location-card--inactive{border:1px solid #e2e8f0}.location-card-header{display:flex;justify-content:space-between;align-items:flex-start}.location-name{margin:0;font-weight:600;color:#0f172a;font-size:.875rem}.location-coords{margin:.4rem 0 0;font-family:Space Mono,monospace;font-size:.72rem;color:#94a3b8}.location-assets{margin:.25rem 0 0;font-size:.8rem;color:#64748b}.report-stats{display:flex;align-items:center;gap:.75rem}.report-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:.6rem 1.1rem;text-align:center}.report-stat-label{margin:0;font-size:.7rem;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.report-stat-value{margin:0;font-family:Space Mono,monospace;font-size:1.4rem;font-weight:700;color:#0f172a}.report-desc{color:#475569;font-size:.875rem;line-height:1.5}.report-tfoot-label{padding:.9rem 1.25rem;font-size:.8rem;font-weight:700;color:#0f172a}.admin-form-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:1.5rem;margin-bottom:1.5rem}.admin-form-title{margin:0 0 1rem;font-size:.9rem;font-weight:600;color:#0f172a}.admin-form-grid{display:grid;grid-template-columns:1fr 1fr auto;gap:.75rem;align-items:flex-end}.form-field-label{display:block;font-size:.75rem;font-weight:600;color:#64748b;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.05em}.form-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.55rem .9rem;font-size:.875rem;color:#0f172a;outline:none;width:100%;font-family:DM Sans,sans-serif}.form-input--error{border-color:#ef4444}.form-error{margin:.25rem 0 0;font-size:.75rem;color:#ef4444}.add-btn{background:#0f172a;color:#fff;border:none;border-radius:8px;padding:.58rem 1.2rem;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;height:38px;font-family:DM Sans,sans-serif}.btn-secondary{background:#f1f5f9;color:#475569;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.85rem;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;transition:background .15s}.btn-secondary:hover{background:#e2e8f0}.popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.popup{background:#fff;border-radius:14px;border:1px solid #e2e8f0;box-shadow:0 20px 60px #0f172a2e;width:100%;max-width:460px;margin:1rem;animation:slideUp .18s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9}.popup-title{margin:0;font-family:Space Mono,monospace;font-size:1rem;font-weight:700;color:#0f172a}.popup-close{background:#f1f5f9;border:none;border-radius:8px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;transition:background .15s,color .15s}.popup-close:hover{background:#fef2f2;color:#ef4444}.popup-body{padding:1.5rem}.popup-form{display:flex;flex-direction:column}.popup-field{margin-bottom:1rem}.popup-actions{display:flex;gap:.75rem;margin-top:.5rem;justify-content:flex-end}.popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;justify-content:center;align-items:center;z-index:10000}.popup-card{background:#fff;padding:2rem;border-radius:12px;width:400px;text-align:center;box-shadow:0 10px 25px #0003}.popup-card select{width:100%;padding:10px;margin:10px 0;border:1px solid #ccc;border-radius:4px}
