body.layout-con-sidebar-cal .layout-con-sidebar-wrapper {
    display: grid;
    grid-template-columns: minmax(0, 75%) minmax(0, 25%);
    gap: 14px;
    align-items: start;
}

.calendar-sidebar-columna {
    justify-self: center;
    margin-left: auto;
    margin-right: auto;
    margin-top: 40px;
    width: calc(100% - 12px);
    max-width: 540px;
    transform: translateX(-22px);
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: stretch;
}

.calendar-sidebar-fijo {
    position: relative;
    width: 100%;
    margin: 0;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: 0 12px 26px rgba(2, 6, 23, 0.2);
    padding: 12px;
    display: none;
}

.calendar-sidebar-columna .sidebar-titulo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
    font-weight: 700;
    color: var(--primary);
}

.calendar-sidebar-bloque-secundario {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: 0 12px 26px rgba(2, 6, 23, 0.2);
    padding: 12px;
    width: 100%;
    margin: 0;
}

.lista-eventos-sidebar-box {
    border: 1px solid var(--border);
    border-radius: 10px;
    background: color-mix(in srgb, var(--card) 92%, #ffffff 8%);
    padding: 8px;
    min-height: 120px;
    max-height: 260px;
    overflow: auto;
}

#lista-eventos-sidebar ul,
#proximos-15-dias-sidebar ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

#lista-eventos-sidebar li,
#proximos-15-dias-sidebar li {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding: 7px 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--card);
    font-size: 12px;
    line-height: 1.35;
}

#lista-eventos-sidebar li.periodo-laboral-mes-header {
    display: block;
    border: none;
    background: transparent;
    padding: 12px 4px 4px;
    margin: 0;
    font-size: 13px;
    font-weight: 700;
    color: var(--muted-foreground, #64748b);
    cursor: default;
    line-height: 1.2;
}

#lista-eventos-sidebar li.periodo-laboral-mes-header:first-child {
    padding-top: 4px;
}

.evento-sidebar-fecha {
    color: #0f172a;
    font-weight: 700;
    font-size: 12px;
}

.tema-oscuro .evento-sidebar-fecha {
    color: #bfdbfe;
}

.calendar-sidebar-widget .fc {
    font-size: 12px;
}

.calendar-sidebar-widget {
    background: var(--card) !important;
    background-color: var(--card) !important;
    --fc-page-bg-color: var(--card) !important;
    --fc-neutral-bg-color: var(--card) !important;
    --fc-border-color: rgba(148, 163, 184, 0.25) !important;
}

.calendar-sidebar-widget .fc .fc-toolbar.fc-header-toolbar {
    margin-bottom: 0.6em;
}

.calendar-sidebar-widget .fc .fc-toolbar-title {
    font-size: 1.05em;
}

.calendar-sidebar-widget .fc .fc-button {
    padding: 0.22em 0.45em;
}

.calendar-sidebar-widget .fc {
    --fc-page-bg-color: var(--card);
    --fc-neutral-bg-color: var(--card);
    --fc-border-color: rgba(148, 163, 184, 0.25);
}

.calendar-sidebar-widget .fc .fc-scrollgrid,
.calendar-sidebar-widget .fc .fc-scrollgrid-section-header,
.calendar-sidebar-widget .fc .fc-scrollgrid-section-header > *,
.calendar-sidebar-widget .fc .fc-scrollgrid-section-header > td,
.calendar-sidebar-widget .fc .fc-scrollgrid-section-header > th,
.calendar-sidebar-widget .fc .fc-scrollgrid-section-header table,
.calendar-sidebar-widget .fc .fc-scrollgrid-section-header tbody,
.calendar-sidebar-widget .fc .fc-scrollgrid-section-header tr,
.calendar-sidebar-widget .fc .fc-scrollgrid-section-header th,
.calendar-sidebar-widget .fc .fc-scrollgrid-sync-table,
.calendar-sidebar-widget .fc .fc-scrollgrid-section-liquid > td,
.calendar-sidebar-widget .fc .fc-scroller,
.calendar-sidebar-widget .fc .fc-scroller-harness,
.calendar-sidebar-widget .fc .fc-col-header,
.calendar-sidebar-widget .fc .fc-col-header-cell,
.calendar-sidebar-widget .fc .fc-col-header-cell-cushion,
.calendar-sidebar-widget .fc table,
.calendar-sidebar-widget .fc thead,
.calendar-sidebar-widget .fc tr {
    background: var(--card) !important;
    background-color: var(--card) !important;
}

.calendar-sidebar-widget .fc table {
    margin-top: 0 !important;
    border-collapse: collapse !important;
}

.calendar-sidebar-widget .fc tr:nth-child(even),
.calendar-sidebar-widget .fc tr:hover {
    background: var(--card) !important;
}

.calendar-sidebar-widget .fc-theme-standard .fc-scrollgrid,
.calendar-sidebar-widget .fc-theme-standard .fc-scrollgrid-section-header,
.calendar-sidebar-widget .fc-theme-standard .fc-scrollgrid-section-header > *,
.calendar-sidebar-widget .fc-theme-standard td,
.calendar-sidebar-widget .fc-theme-standard th {
    background: var(--card) !important;
    background-color: var(--card) !important;
    border-color: rgba(148, 163, 184, 0.25) !important;
}

.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-section-header,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-section-header > *,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-section-header > td,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-section-header > th,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-section-header table,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-section-header tbody,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-section-header tr,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-section-header th,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-sync-table,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scrollgrid-section-liquid > td,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scroller,
.tema-oscuro .calendar-sidebar-widget .fc .fc-scroller-harness,
.tema-oscuro .calendar-sidebar-widget .fc .fc-col-header,
.tema-oscuro .calendar-sidebar-widget .fc .fc-col-header-cell,
.tema-oscuro .calendar-sidebar-widget .fc .fc-col-header-cell-cushion,
.tema-oscuro .calendar-sidebar-widget .fc table,
.tema-oscuro .calendar-sidebar-widget .fc thead,
.tema-oscuro .calendar-sidebar-widget .fc tr {
    background: var(--card) !important;
    background-color: var(--card) !important;
}

.tema-oscuro .calendar-sidebar-widget .fc table {
    margin-top: 0 !important;
    border-collapse: collapse !important;
}

.tema-oscuro .calendar-sidebar-widget .fc tr:nth-child(even),
.tema-oscuro .calendar-sidebar-widget .fc tr:hover {
    background: var(--card) !important;
}

.tema-oscuro .calendar-sidebar-widget .fc-theme-standard .fc-scrollgrid,
.tema-oscuro .calendar-sidebar-widget .fc-theme-standard .fc-scrollgrid-section-header,
.tema-oscuro .calendar-sidebar-widget .fc-theme-standard .fc-scrollgrid-section-header > *,
.tema-oscuro .calendar-sidebar-widget .fc-theme-standard td,
.tema-oscuro .calendar-sidebar-widget .fc-theme-standard th {
    background: var(--card) !important;
    background-color: var(--card) !important;
    border-color: rgba(148, 163, 184, 0.25) !important;
}

@media (max-width: 1320px) {
    body.layout-con-sidebar-cal .layout-con-sidebar-wrapper {
        display: block;
    }
    body.layout-con-sidebar-cal .calendar-sidebar-columna {
        display: flex !important;
        position: static !important;
        visibility: visible !important;
        opacity: 1 !important;
        width: calc(100% - 24px);
        margin: 16px 12px 0 12px;
        align-items: stretch;
    }
    body.layout-con-sidebar-cal .calendar-sidebar-fijo,
    body.layout-con-sidebar-cal .calendar-sidebar-bloque-secundario {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        width: 100%;
        max-width: none;
        margin: 0 0 12px 0;
    }
    body.layout-con-sidebar-cal .lista-eventos-sidebar-box {
        max-height: 320px;
    }
}

@media (max-width: 768px) {
    body.layout-con-sidebar-cal .calendar-sidebar-columna {
        width: 100% !important;
        max-width: none !important;
        margin: 16px 0 0 0 !important;
        transform: none !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-fijo,
    body.layout-con-sidebar-cal .calendar-sidebar-bloque-secundario {
        width: 100% !important;
        max-width: none !important;
        margin: 0 0 12px 0 !important;
    }
}

/* Mobile hard override: sidebar cards exactly full content width */
@media (max-width: 768px) {
    html body.layout-con-sidebar-cal .layout-con-sidebar-wrapper .calendar-sidebar-columna {
        width: calc(100vw - 24px) !important;
        max-width: calc(100vw - 24px) !important;
        min-width: calc(100vw - 24px) !important;
        margin: 12px auto !important;
        padding: 0 !important;
        transform: none !important;
        box-sizing: border-box !important;
    }

    html body.layout-con-sidebar-cal .layout-con-sidebar-wrapper .calendar-sidebar-columna .calendar-sidebar-fijo,
    html body.layout-con-sidebar-cal .layout-con-sidebar-wrapper .calendar-sidebar-columna .calendar-sidebar-bloque-secundario {
        width: 100% !important;
        max-width: none !important;
        min-width: 0 !important;
        margin: 0 0 12px 0 !important;
        box-sizing: border-box !important;
    }
}

/* Mobile final: sidebar cards exactly same width as top cards */
@media (max-width: 768px) {
    body.layout-con-sidebar-cal .layout-con-sidebar-wrapper {
        display: block !important;
    }

    body.layout-con-sidebar-cal .layout-con-sidebar-wrapper > main,
    body.layout-con-sidebar-cal .layout-con-sidebar-wrapper > .calendar-sidebar-columna {
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
        box-sizing: border-box !important;
    }

    body.layout-con-sidebar-cal .layout-con-sidebar-wrapper > .calendar-sidebar-columna {
        transform: none !important;
        padding: 0 !important;
        gap: 12px !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-columna .calendar-sidebar-fijo,
    body.layout-con-sidebar-cal .calendar-sidebar-columna .calendar-sidebar-bloque-secundario {
        width: 100% !important;
        max-width: none !important;
        margin: 0 0 12px 0 !important;
        box-sizing: border-box !important;
    }
}
* {
    outline: none !important;
}

input, textarea, select, button {
    outline: none !important;
}

input:focus, textarea:focus, select:focus, button:focus {
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(37,99,235,0.3);
}

input, textarea, select {
    padding: 10px 12px;
    border-radius: 6px;
    font-size: 14px;
    width: 250px;
    background: white;
}

:root{
  --primary:#0f172a;
  --secondary:#1e40af;
  --accent:#2563eb;
  --background:#f3f6fa;
  --card:#ffffff;
  --border:#e2e8f0;
}

*{
  box-sizing:border-box;
  margin:0;
  padding:0;
  font-family:"Segoe UI", Arial, sans-serif;
}

body{
  background:var(--background);
  line-height:1.6;
  color:#1e293b;
}

/* HEADER */
header {
    background: var(--primary);
    color: white;
    padding: 25px 40px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 15px;
    position: relative;
    z-index: 100; /* Mantener alto */
}

header h1{
  font-size:24px;
  font-weight:600;
}

/* NAV */
nav{
  background:white;
  padding:15px 40px;
  border-bottom:1px solid var(--border);
}

nav a{
  text-decoration:none;
  color:var(--primary);
  margin-right:25px;
  font-weight:500;
  font-size:14px;
  transition:color 0.2s ease;
}

nav a:hover{
  color:var(--accent);
}

/* SECTIONS */
section{
  background:var(--card);
  margin:40px 40px;
  padding:35px;
  border-radius:12px;
  border:1px solid var(--border);
  box-shadow:0 8px 24px rgba(15,23,42,0.06);
  transition:all 0.2s ease;
}

/* efecto visual suave */
section:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(15,23,42,0.08);
}

section h2{
  margin-bottom:25px;
  font-size:22px;
  font-weight:600;
  color:var(--primary);
  border-left:4px solid var(--accent);
  padding-left:12px;
}

section h3{
  margin:35px 0 15px 0;
  font-size:17px;
  font-weight:600;
  color:#334155;
}

/* INPUTS */
input, textarea{
  padding:10px 12px;
  border:1px solid #cbd5e1;
  border-radius:6px;
  font-size:14px;
  width:250px;
}

.destacada-noticia {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    background: #f0f0f0 !important;
    padding: 12px 15px !important;
    border-radius: 8px !important;
    margin: 10px 0 !important;
    width: 100% !important;
}

.destacada-noticia input[type="checkbox"] {
    width: 20px !important;
    height: 20px !important;
    margin: 0 !important;
    cursor: pointer !important;
    accent-color: #fbbf24 !important;
    flex-shrink: 0 !important;
}

.destacada-noticia label {
    display: inline-block !important;
    font-size: 15px !important;
    color: #333333 !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    line-height: 1.4 !important;
    margin: 0 !important;
}

textarea{
  width:400px;
}

input:focus, textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(37,99,235,0.15);
}

/* BUTTONS */
button{
  padding:9px 16px;
  border:none;
  border-radius:6px;
  background:var(--accent);
  color:white;
  font-size:14px;
  cursor:pointer;
  transition:all 0.2s ease;
}

button:hover{
  background:#dc3545;
}

/* TABLE */
table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
  margin-top:15px;
}

th{
  background:var(--secondary);
  color:white;
  text-align:left;
  padding:12px;
}

td{
  padding:12px;
  border-bottom:1px solid var(--border);
}

tr:nth-child(even){
  background:#f8fafc;
}

tr:hover{
  background:#e0f2fe;
}

/* DOCUMENT LIST */
#lista-documentos{
  margin-top:15px;
}

#lista-documentos li{
  margin-bottom:8px;
}

#lista-documentos a{
display:block;
padding:8px;
border-bottom:1px solid #ddd;
text-decoration:none;
color:#1a3a6e;
}

#lista-documentos a:hover{
background:#f2f6ff;
}

/* NOTICIAS */
nav a{
margin-right:15px;
text-decoration:none;
color:#1a1a1a;
}

.noticia{
background:#ffffff;
border-left:5px solid #2563eb;
padding:15px;
margin-bottom:15px;
border-radius:8px;
box-shadow:0 3px 8px rgba(0,0,0,0.08);
transition:0.2s;
position:relative;
overflow:hidden;
}

.noticia:hover{
transform:translateY(-2px);
box-shadow:0 5px 12px rgba(0,0,0,0.12);
}

.noticia h3{
margin:0 0 8px 0;
font-size:18px;
color:#1e293b;
margin-right: 120px;
}

.noticia p{
margin:0;
color:#475569;
}

/* Imagen de noticia: siempre contenida dentro de la tarjeta */
.noticia-imagen{
    width: 100%;
    max-width: 100%;
    margin: 12px 0;
    border-radius: 0;
    position: relative;
    overflow: hidden;
    border: none;
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    max-height: 200px;
}

.noticia-imagen img{
    display: block;
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 200px !important;
    object-fit: contain;
    border-radius: 0 !important;
}

/* Lupa de hover desactivada por petición */
.noticia-imagen::after{
    content: none !important;
}

.modal-imagen-grande{
    position: fixed;
    inset: 0;
    background: rgba(2,6,23,0.82);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.modal-imagen-grande img{
    max-width: min(92vw, 1400px);
    max-height: 88vh;
    width: auto;
    height: auto;
    border-radius: 0;
    box-shadow: 0 10px 40px rgba(0,0,0,0.45);
}

.btn-cerrar-imagen-grande{
    position: absolute;
    right: 20px;
    top: 16px;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    border: none !important;
    background: rgba(15,23,42,0.85) !important;
    color: #fff !important;
    font-size: 28px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Blindaje extra: cualquier imagen dentro de noticia queda contenida */
.noticia img,
.noticia-completa img{
    max-width: 100% !important;
    height: auto !important;
    max-height: 200px !important;
    display: block;
    object-fit: contain;
}

/* CONTENEDOR DE ETIQUETAS */
.noticia-etiquetas{
    position: absolute;
    top: 12px;
    right: 15px;
    display: flex;
    gap: 6px;
}

/* ETIQUETA INDIVIDUAL */
.noticia-etiquetas span{
    background: var(--accent);
    color:white;
    padding:4px 10px;
    border-radius:20px;
    font-size:11px;
    font-weight:600;
}

.noticia-etiquetas span:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 5px 12px rgba(0, 0, 0, 0.25) !important;
    filter: brightness(1.1) !important;
}

#buscar-contacto{
width:250px;
padding:8px;
margin-bottom:10px;
border-radius:6px;

}

/* Enlace "Ver más" en portada (noticias / contactos limitados) */
.ver-mas-portada {
    margin-top: 20px;
    padding: 15px 20px;
    background: #f0f9ff;
    border-radius: 8px;
    border-left: 4px solid var(--accent);
}
.ver-mas-portada p {
    margin: 0;
    color: var(--primary);
    font-size: 15px;
}
.ver-mas-portada a {
    color: var(--accent);
    font-weight: 600;
    text-decoration: none;
}
.ver-mas-portada a:hover {
    text-decoration: underline;
}
.ver-mas-portada a i {
    margin-right: 6px;
}
.ver-mas-portada-cell {
    text-align: center !important;
    padding: 16px !important;
    background: #f0f9ff !important;
    border-top: 2px solid var(--border);
}
.ver-mas-portada-cell a {
    color: var(--accent);
    font-weight: 600;
    text-decoration: none;
}
.ver-mas-portada-cell a:hover {
    text-decoration: underline;
}
.ver-mas-portada-cell a i {
    margin-right: 6px;
}
.tema-oscuro .ver-mas-portada {
    background: #1e3a5f;
    border-left-color: var(--accent);
}
.tema-oscuro .ver-mas-portada p {
    color: var(--text-primary);
}
.tema-oscuro .ver-mas-portada-cell {
    background: #1e3a5f !important;
    border-top-color: var(--border);
}

.aviso-empresa {
    background: #2563eb;
    color: #ffffff !important;
    padding: 15px 20px;
    font-weight: bold;
    text-align: center;
    font-size: 18px;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
    letter-spacing: 0.5px;
    border-radius: 8px;
    width: calc(100% - 80px);
    margin: 28px auto;
}

.aviso-empresa:empty {
    display: none;
}

.form-noticia {
    display: flex;
    flex-direction: column;
    gap: 15px;
    padding: 20px 0;
    margin-top: 15px;
    border-top: 1px solid var(--border);
}

.form-noticia input[type="text"] {
    width: 100%;
    padding: 12px;
    border-radius: 6px;
    font-size: 15px;
}

.form-noticia textarea {
    width: 100%;
    min-height: 80px;
    padding: 12px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 15px;
    resize: vertical;
}

.checkbox-destacada{
    display:flex;
    align-items:center;
    gap:5px;
}

.form-check-input{
    margin-right:2px !important;
}

#buscar-documento {
    width: 250px;
    max-width: 400px;
    padding: 10px 12px;
    margin-bottom: 12px;
    border-radius: 6px;
    box-sizing: border-box;
}

.carpeta-titulo{
cursor:pointer;
background:#f1f5f9;
padding:8px;
border-radius:6px;
margin-top:10px;
}

.carpeta-titulo:hover{
background:#e2e8f0;
}

.carpeta-contenido{
display:none;
margin-left:20px;
margin-top:8px;
transition:all 0.3s ease;
}

.carpeta-contenido.abierta{
display:block;
}

/* MEJORAS PARA EL CALENDARIO */
.fc {
  background: white !important;
  border-radius: 8px;
  font-size: 13px;
}

.fc .fc-toolbar-title {
  font-size: 16px !important;
  color: #0f172a !important;  /* Color oscuro fijo */
}

/* Mes y año en la misma línea, pegados a la derecha de las flechas (sin centrarse) */
.fc .fc-toolbar,
.fc .fc-header-toolbar {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 0 !important;
  justify-content: flex-start !important;
}
.fc .fc-toolbar-chunk {
  flex: 0 0 auto !important;
  max-width: none !important;
}
/* Chunk izquierdo: flechas */
.fc .fc-toolbar-chunk:first-child {
  display: flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  gap: 4px !important;
}
/* Chunk central: título justo al lado de las flechas */
.fc .fc-toolbar-chunk:nth-child(2) {
  display: flex !important;
  align-items: center !important;
  margin-left: 14px !important;
  justify-content: flex-start !important;
}
.fc .fc-toolbar-title {
  margin: 0 !important;
  padding: 0 !important;
}

/* Calendario grande: mismo comportamiento, todo alineado a la izquierda */
.calendar-full .fc-header-toolbar,
.calendar-full .fc-toolbar {
  display: flex !important;
  justify-content: flex-start !important;
  flex-wrap: nowrap !important;
  gap: 0 !important;
}
.calendar-full .fc-toolbar-chunk {
  flex: 0 0 auto !important;
}
.calendar-full .fc-toolbar-chunk:nth-child(2) {
  margin-left: 14px !important;
  justify-content: flex-start !important;
}

.fc .fc-daygrid-day {
  cursor: pointer;
  transition: background 0.2s;
  background: white !important;
}

.fc .fc-daygrid-day:hover {
  background: #e6f0ff !important;
}

.fc .fc-day-today {
  background: #fff3cd !important;
}

.fc .fc-day-today .fc-daygrid-day-number {
  color: #0f172a !important;
  font-weight: bold;
}

.fc .fc-daygrid-day-number {
  padding: 5px !important;
  font-size: 12px;
  color: #0f172a !important;  /* Color oscuro fijo */
}

.fc .fc-day-other .fc-daygrid-day-number {
  color: #94a3b8 !important;  /* Color más claro para días de otros meses */
}

.fc .fc-event {
  cursor: pointer;
  padding: 2px 4px;
  font-size: 11px;
  margin: 1px 0;
  border-radius: 3px;
}

.fc .fc-event.evento-proximo-5dias {
  background: linear-gradient(135deg, #fde047 0%, #facc15 60%, #f59e0b 100%) !important;
  border: 2px solid #b45309 !important;
  color: #111827 !important;
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.45), 0 6px 14px rgba(245, 158, 11, 0.45) !important;
  font-weight: 800 !important;
  transform: translateY(-1px);
  animation: pulsoEventoProximo5Dias 1.2s ease-in-out infinite alternate;
}

.fc .fc-event.evento-proximo-5dias .fc-event-title,
.fc .fc-event.evento-proximo-5dias .fc-event-time,
.fc .fc-event.evento-proximo-5dias .fc-event-main {
  color: #111827 !important;
  font-weight: 800 !important;
}

.lista-eventos-sidebar-mini li.evento-proximo-5dias {
  border: 2px solid #b45309 !important;
  border-left: 8px solid #f59e0b !important;
  background: linear-gradient(90deg, rgba(245, 158, 11, 0.3) 0%, rgba(250, 204, 21, 0.2) 100%);
  box-shadow: 0 8px 16px rgba(245, 158, 11, 0.3);
  font-weight: 800;
}

.tema-oscuro .lista-eventos-sidebar-mini li.evento-proximo-5dias {
  background: linear-gradient(90deg, rgba(245, 158, 11, 0.4) 0%, rgba(250, 204, 21, 0.28) 100%);
  border-color: #f59e0b !important;
  color: #f8fafc !important;
}

@keyframes pulsoEventoProximo5Dias {
  0% {
    box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.35), 0 4px 10px rgba(245, 158, 11, 0.35) !important;
    filter: saturate(1);
  }
  100% {
    box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.65), 0 10px 22px rgba(245, 158, 11, 0.55) !important;
    filter: saturate(1.08);
  }
}

.fc .fc-daygrid-day-frame {
  background: transparent;
}

.fc-col-header-cell {
    background-color: #1f3c88; /* azul del encabezado */
}

.fc-col-header-cell-cushion {
    color: white !important;
    font-weight: 600;
}


/* ====================== */
/* MODO OSCURO */
/* ====================== */

.tema-oscuro {
    --primary: #1e293b;
    --secondary: #2d3a5e;
    --accent: #3b82f6;
    --background: #0f172a;
    --card: #1e293b;
    --border: #334155;
    --text-primary: #f1f5f9;
    --text-secondary: #cbd5e1;
}

.tema-oscuro body {
    background: var(--background);
    color: var(--text-primary);
}

.tema-oscuro h1, 
.tema-oscuro h2, 
.tema-oscuro h3, 
.tema-oscuro h4, 
.tema-oscuro p,
.tema-oscuro span,
.tema-oscuro div:not(.noticia):not(.resultado-item):not(.aviso-empresa) {
    color: var(--text-primary) !important;
}

.tema-oscuro header {
    background: #0a0f1a;
}

.tema-oscuro nav {
    background: var(--card);
    border-bottom-color: var(--border);
}

.tema-oscuro nav a {
    color: var(--text-primary);
}

.tema-oscuro nav a:hover {
    color: var(--accent);
}

.tema-oscuro section {
    background: var(--card);
    border-color: var(--border);
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

.tema-oscuro section h2,
.tema-oscuro section h3 {
    color: var(--text-primary);
}

.tema-oscuro input,
.tema-oscuro textarea,
.tema-oscuro select {
    background: #334155;
    border-color: #475569;
    color: var(--text-primary);
}

.tema-oscuro input::placeholder,
.tema-oscuro textarea::placeholder {
    color: #94a3b8;
}

.tema-oscuro input:focus,
.tema-oscuro textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3);
}

.tema-oscuro table {
    border-color: var(--border);
}

.tema-oscuro th {
    background: #2d3a5e;
    color: var(--text-primary);
}

.tema-oscuro td {
    border-bottom-color: var(--border);
    color: var(--text-secondary);
}

.tema-oscuro tr:nth-child(even) {
    background: #2d3748;
}

.tema-oscuro tr:hover {
    background: #374151;
}

.tema-oscuro .noticia {
    background: #2d3748;
    border-color: var(--border);
    border-left-color: var(--accent);
}

.tema-oscuro .noticia h3 {
    color: var(--text-primary);
}

.tema-oscuro .noticia p {
    color: var(--text-secondary);
}

.tema-oscuro .noticia-imagen{
    background: transparent;
    border-color: transparent;
}

.tema-oscuro .destacada-noticia {
    background: #374151 !important;
    border-color: #4b5563 !important;
}

.tema-oscuro .destacada-noticia label {
    color: #f3f4f6 !important;
}

/* MODO OSCURO - CALENDARIO CORREGIDO */
.tema-oscuro #calendar-widget {
  background: var(--card);
  border-color: var(--border);
}

.tema-oscuro .calendar-header {
  background: #0a0f1a;
}

.tema-oscuro .fc {
  background: var(--card) !important;
}

.tema-oscuro .fc .fc-toolbar-title {
  color: #f1f5f9 !important;  /* Color claro fijo */
}

.tema-oscuro .fc .fc-daygrid-day {
  background: var(--card) !important;
  border-color: var(--border);
}

.tema-oscuro .fc .fc-daygrid-day-number {
  color: #f1f5f9 !important;  /* Color claro fijo */
}

.tema-oscuro .fc .fc-day-today {
  background: #2d3a5e !important;
}

.tema-oscuro .fc .fc-day-today .fc-daygrid-day-number {
  color: #ffffff !important;
}

.tema-oscuro .fc .fc-day-other .fc-daygrid-day-number {
  color: #64748b !important;  /* Color más tenue para otros meses */
}

.tema-oscuro .fc .fc-col-header-cell-cushion {
  color: #f1f5f9 !important;
}

.tema-oscuro .fc .fc-daygrid-day:hover {
  background: #374151 !important;
}

.tema-oscuro .carpeta-titulo {
    background: #2d3748;
    color: var(--text-primary);
}

.tema-oscuro .carpeta-titulo:hover {
    background: #374151;
}

.tema-oscuro #lista-documentos a {
    color: var(--text-secondary);
    border-bottom-color: var(--border);
}

.tema-oscuro #lista-documentos a:hover {
    background: #2d3748;
}

.tema-oscuro .aviso-empresa {
    background: #b45309;
    color: #ffffff !important;
    border-bottom-color: #92400e;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.7);
}

.tema-oscuro p,
.tema-oscuro li,
.tema-oscuro ul,
.tema-oscuro .mensaje,
.tema-oscuro .texto-ayuda,
.tema-oscuro .instruccion {
    color: var(--text-primary) !important;
}

.tema-oscuro .stats-rapidas .stat-item {
    background: var(--card);
    border-color: var(--border);
}

.tema-oscuro .stat-txt {
    color: var(--text-secondary);
}

.tema-oscuro .tema-btn {
    background: var(--card);
    color: var(--text-primary);
    border: 1px solid var(--border);
    padding: 8px 15px;
    border-radius: 30px;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.3s ease;
}

.tema-oscuro .tema-btn:hover {
    background: var(--accent);
    color: white;
}

.tema-oscuro h3:not(.noticia h3):not(.carpeta-titulo) {
    color: var(--text-primary) !important;
}

/* Ajustes para el botón de tema en modo claro */
.tema-btn {
    background: rgba(255,255,255,0.2);
    color: white;
    border: 1px solid rgba(255,255,255,0.3);
    padding: 8px 20px;
    border-radius: 30px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.3s ease;
    position: relative;
    z-index: 101;
}

.tema-btn:hover {
    background: var(--accent);
    transform: scale(1.05);
}

header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 15px;
}

/* Ajuste del header para el botón de tema */
header {
    background: var(--primary);
    color: white;
    padding: 25px 40px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
}

header h1 {
    font-size: 24px;
    font-weight: 600;
    margin: 0;
}

.tema-btn {
    background: rgba(255,255,255,0.2);
    color: white;
    border: 1px solid rgba(255,255,255,0.3);
    padding: 8px 20px;
    border-radius: 30px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.3s ease;
}

.tema-btn:hover {
    background: white;
    color: var(--primary);
    border-color: white;
}

/* RESET PARA EL CALENDARIO - FUERZA BRUTA */
.fc .fc-daygrid-day-number {
  transition: color 0.2s ease, background 0.2s ease;
}

.tema-oscuro .fc .fc-daygrid-day-number {
  color: #f1f5f9 !important;
}

.fc .fc-daygrid-day-number {
  color: #0f172a !important;
}

i{
margin-right:6px;
}

.fa-folder{
color:#2563eb;
}

.fa-newspaper{
color:#2563eb;
}

.fa-users{
color:#2563eb;
}

.fa-star{
color:#f59e0b;
}

.header-derecha{
display:flex;
align-items:center;
gap:15px;
}

#fecha-hora{
font-size:14px;
opacity:0.9;
}

.notificaciones{
cursor:pointer;
position:relative;
font-size:18px;
}

#contadorNotificaciones{
background:red;
color:white;
border-radius:50%;
padding:2px 6px;
font-size:12px;
position:absolute;
top:-8px;
right:-12px;
}

.panel-notificaciones h3{
font-size:14px;
margin-bottom:8px;
}

.panel-notificaciones{
display:none;
position:absolute;
top:70px;
right:30px;
background:white;
color:black;
width:260px;
border-radius:8px;
box-shadow:0 10px 25px rgba(0,0,0,0.2);
padding:15px;
z-index:1000;
}

.panel-notificaciones ul{
list-style:none;
padding:0;
margin-top:10px;
}

.panel-notificaciones li{
border-bottom:1px solid #eee;
padding:8px 0;
font-size:13px;
}

/* MEJORAS PARA EL PANEL DE NOTIFICACIONES */
.panel-notificaciones h3 {
    font-size: 14px;
    margin-bottom: 10px;
    color: #1e293b;
}

.tema-oscuro .panel-notificaciones h3 {
    color: #f1f5f9;
}

.panel-notificaciones {
    position: absolute;
    top: 80px;
    right: 40px;
    background: white;
    color: #1e293b;
    width: 280px;
    border-radius: 8px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.15);
    padding: 15px;
    z-index: 1000;
    border: 1px solid var(--border);
}

.tema-oscuro .panel-notificaciones {
    background: #1e293b;
    color: #f1f5f9;
    border-color: #334155;
}

.panel-notificaciones ul {
    list-style: none;
    padding: 0;
    margin: 0;
    max-height: 300px;
    overflow-y: auto;
}

.panel-notificaciones li {
    padding: 10px 0;
    border-bottom: 1px solid #e2e8f0;
    font-size: 13px;
}

.tema-oscuro .panel-notificaciones li {
    border-bottom-color: #334155;
}

.panel-notificaciones li:last-child {
    border-bottom: none;
}

.panel-notificaciones small {
    color: #64748b;
    display: block;
    margin-top: 4px;
}

.tema-oscuro .panel-notificaciones small {
    color: #94a3b8;
}

/* ESTILO PARA EL CALENDARIO MINIMIZADO */
#calendar-widget.collapsed #calendar {
    display: none;
}

#calendar-widget.collapsed {
    height: auto !important;
    min-height: auto;
}

/* ====================== */
/* CORRECCIÓN URGENTE PARA EL CONTADOR DE NOTIFICACIONES */
/* ====================== */

#contadorNotificaciones {
    background: red !important;
    color: white !important;
    border-radius: 50% !important;
    padding: 2px 6px !important;
    font-size: 12px !important;
    position: absolute !important;
    top: -8px !important;
    right: -12px !important;
    min-width: 18px !important;
    height: 18px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
    z-index: 1000 !important;
    font-weight: bold !important;
    box-shadow: 0 0 0 1px white !important;
}

.tema-oscuro #contadorNotificaciones {
    background: #ef4444 !important;
    color: white !important;
    box-shadow: 0 0 0 1px #1e293b !important;
}

/* Asegurar que el contador sea visible */
.notificaciones {
    position: relative !important;
    display: inline-block !important;
}

/* Forzar visibilidad del número */
#contadorNotificaciones:empty {
    display: none !important;
}

#contadorNotificaciones:not(:empty) {
    display: flex !important;
}

/* ====================== */
/* ESTILOS PARA NOTIFICACIONES NUEVAS */
/* ====================== */

.notificacion-nueva {
    background-color: #f0f7ff !important;
    border-left: 4px solid #2563eb !important;
    padding-left: 12px !important;
    border-radius: 4px !important;
    transition: all 0.3s ease !important;
}

.tema-oscuro .notificacion-nueva {
    background-color: #1e3a5f !important;
    border-left-color: #3b82f6 !important;
}

.nueva-badge {
    display: inline-block !important;
    background-color: #ef4444 !important;
    color: white !important;
    font-size: 10px !important;
    font-weight: bold !important;
    padding: 2px 6px !important;
    border-radius: 12px !important;
    margin-left: 8px !important;
    letter-spacing: 0.5px !important;
    animation: pulse 2s infinite !important;
}

.tema-oscuro .nueva-badge {
    background-color: #dc2626 !important;
}

@keyframes pulse {
    0% {
        opacity: 1;
    }
    50% {
        opacity: 0.7;
    }
    100% {
        opacity: 1;
    }
}

/* Efecto hover para notificaciones nuevas */
.notificacion-nueva:hover {
    background-color: #e6f0ff !important;
    transform: translateX(5px) !important;
}

.tema-oscuro .notificacion-nueva:hover {
    background-color: #2d4b6e !important;
}

/* ====================== */
/* BOTÓN DE BORRAR DATOS - ESTILOS DE PELIGRO */
/* ====================== */

.btn-peligro {
    background-color: #dc3545 !important;
    color: white !important;
    border: none !important;
    padding: 10px 20px !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    margin: 20px 40px !important;
    opacity: 0.7 !important;
    transition: all 0.3s ease !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    box-shadow: 0 2px 5px rgba(220, 53, 69, 0.3) !important;
}

.btn-peligro i {
    font-size: 16px !important;
}

.btn-peligro:hover {
    opacity: 1 !important;
    background-color: #c82333 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 10px rgba(220, 53, 69, 0.5) !important;
}

.btn-peligro:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 5px rgba(220, 53, 69, 0.3) !important;
}

/* Botón Exportar contactos: MISMA posición/layout que btn-peligro */
.btn-export-contactos-blue{
    background-color: #2563eb !important;
}

.btn-export-contactos-blue:hover{
    background-color: #1d4ed8 !important;
}

.tema-oscuro .btn-export-contactos-blue{
    background-color: #2563eb !important;
}

.tema-oscuro .btn-export-contactos-blue:hover{
    background-color: #1d4ed8 !important;
}

/* Estilo para modo oscuro */
.tema-oscuro .btn-peligro {
    background-color: #b02a37 !important;
    box-shadow: 0 2px 5px rgba(176, 42, 55, 0.5) !important;
}

.tema-oscuro .btn-peligro:hover {
    background-color: #dc3545 !important;
}

/* ====================== */
/* MEJORAS ESTÉTICAS - HEADER CON ICONOS */
/* ====================== */

.logo-container {
    display: flex;
    align-items: center;
    gap: 12px;
}

.logo-container i {
    font-size: 28px;
    color: #fbbf24;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
}

.logo-container h1 {
    font-size: 28px;
    font-weight: 600;
    margin: 0;
    background: linear-gradient(135deg, #ffffff 0%, #e0e7ff 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.version-badge {
    background: rgba(255,255,255,0.15);
    padding: 4px 8px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.5px;
    border: 1px solid rgba(255,255,255,0.3);
    backdrop-filter: blur(5px);
}

.fecha-container {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,0.1);
    padding: 6px 12px;
    border-radius: 30px;
    border: 1px solid rgba(255,255,255,0.2);
}

.fecha-container i {
    font-size: 14px;
    color: #fbbf24;
}

#fecha-hora {
    font-size: 14px;
    font-weight: 500;
}

.tema-btn i {
    margin-right: 6px;
    font-size: 14px;
}

.notificaciones i {
    font-size: 20px;
    transition: transform 0.2s ease;
}

.notificaciones:hover i {
    transform: scale(1.1);
}

.panel-notificaciones h3 i {
    margin-right: 8px;
    color: #fbbf24;
}

/* Efecto de brillo en el logo */
@keyframes glow {
    0% {
        filter: drop-shadow(0 2px 4px rgba(251, 191, 36, 0.3));
    }
    50% {
        filter: drop-shadow(0 4px 8px rgba(251, 191, 36, 0.6));
    }
    100% {
        filter: drop-shadow(0 2px 4px rgba(251, 191, 36, 0.3));
    }
}

.logo-container i {
    animation: glow 3s infinite ease-in-out;
}

/* Estilos para modo oscuro */
.tema-oscuro .logo-container h1 {
    background: linear-gradient(135deg, #f1f5f9 0%, #a5b4fc 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.tema-oscuro .fecha-container {
    background: rgba(0,0,0,0.3);
    border-color: rgba(255,255,255,0.1);
}

.tema-oscuro .version-badge {
    background: rgba(0,0,0,0.3);
    border-color: rgba(255,255,255,0.1);
}

/* Responsive */
@media (max-width: 768px) {
    .logo-container {
        width: 100%;
        justify-content: center;
    }
    
    .version-badge {
        display: none;
    }
    
    .fecha-container {
        background: transparent;
        border: none;
        padding: 0;
    }
    
    .fecha-container i {
        display: none;
    }
}

@media (max-width: 480px) {
    .logo-container h1 {
        font-size: 22px;
    }
    
    .logo-container i {
        font-size: 22px;
    }
}

/* ====================== */
/* SECCIÓN AVISO DE EMPRESA MEJORADA */
/* ====================== */

.aviso-mejorado {
    background: var(--card);
    margin: 20px 40px;
    padding: 25px 30px;
    border-radius: 16px;
    border: 1px solid var(--border);
    position: relative;
    overflow: hidden;
}

.aviso-mejorado::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: #2563eb;
    background-size: 200% 100%;
    animation: gradientMove 3s linear infinite;
}

@keyframes gradientMove {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

.aviso-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.aviso-header i {
    font-size: 28px;
    color: #2563eb;
    animation: bellShake 3s infinite ease-in-out;
}

@keyframes bellShake {
    0%, 100% { transform: rotate(0); }
    5% { transform: rotate(15deg); }
    10% { transform: rotate(-15deg); }
    15% { transform: rotate(7deg); }
    20% { transform: rotate(-7deg); }
    25% { transform: rotate(0); }
}

.aviso-header h3 {
    font-size: 20px;
    font-weight: 600;
    color: var(--primary);
    margin: 0;
    flex: 1;
}

.aviso-badge {
    background: #2563eb;
    color: white;
    padding: 4px 12px;
    border-radius: 30px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.aviso-input-group {
    display: flex;
    gap: 12px;
    align-items: center;
    background: #f8fafc;
    border-radius: 50px;
    padding: 4px;
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.aviso-input-group:focus-within {
    border-color: #2563eb;
    background: white;
}

.input-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 45px;
    height: 45px;
    background: #2563eb;
    border-radius: 50%;
    color: white;
    font-size: 18px;
}

.aviso-input-group input {
    flex: 1;
    border: none;
    background: transparent;
    padding: 12px 5px;
    font-size: 15px;
    color: var(--primary);
}

.aviso-input-group input:focus {
    outline: none;
    box-shadow: none;
}

.aviso-input-group input::placeholder {
    color: #94a3b8;
    font-style: italic;
}

.btn-aviso {
    background: #2563eb;
    color: white;
    border: none;
    padding: 10px 25px;
    border-radius: 40px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s ease;
}

.btn-aviso:hover {
    transform: translateY(-2px);
}

.btn-aviso:active {
    transform: translateY(0);
}

/* Botón Ocultar/Mostrar comentario (moderación) */
.btn-comentario-toggle{
    background: var(--accent);
    color: #ffffff;
    border: none;
    border-radius: 4px;
    padding: 6px 10px;
    cursor: pointer;
    transition: background-color 0.15s ease, transform 0.05s ease;
}

.btn-comentario-toggle:hover{
    background: #dc2626; /* rojo como botones de eliminar/peligro */
}

.btn-comentario-toggle:active{
    background: #b91c1c;
}

.btn-aviso i {
    font-size: 14px;
    transition: transform 0.3s ease;
}

.btn-aviso:hover i {
    transform: translateX(3px);
}

.aviso-preview {
    margin-top: 20px;
    padding: 15px 20px;
    background: #f0f9ff;
    border-radius: 12px;
    border-left: 4px solid #2563eb;
    animation: slideDown 0.3s ease;
}

.preview-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
    color: #0369a1;
    font-size: 13px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.preview-header i {
    font-size: 14px;
    color: #2563eb;
}

.preview-content {
    display: flex;
    align-items: center;
    gap: 15px;
    color: var(--primary);
    font-size: 16px;
    line-height: 1.5;
    padding: 5px 0;
}

.preview-content i {
    color: #2563eb;
    font-size: 16px;
    opacity: 0.5;
}

.preview-content i:first-child {
    align-self: flex-start;
}

.preview-content i:last-child {
    align-self: flex-end;
}

.preview-content span {
    flex: 1;
    font-style: italic;
    font-weight: 500;
}

/* Estilos para modo oscuro */
.tema-oscuro .aviso-mejorado {
    background: #1e293b;
    border-color: #334155;
}

.tema-oscuro .aviso-header h3 {
    color: #f1f5f9;
}

.tema-oscuro .aviso-input-group {
    background: #0f172a;
}

.tema-oscuro .aviso-input-group input {
    color: #f1f5f9;
}

.tema-oscuro .aviso-input-group input::placeholder {
    color: #64748b;
}

.tema-oscuro .aviso-preview {
    background: #1e3a5f;
    border-left-color: #2563eb;
}

.tema-oscuro .preview-content {
    color: #f1f5f9;
}

/* Responsive */
@media (max-width: 768px) {
    .aviso-mejorado {
        margin: 20px;
        padding: 20px;
    }
    
    .aviso-input-group {
        flex-direction: column;
        background: transparent;
        padding: 0;
        gap: 10px;
    }
    
    .aviso-input-group:focus-within {
        border-color: transparent;
        box-shadow: none;
    }
    
    .input-icon {
        display: none;
    }
    
    .aviso-input-group input {
        width: 100%;
        background: #f8fafc;
        border-radius: 50px;
        padding: 15px 20px;
    }
    
    .tema-oscuro .aviso-input-group input {
        background: #0f172a;
    }
    
    .btn-aviso {
        width: 100%;
        justify-content: center;
    }
    
    .preview-content {
        flex-direction: column;
        text-align: center;
        gap: 10px;
    }
}

/* ====================== */
/* CALENDARIO EN LA BARRA DE NAVEGACIÓN - VERSIÓN DESPLEGABLE */
/* ====================== */

nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: white;
    padding: 10px 40px;
    border-bottom: 1px solid var(--border);
    position: relative;
    z-index: 50;
}

.nav-left {
    display: flex;
    align-items: center;
    gap: 25px;
    flex-wrap: wrap;
}

/* Estilos para el calendario dentro del nav */
.calendar-in-nav {
    position: relative !important;  /* Para posicionar el contenido desplegable */
    width: 320px !important;        /* Un poco más compacto */
    margin: 0 !important;
    background: #f8fafc;
    border-radius: 8px;
    border: 1px solid var(--border);
    overflow: visible !important;   /* Importante para que el contenido se vea fuera */
    z-index: 100;
}

/* Header del calendario - siempre visible */
.calendar-in-nav .calendar-header {
    background: var(--primary);
    color: white;
    padding: 8px 15px;
    font-size: 13px;
    font-weight: 500;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-radius: 8px 8px 0 0;
    cursor: pointer;  /* Indicador de que se puede hacer clic */
    transition: background 0.2s ease;
}

.calendar-in-nav .calendar-header:hover {
    background: #1e40af; /* Versión más oscura del primary */
}

.calendar-in-nav .calendar-header button {
    background: rgba(255,255,255,0.2);
    color: white;
    padding: 2px 8px;
    font-size: 12px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s ease;
    width: 28px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.calendar-in-nav .calendar-header button:hover {
    background: rgba(255,255,255,0.3);
}

/* Contenido del calendario - desplegable */
.calendar-in-nav .calendar-content {
    position: absolute;
    top: 100%;  /* Justo debajo del header */
    left: 0;
    right: 0;
    background: white;
    border: 1px solid var(--border);
    border-top: none;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
    padding: 10px;
    display: none;  /* Oculto por defecto */
    z-index: 1000;
    max-height: 400px;
    overflow-y: auto;
}

/* Cuando está expandido */
.calendar-in-nav.expanded .calendar-content {
    display: block;
}

.calendar-in-nav.expanded .calendar-header {
    border-radius: 8px 8px 0 0;
}

.calendar-in-nav.expanded .calendar-header button {
    transform: rotate(180deg);
}

/* Hacer el calendario más pequeño */
.calendar-in-nav .fc {
    font-size: 11px !important;
    background: white !important;
}

.calendar-in-nav .fc .fc-toolbar-title {
    font-size: 13px !important;
}

.calendar-in-nav .fc .fc-daygrid-day-number {
    font-size: 10px !important;
    padding: 2px !important;
}

.calendar-in-nav .fc .fc-daygrid-day-frame {
    min-height: 30px !important;
}

.calendar-in-nav .fc .fc-event {
    font-size: 9px !important;
    padding: 1px 2px !important;
}

/* Modo oscuro */
.tema-oscuro .calendar-in-nav {
    background: #1e293b;
    border-color: #334155;
}

.tema-oscuro .calendar-in-nav .calendar-header {
    background: #0a0f1a;
}

.tema-oscuro .calendar-in-nav .calendar-header:hover {
    background: #1e293b;
}

.tema-oscuro .calendar-in-nav .calendar-content {
    background: #1e293b;
    border-color: #334155;
}

.tema-oscuro .calendar-in-nav .fc {
    background: #1e293b !important;
}

.tema-oscuro .calendar-in-nav .fc .fc-daygrid-day-number {
    color: #f1f5f9 !important;
}

/* Responsive */
@media (max-width: 1000px) {
    nav {
        flex-direction: column;
        gap: 15px;
        padding: 15px 20px;
    }
    
    .nav-left {
        justify-content: center;
        width: 100%;
    }
    
    .calendar-in-nav {
        width: 100% !important;
        max-width: 400px;
    }
    
    .calendar-in-nav .calendar-content {
        width: 100%;
    }
}

/* ====================== */
/* CORRECCIONES PARA EL CALENDARIO DESPLEGABLE */
/* ====================== */

.calendar-in-nav .calendar-content {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: white;
    border: 1px solid var(--border);
    border-top: none;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 10px 20px rgba(0,0,0,0.15);
    padding: 12px;
    display: none;
    z-index: 1000;
    min-height: 350px; /* Altura mínima para el calendario */
}

.calendar-in-nav.expanded .calendar-content {
    display: block;
}

/* Asegurar que el calendario de FullCalendar se vea correctamente */
.calendar-in-nav .fc {
    width: 100% !important;
    height: auto !important;
    min-height: 300px !important;
}

.calendar-in-nav .fc .fc-view-harness {
    height: auto !important;
    min-height: 250px !important;
}

.calendar-in-nav .fc .fc-daygrid-day-frame {
    min-height: 35px !important;
}

.calendar-in-nav .fc .fc-col-header-cell {
    padding: 4px 0 !important;
}

.calendar-in-nav .fc .fc-daygrid-day-number {
    font-size: 11px !important;
    padding: 4px !important;
}

/* Corregir el título del calendario */
.calendar-in-nav .fc .fc-toolbar-title {
    font-size: 14px !important;
    color: var(--primary) !important;
}

.tema-oscuro .calendar-in-nav .fc .fc-toolbar-title {
    color: #f1f5f9 !important;
}

.stats-rapidas {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin: 20px 40px;
}

.stat-card{
  background:white;
  padding:18px 20px;
  border-radius:10px;
  border:1px solid var(--border);
  box-shadow:0 4px 12px rgba(0,0,0,0.05);
  display:flex;
  align-items:center;
  gap:14px;
  transition:all 0.2s ease;
}

.stat-card:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 18px rgba(0,0,0,0.08);
}

.stat-card i {
    font-size: 32px;
    color: var(--accent);
}

.stat-info {
    display: flex;
    flex-direction: column;
}

.stat-num {
    font-size: 28px;
    font-weight: 700;
    color: var(--primary);
    line-height: 1.2;
}

.stat-txt {
    font-size: 14px;
    color: #64748b;
}

.tema-oscuro .stat-card {
    background: #1e293b;
}

.tema-oscuro .stat-num {
    color: #f1f5f9;
}

@media (max-width: 768px) {
    .stats-rapidas {
        grid-template-columns: repeat(2, 1fr);
        margin: 20px;
    }
}

/* ====================== */
/* BOTÓN DE TEMA ÚNICO */
/* ====================== */

.tema-toggle {
    background: rgba(255,255,255,0.2);
    color: white;
    border: 1px solid rgba(255,255,255,0.3);
    padding: 8px 18px;
    border-radius: 30px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.tema-toggle i {
    font-size: 16px;
    margin-right: 0;
}

.tema-toggle:hover {
    background: var(--accent);
    transform: scale(1.02);
}

/* Estilo del botón en modo oscuro */
.tema-oscuro .tema-toggle {
    background: #2d3748;
    color: #f1f5f9;
    border-color: #4a5568;
}

.tema-oscuro .tema-toggle:hover {
    background: var(--accent);
}

#noticias,
#documentos,
#directorio{
  margin-top:50px;
}

/* ====================== */
/* BOTÓN DE ELIMINAR AVISO */
/* ====================== */

.btn-eliminar {
    background: #dc3545 !important;
}

.btn-eliminar:hover {
    background: #c82333 !important;
    transform: translateY(-2px);
}

/* Ajuste para el grupo de botones */
.aviso-input-group {
    display: flex;
    gap: 8px;
    align-items: center;
    background: #f8fafc;
    border-radius: 50px;
    padding: 4px;
    border: 2px solid transparent;
    transition: all 0.3s ease;
    flex-wrap: wrap;
}

.aviso-input-group .btn-aviso {
    white-space: nowrap;
}

/* Responsive */
@media (max-width: 768px) {
    .aviso-input-group {
        flex-direction: column;
        width: 100%;
    }
    
    .aviso-input-group .btn-aviso {
        width: 100%;
        justify-content: center;
    }
}

.logo-container{
    display: flex;
    align-items: center;
    gap: 10px;
}

header a.logo-container {
    text-decoration: none;
    color: inherit;
}

.logo-empresa {
    height: 40px !important;
    width: auto !important;
    max-width: 200px; /* opcional: límite máximo */
}

.logout-btn{
background:#ef4444;
color:white;
border:none;
padding:8px 12px;
border-radius:6px;
cursor:pointer;
font-size:14px;
margin-left: 15px;
}

.logout-btn:hover{
background:#dc2626;
}

/* ====================== */
/* TABLA DE CONTACTOS - VERSIÓN ADAPTABLE */
/* ====================== */

#tabla-contactos {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
    margin-top: 15px;
}

#tabla-contactos th {
    background: var(--secondary);
    color: white;
    text-align: left;
    padding: 12px;
}

#tabla-contactos td {
    padding: 12px;
    border-bottom: 1px solid var(--border);
}

#tabla-contactos tr:nth-child(even) {
    background: #f8fafc;
}

#tabla-contactos tr:hover {
    background: #e0f2fe;
}

/* Estilos para modo oscuro */
.tema-oscuro #tabla-contactos tr:nth-child(even) {
    background: #2d3748;
}

.tema-oscuro #tabla-contactos tr:hover {
    background: #374151;
}

/* ====================== */
/* BOTÓN ELIMINAR CONTACTO (SOLO VISIBLE EN MODO EDICIÓN) */
/* ====================== */

.btn-eliminar-contacto {
    background-color: transparent !important;
    color: #dc3545 !important;
    border: none !important;
    padding: 5px 10px !important;
    border-radius: 4px !important;
    cursor: pointer !important;
    font-size: 16px !important;
    transition: all 0.2s ease !important;
    width: auto !important;
    min-width: 35px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.btn-eliminar-contacto:hover {
    background-color: #dc3545 !important;
    color: white !important;
    transform: scale(1.1) !important;
}

.btn-eliminar-contacto i {
    margin: 0 !important;
    font-size: 16px !important;
}

/* Estilo para modo oscuro */
.tema-oscuro .btn-eliminar-contacto {
    color: #ef4444 !important;
}

.tema-oscuro .btn-eliminar-contacto:hover {
    background-color: #ef4444 !important;
    color: #0f172a !important;
}

/* Ajuste responsive */
@media (max-width: 768px) {
    #tabla-contactos {
        font-size: 12px;
    }
    
    #tabla-contactos th,
    #tabla-contactos td {
        padding: 8px 5px;
    }
    
    .btn-eliminar-contacto {
        padding: 3px 6px !important;
        min-width: 30px !important;
        font-size: 14px !important;
    }
}

/* ====================== */
/* MODAL PARA EDITAR CONTACTOS */
/* ====================== */

.modal-contacto {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 10000;
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.modal-contenido {
    background: white;
    border-radius: 16px;
    width: 90%;
    max-width: 500px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    animation: slideUp 0.3s ease;
}

@keyframes slideUp {
    from { transform: translateY(30px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.modal-header {
    background: var(--accent);
    color: white;
    padding: 20px 25px;
    border-radius: 16px 16px 0 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: sticky;
    top: 0;
    z-index: 10;
}

.modal-header h3 {
    margin: 0;
    font-size: 20px;
    font-weight: 600;
    color: white !important;
}

.modal-header h3 i {
    margin-right: 10px;
    color: white;
}

.btn-cerrar-modal {
    background: rgba(255, 255, 255, 0.2) !important;
    color: white !important;
    border: none !important;
    font-size: 28px !important;
    cursor: pointer !important;
    padding: 0 !important;
    width: 36px !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    transition: all 0.2s ease !important;
}

.btn-cerrar-modal:hover {
    background: rgba(255, 255, 255, 0.3) !important;
    transform: rotate(90deg);
}

.modal-body {
    padding: 25px;
}

.campo-formulario {
    margin-bottom: 20px;
}

.campo-formulario label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: var(--primary);
    font-size: 14px;
}

.campo-formulario label i {
    margin-right: 8px;
    color: var(--accent);
    width: 18px;
}

.campo-formulario .label-checkbox-inline {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin: 0 !important;
}

#evento-all-day {
    width: auto !important;
    min-width: 16px !important;
    height: 16px !important;
    margin: 0 !important;
    flex: 0 0 auto !important;
}

.campo-formulario input {
    width: 100%;
    padding: 12px 15px;
    border: 2px solid var(--border);
    border-radius: 8px;
    font-size: 14px;
    transition: all 0.2s ease;
    background: white;
    color: var(--primary);
}

.campo-formulario input:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
    outline: none;
}

.modal-footer {
    padding: 20px 25px 20px 25px;
    border-top: 2px solid var(--border);
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    background: #f8fafc;
    border-radius: 0 0 16px 16px;
}

.modal-footer .btn-eliminar-evento {
    margin-right: 0 !important;
}

.btn-cancelar {
    background: #64748b !important;
    color: white !important;
    border: none !important;
    padding: 10px 20px !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.btn-cancelar:hover {
    background: #475569 !important;
    transform: translateY(-2px);
}

.btn-guardar {
    background: #10b981 !important;
    color: white !important;
    border: none !important;
    padding: 10px 25px !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    transition: all 0.2s ease !important;
}

.btn-guardar:hover {
    background: #059669 !important;
    transform: translateY(-2px);
}

.btn-eliminar-evento {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px 16px !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}
.btn-eliminar-evento:hover {
    filter: brightness(1.1);
    transform: translateY(-2px);
}

.btn-guardar i {
    font-size: 16px;
}

/* ====================== */
/* BOTÓN EDITAR CONTACTO */
/* ====================== */

.btn-editar-contacto {
    background-color: transparent !important;
    color: #10b981 !important;
    border: none !important;
    padding: 5px 8px !important;
    border-radius: 4px !important;
    cursor: pointer !important;
    font-size: 16px !important;
    transition: all 0.2s ease !important;
    width: auto !important;
    min-width: 35px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-right: 5px !important;
}

.btn-editar-contacto:hover {
    background-color: #10b981 !important;
    color: white !important;
    transform: scale(1.1) !important;
}

.btn-editar-contacto i {
    margin: 0 !important;
    font-size: 16px !important;
}

/* Estilo para modo oscuro */
.tema-oscuro .btn-editar-contacto {
    color: #34d399 !important;
}

.tema-oscuro .btn-editar-contacto:hover {
    background-color: #34d399 !important;
    color: #0f172a !important;
}

.tema-oscuro .modal-contenido {
    background: #1e293b;
}

.tema-oscuro .campo-formulario label {
    color: #f1f5f9;
}

.tema-oscuro .campo-formulario input {
    background: #334155;
    border-color: #475569;
    color: #f1f5f9;
}

.tema-oscuro .campo-formulario input:focus {
    border-color: #3b82f6;
}

.tema-oscuro .modal-footer {
    background: #0f172a;
    border-top-color: #334155;
}

/* Responsive */
@media (max-width: 768px) {
    .modal-contenido {
        width: 95%;
        margin: 20px;
    }
    
    .modal-header {
        padding: 15px 20px;
    }
    
    .modal-body {
        padding: 20px;
    }
    
    .modal-footer {
        padding: 15px 20px;
        flex-direction: column;
    }
    
    .btn-cancelar,
    .btn-guardar {
        width: 100%;
        justify-content: center;
    }
    
    .btn-editar-contacto,
    .btn-eliminar-contacto {
        padding: 5px !important;
        min-width: 32px !important;
    }
}

/* ====================== */
/* ESTILOS PARA DOCUMENTOS - CORREGIDOS */
/* ====================== */

#lista-documentos {
    margin-top: 20px;
    width: 100%;
}

.carpeta {
    margin-bottom: 15px;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    background: var(--card);
}

.carpeta-titulo {
    cursor: pointer;
    background: #f1f5f9;
    padding: 12px 15px;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 16px;
    font-weight: 600;
    color: var(--primary);
    transition: background 0.2s ease;
    border-bottom: 1px solid var(--border);
}

.carpeta-flecha {
    margin-left: 12px;
    font-size: 16px;
    color: #475569;
    flex-shrink: 0;
}

.carpeta-titulo:hover {
    background: #e2e8f0;
}

.carpeta-contenido {
    display: none;
    list-style: none;
    padding: 0;
    margin: 0;
    background: var(--card);
}

.carpeta-contenido.abierta {
    display: block;
}

.carpeta-contenido li {
    padding: 10px 15px;
    border-bottom: 1px solid var(--border);
    transition: background 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.carpeta-contenido li:last-child {
    border-bottom: none;
}

.carpeta-contenido li:hover {
    background: #f8fafc;
}

.carpeta-contenido a {
    text-decoration: none;
    color: var(--primary);
    font-size: 14px;
    display: inline-block;
    max-width: calc(100% - 40px);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.carpeta-contenido a:hover {
    color: var(--accent);
    text-decoration: underline;
}

/* Estilos para modo oscuro */
.tema-oscuro .carpeta {
    border-color: #334155;
}

.tema-oscuro .carpeta-titulo {
    background: #2d3748;
    color: #f1f5f9;
    border-bottom-color: #334155;
}

.tema-oscuro .carpeta-flecha {
    color: #cbd5e1;
}

.tema-oscuro .carpeta-titulo:hover {
    background: #374151;
}

.tema-oscuro .carpeta-contenido {
    background: #1e293b;
}

.tema-oscuro .carpeta-contenido li {
    border-bottom-color: #334155;
}

.tema-oscuro .carpeta-contenido li:hover {
    background: #2d3748;
}

.tema-oscuro .carpeta-contenido a {
    color: #f1f5f9;
}

/* ====================== */
/* BOTÓN ELIMINAR DOCUMENTO */
/* ====================== */

.btn-eliminar-documento {
    background-color: transparent !important;
    color: #dc3545 !important;
    border: 1px solid var(--border) !important;
    padding: 0 !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    font-size: 14px !important;
    transition: all 0.2s ease !important;
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-left: 0 !important;
    line-height: 1 !important;
}

.btn-eliminar-documento:hover {
    background-color: rgba(220, 53, 69, 0.12) !important;
    border-color: #dc3545 !important;
    color: #dc3545 !important;
    transform: none !important;
}

.btn-eliminar-documento i {
    margin: 0 !important;
    font-size: 14px !important;
}

/* Botón descargar documento: claro negro, oscuro blanco */
.btn-descargar-documento {
    color: #0f172a !important;
}

.btn-descargar-documento .icono-descarga-documento {
    margin: 0 !important;
    font-size: 15px !important;
    opacity: 1 !important;
}

body:not(.tema-oscuro) .btn-descargar-documento .icono-descarga-documento {
    color: #0f172a !important;
    -webkit-text-fill-color: #0f172a !important;
}

.tema-oscuro .btn-descargar-documento {
    color: #f8fafc !important;
}

body.tema-oscuro .btn-descargar-documento .icono-descarga-documento {
    color: #f8fafc !important;
    -webkit-text-fill-color: #f8fafc !important;
}

/* Estilo para modo oscuro */
.tema-oscuro .btn-eliminar-documento {
    color: #ef4444 !important;
}

.tema-oscuro .btn-eliminar-documento:hover {
    background-color: rgba(239, 68, 68, 0.16) !important;
    border-color: #ef4444 !important;
    color: #ef4444 !important;
}

/* Responsive */
@media (max-width: 768px) {
    .carpeta-titulo {
        padding: 10px 12px;
        font-size: 14px;
    }
    
    .carpeta-contenido li {
        padding: 8px 12px;
        font-size: 13px;
    }
    
    .btn-eliminar-documento {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
    }
}

/* ====================== */
/* CORRECCIÓN DE COLORES PARA DOCUMENTOS */
/* ====================== */

/* MODO CLARO (por defecto) - Texto NEGRO */
.carpeta-contenido a,
#lista-documentos a,
.carpeta-contenido li a,
a[href*="documentos/"] {
    color: #000000 !important;  /* NEGRO ABSOLUTO */
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: color 0.2s ease;
}

/* Hover en modo claro - Azul */
.carpeta-contenido a:hover,
#lista-documentos a:hover {
    color: #2563eb !important;  /* Azul al hacer hover */
    text-decoration: underline !important;
}

/* MODO OSCURO - Texto BLANCO */
.tema-oscuro .carpeta-contenido a,
.tema-oscuro #lista-documentos a,
.tema-oscuro .carpeta-contenido li a,
.tema-oscuro a[href*="documentos/"] {
    color: #ffffff !important;  /* BLANCO ABSOLUTO */
}

/* Hover en modo oscuro - Azul claro */
.tema-oscuro .carpeta-contenido a:hover,
.tema-oscuro #lista-documentos a:hover {
    color: #60a5fa !important;  /* Azul claro */
}

/* Asegurar que los iconos también se vean bien */
.carpeta-contenido a i,
#lista-documentos a i {
    color: inherit !important;
}

.sesame-logo{
height:22px;
margin-right:5px;
}

.sesame-btn{
    background:#22c55e;
    padding:8px;
    border-radius:8px;
    display:flex;
    align-items:center;
    justify-content:center;
    height:40px;
}

.sesame-btn:hover{
    background:#22c55e;
}

.sesame-btn img{
    height:30px;
    width:auto;
    object-fit:contain;
}

/* ====================== */
/* RESPONSIVE GLOBAL MÓVIL */
/* ====================== */
@media (max-width: 1024px) {
    header {
        padding: 16px 18px !important;
        gap: 10px !important;
    }

    nav {
        padding: 10px 12px !important;
    }

    section {
        margin: 14px 12px !important;
        padding: 16px !important;
        border-radius: 10px !important;
    }

    section:hover,
    .noticia:hover {
        transform: none !important;
    }
}

@media (max-width: 768px) {
    body {
        font-size: 14px;
    }

    header {
        flex-direction: column;
        align-items: stretch !important;
    }

    header h1 {
        font-size: 20px !important;
        text-align: center;
    }

    header a.logo-container {
        align-self: center;
    }

    .fecha-container,
    .tema-toggle,
    .logout-btn,
    .notificaciones {
        width: 100%;
        max-width: 100%;
        justify-content: center;
    }

    nav {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
    }

    .nav-left {
        display: flex !important;
        align-items: center;
        gap: 8px;
        width: max-content;
        min-width: 100%;
    }

    nav a {
        margin-right: 0 !important;
        padding: 8px 10px !important;
        border-radius: 8px;
        font-size: 13px !important;
        display: inline-flex;
        align-items: center;
        gap: 6px;
    }

    .sesame-btn {
        height: 36px;
        padding: 6px 10px;
    }

    input,
    textarea,
    select,
    button,
    .campo-formulario input,
    .campo-formulario select,
    .campo-formulario textarea {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }

    textarea {
        min-height: 90px;
    }

    .form-noticia,
    .aviso-input-group,
    .modal-body,
    .modal-footer {
        display: flex;
        flex-direction: column;
        gap: 10px;
    }

    .modal-contacto {
        padding: 10px !important;
    }

    .modal-contenido {
        width: 100% !important;
        max-width: 100% !important;
        border-radius: 10px !important;
    }

    .noticia {
        padding: 12px !important;
    }

    .noticia h3 {
        margin-right: 0 !important;
        font-size: 16px !important;
    }

    .noticia-imagen,
    .noticia-imagen img {
        max-height: 200px !important;
    }

    .modal-imagen-grande {
        padding: 8px !important;
    }

    .modal-imagen-grande img {
        max-width: 98vw !important;
        max-height: 85vh !important;
    }

    .btn-cerrar-imagen-grande {
        right: 10px !important;
        top: 8px !important;
    }

    .noticia-etiquetas {
        position: static !important;
        margin: 0 0 10px 0 !important;
        justify-content: flex-start !important;
        flex-wrap: wrap;
    }

    #lista-eventos {
        overflow-x: auto;
    }

    table {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
    }

    th,
    td {
        padding: 10px 8px !important;
        font-size: 13px !important;
    }

    /* Excepcion: no romper FullCalendar en zoom 100% */
    .fc table {
        display: table !important;
        width: 100% !important;
        overflow: visible !important;
        white-space: normal !important;
    }

    .fc th,
    .fc td {
        padding: 0 !important;
        font-size: 12px !important;
        white-space: normal !important;
    }

    .panel-notificaciones {
        width: calc(100vw - 16px) !important;
        right: 8px !important;
        left: 8px !important;
        max-height: 70vh;
    }
}

@media (max-width: 480px) {
    header {
        padding: 12px 10px !important;
    }

    nav {
        padding: 8px !important;
    }

    section {
        margin: 10px 8px !important;
        padding: 12px !important;
    }

    section h2 {
        font-size: 18px !important;
        margin-bottom: 14px !important;
    }

    .noticia-imagen,
    .noticia-imagen img {
        max-height: 170px !important;
    }

    button,
    .btn-peligro,
    .btn-export-contactos-blue,
    .btn-aviso,
    .logout-btn {
        padding: 10px 12px !important;
        font-size: 13px !important;
    }
}

/* ====================== */
/* REDISENO VISUAL PRO */
/* ====================== */

:root {
    --radius-sm: 10px;
    --radius-md: 16px;
    --radius-lg: 22px;
    --shadow-soft: 0 8px 28px rgba(15, 23, 42, 0.08);
    --shadow-strong: 0 18px 40px rgba(15, 23, 42, 0.14);
    --grad-primary: linear-gradient(135deg, #2563eb 0%, #4f46e5 100%);
    --grad-surface: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

body {
    background:
        radial-gradient(circle at 15% -10%, rgba(37, 99, 235, 0.14), transparent 36%),
        radial-gradient(circle at 90% 0%, rgba(79, 70, 229, 0.12), transparent 30%),
        var(--background);
    color: #0f172a;
}

header {
    background: linear-gradient(120deg, #0f172a 0%, #1e3a8a 58%, #2563eb 100%) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 14px 34px rgba(2, 6, 23, 0.3);
}

.logo-empresa {
    height: 46px !important;
    filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.32));
}

nav {
    background: rgba(255, 255, 255, 0.84) !important;
    border-bottom: 1px solid rgba(148, 163, 184, 0.35) !important;
    backdrop-filter: blur(10px);
    position: sticky;
    top: 0;
}

.nav-left a {
    border-radius: 999px;
    padding: 9px 14px;
    font-weight: 600;
    transition: all 0.25s ease;
}

.nav-left a:hover {
    background: #eff6ff;
    color: #1d4ed8;
    transform: translateY(-1px);
}

section,
.aviso-mejorado {
    background: var(--grad-surface) !important;
    border-radius: var(--radius-lg) !important;
    border: 1px solid #dbe7ff !important;
    box-shadow: var(--shadow-soft) !important;
}

section:hover {
    box-shadow: var(--shadow-strong) !important;
}

section h2 {
    font-size: 24px;
    border-left: none !important;
    padding-left: 0 !important;
    position: relative;
}

section h2::after {
    content: "";
    display: block;
    width: 72px;
    height: 4px;
    margin-top: 9px;
    border-radius: 999px;
    background: var(--grad-primary);
}


input,
textarea,
select {
    border: 1px solid #cfdcf5 !important;
    border-radius: var(--radius-sm) !important;
    background: #ffffff !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}

input:focus,
textarea:focus,
select:focus {
    border-color: #2563eb !important;
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.14) !important;
    transform: translateY(-1px);
}

button {
    border-radius: 12px !important;
    font-weight: 600;
    letter-spacing: 0.2px;
    box-shadow: 0 8px 18px rgba(37, 99, 235, 0.22);
}

button:hover {
    transform: translateY(-2px);
    filter: brightness(1.03);
}

#agregar-noticia,
#agregar-documento,
#agregar-contacto,
.btn-aviso,
.tema-toggle {
    background: var(--grad-primary) !important;
    color: #fff !important;
}

.logout-btn,
.btn-peligro,
.btn-eliminar {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
    box-shadow: 0 10px 20px rgba(239, 68, 68, 0.28) !important;
}

.noticia {
    border: 1px solid #dbe7ff;
    border-left: 5px solid #2563eb;
    border-radius: var(--radius-md);
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.07);
}

.noticia h3 {
    font-size: 20px;
}

.noticia-etiquetas span {
    background: linear-gradient(135deg, #2563eb 0%, #4f46e5 100%);
    box-shadow: 0 5px 12px rgba(37, 99, 235, 0.22);
}

#tabla-contactos {
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid #dbe7ff;
}

#tabla-contactos th {
    background: linear-gradient(135deg, #1e3a8a 0%, #2563eb 100%) !important;
}

#tabla-contactos tr:hover {
    background: #eef4ff !important;
}

.panel-notificaciones {
    border-radius: 14px !important;
    border: 1px solid #dbe7ff !important;
    box-shadow: 0 16px 40px rgba(2, 6, 23, 0.2) !important;
}

.aviso-empresa {
    border-radius: 14px !important;
    background: #ea580c !important;
    box-shadow: 0 10px 26px rgba(37, 99, 235, 0.3);
}

.sesame-btn {
    background: linear-gradient(135deg, #16a34a 0%, #22c55e 100%);
    box-shadow: 0 10px 20px rgba(34, 197, 94, 0.3);
}

.nav-left .sesame-btn {
    background: linear-gradient(135deg, #16a34a 0%, #22c55e 100%) !important;
    border-color: rgba(34, 197, 94, 0.55) !important;
    box-shadow: 0 10px 20px rgba(34, 197, 94, 0.3) !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, filter 0.25s ease, background 0.25s ease !important;
}

.nav-left .sesame-btn:hover {
    background: linear-gradient(135deg, #15803d 0%, #16a34a 55%, #22c55e 100%) !important;
    box-shadow: 0 14px 28px rgba(22, 163, 74, 0.45) !important;
    transform: translateY(-1px);
    filter: brightness(1.05);
}

.nav-left .sesame-btn:active {
    transform: translateY(0);
    filter: brightness(0.98);
    box-shadow: 0 8px 16px rgba(34, 197, 94, 0.28) !important;
}

.tema-oscuro .nav-left .sesame-btn {
    background: linear-gradient(135deg, #16a34a 0%, #22c55e 100%) !important;
    border-color: rgba(34, 197, 94, 0.55) !important;
    color: #111827 !important;
}

.tema-oscuro .nav-left .sesame-btn:hover {
    background: linear-gradient(135deg, #15803d 0%, #16a34a 55%, #22c55e 100%) !important;
    border-color: rgba(74, 222, 128, 0.65) !important;
    color: #f8fafc !important;
    box-shadow: 0 14px 30px rgba(34, 197, 94, 0.38) !important;
    transform: translateY(-1px);
    filter: brightness(1.06);
}

/* Noticias en viñeta: limitar tamaño máximo de imágenes */
.noticia .noticia-imagen {
    max-height: 170px !important;
}

.noticia .noticia-imagen img {
    max-height: 170px !important;
    width: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
}


/* Flechas visibles en recuadros plegables/desplegables */
.carpeta-titulo,
.carpeta-header {
    position: relative;
}

.carpeta-flecha {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-width: 16px;
    font-size: 12px !important;
    font-weight: 600;
    color: #1d4ed8 !important;
    margin-left: 8px;
    line-height: 1;
    text-shadow: 0 0 1px rgba(29, 78, 216, 0.2);
}

.tema-oscuro .carpeta-flecha {
    color: #93c5fd !important;
    text-shadow: none;
}

/* Menus desplegables: una sola flecha, separada del borde derecho */
select,
.select-filtro-noticias,
.controles-directorio select,
.buscador-documentos select {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    padding-right: 44px !important;
    background: #ffffff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%231e3a8a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 18px center / 14px 14px !important;
}

.tema-oscuro select,
.tema-oscuro .select-filtro-noticias,
.tema-oscuro .controles-directorio select,
.tema-oscuro .buscador-documentos select {
    background: #223044 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%23dbeafe' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 18px center / 14px 14px !important;
}

.tema-oscuro body {
    background:
        radial-gradient(circle at 12% -10%, rgba(59, 130, 246, 0.18), transparent 34%),
        radial-gradient(circle at 86% -5%, rgba(99, 102, 241, 0.14), transparent 30%),
        var(--background);
}

.tema-oscuro nav {
    background: rgba(30, 41, 59, 0.82) !important;
    border-bottom-color: rgba(71, 85, 105, 0.8) !important;
}

.tema-oscuro .nav-left a:hover {
    background: #334155;
}

.tema-oscuro section,
.tema-oscuro .aviso-mejorado {
    background: linear-gradient(180deg, #1e293b 0%, #172131 100%) !important;
    border-color: #334155 !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.32) !important;
}

.tema-oscuro input,
.tema-oscuro textarea,
.tema-oscuro select {
    background: #223044 !important;
    border-color: #3f4f66 !important;
}

.tema-oscuro #tabla-contactos tr:hover {
    background: #334155 !important;
}

@keyframes avisoPulsoAzul {
    0% {
        background-position: 0% 50%;
        box-shadow: 0 10px 24px rgba(251, 146, 60, 0.24) !important;
        transform: scale(1);
    }
    100% {
        background-position: 100% 50%;
        box-shadow: 0 18px 38px rgba(194, 65, 12, 0.42) !important;
        transform: scale(1.012);
    }
}

/* Aviso publicado superior (solo visual) */
.aviso-empresa {
    width: min(700px, calc(100% - 300px)) !important;
    margin: 28px auto !important;
    padding: 16px 22px !important;
    border-radius: 14px !important;
    border: 2px solid rgba(251, 191, 36, 0.95) !important;
    background: #ea580c !important;
    background-size: 220% 220% !important;
    color: #ffffff !important;
    font-size: 19px !important;
    font-weight: 700 !important;
    letter-spacing: 0.35px !important;
    text-shadow: none !important;
    box-shadow: 0 14px 34px rgba(234, 88, 12, 0.34) !important;
    animation: avisoPulsoAzul 1.35s ease-in-out infinite alternate !important;
    position: relative;
    z-index: 3;
}

.tema-oscuro .aviso-empresa {
    border-color: rgba(251, 191, 36, 0.85) !important;
    background: #ea580c !important;
    background-size: 220% 220% !important;
    box-shadow: 0 16px 36px rgba(194, 65, 12, 0.36) !important;
}

/* Separación uniforme alrededor del aviso (arriba/abajo) en lectura y edición. */
#avisoEmpresa:not(:empty) + .aviso-mejorado {
    margin-top: 18px !important;
}

#avisoEmpresa:not(:empty) + .layout-con-sidebar-wrapper > main > section:first-child,
#avisoEmpresa:not(:empty) + .layout-con-sidebar-wrapper > section:first-child,
#avisoEmpresa:not(:empty) + main > section:first-child,
#avisoEmpresa:not(:empty) + section {
    margin-top: 18px !important;
}

#avisoEmpresa:not(:empty) + .layout-con-sidebar-wrapper > .calendar-sidebar-columna {
    margin-top: 18px !important;
}

/* Noticias en modo lectura: .aviso-mejorado queda oculto y el siguiente bloque
   es .layout-con-sidebar-wrapper; igualamos también esta separación. */
#avisoEmpresa:not(:empty) + .aviso-mejorado[style*="display: none"] + .layout-con-sidebar-wrapper > main > section:first-child,
#avisoEmpresa:not(:empty) + .aviso-mejorado[style*="display: none"] + .layout-con-sidebar-wrapper > section:first-child,
#avisoEmpresa:not(:empty) + .aviso-mejorado[style*="display: none"] + .layout-con-sidebar-wrapper > .calendar-sidebar-columna {
    margin-top: 18px !important;
}

/* Si no hay aviso publicado, el banner está oculto (:empty); damos aire bajo el nav. */
#avisoEmpresa:empty + .layout-con-sidebar-wrapper,
#avisoEmpresa:empty + .aviso-mejorado,
#avisoEmpresa:empty + main,
#avisoEmpresa:empty + section {
    margin-top: 28px !important;
}

@media (max-width: 768px) {
    #avisoEmpresa:not(:empty) + .aviso-mejorado {
        margin-top: 14px !important;
    }

    #avisoEmpresa:not(:empty) + .layout-con-sidebar-wrapper > main > section:first-child,
    #avisoEmpresa:not(:empty) + .layout-con-sidebar-wrapper > section:first-child,
    #avisoEmpresa:not(:empty) + main > section:first-child,
    #avisoEmpresa:not(:empty) + section {
        margin-top: 14px !important;
    }

    #avisoEmpresa:not(:empty) + .layout-con-sidebar-wrapper > .calendar-sidebar-columna {
        margin-top: 14px !important;
    }

    #avisoEmpresa:not(:empty) + .aviso-mejorado[style*="display: none"] + .layout-con-sidebar-wrapper > main > section:first-child,
    #avisoEmpresa:not(:empty) + .aviso-mejorado[style*="display: none"] + .layout-con-sidebar-wrapper > section:first-child,
    #avisoEmpresa:not(:empty) + .aviso-mejorado[style*="display: none"] + .layout-con-sidebar-wrapper > .calendar-sidebar-columna {
        margin-top: 14px !important;
    }
}

/* ====================== */
/* MENUS DE EDICION PRO */
/* ====================== */

/* Bloques de creacion en paginas dedicadas */
#bloque-crear-noticia,
#bloque-crear-documento,
#bloque-crear-directorio {
    margin-top: 18px;
    padding: 20px;
    border-radius: 16px;
    border: 1px solid #d5e3fb;
    background: linear-gradient(180deg, #ffffff 0%, #f5f9ff 100%);
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

/* Titulos de menu de edicion */
#bloque-crear-noticia h3,
#bloque-crear-documento h3,
#bloque-crear-directorio h3,
#noticias h3,
#documentos h3,
#directorio h3 {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 12px;
    color: #0f172a;
    letter-spacing: 0.2px;
}

/* Inputs de edicion */
#bloque-crear-noticia input,
#bloque-crear-noticia textarea,
#bloque-crear-documento input,
#bloque-crear-documento select,
#bloque-crear-directorio input,
#noticias .form-noticia input,
#noticias .form-noticia textarea {
    border: 1px solid #cfe0fb !important;
    border-radius: 12px !important;
    background: #ffffff !important;
}

#bloque-crear-noticia input:focus,
#bloque-crear-noticia textarea:focus,
#bloque-crear-documento input:focus,
#bloque-crear-documento select:focus,
#bloque-crear-directorio input:focus,
#noticias .form-noticia input:focus,
#noticias .form-noticia textarea:focus {
    border-color: #2563eb !important;
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12) !important;
}

/* Flecha en desplegables de edicion */
#documentos select,
#bloque-crear-documento select {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    padding-right: 44px !important;
    background: #ffffff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%231e3a8a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 18px center / 14px 14px !important;
}

.tema-oscuro #documentos select,
.tema-oscuro #bloque-crear-documento select {
    background: #223044 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%23dbeafe' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 18px center / 14px 14px !important;
}

/* Flecha en selects de modales (crear/editar evento) */
.modal-contacto select,
#modalEvento select {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    padding-right: 44px !important;
    background: #ffffff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%231e3a8a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 16px center / 14px 14px !important;
}

.tema-oscuro .modal-contacto select,
.tema-oscuro #modalEvento select {
    background: #223044 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%23dbeafe' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 16px center / 14px 14px !important;
}

/* Botones principales de edicion */
#agregar-noticia,
#agregar-documento,
#agregar-contacto {
    background: linear-gradient(135deg, #2563eb 0%, #4f46e5 100%) !important;
    border: none !important;
    border-radius: 12px !important;
    font-weight: 700;
    box-shadow: 0 10px 20px rgba(37, 99, 235, 0.24);
}

#agregar-noticia:hover,
#agregar-documento:hover,
#agregar-contacto:hover {
    transform: translateY(-2px);
    filter: brightness(1.03);
}

/* Panel de destacada mas limpio */
.destacada-noticia {
    border: 1px solid #dbe7ff !important;
    background: #f3f8ff !important;
    border-radius: 12px !important;
}

/* Modo oscuro */
.tema-oscuro #bloque-crear-noticia,
.tema-oscuro #bloque-crear-documento,
.tema-oscuro #bloque-crear-directorio {
    background: linear-gradient(180deg, #1e293b 0%, #172131 100%);
    border-color: #334155;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.32);
}

.tema-oscuro #bloque-crear-noticia h3,
.tema-oscuro #bloque-crear-documento h3,
.tema-oscuro #bloque-crear-directorio h3,
.tema-oscuro #noticias h3,
.tema-oscuro #documentos h3,
.tema-oscuro #directorio h3 {
    color: #f1f5f9;
}

.tema-oscuro #bloque-crear-noticia input,
.tema-oscuro #bloque-crear-noticia textarea,
.tema-oscuro #bloque-crear-documento input,
.tema-oscuro #bloque-crear-documento select,
.tema-oscuro #bloque-crear-directorio input,
.tema-oscuro #noticias .form-noticia input,
.tema-oscuro #noticias .form-noticia textarea {
    background: #223044 !important;
    border-color: #3f4f66 !important;
    color: #f1f5f9 !important;
}

.tema-oscuro .destacada-noticia {
    background: #233349 !important;
    border-color: #3f4f66 !important;
}

/* Espaciado uniforme en el formulario de edicion de noticias */
#noticias .form-noticia {
    gap: 0 !important;
}

#noticias .form-noticia > * {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

#noticias .form-noticia > * + * {
    margin-top: 14px !important;
}

#noticias .form-noticia #imagen-noticia,
#noticias .form-noticia .destacada-noticia {
    margin-top: 14px !important;
    margin-bottom: 0 !important;
}

/* Separacion entre el formulario/bloque de noticias y la primera noticia */
#lista-noticias,
#contenedor-noticias,
#contenedor-noticias-completas {
    margin-top: 15px !important;
}

/* Igualar tamano del bloque "Aviso de empresa" al resto de recuadros */
.aviso-mejorado {
    margin: 40px !important;
    padding: 35px !important;
    border-radius: 12px !important;
    width: auto !important;
    box-sizing: border-box !important;
}

/* Igualar espaciado exactamente como los section en movil */
@media (max-width: 768px) {
    .aviso-mejorado {
        margin: 12px !important;
        padding: 14px !important;
        border-radius: 14px !important;
        width: auto !important;
    }
}

/* Override final: aviso exactamente igual que section */
body .aviso-mejorado {
    margin: 40px !important;
    padding: 35px !important;
    border-radius: 12px !important;
    width: auto !important;
    box-sizing: border-box !important;
}

@media (max-width: 1024px) {
    body .aviso-mejorado {
        margin: 14px 12px !important;
        padding: 16px !important;
        border-radius: 10px !important;
    }
}

@media (max-width: 768px) {
    body .aviso-mejorado {
        margin: 12px !important;
        padding: 14px !important;
        border-radius: 14px !important;
    }
}

@media (max-width: 480px) {
    body .aviso-mejorado {
        margin: 10px 8px !important;
        padding: 12px !important;
    }
}

/* Separacion entre "Añadir documento" y la primera carpeta */
#contenedor-documentos,
#lista-documentos {
    margin-top: 15px !important;
}

/* Linea fina en "Añadir documento" como en noticias */
#bloque-crear-documento > h3 + div {
    border-top: 1px solid var(--border) !important;
    padding-top: 14px !important;
    margin-top: 10px !important;
}

/* Boton Exportar contactos: misma posicion que "Borrar todos los datos" */
button[onclick="exportarContactosExcel()"] {
    margin: 20px 40px !important;
}

/* Mantener estilo base de etiqueta sin forzar color fijo */
.noticia-etiquetas span,
.noticia .etiqueta,
.noticia-completa .etiqueta {
    color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.18) !important;
}

/* Flecha forzada para selector de categoria de documentos */
#categoria-documento {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    padding-right: 40px !important;
    background: #ffffff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%231e3a8a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 14px center / 14px 14px !important;
}

.tema-oscuro #categoria-documento {
    background-color: #223044 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%23ffffff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    background-size: 14px 14px !important;
}

/* ====================== */
/* MOBILE BOOST (UX + VISUAL) */
/* ====================== */
@media (max-width: 768px) {
    body {
        padding-bottom: calc(env(safe-area-inset-bottom) + 14px);
    }

    header {
        position: sticky;
        top: 0;
        z-index: 1200;
        backdrop-filter: blur(8px);
    }

    .logo-empresa {
        height: 34px !important;
        max-width: 150px !important;
    }

    .fecha-container,
    .tema-toggle,
    .logout-btn {
        min-height: 42px !important;
        border-radius: 12px !important;
    }

    .notificaciones {
        min-height: 42px;
        border-radius: 12px;
        padding: 0 12px;
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        background: rgba(255, 255, 255, 0.1);
        border: 1px solid rgba(255, 255, 255, 0.18);
    }

    nav {
        position: sticky;
        top: 74px;
        z-index: 1100;
        box-shadow: 0 6px 16px rgba(2, 6, 23, 0.16);
    }

    .nav-left {
        gap: 10px !important;
        padding-bottom: 2px;
    }

    .nav-left a {
        min-height: 38px;
        border: 1px solid rgba(148, 163, 184, 0.35);
        background: rgba(255, 255, 255, 0.9);
    }

    .tema-oscuro .nav-left a {
        background: #1f2937 !important;
        border-color: #334155 !important;
        color: #e2e8f0 !important;
    }

    .tema-oscuro .nav-left a i {
        color: #60a5fa !important;
    }

    .tema-oscuro .nav-left a:hover {
        background: #273449 !important;
        color: #ffffff !important;
    }

    section,
    .aviso-mejorado {
        margin: 12px !important;
        padding: 14px !important;
        border-radius: 14px !important;
    }

    .aviso-empresa {
        width: calc(100% - 24px) !important;
        margin: 22px auto !important;
        font-size: 15px !important;
        padding: 12px 14px !important;
    }

    input,
    textarea,
    select {
        min-height: 44px !important;
        border-radius: 10px !important;
        font-size: 15px !important;
    }

    button {
        min-height: 44px !important;
        border-radius: 10px !important;
        font-size: 14px !important;
        font-weight: 700 !important;
    }

    .noticia,
    .noticia-completa {
        border-radius: 12px !important;
        padding: 12px !important;
    }

    .noticia h3,
    .noticia-completa h2 {
        font-size: 20px !important;
        line-height: 1.35;
    }

    .noticia-etiquetas {
        gap: 8px !important;
    }

    .noticia-etiquetas span {
        font-size: 11px !important;
        padding: 4px 9px !important;
    }

    .panel-notificaciones {
        top: 126px !important;
        border-radius: 14px !important;
        padding: 12px !important;
    }

    .panel-notificaciones li {
        padding: 10px 0 !important;
        font-size: 13px !important;
    }

    #btnBorrarTodosDatosIntranet,
    #btnBorrarTodosDatosNav,
    #btnPapeleraNav,
    button[onclick="exportarContactosExcel()"],
    .btn-peligro {
        width: calc(100% - 24px) !important;
        max-width: 100% !important;
        margin: 12px !important;
        box-sizing: border-box !important;
        white-space: normal !important;
        justify-content: center !important;
    }

    #tabla-contactos,
    .tabla-directorio {
        border-radius: 12px !important;
        border-collapse: separate;
        border-spacing: 0;
    }

    #tabla-contactos th,
    #tabla-contactos td,
    .tabla-directorio th,
    .tabla-directorio td {
        white-space: nowrap;
    }

}

@media (max-width: 480px) {
    nav {
        top: 68px;
    }

    section h2 {
        font-size: 18px !important;
    }

    .noticia h3,
    .noticia-completa h2 {
        font-size: 18px !important;
    }

    .btn-aviso,
    #agregar-noticia,
    #agregar-documento,
    #agregar-contacto {
        width: 100% !important;
        justify-content: center !important;
    }

    .aviso-input-group {
        gap: 8px !important;
    }

    .aviso-input-group .input-icon {
        display: none !important;
    }

    #btnBorrarTodosDatosIntranet,
    #btnBorrarTodosDatosNav,
    #btnPapeleraNav,
    button[onclick="exportarContactosExcel()"],
    .btn-peligro {
        width: calc(100% - 16px) !important;
        margin: 8px !important;
        font-size: 13px !important;
    }
}

/* Header movil: layout compacto y limpio */
@media (max-width: 768px) {
    header {
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        flex-wrap: nowrap !important;
        overflow-x: auto;
        gap: 10px !important;
    }

    header > a.logo-container {
        width: auto !important;
        margin: 0 !important;
        flex: 0 0 auto;
    }

    header > div[style*="margin-left:auto"] {
        margin-left: auto !important;
        width: auto !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        flex-wrap: nowrap !important;
        gap: 10px !important;
        flex: 0 0 auto;
    }

    .fecha-container,
    .tema-toggle,
    .notificaciones,
    .logout-btn {
        width: auto !important;
        min-width: 0 !important;
        margin: 0 !important;
        flex: 0 0 auto;
    }

    #fecha-hora {
        white-space: nowrap;
    }

}

/* Override final: #categoria-documento igual que las demas flechas */
#documentos #categoria-documento,
#bloque-crear-documento #categoria-documento {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    padding-right: 44px !important;
    background-color: #ffffff !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%231e3a8a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 18px center !important;
    background-size: 14px 14px !important;
}

.tema-oscuro #documentos #categoria-documento,
.tema-oscuro #bloque-crear-documento #categoria-documento {
    background-color: #223044 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%23dbeafe' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 18px center !important;
    background-size: 14px 14px !important;
}

/* Ajuste final en movil: calendario lateral al mismo ancho que el resto */
@media (max-width: 768px) {
    .calendar-sidebar-columna,
    body.layout-con-sidebar-cal .calendar-sidebar-columna,
    body.layout-con-sidebar-cal .layout-con-sidebar-wrapper .calendar-sidebar-columna {
        width: calc(100% - 24px) !important;
        max-width: none !important;
        margin: 12px !important;
        transform: none !important;
        justify-self: stretch !important;
        padding: 0 !important;
        box-sizing: border-box !important;
    }

    .calendar-sidebar-columna .calendar-sidebar-fijo,
    .calendar-sidebar-columna .calendar-sidebar-bloque-secundario,
    body.layout-con-sidebar-cal .calendar-sidebar-fijo,
    body.layout-con-sidebar-cal .calendar-sidebar-bloque-secundario {
        width: 100% !important;
        max-width: none !important;
        margin: 0 0 12px 0 !important;
        box-sizing: border-box !important;
    }
}

/* Compacto movil: cabecera y nav en una sola linea */
@media (max-width: 768px) {
    header {
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        flex-wrap: nowrap !important;
        gap: 6px !important;
        padding: 8px 10px !important;
        overflow-x: auto !important;
    }

    header > a.logo-container {
        flex: 0 0 auto !important;
        margin: 0 !important;
    }

    .logo-empresa {
        max-height: 30px !important;
        width: auto !important;
    }

    header > div[style*="margin-left:auto"] {
        gap: 6px !important;
        flex-wrap: nowrap !important;
    }

    .fecha-container,
    .tema-toggle,
    .notificaciones,
    .logout-btn {
        width: auto !important;
        min-height: 32px !important;
        padding: 4px 8px !important;
        font-size: 11px !important;
        white-space: nowrap !important;
        flex: 0 0 auto !important;
    }

    #fecha-hora {
        font-size: 11px !important;
        max-width: 145px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
        display: inline-block !important;
        vertical-align: middle;
    }

    nav {
        padding: 8px 10px !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap !important;
    }

    .nav-left {
        display: flex !important;
        align-items: center !important;
        flex-wrap: nowrap !important;
        gap: 6px !important;
        width: max-content !important;
        min-width: max-content !important;
    }

    .nav-left a {
        display: inline-flex !important;
        align-items: center !important;
        gap: 5px !important;
        padding: 7px 9px !important;
        font-size: 11px !important;
        line-height: 1 !important;
        white-space: nowrap !important;
        flex: 0 0 auto !important;
    }

    .nav-left .sesame-btn {
        height: 30px !important;
        padding: 4px 8px !important;
    }
}

/* Favoritos en nav: icono y texto siempre en la misma linea */
#btnFavoritosNav,
.nav-left #btnFavoritosNav {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center;
    gap: 6px !important;
    white-space: nowrap !important;
    flex-wrap: nowrap !important;
    min-width: max-content !important;
    line-height: 1 !important;
}

#btnFavoritosNav i,
.nav-left #btnFavoritosNav i {
    display: inline-block !important;
    line-height: 1 !important;
    margin: 0 !important;
    vertical-align: middle !important;
}

/* Mobile polish: sidebar calendar blocks readable and tidy */
@media (max-width: 768px) {
    body.layout-con-sidebar-cal .layout-con-sidebar-wrapper .calendar-sidebar-columna {
        width: calc(100% - 20px) !important;
        max-width: none !important;
        margin: 10px auto 14px !important;
        padding: 0 !important;
        gap: 10px !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-fijo,
    body.layout-con-sidebar-cal .calendar-sidebar-bloque-secundario {
        border-radius: 12px !important;
        padding: 10px !important;
        margin: 0 0 10px 0 !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-columna .sidebar-titulo {
        margin-bottom: 8px !important;
        font-size: 13px !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-widget .fc {
        font-size: 11px !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-widget .fc .fc-toolbar-title {
        font-size: 14px !important;
    }

    body.layout-con-sidebar-cal .lista-eventos-sidebar-box {
        min-height: 98px !important;
        max-height: 240px !important;
        padding: 8px !important;
        border-radius: 10px !important;
    }

    body.layout-con-sidebar-cal #lista-eventos-sidebar li:not(.periodo-laboral-mes-header),
    body.layout-con-sidebar-cal #proximos-15-dias-sidebar li {
        padding: 8px !important;
        font-size: 11px !important;
        line-height: 1.35 !important;
        border-radius: 8px !important;
    }
}

/* Mobile refresh: make calendar area clearly bigger/readable */
@media (max-width: 768px) {
    body.layout-con-sidebar-cal .layout-con-sidebar-wrapper .calendar-sidebar-columna {
        width: calc(100% - 12px) !important;
        margin: 12px auto 18px !important;
        gap: 14px !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-fijo,
    body.layout-con-sidebar-cal .calendar-sidebar-bloque-secundario {
        padding: 14px !important;
        border-radius: 16px !important;
        box-shadow: 0 8px 24px rgba(2, 6, 23, 0.28) !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-columna .sidebar-titulo {
        font-size: 14px !important;
        margin-bottom: 10px !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-widget .fc {
        font-size: 12px !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-widget .fc .fc-toolbar-title {
        font-size: 15px !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-widget .fc .fc-daygrid-day {
        min-height: 42px !important;
    }

    body.layout-con-sidebar-cal .calendar-sidebar-widget .fc .fc-daygrid-day-number {
        font-size: 12px !important;
        font-weight: 600 !important;
    }

    body.layout-con-sidebar-cal .lista-eventos-sidebar-box {
        min-height: 120px !important;
        max-height: 320px !important;
        padding: 10px !important;
    }

    body.layout-con-sidebar-cal #lista-eventos-sidebar li:not(.periodo-laboral-mes-header),
    body.layout-con-sidebar-cal #proximos-15-dias-sidebar li {
        padding: 10px !important;
        font-size: 12px !important;
        line-height: 1.45 !important;
    }
}

/* ========= Accesibilidad: saltar al contenido y foco visible (teclado) ========= */
.skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
}

.skip-link:focus,
.skip-link:focus-visible {
    position: fixed;
    left: 12px;
    top: 12px;
    width: auto;
    height: auto;
    clip: auto;
    overflow: visible;
    z-index: 2147483647;
    padding: 12px 16px;
    background: #0f172a;
    color: #f8fafc;
    border-radius: 10px;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    box-shadow: 0 8px 24px rgba(2, 6, 23, 0.45);
    outline: 3px solid #fbbf24 !important;
    outline-offset: 2px;
}

.tema-oscuro .skip-link:focus,
.tema-oscuro .skip-link:focus-visible {
    background: #f8fafc;
    color: #0f172a;
    outline-color: #2563eb !important;
}

*:focus-visible {
    outline: 3px solid #2563eb !important;
    outline-offset: 2px !important;
}

a:focus-visible {
    outline-offset: 4px;
}

button:focus-visible,
.btn-cerrar-modal:focus-visible,
.sesame-btn:focus-visible {
    outline: 3px solid #2563eb !important;
    outline-offset: 2px !important;
}

.tema-oscuro *:focus-visible,
.tema-oscuro a:focus-visible,
.tema-oscuro button:focus-visible,
.tema-oscuro .btn-cerrar-modal:focus-visible,
.tema-oscuro .sesame-btn:focus-visible {
    outline-color: #93c5fd !important;
}

.notificaciones[role="button"]:focus-visible {
    outline: 3px solid #2563eb !important;
    outline-offset: 3px !important;
}

#contenido-principal:focus {
    outline: none;
}
