/*
Theme Name: Cooperación FEMP-AECID
Description: Tema institucional para la web de Internacional y Cooperación del convenio AECID-FEMP. Accesible (WCAG 2.1 AA), responsive, muy visual.
Version: 1.0
Author: Mario Navarro Mesonero
Text Domain: coop-femp
*/

/* ==================== Tokens ==================== */
:root{
  --c-azul:#0a4c8a;          /* azul institucional FEMP */
  --c-azul-osc:#06355f;
  --c-azul-claro:#e8f1f8;
  --c-rojo:#c8102e;          /* acento */
  --c-amarillo:#f4b223;      /* guiño AECID / ODS */
  --c-tinta:#1f2933;
  --c-gris:#5b6770;
  --c-linea:#d9e2ec;
  --c-fondo:#f6f9fc;
  --c-blanco:#ffffff;
  --ff-base:"Segoe UI",-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
  --sombra:0 2px 10px rgba(6,53,95,.08);
  --sombra-hover:0 10px 28px rgba(6,53,95,.16);
  --radio:10px;
  --wrap:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{margin:0;font-family:var(--ff-base);font-size:17px;line-height:1.65;color:var(--c-tinta);background:var(--c-blanco)}
img{max-width:100%;height:auto}
a{color:var(--c-azul)}
a:hover{color:var(--c-azul-osc)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid var(--c-amarillo);outline-offset:2px}
.coop-wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}

/* Skip link (accesibilidad) */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--c-azul-osc);color:#fff;padding:10px 18px;z-index:999;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ==================== Cabecera ==================== */
.topbar{background:var(--c-azul-osc);color:#dbe7f3;font-size:13.5px}
.topbar .coop-wrap{display:flex;justify-content:space-between;align-items:center;min-height:34px;gap:12px;flex-wrap:wrap}
.topbar a{color:#fff;text-decoration:none}
.topbar a:hover{text-decoration:underline}
.topbar .lang a{padding:2px 7px;border-radius:5px}
.topbar .lang a[aria-current="true"]{background:#fff;color:var(--c-azul-osc);font-weight:600}

.site-head{background:var(--c-blanco);border-bottom:1px solid var(--c-linea)}
.site-head .coop-wrap{display:flex;align-items:center;gap:22px;padding-top:14px;padding-bottom:14px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:16px;text-decoration:none;color:var(--c-tinta)}
.brand .logos{display:flex;align-items:center;gap:10px}
.brand .logo-box{display:flex;align-items:center;justify-content:center;width:86px;height:52px;border:1.5px dashed var(--c-linea);border-radius:8px;font-size:11px;letter-spacing:.06em;color:var(--c-gris);background:var(--c-fondo);font-weight:700}
.brand .titulo{line-height:1.2}
.brand .titulo strong{display:block;font-size:20px;color:var(--c-azul-osc)}
.brand .titulo span{font-size:13px;color:var(--c-gris)}
.head-cta{margin-left:auto}
.btn{display:inline-block;background:var(--c-azul);color:#fff!important;text-decoration:none;padding:10px 20px;border-radius:999px;font-weight:600;font-size:15px;border:0;cursor:pointer;transition:background .15s ease, transform .15s ease}
.btn:hover{background:var(--c-azul-osc);transform:translateY(-1px)}
.btn--rojo{background:var(--c-rojo)}
.btn--rojo:hover{background:#9d0c24}
.btn--claro{background:#fff;color:var(--c-azul-osc)!important;border:1.5px solid var(--c-linea)}
.btn--claro:hover{background:var(--c-azul-claro)}

/* Navegación */
.nav-main{background:var(--c-azul)}
.nav-main ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap}
.nav-main a{display:block;color:#fff;text-decoration:none;padding:13px 17px;font-size:15px;font-weight:600;letter-spacing:.01em;border-bottom:3px solid transparent}
.nav-main a:hover,.nav-main .current-menu-item>a,.nav-main a[aria-current="page"]{background:var(--c-azul-osc);border-bottom-color:var(--c-amarillo);color:#fff}
.nav-toggle{display:none;background:var(--c-azul);border:0;color:#fff;font-size:16px;font-weight:700;padding:12px 20px;width:100%;text-align:left;cursor:pointer}
@media (max-width:860px){
  .nav-toggle{display:block}
  .nav-main ul{display:none;flex-direction:column}
  .nav-main.open ul{display:flex}
  .brand .titulo strong{font-size:17px}
  .head-cta{margin-left:0}
}

/* ==================== Hero ==================== */
.hero{position:relative;color:#fff;overflow:hidden;background:var(--c-azul-osc)}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero .velo{position:absolute;inset:0;background:linear-gradient(100deg,rgba(4,38,68,.88) 0%,rgba(6,53,95,.62) 46%,rgba(6,53,95,.18) 100%)}
.hero .coop-wrap{position:relative;padding-top:84px;padding-bottom:92px;max-width:var(--wrap)}
.hero .kicker{display:inline-block;background:var(--c-amarillo);color:#3a2b00;font-weight:700;font-size:13px;letter-spacing:.09em;text-transform:uppercase;padding:4px 12px;border-radius:4px;margin:0 0 16px}
.hero h1{font-size:clamp(30px,4.4vw,52px);line-height:1.12;margin:0 0 16px;max-width:19ch;text-wrap:balance}
.hero p{font-size:19px;max-width:56ch;margin:0 0 26px;color:#e6eef7}
.hero .acciones{display:flex;gap:12px;flex-wrap:wrap}
@media (max-width:640px){.hero .coop-wrap{padding-top:56px;padding-bottom:60px}}

/* ==================== Secciones portada ==================== */
.seccion{padding:56px 0}
.seccion--alt{background:var(--c-fondo)}
.seccion-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap}
.seccion-head h2{font-size:27px;color:var(--c-azul-osc);margin:0;position:relative;padding-left:16px}
.seccion-head h2::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:5px;border-radius:3px;background:var(--c-rojo)}
.ver-todo{font-weight:600;text-decoration:none;white-space:nowrap}
.ver-todo::after{content:" \2192"}

.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:960px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* Tarjetas */
.card{background:#fff;border:1px solid var(--c-linea);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--sombra-hover)}
.card .thumb{aspect-ratio:16/9;overflow:hidden;background:var(--c-azul-claro)}
.card .thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.card:hover .thumb img{transform:scale(1.045)}
.card .cuerpo{padding:18px 20px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.card h3{margin:0;font-size:18.5px;line-height:1.35}
.card h3 a{text-decoration:none;color:var(--c-azul-osc)}
.card h3 a:hover{color:var(--c-rojo)}
.card p{margin:0;color:var(--c-gris);font-size:15px}
.card .meta{font-size:13px;color:var(--c-gris);display:flex;gap:12px;flex-wrap:wrap;margin-top:auto;padding-top:8px}
.chip{display:inline-block;background:var(--c-azul-claro);color:var(--c-azul-osc);font-size:12.5px;font-weight:600;padding:3px 10px;border-radius:999px}
.chip--rojo{background:#fdeaea;color:var(--c-rojo)}

/* Agenda */
.evento-item{display:flex;gap:18px;background:#fff;border:1px solid var(--c-linea);border-radius:var(--radio);padding:16px 18px;box-shadow:var(--sombra);align-items:flex-start;transition:transform .18s ease,box-shadow .18s ease}
.evento-item:hover{transform:translateY(-3px);box-shadow:var(--sombra-hover)}
.fecha-badge{flex:0 0 auto;width:64px;text-align:center;background:var(--c-azul);color:#fff;border-radius:9px;padding:8px 4px;line-height:1.15}
.fecha-badge .dia{display:block;font-size:24px;font-weight:800}
.fecha-badge .mes{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.evento-item h3{margin:0 0 4px;font-size:17.5px}
.evento-item h3 a{text-decoration:none;color:var(--c-azul-osc)}
.evento-item h3 a:hover{color:var(--c-rojo)}
.evento-item .lugar{font-size:14px;color:var(--c-gris)}

/* Documentos (repositorio) */
.doc-item{display:flex;gap:16px;align-items:center;background:#fff;border:1px solid var(--c-linea);border-radius:var(--radio);padding:14px 18px;box-shadow:var(--sombra);transition:transform .18s ease,box-shadow .18s ease}
.doc-item:hover{transform:translateY(-2px);box-shadow:var(--sombra-hover)}
.doc-item .di-main{flex:1;min-width:0}
.doc-item h3{margin:0 0 3px;font-size:16.5px}
.doc-item h3 a{text-decoration:none;color:var(--c-azul-osc)}
.doc-item h3 a:hover{color:var(--c-rojo)}
.doc-item .excerpt{margin:0 0 6px;font-size:14px;color:var(--c-gris)}
.doc-meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;font-size:12.5px;color:var(--c-gris)}
.fmt{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-width:52px;height:52px;border-radius:9px;color:#fff;font-weight:800;font-size:13px;letter-spacing:.03em}
.fmt--pdf{background:#a32d2d}.fmt--docx{background:#185fa5}.fmt--xlsx{background:#1e5b39}.fmt--pptx{background:#c25706}.fmt--zip{background:#5b6770}.fmt--doc{background:#5b6770}
.descargar{flex:0 0 auto;text-decoration:none;background:var(--c-azul);color:#fff;font-weight:600;font-size:14px;padding:9px 16px;border-radius:8px}
.descargar:hover{background:var(--c-azul-osc);color:#fff}
.doc-list{display:flex;flex-direction:column;gap:14px}

/* Toolbar filtros/buscador */
.toolbar{display:flex;flex-direction:column;gap:12px;background:#fff;border:1px solid var(--c-linea);border-radius:var(--radio);padding:16px 18px;margin-bottom:20px;box-shadow:var(--sombra)}
.fgroup{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fgroup .lbl{font-size:13px;font-weight:700;color:var(--c-gris);text-transform:uppercase;letter-spacing:.05em;margin-right:4px}
.fgroup button{border:1.5px solid var(--c-linea);background:#fff;color:var(--c-tinta);font-size:13.5px;padding:6px 13px;border-radius:999px;cursor:pointer}
.fgroup button:hover{border-color:var(--c-azul)}
.fgroup button[aria-pressed="true"]{background:var(--c-azul);border-color:var(--c-azul);color:#fff;font-weight:600}
.buscador input[type="search"]{width:100%;max-width:430px;padding:10px 14px;border:1.5px solid var(--c-linea);border-radius:9px;font-size:15px;font-family:inherit}
.fgroup select{padding:7px 10px;border:1.5px solid var(--c-linea);border-radius:8px;font-size:14px;font-family:inherit;background:#fff}
.contador{font-size:14px;color:var(--c-gris);margin:0 0 14px}
.oculto{display:none!important}
.vacio{color:var(--c-gris);font-style:italic}

/* AOD / Fondo Local */
.card-enlace{position:relative;border-radius:var(--radio);overflow:hidden;color:#fff;text-decoration:none;display:block;min-height:190px;box-shadow:var(--sombra);transition:transform .18s ease,box-shadow .18s ease}
.card-enlace:hover{transform:translateY(-4px);box-shadow:var(--sombra-hover)}
.card-enlace .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .3s ease}
.card-enlace:hover .bg{transform:scale(1.05)}
.card-enlace .velo{position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,53,95,.25),rgba(4,38,68,.85))}
.card-enlace .txt{position:relative;padding:26px 24px;display:flex;flex-direction:column;justify-content:flex-end;min-height:190px}
.card-enlace h3{margin:0 0 6px;font-size:21px;color:#fff}
.card-enlace p{margin:0;font-size:14.5px;color:#dbe7f3}
.card-enlace .ext{position:absolute;top:14px;right:16px;background:rgba(255,255,255,.18);border-radius:6px;padding:3px 9px;font-size:12px}

/* Newsletter */
.newsletter{background:linear-gradient(115deg,var(--c-azul-osc),var(--c-azul));color:#fff;border-radius:14px;padding:36px 34px;display:flex;gap:26px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.newsletter h2{margin:0 0 6px;font-size:24px;color:#fff}
.newsletter p{margin:0;color:#dbe7f3;max-width:52ch}
.newsletter form{display:flex;gap:10px;flex-wrap:wrap}
.newsletter input[type="email"]{padding:12px 16px;border-radius:9px;border:0;min-width:260px;font-size:15px;font-family:inherit}
.nl-ok{background:#e6f6ec;color:#14532d;border:1px solid #b7e4c7;border-radius:9px;padding:12px 16px;font-weight:600}
.nl-hp{position:absolute;left:-9999px}

/* ==================== Interior ==================== */
.page-head{background:linear-gradient(100deg,var(--c-azul-osc),var(--c-azul));color:#fff;padding:44px 0 38px;margin-bottom:38px}
.page-head h1{margin:0;font-size:clamp(26px,3.4vw,38px)}
.page-head .kick{margin:0 0 8px;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-amarillo);font-weight:700}
.entry{max-width:840px}
.entry p{margin:0 0 16px}
.entry h2{color:var(--c-azul-osc);margin:30px 0 12px}
.ficha{width:100%;border-collapse:collapse;margin:18px 0;font-size:15px}
.ficha th{width:230px;text-align:left;color:var(--c-azul-osc);padding:10px 12px;border-bottom:1px solid var(--c-linea);vertical-align:top}
.ficha td{padding:10px 12px;border-bottom:1px solid var(--c-linea)}
.ficha tr:nth-child(even){background:var(--c-fondo)}

/* ==================== Área privada ==================== */
.privado-login{max-width:460px;background:#fff;border:1px solid var(--c-linea);border-radius:var(--radio);box-shadow:var(--sombra);padding:30px 30px 24px;margin:10px auto 40px}
.privado-login h2{margin:0 0 8px;color:var(--c-azul-osc)}
.privado-login p{color:var(--c-gris);font-size:14.5px}
.privado-login .login-username label,.privado-login .login-password label{display:block;font-weight:600;margin-bottom:4px}
.privado-login input[type="text"],.privado-login input[type="password"]{width:100%;padding:11px 13px;border:1.5px solid var(--c-linea);border-radius:8px;font-size:15px;font-family:inherit;margin-bottom:14px}
.privado-login .login-submit input{background:var(--c-azul);border:0;color:#fff;font-weight:700;padding:11px 22px;border-radius:999px;cursor:pointer;font-size:15px}
.privado-login .login-remember{font-size:14px;margin-bottom:10px}
.candado{display:inline-flex;align-items:center;gap:8px;background:var(--c-azul-claro);color:var(--c-azul-osc);font-weight:600;font-size:13.5px;padding:5px 13px;border-radius:999px}

.grupo-card{background:#fff;border:1px solid var(--c-linea);border-left:5px solid var(--c-azul);border-radius:var(--radio);box-shadow:var(--sombra);padding:22px 24px;transition:transform .18s ease,box-shadow .18s ease}
.grupo-card:hover{transform:translateY(-3px);box-shadow:var(--sombra-hover)}
.grupo-card h3{margin:0 0 6px;font-size:19px}
.grupo-card h3 a{color:var(--c-azul-osc);text-decoration:none}
.grupo-card h3 a:hover{color:var(--c-rojo)}
.grupo-card .miembros{font-size:13.5px;color:var(--c-gris)}
.aviso{background:#fff8e6;border:1px solid #f0dfae;border-left:4px solid var(--c-amarillo);border-radius:8px;padding:12px 16px;margin:0 0 12px;font-size:14.5px}
.aviso .fecha{color:var(--c-gris);font-size:12.5px;display:block;margin-bottom:2px}
.privado-bar{display:flex;justify-content:space-between;align-items:center;gap:14px;background:var(--c-azul-claro);border-radius:9px;padding:10px 16px;margin-bottom:24px;font-size:14.5px;flex-wrap:wrap}

/* ==================== Footer ==================== */
.site-foot{background:var(--c-azul-osc);color:#c3d4e5;margin-top:64px;font-size:14.5px}
.site-foot .coop-wrap{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:30px;padding:44px 22px 34px}
.site-foot h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.07em;margin:0 0 12px}
.site-foot ul{list-style:none;margin:0;padding:0}
.site-foot li{margin-bottom:7px}
.site-foot a{color:#c3d4e5;text-decoration:none}
.site-foot a:hover{color:#fff;text-decoration:underline}
.foot-marca strong{color:#fff;font-size:16px;display:block;margin-bottom:6px}
.foot-legal{border-top:1px solid rgba(255,255,255,.15)}
.foot-legal .coop-wrap{display:flex;justify-content:space-between;gap:14px;padding:16px 22px;flex-wrap:wrap;font-size:13px}
.foot-legal a{color:#c3d4e5;text-decoration:none}
.foot-legal a:hover{text-decoration:underline}
@media (max-width:900px){.site-foot .coop-wrap{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.site-foot .coop-wrap{grid-template-columns:1fr}}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.reveal.visto{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* Formularios genéricos */
.campo label{display:block;font-weight:600;margin-bottom:4px}
.campo input,.campo textarea{width:100%;padding:11px 13px;border:1.5px solid var(--c-linea);border-radius:8px;font-family:inherit;font-size:15px;margin-bottom:14px}

/* ==================== Banner cookies ==================== */
.cb-banner{position:fixed;left:0;right:0;bottom:0;z-index:998;background:#fff;border-top:3px solid var(--c-azul);box-shadow:0 -6px 24px rgba(6,53,95,.18);padding:16px 22px;display:flex;gap:20px;align-items:center;justify-content:space-between;flex-wrap:wrap;font-size:14px}
.cb-banner .cb-txt{max-width:720px}
.cb-banner p{margin:4px 0 0;color:var(--c-gris)}
.cb-cats{display:flex;gap:18px;flex-wrap:wrap;margin-top:10px}
.cb-cats label{display:flex;gap:6px;align-items:center;font-weight:600}
.cb-botones{display:flex;gap:10px;flex-wrap:wrap}
@media (max-width:640px){.cb-banner{flex-direction:column;align-items:stretch}.cb-botones{justify-content:stretch}.cb-botones .btn{flex:1;text-align:center}}

/* ==================== 404 ==================== */
.err404{text-align:center;padding:70px 20px}
.err404 .num{font-size:120px;font-weight:800;color:var(--c-azul-claro);line-height:1;letter-spacing:.02em;text-shadow:0 2px 0 var(--c-linea)}
.err404 h1{color:var(--c-azul-osc);margin:10px 0 8px}
.err404 p{color:var(--c-gris);max-width:52ch;margin:0 auto 22px}
