/* ===== Tema Verde Lima + Negro — SaaS 2025 ===== */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
  /* Acento principal */
  --color-accent:        #009CDE;
  --color-accent-light:  #B0E4F5;
  --color-accent-dark:   #0080B8;

  /* Base */
  --color-bg:            #F7F8FA;
  --color-surface:       #FFFFFF;
  --color-surface-2:     #F0F2F5;

  /* Sidebar (claro) */
  --color-sidebar-bg:    #FFFFFF;
  --color-sidebar-text:  #6B7280;
  --color-sidebar-active-bg:  rgba(0,156,222,0.15);
  --color-sidebar-active-text: #006A9E;
  --color-sidebar-hover-bg:   #F0F2F5;

  /* Texto */
  --color-text-primary:  #0D0D0D;
  --color-text-secondary:#6B7280;
  --color-text-muted:    #9CA3AF;

  /* Bordes */
  --color-border:        #E5E7EB;
  --color-border-focus:  #009CDE;

  /* Estados */
  --color-success:       #009CDE;
  --color-warning:       #F59E0B;
  --color-danger:        #EF4444;
  --color-info:          #3B82F6;

  /* Sombras */
  --shadow-card: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-card-hover: 0 4px 12px rgba(0,0,0,0.08);

  /* Radios */
  --radius-sm:   6px;
  --radius-md:   12px;
  --radius-lg:   16px;
  --radius-pill: 999px;

  /* Tipografía */
  --font-sans: 'Plus Jakarta Sans', 'DM Sans', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

/* ===== Base ===== */
body {
  font-family: var(--font-sans) !important;
}

/* ===== Mapa input en formularios ===== */
#mapa-input {
    height: 350px;
    width: 100%;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    z-index: 0;
}

/* ===== Mapa general de sucesos ===== */
#mapa-lista {
    height: calc(100vh - 8rem);
    width: 100%;
    z-index: 0;
}

/* ===== Corregir z-index del sidebar sobre Leaflet ===== */
.sidebar {
    z-index: 10;
}

/* ===== Transición suave en reemplazos HTMX ===== */
.htmx-settling tbody {
    opacity: 0.5;
    transition: opacity 0.2s ease;
}

/* ===== Badge de estado ===== */
.badge-borrador    { background-color: rgba(245,158,11,0.12); color: #B45309; }
.badge-validado    { background-color: rgba(0,156,222,0.15); color: #006A9E; }
.badge-publicado   { background-color: rgba(59,130,246,0.12); color: #1e40af; }

/* ===== Blob decorativo ===== */
.blob-accent {
  position: absolute;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(0,156,222,0.18) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
}

/* ===== Scrollbar personalizado ===== */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: #D1D5DB;
  border-radius: 999px;
}
::-webkit-scrollbar-thumb:hover { background: #009CDE; }

/* ===== Sidebar links ===== */
.sidebar-link {
  color: #6B7280;
  font-weight: 500;
  transition: all 0.15s ease;
}
.sidebar-link:hover {
  background: #F0F2F5;
  color: #0D0D0D;
}
.sidebar-link.sidebar-active {
  background: rgba(0,156,222,0.15);
  color: #006A9E;
  border-left: 3px solid #009CDE;
  font-weight: 600;
}

/* ===== Transiciones globales ===== */
a, button, input, select, textarea {
  transition: all 0.15s ease;
}
