/* ===== CIESOL — tema azul, limpio y responsive ===== */
:root{
  --azul:#306090;          /* azul del logo CIESOL */
  --azul-osc:#244c72;      /* tono oscuro armonizado con el logo (cabecera/pie) */
  --azul-claro:#4a86bb;
  --azul-suave:#e8f0f8;
  --gris:#5a6573;
  --gris-bg:#f5f7fa;
  --texto:#222;
  --borde:#e2e8f0;
  --radio:10px;
  --ancho:1140px;
  --sombra:0 2px 14px rgba(20,73,124,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Montserrat","Segoe UI",system-ui,Arial,sans-serif;color:var(--texto);background:#fff;line-height:1.6}
h1,h2,h3,h4{font-family:"Montserrat",sans-serif}
img{max-width:100%;height:auto;display:block}
a{color:var(--azul-claro);text-decoration:none}
a:hover{text-decoration:underline}
.contenedor{max-width:var(--ancho);margin:0 auto;padding:0 20px}

/* Barra superior */
.topbar{background:var(--azul-osc);color:#fff;font-size:.9rem}
.topbar .contenedor{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar a{color:#fff}
.topbar .idiomas a{margin-left:10px;opacity:.85}
.topbar .idiomas a.activo{font-weight:700;opacity:1;text-decoration:underline}

/* Cabecera */
.cabecera{background:#fff;border-bottom:1px solid var(--borde);position:sticky;top:0;z-index:50}
.cabecera .contenedor{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px}
.logo{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--azul);font-size:1.5rem;letter-spacing:.5px;flex-shrink:0}
.logo img{height:54px;width:auto;flex:none}
nav.menu .nivel0{list-style:none;display:flex;gap:2px;margin:0;padding:0}
nav.menu li{position:relative}
nav.menu a{display:block;padding:10px 12px;color:var(--azul-osc);font-weight:600;border-radius:8px;text-decoration:none;white-space:nowrap;font-size:.95rem}
nav.menu .nivel0>li>a:hover{background:var(--azul-suave);color:var(--azul)}
nav.menu .flecha{font-size:.7em;opacity:.7}
/* Submenús */
nav.menu .submenu{list-style:none;margin:0;padding:6px;position:absolute;top:100%;left:0;min-width:250px;background:#fff;border:1px solid var(--borde);border-radius:10px;box-shadow:0 10px 30px rgba(20,73,124,.16);opacity:0;visibility:hidden;transform:translateY(8px);transition:.15s;z-index:100}
nav.menu li:hover>.submenu{opacity:1;visibility:visible;transform:translateY(0)}
nav.menu .submenu a{font-weight:500;padding:9px 12px;border-radius:6px}
nav.menu .submenu a:hover{background:var(--azul-suave);color:var(--azul)}
nav.menu .submenu3{top:0;left:100%;margin-left:2px}
nav.menu .submenu .tiene-hijos>a{display:flex;justify-content:space-between;gap:10px}
.menu-btn{display:none;background:none;border:0;font-size:1.6rem;color:var(--azul);cursor:pointer}

/* Hero */
.hero{background:linear-gradient(120deg,var(--azul),var(--azul-claro));color:#fff;padding:64px 0;position:relative;overflow:hidden}
.hero.con-foto{background:linear-gradient(100deg,rgba(15,52,88,.92) 0%,rgba(22,73,124,.85) 45%,rgba(47,127,193,.6) 100%),var(--img) center/cover no-repeat}
.hero .contenedor{position:relative;z-index:2}
.hero h1{font-size:2.4rem;margin:0 0 12px}
.hero p{font-size:1.15rem;max-width:680px;opacity:.95}
.hero .botones{margin-top:22px;display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-block;padding:11px 20px;border-radius:8px;font-weight:600;border:2px solid #fff;color:#fff}
.btn:hover{background:#fff;color:var(--azul);text-decoration:none}
.btn.solido{background:#fff;color:var(--azul)}
.btn.azul{background:var(--azul);color:#fff;border-color:var(--azul)}
.btn.azul:hover{background:var(--azul-osc);color:#fff}

/* Secciones */
section.bloque{padding:54px 0}
section.bloque.alt{background:var(--gris-bg)}
.titulo-seccion{text-align:center;margin-bottom:36px}
.titulo-seccion h2{color:var(--azul);font-size:1.8rem;margin:0 0 6px}
.titulo-seccion p{color:var(--gris);margin:0}

/* Rejilla de tarjetas */
.rejilla{display:grid;gap:22px}
.rejilla.col3{grid-template-columns:repeat(3,1fr)}
.rejilla.col4{grid-template-columns:repeat(4,1fr)}
.tarjeta{background:#fff;border:1px solid var(--borde);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column}
.tarjeta:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(20,73,124,.14)}
.tarjeta .img{aspect-ratio:16/10;background:var(--azul-suave) center/cover no-repeat}
.tarjeta .cuerpo{padding:16px;flex:1;display:flex;flex-direction:column}
.tarjeta h3{margin:0 0 6px;font-size:1.05rem;color:var(--azul-osc);line-height:1.3}
.tarjeta .meta{font-size:.85rem;color:var(--gris);margin-bottom:8px}
.tarjeta .etiqueta{display:inline-block;background:var(--azul-suave);color:var(--azul);font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:20px;margin-bottom:8px;width:fit-content}
.tarjeta p{margin:0;font-size:.92rem;color:#444}

/* Tarjeta persona */
.persona .img{aspect-ratio:1/1;border-radius:50%;width:120px;height:120px;margin:18px auto 0;background-size:cover;background-position:center;border:4px solid var(--azul-suave);background-color:var(--azul-suave);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Ccircle cx='50' cy='50' r='50' fill='%23eaf1f8'/%3E%3Ccircle cx='50' cy='40' r='18' fill='%23b9cde0'/%3E%3Cpath d='M20 86c2-18 16-28 30-28s28 10 30 28z' fill='%23b9cde0'/%3E%3C/svg%3E")}
.persona .cuerpo{text-align:center}
.persona h3{font-size:1rem;line-height:1.3;margin:0 0 4px}
.persona .cargo{color:#445;font-weight:500;font-size:.86rem;line-height:1.35;margin-top:2px}
.persona .lugar{display:inline-block;margin-top:6px;color:var(--azul);background:var(--azul-suave);font-weight:700;font-size:.72rem;padding:2px 10px;border-radius:20px;letter-spacing:.2px}
.persona .contacto{margin-top:10px;font-size:.85rem}
.persona .contacto a{display:inline-block;margin:0 5px}

/* Artículo / ficha */
.articulo{max-width:820px;margin:0 auto;padding:40px 20px}
.articulo h1{color:var(--azul-osc);font-size:2rem;line-height:1.25}
.articulo .info{color:var(--gris);font-size:.9rem;margin-bottom:24px;border-bottom:1px solid var(--borde);padding-bottom:14px}
.articulo .destacada{border-radius:var(--radio);margin:0 0 24px;width:100%}
.articulo img{border-radius:8px}
.ficha-datos{background:var(--gris-bg);border-radius:var(--radio);padding:18px 22px;margin:0 0 24px}
.ficha-datos dl{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;margin:0}
.ficha-datos dt{font-weight:700;color:var(--azul)}
.estado{display:inline-block;padding:3px 12px;border-radius:20px;font-size:.78rem;font-weight:700}
.estado.curso{background:#e3f6e9;color:#1f8a4c}
.estado.fin{background:#f0f1f3;color:#7a818c}

/* Filtros */
.filtros{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:28px}
.filtros button,.filtros a{border:1px solid var(--borde);background:#fff;color:var(--azul-osc);padding:7px 15px;border-radius:20px;cursor:pointer;font-size:.88rem}
.filtros .activo{background:var(--azul);color:#fff;border-color:var(--azul)}

/* Pie */
footer.pie{background:var(--azul-osc);color:#cdd9e6;padding:46px 0 22px;margin-top:40px}
footer.pie .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px}
footer.pie h4{color:#fff;margin:0 0 12px;font-size:1.05rem}
footer.pie .pie-logo{display:block;width:auto;max-width:260px;height:auto;margin:0 0 14px}
footer.pie a{color:#cdd9e6}
footer.pie ul{list-style:none;padding:0;margin:0}
footer.pie li{margin-bottom:7px}
footer.pie .copy{border-top:1px solid rgba(255,255,255,.15);margin-top:30px;padding-top:16px;text-align:center;font-size:.85rem;opacity:.8}

/* Slider */
.slider{position:relative;height:480px;overflow:hidden;background:var(--azul-osc)}
.slider .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .8s ease}
.slider .slide.activo{opacity:1}
.slider-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(15,52,88,.45);color:#fff;border:0;width:48px;height:48px;border-radius:50%;font-size:1.8rem;cursor:pointer;z-index:3;line-height:1}
.slider-nav:hover{background:rgba(15,52,88,.8)}
.slider-nav.prev{left:18px}.slider-nav.next{right:18px}
.slider-dots{position:absolute;bottom:18px;left:0;right:0;text-align:center;z-index:3}
.slider-dots span{display:inline-block;width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,.5);margin:0 5px;cursor:pointer}
.slider-dots span.activo{background:#fff}

/* Unidades funcionales — tarjetas con imagen e información superpuesta */
.rejilla.unidades{display:flex;flex-wrap:wrap;justify-content:center;gap:20px}
.rejilla.unidades .tarjeta.unidad{width:calc((100% - 60px)/4)}
@media(max-width:980px){.rejilla.unidades .tarjeta.unidad{width:calc((100% - 40px)/3)}}
@media(max-width:680px){.rejilla.unidades .tarjeta.unidad{width:calc((100% - 20px)/2)}}
@media(max-width:460px){.rejilla.unidades .tarjeta.unidad{width:100%}}
.tarjeta.unidad{position:relative;display:block;aspect-ratio:4/3;border:none;border-radius:14px;overflow:hidden;box-shadow:0 4px 16px rgba(20,73,124,.16);text-decoration:none;color:#fff;transition:transform .25s ease,box-shadow .25s ease}
.tarjeta.unidad .img{position:absolute;inset:0;width:100%;height:100%;aspect-ratio:auto;background-size:cover;background-position:center;transition:transform .6s ease}
.tarjeta.unidad::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(13,38,66,.94) 0%,rgba(13,38,66,.55) 38%,rgba(13,38,66,.10) 66%,rgba(13,38,66,0) 100%);transition:background .3s ease}
.tarjeta.unidad .cuerpo{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:18px 18px 16px;display:block;background:none;text-align:left}
.tarjeta.unidad h3{margin:0;color:#fff;font-size:1.08rem;line-height:1.28;text-align:left;text-shadow:0 2px 10px rgba(0,0,0,.4);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden}
.tarjeta.unidad .vermas{display:inline-flex;align-items:center;gap:7px;margin-top:9px;color:#dcebff;color:#cfe2f5;font-size:.82rem;font-weight:600;text-align:left;letter-spacing:.2px}
.tarjeta.unidad .vermas::before{content:"";width:20px;height:2px;background:var(--azul-claro);transition:width .3s ease}
.tarjeta.unidad:hover{transform:translateY(-5px);box-shadow:0 14px 34px rgba(20,73,124,.30)}
.tarjeta.unidad:hover .img{transform:scale(1.08)}
.tarjeta.unidad:hover::before{background:linear-gradient(to top,rgba(13,38,66,.96) 0%,rgba(20,73,124,.62) 48%,rgba(48,96,144,.22) 100%)}
.tarjeta.unidad:hover .vermas::before{width:34px}

/* Newsletter */
.newsletter{position:relative;padding:60px 0;color:#fff;background:linear-gradient(rgba(15,52,88,.9),rgba(22,73,124,.92)),var(--img) center/cover no-repeat}
.newsletter h2{color:#fff;font-size:1.9rem;margin:0 0 8px}
.newsletter p{opacity:.92;margin:0 0 22px}
.form-news{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.form-news input{padding:12px 16px;border:0;border-radius:8px;min-width:220px;font-size:1rem}
.form-news .btn{cursor:pointer}

/* Quiénes somos */
.rejilla.col2{grid-template-columns:repeat(2,1fr)}
.qs-intro{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
.qs-intro h1{color:var(--azul-osc);font-size:2.1rem;margin-top:0}
.qs-intro p{color:#444}
.qs-foto img{border-radius:var(--radio);box-shadow:var(--sombra);width:100%}
.qs-objetivos{margin:8px 0 0;padding-left:20px}
.qs-objetivos li{margin-bottom:8px;color:#444}
.qs-sub{color:var(--azul);text-align:center;margin:42px 0 18px;font-size:1.3rem}
/* Acordeón */
.qs-acordeon details{background:#fff;border:1px solid var(--borde);border-radius:8px;margin-bottom:10px;box-shadow:var(--sombra)}
.qs-acordeon summary{cursor:pointer;padding:14px 18px;font-weight:600;color:var(--azul-osc);list-style:none;position:relative}
.qs-acordeon summary::-webkit-details-marker{display:none}
.qs-acordeon summary::after{content:'+';position:absolute;right:18px;color:var(--azul-claro);font-size:1.3rem;line-height:1}
.qs-acordeon details[open] summary::after{content:'–'}
.qs-acordeon details[open] summary{color:var(--azul);border-bottom:1px solid var(--borde)}
.qs-acordeon .ac-cont{padding:14px 18px;color:#444}
/* Tabla responsables */
.tabla-resp{overflow-x:auto}
.tabla-resp table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra)}
.tabla-resp th{background:var(--azul);color:#fff;padding:12px 14px;text-align:left;font-size:.92rem}
.tabla-resp td{padding:12px 14px;border-top:1px solid var(--borde);font-size:.9rem;vertical-align:top}
.tabla-resp td.act{font-weight:700;color:var(--azul-osc);background:var(--azul-suave)}
.tabla-resp td strong{color:var(--azul-osc)}
.tarjeta-org{background:#fff;border:1px solid var(--borde);border-radius:var(--radio);padding:16px 18px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--sombra)}
.tarjeta-org.destacada{border-top:4px solid var(--azul)}
.tarjeta-org .rol{display:inline-block;background:var(--azul-suave);color:var(--azul);font-weight:700;font-size:.75rem;padding:3px 10px;border-radius:20px;width:fit-content}
.tarjeta-org strong{color:var(--azul-osc);font-size:1.05rem}
.tarjeta-org .desc{color:var(--gris);font-size:.9rem}
@media(max-width:800px){.qs-intro,.qs-desc{grid-template-columns:1fr}.rejilla.col2{grid-template-columns:1fr}}

/* Organigrama */
.organigrama-sec{background:#fff}
.organigrama{max-width:1180px;margin:0 auto}
.org-fila.org-top{display:grid;grid-template-columns:1fr auto 1.1fr auto 1fr;align-items:center;gap:6px}
.org-col{display:flex;flex-direction:column;align-items:center}
.org-box{background:var(--azul-osc);color:#fff;border-radius:14px;padding:18px 20px;width:100%}
.org-box h4{margin:0 0 12px;text-align:center;font-size:1.05rem;color:#fff}
.org-comite{min-height:100%}
.org-grupo{display:block;text-align:center;font-weight:700;color:#a9c6e2;margin:12px 0 6px;font-size:.85rem}
.org-pers{text-align:center;margin-bottom:9px;line-height:1.25}
.org-pers strong{display:block;font-size:.92rem}
.org-pers em{font-style:normal;font-size:.78rem;opacity:.82}
.org-rol{display:block;font-weight:800;color:#a9c6e2;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}
.org-centro{gap:12px}
.org-logo{height:60px;width:auto;background:#fff;border-radius:10px;padding:8px 12px}
.org-direccion{background:var(--azul);display:flex;flex-direction:column;gap:14px}
.org-flecha{color:var(--azul-claro);font-size:1.8rem;font-weight:700}
.org-flecha-abajo{text-align:center;color:var(--azul-claro);font-size:2rem;margin:6px 0}
.org-unidades{background:var(--azul-claro)}
.org-units{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.org-unit{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:12px;text-align:center}
.org-unit strong{display:block;font-size:.86rem;margin-bottom:6px}
.org-unit span{display:block;font-size:.76rem;opacity:.9}
.grafico-wrap{background:#fff;border:1px solid var(--borde);border-radius:var(--radio);padding:24px;box-shadow:var(--sombra)}
.grafico-fuente{text-align:center;color:var(--gris);font-size:.8rem;margin:14px auto 0;max-width:760px;line-height:1.5}
@media(max-width:900px){
  .org-fila.org-top{grid-template-columns:1fr}
  .org-flecha{transform:rotate(90deg);margin:4px auto}
  .org-units{grid-template-columns:repeat(2,1fr)}
}

/* === Quiénes somos: estilo visual === */
/* Hero */
.qs-hero{position:relative;color:#fff;padding:84px 0 72px;background:linear-gradient(115deg,rgba(15,52,88,.92),rgba(22,73,124,.78) 55%,rgba(47,127,193,.6)),var(--img) center/cover no-repeat}
.qs-hero h1{font-size:2.6rem;margin:0 0 14px}
.qs-hero .lead{font-size:1.2rem;max-width:760px;opacity:.96;line-height:1.6}
/* Lema cita */
.qs-lema .contenedor{max-width:880px;text-align:center}
.qs-quote{position:relative;margin:0 auto 16px;max-width:760px;font-size:1.5rem;line-height:1.45;font-weight:600;color:var(--azul);font-style:italic}
.qs-quote::before{content:'“';position:absolute;left:-14px;top:-26px;font-size:4rem;color:var(--azul-suave);font-family:Georgia,serif;z-index:-1}
.qs-lema-txt{color:var(--gris);font-size:1.05rem}
/* Lead */
.qs-lead{font-size:1.12rem;color:#33414f;max-width:840px;margin:0 auto 30px;text-align:center;line-height:1.7}
/* Encabezados con icono */
.qs-h2{display:flex;align-items:center;gap:12px;color:var(--azul);font-size:1.7rem;margin:0 0 16px;padding-bottom:10px;border-bottom:3px solid var(--azul-suave)}
.qs-h2.center{justify-content:center;border-bottom:0}
.qs-h2 .ic{font-size:1.4rem}
.titulo-seccion .qs-h2{margin-bottom:6px}
/* Infra box */
.infra-box{background:#fff;border:1px solid var(--borde);border-left:4px solid var(--azul-claro);border-radius:var(--radio);padding:18px 22px;box-shadow:var(--sombra)}
.infra-box p{margin:0;color:#33414f;line-height:1.7}
/* Objetivos numerados */
.objetivos-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px}
.obj-card{display:flex;gap:14px;background:#fff;border:1px solid var(--borde);border-radius:var(--radio);padding:18px;box-shadow:var(--sombra)}
.obj-card .num{flex:none;width:38px;height:38px;border-radius:50%;background:var(--azul);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center}
.obj-card p{margin:0;color:#444;font-size:.95rem}
/* Avatar iniciales */
.tarjeta-org{align-items:center;text-align:center}
.tarjeta-org .avatar{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--azul),var(--azul-claro));color:#fff;font-weight:800;font-size:1.4rem;display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.tarjeta-org.destacada .rol{margin:0 auto}
/* Animaciones reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}
@media(max-width:800px){
  .objetivos-cards{grid-template-columns:1fr}
  .qs-hero h1{font-size:2rem}
  .qs-quote{font-size:1.25rem}
}

/* === Organigrama rediseñado (compacto, jerárquico, sin iconos) === */
.organigrama-sec{background:#fff}
.organigrama{max-width:940px;margin:0 auto}
.org-row{display:flex;justify-content:center;gap:16px}
.org-row-top{align-items:center}
.org-node{border-radius:12px}
/* Comités laterales (sutiles) */
.org-node.comite{flex:1;max-width:345px;align-self:stretch;background:var(--gris-bg);border:1px solid var(--borde);padding:16px 20px}
.org-node.comite .node-titulo{display:block;font-weight:700;color:var(--azul);font-size:.85rem;text-align:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--borde)}
.org-subgrupo{display:block;text-align:center;font-weight:700;color:var(--azul);font-size:.76rem;text-transform:uppercase;letter-spacing:.5px;margin:12px 0 7px}
.org-miembro{text-align:center;margin-bottom:9px;line-height:1.22}
.org-miembro strong{display:block;font-size:.85rem;color:var(--azul-osc)}
.org-miembro em{font-style:normal;display:block;font-size:.73rem;color:#5a6573}
.dir-desc{display:block;font-size:.71rem;color:#bcd5ec;margin-top:2px;line-height:1.3}
/* Dirección (cúspide, lo más prominente) */
.org-node.direccion{min-width:210px;max-width:240px;background:var(--azul-osc);color:#fff;padding:4px 18px;align-self:center;box-shadow:0 8px 20px rgba(15,52,88,.26)}
.dir-row{text-align:center;padding:11px 0}
.dir-row + .dir-row{border-top:1px solid rgba(255,255,255,.16)}
.dir-cargo{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:1.2px;color:#9ec1e3;font-weight:700;margin-bottom:2px}
.dir-nombre{display:block;font-size:.96rem;font-weight:700}
/* Conector vertical */
.org-conector{width:2px;height:30px;background:#cbd5e1;margin:0 auto}
/* Áreas de dirección (un escalón por debajo) */
.org-areas{flex-wrap:wrap}
.org-node.area{background:#fff;border:1px solid var(--borde);border-top:3px solid var(--azul-claro);text-align:center;min-width:210px;padding:12px 18px}
.area-rol{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.8px;color:var(--azul-claro);font-weight:700;margin-bottom:4px}
.area-nombre{display:block;font-weight:600;color:var(--azul-osc);font-size:.96rem}
/* Unidades Funcionales */
.org-unidades-row{flex-wrap:wrap;gap:10px}
.org-node.unidad{background:var(--azul-suave);border:1px solid #d6e3f0;text-align:center;width:calc(25% - 8px);min-width:155px;padding:11px 10px}
.org-node.unidad .u-nombre{display:block;font-weight:700;color:var(--azul);font-size:.8rem;margin-bottom:5px;line-height:1.2}
.org-node.unidad .u-pers{display:block;font-size:.74rem;color:#5a6573;line-height:1.3}
/* Detalle dirección: 2 niveles */
.dir-detalle-areas{margin-top:14px}
.dir-detalle-areas .area-card{border-top:3px solid var(--azul-claro)}
.dir-detalle-areas .area-card strong{font-size:1rem}
@media(max-width:820px){
  .org-row{flex-direction:column;align-items:stretch}
  .org-node.comite,.org-node.area{max-width:none}
  .org-node.unidad{width:calc(50% - 5px)}
}

/* === Qué ofrecemos === */
.qs-hero.sin-foto{background:linear-gradient(120deg,var(--azul),var(--azul-claro))}
.qo-fig{margin:26px auto 0;max-width:680px;text-align:center}
.qo-fig.estrecha{max-width:430px;margin-top:32px}
.qo-fig img{width:100%;border-radius:var(--radio);box-shadow:var(--sombra)}
.qo-fig figcaption{font-size:.85rem;color:var(--gris);margin-top:9px;font-style:italic}
.qo-lineas{align-items:start}
.qo-linea{background:#fff;border:1px solid var(--borde);border-top:4px solid var(--azul-claro);border-radius:var(--radio);padding:22px 24px;box-shadow:var(--sombra)}
.qo-linea .qo-tag{display:inline-block;font-weight:700;color:var(--azul);background:var(--azul-suave);padding:4px 13px;border-radius:20px;font-size:.85rem;margin-bottom:12px}
.qo-linea h3{color:var(--azul-osc);margin:0 0 10px;font-size:1.15rem}
.qo-linea p{color:#444;font-size:.94rem;margin:0;line-height:1.65}
.qo-areas summary{display:flex;align-items:center}
.area-fig{margin:0 0 16px;text-align:center}
.area-fig img{width:100%;border-radius:10px;box-shadow:var(--sombra)}
.area-fig figcaption{font-size:.82rem;color:var(--gris);margin-top:7px;font-style:italic}
.ac-num{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--azul);color:#fff;font-size:.8rem;font-weight:700;margin-right:12px;flex:none}

/* === Actividades del centro === */
.act-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:920px;margin:0 auto}
.act-stat{background:linear-gradient(135deg,var(--azul),var(--azul-claro));color:#fff;border-radius:var(--radio);padding:26px 18px;text-align:center;box-shadow:var(--sombra)}
.act-stat .num{display:block;font-size:2.7rem;font-weight:800;line-height:1}
.act-stat .lab{display:block;font-size:.9rem;margin-top:8px;opacity:.95;line-height:1.3}
@media(max-width:760px){.act-stats{grid-template-columns:repeat(2,1fr)}}

/* === Informes (rejilla de portadas) === */
.informes-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:22px}
.informe-card{position:relative;display:block;text-decoration:none;color:inherit;background:#fff;border:1px solid var(--borde);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);transition:transform .15s,box-shadow .15s}
.informe-card:hover{transform:translateY(-4px);box-shadow:0 12px 26px rgba(20,73,124,.2);text-decoration:none}
.informe-cover{aspect-ratio:1/1.414;background:var(--azul-suave);overflow:hidden}
.informe-cover img{width:100%;height:100%;object-fit:cover;display:block}
.informe-pie{display:flex;align-items:center;justify-content:space-between;padding:11px 14px}
.informe-pie .anio{font-weight:800;color:var(--azul);font-size:1.25rem}
.informe-pie .ver{font-size:.74rem;color:var(--gris);font-weight:600;display:flex;align-items:center;gap:5px}
.informe-pie .pdf{background:#c0392b;color:#fff;font-size:.62rem;font-weight:700;padding:2px 6px;border-radius:4px}
.badge-nuevo{position:absolute;top:10px;right:10px;z-index:2;background:var(--azul-claro);color:#fff;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:20px;box-shadow:0 2px 8px rgba(0,0,0,.2)}
@media(max-width:1000px){.informes-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:760px){.informes-grid{grid-template-columns:repeat(3,1fr);gap:14px}}
@media(max-width:480px){.informes-grid{grid-template-columns:repeat(2,1fr)}}

/* === Personal del centro === */
.personal-centro{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;margin:0 auto 26px;max-width:1000px}
.pc-card{width:232px}
.pc-card .pc-desc{font-size:.8rem;color:var(--gris);margin-top:5px;padding:0 8px;line-height:1.35}
.pc-card .pc-email{display:inline-block;margin-top:9px;font-size:.82rem;color:var(--azul-claro);word-break:break-word}

/* === Colaboradores (rejilla de logos) === */
.colab-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:920px;margin:0 auto}
.colab-card{display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--borde);border-radius:var(--radio);padding:26px 28px;box-shadow:var(--sombra);transition:transform .15s,box-shadow .15s}
.colab-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(20,73,124,.16)}
.colab-card img{max-width:100%;max-height:90px;width:auto;object-fit:contain;filter:grayscale(35%);transition:filter .2s}
.colab-card:hover img{filter:grayscale(0)}
@media(max-width:760px){.colab-grid{grid-template-columns:repeat(2,1fr);gap:16px}}
@media(max-width:440px){.colab-grid{grid-template-columns:1fr}}

/* === Grupos de investigación === */
.grupo-hero{padding:70px 0 56px}
.grupo-hero.compacto{padding:46px 0 40px}
.grupo-hero.compacto h1{font-size:2.05rem;margin:0}
.grupo-eyebrow{display:inline-block;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:5px 14px;border-radius:20px;margin-bottom:12px}
/* Submenú visual (pestañas) */
.grupo-submenu{display:flex;flex-wrap:nowrap;justify-content:center;gap:10px;max-width:1100px;margin:0 auto;padding:24px 20px 4px;position:relative;z-index:6;overflow-x:auto}
.grupo-submenu::-webkit-scrollbar{height:6px}
.grupo-submenu::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}
.grupo-hero + .grupo-submenu{margin-top:-26px;padding-top:0}
.grupo-tab{flex:none;white-space:nowrap;background:#fff;border:1px solid var(--borde);border-radius:30px;padding:11px 20px;font-weight:600;font-size:.92rem;color:var(--azul-osc);text-decoration:none;box-shadow:var(--sombra);transition:transform .15s,background .15s,color .15s}
.grupo-tab:hover{transform:translateY(-2px);background:var(--azul-suave);color:var(--azul);text-decoration:none}
.grupo-tab.activo{background:var(--azul);color:#fff;border-color:var(--azul);box-shadow:0 6px 16px rgba(48,96,144,.35)}
/* Descripción + foto */
.grupo-desc{display:grid;grid-template-columns:1.25fr .75fr;gap:32px;align-items:center;margin-top:14px}
.grupo-desc .qs-h2{margin-top:0}
.grupo-desc p{color:#444;line-height:1.7}
.grupo-foto{margin:0}
.grupo-foto img{width:100%;border-radius:var(--radio);box-shadow:var(--sombra)}
/* Investigadores principales */
.pi-list{display:flex;flex-direction:column;gap:22px;max-width:900px;margin:0 auto}
.pi-item{display:grid;grid-template-columns:150px 1fr;gap:26px;background:#fff;border:1px solid var(--borde);border-radius:var(--radio);padding:24px;box-shadow:var(--sombra)}
.pi-foto{width:150px;height:185px;border-radius:10px;background:var(--azul-suave) center/cover no-repeat;border:1px solid var(--borde)}
.pi-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.pi-head strong{color:var(--azul-osc);font-size:1.2rem}
.pi-head .pi-inst{background:var(--azul-suave);color:var(--azul);font-weight:700;font-size:.72rem;padding:3px 11px;border-radius:20px}
.pi-bio{color:#445;font-size:.9rem;line-height:1.65;margin:0;text-align:justify}
@media(max-width:640px){.pi-item{grid-template-columns:1fr;text-align:center}.pi-foto{margin:0 auto}.pi-head{justify-content:center}.pi-bio{text-align:left}}
@media(max-width:800px){.grupo-desc{grid-template-columns:1fr}}

/* Volver */
.volver{display:inline-block;margin-bottom:18px;color:var(--azul-claro);font-weight:600}

@media(max-width:900px){
  .rejilla.col4{grid-template-columns:repeat(2,1fr)}
  .rejilla.col3{grid-template-columns:repeat(2,1fr)}
  footer.pie .cols{grid-template-columns:1fr}
}
@media(max-width:640px){
  nav.menu{display:none;position:absolute;top:78px;left:0;right:0;background:#fff;border-bottom:1px solid var(--borde);padding:10px}
  nav.menu.abierto{display:block}
  nav.menu ul{flex-direction:column}
  .menu-btn{display:block}
  .rejilla.col4,.rejilla.col3{grid-template-columns:1fr}
  .hero h1{font-size:1.8rem}
}

/* ===== Producción científica por unidad (tabla 2025 visual + DOIs) ===== */
.pc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:6px 0 40px}
.pc-stat{background:#fff;border:1px solid var(--borde);border-top:3px solid var(--azul-claro);border-radius:var(--radio);padding:22px 16px;text-align:center;box-shadow:var(--sombra)}
.pc-stat.destacado{background:linear-gradient(135deg,var(--azul-osc),var(--azul-claro));color:#fff;border:none}
.pc-stat .num{display:block;font-size:2.5rem;font-weight:800;line-height:1;color:var(--azul-osc)}
.pc-stat.destacado .num{color:#fff}
.pc-stat .lab{display:block;font-size:.86rem;margin-top:8px;color:var(--gris);line-height:1.3}
.pc-stat.destacado .lab{color:#eaf2fb;opacity:.95}
.pc-stat .lab em{display:block;font-style:normal;font-size:.74rem;margin-top:4px;color:var(--azul-claro);font-weight:600}

.pc-cuartiles{background:#fff;border:1px solid var(--borde);border-radius:var(--radio);box-shadow:var(--sombra);padding:26px 28px;margin:0 0 48px}
.pc-cuartiles-cab{text-align:center;margin-bottom:18px}
.pc-cuartiles-cab h3{font-size:1.2rem}
.pc-cuartiles-cab p{color:var(--gris);margin:4px 0 0;font-size:.92rem}
.pc-cuartiles-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:32px;align-items:center}
.pc-qbars{display:flex;flex-direction:column;gap:14px}
.pc-qrow{display:grid;grid-template-columns:34px 1fr 34px;align-items:center;gap:12px}
.pc-qname{font-weight:800;color:var(--azul-osc);font-size:.95rem}
.pc-qtrack{height:16px;background:var(--gris-bg);border-radius:10px;overflow:hidden}
.pc-qfill{display:block;height:100%;border-radius:10px;min-width:2px;transition:width .9s cubic-bezier(.2,.7,.2,1)}
.pc-qfill.q1{background:#244c72}.pc-qfill.q2{background:#306090}.pc-qfill.q3{background:#4a86bb}.pc-qfill.q4{background:#9ec1e3}
.pc-qval{text-align:right;font-weight:700;color:var(--texto)}
.pc-donut-wrap{max-width:230px;margin:0 auto}

.pc-pub-list{list-style:none;counter-reset:pub;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:14px}
.pc-pub{position:relative;background:#fff;border:1px solid var(--borde);border-left:4px solid var(--azul-claro);border-radius:8px;padding:16px 18px 16px 52px;box-shadow:var(--sombra)}
.pc-pub::before{counter-increment:pub;content:counter(pub);position:absolute;left:14px;top:16px;width:26px;height:26px;border-radius:50%;background:var(--azul-suave);color:var(--azul-osc);font-weight:700;font-size:.82rem;display:flex;align-items:center;justify-content:center}
.pc-pub-cite{margin:0 0 10px;color:#33414f;line-height:1.55;font-size:.95rem}
.pc-doi{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;color:var(--azul);text-decoration:none;font-family:monospace;word-break:break-all}
.pc-doi-tag{background:var(--azul);color:#fff;font-family:Montserrat,sans-serif;font-weight:700;font-size:.68rem;letter-spacing:.5px;padding:2px 7px;border-radius:4px}
.pc-doi-go{font-family:Montserrat,sans-serif;font-weight:600;color:var(--azul-claro);white-space:nowrap}
.pc-doi:hover .pc-doi-go{text-decoration:underline}
.pc-pub:hover{border-left-color:var(--azul-osc)}
.pc-vacio{text-align:center;color:var(--gris);font-style:italic;padding:24px}

.pc-bloque{margin-top:52px}
/* Tesis doctorales defendidas */
.pc-tesis{display:flex;flex-direction:column;gap:14px}
.pc-tesis-item{display:flex;gap:16px;align-items:flex-start;background:var(--azul-suave);border:1px solid #d6e3f0;border-radius:var(--radio);padding:18px 20px;box-shadow:var(--sombra)}
.pc-tesis-icon{font-size:1.6rem;line-height:1.3;flex:0 0 auto}
.pc-tesis-titulo{margin:0 0 4px;color:var(--azul-osc);font-size:1.02rem;line-height:1.4;font-style:italic}
.pc-tesis-autor{margin:0;font-weight:700;color:var(--texto)}
.pc-tesis-detalle{margin:3px 0 0;color:var(--gris);font-size:.86rem;line-height:1.45}
/* Premios y distinciones */
.pc-premios{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.pc-premio{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--borde);border-left:4px solid #e0a800;border-radius:8px;padding:15px 18px;box-shadow:var(--sombra);color:#33414f;line-height:1.55;font-size:.94rem}
.pc-premio-icon{font-size:1.3rem;line-height:1.2;flex:0 0 auto}

/* ===== Difusión y transferencia por unidad ===== */
.dif-grid{display:flex;flex-direction:column;gap:22px}
.dif-bloque{background:#fff;border:1px solid var(--borde);border-radius:var(--radio);box-shadow:var(--sombra);padding:22px 26px}
.dif-h{margin:0 0 14px;color:var(--azul-osc);font-size:1.15rem;padding-bottom:10px;border-bottom:2px solid var(--azul-suave);position:relative}
.dif-h::before{content:"";position:absolute;left:0;bottom:-2px;width:54px;height:2px;background:var(--azul-claro)}
.dif-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:11px}
.dif-list li{position:relative;padding-left:24px;color:#33414f;line-height:1.55;font-size:.95rem}
.dif-list li::before{content:"";position:absolute;left:4px;top:9px;width:8px;height:8px;border-radius:50%;background:var(--azul-claro)}

/* ===== Buscador / filtros de proyectos ===== */
.proy-filtros{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin:0 0 28px;padding:14px 16px;background:#fff;border:1px solid var(--borde);border-radius:var(--radio);box-shadow:var(--sombra)}
.proy-buscador{position:relative;flex:1 1 280px;display:flex;align-items:center}
.proy-buscador svg{position:absolute;left:12px;color:var(--azul-claro);pointer-events:none}
.proy-buscador input{width:100%;padding:10px 12px 10px 38px;border:1px solid var(--borde);border-radius:8px;font:inherit;font-size:.95rem;color:var(--texto);background:var(--gris-bg)}
.proy-buscador input:focus{outline:none;border-color:var(--azul-claro);background:#fff;box-shadow:0 0 0 3px rgba(74,134,187,.15)}
.proy-estado{display:inline-flex;background:var(--gris-bg);border:1px solid var(--borde);border-radius:8px;padding:3px;gap:2px}
.proy-tab{border:none;background:none;font:inherit;font-size:.86rem;font-weight:600;color:var(--gris);padding:7px 14px;border-radius:6px;cursor:pointer;transition:.15s;white-space:nowrap}
.proy-tab:hover{color:var(--azul-osc)}
.proy-tab.activo{background:var(--azul);color:#fff}
.proy-select{font:inherit;font-size:.9rem;color:var(--texto);padding:9px 12px;border:1px solid var(--borde);border-radius:8px;background:var(--gris-bg);cursor:pointer;max-width:100%}
.proy-select:focus{outline:none;border-color:var(--azul-claro);background:#fff}
.proy-contador{margin-left:auto;font-size:.85rem;font-weight:700;color:var(--azul);white-space:nowrap}
.proy-unidad{display:inline-block;font-size:.74rem;font-weight:600;color:var(--azul);background:var(--azul-suave);padding:2px 9px;border-radius:20px;margin-bottom:6px;width:fit-content}
.proy-vacio{text-align:center;color:var(--gris);font-style:italic;padding:30px}
@media(max-width:640px){
  .proy-filtros{gap:10px}
  .proy-contador{margin-left:0;width:100%}
}

/* ===== Ficha de proyecto (vista visual) ===== */
.proy-detalle{padding:36px 0 50px}
.proy-detalle .volver{margin:0 0 20px}
.proy-head{display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center;background:linear-gradient(135deg,var(--azul-osc),var(--azul-claro));color:#fff;border-radius:var(--radio);padding:30px 34px;box-shadow:var(--sombra)}
.proy-head-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.proy-head h1{margin:0;font-size:1.65rem;line-height:1.28;color:#fff}
.proy-head .proy-codigo{margin:14px 0 0;font-family:monospace;font-size:.88rem;color:#dbe8f5;letter-spacing:.4px}
.proy-head .proy-unidad{background:rgba(255,255,255,.18);color:#fff}
.proy-head .estado{box-shadow:0 1px 5px rgba(0,0,0,.14)}
.proy-logo{margin:0;background:#fff;border-radius:10px;padding:14px;width:230px;min-height:120px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.16)}
.proy-logo img{max-height:150px;max-width:100%;width:auto;border-radius:4px;display:block;border:none}
.proy-layout{display:grid;grid-template-columns:1fr 320px;gap:32px;margin-top:30px;align-items:start}
.proy-seccion{margin-bottom:30px}
.proy-h{color:var(--azul-osc);font-size:1.3rem;margin:0 0 14px;padding-bottom:9px;border-bottom:2px solid var(--azul-suave);position:relative}
.proy-h::after{content:"";position:absolute;left:0;bottom:-2px;width:50px;height:2px;background:var(--azul-claro)}
.proy-main .contenido{color:#33414f;line-height:1.7}
.proy-main .contenido p{margin:0 0 12px}
.proy-main .contenido a{color:var(--azul);word-break:break-word}
.proy-main>section>p{color:#33414f;line-height:1.7;margin:0}
.proy-tags-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.proy-tags-list li{position:relative;padding:11px 16px 11px 34px;background:#fff;border:1px solid var(--borde);border-radius:8px;color:#33414f;box-shadow:var(--sombra);line-height:1.45}
.proy-tags-list li::before{content:"";position:absolute;left:14px;top:1.05em;width:8px;height:8px;border-radius:50%;background:var(--azul-claro)}
.proy-aside{display:flex;flex-direction:column;gap:18px;position:sticky;top:90px}
.proy-ficha,.proy-box{background:#fff;border:1px solid var(--borde);border-radius:var(--radio);box-shadow:var(--sombra);padding:20px 22px}
.proy-ficha{border-top:3px solid var(--azul-claro)}
.proy-ficha h3,.proy-box h3{margin:0 0 14px;color:var(--azul-osc);font-size:1.02rem;padding-bottom:8px;border-bottom:1px solid var(--borde)}
.proy-ficha dl{display:grid;grid-template-columns:auto 1fr;gap:11px 14px;margin:0;align-items:baseline}
.proy-ficha dt{font-weight:700;color:var(--gris);font-size:.8rem;text-transform:uppercase;letter-spacing:.4px}
.proy-ficha dd{margin:0;color:var(--texto);font-size:.9rem;line-height:1.4}
.proy-box p{margin:0;color:#33414f;line-height:1.55;font-size:.92rem}
.proy-contactos{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.proy-contactos li{position:relative;padding-left:22px;color:#33414f;font-size:.9rem;line-height:1.4}
.proy-contactos li::before{content:"✉";position:absolute;left:0;top:0;color:var(--azul-claro);font-size:.85rem}
@media(max-width:860px){
  .proy-head{grid-template-columns:1fr}
  .proy-logo{order:-1;width:auto;align-self:flex-start;max-width:200px}
  .proy-layout{grid-template-columns:1fr}
  .proy-aside{position:static}
}

/* ===== Software ===== */
.sw-list{display:flex;flex-direction:column;gap:26px}
.sw-card{display:grid;grid-template-columns:300px 1fr;gap:0;background:#fff;border:1px solid var(--borde);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);transition:transform .15s,box-shadow .15s}
.sw-card:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(20,73,124,.14)}
.sw-img{margin:0;background:linear-gradient(135deg,var(--azul-suave),#f4f8fc);display:flex;align-items:center;justify-content:center;padding:18px;border-right:1px solid var(--borde)}
.sw-img img{max-width:100%;max-height:200px;width:auto;border-radius:6px;box-shadow:0 2px 10px rgba(20,73,124,.12)}
.sw-img-ph{font-family:monospace;font-size:2.4rem;color:var(--azul-claro);font-weight:700}
.sw-body{padding:24px 26px}
.sw-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.sw-nombre{margin:0;color:var(--azul-osc);font-size:1.25rem;line-height:1.3}
.sw-tag{background:#eaf7ee;color:#1f8a4c;font-size:.7rem;font-weight:700;letter-spacing:.4px;padding:3px 10px;border-radius:20px;text-transform:uppercase}
.sw-desc{margin:0 0 10px;color:#33414f;line-height:1.6;font-size:.96rem}
.sw-nota{margin:6px 0 0;padding:10px 14px;background:var(--gris-bg);border-left:3px solid var(--azul-claro);border-radius:6px;color:var(--gris);font-size:.86rem;line-height:1.5}
.sw-descargas{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.sw-btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;border:1px solid var(--azul);border-radius:8px;padding:8px 14px;background:#fff;color:var(--azul);transition:.15s;max-width:100%}
.sw-btn:hover{background:var(--azul-suave)}
.sw-btn.destacado{background:var(--azul);color:#fff}
.sw-btn.destacado:hover{background:var(--azul-osc)}
.sw-btn.ext{border-color:var(--azul-claro);color:var(--azul-claro)}
.sw-btn.ext:hover{background:#eef5fb}
.sw-btn-ico{font-size:1.05rem;font-weight:700;line-height:1;flex:0 0 auto}
.sw-btn-txt{display:flex;flex-direction:column;line-height:1.25;overflow:hidden}
.sw-btn-txt strong{font-size:.9rem;white-space:nowrap}
.sw-btn-txt em{font-style:normal;font-size:.72rem;opacity:.75;white-space:normal}
@media(max-width:720px){
  .sw-card{grid-template-columns:1fr}
  .sw-img{border-right:none;border-bottom:1px solid var(--borde);padding:22px}
  .sw-img img{max-height:170px}
}

/* ===== Formación (Máster + Cursos) ===== */
.fm-filtros{display:inline-flex;background:var(--gris-bg);border:1px solid var(--borde);border-radius:10px;padding:4px;gap:3px;margin:0 0 4px}
.fm-tab{border:none;background:none;font:inherit;font-size:.9rem;font-weight:600;color:var(--gris);padding:9px 20px;border-radius:7px;cursor:pointer;transition:.15s}
.fm-tab:hover{color:var(--azul-osc)}
.fm-tab.activo{background:var(--azul);color:#fff}
.fm-master{display:grid;grid-template-columns:260px 1fr;gap:0;background:#fff;border:1px solid var(--borde);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra)}
.fm-master-img{margin:0;background:var(--gris-bg);display:flex;align-items:center;justify-content:center;padding:22px;border-right:1px solid var(--borde)}
.fm-master-img img{max-width:100%;max-height:300px;width:auto;border-radius:6px;box-shadow:0 3px 14px rgba(20,73,124,.16)}
.fm-master-body{padding:28px 30px}
.fm-eyebrow{display:inline-block;background:var(--azul-suave);color:var(--azul);font-size:.7rem;font-weight:700;letter-spacing:.6px;text-transform:uppercase;padding:3px 11px;border-radius:20px;margin-bottom:10px}
.fm-master-h{margin:0 0 14px;color:var(--azul-osc);font-size:1.4rem;line-height:1.25}
.fm-desc{margin:0 0 12px;color:#33414f;line-height:1.6;font-size:.96rem}
.fm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0}
.fm-stat{background:var(--gris-bg);border-radius:8px;padding:14px 10px;text-align:center}
.fm-stat .num{display:block;font-size:1.5rem;font-weight:800;color:var(--azul-osc);line-height:1}
.fm-stat .lab{display:block;font-size:.74rem;color:var(--gris);margin-top:5px;line-height:1.25}
.fm-btn{display:inline-flex;align-items:center;gap:8px;text-decoration:none;border:1px solid var(--azul);border-radius:8px;padding:10px 18px;background:#fff;color:var(--azul);font-weight:600;font-size:.92rem;transition:.15s;margin-top:6px}
.fm-btn:hover{background:var(--azul-suave)}
.fm-btn.destacado{background:var(--azul);color:#fff}
.fm-btn.destacado:hover{background:var(--azul-osc)}
.fm-cursos{display:flex;flex-direction:column;gap:24px}
.fm-curso{display:grid;grid-template-columns:300px 1fr;background:#fff;border:1px solid var(--borde);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);transition:transform .15s,box-shadow .15s}
.fm-curso:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(20,73,124,.14)}
.fm-curso-img{position:relative;margin:0;min-height:200px;background:var(--azul-suave) center/cover no-repeat;overflow:hidden}
.fm-curso-img img{width:100%;height:100%;object-fit:cover;display:block;border:none;border-radius:0}
.fm-curso-tag{position:absolute;top:12px;left:12px;background:var(--azul);color:#fff;font-size:.72rem;font-weight:700;padding:4px 12px;border-radius:20px;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.fm-curso-body{padding:24px 26px}
.fm-curso-h{margin:0 0 12px;color:var(--azul-osc);font-size:1.25rem;line-height:1.3}
.fm-meta{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:7px}
.fm-meta li{display:flex;gap:9px;color:#445;font-size:.88rem;line-height:1.4}
.fm-meta-ico{flex:0 0 auto;font-size:.95rem}
@media(max-width:760px){
  .fm-master{grid-template-columns:1fr}
  .fm-master-img{padding:24px}
  .fm-master-img img{max-height:240px}
  .fm-stats{grid-template-columns:repeat(2,1fr)}
  .fm-curso{grid-template-columns:1fr}
  .fm-curso-img{min-height:180px}
}

/* ===== Noticias: filtro por año ===== */
.not-filtros{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:0 0 28px}
.not-tab{border:1px solid var(--borde);background:#fff;font:inherit;font-size:.86rem;font-weight:600;color:var(--gris);padding:7px 15px;border-radius:20px;cursor:pointer;transition:.15s}
.not-tab:hover{border-color:var(--azul-claro);color:var(--azul-osc)}
.not-tab.activo{background:var(--azul);border-color:var(--azul);color:#fff}
.not-contador{margin-left:auto;font-size:.85rem;font-weight:700;color:var(--azul)}

/* ===== Noticias: tarjetas uniformes ===== */
.noticia-card{height:100%}
.noticia-card .img{position:relative;aspect-ratio:16/10}
.noticia-anio{position:absolute;top:10px;left:10px;background:rgba(36,76,114,.92);color:#fff;font-size:.74rem;font-weight:700;padding:3px 10px;border-radius:6px;letter-spacing:.3px}
.noticia-card .cuerpo{display:flex;flex-direction:column;flex:1;min-height:188px}
.noticia-card .meta{font-size:.8rem;color:var(--azul-claro);font-weight:600;margin-bottom:6px}
.noticia-card h3{margin:0 0 8px;font-size:1.02rem;line-height:1.34;color:var(--azul-osc);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}
.noticia-card p{margin:0;font-size:.9rem;color:#566;line-height:1.5;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden}
.noticia-mas{margin-top:auto;padding-top:12px;color:var(--azul-claro);font-weight:600;font-size:.84rem}
.noticia-card:hover .noticia-mas{text-decoration:underline}

/* ===== Noticia: ficha visual ===== */
.noticia-detalle{padding:30px 0 50px}
.noticia-detalle .volver{margin:0}
.noticia-hero{position:relative;margin:18px 0 0;min-height:380px;display:flex;align-items:flex-end;background:var(--img) center 30%/cover no-repeat;border-radius:0}
.noticia-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,40,64,.92) 0%,rgba(20,40,64,.55) 45%,rgba(20,40,64,.15) 100%)}
.noticia-hero-txt{position:relative;padding:34px 20px 30px;width:100%}
.noticia-hero-txt h1{color:#fff;margin:0;font-size:2rem;line-height:1.22;max-width:760px;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.noticia-head{padding:10px 0 6px}
.noticia-head h1{color:var(--azul-osc);font-size:2rem;line-height:1.22;margin:8px 0 0}
.noticia-hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.noticia-fecha{background:var(--azul-claro);color:#fff;font-size:.78rem;font-weight:700;padding:4px 12px;border-radius:20px}
.noticia-cat{background:rgba(255,255,255,.18);color:#fff;font-size:.78rem;font-weight:600;padding:4px 12px;border-radius:20px}
.noticia-head .noticia-cat{background:var(--azul-suave);color:var(--azul)}
.noticia-contenido{margin-top:30px;color:#33414f;line-height:1.8;font-size:1.02rem}
.noticia-contenido p{margin:0 0 18px}
.noticia-contenido h2,.noticia-contenido h3,.noticia-contenido h4{color:var(--azul-osc);margin:30px 0 12px;line-height:1.3}
.noticia-contenido a{color:var(--azul);word-break:break-word}
.noticia-contenido img{max-width:100%;height:auto;max-height:460px;object-fit:cover;border-radius:12px;display:block;margin:22px auto;box-shadow:var(--sombra)}
.noticia-contenido figure{margin:22px 0}
.noticia-contenido ul,.noticia-contenido ol{margin:0 0 18px;padding-left:22px}
.noticia-contenido li{margin-bottom:7px}
.volver-pie{display:inline-block;margin-top:34px;padding-top:18px;border-top:1px solid var(--borde);width:100%}
.n-reveal{opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}
.n-reveal.visible{opacity:1;transform:none}
@media(max-width:640px){
  .noticia-hero{min-height:280px}
  .noticia-hero-txt h1,.noticia-head h1{font-size:1.5rem}
  .not-contador{margin-left:0;width:100%}
}
@media(max-width:760px){
  .dif-bloque{padding:18px}
  .pc-stats{grid-template-columns:repeat(2,1fr)}
  .pc-cuartiles-grid{grid-template-columns:1fr}
  .pc-donut-wrap{max-width:200px}
  .pc-pub{padding-left:18px}.pc-pub::before{display:none}
  .pc-doi-go{display:none}
}

/* ===== Texto justificado (alineado a ambos lados) en prosa ===== */
.contenido p,
.noticia-contenido p,
.proy-main .contenido p, .proy-main>section>p,
.grupo-texto p, .grupo-desc p,
.fm-desc, .sw-desc, .sw-nota,
.dif-list li, .pc-pub-cite,
.qs p, .qs-desc p, .infra-box p,
.proy-box p, .articulo .contenido p{
  text-align:justify;
  text-justify:inter-word;
  hyphens:auto;
  -webkit-hyphens:auto;
}

/* ===== Líneas estratégicas (página de grupo) ===== */
.grupo-lineas{margin:14px 0 6px}
.lineas-list{list-style:none;padding:0;margin:18px 0 0;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.lineas-list li{position:relative;padding:13px 16px 13px 42px;background:#fff;border:1px solid var(--borde);border-left:3px solid var(--azul-claro);border-radius:8px;box-shadow:var(--sombra);color:#33414f;line-height:1.5;font-size:.93rem;text-align:left}
.lineas-list li::before{content:"";position:absolute;left:16px;top:16px;width:14px;height:14px;border-radius:50%;background:var(--azul-suave);box-shadow:inset 0 0 0 4px var(--azul-claro)}
@media(max-width:720px){.lineas-list{grid-template-columns:1fr}}

/* ===== Aviso de cookies ===== */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:1000;max-width:760px;margin:0 auto;
  background:#fff;border:1px solid var(--borde);border-radius:12px;box-shadow:0 8px 30px rgba(20,73,124,.22);
  padding:16px 20px;display:flex;flex-wrap:wrap;align-items:center;gap:14px 18px;
  opacity:0;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease}
.cookie-banner.visible{opacity:1;transform:none}
.cookie-txt{margin:0;flex:1 1 320px;color:#33414f;font-size:.9rem;line-height:1.5}
.cookie-txt a{color:var(--azul);font-weight:600}
.cookie-btns{display:flex;gap:10px;flex:0 0 auto;margin-left:auto}
.cookie-btn{border:none;border-radius:8px;padding:9px 20px;font:inherit;font-weight:600;font-size:.9rem;cursor:pointer;
  background:var(--azul);color:#fff;transition:.15s}
.cookie-btn:hover{background:var(--azul-osc)}
.cookie-btn.ghost{background:transparent;color:var(--gris);border:1px solid var(--borde)}
.cookie-btn.ghost:hover{background:var(--gris-bg);color:var(--azul-osc)}
@media(max-width:560px){.cookie-btns{width:100%;margin-left:0}.cookie-btn{flex:1}}
