
/* HLK Extranjería Elementor
   - Usa variables del tema/Elementor si existen.
   - Puedes sobreescribir con controles del widget (CSS vars en wrapper).
*/
.hlk-extr{
  /* Custom vars (set by widget controls) */
  --hlk-primary-custom: var(--hlk-primary-custom);
  --hlk-accent-custom:  var(--hlk-accent-custom);
  --hlk-text-custom:    var(--hlk-text-custom);

  /* Resolved vars (prefer custom, then Elementor globals, then fallback) */
  --hlk-primary: var(--hlk-primary-custom, var(--e-global-color-primary, #1B4172));
  --hlk-accent:  var(--hlk-accent-custom,  var(--e-global-color-accent,  #4F818D));
  --hlk-text:    var(--hlk-text-custom,    var(--e-global-color-text,    #606b75));

  --hlk-bg-soft: #f6f7f9;
  --hlk-bg: #ffffff;
  --hlk-radius: 14px;
  --hlk-shadow: 0 10px 30px rgba(27,65,114,.10);

  color: var(--hlk-text);
}

/* Full-bleed breakout (evita el "recuadro" lateral del tema/section boxed) */
.hlk-extr{
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow-x: clip;
}

.hlk-extr img{max-width:100%; height:auto; display:block;}
.hlk-extr-container{max-width:1140px; margin:0 auto; padding:0 24px;}
.hlk-extr-section{padding:96px 0;}
.hlk-extr-grid-2{display:grid; grid-template-columns: 1fr 1fr; gap:64px; align-items:center;}
.hlk-extr-media{border-radius: var(--hlk-radius); overflow:hidden; background: #eef2f6;}
.hlk-extr-media img{width:100%; height:100%; object-fit:cover;}
.hlk-extr-img-ph{min-height:320px; display:flex; align-items:center; justify-content:center; font-size:.95rem; opacity:.7; padding:24px; text-align:center;}

.hlk-extr-label{
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color: var(--hlk-accent);
  margin-bottom:14px;
}
.hlk-extr-label-inv{color: rgba(255,255,255,.75);}

.hlk-extr-h1, .hlk-extr-h2, .hlk-extr-h3, .hlk-extr-h4{color: var(--hlk-primary); margin:0 0 14px 0; line-height:1.15;}
.hlk-extr-h1{font-size: clamp(2.2rem, 4vw, 3.4rem); color:#fff;}
.hlk-extr-h1 em{color: rgba(255,255,255,.85); font-style: italic;}
.hlk-extr-h2{font-size: clamp(1.7rem, 2.6vw, 2.3rem);}
.hlk-extr-h2-inv{color:#fff;}
.hlk-extr-h3{font-size:1.05rem; margin-bottom:10px;}
.hlk-extr-h4{font-size:.95rem; margin-bottom:6px;}

.hlk-extr-p{margin: 0 0 14px 0; line-height:1.8;}
.hlk-extr-sub{max-width: 680px; margin:0 0 40px 0; line-height:1.8;}
.hlk-extr-sub-inv{color: rgba(255,255,255,.78);}
.hlk-extr-small{margin:0; line-height:1.7; font-size:.92rem; color: var(--hlk-text);}

.hlk-extr-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 14px 26px;
  border-radius: 10px;
  text-decoration:none;
  font-weight: 700;
  letter-spacing:.02em;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  border: 1px solid transparent;
}
.hlk-extr-btn-primary{
  background: var(--hlk-accent);
  color:#fff;
  box-shadow: 0 10px 26px rgba(79,129,141,.28);
}
.hlk-extr-btn-primary:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(79,129,141,.34);
  filter: brightness(1.08);
  color:#fff;
  text-decoration:none;
}
.hlk-extr-btn-ghost{
  background: transparent;
  color:#fff;
  border-color: rgba(255,255,255,.22);
}
.hlk-extr-btn-ghost:hover{background: rgba(255,255,255,.06);}

.hlk-extr-hero{
  background: var(--hlk-primary);
  padding: 140px 0 70px;
  position:relative;
  overflow:hidden;
}
.hlk-extr-hero:before{
  content:'';
  position:absolute;
  right:-260px; top:-260px;
  width:640px; height:640px;
  background: radial-gradient(circle, rgba(79,129,141,.16) 0%, transparent 62%);
  border-radius:50%;
}
.hlk-extr-hero-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:56px; align-items:center; position:relative; z-index:1;}
.hlk-extr-badge{
  display:inline-flex; align-items:center; gap:10px;
  padding: 7px 16px;
  border-radius: 999px;
  background: rgba(79,129,141,.12);
  border: 1px solid rgba(79,129,141,.22);
  color: rgba(255,255,255,.82);
  margin-bottom: 22px;
  font-size:.76rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.hlk-extr-hero-text{color: rgba(255,255,255,.74); line-height:1.85; margin-bottom: 34px;}
.hlk-extr-hero-media{border-radius: 18px; overflow:hidden; background: rgba(255,255,255,.06);}
.hlk-extr-hero-media img{width:100%; height:auto; object-fit:cover; border-radius: 18px;}
.hlk-extr-stats{display:flex; gap:34px; margin-top:44px; padding-top:26px; border-top:1px solid rgba(255,255,255,.10);}
.hlk-extr-stat-num{color:#fff; font-weight:700; font-size:1.55rem; line-height:1;}
.hlk-extr-stat-label{color: rgba(255,255,255,.70); font-size:.84rem;}

.hlk-extr-services{background: var(--hlk-bg-soft);}
.hlk-extr-cards{display:grid; grid-template-columns: repeat(3, 1fr); gap: 22px;}
.hlk-extr-card{
  background:#fff;
  border-radius: var(--hlk-radius);
  padding: 30px 26px;
  border:1px solid rgba(27,65,114,.08);
  transition: transform .2s ease, box-shadow .2s ease;
}
.hlk-extr-card:hover{transform: translateY(-4px); box-shadow: var(--hlk-shadow);}
.hlk-extr-ic{
  width: 46px; height:46px;
  border-radius: 12px;
  background: rgba(79,129,141,.12);
  display:flex; align-items:center; justify-content:center;
  margin-bottom: 18px;
}
.hlk-extr-ic span{font-size: 20px;}

.hlk-extr-mini-grid{display:grid; grid-template-columns: 1fr 1fr; gap:14px; margin-top:28px;}
.hlk-extr-mini{
  background: #f6f7f9;
  border-radius: 12px;
  padding: 18px;
  border-left: 3px solid var(--hlk-accent);
}

.hlk-extr-why{background: var(--hlk-primary); position:relative; overflow:hidden;}
.hlk-extr-why:before{
  content:'';
  position:absolute;
  left:-220px; bottom:-220px;
  width:520px; height:520px;
  background: radial-gradient(circle, rgba(79,129,141,.16) 0%, transparent 62%);
  border-radius:50%;
}
.hlk-extr-why-grid{display:grid; grid-template-columns: repeat(2, 1fr); gap:22px; position:relative; z-index:1;}
.hlk-extr-why-card{
  background:#fff;
  border-radius: var(--hlk-radius);
  padding: 30px 26px;
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
}
.hlk-extr-why-num{color: var(--hlk-accent); font-weight:700; margin-bottom:10px;}

.hlk-extr-process{background:#fff;}
.hlk-extr-steps{display:grid; grid-template-columns: repeat(3, 1fr); gap: 22px;}
.hlk-extr-step{
  background: var(--hlk-bg-soft);
  border-radius: var(--hlk-radius);
  padding: 26px;
}
.hlk-extr-step-num{color: var(--hlk-accent); font-weight:800; font-size:1.2rem; margin-bottom:10px;}

.hlk-extr-faq{background:#fff;}
.hlk-extr-faq-grid{display:grid; grid-template-columns: 360px 1fr; gap:56px; align-items:start; margin-top: 36px;}
.hlk-extr-faq-media{border-radius: var(--hlk-radius); overflow:hidden; position:sticky; top: 30px;}
.hlk-extr-faq-media img{width:100%; height:auto; object-fit:cover; aspect-ratio: 3/4;}

.hlk-extr-faq-list{display:flex; flex-direction:column; gap: 14px;}
.hlk-extr-faq-item{
  background: var(--hlk-bg-soft);
  border-radius: var(--hlk-radius);
  overflow:hidden;
  border: 1px solid rgba(27,65,114,.07);
}
.hlk-extr-faq-q{
  width:100%;
  display:flex; align-items:center; justify-content:space-between;
  padding: 18px 18px;
  background: transparent;
  border:0;
  cursor:pointer;
  font-weight: 700;
  color: var(--hlk-primary);
  text-align:left;
}
.hlk-extr-plus{color: var(--hlk-accent); font-size: 20px; transform: rotate(0deg); transition: transform .2s ease;}
.hlk-extr-faq-a{max-height:0; overflow:hidden; transition: max-height .25s ease;}
.hlk-extr-faq-item.is-open .hlk-extr-faq-a{max-height: 420px;}
.hlk-extr-faq-item.is-open .hlk-extr-plus{transform: rotate(45deg);}
.hlk-extr-faq-a .hlk-extr-p{padding: 0 18px 18px 18px;}

.hlk-extr-cta{
  background: var(--hlk-primary);
  position:relative;
  overflow:hidden;
}
.hlk-extr-cta:before{
  content:'';
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 50% 0%, rgba(79,129,141,.18) 0%, transparent 62%);
}
.hlk-extr-cta .hlk-extr-container{position:relative; z-index:1; text-align:center;}
.hlk-extr-cta-text{color: rgba(255,255,255,.74); max-width: 720px; margin: 0 auto 28px auto; line-height:1.85;}
.hlk-extr-cta-btns{display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top: 18px;}
.hlk-extr-cta-meta{display:flex; justify-content:center; gap:28px; flex-wrap:wrap; margin-top: 28px; color: rgba(255,255,255,.70);}
.hlk-extr-meta{font-size:.95rem;}

@media (max-width: 1024px){
  .hlk-extr-hero-grid{grid-template-columns:1fr; gap:36px;}
  .hlk-extr-hero-media img{aspect-ratio:auto; max-height: 420px; width:100%; object-fit:contain;}
  .hlk-extr-grid-2{grid-template-columns:1fr; gap:34px;}
  .hlk-extr-cards{grid-template-columns: repeat(2,1fr);}
  .hlk-extr-steps{grid-template-columns: repeat(2,1fr);}
  .hlk-extr-faq-grid{grid-template-columns:1fr;}
  .hlk-extr-faq-media{display:none;}
}
@media (max-width: 640px){
  .hlk-extr-section{padding: 62px 0;}
  .hlk-extr-cards{grid-template-columns:1fr;}
  .hlk-extr-mini-grid{grid-template-columns:1fr;}
  .hlk-extr-why-grid{grid-template-columns:1fr;}
  .hlk-extr-steps{grid-template-columns:1fr;}
  .hlk-extr-stats{flex-direction:column; gap: 12px;}
  .hlk-extr-cta-btns{flex-direction:column; align-items:center;}
  .hlk-extr-cta-meta{flex-direction:column; gap: 12px;}
}

/* ===== HOME SERVICIOS EXTRAS ===== */
.hlk-home-card{display:flex;flex-direction:column}
.hlk-home-card .hlk-extr-small{flex:1}
.hlk-home-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;color:var(--hlk-accent);font-weight:700;font-size:.88rem;text-decoration:none;letter-spacing:.02em;transition:gap .2s ease,color .2s ease}
.hlk-home-link:hover{gap:10px;color:var(--hlk-primary)}
.hlk-home-link span{transition:transform .2s ease}
.hlk-home-link:hover span{transform:translateX(3px)}
[data-widget="hlk-home-servicios"] .hlk-extr-cards{grid-template-columns:repeat(4,1fr)}
@media(max-width:1024px){[data-widget="hlk-home-servicios"] .hlk-extr-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){[data-widget="hlk-home-servicios"] .hlk-extr-cards{grid-template-columns:1fr}}
/* CTA section */
.hlk-extr-cta{background:var(--hlk-primary);padding:80px 0;text-align:center}
.hlk-extr-cta-text{color:rgba(255,255,255,.8);font-size:1.1rem;max-width:640px;margin:0 auto 32px;line-height:1.7}
.hlk-extr-cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hlk-extr-btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border:2px solid rgba(255,255,255,.4);border-radius:var(--hlk-radius);color:#fff;font-weight:700;font-size:.95rem;text-decoration:none;transition:all .25s ease}
.hlk-extr-btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
