@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Orbitron:wght@700;900&family=Roboto+Mono:wght@400;500;600;700&display=swap');

:root{--bg-primary:#0a0e27;--bg-secondary:#141b2d;--bg-card:#1e293b;--bg-hover:#2d3748;--accent-cyan:#06b6d4;--accent-blue:#3b82f6;--accent-green:#10b981;--accent-red:#ef4444;--accent-yellow:#f59e0b;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#64748b;--glow-blue:0 0 20px rgba(59,130,246,.5);--glow-green:0 0 20px rgba(16,185,129,.5);--glow-red:0 0 20px rgba(239,68,68,.5)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:'Roboto Mono','Courier New',monospace;background:var(--bg-primary);color:var(--text-primary);line-height:1.6}body::before{content:'';position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 50%,rgba(59,130,246,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(16,185,129,.05) 0%,transparent 50%);pointer-events:none;z-index:0}.header{background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);border-bottom:2px solid var(--accent-cyan);box-shadow:0 4px 20px rgba(6,182,212,.2);padding:1.5rem 2rem;position:relative;z-index:100}.header::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--accent-cyan) 50%,transparent 100%);animation:pulse-line 3s ease-in-out infinite}@keyframes pulse-line{0%,100%{opacity:.5}50%{opacity:1}}.header-content{max-width:1600px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header h1{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.5px}.header small{color:var(--text-secondary);font-size:.875rem;display:block;margin-top:.25rem;font-family:'Inter',sans-serif}.header-info{display:flex;gap:2rem;align-items:center;font-size:.875rem;font-family:'Inter',sans-serif}.status-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-card);border-radius:.5rem;border:1px solid rgba(6,182,212,.3)}.status-online{color:var(--accent-green);animation:pulse-online 2s ease-in-out infinite}.status-offline{color:var(--accent-red);animation:pulse-offline 1s ease-in-out infinite}@keyframes pulse-online{0%,100%{filter:drop-shadow(var(--glow-green))}50%{filter:drop-shadow(0 0 30px rgba(16,185,129,.8))}}@keyframes pulse-offline{0%,100%{filter:drop-shadow(var(--glow-red))}50%{filter:drop-shadow(0 0 30px rgba(239,68,68,.8))}}.container{max-width:1600px;margin:0 auto;padding:2rem;position:relative;z-index:1}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid rgba(6,182,212,.2);border-radius:.75rem;padding:1.5rem;position:relative;overflow:hidden;transition:all .3s ease}.stat-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-blue))}.stat-card.danger::before{background:linear-gradient(90deg,var(--accent-red),#dc2626)}.stat-card.warning::before{background:linear-gradient(90deg,var(--accent-yellow),#d97706)}.stat-card.success::before{background:linear-gradient(90deg,var(--accent-green),#059669)}.stat-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px rgba(6,182,212,.3);border-color:var(--accent-cyan)}.stat-value{font-size:3rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1;font-family:'Orbitron',monospace}.stat-label{font-size:.875rem;color:var(--text-secondary);margin-top:.5rem;text-transform:uppercase;letter-spacing:1px}.card{background:var(--bg-card);border:1px solid rgba(6,182,212,.2);border-radius:.75rem;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px rgba(0,0,0,.3);position:relative}.card::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--accent-cyan) 50%,transparent 100%)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid rgba(6,182,212,.2)}.card-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.75rem}.card-title::before{content:'';width:4px;height:24px;background:linear-gradient(180deg,var(--accent-cyan),var(--accent-blue));border-radius:2px;box-shadow:var(--glow-blue)}.eventos-table{width:100%;border-collapse:separate;border-spacing:0 .5rem}.eventos-table thead{background:var(--bg-secondary)}.eventos-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--accent-cyan);text-transform:uppercase;letter-spacing:.5px;border:none}.eventos-table tbody tr{background:var(--bg-secondary);transition:all .3s ease;cursor:pointer}.eventos-table tbody tr:hover{background:var(--bg-hover);transform:translateX(5px);box-shadow:-4px 0 0 var(--accent-cyan)}.eventos-table td{padding:1rem;border:none;font-size:.875rem;color:var(--text-secondary)}.badge{display:inline-block;padding:.375rem .875rem;border-radius:.375rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid}.badge-alta{background:rgba(239,68,68,.2);color:var(--accent-red);border-color:var(--accent-red);box-shadow:0 0 10px rgba(239,68,68,.3)}.badge-media{background:rgba(245,158,11,.2);color:var(--accent-yellow);border-color:var(--accent-yellow);box-shadow:0 0 10px rgba(245,158,11,.3)}.badge-baixa{background:rgba(59,130,246,.2);color:var(--accent-blue);border-color:var(--accent-blue);box-shadow:0 0 10px rgba(59,130,246,.3)}.status-badge{padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600;border:1px solid}.status-novo{background:rgba(59,130,246,.2);color:#60a5fa;border-color:#3b82f6}.status-em-apuracao{background:rgba(245,158,11,.2);color:#fbbf24;border-color:#f59e0b}.status-acionado{background:rgba(249,115,22,.2);color:#fb923c;border-color:#f97316}.status-encerrado{background:rgba(16,185,129,.2);color:#34d399;border-color:#10b981}.btn{padding:.75rem 1.5rem;border:2px solid var(--accent-cyan);background:rgba(6,182,212,.1);color:var(--accent-cyan);border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;position:relative;overflow:hidden}.btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(6,182,212,.3),transparent);transition:left .5s ease}.btn:hover{background:var(--accent-cyan);color:var(--bg-primary);box-shadow:var(--glow-blue);transform:translateY(-2px)}.btn:hover::before{left:100%}.btn-primary{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));border:none;color:white}.btn-primary:hover{box-shadow:0 0 20px rgba(6,182,212,.6)}.btn-secondary{background:var(--bg-secondary);border-color:var(--text-muted);color:var(--text-secondary)}.btn-sm{padding:.5rem 1rem;font-size:.8125rem;display: inline-flex;justify-content: center;}.filters{display:flex;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:600;color:var(--accent-cyan);text-transform:uppercase;letter-spacing:.5px}.filter-group select,.filter-group input{padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid rgba(6,182,212,.3);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;transition:all .3s ease}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 10px rgba(6,182,212,.3)}#map{height:600px;border-radius:.75rem;overflow:hidden;border:2px solid rgba(6,182,212,.3);box-shadow:0 0 30px rgba(6,182,212,.2)}.modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(10,14,39,.95);backdrop-filter:blur(10px);z-index:9999;align-items:center;justify-content:center}.modal.active{display:flex;animation:fadeIn .3s ease}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);border:2px solid var(--accent-cyan);border-radius:1rem;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 0 50px rgba(6,182,212,.5);animation:slideUp .3s ease}@keyframes slideUp{from{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header h2{color:var(--accent-cyan);text-shadow:var(--glow-blue)}.modal-close{position:absolute;top:1rem;right:1rem;font-size:1.75rem;cursor:pointer;color:var(--text-secondary);transition:all .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:.25rem}.modal-close:hover{color:var(--accent-cyan);background:rgba(255,255,255,.1)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--accent-cyan);text-transform:uppercase;font-size:.875rem;letter-spacing:.5px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid rgba(6,182,212,.3);border-radius:.5rem;color:var(--text-primary);font-size:.875rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 15px rgba(6,182,212,.3)}.form-group textarea{min-height:120px;resize:vertical;font-family:inherit}.loading{text-align:center;padding:3rem;color:var(--text-secondary)}.spinner{border:4px solid var(--bg-secondary);border-top-color:var(--accent-cyan);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem;box-shadow:0 0 20px rgba(6,182,212,.5)}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--accent-cyan);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--accent-blue)}@media (max-width:768px){.stats-grid{grid-template-columns:1fr}.filters{flex-direction:column}#map{height:400px}.header h1{font-size:1.25rem}}.login-container{text-align:center;max-width:400px;margin:0 auto;padding:3rem 2rem}.login-logo{font-size:4rem;margin-bottom:1.5rem;animation:pulse-online 2s infinite}.login-title{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem}.login-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:1rem}.evento-popup h3{color:var(--text-primary);margin-bottom:.75rem}.evento-popup p{color:var(--text-secondary);margin:.25rem 0;font-size:.875rem}.evento-popup strong{color:var(--accent-cyan)}

.evento-popup hr {
  border:none;
  border-top:1px solid rgba(6,182,212,.2);
  margin:1rem 0;
}

.popup-actions {
  display:flex;
  gap:.5rem;
  margin-top:1rem;
  flex-wrap:wrap;
  flex-direction:column;
}

.evento-popup {
  background-color: var(--bg-card);
}

.leaflet-popup-content-wrapper {
  background: var(--bg-card) !important;
}

.leaflet-popup-tip {
  background: var(--bg-card) !important;
}

.login-container {
  max-width: 800px;
  margin: 0 auto;
}

.login-container form {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.login-container h1 {
  margin: 0 0 20px 0;
  text-align: center;
  margin-bottom: 20px;
}

.login-container h2 {
  margin: 0 0 20px 0;
  text-align: center;
  margin-bottom: 15px;
}

.login-container input[type="email"],
.login-container input[type="password"],
.login-container input[type="submit"],
.login-container input[type="text"] {
  padding: 0.875rem 1rem;
  font-size: 0.9375rem;
  margin-bottom: 5px;
}

.login-container input[type="email"]:focus,
.login-container input[type="password"]:focus,
.login-container input[type="submit"]:focus,
.login-container input[type="text"]:focus {
  border-color: var(--accent-cyan);
  box-shadow: 0 0 20px rgba(6, 182, 212, 0.4);
}

.login-container label {
  font-size: 0.875rem;
  color: var(--text-secondary);
  margin-bottom: 0.5rem;
}

.login-container .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 30px rgba(6, 182, 212, 0.6);
}

.login-logo svg {
  animation: float 3s ease-in-out infinite;
}

.login-container button {
  background: var(--accent-cyan);
  border-color: var(--accent-cyan);
  color: var(--bg-primary);
  box-shadow: 0 0 20px rgba(6, 182, 212, 0.5);
  padding: 10px 20px;
  border-radius: 5px;
  margin-top: 15px;
}

.login-container input[type="submit"] {
  background-color: blue;
  color: white;
  padding: 10px 20px;
  border-radius: 5px;
  border: none;
  cursor: pointer;
  margin-top: 10px;
  box-sizing: border-box;
  margin-bottom: 15px;
}

.login-container .error-message {
  color: red;
  font-size: 0.9em;
  margin: 4px 0;
}

@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-10px); }
}

/* Checkbox customizado */
input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--accent-cyan);
  cursor: pointer;
}

/* Link hover */
a:hover {
  text-decoration: underline;
  opacity: 0.8;
}

/* Monitor de Alertas Climáticos */
.badge-alert-clima {
  background: rgba(239, 68, 68, 0.2);
  color: var(--accent-red);
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  font-weight: 700;
  border: 2px solid var(--accent-red);
  box-shadow: 0 0 15px rgba(239, 68, 68, 0.4);
  animation: pulse-alert 2s ease-in-out infinite;
}

@keyframes pulse-alert {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

.clima-monitor-section {
  background: var(--bg-secondary);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid rgba(6, 182, 212, 0.2);
  max-height: 600px;
  display: flex;
  flex-direction: column;
  padding-bottom: 1rem;
}

.alertas-container {
    flex: 1 1 auto;
    overflow-y: auto; /* scroll if too many alerts */
    overflow-x: hidden;
}

.stats-grid {
    margin-top: auto;  /* pushes to bottom */
    gap: 0.25rem;
}

#eventos-container {
    max-height: 800px;
    overflow-y: auto;
    overflow-x: hidden;
}

.section-subtitle {
  font-size: 1rem;
  font-weight: 600;
  color: var(--accent-cyan);
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(6, 182, 212, 0.2);
}

.alerta-clima-item {
  padding: 1rem;
  margin-bottom: 0.75rem;
  border-radius: 0.5rem;
  border-left: 4px solid;
  font-size: 0.875rem;
  transition: all 0.3s ease;
  position: relative;
}

.alerta-clima-item:hover {
  transform: translateX(5px);
}

.alerta-critico {
  background: rgba(239, 68, 68, 0.1);
  border-color: var(--accent-red);
  color: var(--text-primary);
}

.alerta-atencao {
  background: rgba(245, 158, 11, 0.1);
  border-color: var(--accent-yellow);
  color: var(--text-primary);
}

.alerta-tempo {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 0.5rem;
}

.clima-stat-box {
  background: var(--bg-card);
  border: 1px solid rgba(6, 182, 212, 0.3);
  border-radius: 0.5rem;
  text-align: center;
}

.clima-stat-value {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--accent-cyan);
  font-family: 'Orbitron', monospace;
}

.clima-stat-label {
  font-size: 0.75rem;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 0.25rem;
}

.localidades-scroll {
  flex: 1;
  overflow-y: auto;
  padding-right: 0.5rem;
}

.localidade-item {
  display: grid;
  grid-template-columns: 1.5fr 0.75fr 0.75fr 0.25fr;
  align-items: center;
  gap: 2.0rem;
  padding: 0.875rem 1rem;
  margin-bottom: 0.5rem;
  background: var(--bg-card);
  border-radius: 0.5rem;
  border-left: 3px solid;
  transition: all 0.3s ease;
}

.localidade-item:hover {
  transform: translateX(3px);
  box-shadow: -3px 0 0 var(--accent-cyan);
}

.localidade-item.status-ok {
  border-color: var(--accent-green);
}

.localidade-item.status-alerta {
  border-color: var(--accent-red);
}

.localidade-nome {
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.875rem;
}

.localidade-rodovia {
  color: var(--text-muted);
  font-size: 0.8125rem;
}

.localidade-temperatura {
  color: var(--text-muted);
  font-size: 0.8125rem;
}

.status-icon {
  font-size: 1.25rem;
}

.waze-monitor-section {
  background: var(--bg-secondary);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid rgba(6, 182, 212, 0.2);
  margin-top: 1.5rem;
}

.waze-buttons {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.waze-btn {
  padding: 0.75rem 1.5rem;
  background: var(--bg-card);
  border: 2px solid rgba(6, 182, 212, 0.3);
  border-radius: 0.5rem;
  color: var(--text-secondary);
  font-weight: 600;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.3s ease;
}

.waze-btn:hover {
  border-color: var(--accent-cyan);
  color: var(--accent-cyan);
  transform: translateY(-2px);
}

.waze-btn.active {
  background: var(--accent-cyan);
  border-color: var(--accent-cyan);
  color: var(--bg-primary);
  box-shadow: 0 0 20px rgba(6, 182, 212, 0.5);
}
