/* ─────────────────────────────────────────────────────────
   Agenda Benahadux · Estilos compartidos
   Usado por: admin-563c004c.html, index.html
   ───────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --azul: #1B3A6B; --azul-claro: #2B5299; --naranja: #E8640C;
  --fondo: #F8F7F4; --blanco: #FFFFFF; --gris-texto: #4A4A4A;
  --gris-suave: #DDD8D0; --gris-label: #888480;
}
body { font-family: 'Inter', sans-serif; background: var(--fondo); color: var(--gris-texto); min-height: 100vh; }

header {
  background: var(--azul); color: white; padding: 28px 40px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 20px; border-bottom: 4px solid var(--naranja);
}
.header-izq { display: flex; align-items: center; gap: 20px; }
.escudo {
  width: 52px; height: 52px; background: white; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 24px;
}
.header-texto h1 { font-family: 'Playfair Display', serif; font-size: 1.6rem; font-weight: 700; line-height: 1.1; }
.header-texto p { font-size: 0.78rem; color: rgba(255,255,255,0.65); margin-top: 3px; text-transform: uppercase; letter-spacing: 0.1em; }
.btn-salir { background: rgba(255,255,255,0.1); color: white; border: 1px solid rgba(255,255,255,0.3); border-radius: 6px; padding: 8px 16px; font-size: 0.8rem; font-weight: 600; cursor: pointer; font-family: 'Inter', sans-serif; }
.btn-salir:hover { background: rgba(255,255,255,0.18); }

.contenedor { max-width: 860px; margin: 0 auto; padding: 40px 24px 80px; }

/* ─── LOGIN ─── */
.login-pantalla { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }
.login-caja { background: var(--blanco); border: 1px solid var(--gris-suave); border-radius: 10px; padding: 40px 36px; max-width: 380px; width: 100%; text-align: center; }
.login-caja .escudo { margin: 0 auto 18px; width: 56px; height: 56px; font-size: 26px; background: var(--fondo); border: 1px solid var(--gris-suave); }
.login-caja h1 { font-family: 'Playfair Display', serif; font-size: 1.3rem; color: var(--azul); margin-bottom: 6px; }
.login-caja p { font-size: 0.82rem; color: var(--gris-label); margin-bottom: 24px; }
.login-error { font-size: 0.8rem; color: #c0392b; margin-top: 10px; min-height: 1.2em; }

.panel-anadir { background: var(--blanco); border: 1px solid var(--gris-suave); border-radius: 10px; margin-bottom: 48px; overflow: hidden; }

.panel-tabs { display: flex; border-bottom: 1px solid var(--gris-suave); overflow-x: auto; }
.tab {
  flex: 1; min-width: 120px; padding: 13px 14px; font-size: 0.78rem; font-weight: 600;
  color: var(--gris-label); cursor: pointer; border: none; background: none;
  transition: all 0.15s; text-align: center; white-space: nowrap;
}
.tab.activo { color: var(--azul); border-bottom: 2px solid var(--naranja); background: var(--fondo); }
.tab:hover:not(.activo) { background: var(--fondo); color: var(--gris-texto); }

.panel-cuerpo { padding: 24px; }
.modo { display: none; }
.modo.visible { display: block; }

.etiqueta { font-size: 0.75rem; font-weight: 600; color: var(--gris-label); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 8px; display: block; }

textarea, input[type=text], input[type=date], input[type=time], input[type=password], select {
  width: 100%; font-family: 'Inter', sans-serif; font-size: 0.88rem; color: var(--gris-texto);
  border: 1px solid var(--gris-suave); border-radius: 6px; padding: 10px 14px;
  background: var(--fondo); transition: border-color 0.15s; outline: none;
}
textarea:focus, input:focus, select:focus { border-color: var(--azul-claro); }
textarea { resize: vertical; min-height: 110px; }

.campo-grupo { margin-bottom: 16px; }
.fila-tres { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }

.aviso-claude {
  display: flex; gap: 12px; background: rgba(27,58,107,0.05); border: 1px solid rgba(27,58,107,0.15);
  border-radius: 8px; padding: 14px 16px; margin-bottom: 18px; align-items: flex-start;
}
.aviso-claude .icono { font-size: 1.3rem; line-height: 1; }
.aviso-claude p { font-size: 0.82rem; color: var(--gris-texto); line-height: 1.5; }
.aviso-claude strong { color: var(--azul); }

.pega-json { width: 100%; min-height: 90px; font-family: 'Inter', sans-serif; font-size: 0.82rem; }

.zona-imagen {
  border: 2px dashed var(--gris-suave); border-radius: 8px; padding: 18px;
  text-align: center; cursor: pointer; transition: all 0.2s; position: relative;
}
.zona-imagen:hover { border-color: var(--azul-claro); background: rgba(27,58,107,0.03); }
.zona-imagen input[type=file] { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%; }
.zona-imagen p { font-size: 0.8rem; color: var(--gris-label); }
.imagen-preview-cont { display: flex; align-items: center; gap: 12px; margin-top: 10px; }
.imagen-preview-cont img { width: 70px; height: 70px; object-fit: cover; border-radius: 6px; border: 1px solid var(--gris-suave); }
.imagen-preview-cont .quitar-imagen { background: none; border: 1px solid var(--gris-suave); color: #c0392b; border-radius: 6px; padding: 5px 10px; font-size: 0.75rem; cursor: pointer; font-family: 'Inter', sans-serif; }
.subiendo-texto { font-size: 0.78rem; color: var(--gris-label); margin-top: 8px; }

/* BOTONES */
.btn {
  display: inline-flex; align-items: center; gap: 7px; padding: 10px 20px;
  border-radius: 6px; font-family: 'Inter', sans-serif; font-size: 0.85rem;
  font-weight: 600; cursor: pointer; border: none; transition: all 0.15s;
}
.btn-primario { background: var(--azul); color: white; }
.btn-primario:hover { background: var(--azul-claro); }
.btn-primario:disabled { background: var(--gris-suave); color: var(--gris-label); cursor: not-allowed; }
.btn-naranja { background: var(--naranja); color: white; }
.btn-naranja:hover { background: #cf5a0a; }
.btn-naranja:disabled { background: var(--gris-suave); color: var(--gris-label); cursor: not-allowed; }
.btn-secundario { background: var(--fondo); color: var(--azul); border: 1px solid var(--gris-suave); }
.btn-secundario:hover { border-color: var(--azul); }
.btn-fila { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; }
.btn-ancho { width: 100%; justify-content: center; }

.spinner { display: none; align-items: center; gap: 10px; color: var(--gris-label); font-size: 0.85rem; margin-top: 12px; }
.spinner.visible { display: flex; }
.spin { width: 18px; height: 18px; border: 2px solid var(--gris-suave); border-top-color: var(--azul); border-radius: 50%; animation: girar 0.7s linear infinite; }
@keyframes girar { to { transform: rotate(360deg); } }

/* REVISIÓN MÚLTIPLE EVENTOS */
.bloque-revision { display: none; background: var(--fondo); border: 1px solid var(--gris-suave); border-radius: 8px; padding: 20px; margin-top: 16px; }
.bloque-revision.visible { display: block; }
.revision-cabecera { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.revision-cabecera h4 { font-size: 0.75rem; font-weight: 700; color: var(--naranja); text-transform: uppercase; letter-spacing: 0.08em; }
.revision-cabecera span { font-size: 0.78rem; color: var(--gris-label); }

.evento-revision {
  background: var(--blanco); border: 1px solid var(--gris-suave); border-radius: 8px;
  padding: 16px; margin-bottom: 12px; position: relative;
}
.evento-revision.descartado { opacity: 0.4; }
.revision-num {
  position: absolute; top: -10px; left: 16px; background: var(--naranja); color: white;
  font-size: 0.68rem; font-weight: 700; padding: 2px 8px; border-radius: 20px;
}
.revision-acciones { display: flex; gap: 8px; margin-top: 12px; justify-content: flex-end; }
.btn-descartar { background: none; border: 1px solid var(--gris-suave); color: var(--gris-label); border-radius: 6px; padding: 6px 12px; font-size: 0.78rem; cursor: pointer; font-family: 'Inter', sans-serif; }
.btn-descartar:hover { border-color: #c0392b; color: #c0392b; }
.btn-restaurar { background: none; border: 1px solid var(--gris-suave); color: var(--azul); border-radius: 6px; padding: 6px 12px; font-size: 0.78rem; cursor: pointer; font-family: 'Inter', sans-serif; }

.revision-fila-tres { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-bottom: 10px; }
.revision-campo-grupo { margin-bottom: 10px; }
.revision-campo-grupo:last-child { margin-bottom: 0; }

/* AGENDA */
.agenda-cabecera { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 28px; flex-wrap: wrap; gap: 10px; }
.agenda-cabecera h2 { font-family: 'Playfair Display', serif; font-size: 1.4rem; color: var(--azul); }
.contador { font-size: 0.78rem; color: var(--gris-label); font-weight: 500; }
.mes-grupo { margin-bottom: 36px; }
.mes-titulo { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: var(--gris-label); padding-bottom: 10px; border-bottom: 1px solid var(--gris-suave); margin-bottom: 0; }

/* ─── AGENDA PÚBLICA: JERARQUÍA MES → DÍA → EVENTO ─── */
.meses-lista { display: flex; flex-direction: column; gap: 56px; }

.mes-grupo-pub { position: relative; }
.mes-titulo-pub {
  display: flex; align-items: baseline; gap: 12px; margin-bottom: 22px;
  font-family: 'Playfair Display', serif; font-size: 1.55rem; font-weight: 700; color: var(--azul);
}
.mes-titulo-pub .mes-cuenta { font-family: 'Inter', sans-serif; font-size: 0.72rem; font-weight: 600; color: var(--gris-label); text-transform: uppercase; letter-spacing: 0.08em; }
.mes-titulo-pub::after { content: ''; flex: 1; height: 3px; background: var(--naranja); border-radius: 2px; align-self: center; margin-left: 4px; opacity: 0.9; }

.dias-lista { display: flex; flex-direction: column; }
.dia-grupo { display: flex; gap: 20px; padding: 22px 0; border-bottom: 1px solid var(--gris-suave); }
.dia-grupo:first-child { padding-top: 4px; }
.dia-grupo:last-child { border-bottom: none; padding-bottom: 4px; }

.dia-fecha { flex: 0 0 58px; text-align: center; padding-top: 2px; }
.dia-fecha .dia-num { display: block; font-family: 'Playfair Display', serif; font-size: 1.9rem; font-weight: 700; color: var(--azul); line-height: 1; }
.dia-fecha .dia-semana { display: block; font-size: 0.64rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--naranja); margin-top: 5px; }

.dia-eventos { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 14px; }

.evento-tarjeta {
  background: var(--blanco); border: 1px solid var(--gris-suave); border-radius: 10px;
  padding: 18px 20px; transition: box-shadow 0.15s, border-color 0.15s;
}
.evento-tarjeta:hover { border-color: var(--azul-claro); box-shadow: 0 4px 16px rgba(27,58,107,0.08); }
.evento-tarjeta .evento-meta { margin-bottom: 8px; }
.evento-tarjeta .evento-titulo { margin-bottom: 6px; }
.evento-tarjeta .evento-desc { padding-bottom: 0; }
.evento-tarjeta .evento-lugar:last-of-type { margin-bottom: 6px; }

@media (max-width: 600px) {
  .meses-lista { gap: 40px; }
  .dia-grupo { gap: 14px; padding: 18px 0; }
  .dia-fecha { flex-basis: 44px; }
  .dia-fecha .dia-num { font-size: 1.5rem; }
  .mes-titulo-pub { font-size: 1.25rem; }
}

.timeline { position: relative; padding-left: 32px; }
.timeline::before { content: ''; position: absolute; left: 7px; top: 0; bottom: 0; width: 2px; background: var(--gris-suave); }
.evento-item { position: relative; padding: 20px 0 4px; border-bottom: 1px solid var(--gris-suave); animation: aparecer 0.25s ease; }
.evento-item:last-child { border-bottom: none; }
@keyframes aparecer { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }

.evento-punto { position: absolute; left: -28px; top: 24px; width: 14px; height: 14px; border-radius: 50%; background: var(--naranja); border: 2px solid var(--fondo); box-shadow: 0 0 0 2px var(--naranja); }

.evento-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; flex-wrap: wrap; }
.evento-fecha-chip { font-size: 0.72rem; font-weight: 700; color: var(--azul); background: rgba(27,58,107,0.08); padding: 3px 9px; border-radius: 20px; white-space: nowrap; }
.evento-hora-chip { font-size: 0.72rem; color: var(--gris-label); }
.evento-categoria { font-size: 0.68rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; padding: 2px 8px; border-radius: 20px; margin-left: auto; }
.cat-cultura { background: #E8F4FD; color: #1a6fa0; }
.cat-deporte { background: #E8F8EE; color: #1a7a3f; }
.cat-acto_institucional { background: #EFEFEF; color: #4a4a4a; }
.cat-acto_religioso { background: #F3F0FF; color: #5b3fa0; }
.cat-fiestas { background: #FFF0F0; color: #c0392b; }
.cat-presentacion { background: #FFF3E0; color: #b85c00; }
.cat-salud { background: #E8FBF5; color: #0f8a6c; }
.cat-comercio { background: #FFF8E0; color: #9a7400; }
.cat-infantil { background: #FDE8F5; color: #a0317f; }

.evento-titulo { font-size: 1rem; font-weight: 600; color: var(--azul); margin-bottom: 5px; line-height: 1.3; }
.evento-lugar { font-size: 0.82rem; color: var(--gris-label); display: flex; align-items: center; gap: 5px; margin-bottom: 6px; }
.evento-desc { font-size: 0.83rem; color: var(--gris-texto); line-height: 1.55; padding-bottom: 16px; }

.evento-acciones-rapidas { position: absolute; right: 0; top: 16px; display: flex; gap: 4px; }
.btn-eliminar { background: none; border: none; cursor: pointer; color: var(--gris-label); font-size: 22px; transition: color 0.15s; padding: 6px 10px; line-height: 1; border-radius: 6px; }
.btn-eliminar:hover { color: #c0392b; background: rgba(192,57,43,0.08); }
.btn-editar { background: none; border: none; cursor: pointer; font-size: 18px; transition: background 0.15s; padding: 6px 10px; border-radius: 6px; opacity: 0.75; }
.btn-editar:hover { opacity: 1; background: rgba(27,58,107,0.08); }
.evento-edicion-form { background: var(--fondo); border: 1px solid var(--gris-suave); border-radius: 8px; padding: 16px; margin: 12px 0; }

/* ─── FILTRO DE CATEGORÍAS (agenda pública) ─── */
.filtro-categorias { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; }
.filtro-btn {
  background: var(--blanco); border: 1px solid var(--gris-suave); color: var(--gris-texto);
  border-radius: 20px; padding: 7px 16px; font-size: 0.78rem; font-weight: 600;
  cursor: pointer; font-family: 'Inter', sans-serif; transition: all 0.15s; white-space: nowrap;
}
.filtro-btn:hover { border-color: var(--azul-claro); }
.filtro-btn.activo { background: var(--azul); border-color: var(--azul); color: white; }

.estado-vacio { text-align: center; padding: 60px 20px; color: var(--gris-label); }
.estado-vacio .icono { font-size: 3rem; margin-bottom: 16px; }
.estado-vacio p { font-size: 0.9rem; line-height: 1.6; }

.toast { position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--azul); color: white; padding: 12px 22px; border-radius: 8px; font-size: 0.85rem; font-weight: 500; opacity: 0; transition: all 0.25s; pointer-events: none; z-index: 100; white-space: nowrap; max-width: 90vw; text-align: center; }
.toast.visible { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.error { background: #c0392b; }

@media (max-width: 600px) {
  header { padding: 20px; flex-wrap: wrap; }
  .contenedor { padding: 24px 16px 60px; }
  .fila-tres, .revision-fila-tres { grid-template-columns: 1fr; }
}
