*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--green:#39d353;--green-dk:#22a83a;--green-xdk:#166128;--black:#0f0f0f;--charcoal:#1a1a1a;--gray-dk:#2a2a2a;--gray:#3a3a3a;--gray-mid:#5c5c5c;--gray-lt:#9a9a9a;--gray-pale:#d4d4d4;--white:#fff;--off-white:#f7f7f7;--amber:#f5a623;--red:#e53935;--blue:#1976d2;--font-head:"Barlow Condensed",sans-serif;--font-body:"Barlow",sans-serif;--radius:6px;--radius-lg:10px;--shadow:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--bottom-nav-height:64px}body{-webkit-font-smoothing:antialiased;background:#f7f7f7;background:var(--off-white);color:#0f0f0f;color:var(--black);font-family:Barlow,sans-serif;font-family:var(--font-body);font-size:14px}.app-shell,body{min-height:100vh}.app-shell{display:flex;flex-direction:column}.topbar{background:#0f0f0f;background:var(--black);border-bottom:3px solid #39d353;border-bottom:3px solid var(--green);height:60px;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:100}.logo,.topbar{align-items:center;display:flex}.logo{gap:10px;text-decoration:none}.logo-mark{align-items:center;background:#39d353;background:var(--green);border-radius:4px;display:flex;flex-shrink:0;height:34px;justify-content:center;width:34px}.logo-mark svg{height:20px;width:20px}.logo-text{color:#fff;color:var(--white);font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:18px;font-weight:700;letter-spacing:.5px}.logo-sub{color:#9a9a9a;color:var(--gray-lt);display:block;font-size:10px;letter-spacing:1.5px;margin-top:1px;text-transform:uppercase}.topbar-right{gap:12px}.topbar-right,.user-chip{align-items:center;display:flex}.user-chip{background:#3a3a3a;background:var(--gray);border-radius:20px;gap:8px;padding:4px 12px 4px 4px}.user-avatar{align-items:center;background:#39d353;background:var(--green);border-radius:50%;color:#0f0f0f;color:var(--black);display:flex;font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:12px;font-weight:700;height:26px;justify-content:center;width:26px}.user-name{color:#fff;color:var(--white);font-size:12px;font-weight:500}.user-role{color:#39d353;color:var(--green);font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.hamburger{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;cursor:pointer;display:none;flex-shrink:0;height:40px;justify-content:center;margin-right:8px;width:40px}.sidenav{background:#fff;background:var(--white);border-right:1px solid #e8e8e8;display:flex;flex-direction:column;flex-shrink:0;padding:1rem 0;width:220px}.main-layout{display:flex;flex:1 1}.main-content{flex:1 1;overflow-x:hidden;padding:1.5rem}.sidebar-overlay{display:none}.nav-section-label{color:#9a9a9a;color:var(--gray-lt);font-size:10px;font-weight:600;letter-spacing:1.5px;margin-top:.5rem;padding:.5rem 1.25rem .25rem;text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-left:3px solid #0000;color:#5c5c5c;color:var(--gray-mid);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px;padding:.6rem 1.25rem;text-align:left;text-decoration:none;transition:all .15s;width:100%}.nav-item:hover{background:#f7f7f7;background:var(--off-white);color:#0f0f0f;color:var(--black)}.nav-item.active{background:#eaf7ed;border-left-color:#39d353;border-left-color:var(--green);color:#22a83a;color:var(--green-dk)}.nav-item svg{flex-shrink:0;height:16px;width:16px}.nav-badge{background:#f5a623;background:var(--amber);border-radius:10px;color:#0f0f0f;color:var(--black);font-size:10px;font-weight:700;margin-left:auto;min-width:18px;padding:1px 6px;text-align:center}.bottom-nav{background:#0f0f0f;background:var(--black);border-top:2px solid #39d353;border-top:2px solid var(--green);bottom:0;display:none;height:64px;height:var(--bottom-nav-height);left:0;padding:0 0 env(safe-area-inset-bottom);position:fixed;right:0;z-index:150}.bottom-nav-inner{display:flex;height:100%}.bottom-nav-item{-webkit-tap-highlight-color:transparent;align-items:center;background:none;border:none;color:#9a9a9a;color:var(--gray-lt);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:10px;font-weight:600;gap:3px;justify-content:center;letter-spacing:.5px;padding:6px 4px;position:relative;text-transform:uppercase;transition:color .15s}.bottom-nav-item svg{flex-shrink:0;height:22px;width:22px}.bottom-nav-item.active{color:#39d353;color:var(--green)}.bottom-nav-item.active:before{background:#39d353;background:var(--green);border-radius:0 0 2px 2px;content:"";height:2px;left:20%;position:absolute;right:20%;top:0}.bottom-nav-badge{background:#f5a623;background:var(--amber);border-radius:8px;color:#0f0f0f;color:var(--black);font-size:9px;font-weight:700;line-height:1.4;min-width:14px;padding:1px 4px;position:absolute;right:calc(50% - 18px);text-align:center;top:6px}.card{background:#fff;background:var(--white);border:1px solid #e8e8e8;border-radius:10px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow)}.card-header{align-items:center;border-bottom:1px solid #e8e8e8;display:flex;justify-content:space-between;padding:1rem 1.25rem}.card-title{font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:16px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}.card-body{padding:1.25rem}.page-header{margin-bottom:1.25rem}.page-title{color:#0f0f0f;color:var(--black);font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:26px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.page-sub{color:#5c5c5c;color:var(--gray-mid);font-size:13px;margin-top:2px}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:1.25rem}.stat-card{background:#fff;background:var(--white);border:1px solid #e8e8e8;border-radius:10px;border-radius:var(--radius-lg);border-top:3px solid #d4d4d4;border-top:3px solid var(--gray-pale);padding:1rem 1.25rem}.stat-card.green{border-top-color:#39d353;border-top-color:var(--green)}.stat-card.amber{border-top-color:#f5a623;border-top-color:var(--amber)}.stat-card.red{border-top-color:#e53935;border-top-color:var(--red)}.stat-card.blue{border-top-color:#1976d2;border-top-color:var(--blue)}.stat-label{color:#9a9a9a;color:var(--gray-lt);font-size:11px;font-weight:600;letter-spacing:1px;margin-bottom:6px;text-transform:uppercase}.stat-value{color:#0f0f0f;color:var(--black);font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:28px;font-weight:700;line-height:1}.stat-value.green{color:#22a83a;color:var(--green-dk)}.stat-value.amber{color:#b36f00}.stat-value.red{color:#e53935;color:var(--red)}.btn{align-items:center;border:none;border-radius:6px;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:13px;font-weight:700;gap:6px;letter-spacing:.5px;padding:8px 18px;text-transform:uppercase;transition:all .15s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#39d353;background:var(--green);color:#0f0f0f;color:var(--black)}.btn-primary:hover:not(:disabled){background:#22a83a;background:var(--green-dk);color:#fff;color:var(--white)}.btn-secondary{background:#fff;background:var(--white);border:1px solid #d0d0d0;color:#0f0f0f;color:var(--black)}.btn-secondary:hover:not(:disabled){background:#f7f7f7;background:var(--off-white)}.btn-danger{background:#fee8e8;border:1px solid #facaca;color:#e53935;color:var(--red)}.btn-danger:hover:not(:disabled){background:#facaca}.btn-warning{background:#fff3e0;border:1px solid #ffd9a0;color:#b36f00}.btn-warning:hover:not(:disabled){background:#ffd9a0}.btn-ghost{background:#0000;border:1px solid #e0e0e0;color:#5c5c5c;color:var(--gray-mid)}.btn-ghost:hover:not(:disabled){background:#f7f7f7;background:var(--off-white);color:#0f0f0f;color:var(--black)}.btn-sm{font-size:11px;padding:5px 12px}.btn-icon{border-radius:6px;border-radius:var(--radius);padding:7px}.table-wrap{border:1px solid #e8e8e8;border-radius:10px;border-radius:var(--radius-lg);max-height:calc(100vh - 280px);overflow-x:auto;overflow-y:auto}table{background:#fff;background:var(--white);border-collapse:collapse;font-size:13px;width:100%}thead th{background:#f7f7f7;background:var(--off-white);border-bottom:2px solid #39d353;border-bottom:2px solid var(--green);color:#5c5c5c;color:var(--gray-mid);font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1px;padding:10px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}tbody tr{border-bottom:1px solid #f0f0f0}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#fafff8}tbody td{color:#0f0f0f;color:var(--black);padding:10px 12px}tbody tr.flagged{background:#fff8e8}.tool-card-list{gap:10px}.tool-card,.tool-card-list{display:flex;flex-direction:column}.tool-card{-webkit-tap-highlight-color:transparent;background:#fff;background:var(--white);border:1px solid #e8e8e8;border-radius:10px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow);cursor:pointer;gap:8px;padding:14px;transition:box-shadow .15s}.tool-card:active{box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md)}.tool-card-top{align-items:flex-start;display:flex;gap:8px;justify-content:space-between}.tool-card-name{color:#0f0f0f;color:var(--black);font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:15px;font-weight:700;line-height:1.2}.tool-card-model{color:#5c5c5c;color:var(--gray-mid);font-size:12px;margin-top:2px}.tool-card-meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.tool-card-chip{background:#f7f7f7;background:var(--off-white);border:1px solid #e8e8e8;color:#5c5c5c;color:var(--gray-mid);font-weight:600;letter-spacing:.3px;padding:2px 7px}.badge,.tool-card-chip{border-radius:4px;font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:11px;text-transform:uppercase}.badge{align-items:center;display:inline-flex;font-weight:700;letter-spacing:.5px;padding:3px 9px}.badge-active{background:#e8f5e9;color:#2e7d32}.badge-tagged{background:#fff3e0;color:#e65100}.badge-repair{background:#ffebee;color:#c62828}.badge-transit{background:#e3f2fd;color:#1565c0}.badge-retired{background:#f5f5f5;color:#757575}.badge-spare{background:#ede7f6;color:#4527a0}.badge-pending{background:#fff3e0;color:#e65100}.badge-intransit{background:#e8f4fd;border:1px solid #b3d7f0;color:#1a6fa8}.badge-approved{background:#e8f5e9;color:#2e7d32}.badge-denied{background:#ffebee;color:#c62828}.badge-fulfilled{background:#e8f5e9;color:#1b5e20}.badge-atshop{background:#e3f2fd;color:#0d47a1}.badge-completed{background:#e8f5e9;color:#1b5e20}.form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.form-grid.cols-1{grid-template-columns:1fr}.form-group{display:flex;flex-direction:column;gap:5px}.form-group.full{grid-column:1/-1}.form-label{color:#5c5c5c;color:var(--gray-mid);font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase}.form-input,.form-select,.form-textarea{background:#fff;background:var(--white);border:1px solid #d0d0d0;border-radius:6px;border-radius:var(--radius);color:#0f0f0f;color:var(--black);font-family:Barlow,sans-serif;font-family:var(--font-body);font-size:13px;padding:8px 12px;transition:border-color .15s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#39d353;border-color:var(--green);box-shadow:0 0 0 3px #39d35326;outline:none}.form-textarea{min-height:80px;resize:vertical}.form-hint{color:#9a9a9a;color:var(--gray-lt);font-size:11px}.modal-overlay{align-items:flex-start;background:#00000080;display:flex;inset:0;justify-content:center;overflow-y:auto;padding:2rem 1rem;position:fixed;z-index:1000}.modal{background:#fff;background:var(--white);border-radius:10px;border-radius:var(--radius-lg);border-top:3px solid #39d353;border-top:3px solid var(--green);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);margin:auto;max-width:560px;width:100%}.modal-lg{max-width:720px}.modal-header{align-items:center;border-bottom:1px solid #e8e8e8;display:flex;justify-content:space-between;padding:1rem 1.25rem}.modal-title{color:#22a83a;color:var(--green-dk);font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:17px;font-weight:700;text-transform:uppercase}.modal-body{padding:1.25rem}.modal-footer{border-top:1px solid #e8e8e8;display:flex;gap:8px;justify-content:flex-end;padding:1rem 1.25rem}.close-btn{background:none;border:none;color:#9a9a9a;color:var(--gray-lt);cursor:pointer;font-size:22px;line-height:1;padding:0}.close-btn:hover{color:#0f0f0f;color:var(--black)}.toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1rem}.search-input{background:#fff url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239A9A9A' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 10px;background:var(--white) url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239A9A9A' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 10px center;border:1px solid #d0d0d0;border-radius:6px;border-radius:var(--radius);color:#0f0f0f;color:var(--black);flex:1 1;font-family:Barlow,sans-serif;font-family:var(--font-body);font-size:13px;min-width:200px;padding:8px 12px 8px 36px}.search-input:focus{border-color:#39d353;border-color:var(--green);outline:none}.filter-select{background:#fff;background:var(--white);border:1px solid #d0d0d0;border-radius:6px;border-radius:var(--radius);color:#0f0f0f;color:var(--black);cursor:pointer;font-family:Barlow,sans-serif;font-family:var(--font-body);font-size:13px;padding:8px 12px}.filter-select:focus{border-color:#39d353;border-color:var(--green);outline:none}.alert{align-items:center;border-radius:6px;border-radius:var(--radius);display:flex;font-size:13px;gap:10px;margin-bottom:1rem;padding:10px 14px}.alert-warning{background:#fff3e0;border-left:3px solid #f5a623;border-left:3px solid var(--amber);color:#b36f00}.alert-danger{background:#ffebee;border-left:3px solid #e53935;border-left:3px solid var(--red);color:#c62828}.alert-success{background:#e8f5e9;border-left:3px solid #39d353;border-left:3px solid var(--green);color:#2e7d32}.alert-info{background:#e3f2fd;border-left:3px solid #1976d2;border-left:3px solid var(--blue);color:#1565c0}.pagination{align-items:center;border-top:1px solid #f0f0f0;color:#5c5c5c;color:var(--gray-mid);display:flex;font-size:12px;gap:8px;padding:.75rem 1rem}.pagination-info{flex:1 1}.empty-state{color:#9a9a9a;color:var(--gray-lt);padding:3rem 1rem;text-align:center}.empty-state-icon{font-size:40px;margin-bottom:.75rem;opacity:.4}.empty-state-title{color:#d4d4d4;color:var(--gray-pale);font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:16px;font-weight:700;margin-bottom:6px;text-transform:uppercase}.empty-state-sub{font-size:13px}.login-wrap{align-items:center;background:#0f0f0f;background:var(--black);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:#1a1a1a;background:var(--charcoal);border:1px solid #3a3a3a;border-top:4px solid #39d353;border:1px solid var(--gray);border-radius:10px;border-radius:var(--radius-lg);border-top:4px solid var(--green);max-width:400px;padding:2rem;width:100%}.login-logo{margin-bottom:2rem;text-align:center}.login-logo-mark{align-items:center;background:#39d353;background:var(--green);border-radius:8px;display:inline-flex;height:56px;justify-content:center;margin-bottom:12px;width:56px}.login-logo-mark svg{height:34px;width:34px}.login-title{color:#fff;color:var(--white);font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:28px;font-weight:700}.login-sub{color:#9a9a9a;color:var(--gray-lt);font-size:12px;letter-spacing:1px;text-transform:uppercase}.login-form{display:flex;flex-direction:column;gap:14px}.login-input{background:#2a2a2a;background:var(--gray-dk);border:1px solid #3a3a3a;border:1px solid var(--gray);border-radius:6px;border-radius:var(--radius);color:#fff;color:var(--white);font-family:Barlow,sans-serif;font-family:var(--font-body);font-size:14px;padding:10px 14px;width:100%}.login-input:focus{border-color:#39d353;border-color:var(--green);outline:none}.login-input::placeholder{color:#5c5c5c;color:var(--gray-mid)}.login-btn{background:#39d353;background:var(--green);border:none;border-radius:6px;border-radius:var(--radius);color:#0f0f0f;color:var(--black);cursor:pointer;font-family:Barlow Condensed,sans-serif;font-family:var(--font-head);font-size:15px;font-weight:700;letter-spacing:1px;margin-top:6px;padding:12px;text-transform:uppercase;transition:background .15s}.login-btn:hover{background:#22a83a;background:var(--green-dk);color:#fff;color:var(--white)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.login-error{background:#3a1a1a;border:1px solid #7a3a3a;border-radius:6px;border-radius:var(--radius);color:#ff8a80;font-size:13px;padding:10px 14px}.login-label{display:block;font-size:11px;font-weight:600;letter-spacing:1px;margin-bottom:4px;text-transform:uppercase}.login-label,.text-muted{color:#9a9a9a;color:var(--gray-lt)}.text-sm{font-size:12px}.text-xs{font-size:11px}.font-head{font-family:Barlow Condensed,sans-serif;font-family:var(--font-head)}.fw-700{font-weight:700}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.flex{display:flex}.flex-center{align-items:center;display:flex}.gap-1{gap:.5rem}.gap-2{gap:1rem}.ml-auto{margin-left:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.divider{background:#e8e8e8;height:1px;margin:1rem 0}.section-label{font-size:11px;font-weight:600;letter-spacing:1.5px;margin-bottom:8px;text-transform:uppercase}.loading,.section-label{color:#9a9a9a;color:var(--gray-lt)}.loading{align-items:center;display:flex;font-size:13px;gap:8px;justify-content:center;padding:3rem}.spinner{animation:spin .7s linear infinite;border:2px solid #e0e0e0;border-radius:50%;border-top:2px solid var(--green);height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.topbar{gap:0;height:54px;padding:0 .75rem}.logo-sub{display:none!important}.logo-text{font-size:15px}.hamburger{display:flex}.user-name,.user-role{display:none}.user-chip{background:#0000;padding:4px}.user-avatar{font-size:11px;height:30px;width:30px}.topbar-pending,.topbar-signout{display:none}.sidenav{box-shadow:4px 0 20px #00000026;display:flex;flex-direction:column;height:calc(100dvh - 54px);left:-240px;overflow:hidden;padding:0;position:fixed;top:54px;transition:left .25s ease;width:240px;z-index:200}.sidenav.open{left:0}.sidebar-overlay{background:#00000073;display:none;inset:54px 0 0 0;position:fixed;z-index:199}.sidebar-overlay.open{display:block}.main-layout{flex-direction:column}.main-content{padding:.875rem .875rem calc(64px + env(safe-area-inset-bottom) + .875rem);padding-bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom) + .875rem)}.bottom-nav{display:block}.page-title{font-size:22px!important}.page-header{margin-bottom:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)!important}.toolbar{align-items:stretch;flex-direction:column}.toolbar>*{min-width:0!important;min-width:auto!important}.filter-select,.search-input,.toolbar>*{width:100%!important}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}table{min-width:600px}.form-grid{grid-template-columns:1fr}.modal-overlay{align-items:flex-end!important;padding:0!important}.modal{border-radius:10px 10px 0 0!important;border-radius:var(--radius-lg) var(--radius-lg) 0 0!important;border-top:3px solid #39d353!important;border-top:3px solid var(--green)!important;margin:0!important;max-height:92vh;max-width:100vw!important;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom);width:100vw!important}.notif-dropdown{border-radius:0!important;left:0!important;margin-top:0!important;max-height:calc(100vh - 54px)!important;position:fixed!important;right:0!important;top:54px!important;width:100vw!important}}
/*# sourceMappingURL=main.85e0ffcb.css.map*/