@import"https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&family=Inter:wght@400;500;600&display=swap";.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--color-bg-dark)}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 50%,rgba(26,60,110,.4) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(249,115,22,.15) 0%,transparent 50%),linear-gradient(135deg,#0f172a,#1e293b,#0f172a);z-index:0}.login-bg__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.05) 1px,transparent 0);background-size:40px 40px}.login-card{position:relative;z-index:1;width:100%;max-width:420px;margin:var(--space-4);background:#fffffff7;border-radius:var(--radius-2xl);padding:var(--space-10) var(--space-8);box-shadow:0 25px 50px #0006,0 0 0 1px #ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-logo{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);justify-content:center}.login-logo__icon{font-size:2.5rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.login-logo__text{display:flex;flex-direction:column}.login-logo__brand{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:700;color:var(--color-primary);line-height:1}.login-logo__sub{font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:500;letter-spacing:.1em;text-transform:uppercase}.login-title{font-size:var(--text-2xl);font-weight:700;color:var(--color-text-primary);text-align:center;margin-bottom:var(--space-2)}.login-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center;margin-bottom:var(--space-8)}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.login-error{background:var(--color-error-bg);color:#b91c1c;border:1px solid #FECACA;border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:500}.login-field{display:flex;flex-direction:column;gap:var(--space-2)}.login-label{font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.login-input{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-bg);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.login-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1a3c6e1a}.login-input:disabled{opacity:.6;cursor:not-allowed}.login-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-4);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;font-family:var(--font-body);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);margin-top:var(--space-2)}.login-btn:hover:not(:disabled){background:var(--color-primary-light);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-btn__spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .75s linear infinite;flex-shrink:0}.login-footer{text-align:center;font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-6)}.map-section{position:relative;width:100%;height:100%}.leaflet-map-container{width:100%;height:100%;background:#1a1a2e}.map-vehicle-count{position:absolute;bottom:var(--space-4);left:var(--space-4);background:#0f172ad9;color:#ffffffe6;padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);font-size:var(--text-sm);font-weight:500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);z-index:10;pointer-events:none}.map-vehicle-count__online{color:var(--color-success);font-weight:600}.vehicle-popup{min-width:220px;font-family:var(--font-body)}.vehicle-popup__header{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.vehicle-popup__name{font-family:var(--font-heading);font-size:var(--text-base);font-weight:700;color:var(--color-text-primary)}.vehicle-popup__status{font-size:var(--text-xs);font-weight:600}.vehicle-popup__status.active{color:#15803d}.vehicle-popup__status.inactive{color:#b91c1c}.vehicle-popup__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);margin-bottom:var(--space-3)}.vehicle-popup__item{display:flex;flex-direction:column;gap:2px}.vehicle-popup__label{font-size:10px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.vehicle-popup__value{font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.vehicle-popup__btn{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.vehicle-popup__btn:hover{background:var(--color-primary-light)}.marker-container.selected{background:var(--color-accent)!important;border-color:#fff!important;border-width:3px!important;box-shadow:0 0 0 4px #f973164d,var(--shadow-lg)!important}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:600;font-family:var(--font-body);white-space:nowrap;letter-spacing:.02em}.badge--default{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.badge--success{background:var(--color-success-bg);color:#15803d}.badge--warning{background:var(--color-warning-bg);color:#92400e}.badge--error{background:var(--color-error-bg);color:#b91c1c}.badge--info{background:var(--color-info-bg);color:#1d4ed8}.badge--primary{background:#1a3c6e1a;color:var(--color-primary)}.badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.badge--success .badge__dot{animation:pulse-dot 2s infinite}.vehicle-list{display:flex;flex-direction:column;height:100%;color:var(--color-text-inverse)}.vehicle-list__header{padding:var(--space-4);border-bottom:1px solid var(--color-border-dark);flex-shrink:0}.vehicle-list__title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.vehicle-list__title{font-size:var(--text-base);font-weight:700;color:#fff}.vehicle-list__count{background:var(--color-primary);color:#fff;font-size:var(--text-xs);font-weight:700;padding:2px var(--space-2);border-radius:var(--radius-pill);min-width:24px;text-align:center}.vehicle-list__stats{display:flex;gap:var(--space-3);margin-bottom:var(--space-2)}.vehicle-stat{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:#fff9}.vehicle-stat__dot{width:6px;height:6px;border-radius:50%;background:var(--color-success);animation:pulse-dot 2s infinite}.vehicle-list__update{font-size:11px;color:#ffffff59}.vehicle-list__search{position:relative;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-dark);flex-shrink:0}.vehicle-list__search-icon{position:absolute;left:calc(var(--space-4) + var(--space-3));top:50%;transform:translateY(-50%);font-size:var(--text-sm);pointer-events:none}.vehicle-list__search-input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) var(--space-8);background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-md);color:#fff;font-size:var(--text-sm);outline:none;transition:border-color var(--transition-fast),background var(--transition-fast)}.vehicle-list__search-input::placeholder{color:#ffffff59}.vehicle-list__search-input:focus{border-color:var(--color-primary-light);background:#ffffff1f}.vehicle-list__search-clear{position:absolute;right:calc(var(--space-4) + var(--space-2));top:50%;transform:translateY(-50%);background:none;border:none;color:#fff6;font-size:var(--text-sm);cursor:pointer;padding:var(--space-1);line-height:1}.vehicle-list__filters{display:flex;gap:var(--space-1);padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--color-border-dark);flex-shrink:0;flex-wrap:wrap}.vehicle-filter-btn{padding:var(--space-1) var(--space-3);background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-pill);color:#fff9;font-size:11px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.vehicle-filter-btn:hover{background:#ffffff1f;color:#fff}.vehicle-filter-btn--active{background:var(--color-primary);border-color:var(--color-primary-light);color:#fff}.vehicle-list__items{flex:1;overflow-y:auto;padding:var(--space-2)}.vehicle-list__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-12) var(--space-4);color:#ffffff4d;text-align:center}.vehicle-list__empty-icon{font-size:2.5rem;opacity:.5}.vehicle-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);border:1px solid transparent;margin-bottom:var(--space-1)}.vehicle-item:hover{background:#ffffff0f}.vehicle-item--selected{background:#1a3c6e80!important;border-color:var(--color-primary-light)}.vehicle-item__icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;transition:background var(--transition-fast)}.vehicle-item__icon.online{background:#22c55e26}.vehicle-item__icon.offline{background:#94a3b81a}.vehicle-item__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.vehicle-item__name-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.vehicle-item__name{font-size:var(--text-sm);font-weight:600;color:#fff}.vehicle-item__status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.vehicle-item__status-dot.online{background:var(--color-success);animation:pulse-dot 2s infinite}.vehicle-item__status-dot.offline{background:var(--color-offline)}.vehicle-item__plate{font-size:11px;color:#ffffff73;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.vehicle-item__meta{display:flex;align-items:center;gap:var(--space-2);margin-top:2px}.vehicle-item__battery{font-size:11px;color:#ffffff73}.vehicle-item__battery.low{color:var(--color-error);font-weight:600}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.spinner{display:inline-block;border-radius:50%;border-style:solid;border-color:transparent;animation:spin .75s linear infinite}.spinner--small{width:16px;height:16px;border-width:2px}.spinner--medium{width:28px;height:28px;border-width:3px}.spinner--large{width:48px;height:48px;border-width:4px}.spinner--primary{border-top-color:var(--color-primary);border-right-color:var(--color-primary-light)}.spinner--accent{border-top-color:var(--color-accent);border-right-color:var(--color-accent-light)}.spinner--white{border-top-color:#fff;border-right-color:#ffffff80}@keyframes spin{to{transform:rotate(360deg)}}.detail-panel{display:flex;flex-direction:column;height:100%;color:var(--color-text-inverse);overflow-y:auto}.detail-panel__header{padding:var(--space-4);border-bottom:1px solid var(--color-border-dark);flex-shrink:0;background:#ffffff08}.detail-panel__title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3)}.detail-panel__vehicle-info{display:flex;align-items:center;gap:var(--space-3)}.detail-panel__vehicle-icon{font-size:2rem;line-height:1}.detail-panel__vehicle-name{font-size:var(--text-base);font-weight:700;color:#fff;margin-bottom:2px}.detail-panel__vehicle-plate{font-size:var(--text-xs);color:#ffffff73;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.detail-panel__close{background:#ffffff14;border:none;color:#fff9;width:28px;height:28px;border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.detail-panel__close:hover{background:#ef44444d;color:#fff}.detail-panel__status-row{display:flex;flex-wrap:wrap;gap:var(--space-2)}.detail-panel__section{padding:var(--space-4);border-bottom:1px solid var(--color-border-dark)}.detail-panel__section-title{font-size:var(--text-xs);font-weight:700;color:#ffffff80;text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-3)}.detail-panel__coords{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-2)}.detail-panel__coord-item{display:flex;flex-direction:column;gap:3px}.detail-panel__coord-label{font-size:10px;color:#fff6;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.detail-panel__coord-value{font-size:var(--text-sm);font-weight:600;color:#fff;font-family:var(--font-mono)}.detail-panel__timestamp{font-size:11px;color:#ffffff59}.detail-panel__metrics{display:flex;gap:var(--space-3)}.detail-metric{flex:1;display:flex;flex-direction:column;align-items:center;background:#ffffff0d;border-radius:var(--radius-md);padding:var(--space-3) var(--space-2);border:1px solid rgba(255,255,255,.08);gap:2px}.detail-metric--warning{border-color:#ef444466;background:#ef444414}.detail-metric__icon{font-size:var(--text-lg)}.detail-metric__value{font-size:var(--text-xl);font-weight:700;color:#fff;line-height:1}.detail-metric__unit{font-size:10px;color:#fff6;font-weight:600}.detail-metric__label{font-size:10px;color:#fff6;text-transform:uppercase;letter-spacing:.05em}.detail-panel__stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.detail-stat{display:flex;flex-direction:column;gap:3px;background:#ffffff0a;border-radius:var(--radius-md);padding:var(--space-3)}.detail-stat__label{font-size:10px;color:#fff6;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.detail-stat__value{font-size:var(--text-base);font-weight:700;color:#fff}.detail-panel__history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.detail-panel__history-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-2)}.history-tab{flex:1;padding:var(--space-2);background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#fff9;font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:all var(--transition-fast);text-align:center}.history-tab:hover:not(:disabled){background:#ffffff1f;color:#fff}.history-tab--active{background:var(--color-primary);border-color:var(--color-primary-light);color:#fff}.history-tab:disabled{opacity:.5;cursor:not-allowed}.detail-panel__history-hint{font-size:11px;color:#ffffff4d;font-style:italic}.detail-panel__actions{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);margin-top:auto}.detail-panel__action-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;text-decoration:none;transition:all var(--transition-fast);text-align:center}.detail-panel__action-btn--secondary{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#ffffffb3}.detail-panel__action-btn--secondary:hover{background:#ffffff1f;color:#fff}.alert-banner{flex-shrink:0;z-index:calc(var(--z-navbar) - 1);animation:slideDown var(--transition-normal)}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.alert-banner--critical{background:linear-gradient(135deg,#7f1d1d,#991b1b);border-bottom:2px solid #EF4444}.alert-banner--warning{background:linear-gradient(135deg,#78350f,#92400e);border-bottom:2px solid #F59E0B}.alert-banner__bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);gap:var(--space-4)}.alert-banner__left{display:flex;align-items:center;gap:var(--space-2);flex:1}.alert-banner__icon{font-size:var(--text-lg);animation:shake .5s ease-in-out infinite alternate}@keyframes shake{0%{transform:rotate(-5deg)}to{transform:rotate(5deg)}}.alert-banner__text{font-size:var(--text-sm);color:#fff;font-weight:500;display:flex;align-items:center;gap:var(--space-2)}.alert-banner__critical-badge{background:#fff3;color:#fff;font-size:var(--text-xs);font-weight:700;padding:1px var(--space-2);border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.05em}.alert-banner__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.alert-banner__btn{padding:var(--space-1) var(--space-3);background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-pill);color:#fff;font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.alert-banner__btn:hover{background:#ffffff40}.alert-banner__btn--read{background:#22c55e33;border-color:#22c55e66}.alert-banner__btn--read:hover{background:#22c55e59}.alert-banner__btn--close{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.alert-banner__list{max-height:240px;overflow-y:auto;border-top:1px solid rgba(255,255,255,.1);background:#0003}.alert-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);border-bottom:1px solid rgba(255,255,255,.05);transition:background var(--transition-fast)}.alert-item:hover{background:#ffffff0d}.alert-item__icon{font-size:var(--text-base);flex-shrink:0}.alert-item__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.alert-item__vehicle{font-size:var(--text-xs);font-weight:700;color:#ffffffe6}.alert-item__message{font-size:var(--text-xs);color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alert-item__time{font-size:11px;color:#fff6;font-family:var(--font-mono);flex-shrink:0}.alert-item--critical{border-left:3px solid #EF4444}.alert-item--warning{border-left:3px solid #F59E0B}.alert-item--info{border-left:3px solid #3B82F6}.gps-page{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--color-bg-dark)}.gps-navbar{display:flex;align-items:center;justify-content:space-between;height:var(--navbar-height);padding:0 var(--space-4);background:var(--color-primary-dark);border-bottom:1px solid rgba(255,255,255,.08);z-index:var(--z-navbar);flex-shrink:0;gap:var(--space-4)}.gps-navbar__left,.gps-navbar__right{display:flex;align-items:center;gap:var(--space-3);flex:1}.gps-navbar__right{justify-content:flex-end}.gps-navbar__center{display:flex;align-items:center;justify-content:center}.gps-navbar__toggle{background:#ffffff1a;color:#fff;border:none;border-radius:var(--radius-md);width:36px;height:36px;font-size:var(--text-lg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast)}.gps-navbar__toggle:hover{background:#fff3}.gps-navbar__brand{display:flex;align-items:center;gap:var(--space-2)}.gps-navbar__icon{font-size:var(--text-xl)}.gps-navbar__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:700;color:#fff;white-space:nowrap}.gps-navbar__user{font-size:var(--text-sm);color:#fffc;display:flex;align-items:center;gap:var(--space-2)}.gps-navbar__admin-badge{background:var(--color-accent);color:#fff;font-size:var(--text-xs);font-weight:700;padding:2px var(--space-2);border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.05em}.gps-navbar__logout{background:#ffffff1a;color:#fff;border:none;border-radius:var(--radius-md);width:36px;height:36px;font-size:var(--text-base);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast)}.gps-navbar__logout:hover{background:#ef44444d}.connection-status{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:600;background:#ffffff14;color:#ffffffb3}.connection-status__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.connection-status--connected .connection-status__dot{background:var(--color-success);animation:pulse-dot 2s infinite}.connection-status--connecting .connection-status__dot,.connection-status--reconnecting .connection-status__dot{background:var(--color-warning);animation:pulse-dot 1s infinite}.connection-status--disconnected .connection-status__dot,.connection-status--error .connection-status__dot{background:var(--color-error)}.connection-status--connected{color:#ffffffe6}.connection-status--error{color:#fca5a5}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.gps-body{display:flex;flex:1;overflow:hidden;position:relative}.gps-sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--color-bg-panel);border-right:1px solid var(--color-border-dark);overflow-y:auto;transition:width var(--transition-normal),transform var(--transition-normal);z-index:var(--z-panel)}.gps-sidebar:not(.gps-sidebar--open){width:0;overflow:hidden}.gps-main{flex:1;position:relative;overflow:hidden}.gps-detail-panel{width:var(--panel-width);flex-shrink:0;background:var(--color-bg-panel);border-left:1px solid var(--color-border-dark);overflow-y:auto;z-index:var(--z-panel);animation:slideInRight var(--transition-normal)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.gps-sidebar{position:absolute;top:0;left:0;height:100%;transform:translate(-100%);box-shadow:var(--shadow-xl)}.gps-sidebar.gps-sidebar--open{width:300px;transform:translate(0)}.gps-detail-panel{position:absolute;top:0;right:0;height:100%;width:100%;max-width:360px;box-shadow:var(--shadow-xl)}.gps-navbar__title{display:none}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.3;color:var(--color-text-primary)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-light)}button{cursor:pointer;font-family:var(--font-body);border:none;outline:none;transition:all var(--transition-fast)}input,select,textarea{font-family:var(--font-body);font-size:var(--text-base)}img{max-width:100%;height:auto}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:var(--space-4);color:var(--color-text-secondary);font-size:var(--text-sm)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.leaflet-container{font-family:var(--font-body)!important;z-index:1}.leaflet-popup-content-wrapper{border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-xl)!important;border:1px solid var(--color-border)}.leaflet-popup-content{margin:var(--space-3) var(--space-4)!important}.leaflet-popup-tip{background:#fff!important}.vehicle-marker{background:transparent!important;border:none!important}.marker-container{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);border-radius:50%;border:3px solid white;box-shadow:var(--shadow-lg);font-size:18px;transition:transform var(--transition-fast)}.marker-container:hover{transform:scale(1.15)}.marker-container.moving{background:var(--color-moving);animation:markerPulse 2s infinite}.marker-pulse{position:absolute;width:100%;height:100%;border-radius:50%;background:var(--color-moving);opacity:.4;animation:pulseRing 2s infinite}@keyframes markerPulse{0%,to{box-shadow:0 0 #3b82f666}50%{box-shadow:0 0 0 8px #3b82f600}}@keyframes pulseRing{0%{transform:scale(1);opacity:.4}to{transform:scale(2.5);opacity:0}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:root{--color-primary: #1A3C6E;--color-primary-light: #2A5298;--color-primary-dark: #0F2444;--color-accent: #F97316;--color-accent-light: #FB923C;--color-accent-dark: #EA6C0A;--color-bg: #FFFFFF;--color-bg-secondary: #F8FAFC;--color-bg-tertiary: #F1F5F9;--color-bg-dark: #0F172A;--color-bg-panel: #1E293B;--color-text-primary: #1E293B;--color-text-secondary: #64748B;--color-text-muted: #94A3B8;--color-text-inverse: #F8FAFC;--color-border: #E2E8F0;--color-border-dark: #334155;--color-success: #22C55E;--color-success-bg: #F0FDF4;--color-warning: #F59E0B;--color-warning-bg: #FFFBEB;--color-error: #EF4444;--color-error-bg: #FEF2F2;--color-info: #3B82F6;--color-info-bg: #EFF6FF;--color-online: #22C55E;--color-offline: #94A3B8;--color-moving: #3B82F6;--color-stopped: #F59E0B;--color-alert: #EF4444;--font-heading: "Poppins", sans-serif;--font-body: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-pill: 9999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px rgba(0,0,0,.07);--shadow-lg: 0 10px 15px rgba(0,0,0,.1);--shadow-xl: 0 20px 25px rgba(0,0,0,.1);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--sidebar-width: 320px;--navbar-height: 64px;--panel-width: 360px;--z-navbar: 100;--z-panel: 50;--z-modal: 200;--z-toast: 300}[data-theme=dark]{--color-bg: #0F172A;--color-bg-secondary: #1E293B;--color-bg-tertiary: #334155;--color-text-primary: #F8FAFC;--color-text-secondary: #94A3B8;--color-border: #334155}
