/* Compat con estilos legados — los tokens están en tokens.css */
:root {
  /* el tamaño del sidebar y header se sobrescriben aquí porque la nueva
     UI los reescaló respecto al diseño original (220px → 240px / 56px → 60px). */
}
*,*::before,*::after{box-sizing:border-box}
body{font-family:'DM Sans',system-ui,sans-serif;color:var(--gray-900);background:var(--gray-50);margin:0}

/* Layout */
#app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--header-h) 1fr;height:100vh;overflow:hidden}

/* Header */
#app-header{grid-column:1/-1;grid-row:1;background:var(--blue);display:flex;align-items:center;padding:0 24px;gap:16px;z-index:30}
.header-identity{display:flex;align-items:center;gap:48px;min-width:0}
.header-logo-frame{align-self:stretch;display:flex;align-items:center;background:#fff;padding:0 38px 0 24px;margin-left:-24px;position:relative;flex-shrink:0}
.header-logo-frame::after{content:"";position:absolute;top:0;right:-34px;width:34px;height:100%;background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,.72) 38%,rgba(26,74,122,0) 100%);pointer-events:none}
.header-logo{width:auto;height:50px;max-width:210px;object-fit:contain;flex-shrink:0}
.header-title-wrap{min-width:0}
.header-brand{font-family:'DM Serif Display',Georgia,serif;font-size:24px;color:#fff;letter-spacing:.2px;white-space:nowrap;line-height:1}
.header-sub{font-size:13px;color:rgba(255,255,255,.72);margin-top:3px}
.header-spacer{flex:1}
.header-year{display:flex;align-items:center;gap:6px}
.header-year button{width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:transparent;color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}
.header-year button:hover{background:rgba(255,255,255,.15)}
.header-year span{font-size:15px;font-weight:600;color:#fff;min-width:44px;text-align:center}
/* legacy header-action styles removed — ahora se usa el FAB universal */

/* Sidebar */
#sidebar{grid-column:1;grid-row:2;background:#fff;border-right:1px solid var(--gray-200);overflow-y:auto;padding:16px 0}
.nav-section-title{font-size:10px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.6px;padding:0 20px 6px;margin-top:16px}
.nav-section-title:first-child{margin-top:0}
.side-nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:14px;font-weight:500;color:#475569;cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:background .12s,color .12s;font-family:'DM Sans',sans-serif}
.side-nav-item:hover{background:var(--gray-50)}
.side-nav-item.active{background:var(--blue-light);color:var(--blue);font-weight:600}
.side-nav-item i{font-size:16px;flex-shrink:0}
.sidebar-legend{padding:12px 16px;margin:12px 10px 0;background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--gray-200)}
.sidebar-legend-title{font-size:10px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.leg-item{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--gray-500);margin-bottom:5px}
.leg-sq{width:11px;height:11px;border-radius:3px;flex-shrink:0}

/* Main */
#main-content{grid-column:2;grid-row:2;overflow-y:auto;background:var(--gray-50)}
.section-pane{display:none;padding:24px 28px}
.section-pane.active{display:block}
.section-heading{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.section-heading h1{font-family:'DM Serif Display',Georgia,serif;font-size:26px;color:var(--gray-900);margin:0}
.count-badge{background:var(--blue-light);color:var(--blue);font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px}

/* ── CALENDARIO ─────────────────────────────────────────── */
/* Sección sin scroll vertical propio — el grid ocupa el espacio disponible */
#sec-calendario.active{display:flex;flex-direction:column;height:100%;overflow:hidden;padding:16px 20px}
.cal-nav{display:flex;align-items:center;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.cal-nav-btn{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:5px 11px;font-size:12px;font-weight:600;color:var(--gray-700);cursor:pointer;transition:border-color .12s,color .12s}
.cal-nav-btn:hover{border-color:var(--blue);color:var(--blue)}
.cal-nav-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.cal-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.cal-mode-toggle{display:flex;gap:6px;padding:4px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}
.cal-mode-btn{border:none;background:transparent;color:var(--gray-500);border-radius:var(--radius-sm);padding:6px 11px;font-size:12px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;display:flex;align-items:center;gap:5px}
.cal-mode-btn.active{background:var(--blue);color:#fff}
.cal-period-nav{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:4px;box-shadow:var(--shadow-sm)}
.cal-period-nav[hidden]{display:none}
.cal-period-btn{width:30px;height:30px;border:none;background:var(--gray-50);color:var(--blue);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer}
.cal-period-btn:hover{background:var(--blue-light)}
.cal-period-label{min-width:128px;text-align:center;font-size:12px;font-weight:800;color:var(--gray-700)}
.cal-scope-legend{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--gray-500)}
.scope-legend-item{display:inline-flex;align-items:center;gap:5px;font-weight:700}
.scope-mark{width:9px;height:9px;border-radius:50%;display:inline-block}
.scope-publico{--scope:#059669;--scope-bg:#ecfdf5;--scope-soft:#d1fae5}
.scope-municipal{--scope:#2563eb;--scope-bg:#eff6ff;--scope-soft:#dbeafe}
.scope-compartido{--scope:#d97706;--scope-bg:#fff7ed;--scope-soft:#fed7aa}
.scope-area{--scope:#64748b;--scope-bg:#f8fafc;--scope-soft:#e2e8f0}
.scope-area-externa{--scope:#475569;--scope-bg:#f1f5f9;--scope-soft:#cbd5e1}
.scope-personal{--scope:#9333ea;--scope-bg:#faf5ff;--scope-soft:#e9d5ff}
.scope-publico .scope-mark,.scope-mark.scope-publico{background:#059669}
.scope-municipal .scope-mark,.scope-mark.scope-municipal{background:#2563eb}
.scope-compartido .scope-mark,.scope-mark.scope-compartido{background:#d97706}
.scope-area .scope-mark,.scope-mark.scope-area{background:#64748b}
.scope-area-externa .scope-mark,.scope-mark.scope-area-externa{background:#475569}
.scope-personal .scope-mark,.scope-mark.scope-personal{background:#9333ea}
.scope-area-externa.cal-mini-event,
.scope-area-externa.cal-floating-card,
.scope-area-externa.cal-time-block,
.scope-area-externa.cal-ev-item,
.ev-card.scope-area-externa{opacity:.68;border-style:dashed!important;filter:saturate(.7)}
.scope-area-externa.cal-mini-event::before,
.scope-area-externa.cal-floating-card::before,
.scope-area-externa.cal-time-block::before{content:"Evento de área";display:block;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:#475569;line-height:1.1;margin-bottom:2px}

/* Layout: grilla + panel lateral, flex para que ocupe el alto restante.
   Por defecto (Mes/Semana) el calendario ocupa todo el ancho; el panel
   lateral solo aparece en vista Día (clase .has-side) como resumen del día. */
.cal-layout{display:grid;grid-template-columns:1fr;gap:14px;flex:1;min-height:0}
.cal-layout.has-side{grid-template-columns:1fr 280px}
.cal-grid-wrapper{display:flex;flex-direction:column;min-height:0}
.cal-grid{background:var(--surface-0);border-radius:var(--radius-lg);border:1px solid var(--border-1);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;flex:1;min-height:0}
.cal-grid.cal-grid-agenda{display:block;overflow:auto;padding:12px;background:#f8fafc}
.cal-header-row{display:grid;grid-template-columns:repeat(7,1fr);background:var(--blue);flex-shrink:0}
.cal-dow{padding:7px 4px;text-align:center;font-size:10px;font-weight:700;color:rgba(255,255,255,.8);letter-spacing:.4px}
/* cal-body ocupa el espacio restante y divide en filas iguales */
.cal-body{display:grid;grid-template-columns:repeat(7,1fr);flex:1;min-height:0}
.cal-cell{border-right:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);padding:3px 4px;cursor:pointer;transition:background .12s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.cal-cell:nth-child(7n){border-right:none}
.cal-cell:hover{background:var(--gray-50)}
.cal-cell.today{background:#eff6ff}
.cal-cell.selected{background:#dbeafe !important;outline:2px solid var(--blue);outline-offset:-2px;z-index:1}
.cal-cell.other-month{background:#fafafa}
.cal-cell.other-month .cal-day-num{color:var(--text-4)}
.cal-day-num{font-size:11px;font-weight:600;color:var(--gray-700);line-height:1;margin-bottom:2px;flex-shrink:0}
.cal-cell.today .cal-day-num{background:var(--blue);color:#fff;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px}
/* Puntos compactos: solo color, sin texto */
.cal-dots{display:flex;flex-wrap:wrap;gap:2px;margin-top:1px}
.cal-dot-circle{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.cal-more{font-size:9px;color:var(--gray-400);font-weight:600;line-height:1;margin-top:2px}
.cal-mini-events{display:flex;flex-direction:column;gap:2px;min-height:0;overflow:hidden}
.cal-mini-event{height:17px;display:flex;align-items:center;gap:4px;border-radius:5px;padding:0 5px;font-size:10px;font-weight:700;line-height:1;color:var(--gray-700);background:var(--scope-bg);border-left:3px solid var(--scope);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:filter .12s,transform .12s}
.cal-mini-event:hover{filter:brightness(.97);transform:translateY(-1px)}
.cal-mini-event .mini-dot{width:6px;height:6px;border-radius:50%;flex:0 0 auto}

/* Panel lateral (oculto por defecto; visible solo en vista Día vía .has-side) */
.cal-side-panel{background:var(--surface-0);border-radius:var(--radius-lg);border:1px solid var(--border-1);padding:14px;box-shadow:var(--shadow-sm);display:none;flex-direction:column;overflow:hidden}
.cal-layout.has-side .cal-side-panel{display:flex}
.cal-side-title{font-family:'DM Serif Display',Georgia,serif;font-size:15px;color:var(--blue);margin-bottom:4px;flex-shrink:0}
.cal-side-subtitle{font-size:11px;color:var(--gray-400);margin-bottom:12px;flex-shrink:0}
.cal-side-scroll{flex:1;overflow-y:auto;min-height:0}
.cal-side-empty{color:var(--gray-400);font-size:13px;text-align:center;padding:32px 0}
.cal-ev-item{padding:9px 10px;border-radius:var(--radius-sm);border:1px solid var(--gray-100);margin-bottom:8px;transition:border-color .12s;background:var(--surface-0)}
.cal-ev-item[class*="scope-"]{border-left:4px solid var(--scope);background:linear-gradient(90deg,var(--scope-bg),var(--surface-0) 30%)}
.cal-ev-item:hover{border-color:var(--blue)}
.cal-ev-name{font-size:13px;font-weight:600;line-height:1.3}
.cal-ev-meta{font-size:11px;color:var(--gray-400);margin-top:3px;display:flex;align-items:center;flex-wrap:wrap;gap:5px}
.cal-ev-actions{display:flex;gap:6px;margin-top:8px}
.cal-btn-edit{flex:1;padding:6px;border-radius:var(--radius-sm);border:none;background:var(--gray-100);color:var(--gray-700);font-size:12px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity .12s}
.cal-btn-edit:hover{opacity:.8}
/* Botón nuevo evento desde panel lateral */
.cal-side-new-btn{width:100%;margin-top:10px;padding:9px;border-radius:var(--radius-sm);border:1.5px dashed var(--blue-mid);background:transparent;color:var(--blue);font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .12s;flex-shrink:0}
.cal-side-new-btn:hover{background:var(--blue-light)}
.cal-agenda{display:flex;flex-direction:column;gap:10px;min-height:0;overflow:hidden}
.cal-agenda-header{display:grid;grid-template-columns:74px repeat(var(--days,7),minmax(0,1fr));gap:8px;flex-shrink:0}
.cal-agenda-corner{min-width:0}
.cal-agenda-day{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:8px 10px;box-shadow:var(--shadow-sm);cursor:pointer;text-align:left}
.cal-agenda-day.active{border-color:var(--blue);background:#eff6ff}
.cal-agenda-day-name{font-size:11px;color:var(--gray-400);font-weight:700;text-transform:uppercase}
.cal-agenda-day-num{font-size:18px;font-weight:800;color:var(--gray-900);line-height:1.1}
.cal-agenda-all-day{display:grid;grid-template-columns:74px repeat(var(--days,7),minmax(0,1fr));gap:8px;align-items:start;flex-shrink:0}
.cal-agenda-label{font-size:10px;text-transform:uppercase;font-weight:800;color:var(--gray-400);padding-top:7px}
.cal-all-day-col{min-height:44px;background:var(--surface-0);border:1px dashed var(--gray-200);border-radius:var(--radius-md);padding:6px;display:flex;flex-direction:column;gap:5px}
.cal-floating-card{border-left:4px solid var(--scope);background:var(--scope-bg);border-radius:var(--radius-sm);padding:6px 8px;font-size:11px;font-weight:800;color:var(--gray-900);box-shadow:var(--shadow-sm);cursor:pointer}
/* Eventos marco (contenedores): se distinguen con borde punteado tipo "banda" */
.cal-floating-card.ev-marco{border:1.5px dashed var(--scope);border-left-width:4px;background:repeating-linear-gradient(135deg,var(--scope-bg),var(--scope-bg) 8px,var(--scope-soft) 8px,var(--scope-soft) 9px)}
.cal-time-block.ev-marco{border:1.5px dashed var(--scope)}
.cal-mini-event.ev-marco{outline:1px dashed var(--scope);outline-offset:-2px;font-weight:800}
/* Contenedor de marco en semana/día: cabecera + sub-eventos anidados */
.cal-marco-block{padding:0!important;display:flex;flex-direction:column;border:1.5px dashed var(--scope);border-left-width:4px;background:var(--scope-bg);border-radius:var(--radius-md);overflow:hidden}
.cal-marco-block.cal-floating-card{box-shadow:var(--shadow-sm)}
.cal-marco-head{display:flex;align-items:center;gap:6px;padding:5px 8px;background:var(--scope);color:#fff;font-size:11px;font-weight:800;cursor:pointer;flex:0 0 auto}
.cal-marco-head .cal-marco-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-marco-head .cal-marco-time{font-weight:700;opacity:.92;font-size:10px;white-space:nowrap}
.cal-marco-body{flex:1 1 auto;min-height:0;overflow:auto;padding:5px;display:flex;flex-direction:column;gap:4px}
.cal-floating-card.cal-marco-block .cal-marco-body{max-height:240px}
.cal-sub{display:flex;align-items:center;gap:6px;background:var(--surface-0);border-left:3px solid var(--scope);border-radius:4px;padding:4px 7px;font-size:11px;cursor:pointer;box-shadow:0 1px 2px rgba(15,23,42,.06)}
.cal-sub:hover{background:var(--scope-soft)}
.cal-sub-time{font-weight:800;color:var(--gray-600);white-space:nowrap;font-size:10px}
.cal-sub-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;color:var(--gray-900)}
.cal-sub.cal-sub-susp{opacity:.6}.cal-sub.cal-sub-susp .cal-sub-name{text-decoration:line-through}
.cal-marco-empty{font-size:10px;color:var(--gray-400);padding:4px 2px}
/* Marco "de período" (Fiesta/Festival): banda de día completo */
.cal-marco-meta{display:flex;align-items:center;gap:5px;padding:3px 8px;font-size:10px;font-weight:700;color:var(--scope);background:var(--scope-soft)}
.cal-marco-periodo{border-style:dashed}
.cal-marco-periodo .cal-marco-head{letter-spacing:.2px}
.cal-timeline{display:grid;grid-template-columns:74px repeat(var(--days,7),minmax(0,1fr));gap:8px;overflow:auto;min-height:0;padding-bottom:8px}
.cal-hours{position:relative;height:960px}
.cal-hour-label{height:60px;font-size:10px;color:var(--gray-400);text-align:right;padding-right:4px;border-top:1px solid transparent}
.cal-day-lane{position:relative;height:960px;background:var(--surface-0);border:1px solid var(--gray-200);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}
/* Día con fiesta/festival en curso: tinte de fondo "todo el día" */
.cal-day-lane.cal-lane-periodo{border-color:var(--scope,var(--border-2))}
/* Celda del mes con fiesta/festival: tinte de fondo (overlay) sin tapar el contenido ni el highlight de hoy */
.cal-cell.cal-cell-periodo::after{content:"";position:absolute;inset:0;background:var(--cell-tint);pointer-events:none;z-index:0}
.cal-cell.cal-cell-periodo > *{position:relative;z-index:1}
/* Banner slim de fiesta/festival en la franja "Todo el día" */
.cal-periodo-banner{display:block;width:100%;text-align:left;border:1px solid var(--scope);border-left:4px solid var(--scope);background:var(--scope-bg);border-radius:var(--radius-sm);padding:5px 8px;cursor:pointer;box-shadow:var(--shadow-sm)}
.cal-periodo-banner .cpb-name{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:800;color:var(--gray-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-periodo-banner .cpb-meta{font-size:10px;font-weight:700;color:var(--scope);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Sub-evento que pertenece a un marco: distintivo para separarlo de los sueltos */
.cal-time-block.ev-de-marco,.cal-floating-card.ev-de-marco{border-left-width:4px!important;border-left-style:solid!important}
.cal-de-marco-ico{font-size:9px;opacity:.85;margin-right:2px}
.cal-hour-line{position:absolute;left:0;right:0;height:1px;background:var(--gray-100)}
.cal-time-block{position:absolute;border-left:4px solid var(--scope);background:var(--scope-bg);border-radius:var(--radius-sm);padding:6px 8px;box-shadow:0 2px 8px rgba(15,23,42,.08);overflow:hidden;cursor:pointer}
/* Cuando hay superposición y el evento NO es el prioritario para el rol
   actual, lo mostramos atenuado y con borde discontinuo para que el
   evento prioritario quede visualmente arriba pero el secundario siga
   siendo legible. */
.cal-time-block.is-secundario{opacity:.78;border-left-style:dashed;filter:saturate(.9)}
.cal-time-block.is-prioritario{box-shadow:0 4px 14px rgba(15,23,42,.16);z-index:2}
.cal-time-title{font-size:12px;font-weight:800;color:var(--gray-900);line-height:1.2}
.cal-time-meta{font-size:10px;color:var(--gray-500);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-agenda-empty{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:22px;text-align:center;color:var(--gray-400)}
/* ── Agenda vertical (vista Semana en mobile) — oculta en escritorio ──────── */
.cal-agenda-vertical{display:none}
.agv-day{margin-bottom:14px}
.agv-day-head{display:flex;align-items:baseline;gap:8px;padding:7px 2px;border-bottom:2px solid var(--border-2);margin-bottom:8px;position:sticky;top:0;background:var(--surface-1);z-index:2}
.agv-dow{font-size:11px;font-weight:800;text-transform:uppercase;color:var(--brand-600);letter-spacing:.4px}
.agv-date{font-size:14px;font-weight:700;color:var(--text-1)}
.agv-day-head.is-today{border-bottom-color:var(--brand-600)}
.agv-day-head.is-today .agv-date{color:var(--brand-600)}
.agv-count{margin-left:auto;font-size:11px;font-weight:700;color:var(--text-3)}
.agv-empty{font-size:12px;color:var(--text-4);padding:2px 2px 12px}
.agv-row{display:flex;gap:10px;align-items:flex-start;width:100%;text-align:left;padding:9px 11px;border:1px solid var(--border-1);border-left:3px solid var(--scope,#cbd5e1);border-radius:var(--radius-md);background:var(--surface-0);margin-bottom:6px;cursor:pointer;font-family:inherit}
.agv-row:active{background:var(--surface-1)}
.agv-row.agv-periodo{border:1.5px dashed var(--scope);background:var(--scope-bg)}
.agv-time{font-size:12px;font-weight:800;color:var(--text-2);white-space:nowrap;min-width:48px;flex-shrink:0;padding-top:1px}
.agv-main{min-width:0;flex:1}
.agv-name{display:block;font-size:14px;font-weight:600;color:var(--text-1);line-height:1.3}
.agv-meta{display:flex;flex-wrap:wrap;gap:5px;align-items:center;font-size:11px;color:var(--text-3);margin-top:4px}
.agv-sub{margin:0 0 6px 16px;border-left:2px dashed var(--border-2);padding-left:8px}

/* ── FILTROS ──────────────────────────────────────────── */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{padding:6px 14px;border-radius:20px;border:1px solid var(--gray-200);background:#fff;font-size:12px;font-weight:500;color:var(--gray-500);cursor:pointer;white-space:nowrap;font-family:'DM Sans',sans-serif;transition:background .12s,color .12s,border-color .12s}
.chip:hover{border-color:var(--blue);color:var(--blue)}
.chip.active{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ── EVENTOS PASADOS ─────────────────────────────────── */
.ev-card.pasado{opacity:.45;filter:grayscale(30%);transition:opacity .2s,filter .2s}
.ev-card.pasado:hover{opacity:.7}
.ev-item.comprimido .ev-card{cursor:pointer}
.ev-item.comprimido .ev-loc,
.ev-item.comprimido .ev-horario,
.ev-item.comprimido .mb-2,
.ev-item.comprimido .ev-notas,
.ev-item.comprimido .ev-obras-section,
.ev-item.comprimido .ev-feriado-subsumido,
.ev-item.comprimido .ev-actions{display:none!important}
.ev-item.comprimido .ev-top{margin-bottom:0}
.ev-item.comprimido .ev-body{padding:10px 15px}

/* ── MES COLAPSADO ───────────────────────────────────── */
.mes-heading.colapsado{opacity:.5;cursor:pointer;user-select:none}
.mes-heading.colapsado:hover{opacity:.75}
.mes-heading .mes-toggle{font-size:12px;margin-right:4px;display:inline-block;transition:transform .2s}
.mes-heading.colapsado .mes-toggle{transform:rotate(-90deg)}
.mes-grid-wrapper.oculto{display:none}

/* ── CARDS DE EVENTOS ─────────────────────────────────── */
.ev-card{background:var(--surface-0);border-radius:var(--radius-md);border:1px solid var(--border-1);overflow:hidden;box-shadow:var(--shadow-2);transition:box-shadow .15s, transform .15s, border-color .15s;height:auto;position:relative}
.ev-card[class*="scope-"]{border-left:4px solid var(--scope)}
.ev-card:hover{box-shadow:var(--shadow-3);transform:translateY(-1px);border-color:var(--border-2)}
/* Distintivo de agrupación por marco (sin colores nuevos): el marco lleva
   borde superior/derecho/inferior punteado; los sub-eventos, un borde izquierdo
   punteado que los "ata" visualmente al marco. */
.ev-card.ev-marco-card{border-top:1.5px dashed var(--gray-400);border-right:1.5px dashed var(--gray-400);border-bottom:1.5px dashed var(--gray-400)}
.ev-card.ev-hijo-card{border-left-style:dashed!important}
.ev-card.ev-hijo-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:repeating-linear-gradient(180deg,var(--gray-400),var(--gray-400) 4px,transparent 4px,transparent 8px)}
.ev-accent{height:3px;opacity:.85}
.ev-accent.municipal  {background:linear-gradient(90deg,#2dd4bf,#0f766e)}
.ev-accent.privado    {background:linear-gradient(90deg,#94a3b8,#475569)}
.ev-accent.fiesta     {background:linear-gradient(90deg,#86efac,#16a34a)}
.ev-accent.festival   {background:linear-gradient(90deg,#f0abfc,#c026d3)}
.ev-accent.patrio     {background:linear-gradient(90deg,#93c5fd,#2563eb)}
.ev-accent.aniv       {background:linear-gradient(90deg,#fcd34d,#d97706)}
.ev-accent.inauguracion{background:linear-gradient(90deg,#fca5a5,#dc2626)}
.ev-accent.recorrida  {background:linear-gradient(90deg,#c4b5fd,#7c3aed)}
.ev-accent.visita     {background:linear-gradient(90deg,#67e8f9,#0891b2)}
.ev-accent.gira       {background:linear-gradient(90deg,#f9a8d4,#db2777)}
.ev-accent.reunion    {background:linear-gradient(90deg,#a5b4fc,#4f46e5)}
.ev-accent.feriado    {background:linear-gradient(90deg,#e879f9,#9333ea)}
.ev-accent.trasladable{background:linear-gradient(90deg,#fdba74,#ea580c)}
.ev-accent.custom     {background:linear-gradient(90deg,#d6d3d1,#78716c)}
.ev-body{padding:13px 15px}
.ev-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:3px}
.ev-name{font-size:14px;font-weight:600;line-height:1.35;flex:1}
.ev-date-label{font-size:11px;color:var(--gray-400);white-space:nowrap;margin-top:2px;flex-shrink:0}
.ev-loc{font-size:12px;color:var(--gray-500);margin-bottom:7px;display:flex;align-items:center;gap:4px}
.ev-horario{font-size:12px;color:var(--gray-500);margin-bottom:7px;display:flex;align-items:center;gap:4px;font-weight:500}
.ev-notas{font-size:12px;color:var(--gray-500);line-height:1.4;margin-bottom:8px}
.badge-tipo{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 9px;border-radius:var(--radius-pill);border:1px solid transparent;line-height:1.3;margin-right:2px}
.badge-municipal  {background:#ccfbf1;color:#134e4a;border-color:#5eead4}
.badge-privado    {background:#e5e7eb;color:#374151;border-color:#9ca3af}
.badge-fiesta     {background:#dcfce7;color:#166534;border-color:#86efac}
.badge-festival   {background:#fae8ff;color:#86198f;border-color:#f0abfc}
.btn-sm-outline{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--blue);background:#fff;border:1px solid var(--blue);border-radius:var(--radius-sm);padding:6px 11px;cursor:pointer;font-family:'DM Sans',sans-serif}
.btn-sm-outline:hover{background:var(--blue-light)}
.badge-patrio     {background:var(--color-blue-bg);color:var(--color-blue-fg);border-color:#93c5fd}
.badge-aniv       {background:var(--color-warning-bg);color:var(--color-warning-fg);border-color:#fcd34d}
.badge-inauguracion{background:#fee2e2;color:#991b1b;border-color:#fca5a5}
.badge-recorrida  {background:var(--color-violet-bg);color:var(--color-violet-fg);border-color:#c4b5fd}
.badge-visita     {background:#cffafe;color:#155e75;border-color:#67e8f9}
.badge-gira       {background:#fce7f3;color:#9d174d;border-color:#f9a8d4}
.badge-reunion    {background:#e0e7ff;color:#3730a3;border-color:#a5b4fc}
.badge-feriado    {background:#fae8ff;color:#86198f;border-color:#e879f9}
.badge-trasladable{background:#ffedd5;color:#9a3412;border-color:#fdba74}
.badge-custom     {background:#f5f5f4;color:#57534e;border-color:#d6d3d1}
.badge-repetir    {background:var(--color-success-bg);color:var(--color-success-fg)}

/* Obras vinculadas en card de evento */
.ev-obras-section{margin-top:10px;padding-top:10px;border-top:1px solid var(--gray-100)}
.ev-obras-section:empty{margin-top:0;padding-top:0;border-top:none}
.ev-obras-title{font-size:10px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.ev-obra-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;padding:3px 8px;border-radius:20px;margin-right:4px;margin-bottom:4px}
.pill-en_gestion   {background:var(--color-neutral-bg);color:var(--color-neutral-fg)}
.pill-en_licitacion{background:var(--color-warning-bg);color:var(--color-warning-fg)}
.pill-en_ejecucion {background:var(--color-blue-bg);color:var(--color-blue-fg)}
.pill-paralizada   {background:var(--color-danger-bg);color:var(--color-danger-strong)}
.pill-completada   {background:var(--color-success-bg);color:var(--color-success-fg)}
.pill-inaugurada   {background:var(--color-violet-bg);color:var(--color-violet-fg)}
/* compatibilidad legado */
.pill-activa{background:var(--color-neutral-bg);color:var(--color-neutral-fg)}.pill-pendiente{background:var(--color-warning-bg);color:var(--color-warning-fg)}

.ev-actions{display:flex;gap:8px;margin-top:10px}
.ev-btn{flex:1;padding:8px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity .12s}
.ev-btn:hover{opacity:.82}
.ev-btn-edit{background:var(--gray-100);color:var(--gray-700)}
.ev-btn-del {background:var(--color-danger-bg);color:var(--color-danger-strong)}

/* Mes heading */
.mes-heading{font-family:'DM Serif Display',Georgia,serif;font-size:18px;color:var(--blue);padding-bottom:8px;border-bottom:2px solid var(--blue-light);margin-bottom:14px;margin-top:26px;display:flex;align-items:center;gap:10px}
.mes-heading:first-of-type{margin-top:0}
.mes-count{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;background:var(--blue-light);color:var(--blue);padding:2px 8px;border-radius:20px}

/* ── TOGGLE VISTA LISTA ───────────────────────────────── */
.vista-toggle-bar{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-bottom:14px}
.btn-vista{background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:5px 12px;font-size:12px;font-weight:600;color:var(--gray-500);cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .15s;font-family:'DM Sans',sans-serif}
.btn-vista.activo{background:var(--blue);border-color:var(--blue);color:#fff}

/* Modo lista */
#lista-eventos.vista-lista .row{display:flex;flex-direction:column;gap:0}
#lista-eventos.vista-lista .ev-item{width:100%!important;max-width:100%!important;flex:none}
#lista-eventos.vista-lista .ev-card{border-radius:0;border-bottom:none;height:auto}
#lista-eventos.vista-lista .ev-item:first-child .ev-card{border-radius:var(--radius-sm) var(--radius-sm) 0 0}
#lista-eventos.vista-lista .ev-item:last-child .ev-card{border-radius:0 0 var(--radius-sm) var(--radius-sm);border-bottom:1px solid var(--gray-200)}
#lista-eventos.vista-lista .ev-accent{height:0;width:4px;position:absolute;top:0;bottom:0;left:0;border-radius:0}
#lista-eventos.vista-lista .ev-card{position:relative;padding-left:4px}
#lista-eventos.vista-lista .ev-body{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto;column-gap:16px;padding:10px 14px 10px 18px;align-items:center}
#lista-eventos.vista-lista .ev-top{margin-bottom:0;grid-column:1;grid-row:1}
#lista-eventos.vista-lista .ev-loc,
#lista-eventos.vista-lista .ev-horario{display:inline-flex;margin-bottom:0;margin-right:10px}
#lista-eventos.vista-lista .ev-meta{display:flex;align-items:center;flex-wrap:wrap;gap:4px;grid-column:1;grid-row:2;margin-top:3px}
#lista-eventos.vista-lista .mb-2{margin-bottom:0!important}
#lista-eventos.vista-lista .ev-notas{display:none}
#lista-eventos.vista-lista .ev-obras-section{display:none}
#lista-eventos.vista-lista .ev-feriado-subsumido:not(:empty){grid-column:1;grid-row:3}
#lista-eventos.vista-lista .ev-actions{margin-top:0;grid-column:2;grid-row:1 / span 3;flex-direction:column;width:90px;align-self:center}
#lista-eventos.vista-lista .ev-btn{padding:6px;font-size:12px}

/* ── ÍNDICE DE MESES ─────────────────────────────────── */
.mes-index-bar{position:sticky;top:0;z-index:10;background:var(--gray-50);border-bottom:1px solid var(--gray-200);margin:0 -24px 20px -24px;padding:0 24px;display:flex;align-items:center;gap:4px;overflow-x:auto;scrollbar-width:none}
.mes-index-bar::-webkit-scrollbar{display:none}
.mes-index-btn{flex-shrink:0;padding:8px 10px;font-size:12px;font-weight:600;color:var(--gray-400);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap}
.mes-index-btn:hover{color:var(--blue)}
.mes-index-btn.activo{color:var(--blue);border-bottom-color:var(--blue)}
.mes-index-btn.sin-eventos{opacity:.35;cursor:default;pointer-events:none}

/* ── OBRAS ────────────────────────────────────────────── */
.obras-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px}

/* Toggle Activas / Inauguradas */
.obras-vista-toggle{display:flex;gap:6px}
.obras-vista-btn{background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:5px 14px;font-size:12px;font-weight:600;color:var(--gray-500);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.obras-vista-btn.activo{background:var(--blue);border-color:var(--blue);color:#fff}

/* Grid de localidades */
.obras-grid{display:flex;flex-direction:column;gap:2px}

/* Card de localidad */
.obras-loc-card{background:#fff;border-radius:var(--radius-md);border:1px solid var(--gray-200);overflow:hidden;box-shadow:var(--shadow-sm)}
.obras-loc-header{background:var(--blue);padding:9px 15px;display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer;user-select:none}
.obras-loc-header:hover{background:#1e5590}
.obras-loc-nombre{font-family:'DM Serif Display',Georgia,serif;font-size:14px;color:#fff}
.obras-loc-toggle{font-size:12px;color:rgba(255,255,255,.8);transition:transform .2s;display:inline-block}
.obras-loc-count{background:rgba(255,255,255,.2);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px}
.obras-loc-body{padding:0}
.obras-loc-body.oculto{display:none}

/* Items de obra */
.obra-item{display:flex;align-items:center;gap:10px;padding:8px 15px;border-bottom:1px solid var(--gray-100);transition:background .12s}
.obra-item:last-child{border-bottom:none}
.obra-item:hover{background:var(--gray-50)}
.obra-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-en_gestion   {background:#94a3b8}
.dot-en_licitacion{background:#f59e0b}
.dot-en_ejecucion {background:#3b82f6}
.dot-paralizada   {background:#ef4444}
.dot-completada   {background:#10b981}
.dot-inaugurada   {background:#8b5cf6}
.dot-activa{background:#94a3b8}.dot-pendiente{background:#f59e0b}
.obra-nombre{font-size:13px;font-weight:500;flex:1}
.obra-localidad{font-size:11px;color:var(--gray-400)}
.estado-pill{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap}
.estado-en_gestion   {background:var(--color-neutral-bg);color:var(--color-neutral-fg)}
.estado-en_licitacion{background:var(--color-warning-bg);color:var(--color-warning-fg)}
.estado-en_ejecucion {background:var(--color-blue-bg);color:var(--color-blue-fg)}
.estado-paralizada   {background:var(--color-danger-bg);color:var(--color-danger-strong)}
.estado-completada   {background:var(--color-success-bg);color:var(--color-success-fg)}
.estado-inaugurada   {background:var(--color-violet-bg);color:var(--color-violet-fg)}
.estado-activa{background:var(--color-neutral-bg);color:var(--color-neutral-fg)}.estado-pendiente{background:var(--color-warning-bg);color:var(--color-warning-fg)}

/* Acciones — visibles solo en hover */
.obra-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity .15s}
.obra-item:hover .obra-actions{opacity:1}
.obra-action-btn{width:26px;height:26px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:opacity .12s}
.obra-action-btn:hover{opacity:.75}
.btn-edit-obra{background:var(--gray-100);color:var(--gray-700)}
.btn-del-obra {background:var(--color-danger-bg);color:var(--color-danger-strong)}
.btn-agregar-obra{background:rgba(255,255,255,.15);border:1px dashed rgba(255,255,255,.4);color:#fff;border-radius:6px;padding:3px 10px;font-size:11px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap}
.btn-agregar-obra:hover{background:rgba(255,255,255,.25)}

/* Empty */
.empty-state{text-align:center;padding:56px 24px;color:var(--gray-400)}
.empty-state i{font-size:44px;display:block;margin-bottom:12px;opacity:.35}
.empty-state p{font-size:15px}

/* ── MODALES ──────────────────────────────────────────── */
.modal-content{border:none;border-radius:var(--radius-lg);box-shadow:0 20px 60px rgba(0,0,0,.18);font-family:'DM Sans',sans-serif}
.modal-header{background:var(--blue);color:#fff;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:15px 22px;border-bottom:none}
.modal-title{font-family:'DM Serif Display',Georgia,serif;font-size:18px;color:#fff}
.btn-close-white{filter:invert(1) grayscale(1)}
.modal-body{padding:20px 22px;background:#fff}
.modal-footer{padding:13px 22px;background:#fff;border-top:1px solid var(--gray-200);border-radius:0 0 var(--radius-lg) var(--radius-lg)}
.form-label{font-size:11px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px}
.form-control,.form-select{border:1.5px solid var(--gray-200);border-radius:var(--radius-md);font-family:'DM Sans',sans-serif;font-size:14px;color:var(--gray-900);padding:10px 13px;background:#fff;transition:border-color .15s,box-shadow .15s}
.form-control:focus,.form-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,74,122,.12);outline:none}
.form-check-input:checked{background-color:var(--blue);border-color:var(--blue)}
.btn-primary-mch{background:var(--blue);color:#fff;border:none;border-radius:var(--radius-md);padding:10px 22px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s}
.btn-primary-mch:hover{opacity:.88}
.btn-secondary-mch{background:var(--gray-100);color:var(--gray-700);border:none;border-radius:var(--radius-md);padding:10px 18px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s}
.btn-secondary-mch:hover{opacity:.82}
#form-feedback{font-size:13px;padding:8px 12px;border-radius:var(--radius-sm);margin-top:10px;display:none}
#form-feedback.error  {background:var(--color-danger-bg);color:var(--color-danger-strong);display:block}
#form-feedback.success{background:var(--color-success-bg);color:var(--color-success-fg);display:block}
#form-feedback-obra{font-size:13px;padding:7px 12px;border-radius:var(--radius-sm);margin-top:8px;display:none}
#form-feedback-obra.error  {background:var(--color-danger-bg);color:var(--color-danger-strong);display:block}
#form-feedback-obra.success{background:var(--color-success-bg);color:var(--color-success-fg);display:block}
#form-feedback-coordinacion{font-size:13px;padding:7px 12px;border-radius:var(--radius-sm);margin-top:8px;display:none}
#form-feedback-coordinacion.error  {background:var(--color-danger-bg);color:var(--color-danger-strong);display:block}
#form-feedback-coordinacion.success{background:var(--color-success-bg);color:var(--color-success-fg);display:block}
.spinner-border-sm{width:14px;height:14px;border-width:2px}

/* ══ Carga rápida + asistente (Intendencia y Prensa) ═══════════
   El asistente de 3 pasos es la base (igual que admin/áreas).
   Estos roles ABREN en "modo-rapido": una sola pantalla con lo
   esencial. El toggle "Formulario completo" reactiva el asistente. */
.quick-pill{border:1px solid var(--gray-200);background:#fff;color:var(--gray-700);border-radius:20px;padding:5px 12px;font-size:11px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:background .15s,border-color .15s,color .15s}
.quick-pill:hover{border-color:var(--blue)}
.quick-pill.active{background:var(--blue);border-color:var(--blue);color:#fff}

/* Barra superior: selector de modo + visibilidad rápida */
.ev-quick-bar{display:none;flex-direction:column;gap:11px;background:#f8fafc;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:11px 12px;margin-bottom:16px}
#modalEvento.tiene-carga-rapida .ev-quick-bar{display:flex}
.ev-modo-switch{display:inline-flex;background:var(--gray-100);border-radius:var(--radius-md);padding:3px;gap:3px;align-self:flex-start}
.ev-modo-btn{border:none;background:transparent;color:var(--gray-600);border-radius:calc(var(--radius-md) - 3px);padding:6px 14px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .15s,color .15s,box-shadow .15s}
.ev-modo-btn.is-active{background:#fff;color:var(--blue);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.ev-quick-vis{display:none;align-items:center;flex-wrap:wrap;gap:6px}
#modalEvento.tiene-carga-rapida.modo-rapido .ev-quick-vis{display:flex}
.ev-quick-vis-label{font-size:11px;font-weight:800;color:var(--gray-500);text-transform:uppercase;letter-spacing:.4px;margin-right:2px}

/* Campos avanzados ocultos en el modo rápido */
#modalEvento.modo-rapido .intendencia-avanzado,
#modalEvento.modo-rapido #row-areas-compartidas{display:none!important}
/* Ancho enfocado en modo rápido; el asistente usa el ancho estándar (modal-lg) */
#modalEvento.tiene-carga-rapida.modo-rapido .modal-dialog{max-width:680px}
/* Orden limpio de la pantalla rápida: qué → cuándo → hora → dónde → visibilidad → notas */
#modalEvento.modo-rapido #row-nombre-evento{order:1}
#modalEvento.modo-rapido #row-fecha-inicio{order:2}
#modalEvento.modo-rapido #row-fecha-fin{order:3}
#modalEvento.modo-rapido #row-horario{order:4}
#modalEvento.modo-rapido #row-horario-fin{order:5}
#modalEvento.modo-rapido #row-localidad{order:6}
#modalEvento.modo-rapido #row-lugar{order:7}
#modalEvento.modo-rapido #row-visibilidad{order:8}
#modalEvento.modo-rapido #row-notas{order:9}

/* ── Wizard de evento (3 pasos) — solo modo estándar ────── */
#modalEvento.js-wizard [data-wzstep]:not(.wz-active){display:none!important}
.ev-wizard-steps{display:flex;gap:0;margin:0 0 20px;padding:0;list-style:none}
.ev-wizard-steps[hidden]{display:none}
.ev-wizard-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;font-size:11px;font-weight:600;color:var(--text-3);cursor:pointer;background:none;border:none;font-family:inherit;padding:0;text-align:center}
.ev-wizard-step::before{content:'';position:absolute;top:14px;left:-50%;width:100%;height:2px;background:var(--border-1);z-index:0}
.ev-wizard-step:first-child::before{display:none}
.ev-wizard-step.is-done::before{background:var(--blue)}
.ev-wizard-step .wz-dot{position:relative;z-index:1;width:30px;height:30px;border-radius:50%;background:var(--surface-2);color:var(--text-3);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;border:2px solid var(--border-1);transition:background .15s,color .15s,border-color .15s}
.ev-wizard-step.is-active .wz-dot{background:var(--blue);color:#fff;border-color:var(--blue)}
.ev-wizard-step.is-done .wz-dot{background:var(--blue-light);color:var(--blue);border-color:var(--blue)}
.ev-wizard-step.is-active,.ev-wizard-step.is-done{color:var(--blue)}
.obras-chips-selected{display:flex;flex-wrap:wrap;gap:6px;min-height:32px;padding:8px 10px;border-radius:var(--radius-md);border:1.5px solid var(--gray-200);background:#fff;margin-bottom:8px}
.obra-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;background:var(--blue-light);color:var(--blue);cursor:default}
.obra-chip .chip-remove{background:none;border:none;color:inherit;cursor:pointer;padding:0;line-height:1;font-size:14px;opacity:.7;display:flex;align-items:center}
.obra-chip .chip-remove:hover{opacity:1}
.obras-check-list{max-height:160px;overflow-y:auto;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);padding:4px 8px}
.obras-check-item{display:flex;align-items:center;gap:8px;padding:6px 4px;border-bottom:1px solid var(--gray-100)}
.obras-check-item:last-child{border-bottom:none}
.obras-check-item label{font-size:13px;cursor:pointer;flex:1}
.obras-check-localidad{font-size:10px;color:var(--gray-400)}
.obras-filter-localidad{margin-bottom:6px}

/* ── Dashboard welcome banner ────────────────────────── */
.dash-welcome{display:flex;align-items:center;justify-content:space-between;gap:16px;background:linear-gradient(135deg,var(--brand-600) 0%,var(--brand-500) 100%);color:#fff;border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:var(--space-4);box-shadow:var(--shadow-3)}
.dash-welcome-hola{font-family:'DM Serif Display',Georgia,serif;font-size:22px;line-height:1.1}
.dash-welcome-sub{font-size:var(--fs-sm);color:rgba(255,255,255,.75);margin-top:3px}
/* ── Dashboard accesos rápidos ─────────────────────── */
.dash-accesos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:8px;padding:var(--space-2)}
.dash-acceso-btn{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:5px;min-height:68px;padding:9px 4px;background:var(--surface-1);border:1px solid var(--border-1);border-radius:var(--radius-md);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:10.5px;font-weight:600;color:var(--text-2);text-align:center;line-height:1.2;transition:background .15s,border-color .15s,color .15s}
.dash-acceso-btn:hover{background:var(--surface-2);border-color:var(--brand-600);color:var(--brand-600)}
.dash-acceso-icon{font-size:18px;color:var(--brand-600)}
.dash-acceso-btn:hover .dash-acceso-icon{color:var(--brand-700)}
/* Dark mode dashboard welcome */
:root.theme-dark .dash-welcome{background:linear-gradient(135deg,var(--brand-700) 0%,var(--brand-600) 100%)}
:root.theme-dark .dash-acceso-btn{background:var(--surface-1);border-color:var(--border-1);color:var(--text-2)}
:root.theme-dark .dash-acceso-btn:hover{background:var(--surface-2);border-color:var(--brand-500);color:var(--brand-400)}
:root.theme-dark .dash-acceso-icon{color:var(--brand-400)}

/* Toast */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.mch-toast{background:var(--text-1);color:var(--surface-0);padding:11px 16px;border-radius:var(--radius-md);font-size:var(--fs-md);font-weight:500;box-shadow:var(--shadow-3);opacity:0;transform:translateY(8px);transition:opacity .2s,transform .2s;display:flex;align-items:center;gap:8px;max-width:360px}
.mch-toast i{font-size:18px;color:var(--color-success-strong);flex-shrink:0}
.mch-toast-error{background:var(--color-danger-strong);color:#fff}
.mch-toast-error i{color:#fff}
.mch-toast.show{opacity:1;transform:translateY(0)}

/* ════════════════════════════════════════════════════════
   MOBILE  ≤ 768px
════════════════════════════════════════════════════════ */
@media(max-width:768px){

  /* Grid: header / contenido / bottom-nav sin desborde */
  #app{
    grid-template-columns:1fr;
    grid-template-rows:var(--header-h) 1fr calc(64px + env(safe-area-inset-bottom));
    height:100dvh;
    overflow:hidden;
    width:100%;
    max-width:100vw;
  }

  /* Header compacto */
  #app-header{padding:0 10px;gap:8px;overflow:hidden}
  .header-identity{gap:0;flex:0 0 auto}
  .header-logo-frame{padding:0 24px 0 10px;margin-left:-10px}
  .header-logo-frame::after{right:-24px;width:24px}
  .header-logo{width:auto;height:42px;max-width:120px}
  .header-title-wrap{display:none}
  .header-sub{display:none}
  .header-brand{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90px}
  .header-spacer{flex:1;min-width:2px}
  .header-user-info{display:none!important}
  .header-user-chev{display:none!important}
  .header-user-btn{padding:5px}
  .header-year span{min-width:36px;font-size:14px}
  .header-year button{width:26px;height:26px}

  /* El menú de usuario es absolute dentro del header, que en mobile tiene
     overflow:hidden → quedaba recortado/tapado. Lo fijamos al viewport. */
  .header-user-menu{position:fixed;top:calc(var(--header-h) + 6px);right:8px;left:auto;min-width:230px;max-width:calc(100vw - 16px);z-index:200}

  /* Sidebar oculto */
  #sidebar{display:none}

  /* Contenido principal */
  #main-content{
    grid-column:1;
    grid-row:2;
    overflow-y:auto;
    overflow-x:hidden;
    width:100%;
    max-width:100vw;
    -webkit-overflow-scrolling:touch;
  }

  /* Secciones */
  .section-pane{padding:12px}
  .section-heading h1{font-size:20px}

  /* Calendario mobile */
  #sec-calendario.active{display:block !important;height:auto;overflow:visible;padding:12px}
  .cal-topbar{align-items:flex-start}
  .cal-mode-toggle{width:100%;justify-content:space-between}
  .cal-mode-btn{flex:1;justify-content:center}
  .cal-period-nav{width:100%;justify-content:space-between}
  .cal-period-label{flex:1;min-width:0}
  .cal-scope-legend{gap:6px;font-size:10px}
  .cal-nav{gap:4px;margin-bottom:8px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .cal-nav::-webkit-scrollbar{display:none}
  .cal-nav-btn{padding:4px 8px;font-size:11px}
  .cal-layout,.cal-layout.has-side{grid-template-columns:1fr}
  .cal-side-panel,.cal-layout.has-side .cal-side-panel{display:none}
  .cal-grid-wrapper{display:block}
  .cal-grid{display:block;flex:none}
  .cal-body{grid-auto-rows:52px}
  .cal-dow{padding:6px 2px;font-size:10px}
  .cal-cell{padding:2px 3px}
  .cal-day-num{font-size:10px}
  /* Mostrar primer evento como texto truncado, los demás como puntos */
  .cal-mini-event{height:14px;font-size:9px;padding:0 3px;border-left-width:2px;line-height:14px}
  .cal-mini-events .cal-mini-event:not(:first-child){font-size:0;height:6px;width:6px;border-left:none;border-radius:50%;background:var(--scope) !important;display:inline-block;margin:0 2px}
  .cal-mini-event .mini-dot{width:5px;height:5px}
  .cal-agenda-header{gap:5px;overflow-x:auto;grid-template-columns:48px repeat(var(--days,7),130px);padding-bottom:2px;scrollbar-width:none}
  .cal-agenda-header::-webkit-scrollbar{display:none}
  .cal-agenda-day{padding:7px 8px}
  .cal-agenda-day-name{font-size:9px}
  .cal-agenda-day-num{font-size:15px}
  .cal-agenda-all-day{grid-template-columns:48px repeat(var(--days,7),130px);overflow-x:auto;gap:5px;scrollbar-width:none}
  .cal-agenda-all-day::-webkit-scrollbar{display:none}
  .cal-timeline{grid-template-columns:48px repeat(var(--days,7),130px);gap:5px}
  .cal-hours,.cal-day-lane{height:900px}
  .cal-hour-label{height:56px;font-size:9px}
  .cal-time-block{left:4px;right:4px;padding:5px 6px}
  .cal-time-title{font-size:11px}
  #cal-mobile-events{display:block}

  /* DÍA en mobile: la franja horaria queda contenida (scroll interno) en vez de
     estirar la página; los encabezados quedan a la vista. */
  .cal-agenda-all-day{max-height:26vh;overflow:auto}
  .cal-timeline{max-height:58vh}
  /* (con :has) sólo en vista DÍA fijamos el calendario al viewport; la SEMANA
     usa la agenda vertical, que fluye con la página. */
  #sec-calendario.active:has(.cal-grid-agenda:not(.cal-week)){display:flex !important;flex-direction:column;height:100%;overflow:hidden}
  #sec-calendario.active:has(.cal-grid-agenda:not(.cal-week)) .cal-layout{flex:1;min-height:0}
  #sec-calendario.active:has(.cal-grid-agenda:not(.cal-week)) .cal-grid-wrapper{height:100%;min-height:0}
  #sec-calendario.active:has(.cal-grid-agenda:not(.cal-week)) .cal-grid-agenda{height:100%;display:flex;flex-direction:column}
  #sec-calendario.active:has(.cal-grid-agenda:not(.cal-week)) .cal-agenda{flex:1;min-height:0}
  #sec-calendario.active:has(.cal-grid-agenda:not(.cal-week)) .cal-timeline{max-height:none}

  /* SEMANA en mobile: lista vertical por día (estilo app de calendario). Se
     oculta la grilla horizontal y se muestra la lista (fluye con la página). */
  .cal-grid-agenda.cal-week .cal-agenda{display:none}
  .cal-grid-agenda.cal-week .cal-agenda-vertical{display:block}
  /* Sin marco/overflow para que la lista fluya y los encabezados de día puedan
     quedar sticky relativos al scroll de la página. */
  .cal-grid-agenda.cal-week{overflow:visible;border:none;box-shadow:none;background:transparent}

  /* Cards de eventos: una por fila */
  #lista-eventos .row{margin:0}
  #lista-eventos .ev-item{
    padding-left:0;padding-right:0;
    width:100%;max-width:100%;flex:0 0 100%;
  }

  /* Chips: scroll horizontal sin wrap */
  .filter-bar{
    flex-wrap:nowrap;overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding-bottom:4px;gap:6px;
    scrollbar-width:none;
  }
  .filter-bar::-webkit-scrollbar{display:none}
  .chip{flex-shrink:0}

  /* Obras */
  .obras-grid{grid-template-columns:1fr}
  .obras-toolbar{flex-direction:column;align-items:flex-start}

  /* Bottom nav */
  #mobile-nav{
    display:flex;
    grid-column:1;grid-row:3;
    background:var(--surface-0);
    border-top:1px solid var(--border-1);
    height:calc(64px + env(safe-area-inset-bottom));width:100%;z-index:20;
    padding-bottom:env(safe-area-inset-bottom);
  }
  .mnav-item{
    flex:1;display:flex;flex-direction:column;position:relative;
    align-items:center;justify-content:center;
    gap:3px;border:none;background:none;
    color:var(--text-3);font-family:'DM Sans',sans-serif;
    font-size:10px;font-weight:600;cursor:pointer;padding:0 2px;
    min-width:0;
  }
  .mnav-item i{font-size:20px}
  .mnav-item.active{color:var(--blue)}
  .mnav-badge{position:absolute;top:7px;right:50%;transform:translateX(18px);background:#dc2626;color:#fff;font-size:9px;font-weight:800;line-height:1;padding:2px 5px;border-radius:20px}

  /* Usuarios: tabla convertida en tarjetas */
  #tabla-usuarios-wrapper table{display:block!important;background:transparent!important;box-shadow:none!important;border-radius:0!important}
  #tabla-usuarios-wrapper thead{display:none!important}
  #tabla-usuarios-wrapper tbody{display:grid!important;gap:10px}
  #tabla-usuarios-wrapper tr{display:block!important;background:var(--surface-0)!important;border:1px solid var(--border-1)!important;border-radius:var(--radius-md)!important;padding:10px 12px!important;box-shadow:var(--shadow-sm)}
  #tabla-usuarios-wrapper td{display:flex!important;justify-content:space-between;align-items:center;gap:12px;padding:7px 0!important;border:0!important;text-align:right!important}
  #tabla-usuarios-wrapper td::before{font-size:10px;font-weight:800;color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;text-align:left;flex-shrink:0}
  #tabla-usuarios-wrapper td:nth-child(1)::before{content:'Nombre'}
  #tabla-usuarios-wrapper td:nth-child(2)::before{content:'Email'}
  #tabla-usuarios-wrapper td:nth-child(3)::before{content:'Área'}
  #tabla-usuarios-wrapper td:nth-child(4)::before{content:'Rol'}
  #tabla-usuarios-wrapper td:nth-child(5)::before{content:'Estado'}
  #tabla-usuarios-wrapper td:nth-child(6){justify-content:flex-end;border-top:1px solid var(--gray-100)!important;margin-top:4px;padding-top:10px!important}
  #tabla-usuarios-wrapper td:nth-child(6)::before{display:none}

  /* Toast y modales */
  #toast-container{bottom:72px;right:12px}
  .modal-dialog{margin:8px;max-width:calc(100vw - 16px)}
  .modal-dialog-scrollable .modal-content{max-height:calc(100dvh - 16px)}
  .modal-footer{position:sticky;bottom:0}
}

@media(min-width:769px){
  #mobile-nav{display:none}
  #sec-calendario.active{overflow:hidden}
  .cal-body{grid-auto-rows:1fr}
}