/* ============================================================
   SISTEMA VISUAL · UJP-ISEHF · webproX
   chrome.css — Header + Footer · theming por institución · MOBILE FIRST
   UJP: magenta vivo + glassmorphism · ISEHF: naranja + vino oscuro
   Íconos Lucide inline. Tamaños generosos (Carmen). Fiel a capturas reales.
   ============================================================ */

/* ---- THEMING por institución ---- */
.ujp-chrome.is-ujp{
  --c-grad-from:#BD2453; --c-grad-to:#f2295b;     /* header magenta vivo (real) */
  --c-footer:#BD2453;                              /* footer magenta vivo (real) */
  --c-wine-deep:#6B1B31; --c-accent:#FEDF20;       /* amarillo: footer (íconos sedes) */
  --c-nav-accent:#FFFFFF;                          /* nav UJP activo/hover en BLANCO (sin amarillo) */
  --c-font-display:var(--ujp-font-display, "Amelia Basis", Georgia, serif);
  --c-font-body:"Inter", system-ui, sans-serif;
  --c-nav-font:var(--ujp-font-display, "Amelia Basis", Georgia, serif);  /* nav UJP en Amelia */
  --c-nav-size:19px;
}
.ujp-chrome.is-isehf{
  --c-grad-from:#E3882E; --c-grad-to:#E3882E;      /* topbar naranja (sin amarillo) */
  --c-bar:#A02654;                                 /* barra principal: VINO VIVO real (#A02654 prima) */
  --c-footer:#A02654;                              /* footer ISEHF: vino vivo real */
  --c-wine-deep:#470426; --c-accent:#E3882E;       /* naranja ISEHF */
  --c-nav-accent:#E3882E;                          /* nav ISEHF activo/hover naranja */
  --c-font-display:"DM Serif Display", Georgia, serif;
  --c-font-body:"DM Sans", system-ui, sans-serif;
  --c-nav-font:"DM Sans", system-ui, sans-serif;   /* nav ISEHF en DM Sans (sin Inter) */
  --c-nav-size:17px;
}

/* ============================================================
   HEADER (común) — MOBILE FIRST (base = chico, escala a desktop)
   ============================================================ */
.ujp-chrome .ch-header{position:absolute;top:0;left:0;right:0;z-index:99;font-family:var(--c-font-body)}

/* topbar: en mobile se oculta lo no esencial; en desktop fila completa */
.ujp-chrome .ch-top{display:none;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem 1.2rem;padding:.5rem 1rem;
  background:rgba(0,0,0,.18);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px)}  /* oculto en mobile, exclusivo desktop */
.ujp-chrome.is-isehf .ch-top{background:linear-gradient(268deg,var(--c-grad-from),var(--c-grad-to));backdrop-filter:none}
.ujp-chrome .ch-top a,.ujp-chrome .ch-top .ch-loc{color:rgba(255,255,255,.9);text-decoration:none;font-size:.8rem;font-weight:500;display:inline-flex;align-items:center;gap:.4rem;transition:color .2s,transform .2s}
.ujp-chrome .ch-top .ch-loc{cursor:pointer}
.ujp-chrome .ch-top .ch-loc:hover{color:#fff;transform:scale(1.06)}  /* GROW en direcciones */
.ujp-chrome .ch-top a{transition:color .2s,transform .2s}
.ujp-chrome .ch-top a:hover{color:#fff;transform:scale(1.06)}  /* GROW en links del topbar (ambos sitios) */
.ujp-chrome .ch-top svg{width:14px;height:14px;stroke:currentColor;stroke-width:2;fill:none;flex-shrink:0}
.ujp-chrome .ch-top a svg.ic-brand{fill:currentColor !important;stroke:none !important}  /* WhatsApp marca en topbar */
.ujp-chrome .ch-top .sep{width:1px;height:13px;background:rgba(255,255,255,.3);display:none}
.ujp-chrome .ch-top-social{display:inline-flex;gap:.5rem;margin-left:.3rem}
.ujp-chrome .ch-top-social a{width:28px;height:28px;min-width:28px;flex:0 0 28px;aspect-ratio:1/1;border-radius:50%;background:rgba(255,255,255,.18);display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;transition:transform .25s ease,background .2s}
.ujp-chrome .ch-top-social a:hover{transform:scale(1.18);background:rgba(255,255,255,.3)}  /* GROW */
.ujp-chrome .ch-top-social svg{width:14px;height:14px;fill:#fff;stroke:none}

/* barra principal */
.ujp-chrome .ch-main{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;
  background:linear-gradient(351deg,var(--c-grad-from) 0%,var(--c-grad-to) 100%)}
.ujp-chrome.is-isehf .ch-main{background:linear-gradient(180deg,#A02654 0%,#A02654 70%,#6e1a38 100%)}
.ujp-chrome .ch-logo img{height:48px;width:auto;display:block}
.ujp-chrome .ch-nav{display:none;align-items:center;gap:1.4rem}  /* oculto en mobile */
.ujp-chrome .ch-nav a{color:#fff;text-decoration:none;font-family:var(--c-nav-font);font-size:var(--c-nav-size);font-weight:400;letter-spacing:.01em;display:inline-flex;align-items:center;gap:.3rem;position:relative;padding:.3rem 0;white-space:nowrap;transition:opacity .2s}
.ujp-chrome.is-isehf .ch-nav a{font-weight:600;text-transform:uppercase;font-size:15px;letter-spacing:.03em}
.ujp-chrome .ch-nav a svg{width:13px;height:13px;stroke:currentColor;stroke-width:2.4;fill:none;opacity:.8}
/* menú con GROW en vez de subrayado */
.ujp-chrome .ch-nav a{transition:opacity .2s,transform .2s,color .2s}
.ujp-chrome .ch-nav a:hover{transform:scale(1.08)}
.ujp-chrome .ch-nav a.active{font-weight:700}
.ujp-chrome .ch-nav a.active{color:var(--c-nav-accent)}
.ujp-chrome .ch-cta{margin-left:1rem;background:var(--c-accent);color:var(--c-wine-deep);padding:.6rem 1.5rem;border-radius:999px;font-family:var(--c-font-body);font-size:.9rem;font-weight:700;text-decoration:none;white-space:nowrap;transition:transform .2s,box-shadow .2s,filter .2s}
.ujp-chrome .ch-cta::after{display:none !important}  /* el CTA no lleva la rayita de los links */
.ujp-chrome .ch-cta:hover{transform:translateY(-1px);filter:brightness(1.08);box-shadow:0 8px 20px -6px rgba(0,0,0,.4)}
.ujp-chrome .ch-burger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:.4rem;background:none;border:none;flex-shrink:0}
.ujp-chrome .ch-burger span{width:25px;height:2px;background:#fff;border-radius:2px}

/* DESKTOP: nav visible, burger oculto, topbar separadores */
@media (min-width:861px){
  .ujp-chrome .ch-top{display:flex;justify-content:flex-end;gap:1.4rem;padding:.55rem 2rem}
  .ujp-chrome .ch-top .sep{display:block}
  .ujp-chrome .ch-main{padding:1rem 2rem}
  .ujp-chrome .ch-logo img{height:58px}
  .ujp-chrome .ch-nav{display:flex}
  .ujp-chrome .ch-burger{display:none}
}

/* ============================================================
   FOOTER (común) — MOBILE FIRST
   ============================================================ */
.ujp-chrome .ch-footer{background:var(--c-footer);color:#fff;font-family:var(--c-font-body)}
.ujp-chrome .ch-ft-main{max-width:1180px;margin:0 auto;padding:2.5rem 1.2rem 1.5rem;display:grid;grid-template-columns:1fr;gap:2rem;text-align:center}
.ujp-chrome .ch-ft-brand{display:flex;flex-direction:column;align-items:center}
.ujp-chrome .ch-ft-brand img{height:120px;width:auto;margin-bottom:1rem;display:block;transition:transform .25s ease}
.ujp-chrome .ch-ft-brand a{display:inline-block;cursor:pointer}
.ujp-chrome .ch-ft-brand a:hover img{transform:scale(1.06)}  /* escudo grow + enlace */
.ujp-chrome .ch-ft-brand p{color:rgba(255,255,255,.78);font-size:.92rem;max-width:34ch;line-height:1.6;margin:0 auto}
.ujp-chrome .ch-ft-col h4{font-family:var(--c-font-display);font-size:1.15rem;font-weight:700;margin-bottom:1rem;color:#fff}
.ujp-chrome.is-isehf .ch-ft-col h4,.ujp-chrome.is-isehf .ch-ft-title{font-family:"DM Serif Display",serif}
.ujp-chrome .ch-ft-col ul{list-style:none}
.ujp-chrome .ch-ft-col li{margin-bottom:.65rem}
.ujp-chrome .ch-ft-col a{color:rgba(255,255,255,.82);text-decoration:none;font-size:.95rem;transition:color .2s;display:inline-flex;align-items:center;gap:.5rem;justify-content:center}
.ujp-chrome .ch-ft-col a:hover{color:var(--c-accent)}
.ujp-chrome .ch-contact .row{display:inline-flex;align-items:center;gap:.6rem;margin-bottom:.75rem;font-size:.95rem;color:rgba(255,255,255,.85);justify-content:center;width:100%}
.ujp-chrome .ch-contact svg{width:17px;height:17px;stroke:var(--c-accent);stroke-width:1.9;fill:none;flex-shrink:0}
/* filas de contacto como botones (a.row): cambian color en hover como el resto */
.ujp-chrome .ch-contact a.row{text-decoration:none;transition:color .2s}
.ujp-chrome .ch-contact a.row:hover{color:var(--c-accent)}
.ujp-chrome .ch-contact a.row:hover svg{stroke:var(--c-accent)}
.ujp-chrome .ch-contact a.row.is-brand:hover svg{fill:var(--c-accent);stroke:none}
.ujp-chrome .ch-social{display:flex;gap:.7rem;margin-top:1rem;justify-content:center}
.ujp-chrome .ch-social a{width:38px;height:38px;min-width:38px;min-height:38px;flex:0 0 38px;aspect-ratio:1/1;border-radius:50%;background:#fff;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;line-height:0;padding:0;transition:transform .25s ease,box-shadow .25s ease}
.ujp-chrome .ch-social a:hover{transform:scale(1.15);box-shadow:0 8px 20px -6px rgba(0,0,0,.35)}  /* GROW */
.ujp-chrome .ch-social svg{display:block;margin:auto}  /* centrado real del ícono */
.ujp-chrome .ch-social svg{width:17px;height:17px;fill:var(--c-footer);stroke:none}

/* franja "Pertenecemos a" (logos de red a COLOR sobre blanco — fiel a ISEHF) */
.ujp-chrome .ch-network-band{background:#fff;padding:2rem 1.2rem}
.ujp-chrome .ch-network-band .lbl{text-align:center;font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--c-footer);opacity:.7;margin-bottom:1.3rem}
.ujp-chrome .ch-network{max-width:900px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap}
.ujp-chrome .ch-network img{height:60px;width:auto;opacity:.9;transition:opacity .2s}
.ujp-chrome .ch-network a:hover img{opacity:1}

.ujp-chrome .ch-bottom{position:relative;background:var(--c-footer);border-top:1px solid rgba(255,255,255,.85);padding:1.2rem;text-align:center;font-size:.85rem;color:rgba(255,255,255,.8)}  /* mismo magenta + línea blanca */
.ujp-chrome .ch-credit{position:absolute;right:1.2rem;bottom:.5rem;font-size:.66rem;letter-spacing:.02em;color:rgba(255,255,255,.32);text-decoration:none;transition:color .2s}
.ujp-chrome .ch-credit:hover{color:rgba(255,255,255,.6)}
@media (max-width:720px){.ujp-chrome .ch-credit{position:static;display:block;margin-top:.6rem;text-align:center}}

/* DESKTOP footer: columnas */
@media (min-width:721px){
  .ujp-chrome.is-ujp .ch-ft-main{grid-template-columns:auto 1fr 1fr 1fr;gap:2.5rem;text-align:left;align-items:start}
  .ujp-chrome.is-ujp .ch-ft-brand{align-items:flex-start}
  .ujp-chrome.is-ujp .ch-ft-col a,.ujp-chrome.is-ujp .ch-contact .row{justify-content:flex-start;width:auto}
  .ujp-chrome.is-ujp .ch-social{justify-content:flex-start}
  .ujp-chrome .ch-ft-main{padding:3.2rem 2rem 2rem}
}

/* íconos de marca embebidos en contexto de interfaz (ej: WhatsApp en filas de contacto) */
.ujp-chrome .ch-contact svg.ic-brand,.ujp-chrome .ic-brand{fill:var(--c-accent) !important;stroke:none !important}
.ujp-chrome .ch-contact .row svg.ic-brand{fill:var(--c-accent) !important;stroke:none !important}


/* ============================================================
   SECCIÓN DE MAPAS · facade (liviano: imagen estática, iframe al click)
   ============================================================ */
.ujp-chrome .ch-maps{background:var(--ujp-paper, #FBF8F4);padding:3rem 1.2rem 2.5rem}  /* franja de mapas en claro (paper), el resto del footer sigue magenta */
.ujp-chrome .ch-maps-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:2rem}
.ujp-chrome .ch-map h4{text-align:center;font-family:var(--c-font-display);font-size:1.3rem;font-weight:700;color:var(--c-wine-deep);margin-bottom:1.2rem;position:relative;display:inline-block;left:50%;transform:translateX(-50%)}
.ujp-chrome .ch-map h4::after{content:'';position:absolute;left:0;right:0;bottom:-5px;height:2px;background:var(--c-footer)}  /* subrayado magenta sobre claro */
.ujp-chrome .ch-map-frame{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 10px 28px -14px rgba(0,0,0,.4);aspect-ratio:4/3;background:#dfe3e6}
/* facade: capa estática con patrón de mapa + botón. Al click, JS inyecta el iframe */
.ujp-chrome .ch-map-facade{position:absolute;inset:0;cursor:pointer;display:flex;align-items:flex-start;justify-content:flex-start;padding:1rem;
  background-size:cover;background-position:center;background-color:#dde1e4;transition:filter .2s}
.ujp-chrome .ch-map-facade:hover{filter:brightness(1.04) saturate(1.05)}
.ujp-chrome .ch-map-facade::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.04);pointer-events:none}
.ujp-chrome .ch-map-pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-100%);width:34px;height:34px;color:#d4324a;filter:drop-shadow(0 3px 4px rgba(0,0,0,.3))}
.ujp-chrome .ch-map-pin svg{width:100%;height:100%;fill:#d4324a;stroke:#fff;stroke-width:1}
.ujp-chrome .ch-map-open{position:relative;z-index:2;background:#fff;color:#1a73e8;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;box-shadow:0 2px 6px rgba(0,0,0,.2);transition:box-shadow .2s}
.ujp-chrome .ch-map-open:hover{box-shadow:0 4px 12px rgba(0,0,0,.3)}
.ujp-chrome .ch-map-open svg{width:14px;height:14px;stroke:currentColor;stroke-width:2;fill:none}
.ujp-chrome .ch-map-hint{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);z-index:2;background:rgba(0,0,0,.6);color:#fff;padding:.35rem .8rem;border-radius:999px;font-size:.72rem;pointer-events:none;white-space:nowrap}
.ujp-chrome .ch-map-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

@media (min-width:721px){
  .ujp-chrome .ch-maps-grid{grid-template-columns:1fr 1fr 1fr}
}
