.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);padding:2rem;position:relative;overflow:hidden}.login-container:before,.login-container:after{content:"";position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);animation:float 20s infinite ease-in-out}.login-container:before{width:600px;height:600px;top:-300px;right:-300px;animation-delay:0s}.login-container:after{width:500px;height:500px;bottom:-250px;left:-250px;animation-delay:10s}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(120deg)}66%{transform:translate(-20px,20px) rotate(240deg)}}.login-box{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:0 32px 64px #00000040;padding:3rem;width:100%;max-width:480px;position:relative;z-index:1;border:1px solid var(--border-primary);animation:zoomIn .6s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-header{text-align:center;margin-bottom:2.5rem;animation:slideDown .6s ease .2s backwards}@keyframes slideDown{0%{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}.login-logo{display:inline-flex;padding:1.5rem;background:var(--gradient-primary);border-radius:var(--radius-lg);margin-bottom:1.5rem;color:#fff;box-shadow:0 12px 32px #667eea66;animation:bounceIn .8s cubic-bezier(.68,-.55,.265,1.55) .4s backwards;position:relative}@keyframes bounceIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.login-logo img{width:64px;height:64px;filter:brightness(0) invert(1);animation:float 3s ease-in-out infinite}.login-header h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.625rem;letter-spacing:-.03em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:var(--text-secondary);font-size:1rem;font-weight:400}.login-form{display:flex;flex-direction:column;gap:1.75rem}.form-group{display:flex;flex-direction:column;gap:.625rem;animation:fadeIn .5s ease calc(.6s + var(--index) * .1s) backwards}.form-group label{display:flex;align-items:center;gap:.625rem;font-weight:600;color:var(--text-primary);font-size:.95rem;transition:color var(--transition-fast)}.form-group:focus-within label{color:var(--accent-primary)}.form-group input{padding:1rem 1.25rem;border:2px solid var(--border-primary);border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-normal);font-family:Rubik,sans-serif;background:var(--bg-secondary);color:var(--text-primary);position:relative}.form-group input::placeholder{color:var(--text-tertiary)}.form-group input:hover{border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.form-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px #3b82f626,0 8px 16px #3b82f61a;background:var(--bg-primary);transform:translateY(-2px)}.login-btn{padding:1.125rem 1.5rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1.0625rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);font-family:Rubik,sans-serif;margin-top:.5rem;box-shadow:0 8px 24px #667eea66;position:relative;overflow:hidden;animation:fadeIn .6s ease .8s backwards}.login-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.login-btn:hover:before{width:400px;height:400px}.login-btn:hover{transform:translateY(-4px);box-shadow:0 16px 32px #667eea80}.login-btn:active{transform:translateY(-2px)}.login-footer{text-align:center;margin-top:1.25rem;animation:fadeIn .6s ease .9s backwards}.login-footer a{color:var(--accent-primary);text-decoration:none;font-size:.9375rem;font-weight:500;transition:all var(--transition-fast);position:relative}.login-footer a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--accent-primary);transition:width var(--transition-normal)}.login-footer a:hover:after{width:100%}.demo-info{margin-top:2rem;padding:1.25rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);text-align:center;animation:fadeIn .6s ease 1s backwards}.demo-info p{font-size:.875rem;color:var(--text-secondary);line-height:1.6}.demo-info strong{color:var(--text-primary);font-weight:600}@media (max-width: 480px){.login-container{padding:1.5rem}.login-box{padding:2rem 1.5rem}.login-header h1{font-size:1.625rem}.login-header p{font-size:.9375rem}}.dashboard{height:calc(100vh - 70px);display:flex;flex-direction:column;background:var(--bg-secondary);animation:fadeIn .5s ease}.dashboard-header{padding:1.5rem 2rem;background:var(--bg-primary);border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slideDown .4s ease .1s backwards}.dashboard-header h1{font-size:1.625rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em;position:relative}.dashboard-header h1:after{content:"";position:absolute;bottom:-8px;left:0;width:60px;height:3px;background:var(--gradient-primary);border-radius:2px}.header-controls{display:flex;gap:.75rem;animation:fadeIn .6s ease .3s backwards}.control-btn{display:flex;align-items:center;gap:.625rem;padding:.75rem 1.25rem;background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:Rubik,sans-serif;font-size:.9375rem;position:relative;overflow:hidden}.control-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#3b82f633;transform:translate(-50%,-50%);transition:width .6s,height .6s}.control-btn:hover:before{width:300px;height:300px}.control-btn:hover{border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.control-btn.active{background:var(--gradient-primary);border-color:transparent;color:#fff;box-shadow:0 4px 12px #667eea66}.control-btn.active:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px #667eea80}.dashboard-content{flex:1;display:flex;overflow:hidden}.viaturas-sidebar{width:380px;background:var(--bg-primary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow:hidden;animation:slideInLeft .5s ease .2s backwards}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.viaturas-sidebar h2{padding:1.75rem 1.5rem;font-size:1.25rem;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-primary);letter-spacing:-.01em;background:var(--bg-secondary)}.viaturas-list{flex:1;overflow-y:auto;padding:1.25rem}.viatura-card{background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden;animation:fadeIn .4s ease calc(var(--index) * .1s) backwards}.viatura-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.viatura-card:hover:before{left:100%}.viatura-card:hover{border-color:var(--accent-primary);box-shadow:0 8px 24px #3b82f626;transform:translateY(-4px) scale(1.02)}.viatura-card.selected{border-color:var(--accent-primary);background:var(--bg-primary);box-shadow:0 0 0 4px #3b82f626,0 8px 24px #3b82f633;animation:cardPulse 2s ease infinite}@keyframes cardPulse{0%,to{box-shadow:0 0 0 4px #3b82f626,0 8px 24px #3b82f633}50%{box-shadow:0 0 0 6px #3b82f640,0 12px 32px #3b82f64d}}.viatura-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.viatura-icon{padding:.75rem;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-radius:var(--radius-md);display:flex;border:1px solid rgba(59,130,246,.2);transition:all var(--transition-fast)}.viatura-card:hover .viatura-icon{transform:rotate(5deg) scale(1.1);box-shadow:0 4px 12px #3b82f64d}.viatura-info{flex:1}.viatura-info h3{font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem;letter-spacing:.01em}.viatura-info p{font-size:.875rem;color:var(--text-tertiary)}.status-badge{padding:.375rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;color:#fff;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em;box-shadow:var(--shadow-sm);animation:badgePulse 2s ease infinite}@keyframes badgePulse{0%,to{opacity:1}50%{opacity:.8}}.viatura-details{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border-primary)}.detail-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);font-weight:500}.driver-name{font-weight:500;color:var(--text-secondary)}.stats-grid{padding:1.25rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem;border-top:1px solid var(--border-primary);background:var(--bg-secondary)}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);transition:all var(--transition-normal);cursor:pointer}.stat-card:hover{transform:translateY(-4px) scale(1.05);box-shadow:var(--shadow-lg)}.stat-icon{padding:.75rem;border-radius:var(--radius-md);display:flex;color:#fff;box-shadow:var(--shadow-sm);animation:float 3s ease-in-out infinite}.stat-icon.green{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon.red{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-info h3{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:.375rem}.stat-info p{font-size:.8125rem;color:var(--text-tertiary);font-weight:500}.map-container{flex:1;position:relative;background:var(--bg-tertiary);animation:fadeIn .6s ease .4s backwards}.viatura-marker{cursor:pointer;transform:translate(-35px,-70px);display:flex;flex-direction:column;align-items:center;gap:.5rem;transition:all var(--transition-normal);animation:bounceIn .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes bounceIn{0%{transform:translate(-35px,-70px) scale(0);opacity:0}50%{transform:translate(-35px,-70px) scale(1.1)}to{transform:translate(-35px,-70px) scale(1);opacity:1}}.viatura-marker:hover{transform:translate(-35px,-70px) scale(1.15);z-index:1000}.viatura-icon-map{width:40px;height:40px;filter:drop-shadow(0 6px 20px rgba(0,0,0,.4));transition:all var(--transition-normal);position:relative}.viatura-icon-map.moving{animation:carMove .8s ease infinite}.viatura-icon-map.stopped{filter:grayscale(50%) drop-shadow(0 4px 12px rgba(0,0,0,.3));opacity:.85}@keyframes carMove{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.status-indicator-pulse{position:absolute;top:-8px;right:-8px;width:20px;height:20px;background:#10b981;border-radius:50%;border:3px solid white;box-shadow:0 2px 8px #10b98180;animation:pulse 2s ease infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.viatura-label{padding:.5rem 1rem;background:#3b82f6f2;border:2px solid rgba(255,255,255,.9);border-radius:var(--radius-md);font-size:.8125rem;font-weight:700;color:#fff;box-shadow:0 4px 16px #3b82f680;white-space:nowrap;animation:fadeIn .4s ease .2s backwards;letter-spacing:.8px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.cameras-panel{width:700px;background:var(--bg-primary);border-left:1px solid var(--border-primary);display:flex;flex-direction:column;box-shadow:-4px 0 24px #0000001a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slideInRight .4s cubic-bezier(.16,1,.3,1)}.cameras-header{padding:1.5rem;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.cameras-title{display:flex;align-items:center;gap:1rem;color:var(--accent-primary);animation:fadeIn .6s ease}.cameras-title svg{animation:float 3s ease-in-out infinite}.cameras-title h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.cameras-title p{font-size:.875rem;color:var(--text-tertiary)}.btn-close-cameras{padding:.75rem;background:transparent;border:1px solid var(--border-primary);color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex}.btn-close-cameras:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:rotate(90deg) scale(1.1)}.cameras-loading{display:flex;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--text-secondary);font-size:1rem;animation:fadeIn .4s ease}.cameras-loading p{display:flex;align-items:center;gap:.75rem}.cameras-loading:before{content:"";width:20px;height:20px;border:3px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;margin-right:.75rem}.cameras-grid{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1.5rem;overflow-y:auto}.cameras-iframe-container{flex:1;display:flex;flex-direction:column;padding:1.5rem;overflow:hidden;background:var(--bg-secondary);position:relative}.cameras-iframe-container>div:last-child{flex:1;display:flex;flex-direction:column;position:relative;min-height:0}.iframe-header-controls{display:flex;justify-content:flex-end;gap:.5rem;margin-bottom:.75rem;z-index:10}.btn-open-popup{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--accent-primary);border:1px solid var(--accent-primary);color:#fff;border-radius:var(--radius-md);font-weight:600;font-size:.8125rem;transition:all var(--transition-fast);cursor:pointer}.btn-open-popup:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.btn-open-external-small{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-primary);border:1px solid var(--border-primary);color:var(--text-primary);text-decoration:none;border-radius:var(--radius-md);font-weight:500;font-size:.8125rem;transition:all var(--transition-fast)}.btn-open-external-small:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f633}.cameras-iframe{flex:1;width:100%;min-height:0;border:none;border-radius:var(--radius-lg);background:#000;box-shadow:0 8px 32px #0003;animation:fadeIn .4s ease;position:relative}.iframe-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-lg);z-index:10}.iframe-loading-overlay .cameras-loading{background:#ffffff1a;padding:2rem;border-radius:var(--radius-md);color:#fff}.iframe-loading-overlay .cameras-loading p{color:#fff}.iframe-error-fallback{flex:1;width:100%;min-height:0;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:2rem}.iframe-error-message{text-align:center;color:var(--text-secondary);max-width:500px}.iframe-error-message svg{color:var(--text-tertiary);margin-bottom:1rem;opacity:.5}.iframe-error-message h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.iframe-error-message p{font-size:.875rem;color:var(--text-tertiary);margin-bottom:1.5rem}.btn-open-external{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--accent-primary);color:#fff;text-decoration:none;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;transition:all var(--transition-fast)}.btn-open-external:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.iframe-blocked-warning{position:absolute;bottom:1rem;left:1rem;right:1rem;z-index:15;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.iframe-blocked-message{display:flex;align-items:flex-start;gap:.75rem;padding:1.25rem;background:#ef4444f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(239,68,68,.5);border-radius:var(--radius-md);color:#fff;box-shadow:0 4px 16px #0000004d;animation:slideUp .3s ease}.iframe-blocked-message svg{flex-shrink:0;margin-top:.125rem}.iframe-blocked-content{flex:1}.iframe-blocked-message strong{display:block;font-size:.9375rem;font-weight:700;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.iframe-blocked-message p{font-size:.8125rem;margin:0 0 1rem;opacity:.95;line-height:1.5}.iframe-blocked-actions{display:flex;align-items:center;gap:.75rem}.btn-open-external-inline{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;text-decoration:none;border-radius:var(--radius-md);font-weight:600;font-size:.8125rem;transition:all var(--transition-fast)}.btn-open-external-inline:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px);box-shadow:0 2px 8px #0003}.btn-dismiss-warning{display:flex;align-items:center;justify-content:center;padding:.5rem;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.btn-dismiss-warning:hover{background:#ffffff4d;border-color:#ffffff80;transform:scale(1.1)}.camera-card{background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;min-height:250px;transition:all var(--transition-normal);animation:scaleIn .4s ease calc(var(--index) * .1s) backwards}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.camera-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000026;border-color:var(--accent-primary)}.camera-label{padding:.75rem 1rem;background:linear-gradient(135deg,#3b82f614,#8b5cf614);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;font-size:.875rem;font-weight:600;color:var(--text-primary)}.camera-label>span{display:flex;align-items:center;gap:.5rem}.btn-fullscreen{padding:.375rem;background:transparent;border:1px solid var(--border-primary);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);display:flex}.btn-fullscreen:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;transform:scale(1.2)}.camera-view{flex:1;background:#000;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.camera-view:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.03) 50%,transparent 70%);pointer-events:none;animation:shimmer 3s infinite}.camera-footer{padding:1rem 1.5rem;background:linear-gradient(135deg,#10b9811a,#0596691a);border-top:1px solid var(--success-bg);font-size:.8125rem;color:var(--text-secondary);line-height:1.5;text-align:center;animation:fadeIn .8s ease}.camera-footer strong{color:var(--success)}.fullscreen-camera-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5000;display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeIn .3s ease}.fullscreen-camera-content{width:100%;max-width:1600px;height:90vh;background:var(--bg-primary);border-radius:var(--radius-xl);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 32px 64px #00000080;animation:zoomIn .4s cubic-bezier(.16,1,.3,1)}.fullscreen-camera-header{padding:1.5rem 2rem;background:linear-gradient(135deg,#3b82f614,#8b5cf614);border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center}.fullscreen-camera-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.fullscreen-camera-header p{font-size:.9375rem;color:var(--text-tertiary)}.fullscreen-camera-header button{padding:.75rem;background:transparent;border:1px solid var(--border-primary);color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex}.fullscreen-camera-header button:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:rotate(90deg) scale(1.1)}.fullscreen-camera-player{flex:1;background:#000;display:flex;align-items:center;justify-content:center}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.checkpoint-info-window{font-family:Rubik,sans-serif;min-width:280px;padding:.5rem}.checkpoint-info-window .info-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.checkpoint-info-window .info-icon{font-size:2rem;line-height:1}.checkpoint-info-window .info-header h3{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0;line-height:1.3}.checkpoint-info-window .info-body{display:flex;flex-direction:column;gap:.75rem}.checkpoint-info-window .info-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:.875rem}.checkpoint-info-window .info-row strong{color:#6b7280;font-weight:600;white-space:nowrap}.checkpoint-info-window .info-row span{color:#1f2937;font-weight:500;text-align:right}.checkpoint-info-window .info-badge{padding:.25rem .75rem;color:#fff;border-radius:.375rem;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.checkpoint-info-window .coordinates{font-family:Courier New,monospace;font-size:.75rem;color:#4b5563;background:#f3f4f6;padding:.25rem .5rem;border-radius:.25rem}.checkpoint-info-window .info-origin{font-size:.8125rem;color:#6366f1;font-weight:600}@media (max-width: 1400px){.cameras-panel{width:550px}}@media (max-width: 1200px){.viaturas-sidebar{width:320px}.cameras-panel{width:500px}.cameras-grid{grid-template-columns:1fr}}@media (max-width: 1024px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem}.dashboard-header h1{font-size:1.375rem}.header-controls{width:100%;justify-content:flex-start}}@media (max-width: 768px){.dashboard-content{flex-direction:column}.viaturas-sidebar{width:100%;max-height:45vh;border-right:none;border-bottom:1px solid var(--border-primary)}.cameras-panel{position:fixed;top:0;right:0;bottom:0;width:100%;z-index:3000}.fullscreen-camera-modal{padding:0}.fullscreen-camera-content{max-width:100%;height:100vh;border-radius:0}.stats-grid,.control-btn span{display:none}.control-btn{padding:.75rem}.viatura-icon-map{width:50px;height:50px}.viatura-marker{transform:translate(-25px,-50px)}.viatura-marker:hover{transform:translate(-25px,-50px) scale(1.15)}}.viaturas-page{min-height:calc(100vh - 70px);background:var(--bg-secondary);display:flex;flex-direction:column;animation:fadeIn .5s ease}.page-header{background:var(--bg-primary);border-bottom:1px solid var(--border-primary);padding:2rem;box-shadow:var(--shadow-sm);animation:slideDown .4s ease}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.header-title{display:flex;align-items:center;gap:1.25rem;animation:fadeIn .6s ease .2s backwards}.header-title img{filter:drop-shadow(0 4px 8px rgba(0,0,0,.1));transition:transform var(--transition-normal);animation:float 3s ease-in-out infinite}.header-title:hover img{transform:scale(1.1) rotate(5deg)}.header-title h1{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;letter-spacing:-.02em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-title p{font-size:.9375rem;color:var(--text-tertiary)}.btn-primary{display:flex;align-items:center;gap:.625rem;padding:.875rem 1.5rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-normal);font-family:Rubik,sans-serif;box-shadow:0 8px 24px #667eea66;font-size:.9375rem;position:relative;overflow:hidden;animation:fadeIn .6s ease .3s backwards}.btn-primary:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-primary:hover:before{width:300px;height:300px}.btn-primary:hover{transform:translateY(-4px);box-shadow:0 16px 32px #667eea80}.btn-primary:active{transform:translateY(-2px)}.page-content{flex:1;max-width:1400px;margin:0 auto;padding:2rem;width:100%;animation:fadeIn .6s ease .3s backwards}.filters-bar{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}.search-box{flex:1;display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:var(--bg-primary);border:2px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-tertiary);transition:all var(--transition-normal);max-width:500px}.search-box:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 4px #3b82f626,0 8px 16px #3b82f61a;transform:translateY(-2px)}.search-box input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:.9375rem;font-family:Rubik,sans-serif;outline:none}.search-box input::placeholder{color:var(--text-tertiary)}.stats-summary{display:flex;gap:.75rem}.stat-badge{padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;color:#fff;box-shadow:var(--shadow-md);animation:fadeIn .5s ease calc(.4s + var(--index) * .1s) backwards;transition:all var(--transition-fast)}.stat-badge:hover{transform:translateY(-2px) scale(1.05);box-shadow:var(--shadow-lg)}.stat-badge.green{background:linear-gradient(135deg,#10b981,#059669)}.stat-badge.yellow{background:linear-gradient(135deg,#f59e0b,#d97706)}.viaturas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.viatura-card-grid{background:var(--bg-primary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition-normal);display:flex;flex-direction:column;gap:1.25rem;position:relative;overflow:hidden;animation:scaleIn .4s ease calc(var(--index) * .08s) backwards}.viatura-card-grid:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s}.viatura-card-grid:hover:before{left:100%}.viatura-card-grid:hover{border-color:var(--accent-primary);box-shadow:0 12px 32px #3b82f626;transform:translateY(-8px) scale(1.02)}.card-header{display:flex;justify-content:space-between;align-items:center}.card-icon{padding:.75rem;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-md);display:flex;transition:all var(--transition-fast)}.viatura-card-grid:hover .card-icon{transform:rotate(10deg) scale(1.1);box-shadow:0 4px 12px #3b82f64d}.status-indicator{padding:.375rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.03em;box-shadow:var(--shadow-sm);animation:pulse 2s ease infinite}.card-body h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;letter-spacing:.02em}.modelo{color:var(--text-tertiary);font-size:.9375rem;margin-bottom:1rem}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item .label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.info-item .value{font-size:.9375rem;color:var(--text-primary);font-weight:500}.card-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-primary)}.btn-icon{flex:1;padding:.75rem;border:2px solid var(--border-primary);background:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center}.btn-icon.edit{color:var(--accent-primary)}.btn-icon.edit:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;transform:translateY(-4px) rotate(5deg);box-shadow:0 8px 24px #3b82f666}.btn-icon.delete{color:var(--danger)}.btn-icon.delete:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:translateY(-4px);box-shadow:0 8px 24px #ef444466}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-tertiary);animation:fadeIn .6s ease}.empty-state img{opacity:.3;margin-bottom:1.5rem;animation:float 3s ease-in-out infinite}.empty-state h3{font-size:1.25rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.empty-state p{font-size:.9375rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;animation:fadeIn .3s ease}.modal-content{background:var(--bg-primary);border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 32px 64px #0000004d;animation:zoomIn .4s cubic-bezier(.16,1,.3,1);border:1px solid var(--border-primary)}.modal-content.modal-large{max-width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.75rem 2rem;border-bottom:1px solid var(--border-primary);background:linear-gradient(135deg,#3b82f60d,#8b5cf60d)}.modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.btn-close{padding:.5rem;background:transparent;border:1px solid var(--border-primary);color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex}.btn-close:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:rotate(90deg) scale(1.1)}.modal-form{padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-top:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-primary);display:flex;align-items:center;gap:.5rem}.section-description{font-size:.875rem;color:var(--text-tertiary);margin-top:-.75rem}.cameras-config{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;padding:1.5rem;background:linear-gradient(135deg,#3b82f608,#8b5cf608);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-size:.875rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;transition:color var(--transition-fast)}.form-field:focus-within label{color:var(--accent-primary)}.form-field input,.form-field select{padding:.875rem 1rem;border:2px solid var(--border-primary);border-radius:var(--radius-md);font-size:.9375rem;font-family:Rubik,sans-serif;background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-normal)}.form-field input::placeholder{color:var(--text-tertiary)}.form-field input:hover,.form-field select:hover{border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px #3b82f61a;background:var(--bg-primary);transform:translateY(-2px)}.modal-actions{display:flex;gap:1rem;padding-top:1rem;border-top:1px solid var(--border-primary)}.btn-secondary{flex:1;padding:.875rem 1.5rem;background:var(--bg-secondary);border:2px solid var(--border-primary);color:var(--text-primary);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-normal);font-family:Rubik,sans-serif;font-size:.9375rem}.btn-secondary:hover{border-color:var(--accent-primary);color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.modal-actions .btn-primary{flex:1}@media (max-width: 768px){.page-header{padding:1.5rem}.header-content{flex-direction:column;align-items:flex-start;gap:1rem}.header-title{gap:1rem}.header-title h1{font-size:1.5rem}.page-content{padding:1.5rem}.filters-bar{flex-direction:column;align-items:stretch}.search-box{max-width:100%}.viaturas-grid,.form-row,.cameras-config{grid-template-columns:1fr}}.kmz-importer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:3000;padding:2rem;animation:fadeIn .3s ease}.kmz-importer-modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:100%;max-width:1000px;max-height:85vh;overflow:hidden;box-shadow:0 32px 64px #0000004d;border:1px solid var(--border-primary);animation:zoomIn .4s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}@keyframes zoomIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.kmz-header{padding:1.75rem 2rem;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:flex-start;background:linear-gradient(135deg,#3b82f60d,#8b5cf60d)}.kmz-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;gap:.75rem}.kmz-header p{font-size:.9375rem;color:var(--text-tertiary)}.btn-close-kmz{padding:.5rem;background:transparent;border:1px solid var(--border-primary);color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex}.btn-close-kmz:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:rotate(90deg) scale(1.1)}.kmz-upload-section{padding:2rem;display:flex;flex-direction:column;gap:2rem}.upload-area{border:3px dashed var(--border-secondary);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;transition:all var(--transition-normal);cursor:pointer;background:var(--bg-secondary)}.upload-area:hover{border-color:var(--accent-primary);background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);transform:translateY(-4px)}.upload-area svg{color:var(--accent-primary);margin-bottom:1.5rem;animation:float 3s ease-in-out infinite}.upload-area h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.upload-area p{font-size:.9375rem;color:var(--text-tertiary);margin-bottom:1.5rem}#kmz-file-input{display:none}.upload-btn{display:inline-block;padding:.875rem 2rem;background:var(--gradient-primary);color:#fff;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 4px 12px #667eea66}.upload-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea80}.loading-state,.error-state{padding:2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner{width:48px;height:48px;border:4px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-state{color:var(--danger)}.info-box{padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.info-box h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.info-box ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}.info-box li{font-size:.875rem;color:var(--text-secondary)}.kmz-preview-section{display:flex;flex-direction:column;flex:1;overflow:hidden}.preview-header{padding:1.5rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.preview-header h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.preview-header p{font-size:.875rem;color:var(--text-tertiary)}.bulk-actions{padding:1rem 2rem;background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border-bottom:1px solid var(--border-primary);animation:slideDown .4s ease}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.bulk-actions h4{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.bulk-actions-controls{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:flex-start}.bulk-control{display:flex;flex-direction:column;gap:.5rem}.bulk-control label{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.bulk-buttons{display:flex;gap:.5rem}.bulk-btn{padding:.5rem 1rem;border:2px solid var(--border-primary);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:Rubik,sans-serif;white-space:nowrap}.bulk-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.bulk-btn.checkpoint:hover{border-color:#3b82f6;background:#3b82f6;color:#fff;box-shadow:0 4px 12px #3b82f666}.bulk-btn.base:hover{border-color:#f59e0b;background:#f59e0b;color:#fff;box-shadow:0 4px 12px #f59e0b66}.bulk-btn.poi:hover{border-color:#8b5cf6;background:#8b5cf6;color:#fff;box-shadow:0 4px 12px #8b5cf666}.bulk-btn-small{padding:.5rem .875rem;border:2px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:Rubik,sans-serif}.bulk-btn-small:hover{border-color:var(--accent-primary);background:var(--accent-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.bulk-btn-small.active{border-color:var(--success);background:var(--success);color:#fff}.bulk-raio-input{display:flex;gap:.5rem;align-items:center}.bulk-raio-input input{width:80px;padding:.5rem .75rem;border:2px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.8125rem;text-align:center;font-family:Rubik,sans-serif;transition:all var(--transition-fast)}.bulk-raio-input input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a}.preview-table-container{flex:1;overflow-y:auto;padding:1.5rem 2rem}.preview-table{width:100%;border-collapse:collapse}.preview-table thead th{background:var(--bg-secondary);padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-primary);border-bottom:2px solid var(--border-primary);position:sticky;top:0;z-index:10}.preview-table tbody tr{border-bottom:1px solid var(--border-primary);transition:all var(--transition-fast)}.preview-table tbody tr:hover{background:var(--bg-hover)}.preview-table tbody td{padding:1rem;font-size:.875rem;color:var(--text-secondary)}.preview-table td.coords{font-family:Courier New,monospace;font-size:.8125rem;color:var(--text-tertiary)}.preview-table td.center{text-align:center}.input-nome{width:100%;padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-family:Rubik,sans-serif;transition:all var(--transition-fast)}.input-nome:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a}.select-tipo{width:100%;padding:.5rem .75rem;border:2px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-weight:600;font-family:Rubik,sans-serif;cursor:pointer;transition:all var(--transition-fast)}.select-tipo:focus{outline:none;box-shadow:0 0 0 3px #3b82f61a}.checkbox-obrigatorio{width:20px;height:20px;cursor:pointer;accent-color:var(--accent-primary)}.input-raio{width:80px;padding:.5rem .75rem;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;text-align:center;font-family:Rubik,sans-serif;transition:all var(--transition-fast)}.input-raio:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a}.preview-summary{padding:1rem 2rem;background:var(--bg-secondary);border-top:1px solid var(--border-primary);border-bottom:1px solid var(--border-primary);display:flex;gap:2rem;justify-content:center}.summary-item{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;color:var(--text-primary)}.kmz-actions{padding:1.5rem 2rem;display:flex;gap:1rem;background:var(--bg-primary)}.btn-cancel{flex:1;padding:.875rem 1.5rem;background:var(--bg-secondary);border:2px solid var(--border-primary);color:var(--text-primary);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-normal);font-family:Rubik,sans-serif;font-size:.9375rem}.btn-cancel:hover{border-color:var(--accent-primary);color:var(--accent-primary);transform:translateY(-2px)}.btn-confirm{flex:2;padding:.875rem 1.5rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-normal);font-family:Rubik,sans-serif;font-size:.9375rem;box-shadow:0 4px 12px #667eea66;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-confirm:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea80}@media (max-width: 768px){.kmz-importer-modal{max-width:100%;max-height:100vh;border-radius:0}.preview-table-container{padding:1rem}.preview-table{font-size:.8125rem}.preview-table th,.preview-table td{padding:.75rem .5rem}.preview-summary{flex-direction:column;gap:.75rem}.bulk-actions-controls{flex-direction:column;gap:1rem}.bulk-buttons{flex-wrap:wrap}}.checkpoints-page{height:calc(100vh - 70px);display:flex;flex-direction:column;background:var(--bg-secondary);animation:fadeIn .5s ease}.checkpoints-content{flex:1;display:flex;overflow:hidden}.checkpoints-sidebar{width:400px;background:var(--bg-primary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow:hidden;animation:slideInLeft .5s ease .2s backwards}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#3b82f60d,#8b5cf60d)}.sidebar-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.count-badge{padding:.375rem .875rem;background:var(--gradient-primary);color:#fff;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;box-shadow:0 4px 12px #667eea66;animation:pulse 2s ease infinite}.checkpoints-list{flex:1;overflow-y:auto;padding:1rem}.checkpoint-item{background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;cursor:pointer;transition:all var(--transition-normal);display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;position:relative;overflow:hidden;animation:scaleIn .4s ease calc(var(--index) * .1s) backwards}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.checkpoint-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s}.checkpoint-item:hover:before{left:100%}.checkpoint-item:hover{border-color:var(--accent-primary);box-shadow:0 8px 24px #3b82f626;transform:translate(6px) scale(1.02)}.checkpoint-item.selected{border-color:var(--accent-primary);background:var(--bg-primary);box-shadow:0 0 0 4px #3b82f626;animation:cardPulse 2s ease infinite}.checkpoint-info{flex:1;display:flex;gap:1rem}.checkpoint-icon{padding:.75rem;background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-md);color:var(--accent-primary);display:flex;align-items:center;justify-content:center;height:fit-content;transition:all var(--transition-fast)}.checkpoint-item:hover .checkpoint-icon{transform:rotate(10deg) scale(1.1);box-shadow:0 4px 12px #3b82f64d}.checkpoint-details h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.checkpoint-details p{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:.75rem}.checkpoint-meta{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.meta-item{font-size:.75rem;color:var(--text-secondary);font-weight:500}.badge-required{padding:.25rem .625rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;box-shadow:0 2px 8px #ef44444d;animation:pulse 2s ease infinite}.checkpoint-actions{display:flex;gap:.5rem}.btn-icon-small{padding:.5rem;border:2px solid var(--border-primary);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.btn-icon-small.edit{color:var(--accent-primary)}.btn-icon-small.edit:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;transform:scale(1.2) rotate(10deg);box-shadow:0 4px 12px #3b82f666}.btn-icon-small.delete{color:var(--danger)}.btn-icon-small.delete:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:scale(1.2);box-shadow:0 4px 12px #ef444466}.empty-state-small{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;color:var(--text-tertiary);text-align:center;animation:fadeIn .6s ease}.empty-state-small svg{opacity:.3;margin-bottom:1rem;animation:float 3s ease-in-out infinite}.empty-state-small p{font-size:.9375rem}.map-section{flex:1;position:relative;background:var(--bg-tertiary);animation:fadeIn .6s ease .4s backwards}.floating-form{position:absolute;top:1.5rem;right:1.5rem;z-index:100;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 16px 48px #0003;border:1px solid var(--border-primary);max-width:420px;animation:slideInRight .4s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.floating-form form{padding:1.75rem;display:flex;flex-direction:column;gap:1.25rem}.floating-form h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.form-hint{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-tertiary);padding:.75rem;background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.form-row-inline{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-checkbox{display:flex;align-items:center;gap:.625rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:2px solid var(--border-primary);cursor:pointer;transition:all var(--transition-normal)}.form-checkbox:hover{border-color:var(--accent-primary);box-shadow:0 4px 12px #3b82f626;transform:translateY(-2px)}.form-checkbox input[type=checkbox]{width:1.25rem;height:1.25rem;cursor:pointer;accent-color:var(--accent-primary)}.form-checkbox label{flex:1;font-weight:500;color:var(--text-primary);cursor:pointer;font-size:.9375rem}.form-actions{display:flex;gap:.75rem;padding-top:.75rem;border-top:1px solid var(--border-primary)}.form-actions .btn-secondary,.form-actions .btn-primary{flex:1;padding:.75rem 1rem;font-size:.9375rem}@media (max-width: 1024px){.checkpoints-sidebar{width:320px}.floating-form{max-width:320px}}@media (max-width: 768px){.checkpoints-content{flex-direction:column}.checkpoints-sidebar{width:100%;max-height:40vh;border-right:none;border-bottom:1px solid var(--border-primary)}.floating-form{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);max-width:calc(100% - 2rem);max-height:80vh;overflow-y:auto}.form-row-inline{grid-template-columns:1fr}}.header-actions{display:flex;gap:.75rem}.header-actions .btn-secondary,.header-actions .btn-primary{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-normal);font-family:Rubik,sans-serif;font-size:.9375rem}.header-actions .btn-secondary{background:var(--bg-secondary);border:2px solid var(--border-primary);color:var(--text-primary)}.header-actions .btn-secondary:hover{border-color:var(--accent-primary);color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f633}.header-actions .btn-primary{background:var(--gradient-primary);border:none;color:#fff;box-shadow:0 4px 12px #667eea66}.header-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea80}.badge-tipo{padding:.25rem .625rem;color:#fff;font-size:.6875rem;font-weight:600;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.03em}.historico-page{height:calc(100vh - 70px);display:flex;flex-direction:column;background:var(--bg-secondary);animation:fadeIn .5s ease}.historico-content{flex:1;display:flex;overflow:hidden}.historico-sidebar{width:420px;background:var(--bg-primary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow-y:auto;animation:slideInLeft .5s ease .2s backwards}.stats-overview{padding:1.5rem;background:linear-gradient(135deg,#3b82f60d,#8b5cf60d);border-bottom:1px solid var(--border-primary);display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.stat-overview-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.25rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;transition:all var(--transition-normal);cursor:pointer;animation:scaleIn .4s ease calc(var(--index) * .1s) backwards}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.stat-overview-card:hover{transform:translateY(-6px) scale(1.05);box-shadow:0 12px 32px #00000026;border-color:var(--accent-primary)}.stat-icon-large{padding:1rem;border-radius:var(--radius-lg);display:flex;color:#fff;box-shadow:0 4px 16px #0003;animation:float 3s ease-in-out infinite}.stat-icon-large.success{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon-large.info{background:linear-gradient(135deg,#06b6d4,#0891b2)}.stat-icon-large.primary{background:var(--gradient-primary)}.stat-content h3{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1}.stat-content p{font-size:.75rem;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.03em}.filters-section{padding:1.5rem;border-bottom:1px solid var(--border-primary);background:var(--bg-primary)}.filters-section>h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}.filter-group{margin-bottom:1rem}.filter-group:last-child{margin-bottom:0}.filter-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;transition:color var(--transition-fast)}.filter-group:focus-within label{color:var(--accent-primary)}.filter-group select,.filter-group input{width:100%;padding:.75rem 1rem;border:2px solid var(--border-primary);border-radius:var(--radius-md);font-size:.9375rem;font-family:Rubik,sans-serif;background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-normal)}.filter-group select:hover,.filter-group input:hover{border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px #3b82f61a;transform:translateY(-2px)}.historico-list{flex:1;padding:1.5rem;overflow-y:auto}.historico-list>h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1.25rem}.historico-item{background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden;animation:scaleIn .4s ease calc(var(--index) * .08s) backwards}.historico-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s}.historico-item:hover:before{left:100%}.historico-item:hover{border-color:var(--accent-primary);box-shadow:0 8px 24px #3b82f626;transform:translate(6px) scale(1.02)}.historico-item.selected{border-color:var(--accent-primary);background:var(--bg-primary);box-shadow:0 0 0 4px #3b82f626;animation:cardPulse 2s ease infinite}@keyframes cardPulse{0%,to{box-shadow:0 0 0 4px #3b82f626}50%{box-shadow:0 0 0 6px #3b82f640}}.item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-primary)}.item-header h4{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem;letter-spacing:.01em}.motorista{font-size:.875rem;color:var(--text-tertiary)}.item-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.detail-row{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.detail-row svg{color:var(--text-tertiary)}.duration{margin-left:auto;font-weight:600;color:var(--accent-primary)}.item-progress{margin-bottom:1rem}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.progress-value{color:var(--text-primary)}.progress-bar{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden;position:relative}.progress-fill{height:100%;transition:width .8s ease;border-radius:var(--radius-sm);position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.item-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border-primary)}.distance{font-size:.9375rem;font-weight:700;color:var(--text-primary)}.btn-view{padding:.5rem 1rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:Rubik,sans-serif;box-shadow:0 4px 12px #667eea4d}.btn-view:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #667eea66}.map-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);text-align:center;padding:2rem;animation:fadeIn .6s ease}.map-placeholder svg{opacity:.3;margin-bottom:1.5rem;animation:float 3s ease-in-out infinite}.map-placeholder h3{font-size:1.5rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.map-placeholder p{font-size:.9375rem}.map-info-card{position:absolute;top:1.5rem;left:1.5rem;z-index:100;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:0 12px 32px #00000026;max-width:350px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slideInLeft .4s cubic-bezier(.16,1,.3,1)}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.875rem}.info-row:not(:last-child){border-bottom:1px solid var(--border-primary)}.info-row strong{color:var(--text-primary);font-weight:600}.info-row span{color:var(--text-secondary);text-align:right}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media (max-width: 1200px){.historico-sidebar{width:360px}.stats-overview{grid-template-columns:1fr;gap:.75rem}.stat-overview-card{flex-direction:row;text-align:left}}@media (max-width: 768px){.historico-content{flex-direction:column}.historico-sidebar{width:100%;max-height:50vh;border-right:none;border-bottom:1px solid var(--border-primary)}.stats-overview{grid-template-columns:1fr}.map-info-card{position:static;margin:1rem;max-width:none}}.layout{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-secondary)}.top-bar{height:70px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;box-shadow:0 2px 12px #00000014;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:sticky;top:0;z-index:1000;animation:slideDown .4s ease}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.top-bar-left{display:flex;align-items:center;gap:2rem}.logo-compact{display:flex;align-items:center;gap:.75rem;animation:fadeIn .6s ease}.logo-compact img{width:40px;height:40px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:transform var(--transition-normal)}.logo-compact img:hover{transform:scale(1.1) rotate(5deg)}.logo-compact h1{font-size:1.375rem;font-weight:700;color:var(--text-primary);letter-spacing:-.03em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.top-nav{display:flex;gap:.5rem}.nav-item{display:flex;align-items:center;gap:.625rem;padding:.75rem 1.25rem;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);font-weight:500;font-size:.9375rem;transition:all var(--transition-fast);position:relative;overflow:hidden}.nav-item:before{content:"";position:absolute;bottom:0;left:0;width:0;height:3px;background:var(--gradient-primary);transition:width var(--transition-normal)}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary);transform:translateY(-2px)}.nav-item:hover:before{width:100%}.nav-item.active{background:linear-gradient(135deg,#667eea26,#764ba226);color:var(--accent-primary);font-weight:600}.nav-item.active:before{width:100%}.nav-item img{width:20px;height:20px}.top-bar-right{display:flex;align-items:center;gap:.75rem}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-primary);color:var(--accent-primary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.theme-toggle-btn:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;transform:rotate(180deg) scale(1.1)}.logout-btn{display:flex;align-items:center;gap:.625rem;padding:.75rem 1.25rem;background:transparent;border:1px solid var(--border-primary);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);font-weight:500;font-size:.9375rem;font-family:Rubik,sans-serif;transition:all var(--transition-fast)}.logout-btn:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.main-content{flex:1;background:var(--bg-secondary);animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 1024px){.top-nav{gap:.25rem}.nav-item{padding:.75rem 1rem;font-size:.875rem}.nav-item span{display:none}}@media (max-width: 768px){.top-bar{padding:0 1rem;height:60px}.logo-compact h1,.logout-btn span{display:none}.logout-btn{padding:.75rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-hover: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #64748b;--text-inverse: #ffffff;--border-primary: #e2e8f0;--border-secondary: #cbd5e0;--accent-primary: #3b82f6;--accent-primary-hover: #2563eb;--accent-secondary: #8b5cf6;--success: #10b981;--success-bg: #d1fae5;--success-light: #ecfdf5;--danger: #ef4444;--danger-bg: #fee2e2;--danger-light: #fef2f2;--warning: #f59e0b;--warning-bg: #fed7aa;--warning-light: #fffbeb;--info: #06b6d4;--info-bg: #cffafe;--info-light: #f0fdfa;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-sidebar: linear-gradient(180deg, #1e3a8a 0%, #1e40af 100%);--gradient-animated: linear-gradient(45deg, #667eea, #764ba2, #667eea);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-hover: #2d3748;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-tertiary: #94a3b8;--text-inverse: #0f172a;--border-primary: #334155;--border-secondary: #475569;--accent-primary: #60a5fa;--accent-primary-hover: #3b82f6;--accent-secondary: #a78bfa;--success: #34d399;--success-bg: #064e3b;--success-light: #065f46;--danger: #f87171;--danger-bg: #7f1d1d;--danger-light: #991b1b;--warning: #fbbf24;--warning-bg: #78350f;--warning-light: #92400e;--info: #22d3ee;--info-bg: #164e63;--info-light: #155e75;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .6);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .7);--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-sidebar: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);--gradient-animated: linear-gradient(45deg, #667eea, #764ba2, #667eea)}body{font-family:Rubik,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-secondary);color:var(--text-primary);transition:background-color var(--transition-normal),color var(--transition-normal)}#root{min-height:100vh}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.fade-in{animation:fadeIn var(--transition-slow)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp var(--transition-slow)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.glass{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}[data-theme=dark] .glass{background:#0f172ab3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1)}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.gradient-animated{background:var(--gradient-animated);background-size:200% 200%;animation:gradientShift 3s ease infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.bounce{animation:bounce 1s ease-in-out infinite}*:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:var(--accent-primary);color:var(--text-inverse)}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.shimmer{background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-hover) 50%,var(--bg-tertiary) 100%);background-size:1000px 100%;animation:shimmer 2s infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.float{animation:float 3s ease-in-out infinite}
