/**
 * 100 VOCES / Alumni Emprendedores
 * css/emprendedores.css
 * RUTA: /var/www/html/cien-voces/web/themes/custom/utpl_template/css/emprendedores.css
 */

:root {
  --cv-primario:    #003F72;
  --cv-primario-h:  #004d8c;
  --cv-secundario:  #EAAB00;
  --cv-terciario1:  #A71930;
  --cv-terciario2:  #7D7D7D;
  --cv-blanco:      #ffffff;
  --cv-crema:       #F7F5F0;
  --cv-crema-2:     #EFEDE7;
  --cv-shadow-sm:   0 1px 4px rgba(0,63,114,0.07), 0 2px 14px rgba(0,63,114,0.06);
  --cv-shadow-lg:   0 12px 40px rgba(0,63,114,0.18);
  --cv-radius-sm:   8px;
  --cv-radius-md:   14px;
  --cv-radius-lg:   20px;
  --cv-radius-pill: 999px;
  --cv-font-display:'Lora', Georgia, serif;
  --cv-font-body:   'Inter', system-ui, sans-serif;
  --cv-transition:  all .22s ease;
}

/* ══ BLOQUE ══ */
.em-bloque { font-family: var(--cv-font-body) !important; color: #222 !important; margin: 0 !important; padding: 0 !important; -webkit-font-smoothing: antialiased; }
.em-bloque .em-container { max-width: 1200px !important; margin-left: auto !important; margin-right: auto !important; padding-left: 32px !important; padding-right: 32px !important; width: 100% !important; }
@media(max-width:640px){ .em-bloque .em-container { padding-left: 16px !important; padding-right: 16px !important; } }

/* ══ HERO ══ */
.em-bloque .em-hero {
  background: var(--cv-primario) !important;
  padding: 56px 0 44px !important;
  position: relative; overflow: hidden;
}
.em-bloque .em-hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 60% 80% at 85% 50%, rgba(234,171,0,0.10) 0%, transparent 65%),
              radial-gradient(ellipse 40% 60% at 5%  90%, rgba(167,25,48,0.10) 0%, transparent 55%);
}
.em-bloque .em-hero__eyebrow { display: inline-flex !important; align-items: center !important; gap: 8px !important; background: rgba(234,171,0,0.14) !important; border: 1px solid rgba(234,171,0,0.30) !important; color: var(--cv-secundario) !important; font-size: 11px !important; font-weight: 600 !important; letter-spacing: .12em !important; text-transform: uppercase !important; padding: 5px 14px !important; border-radius: var(--cv-radius-pill) !important; margin-bottom: 18px !important; width: fit-content !important; position: relative; z-index: 1; }
.em-bloque .em-hero__eyebrow::before { content: '' !important; width: 6px !important; height: 6px !important; background: var(--cv-secundario) !important; border-radius: 50% !important; display: inline-block !important; }
.em-bloque .em-hero__title { font-family: var(--cv-font-display) !important; font-size: clamp(28px,4vw,48px) !important; color: var(--cv-blanco) !important;  line-height: 1.15 !important; margin-bottom: 12px !important; position: relative; z-index: 1; }
.em-bloque .em-hero__title em { color: var(--cv-secundario) !important; font-style: italic !important; }
.em-bloque .em-hero__desc { font-size: 16px !important; color: rgba(255,255,255,0.65) !important; max-width: 520px !important; line-height: 1.75 !important; font-weight: 300 !important; position: relative; z-index: 1; }

/* ══ CONTROLES ══ */
.em-bloque .em-controles { background: var(--cv-blanco) !important; padding: 16px 0 !important; border-bottom: 1px solid #e5e3dc !important; position: sticky !important; top: 0 !important; z-index: 200 !important; box-shadow: 0 2px 10px rgba(0,63,114,0.06) !important; }
.em-bloque .em-searchbar { display: flex !important; gap: 12px !important; align-items: center !important; flex-wrap: wrap !important; }
.em-bloque .em-searchbar__input-wrap { flex: 1 !important; min-width: 200px !important; display: flex !important; align-items: center !important; gap: 10px !important; background: var(--cv-crema) !important; border: 2px solid transparent !important; border-radius: var(--cv-radius-pill) !important; padding: 9px 18px !important; transition: border-color .2s !important; box-shadow: none !important; }
.em-bloque .em-searchbar__input-wrap:focus-within { border-color: var(--cv-secundario) !important; box-shadow: 0 0 0 3px rgba(234,171,0,0.13) !important; }
.em-bloque .em-searchbar__icon { color: var(--cv-terciario2) !important; flex-shrink: 0 !important; }
.em-bloque .em-searchbar__input,
.em-bloque input.em-searchbar__input { border: none !important; outline: none !important; background: transparent !important; box-shadow: none !important; font-size: 14px !important; color: var(--cv-primario) !important; width: 100% !important; font-family: var(--cv-font-body) !important; padding: 0 !important; margin: 0 !important; height: auto !important; }
.em-bloque .em-searchbar__input:focus { border: none !important; box-shadow: none !important; outline: none !important; }
.em-bloque .em-searchbar__input::placeholder { color: #bbb !important; }
.em-bloque .em-chips { display: flex !important; gap: 7px !important; flex-wrap: wrap !important; }
.em-bloque .em-chip,
.em-bloque button.em-chip { padding: 6px 14px !important; border-radius: var(--cv-radius-pill) !important; font-size: 12.5px !important; font-weight: 500 !important; border: 1.5px solid #d5d3ce !important; background: transparent !important; color: var(--cv-terciario2) !important; cursor: pointer !important; transition: var(--cv-transition) !important; font-family: var(--cv-font-body) !important; display: inline-flex !important; align-items: center !important; }
.em-bloque .em-chip:hover { border-color: var(--cv-primario) !important; color: var(--cv-primario) !important; }
.em-bloque .em-chip.is-active { background: var(--cv-primario) !important; color: var(--cv-blanco) !important; border-color: var(--cv-primario) !important; }
.em-bloque .em-chip.is-disabled { opacity: .32 !important; pointer-events: none !important; }
.em-bloque .em-chip[data-cat="alimentos"]  { --chip-cat:#e65c00; }
.em-bloque .em-chip[data-cat="tecnologia"] { --chip-cat:#1257d9; }
.em-bloque .em-chip[data-cat="salud"]      { --chip-cat:#0f9f76; }
.em-bloque .em-chip[data-cat="educacion"]  { --chip-cat:#a71930; }
.em-bloque .em-chip[data-cat="moda"]       { --chip-cat:#8b1bb1; }
.em-bloque .em-chip[data-cat="servicios"]  { --chip-cat:#d19200; }
.em-bloque .em-chip[data-cat="arte"]       { --chip-cat:#f15a24; }
.em-bloque .em-chip[data-cat]:not([data-cat="todos"]) { border-color: color-mix(in srgb, var(--chip-cat) 30%, white 70%) !important; color: var(--chip-cat) !important; background: color-mix(in srgb, var(--chip-cat) 8%, white 92%) !important; }
.em-bloque .em-chip[data-cat]:not([data-cat="todos"]).is-active { background: var(--chip-cat) !important; border-color: var(--chip-cat) !important; color: #fff !important; }
.em-bloque .em-count { font-size: 13px !important; color: var(--cv-terciario2) !important; white-space: nowrap !important; font-weight: 500 !important; }
.em-bloque .em-reset { display: inline-flex !important; align-items: center !important; gap: 6px !important; background: transparent !important; border: 1.5px solid var(--cv-terciario2) !important; color: var(--cv-terciario2) !important; font-size: 12.5px !important; font-weight: 500 !important; padding: 6px 14px !important; border-radius: var(--cv-radius-pill) !important; cursor: pointer !important; font-family: var(--cv-font-body) !important; transition: var(--cv-transition) !important; white-space: nowrap !important; }
.em-bloque .em-reset:hover { border-color: var(--cv-terciario1) !important; color: var(--cv-terciario1) !important; }
.em-bloque .em-reset[hidden] { display: none !important; }

/* ══ ABECEDARIO ══ */
.em-bloque .em-abc-bar { background: var(--cv-blanco) !important; border-bottom: 2px solid var(--cv-crema-2) !important; padding: 14px 0 !important; }
.em-bloque .em-abc-bar__label { font-size: 11px !important; font-weight: 600 !important; letter-spacing: .12em !important; text-transform: uppercase !important; color: var(--cv-terciario2) !important; margin-bottom: 10px !important; }
.em-bloque .em-abc-bar__row { display: flex !important; flex-wrap: wrap !important; gap: 5px !important; }
.em-bloque .em-abc-btn,
.em-bloque button.em-abc-btn { min-width: 34px !important; height: 34px !important; padding: 0 5px !important; border-radius: var(--cv-radius-sm) !important; border: none !important; background: var(--cv-crema-2) !important; color: var(--cv-primario) !important; font-family: var(--cv-font-display) !important;  font-size: 15px !important; cursor: pointer !important; transition: var(--cv-transition) !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.em-bloque .em-abc-btn:hover { background: var(--cv-primario) !important; color: var(--cv-secundario) !important; transform: scale(1.08) !important; }
.em-bloque .em-abc-btn.is-active { background: var(--cv-primario) !important; color: var(--cv-secundario) !important; box-shadow: 0 2px 10px rgba(0,63,114,.22) !important; transform: scale(1.08) !important; }
.em-bloque .em-abc-btn.is-empty   { opacity: .22 !important; pointer-events: none !important; }
.em-bloque .em-abc-btn.is-disabled { opacity: .32 !important; pointer-events: none !important; }

/* ══ GRID ══ */
.em-bloque .em-grid-wrap { background: var(--cv-crema) !important; padding: 36px 0 60px !important; }
.em-bloque .em-grid > div,
.em-bloque .em-grid > div > div { display: contents !important; }
.em-bloque .em-grid { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)) !important; gap: 18px !important; }

/* ══ TARJETA ══ */
.em-bloque .em-card {
  --em-cat: var(--cv-primario);
  --em-cat-2: var(--cv-secundario);
  --em-cat-soft: rgba(0,63,114,0.08);
  --em-cat-border: rgba(0,63,114,0.18);
  background: var(--cv-blanco) !important;
  border-radius: var(--cv-radius-lg) !important;
  overflow: hidden !important;
  box-shadow: 0 12px 34px rgba(0, 31, 63, 0.09) !important;
  border: 1.5px solid rgba(0, 63, 114, 0.08) !important;
  display: flex !important;
  flex-direction: column !important;
  cursor: pointer !important;
  transition: transform .24s, box-shadow .24s, border-color .24s !important;
  margin: 0 !important;
}
.em-bloque .em-card:hover { transform: translateY(-6px) !important; box-shadow: 0 20px 48px rgba(0,63,114,0.18) !important; border-color: var(--em-cat-border) !important; }
.em-bloque .em-card[data-hidden="true"] { display: none !important; }

/* Franja de color por categoría */
.em-bloque .em-card[data-cat="alimentos"]  { --em-cat:#e65c00; --em-cat-2:#f9d423; --em-cat-soft:rgba(230,92,0,0.10); --em-cat-border:rgba(230,92,0,0.28); }
.em-bloque .em-card[data-cat="tecnologia"] { --em-cat:#1257d9; --em-cat-2:#34b7f1; --em-cat-soft:rgba(18,87,217,0.10); --em-cat-border:rgba(18,87,217,0.28); }
.em-bloque .em-card[data-cat="salud"]      { --em-cat:#0f9f76; --em-cat-2:#43d889; --em-cat-soft:rgba(15,159,118,0.10); --em-cat-border:rgba(15,159,118,0.28); }
.em-bloque .em-card[data-cat="educacion"]  { --em-cat:#a71930; --em-cat-2:#e05c78; --em-cat-soft:rgba(167,25,48,0.10); --em-cat-border:rgba(167,25,48,0.28); }
.em-bloque .em-card[data-cat="moda"]       { --em-cat:#8b1bb1; --em-cat-2:#e05cc9; --em-cat-soft:rgba(139,27,177,0.10); --em-cat-border:rgba(139,27,177,0.28); }
.em-bloque .em-card[data-cat="servicios"]  { --em-cat:#eaab00; --em-cat-2:#f6d778; --em-cat-soft:rgba(234,171,0,0.14); --em-cat-border:rgba(234,171,0,0.34); }
.em-bloque .em-card[data-cat="arte"]       { --em-cat:#f15a24; --em-cat-2:#f7b733; --em-cat-soft:rgba(241,90,36,0.10); --em-cat-border:rgba(241,90,36,0.28); }
.em-bloque .em-card__banner { height: 6px !important; background: linear-gradient(90deg, var(--em-cat), var(--em-cat-2)) !important; }

/* Cuerpo de tarjeta */
.em-bloque .em-card__body { padding: 18px 20px 0 !important; display: flex !important; align-items: flex-start !important; gap: 16px !important; }
.em-bloque .em-card__logo-wrap { width: 76px !important; height: 76px !important; border-radius: 11px !important; background: var(--cv-crema-2) !important; border: 1px solid #e8e6e1 !important; overflow: hidden !important; flex-shrink: 0 !important; display: flex !important; align-items: center !important; justify-content: center !important; font-family: var(--cv-font-display) !important; font-size: 22px !important; color: var(--em-cat) !important; box-shadow: 0 8px 20px rgba(0,63,114,0.08) !important; }
.em-bloque .em-card__logo-wrap img,
.em-bloque .em-card__logo-wrap .field--type-image img { width: 76px !important; height: 76px !important; object-fit: cover !important; object-position: center !important; display: block !important; margin: 0 !important; border-radius: 0 !important; max-width: none !important; }
.em-bloque .em-card__info { flex: 1 !important; min-width: 0 !important; }
.em-bloque .em-card__cat-badge { display: inline-flex !important; align-items: center !important; padding: 4px 10px !important; border-radius: var(--cv-radius-pill) !important; font-size: 10px !important; font-weight: 800 !important; letter-spacing: .06em !important; text-transform: uppercase !important; background: var(--em-cat-soft) !important; border: 1px solid var(--em-cat-border) !important; color: var(--em-cat) !important; margin-bottom: 7px !important; }
.em-bloque .em-card__nombre { font-family: var(--cv-font-body) !important; font-weight: 800 !important; font-size: 20px !important; color: #071b4d !important; line-height: 1.15 !important; margin-bottom: 6px !important; letter-spacing: 0 !important; }
.em-bloque .em-card__ubicacion { font-size: 12.5px !important; color: #7c8593 !important; display: flex !important; align-items: center !important; gap: 5px !important; }
.em-bloque .em-card__ubicacion svg { width: 13px !important; height: 13px !important; }

/* Descripción */
.em-bloque .em-card__desc-wrap { margin: 16px 20px 0 !important; padding: 14px 0 0 !important; border-top: 1px solid #eceff3 !important; }
.em-bloque .em-card__desc,
.em-bloque p.em-card__desc { font-size: 13.5px !important; color: #4d5563 !important; line-height: 1.55 !important; margin: 0 !important; overflow: hidden !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; }

/* Beneficio */
.em-bloque .em-card__beneficio { margin: 14px 20px 0 !important; background: linear-gradient(90deg, var(--em-cat-soft), rgba(255,255,255,0.78)) !important; border-left: 4px solid var(--em-cat) !important; border-radius: 7px !important; padding: 11px 14px !important; }
.em-bloque .em-card__beneficio-label { display: flex !important; align-items: center !important; gap: 8px !important; font-size: 10.5px !important; font-weight: 800 !important; letter-spacing: .08em !important; text-transform: uppercase !important; color: var(--em-cat) !important; margin-bottom: 5px !important; }
.em-bloque .em-card__beneficio-ico { width: 22px !important; height: 22px !important; border-radius: 7px !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; color: #fff !important; background: var(--em-cat) !important; flex: 0 0 22px !important; }
.em-bloque .em-card__beneficio-ico svg { width: 12px !important; height: 12px !important; }
.em-bloque .em-card__beneficio-texto { font-size: 13px !important; color: #071b4d !important;  line-height: 1.45 !important; overflow: hidden !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; padding-left: 30px !important; }

/* Footer */
.em-bloque .em-card__footer { margin-top: auto !important; padding: 16px 20px 18px !important; border-top: 1px solid #f0ede8 !important; display: flex !important; align-items: center !important; justify-content: space-between !important; gap: 10px !important; }
.em-bloque .em-card__contactos { display: flex !important; gap: 6px !important; flex-wrap: wrap !important; }
.em-bloque .em-card__ico { width: 34px !important; height: 34px !important; border-radius: 9px !important; border: 1px solid #dfe4ec !important; background: #fff !important; display: flex !important; align-items: center !important; justify-content: center !important; text-decoration: none !important; transition: var(--cv-transition) !important; flex-shrink: 0 !important; box-shadow: 0 6px 14px rgba(0,63,114,0.05) !important; }
.em-bloque .em-card__ico:hover { transform: scale(1.12) !important; }
.em-bloque .em-card__ico--web { color: var(--cv-primario) !important; }
.em-bloque .em-card__ico--fb  { color: #1877f2 !important; }
.em-bloque .em-card__ico--ig  { color: #e1306c !important; }
.em-bloque .em-card__ico--yt  { color: #ff0000 !important; }
.em-bloque .em-card__ico--wa  { color: #25D366 !important; }
.em-bloque .em-card__ico--li  { color: #0a66c2 !important; }
.em-bloque .em-card__ico--tt  { color: #010101 !important; }
.em-bloque .em-card__ico svg { width: 16px !important; height: 16px !important; }
.em-bloque .em-card__btn-ver { display: inline-flex !important; align-items: center !important; gap: 8px !important; font-size: 13px !important; font-weight: 800 !important; color: #fff !important; background: var(--cv-primario) !important; border: 1px solid var(--cv-primario) !important; padding: 9px 18px !important; border-radius: 9px !important; cursor: pointer !important; font-family: var(--cv-font-body) !important; transition: var(--cv-transition) !important; white-space: nowrap !important; box-shadow: 0 8px 18px rgba(0,63,114,0.18) !important; }
.em-bloque .em-card__btn-ver:hover { background: var(--em-cat) !important; color: #fff !important; border-color: var(--em-cat) !important; }

/* Sin resultados */
.em-bloque .em-no-resultados { text-align: center !important; padding: 60px 20px !important; }
.em-bloque .em-no-resultados__icono { font-size: 48px !important; margin-bottom: 14px !important; }
.em-bloque .em-no-resultados__texto { font-size: 16px !important; color: var(--cv-terciario2) !important; margin: 0 !important; }

/* ══ MODAL ══ */
.em-modal-overlay { display: none; position: fixed; inset: 0; z-index: 9900; background: rgba(0,20,45,.72); backdrop-filter: blur(6px); }
.em-modal-overlay.is-open { display: block; }
.em-modal-bg { display: none; position: fixed; inset: 0; z-index: 9901; align-items: center; justify-content: center; padding: 20px; }
.em-modal-bg.is-open { display: flex; animation: em-fade-in .18s ease; }
.em-modal {
  --em-cat: var(--cv-primario);
  --em-cat-2: var(--cv-secundario);
  --em-cat-soft: rgba(0,63,114,0.08);
  --em-cat-border: rgba(0,63,114,0.18);
  background: #fff;
  border-radius: var(--cv-radius-lg);
  max-width: 620px;
  width: 100%;
  max-height: 92vh;
  overflow-y: auto;
  animation: em-pop-in .26s ease;
  box-shadow: 0 24px 64px rgba(0,0,0,.26);
  font-family: var(--cv-font-body);
  position: relative;
  border: 1px solid rgba(255,255,255,0.72);
}
.em-modal[data-cat="alimentos"]  { --em-cat:#e65c00; --em-cat-2:#f9d423; --em-cat-soft:rgba(230,92,0,0.10); --em-cat-border:rgba(230,92,0,0.28); }
.em-modal[data-cat="tecnologia"] { --em-cat:#1257d9; --em-cat-2:#34b7f1; --em-cat-soft:rgba(18,87,217,0.10); --em-cat-border:rgba(18,87,217,0.28); }
.em-modal[data-cat="salud"]      { --em-cat:#0f9f76; --em-cat-2:#43d889; --em-cat-soft:rgba(15,159,118,0.10); --em-cat-border:rgba(15,159,118,0.28); }
.em-modal[data-cat="educacion"]  { --em-cat:#a71930; --em-cat-2:#e05c78; --em-cat-soft:rgba(167,25,48,0.10); --em-cat-border:rgba(167,25,48,0.28); }
.em-modal[data-cat="moda"]       { --em-cat:#8b1bb1; --em-cat-2:#e05cc9; --em-cat-soft:rgba(139,27,177,0.10); --em-cat-border:rgba(139,27,177,0.28); }
.em-modal[data-cat="servicios"]  { --em-cat:#eaab00; --em-cat-2:#f6d778; --em-cat-soft:rgba(234,171,0,0.14); --em-cat-border:rgba(234,171,0,0.34); }
.em-modal[data-cat="arte"]       { --em-cat:#f15a24; --em-cat-2:#f7b733; --em-cat-soft:rgba(241,90,36,0.10); --em-cat-border:rgba(241,90,36,0.28); }
.em-modal__banner { height: 8px; border-radius: var(--cv-radius-lg) var(--cv-radius-lg) 0 0; background: linear-gradient(90deg, var(--em-cat), var(--em-cat-2)); }
.em-modal__close { position: absolute; top: 18px; right: 18px; width: 34px; height: 34px; border-radius: 50%; background: #fff; border: 1px solid #dfe5ee; color: #7b8492; font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--cv-transition); z-index: 1; box-shadow: 0 8px 18px rgba(0,63,114,0.10); }
.em-modal__close:hover { background: var(--em-cat-soft); color: var(--em-cat); border-color: var(--em-cat-border); }
.em-modal__top { padding: 24px 28px 0; display: flex; align-items: flex-start; gap: 18px; }
.em-modal__logo { width: 86px; height: 86px; border-radius: 12px; border: 1px solid #e8e6e1; background: var(--cv-crema-2); overflow: hidden; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-family: var(--cv-font-display); font-weight: 700; font-size: 28px; color: var(--em-cat); box-shadow: 0 10px 24px rgba(0,63,114,0.09); }
.em-modal__logo img { width: 100% !important; height: 100% !important; object-fit: cover !important; object-position: center !important; display: block !important; margin: 0 !important; border-radius: 0 !important; max-width: none !important; }
.em-modal__header-info { flex: 1; padding-top: 3px; min-width: 0; }
.em-modal .em-card__cat-badge { display: inline-flex !important; align-items: center !important; padding: 4px 11px !important; border-radius: var(--cv-radius-pill) !important; font-size: 10px !important; font-weight: 800 !important; letter-spacing: .07em !important; text-transform: uppercase !important; background: var(--em-cat-soft) !important; border: 1px solid var(--em-cat-border) !important; color: var(--em-cat) !important; margin-bottom: 6px !important; }
.em-modal__nombre { font-family: var(--cv-font-body); font-size: 24px; font-weight: 800; color: #071b4d; line-height: 1.12; margin: 6px 42px 6px 0; letter-spacing: 0; }
.em-modal__ubicacion { font-size: 13px; color: #7c8593; display: flex; align-items: center; gap: 5px; }
.em-modal__content { padding: 20px 28px 28px; }
.em-modal__section { margin-top: 18px; padding-top: 16px; border-top: 1px solid #e8ecf2; }
.em-modal__section:first-child { margin-top: 0; }
.em-modal__section-title { font-size: 11.5px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: #18345f; margin-bottom: 10px; display: flex; align-items: center; gap: 9px; }
.em-modal__section-title::before { content: ''; width: 15px; height: 2px; background: var(--em-cat); border-radius: 2px; flex-shrink: 0; }
.em-modal__text { font-size: 14px; color: #3d4654; line-height: 1.65; max-height: 132px; overflow-y: auto; scrollbar-width: thin; scrollbar-color: #d5d3ce transparent; margin: 0; }
.em-modal__text::-webkit-scrollbar { width: 4px; }
.em-modal__text::-webkit-scrollbar-thumb { background: #d5d3ce; border-radius: 4px; }
.em-modal__beneficio { display: flex; align-items: center; gap: 14px; background: linear-gradient(90deg, var(--em-cat-soft), rgba(255,255,255,0.72)); border: 1px solid var(--em-cat-border); border-left: 4px solid var(--em-cat); border-radius: var(--cv-radius-md); padding: 14px 16px; }
.em-modal__beneficio-icon { width: 44px; height: 44px; border-radius: 50%; color: var(--em-cat); background: rgba(255,255,255,0.82); border: 1px solid var(--em-cat-border); display: flex; align-items: center; justify-content: center; flex: 0 0 44px; }
.em-modal__beneficio-icon svg { width: 20px; height: 20px; }
.em-modal__beneficio-copy { min-width: 0; }
.em-modal__beneficio-label { font-size: 10.5px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--em-cat); margin-bottom: 4px; }
.em-modal__beneficio-texto { font-size: 14.5px; color: #071b4d; line-height: 1.45; }
.em-modal__contactos { display: flex; flex-direction: column; gap: 0; }
.em-modal__contacto-item { display: flex; align-items: center; gap: 10px; min-height: 36px; padding: 5px 0; border-bottom: 1px solid #edf0f4; font-size: 13px; color: #303846; }
.em-modal__contacto-item a { color: var(--cv-primario); text-decoration: none; }
.em-modal__contacto-item a:hover { text-decoration: underline; }
.em-modal__contacto-ico { width: 30px; height: 30px; border-radius: 8px; background: #eaf2fb; color: var(--cv-primario); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 13px; font-weight: 800; }
.em-modal__redes { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.em-modal__red-btn { display: inline-flex; align-items: center; gap: 8px; min-height: 38px; padding: 7px 11px; border-radius: var(--cv-radius-pill); font-size: 12px; font-weight: 800; text-decoration: none !important; transition: var(--cv-transition); font-family: var(--cv-font-body); color: #18345f !important; background: #fff; border: 1px solid #dfe5ee; box-shadow: 0 8px 18px rgba(0,63,114,0.06); }
.em-modal__red-btn:hover { transform: translateY(-2px); border-color: var(--em-cat-border); opacity: 1; }
.em-modal__red-btn span { width: 24px; height: 24px; border-radius: 50%; color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 800; flex: 0 0 24px; }
.em-modal__red-btn--web span { background: var(--cv-primario); }
.em-modal__red-btn--fb span  { background: #1877f2; }
.em-modal__red-btn--ig span  { background: linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); }
.em-modal__red-btn--yt span  { background: #ff0000; }
.em-modal__red-btn--wa span  { background: #25D366; }
.em-modal__red-btn--li span  { background: #0a66c2; }
.em-modal__red-btn--tt span  { background: #010101; }

@keyframes em-fade-in { from{opacity:0;} to{opacity:1;} }
@keyframes em-pop-in  { from{opacity:0;transform:scale(.95) translateY(8px);} to{opacity:1;transform:scale(1) translateY(0);} }

/* ══ RESPONSIVE ══ */
@media(max-width:1100px) {
  .em-bloque .em-card__body { padding: 18px 18px 0 !important; gap: 14px !important; }
  .em-bloque .em-card__logo-wrap,
  .em-bloque .em-card__logo-wrap img,
  .em-bloque .em-card__logo-wrap .field--type-image img { width: 70px !important; height: 70px !important; }
  .em-bloque .em-card__nombre { font-size: 19px !important; }
  .em-bloque .em-card__desc-wrap,
  .em-bloque .em-card__beneficio { margin-left: 18px !important; margin-right: 18px !important; }
  .em-bloque .em-card__footer { padding-left: 18px !important; padding-right: 18px !important; }
}
@media(max-width:900px) { .em-bloque .em-grid { grid-template-columns: repeat(auto-fill, minmax(290px,1fr)) !important; } }
@media(max-width:640px) {
  .em-bloque .em-chip { padding: 5px 11px !important; font-size: 12px !important; }
  .em-bloque .em-abc-btn { min-width: 28px !important; height: 28px !important; font-size: 13px !important; }
  .em-bloque .em-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .em-bloque .em-card__body { padding: 16px 16px 0 !important; gap: 12px !important; }
  .em-bloque .em-card__logo-wrap,
  .em-bloque .em-card__logo-wrap img,
  .em-bloque .em-card__logo-wrap .field--type-image img { width: 64px !important; height: 64px !important; }
  .em-bloque .em-card__cat-badge { font-size: 10px !important; padding: 5px 11px !important; margin-bottom: 8px !important; }
  .em-bloque .em-card__nombre { font-size: 18px !important; }
  .em-bloque .em-card__ubicacion { font-size: 13px !important; }
  .em-bloque .em-card__desc-wrap { margin: 14px 16px 0 !important; padding-top: 12px !important; }
  .em-bloque .em-card__desc,
  .em-bloque p.em-card__desc { font-size: 13px !important; }
  .em-bloque .em-card__beneficio { margin: 14px 16px 0 !important; padding: 11px 13px !important; }
  .em-bloque .em-card__beneficio-texto { padding-left: 0 !important; font-size: 13px !important; }
  .em-bloque .em-card__footer { padding: 15px 16px !important; flex-direction: column !important; align-items: stretch !important; }
  .em-bloque .em-card__btn-ver { justify-content: center !important; width: 100% !important; }
  .em-modal-bg { padding: 12px; }
  .em-modal__top { flex-direction: column; align-items: center; text-align: center; padding: 24px 18px 0; }
  .em-modal__logo { width: 74px; height: 74px; }
  .em-modal__nombre { margin-right: 0; font-size: 22px; }
  .em-modal__content { padding: 18px 18px 24px; }
  .em-modal__beneficio { align-items: flex-start; }
  .em-modal__redes { grid-template-columns: 1fr 1fr; }
  .em-modal__ubicacion { justify-content: center; }
}
@media(max-width:400px) { .em-bloque .em-grid { grid-template-columns: 1fr !important; } }
