:root{
  --azul:#1f5fb0;--azul-osc:#184a8c;--azul-deep:#12305c;
  --verde:#1f9d3a;--gold:#f4c20d;--rojo:#d62828;
  --txt:#2b2b2b;--muted:#7a8699;--bg:#f4f6f9;--linea:#e8ecf2;
  --shadow:0 6px 24px rgba(20,40,80,.07);--shadow-h:0 14px 34px rgba(20,40,80,.13);
  --r:14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Raleway',system-ui,-apple-system,"Segoe UI",sans-serif;
  color:var(--txt);background:var(--azul-deep);line-height:1.65;
  display:flex;flex-direction:column;min-height:100vh;
  overscroll-behavior-y:none}
html{background:var(--azul-deep);overscroll-behavior-y:none}
main{background:#fff}
/* Bloquear scroll del body cuando el menú móvil está abierto */
body.nav-open{overflow:hidden;position:fixed;width:100%;top:0;left:0;right:0}
img{max-width:100%;display:block}
a{color:var(--azul);text-decoration:none}
a:hover{text-decoration:none;color:var(--azul-osc)}
main{flex:1}
.container{max-width:1080px;margin:0 auto;padding:0 clamp(20px, 4.5vw, 52px);width:100%}
h1,h2,h3,h4{color:var(--azul-deep);line-height:1.25;font-weight:800}
.muted{color:var(--muted)}

.btn{display:inline-block;background:var(--azul);color:#fff;padding:.78rem 1.7rem;border-radius:999px;
  font-weight:700;border:0;cursor:pointer;font-size:.9rem;letter-spacing:.3px;
  box-shadow:0 6px 16px rgba(31,95,176,.28);transition:.18s}
.btn:hover{transform:translateY(-2px);color:#fff;box-shadow:0 10px 22px rgba(31,95,176,.36)}
.btn-acento{background:var(--gold);color:#3a2e00;box-shadow:0 6px 16px rgba(244,194,13,.35)}
.btn-acento:hover{color:#3a2e00}
.btn-sm{padding:.45rem 1.05rem;font-size:.78rem}
.link-more{font-weight:700;white-space:nowrap;color:var(--azul);font-size:.9rem}
.link-more:hover{color:var(--verde)}

/* ===== Cabecera ===== */
.masthead{background:#fff;padding:1.5rem 0;border-bottom:1px solid var(--linea)}
.masthead-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;align-items:center;gap:16px;color:#1a1a1a}
.brand:hover{text-decoration:none}
.brand-logo{height:92px;width:auto}
.brand-text{display:flex;flex-direction:column}
.brand-name{font-size:2rem;font-weight:800;letter-spacing:1px;color:var(--azul-deep);line-height:1}
.brand-rule{height:3px;width:54px;background:linear-gradient(90deg,var(--azul),var(--verde));
  border-radius:2px;margin:8px 0 6px}
.brand-sub{font-size:.9rem;color:#555;font-weight:600}
.brand-quote{font-size:.8rem;color:#8a8a8a;font-style:italic;margin-top:2px}
.masthead-right{display:flex;flex-direction:column;align-items:stretch;gap:.55rem;flex:0 0 auto}
.masthead-republica{display:flex;align-items:center;width:100%;
  justify-content:flex-start;gap:.55rem}
.masthead-republica img{height:40px;width:auto;flex:0 0 auto}
.masthead-republica span{font-family:'Playfair Display','Times New Roman',serif;font-style:italic;
  font-weight:500;font-size:1.32rem;color:#1a1a1a;line-height:1;white-space:nowrap;
  flex:0 0 auto}
.masthead-eyebrow span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.site-search{display:flex;width:100%}
.site-search input{flex:1;border:2px solid var(--azul);border-right:0;padding:.62rem .9rem;
  font-size:.95rem;font-family:inherit;border-radius:5px 0 0 5px;outline:none;background:#fff;color:#333}
.site-search input::placeholder{color:#9aa3b2}
.site-search button{background:var(--azul);color:#fff;border:2px solid var(--azul);
  padding:0 1.1rem;font-size:1.05rem;border-radius:0 5px 5px 0;cursor:pointer}
.site-search button:hover{background:var(--azul-osc);border-color:var(--azul-osc)}
.top-links{font-size:.86rem;color:#667;font-weight:600;letter-spacing:.3px;
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:0 .15rem}
.top-links a{color:#667}
.top-links a:hover{color:var(--azul)}
.top-links span{color:#cbd2dd}

/* ===== Menú ===== */
.mainnav{background:linear-gradient(90deg,var(--azul-deep),var(--azul));position:sticky;top:0;z-index:60;
  box-shadow:0 4px 16px rgba(18,48,92,.18)}
.mainnav-inner{display:flex;align-items:stretch;justify-content:flex-start;flex-wrap:wrap}
.mainnav-links{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:stretch;
  width:100%}
.mainnav a{color:#eaf1fb;padding:1rem 1.25rem;font-size:.83rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.6px;display:flex;align-items:center}
.mainnav a:hover{background:rgba(255,255,255,.13);color:#fff}
.mainnav a.active{background:#fff;color:var(--azul-deep)}

.has-dropdown{position:relative;display:flex;align-items:stretch}
.has-dropdown > a{height:100%}
.has-dropdown > a::after{content:" ▾";font-size:.7em;opacity:.85}
.has-dropdown .dropdown{position:absolute;top:100%;left:0;min-width:260px;background:#fff;
  box-shadow:0 12px 30px rgba(0,0,0,.22);border-radius:0 0 10px 10px;
  border-top:3px solid var(--verde);opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .15s, transform .15s;z-index:80;padding:.3rem 0}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{
  opacity:1;visibility:visible;transform:translateY(0)}
.has-dropdown .dropdown a{display:block;color:var(--azul-deep);padding:.7rem 1.1rem;
  font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  border-bottom:1px solid var(--linea);border-radius:0}
.has-dropdown .dropdown a:last-child{border-bottom:0}
.has-dropdown .dropdown a:hover{background:var(--bg);color:var(--verde)}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:.9rem;
  padding:.7rem 1rem;cursor:pointer;font-weight:700;text-transform:uppercase}

/* ===== Hero ===== */
.hero{background:linear-gradient(120deg,var(--azul-deep),var(--azul) 60%,var(--verde));
  color:#fff;background-size:cover;background-position:center;padding:6rem 0}
.hero-inner{max-width:760px;margin:0}

/* ===== Slider de portada ===== */
.slider{position:relative;height:clamp(360px,52vw,560px);overflow:hidden;background:var(--azul-deep)}
.slider-track{position:absolute;inset:0}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;
  display:flex;align-items:center;opacity:0;visibility:hidden;
  transition:opacity .7s ease;z-index:1}
.slide.is-active{opacity:1;visibility:visible;z-index:2}
.slide-inner{color:#fff}
.slide-inner .slide-eyebrow{display:inline-block;background:var(--gold);color:#3a2e00;
  font-weight:700;font-size:.78rem;padding:.3rem .9rem;border-radius:999px;
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem}
.slide-inner h2{color:#fff;font-size:clamp(1.3rem,3.4vw,2.6rem);font-weight:800;line-height:1.18;
  margin:0 0 1.2rem;max-width:780px;text-shadow:0 2px 14px rgba(0,0,0,.35);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.22);color:#fff;font-size:1.7rem;line-height:1;
  display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.slider-arrow:hover{background:rgba(255,255,255,.38)}
.slider-arrow.prev{left:18px}.slider-arrow.next{right:18px}
.slider-dots{position:absolute;bottom:20px;left:0;right:0;z-index:5;
  display:flex;gap:10px;justify-content:center}
.slider-dots .dot{width:11px;height:11px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.45);padding:0}
.slider-dots .dot.is-active{background:#fff;transform:scale(1.15)}
.hero h1{color:#fff;font-size:clamp(1.8rem,4.4vw,2.9rem);margin:0 0 .8rem;font-weight:800;line-height:1.14}
.hero p{font-size:clamp(1rem,2vw,1.18rem);color:#eaf1fb;margin:0 0 2rem;font-weight:400}

/* ===== Banda 3 columnas ===== */
.band{background:var(--bg);padding:3.2rem 0}
.band-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;align-items:stretch}
.band-col{display:flex;flex-direction:column}
.band-title{font-size:1.2rem;text-transform:uppercase;font-weight:800;color:var(--azul-deep);
  margin:0 0 1rem;letter-spacing:.5px;display:flex;align-items:center;gap:.6rem}
.band-title::before{content:"";width:26px;height:4px;border-radius:2px;
  background:linear-gradient(90deg,var(--azul),var(--verde))}
.band-card,.band-feature,.band-gallery-card{background:#fff;border-radius:var(--r);
  box-shadow:var(--shadow);flex:1;display:flex;flex-direction:column;overflow:hidden}
.band-card{padding:1.6rem}
.band-card p{margin:0 0 1rem;color:#475066;font-size:.97rem;flex:1}
.band-feature{transition:.18s;color:inherit}
.band-feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-h);text-decoration:none}
.band-feature img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;flex:none}
.band-feature-cap{display:block;color:var(--azul-deep);font-weight:700;padding:.95rem 1.1rem;
  font-size:1rem;background:#fff;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.band-gallery-card{padding:.85rem}
.band-gallery{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;
  flex:1;min-height:0}
.band-gallery a{display:block;background-size:cover;background-position:center;
  border-radius:8px;background-color:#dde3ec;transition:.18s}
.band-gallery a:hover{transform:scale(1.03)}

/* ===== Secciones ===== */
.section{padding:3.6rem 0}
.section-alt{background:var(--bg)}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  margin-bottom:2rem;flex-wrap:wrap}
.section-title{font-size:1.7rem;margin:0;font-weight:800;color:var(--azul-deep);
  display:flex;align-items:center;gap:.7rem}
.section-title::before{content:"";width:34px;height:5px;border-radius:3px;
  background:linear-gradient(90deg,var(--azul),var(--verde))}
.page-head{background:linear-gradient(120deg,var(--azul-deep),var(--azul));color:#fff;padding:3rem 0}
.page-head h1{color:#fff;margin:0;font-weight:800;padding-left:1.25rem}
.page-head .breadcrumb{padding-left:1.25rem}

/* ===== Tarjetas de servicios ===== */
.serv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.8rem}
.serv-card{display:flex;flex-direction:column;align-items:center;text-align:center;color:var(--azul-deep);
  background:#fff;border-radius:var(--r);padding:1.4rem;box-shadow:var(--shadow);transition:.18s}
.serv-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-h)}
.serv-img{width:100%;height:140px;border-radius:10px;background-size:cover;background-position:center;
  background-color:#eef2f8;display:flex;align-items:center;justify-content:center;
  font-size:2.6rem;font-weight:800;color:#b9c6dc}
.serv-stars{color:var(--gold);letter-spacing:3px;font-size:.95rem;margin:.85rem 0 .3rem}
.serv-titulo{font-weight:700;font-size:1.02rem;color:var(--azul-deep)}
.serv-card:hover .serv-titulo{color:var(--verde)}

/* ===== Noticias 2 columnas ===== */
.news-cols{display:grid;grid-template-columns:1fr 1fr;gap:2rem 3rem}
.news-list{display:block}
.news-item{display:flex;gap:1.4rem;padding:1rem 0;background:transparent;box-shadow:none;
  border:0;border-radius:0;transition:none;align-items:flex-start}
.news-item:hover{transform:none;box-shadow:none}
.news-thumb{flex:0 0 175px;width:175px;height:175px;border-radius:6px;overflow:hidden;background:#eef2f8;display:block;
  border:1px solid var(--linea);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.news-thumb img{width:100%;height:100%;object-fit:cover;transition:.25s}
.news-thumb:hover img{transform:scale(1.06)}
.news-thumb-ph{display:flex;align-items:center;justify-content:center;height:100%;
  color:#b9c6dc;font-weight:800;font-size:.8rem}
.news-body{flex:1;min-width:0}
.news-body h3{margin:0 0 .35rem;font-size:1.1rem;font-weight:800;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-body h3 a{color:var(--azul-deep)}
.news-body h3 a:hover{color:var(--verde)}
.news-date{display:block;color:var(--muted);font-size:.8rem;font-style:italic;margin-bottom:.5rem}
.news-body p{margin:0 0 .6rem;color:#5a6478;font-size:.9rem;text-align:justify;hyphens:auto;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}

/* ===== Galería ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery-item{position:relative;display:block;aspect-ratio:1;border-radius:12px;overflow:hidden;
  background:#eef2f8;box-shadow:var(--shadow)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.25s}
.gallery-item:hover img{transform:scale(1.07)}
.gallery-caption{position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(transparent,rgba(18,48,92,.85));
  color:#fff;font-size:.8rem;padding:1.2rem .7rem .55rem}

/* ===== Lightbox (visor de galería) ===== */
.lightbox{position:fixed;inset:0;background:rgba(8,18,40,.92);display:none;
  align-items:center;justify-content:center;z-index:999;
  animation:lbFade .18s ease}
.lightbox.is-open{display:flex}
.lb-figure{margin:0;max-width:min(94vw,1100px);max-height:90vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative}
.lb-img{max-width:100%;max-height:80vh;width:auto;height:auto;
  border-radius:8px;box-shadow:0 16px 50px rgba(0,0,0,.6);background:#fff}
.lb-caption{color:#fff;text-align:center;font-size:.95rem;margin-top:1rem;
  max-width:800px;line-height:1.4}
.lb-counter{color:rgba(255,255,255,.6);font-size:.82rem;font-weight:600;margin-top:.4rem;letter-spacing:.5px}
.lb-close,.lb-arrow{position:absolute;background:rgba(255,255,255,.15);border:0;cursor:pointer;
  color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;
  transition:.15s;backdrop-filter:blur(4px)}
.lb-close:hover,.lb-arrow:hover{background:rgba(255,255,255,.3)}
.lb-close{top:20px;right:20px;width:46px;height:46px;font-size:1.8rem;line-height:1}
.lb-arrow{top:50%;transform:translateY(-50%);width:56px;height:56px;font-size:2rem;line-height:1;z-index:5}
.lb-prev{left:24px}.lb-next{right:24px}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
@media(max-width:680px){
  .lb-arrow{width:44px;height:44px;font-size:1.6rem}
  .lb-prev{left:8px}.lb-next{right:8px}
  .lb-close{top:10px;right:10px;width:40px;height:40px}
}

/* ===== Páginas de contenido / Artículo ===== */
.article{padding:3.2rem 0;background:var(--bg)}
.section:has(> .article-narrow){background:var(--bg)}
.section > .article-narrow,
.article > .article-narrow{
  max-width:900px;margin:0 auto;background:#fff;border:1px solid var(--linea);
  border-radius:var(--r);box-shadow:var(--shadow);padding:2.6rem 2.8rem}
.article-narrow .article-date{margin-top:0}
.article-date{display:block;color:var(--muted);font-style:italic;font-size:.9rem;margin:1rem 0 .3rem}
.article h1{font-size:2.2rem;margin:.2rem 0 1.3rem;font-weight:800}
.article-hero{width:100%;border-radius:var(--r);margin-bottom:1.6rem;box-shadow:var(--shadow)}
.article-body{font-size:1.07rem;color:#3c4658;text-align:justify;hyphens:auto;word-spacing:.02em}
.article-body p{text-align:justify}
.gallery-title{margin:2.6rem 0 1.2rem;font-size:1.3rem;font-weight:800;display:flex;
  align-items:center;gap:.6rem}
.gallery-title::before{content:"";width:30px;height:5px;border-radius:3px;
  background:linear-gradient(90deg,var(--azul),var(--verde))}

.pagination{display:flex;gap:6px;justify-content:center;margin-top:2.6rem;flex-wrap:wrap}
.pagination a,.pagination span{padding:.55rem .9rem;border:1px solid var(--linea);border-radius:6px;
  color:var(--azul);font-weight:700;background:#fff;font-size:.92rem;
  min-width:38px;text-align:center;display:inline-block;line-height:1.2}
.pagination a:hover{background:var(--bg);text-decoration:none}
.pagination a.active{background:var(--azul);color:#fff;border-color:var(--azul);cursor:default}
.pagination span.disabled{color:#c5cad3;background:#f7f8fa}
.pagination span.dots{border:0;background:transparent;color:var(--muted);font-weight:400}

/* ===== Carpetas de galería ===== */
.carpeta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.carpeta-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--linea);
  border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:.18s;
  color:inherit;text-decoration:none}
.carpeta-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-h);text-decoration:none}
.carpeta-cover{position:relative;aspect-ratio:16/10;background:linear-gradient(135deg,var(--azul),var(--verde));
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.carpeta-cover img{width:100%;height:100%;object-fit:cover}
.carpeta-cover-ph{font-size:3rem;color:rgba(255,255,255,.7)}
.carpeta-count{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.65);color:#fff;
  font-size:.78rem;font-weight:700;padding:.25rem .7rem;border-radius:999px}
.carpeta-info{padding:1.1rem 1.2rem}
.carpeta-info h3{margin:0 0 .25rem;font-size:1.1rem;color:var(--azul-deep)}
.carpeta-info p{margin:0;color:#5a6478;font-size:.9rem;display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ===== Subpáginas "Sobre Nosotros" — layout 2 cols + sidebar ===== */
.page-head .breadcrumb{color:rgba(255,255,255,.85);font-size:.85rem;margin-bottom:.55rem;
  letter-spacing:.3px}
.page-head .breadcrumb strong{font-weight:700;margin-right:.3rem}
.page-head .breadcrumb a{color:rgba(255,255,255,.85)}
.page-head .breadcrumb a:hover{color:#fff;text-decoration:underline}

.section:has(> .sub-layout){background:var(--bg)}
.sub-layout{display:grid;grid-template-columns:1fr 280px;gap:2rem;align-items:start}
.sub-content{background:#fff;border:1px solid var(--linea);border-radius:var(--r);
  box-shadow:var(--shadow);padding:2.4rem 2.6rem;min-width:0}
.sub-content h2{margin:1.8rem 0 .8rem;font-size:1.25rem;color:var(--azul-deep);
  border-left:4px solid var(--verde);padding-left:.8rem}
.sub-content h2:first-child{margin-top:0}
.sub-content .article-body{text-align:justify;hyphens:auto;color:#3c4658;font-size:1rem;
  line-height:1.75}
.sub-content .article-body p{margin:0 0 1rem}
.sub-content .article-body p:last-child{margin-bottom:0}
.sub-content .article-body strong{color:var(--azul-deep)}
.sub-content .article-body br + br{display:block;content:"";margin-top:.8rem}

.sub-sidebar{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;
  position:sticky;top:90px}
.sub-sidebar h3{background:linear-gradient(135deg,var(--azul-deep),var(--azul));color:#fff;
  margin:0;padding:1rem 1.2rem;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;
  font-weight:800}
.sub-sidebar ul{list-style:none;padding:0;margin:0}
.sub-sidebar li{border-bottom:1px solid var(--linea)}
.sub-sidebar li:last-child{border-bottom:0}
.sub-sidebar a,.sub-sidebar li.current{display:block;padding:.85rem 1.2rem;
  color:var(--azul-deep);font-weight:600;font-size:.92rem;line-height:1.3}
.sub-sidebar a:hover{background:var(--bg);color:var(--verde);text-decoration:none}
.sub-sidebar li.current{background:var(--verde);color:#fff}

/* ===== Despacho del Presidente ===== */
.presidente-box{background:#fff;border:1px solid var(--linea);border-radius:var(--r);
  box-shadow:var(--shadow);padding:2.2rem 2.4rem}
.presidente-box::after{content:"";display:block;clear:both}
.presidente-box--in-card{background:transparent;border:0;box-shadow:none;padding:0}
.presidente-foto{float:left;width:240px;aspect-ratio:3/4;border-radius:12px;overflow:hidden;
  background:linear-gradient(135deg,var(--azul),var(--verde));display:flex;
  align-items:center;justify-content:center;margin:0 1.8rem 1rem 0}
.presidente-info{display:block;text-align:justify;hyphens:auto}
.presidente-info > .article-body{text-align:justify;hyphens:auto;line-height:1.75;color:#3c4658}
.presidente-info > .article-body p{margin:0 0 1rem}
.presidente-foto img{width:100%;height:100%;object-fit:cover}
.presidente-foto span{color:#fff;font-weight:800;font-size:5rem}
.presidente-cargo{display:inline-block;background:var(--verde);color:#fff;
  font-size:.78rem;text-transform:uppercase;font-weight:700;letter-spacing:.5px;
  padding:.3rem .9rem;border-radius:999px;margin-bottom:.7rem}
.presidente-info h2{font-size:2rem;margin:0 0 1rem;color:var(--azul-deep)}

/* ===== Directorio de Funcionarios ===== */
.func-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.func-grid--in-card{grid-template-columns:repeat(3,1fr);gap:1.2rem}
.func-card{background:#fff;border:1px solid var(--linea);border-radius:var(--r);
  box-shadow:var(--shadow);padding:1.2rem;text-align:center;transition:.18s}
.func-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-h)}
.func-foto{width:100%;aspect-ratio:4/5;border-radius:10px;overflow:hidden;
  background:linear-gradient(135deg,var(--azul),var(--verde));margin:0 auto 1rem;
  display:flex;align-items:center;justify-content:center}
.func-foto img{width:100%;height:100%;object-fit:cover}
.func-foto span{color:#fff;font-weight:800;font-size:3rem}
.func-card h3{margin:.4rem 0 .25rem;font-size:1.05rem;color:var(--azul-deep)}
.func-cargo{margin:0;color:var(--verde);font-weight:600;font-size:.88rem}

/* ===== Lista de documentos descargables ===== */
.doc-list{margin-top:2rem;border-top:1px solid var(--linea);padding-top:1.5rem}
.doc-list-title{font-size:1.05rem;color:var(--azul-deep);margin:0 0 1rem;font-weight:800}
.doc-item{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;
  background:#fff;border:1px solid var(--linea);border-radius:8px;margin-bottom:.6rem;
  color:var(--txt);transition:.15s}
.doc-item:hover{background:var(--bg);border-color:var(--azul);text-decoration:none;
  transform:translateX(3px)}
.doc-ico{flex:0 0 48px;width:48px;height:48px;border-radius:6px;color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.78rem;
  letter-spacing:.5px}
.doc-meta{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}
.doc-titulo{font-weight:600;color:var(--azul-deep);font-size:.95rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-tam{font-size:.78rem;color:var(--muted)}
.doc-download{flex:0 0 30px;color:var(--verde);font-size:1.4rem;font-weight:800}

/* ===== Portal de Transparencia ===== */
.trans-layout{display:grid;grid-template-columns:300px 1fr;gap:2rem;align-items:start}
/* Toggle del sidebar de Transparencia (solo móvil) */
.trans-side-toggle{display:none;align-items:center;justify-content:space-between;width:100%;
  background:linear-gradient(115deg,#0a2a4a,#1257a0);color:#fff;border:0;cursor:pointer;
  padding:.95rem 1.2rem;border-radius:var(--r);font-weight:700;font-size:.95rem;
  letter-spacing:.5px;text-transform:uppercase;
  box-shadow:0 6px 16px rgba(13,59,102,.18);border-bottom:3px solid #f4a300}
.trans-side-toggle .chev{font-size:1.4rem;transition:transform .2s;line-height:1}
.trans-side-toggle[aria-expanded="true"] .chev{transform:rotate(90deg)}
.trans-sidebar{background:var(--azul-deep);border-radius:var(--r);
  box-shadow:0 8px 24px rgba(0,0,0,.15);position:sticky;top:90px}
.trans-sidebar > h3{border-radius:var(--r) var(--r) 0 0}
.trans-sidebar > ul > li:last-child > a{border-radius:0 0 var(--r) var(--r)}
.trans-sidebar h3{background:rgba(255,255,255,.07);color:#fff;
  margin:0;padding:1.1rem 1.3rem;font-size:.92rem;text-transform:uppercase;letter-spacing:.6px;
  font-weight:800;text-align:center;border-bottom:1px solid rgba(255,255,255,.1)}
.trans-sidebar ul{list-style:none;padding:0;margin:0}
.trans-sidebar li{border-bottom:1px solid rgba(255,255,255,.08)}
.trans-sidebar li:last-child{border-bottom:0}
.trans-sidebar > ul > li > a{display:flex;align-items:center;gap:.6rem;padding:.9rem 1.2rem;
  color:#dde6f3;font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.4px}
.trans-sidebar > ul > li > a:hover{background:rgba(255,255,255,.06);color:#fff;text-decoration:none}
.trans-sidebar > ul > li.current > a{background:var(--azul);color:#fff}
.trans-sidebar > ul > li.has-subs > a .trans-chev{margin-left:auto;font-size:1.1rem;
  transition:transform .2s;opacity:.7}
.trans-sidebar > ul > li.expanded > a .trans-chev{transform:rotate(90deg);opacity:1}
.trans-sidebar > ul > li.has-subs.expanded > a{background:rgba(255,255,255,.04);color:#fff}
.trans-ico{font-size:1rem;opacity:.85;flex:0 0 1rem;text-align:center}
.trans-label{flex:1;line-height:1.2}

/* Submenús */
.trans-subs{list-style:none;padding:0;margin:0;background:rgba(0,0,0,.25);
  max-height:0;overflow:hidden;transition:max-height .3s}
.trans-sidebar > ul > li.expanded > .trans-subs{max-height:800px}
.trans-subs li{border-bottom:1px solid rgba(255,255,255,.05)}
.trans-subs li:last-child{border-bottom:0}
.trans-subs a{display:block;padding:.65rem 1.2rem .65rem 2.6rem;color:#aebbd1;
  font-size:.78rem;text-transform:none;letter-spacing:0;font-weight:500;line-height:1.3}
.trans-subs a:hover{background:rgba(255,255,255,.05);color:#fff;text-decoration:none}
.trans-subs li.current a{background:var(--verde);color:#fff;font-weight:600}

/* Flyout al pasar el mouse (solo escritorio) */
@media(min-width:681px){
  .trans-sidebar > ul > li.has-subs{position:relative}
  /* Sobrescribe el acordeón: el submenú ahora vuela a la derecha */
  .trans-sidebar > ul > li.has-subs > .trans-subs{
    position:absolute;left:100%;top:0;
    min-width:260px;max-width:320px;
    background:var(--azul-deep);
    border-radius:0 var(--r) var(--r) 0;
    box-shadow:8px 8px 24px rgba(0,0,0,.25);
    max-height:none;overflow:visible;
    opacity:0;visibility:hidden;transform:translateX(-6px);
    transition:opacity .18s ease,transform .18s ease,visibility .18s;
    z-index:50;padding:.3rem 0;
  }
  /* Puente invisible para que no se cierre al cruzar el gap */
  .trans-sidebar > ul > li.has-subs > .trans-subs::before{
    content:"";position:absolute;left:-10px;top:0;width:10px;height:100%;
  }
  .trans-sidebar > ul > li.has-subs:hover > .trans-subs,
  .trans-sidebar > ul > li.has-subs:focus-within > .trans-subs{
    opacity:1;visibility:visible;transform:translateX(0);
  }
  .trans-sidebar > ul > li.has-subs:hover > a,
  .trans-sidebar > ul > li.has-subs:focus-within > a{
    background:rgba(255,255,255,.08);color:#fff;
  }
  .trans-sidebar > ul > li.has-subs > a .trans-chev{
    transform:rotate(0);transition:transform .18s ease,opacity .18s ease;
  }
  .trans-sidebar > ul > li.has-subs:hover > a .trans-chev,
  .trans-sidebar > ul > li.has-subs:focus-within > a .trans-chev{
    transform:rotate(0);opacity:1;
  }
  .trans-sidebar > ul > li.has-subs > .trans-subs a{
    padding:.7rem 1.2rem;color:#dde6f3;font-size:.82rem;
  }
}

/* ====== Banner superior del Portal de Transparencia (estilo institucional) ====== */
.trans-head{position:relative;overflow:hidden;
  background:linear-gradient(115deg,#0a2a4a 0%,#0d3b66 38%,#1257a0 100%);
  padding:3.2rem 0 3.6rem;
  border-bottom:4px solid #f4a300}
.trans-head::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 85% 50%,rgba(244,163,0,.18),transparent 60%),
    radial-gradient(ellipse 50% 60% at 15% 100%,rgba(255,255,255,.08),transparent 55%);
  pointer-events:none}
.trans-head::after{content:"";position:absolute;right:-40px;top:50%;transform:translateY(-50%);
  width:260px;height:260px;opacity:.08;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><circle cx='40' cy='40' r='28' fill='none' stroke='white' stroke-width='5'/><line x1='62' y1='62' x2='90' y2='90' stroke='white' stroke-width='8' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-size:contain}
.trans-head .container{position:relative;z-index:2}
.trans-head h1{font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:800;letter-spacing:-.3px;
  margin:0;padding-left:0;text-shadow:0 2px 12px rgba(0,0,0,.25)}
.trans-head .breadcrumb{padding-left:0;margin-bottom:.8rem;
  font-size:.82rem;text-transform:uppercase;letter-spacing:.8px;font-weight:500;
  color:rgba(255,255,255,.78)}
.trans-head .breadcrumb a{color:#f4a300}
.trans-head .breadcrumb a:hover{color:#fff}

/* La sección que sigue (sidebar + contenido) se monta sobre el banner */
.trans-head + .section{padding-top:0;margin-top:-1.8rem;position:relative;z-index:3}

/* Sidebar: el h3 ahora hace juego visual con el banner superior */
.trans-sidebar h3{background:linear-gradient(115deg,#0a2a4a,#1257a0);
  border-bottom:3px solid #f4a300;letter-spacing:.8px}

/* Imagen destacada de páginas custom */
.custom-page-img{width:100%;max-height:420px;object-fit:cover;border-radius:14px;
  box-shadow:0 12px 30px rgba(13,59,102,.15);margin-bottom:1.6rem}

/* Toggle grid admin */
.tx-toggle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.7rem;margin-top:.8rem}
.tx-toggle{display:flex;align-items:center;justify-content:space-between;gap:.8rem;
  padding:.85rem 1rem;border:1px solid #e2e8f0;border-radius:10px;background:#fff;
  transition:border-color .2s,background .2s}
.tx-toggle.on{border-left:4px solid #16a34a}
.tx-toggle.off{border-left:4px solid #ef4444;background:#fef9f9;opacity:.85}
.tx-toggle-info{display:flex;flex-direction:column;line-height:1.3;font-size:.9rem}
.tx-toggle-info .muted{font-size:.74rem;margin-top:.15rem}

@media(max-width:680px){
  .trans-head{padding:1.6rem 0 1.8rem;text-align:center;border-bottom-width:3px}
  .trans-head::after{display:none}
  .trans-head::before{background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(244,163,0,.18),transparent 60%)}
  .trans-head h1{font-size:1.35rem;line-height:1.25;text-align:center;padding:0 .6rem}
  .trans-head .breadcrumb{text-align:center;font-size:.72rem;margin-bottom:.6rem;
    letter-spacing:.5px;padding:0 .6rem}
  .trans-head + .section{margin-top:0}
  .trans-head + .section .container{padding-top:1rem}
}

/* Banner de bienvenida */
.trans-banner{width:100%;max-height:280px;object-fit:cover;border-radius:var(--r);margin-bottom:1.5rem}

.trans-content{background:#fff;border:1px solid var(--linea);border-radius:var(--r);
  box-shadow:var(--shadow);padding:2rem 2.2rem;min-width:0}
.trans-content .panel-head{align-items:flex-start;margin-bottom:1.4rem;border-bottom:1px solid var(--linea);padding-bottom:1rem}
.trans-content h2{margin:0;font-size:1.4rem;color:var(--azul-deep)}
.trans-content .panel-head p{margin:.3rem 0 0}

.trans-empty{padding:2rem;text-align:center;background:var(--bg);border-radius:8px;color:var(--muted)}

/* Lista de carpetas */
.trans-carpetas{display:flex;flex-direction:column;gap:.6rem}
.trans-carpeta{display:flex;align-items:center;gap:1.1rem;padding:1.1rem 1.3rem;
  background:var(--bg);border:1px solid var(--linea);border-radius:10px;
  color:var(--azul-deep);transition:.15s}
.trans-carpeta:hover{background:#fff;border-color:var(--azul);transform:translateX(4px);
  text-decoration:none;box-shadow:0 4px 14px rgba(0,0,0,.08)}
.trans-carpeta > div{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}
.trans-folder-ico{font-size:1.8rem;flex:0 0 auto}
.trans-carpeta strong{font-size:1rem}
.trans-carpeta-meta{font-size:.78rem;color:var(--verde);font-weight:700;letter-spacing:.3px}
.trans-carpeta-desc{font-size:.85rem;color:var(--muted);margin-top:.2rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trans-arrow{color:var(--azul);font-size:1.5rem;font-weight:700;flex:0 0 auto}

/* Tabla de documentos */
.trans-tbl{width:100%;border-collapse:collapse}
.trans-tbl th{text-align:left;padding:.7rem .8rem;font-size:.78rem;color:var(--muted);
  text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--linea)}
.trans-tbl td{padding:1rem .8rem;border-bottom:1px solid var(--linea);vertical-align:middle;font-size:.92rem}
.trans-tbl tr:hover td{background:var(--bg)}
.trans-doc-ico{margin-right:.6rem;vertical-align:middle}
.trans-acciones{white-space:nowrap}
.trans-acciones a{display:inline-block;margin-right:.7rem;color:var(--azul);font-weight:600;
  font-size:.85rem}
.trans-acciones a:hover{color:var(--verde)}

/* ===== Detalle de servicio ===== */
.servicio-detalle{background:#fff;border:1px solid var(--linea);border-radius:var(--r);
  box-shadow:var(--shadow);padding:2.2rem 2.4rem;max-width:920px;margin:0 auto}
.servicio-imagen{margin:-2.2rem -2.4rem 2rem;overflow:hidden;border-radius:var(--r) var(--r) 0 0}
.servicio-imagen img{width:100%;max-height:300px;object-fit:cover;display:block}
.serv-block{margin-bottom:1.5rem;border:1px solid var(--linea);border-radius:10px;
  padding:1rem 1.2rem;background:var(--bg)}
.serv-block h2{font-style:italic;font-size:1.1rem;color:var(--azul);margin:0 0 .5rem}
.serv-block p{margin:0;color:#3c4658;font-size:.97rem;line-height:1.6}
.serv-contacto{border-left:4px solid var(--azul);padding:.9rem 1.2rem;background:#f7f9fc;
  border-radius:6px;margin-bottom:1.5rem}
.serv-contacto p{margin:.25rem 0;color:#3c4658;font-size:.94rem}
.serv-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin:1.5rem 0}
.serv-info-card{background:#fff;border:1px solid var(--linea);border-radius:10px;
  padding:1.4rem 1rem;text-align:center;box-shadow:var(--shadow)}
.serv-info-ico{display:inline-flex;width:48px;height:48px;border-radius:50%;
  background:var(--bg);align-items:center;justify-content:center;font-size:1.4rem;
  font-weight:800;color:var(--azul);margin-bottom:.6rem}
.serv-info-card h4{margin:0 0 .25rem;font-size:.92rem;font-weight:700;color:var(--azul-deep)}
.serv-info-card p{margin:0;color:#5a6478;font-size:.92rem}
.serv-url{margin-top:1.5rem;font-weight:600}
.serv-url a{color:var(--azul)}

/* ===== Servicios (lista 2 columnas estilo FEDODIM) ===== */
.serv-intro{color:#475066;font-size:1.05rem;margin:0 0 2rem;max-width:900px}
.serv-media-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem 3rem}
.serv-media{display:flex;gap:1.4rem;align-items:flex-start}
.serv-media-img{flex:0 0 180px;width:180px;height:160px;border-radius:8px;overflow:hidden;
  background:#fff;border:1px solid var(--linea);box-shadow:0 2px 8px rgba(0,0,0,.08);
  display:flex;align-items:center;justify-content:center;transition:.18s}
.serv-media-img:hover{transform:translateY(-3px);box-shadow:0 8px 18px rgba(0,0,0,.14)}
.serv-media-img img{width:100%;height:100%;object-fit:cover}
.serv-media-img span{font-size:2.6rem;font-weight:800;color:#b9c6dc}
.serv-media-body{flex:1;min-width:0}
.serv-media-body h3{margin:0 0 .7rem;font-size:1.2rem;font-weight:800;
  font-style:italic;line-height:1.25}
.serv-media-body h3 a{color:var(--azul-deep)}
.serv-media-body h3 a:hover{color:var(--verde);text-decoration:none}
.serv-media-body p{margin:0;color:#5a6478;font-size:.95rem;line-height:1.6;text-align:justify}

/* ===== Contacto ===== */
.contacto-mapa{position:relative;background:#fff;border:1px solid var(--linea);
  border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;margin-bottom:2.2rem}
.contacto-mapa iframe{display:block;width:100%;height:360px;border:0}
.contacto-mapa .mapa-btn{position:absolute;bottom:14px;right:14px;background:var(--azul);
  color:#fff;padding:.6rem 1rem;border-radius:999px;font-weight:700;font-size:.85rem;
  box-shadow:0 6px 14px rgba(0,0,0,.25);text-decoration:none}
.contacto-mapa .mapa-btn:hover{background:var(--azul-deep);color:#fff}
.contacto-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:2.2rem;align-items:start}
.contacto-info,.contacto-form-box{background:#fff;border:1px solid var(--linea);
  border-radius:var(--r);box-shadow:var(--shadow);padding:2rem 2.1rem}
.contacto-intro{color:#475066;margin:.4rem 0 1.2rem}
.contact-list{list-style:none;padding:0;margin:1.2rem 0 0}
.contact-list li{padding:.7rem 0;border-bottom:1px solid var(--linea);display:flex;
  flex-direction:column;gap:.15rem}
.contact-list li strong{color:var(--azul-deep);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}
.contact-list li span{color:#444;font-size:1rem}
.contacto-rs{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.2rem}
.contacto-rs a{background:var(--bg);border:1px solid var(--linea);border-radius:999px;
  padding:.4rem 1rem;font-size:.85rem;font-weight:600}
.form-contacto{display:flex;flex-direction:column}
.form-contacto label{font-weight:600;font-size:.88rem;margin:.9rem 0 .35rem;color:var(--azul-deep)}
.form-contacto input,.form-contacto textarea{border:1px solid var(--linea);border-radius:8px;
  padding:.7rem .85rem;font-size:1rem;font-family:inherit;background:var(--bg)}
.form-contacto input:focus,.form-contacto textarea:focus{outline:none;border-color:var(--azul);background:#fff}
.form-contacto .btn{align-self:flex-start;margin-top:1.3rem}
.form-contacto .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-ok{background:#e6f7ec;color:#176b33;border:1px solid #b6e3c6;padding:.9rem 1.1rem;
  border-radius:8px;margin-bottom:1rem;font-weight:600}
.form-err{background:#fdeaea;color:#a32020;border:1px solid #f3c2c2;padding:.8rem 1.1rem;
  border-radius:8px;margin-bottom:1rem}
.form-err ul{margin:.2rem 0;padding-left:1.1rem}

/* ===== Banda de redes ===== */
.enlaces-band{background:linear-gradient(120deg,var(--azul-deep),var(--azul));color:#fff;
  padding:3.4rem 0;margin-top:3.5rem}
.enlaces-title{color:#fff;font-weight:800;font-size:1.5rem;margin:0 0 1.8rem;text-align:center}
.social-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;max-width:880px;margin:0 auto}
.sb{display:flex;align-items:center;justify-content:center;padding:1.05rem;border-radius:6px;
  color:#fff;font-weight:700;font-size:1rem;letter-spacing:.3px;transition:.18s}
.sb:hover{color:#fff;transform:translateY(-3px)}
.sb-fb{background:#1877f2}.sb-tw{background:#1da1f2}.sb-yt{background:#e0241b}
.sb-ig{background:linear-gradient(45deg,#f58529,#dd2a7b,#8134af)}

/* ===== Footer ===== */
.site-footer{background:var(--azul-deep);color:#c4cfe0;padding:3.2rem 0}
.footer-center{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.footer-marks{display:flex;align-items:center;justify-content:center;gap:1.1rem;margin-bottom:.7rem}
.footer-mark{height:64px;width:auto}
.footer-escudo{height:64px;width:auto}
.footer-divider{display:inline-block;width:1px;height:46px;background:rgba(255,255,255,.55)}
.site-footer h3{color:#fff;margin:.2rem 0 .5rem;font-weight:800;font-size:1.15rem}
.site-footer p{margin:.2rem 0;font-size:.92rem;color:#aebbd1}
.site-footer a{color:#aebbd1}.site-footer a:hover{color:#fff}
.footer-links{margin-top:.8rem!important;font-weight:600}
.footer-copy{margin-top:.7rem!important;font-size:.84rem;color:#8392ac}

@media(max-width:1024px){
  .hero{padding:4.5rem 0}
  .section{padding:2.8rem 0}
  .section > .article-narrow,.article > .article-narrow{padding:2rem 1.6rem}
}
@media(max-width:980px){
  .band-grid{grid-template-columns:1fr;gap:1.6rem}
  .serv-grid{grid-template-columns:repeat(2,1fr)}
  .news-cols{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .social-buttons{grid-template-columns:repeat(2,1fr)}
  .masthead-inner{flex-wrap:wrap;gap:1.2rem}
  .masthead-right{align-items:stretch;width:100%;flex:1 1 100%;max-width:480px}
  .top-links{text-align:center}
  .contacto-grid{grid-template-columns:1fr}
  .serv-media-grid{grid-template-columns:1fr}
  .presidente-foto{float:none;width:100%;max-width:280px;margin:0 auto 1.4rem}
  .presidente-info{text-align:left}
  .func-grid{grid-template-columns:repeat(3,1fr)}
  .sub-layout{grid-template-columns:1fr}
  .sub-sidebar{position:static}
  .carpeta-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  /* Esconder bloque derecho del header (escudo + buscador + links) en móvil */
  .masthead-right{display:none}
  .masthead{padding:1rem 0}
  .masthead-inner{justify-content:center}
  .brand{justify-content:center}
  .brand-name{font-size:1.55rem}.brand-logo{height:60px}

  /* ===== Menú móvil ===== */
  .mainnav{background:var(--azul-deep)}
  .mainnav-inner{display:block;padding:0;width:100%;max-width:100%}
  .nav-toggle{display:flex;align-items:center;justify-content:space-between;
    width:100%;background:transparent;color:#fff;font-size:.95rem;
    padding:1rem 1.2rem;font-weight:700;text-transform:uppercase;border:0;cursor:pointer}
  .nav-toggle::after{content:"▾";font-size:1rem;transition:transform .2s}
  body.nav-open .nav-toggle::after{transform:rotate(180deg)}
  .mainnav-links{display:none !important;flex-direction:column;width:100%;
    background:var(--azul-deep);justify-content:flex-start !important;
    border-top:1px solid rgba(255,255,255,.12);gap:0}
  body.nav-open .mainnav-links{display:flex !important}
  .mainnav-links > a,.mainnav-links > .has-dropdown{width:100%;display:block;padding:0;margin:0;
    border-bottom:1px solid rgba(255,255,255,.08)}
  .mainnav-links > a{padding:.9rem 1.4rem;font-size:.85rem;color:#fff;
    border-radius:0;background:transparent}
  .mainnav-links > a.active{background:var(--azul)}
  .has-dropdown{position:static;display:block;align-items:initial}
  .has-dropdown > a{display:flex !important;justify-content:space-between;align-items:center;
    padding:.9rem 1.4rem;font-size:.85rem;color:#fff;border-radius:0;background:transparent}
  .has-dropdown > a::after{content:"▾";font-size:.85rem;transition:transform .2s;opacity:.85}
  .has-dropdown.is-open > a::after{transform:rotate(180deg)}
  .has-dropdown .dropdown{position:static;width:100%;display:none;
    opacity:1;visibility:visible;transform:none;
    background:rgba(0,0,0,.22);box-shadow:none;border:0;border-radius:0;padding:0}
  .has-dropdown.is-open .dropdown{display:block}
  .has-dropdown .dropdown a{display:block;padding:.7rem 1.4rem .7rem 2.6rem;
    color:#cdd9e6;font-size:.78rem;background:transparent;
    border-bottom:1px solid rgba(255,255,255,.05);border-radius:0}
  .has-dropdown .dropdown a:last-child{border-bottom:0}

  /* Hero/slider más compactos */
  .hero{padding:4rem 0}.hero h1{font-size:1.95rem}
  .slider{height:clamp(280px,80vw,420px)}
  .slide-inner h2{font-size:1.4rem;line-height:1.22}

  /* Cards/listas a 1 columna o 2 según corresponda */
  .news-item{flex-direction:column}.news-thumb{flex:none;width:100%;height:200px}
  .gallery-grid,.social-buttons,.func-grid{grid-template-columns:repeat(2,1fr)}
  .carpeta-grid{grid-template-columns:1fr;gap:1rem}
  .trans-layout{grid-template-columns:1fr;gap:.7rem;margin-top:.4rem}
  .trans-side-toggle{display:flex;padding:.85rem 1rem;font-size:.88rem}
  .trans-sidebar{position:static;display:none}
  .trans-sidebar.is-open{display:block;animation:transSlide .25s ease}
  @keyframes transSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
  .trans-sidebar > h3{font-size:.85rem;padding:.85rem 1rem}
  .trans-sidebar > ul > li > a{padding:.85rem 1rem;font-size:.78rem}
  .trans-subs a{padding:.6rem 1rem .6rem 2.2rem !important;font-size:.78rem !important}
  .trans-content{padding:1rem;border-radius:10px}
  .trans-content h2{font-size:1.15rem}
  .trans-content{padding:1.2rem}
  .trans-tbl thead{display:none}
  .trans-tbl,.trans-tbl tbody,.trans-tbl tr,.trans-tbl td{display:block;width:100%}
  .trans-tbl tr{border:1px solid var(--linea);border-radius:8px;margin-bottom:.8rem;padding:.6rem;background:var(--bg)}
  .trans-tbl td{border:0;padding:.35rem 0;font-size:.9rem}
  .trans-tbl td:first-child{font-size:1rem}
  .trans-acciones a{display:inline-block;margin:.4rem .6rem 0 0;padding:.4rem .8rem;
    background:var(--azul);color:#fff;border-radius:999px;font-size:.8rem}
  .trans-acciones a:hover{background:var(--azul-deep);color:#fff}
  .serv-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
  .serv-img{height:120px;font-size:2rem}
  .serv-titulo{font-size:.85rem;line-height:1.2}
  .serv-media-grid{grid-template-columns:1fr}
  .serv-media{flex-direction:column}
  .serv-media-img{flex:none;width:100%;height:170px}

  /* Galería de fotos en banda de portada */
  .band-grid{grid-template-columns:1fr;gap:1.2rem}
  .band-gallery{grid-template-columns:1fr 1fr;grid-template-rows:120px 120px;min-height:240px}
  .band-feature img{aspect-ratio:16/10}

  /* ===== Tipografía móvil consistente ===== */
  .page-head{padding:1.8rem 0}
  .page-head h1{font-size:1.6rem;padding-left:0}
  .page-head .breadcrumb{font-size:.78rem;padding-left:0;margin-bottom:.4rem}
  .container{padding:0 1rem}

  .section-title{font-size:1.3rem}
  .section{padding:2rem 0}
  .section-head{margin-bottom:1.2rem}
  .link-more{font-size:.82rem}

  /* Tarjetas de álbumes (galería principal) */
  .carpeta-cover{aspect-ratio:16/9}
  .carpeta-info{padding:1rem 1.2rem}
  .carpeta-info h3{font-size:1.05rem;line-height:1.3;margin-bottom:.4rem}
  .carpeta-info p{font-size:.88rem;line-height:1.5}
  .carpeta-count{font-size:.72rem;padding:.22rem .6rem}

  /* Tarjetas de noticias */
  .news-body h3{font-size:1.05rem;line-height:1.3}
  .news-body p{font-size:.88rem;line-height:1.5}
  .news-date{font-size:.76rem}

  /* Subpáginas (Quiénes Somos, etc.) */
  .sub-content{padding:1.4rem 1.2rem}
  .sub-content h2{font-size:1.1rem;margin:1.2rem 0 .6rem}
  .sub-content .article-body{font-size:.95rem;line-height:1.65}
  .sub-sidebar h3{font-size:.85rem;padding:.85rem 1rem}
  .sub-sidebar a,.sub-sidebar li.current{padding:.75rem 1rem;font-size:.86rem}

  /* Footer */
  .site-footer h3{font-size:1.05rem}
  .site-footer p{font-size:.85rem}

  /* Botones servicios cards */
  .serv-stars{font-size:.82rem;margin:.5rem 0 .2rem}

  /* Píldora "PRESIDENTE" más pequeña */
  .presidente-cargo{font-size:.7rem;padding:.25rem .7rem}
  .presidente-info h2{font-size:1.5rem;margin-bottom:.7rem}
}
