:root{--navy: #1a2332;--navy-light: #243447;--navy-lighter: #2d4060;--red: #C0392B;--red-light: #e74c3c;--red-dark: #962d22;--gray: #f5f6fa;--gray-mid: #dfe3ea;--gray-dark: #8892a4;--white: #ffffff;--text: #2c3e50;--text-light: #7f8c9a;--success: #27ae60;--success-bg: #e8f8ef;--warning: #f39c12;--warning-bg: #fef9e7;--danger: #e74c3c;--danger-bg: #fde8e6;--info: #2980b9;--info-bg: #e8f4fc;--sidebar-w: 260px;--topbar-h: 60px;--radius: 10px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 24px rgba(0,0,0,.14);--transition: .18s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px;-webkit-font-smoothing:antialiased}body{font-family:IBM Plex Sans,sans-serif;background:var(--gray);color:var(--text);min-height:100vh}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit}table{border-collapse:collapse;width:100%}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-mid);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-dark)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--navy);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:200;transition:transform var(--transition);overflow:hidden}.sidebar-brand{padding:1.2rem 1.25rem .9rem;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0;text-align:center}.brand-logo-wrap{display:flex;align-items:center;justify-content:center;padding:.4rem .25rem .3rem;background:#fff;border-radius:12px;margin-bottom:.55rem}.brand-logo-img{width:148px;height:auto;display:block;object-fit:contain}.brand-sub-text{font-size:.62rem;color:#4a5568;text-transform:uppercase;letter-spacing:.8px;font-weight:600}.brand-row{display:flex;align-items:center;gap:.75rem}.brand-icon{width:44px;height:44px;background:var(--red);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.brand-icon svg{width:22px;height:22px;fill:#fff}.brand-name{font-family:Bebas Neue,sans-serif;font-size:1.1rem;color:#fff;letter-spacing:1.5px;line-height:1.1}.brand-sub{font-size:.66rem;color:var(--gray-dark);text-transform:uppercase;letter-spacing:.5px;margin-top:1px}.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}.nav-section{padding:.8rem 1.25rem .3rem;font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:#4a5568}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.68rem 1.25rem;color:#9aa3b0;font-size:.86rem;font-weight:500;border-left:3px solid transparent;transition:all var(--transition);cursor:pointer;-webkit-user-select:none;user-select:none}.nav-link:hover{background:var(--navy-light);color:#fff}.nav-link.active{background:var(--navy-light);color:#fff;border-left-color:var(--red)}.nav-link svg{width:17px;height:17px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2}.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:.65rem;font-weight:700;padding:.1rem .45rem;border-radius:10px;min-width:18px;text-align:center}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:.65rem;margin-bottom:.75rem}.user-avatar{width:34px;height:34px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:#fff;flex-shrink:0}.user-info-text .user-name{font-size:.83rem;color:#c8d0da;font-weight:600}.user-info-text .user-role{font-size:.7rem;color:#4a5568}.btn-logout{width:100%;padding:.5rem .75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:7px;color:#9aa3b0;font-size:.8rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all var(--transition)}.btn-logout:hover{background:var(--red);color:#fff;border-color:var(--red)}.btn-logout svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:150;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh}.topbar{background:#fff;border-bottom:1px solid var(--gray-mid);height:var(--topbar-h);padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 0 var(--gray-mid)}.topbar-left{display:flex;align-items:center;gap:1rem}.hamburger{display:none;background:none;border:none;width:36px;height:36px;border-radius:7px;align-items:center;justify-content:center;transition:background var(--transition)}.hamburger:hover{background:var(--gray)}.hamburger svg{width:20px;height:20px;stroke:var(--text);fill:none;stroke-width:2}.page-title{font-size:1rem;font-weight:700;color:var(--text)}.topbar-right{display:flex;align-items:center;gap:1.25rem}.live-badge{display:flex;align-items:center;gap:.35rem;font-size:.72rem;color:var(--success);font-weight:600}.live-dot{width:7px;height:7px;background:var(--success);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.last-updated{font-size:.73rem;color:var(--text-light)}.content{padding:1.5rem;flex:1}.page-header{margin-bottom:1.5rem}.page-header h1{font-family:Bebas Neue,sans-serif;font-size:1.8rem;letter-spacing:1px;color:var(--text);line-height:1}.page-header p{color:var(--text-light);font-size:.83rem;margin-top:.3rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.kpi-card{background:#fff;border-radius:var(--radius);padding:1.2rem 1.25rem 1rem;box-shadow:var(--shadow-sm);border-top:3px solid var(--gray-mid);transition:transform var(--transition),box-shadow var(--transition);position:relative;overflow:hidden}.kpi-card:after{content:"";position:absolute;right:-10px;bottom:-10px;width:80px;height:80px;border-radius:50%;opacity:.04;background:currentColor}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-card.red{border-top-color:var(--red)}.kpi-card.green{border-top-color:var(--success)}.kpi-card.blue{border-top-color:var(--info)}.kpi-card.orange{border-top-color:var(--warning)}.kpi-card.purple{border-top-color:#8e44ad}.kpi-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:.75rem}.kpi-icon svg{width:18px;height:18px}.kpi-card.red .kpi-icon{background:#fde8e6;color:var(--red)}.kpi-card.green .kpi-icon{background:var(--success-bg);color:var(--success)}.kpi-card.blue .kpi-icon{background:var(--info-bg);color:var(--info)}.kpi-card.orange .kpi-icon{background:var(--warning-bg);color:var(--warning)}.kpi-card.purple .kpi-icon{background:#f5eef8;color:#8e44ad}.kpi-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin-bottom:.3rem}.kpi-value{font-family:Bebas Neue,sans-serif;font-size:2.4rem;color:var(--text);line-height:1;margin-bottom:.2rem}.kpi-sub{font-size:.72rem;color:var(--text-light)}.charts-row{display:grid;grid-template-columns:2fr 1fr;gap:1rem;margin-bottom:1.5rem}.chart-card{background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-sm)}.chart-card h3{font-size:.85rem;font-weight:700;color:var(--text);margin-bottom:1rem}.chart-wrap{position:relative;height:210px}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:1.25rem;overflow:hidden}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--gray-mid);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.card-header h3{font-size:.9rem;font-weight:700;color:var(--text)}.card-header-right{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.card-body{padding:1.25rem}.filter-bar{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.filter-input,.filter-select{padding:.42rem .75rem;border:1.5px solid var(--gray-mid);border-radius:7px;font-size:.8rem;outline:none;background:#fff;color:var(--text);transition:border-color var(--transition)}.filter-input:focus,.filter-select:focus{border-color:var(--red)}.filter-input{width:200px}.table-wrap{overflow-x:auto}thead tr{background:var(--gray)}th{padding:.65rem 1rem;text-align:left;font-size:.71rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);white-space:nowrap}td{padding:.72rem 1rem;font-size:.82rem;color:var(--text);border-top:1px solid var(--gray-mid);vertical-align:middle}tbody tr:hover td{background:#fafbfc}.td-mono{font-family:IBM Plex Mono,monospace;font-size:.76rem}.td-muted{color:var(--text-light)}.td-strong{font-weight:600}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.22rem .65rem;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.badge-green{background:var(--success-bg);color:#1e8449}.badge-red{background:var(--danger-bg);color:#c0392b}.badge-yellow{background:var(--warning-bg);color:#b7770d}.badge-blue{background:var(--info-bg);color:#1a6fa8}.badge-gray{background:#f0f0f0;color:#666}.badge-purple{background:#f5eef8;color:#7d3c98}.badge-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.gps-link{color:var(--info);font-size:.78rem;white-space:nowrap;display:inline-flex;align-items:center;gap:.2rem}.gps-link:hover{text-decoration:underline}.pagination{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border-top:1px solid var(--gray-mid);flex-wrap:wrap;gap:.5rem}.pagination-info{font-size:.78rem;color:var(--text-light)}.pagination-controls{display:flex;gap:.3rem}.page-btn{padding:.3rem .7rem;border:1.5px solid var(--gray-mid);border-radius:6px;font-size:.78rem;background:#fff;color:var(--text);transition:all var(--transition);min-width:34px;text-align:center}.page-btn:hover{border-color:var(--red);color:var(--red)}.page-btn.active{background:var(--red);color:#fff;border-color:var(--red)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.loading-cell{text-align:center;padding:2.5rem!important;color:var(--text-light)!important}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--gray-mid);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:6px}@keyframes spin{to{transform:rotate(360deg)}}.page-loader{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;padding:4rem 1rem;color:var(--text-light)}.page-loader .spinner{width:32px;height:32px;border-width:3px}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-light)}.empty-state-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.5}.empty-state-text{font-size:.9rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:7px;font-size:.82rem;font-weight:600;border:none;transition:all var(--transition);cursor:pointer}.btn-primary{background:var(--red);color:#fff}.btn-primary:hover{background:var(--red-dark)}.btn-sm{padding:.32rem .7rem;font-size:.76rem}.btn-outline{background:#fff;color:var(--text);border:1.5px solid var(--gray-mid)}.btn-outline:hover{border-color:var(--red);color:var(--red)}.btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d1824 0%,var(--navy) 60%,#1a0f0b 100%);padding:1rem;position:relative;overflow:hidden}.login-bg-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.01) 0px,rgba(255,255,255,.01) 1px,transparent 1px,transparent 20px);pointer-events:none}.login-box{background:#fff;border-radius:16px;padding:2.5rem 2.25rem 2rem;width:100%;max-width:400px;box-shadow:0 30px 80px #00000080;position:relative;z-index:1}.login-logo{text-align:center;margin-bottom:2rem}.login-logo-icon{width:72px;height:72px;background:var(--red);border-radius:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 8px 24px #c0392b66}.login-logo-icon svg{width:38px;height:38px;fill:#fff}.login-logo h1{font-family:Bebas Neue,sans-serif;font-size:1.7rem;color:var(--text);letter-spacing:2px}.login-logo p{color:var(--text-light);font-size:.8rem;margin-top:3px}.login-tag{display:inline-block;background:#fde8e6;color:var(--red);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding:.2rem .7rem;border-radius:20px;margin-top:.6rem}.login-form h2{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.72rem;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.45rem}.form-group input{width:100%;padding:.72rem .9rem;border:1.5px solid var(--gray-mid);border-radius:8px;font-size:.92rem;color:var(--text);transition:border-color var(--transition);outline:none}.form-group input:focus{border-color:var(--red);box-shadow:0 0 0 3px #c0392b1a}.login-btn{width:100%;padding:.85rem;background:var(--red);color:#fff;border:none;border-radius:9px;font-size:.95rem;font-weight:700;margin-top:.5rem;cursor:pointer;transition:background var(--transition);display:flex;align-items:center;justify-content:center;gap:.5rem}.login-btn:hover{background:var(--red-dark)}.login-btn:disabled{opacity:.65;cursor:not-allowed}.login-error{color:var(--danger);font-size:.8rem;text-align:center;margin-top:.75rem;min-height:1rem}.login-footer{text-align:center;color:var(--text-light);font-size:.72rem;margin-top:1.5rem}.login-demo{background:var(--gray);border-radius:8px;padding:.75rem 1rem;margin-top:1.25rem;font-size:.78rem;color:var(--text-light)}.login-demo strong{color:var(--text)}.detail-panel{background:#fafbfc;border-top:2px solid var(--gray-mid);padding:1rem 1.25rem}.detail-panel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.detail-item label{display:block;font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin-bottom:.2rem}.detail-item span{font-size:.83rem;color:var(--text)}.summary-bar{display:flex;gap:.5rem;flex-wrap:wrap;background:var(--navy);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1.25rem;align-items:center}.summary-bar-item{display:flex;flex-direction:column;align-items:center;flex:1;min-width:100px}.summary-bar-value{font-family:Bebas Neue,sans-serif;font-size:1.8rem;color:#fff;line-height:1}.summary-bar-label{font-size:.67rem;color:var(--gray-dark);text-transform:uppercase;letter-spacing:.5px;margin-top:.2rem}.summary-bar-divider{width:1px;height:40px;background:#ffffff1a;flex-shrink:0}.alert{border-radius:8px;padding:.85rem 1rem;font-size:.82rem;display:flex;gap:.6rem;align-items:flex-start;margin-bottom:1rem}.alert-warning{background:var(--warning-bg);color:#7d5a00;border:1px solid #fad894}.alert-info{background:var(--info-bg);color:#1a5276;border:1px solid #a9cce3}.alert-success{background:var(--success-bg);color:#1e6b3e;border:1px solid #a9dfbf}.fb-mini-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1rem}.fb-stat-card{background:#fff;border-radius:8px;padding:.9rem 1rem;box-shadow:var(--shadow-sm);text-align:center;border-top:3px solid var(--gray-mid)}.fb-stat-card.green{border-top-color:var(--success)}.fb-stat-card.red{border-top-color:var(--danger)}.fb-stat-num{font-family:Bebas Neue,sans-serif;font-size:1.8rem;line-height:1}.fb-stat-label{font-size:.7rem;color:var(--text-light);text-transform:uppercase;font-weight:600;letter-spacing:.4px;margin-top:.2rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:14px;width:100%;max-width:560px;box-shadow:0 24px 60px #0000004d;animation:slide-up .2s ease;max-height:90vh;overflow-y:auto}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:1.25rem 1.5rem 1rem;border-bottom:1px solid var(--gray-mid);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:1rem;font-weight:700}.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--text-light);padding:0 .25rem}.modal-close:hover{color:var(--danger)}.modal-body{padding:1.25rem 1.5rem}.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.modal-field label{font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);display:block;margin-bottom:.2rem}.modal-field p{font-size:.85rem;color:var(--text)}.modal-field.full{grid-column:1 / -1}@media (max-width: 1100px){.charts-row{grid-template-columns:1fr}}@media (max-width: 900px){.fb-mini-stats{grid-template-columns:repeat(2,1fr)}.modal-grid{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-overlay.open{pointer-events:all}.main{margin-left:0}.hamburger{display:flex}.content{padding:1rem}.kpi-grid{grid-template-columns:repeat(2,1fr)}.filter-input{width:140px}.summary-bar{flex-wrap:wrap}.summary-bar-divider{display:none}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr 1fr}.kpi-value{font-size:2rem}.fb-mini-stats{grid-template-columns:1fr 1fr}.login-box{padding:2rem 1.5rem 1.5rem}}
