/* ============================================================
   BHRS – Best Human Resources Solutions | Stylesheet
   Paleta oficial: #0055a5 / #0d71c3 / #000 / #fff / grises
   ============================================================ */

/* ----- Variables ----- */
:root {
  --primary:        #0055a5;   /* azul institucional principal */
  --primary-dark:   #003d7a;
  --primary-light:  #0d71c3;   /* azul medio CTA */
  --primary-pale:   #E8F1FA;
  --accent:         #0d71c3;   /* alias para CTAs */
  --navy-text:      #2C3E50;   /* gris-azulado del "BHRS" del logo */
  --text-dark:      #1A2332;
  --text-body:      #4A5568;
  --text-light:     #718096;
  --black:          #000000;
  --white:          #FFFFFF;
  --bg:             #F4F8FB;
  --bg-light:       #F7FAFB;
  --bg-blue:        #EEF5FB;
  --border:         #E2E8F0;
  --border-blue:    #CFE2F3;
  --shadow:         0 4px 24px rgba(0,85,165,.08);
  --shadow-md:      0 8px 40px rgba(0,85,165,.13);
  --shadow-lg:      0 16px 60px rgba(0,85,165,.18);
  --whatsapp:       #25D366;
  --radius:         14px;
  --radius-sm:      8px;
  --tr:             all .28s ease;
}

/* ----- Reset ----- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html  { scroll-behavior: smooth; }
body  { font-family: 'Inter', 'Segoe UI', sans-serif; color: var(--text-body); background: var(--white); line-height: 1.7; overflow-x: hidden; }
img   { max-width: 100%; height: auto; display: block; }
a     { text-decoration: none; color: inherit; }
ul    { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ----- Typography ----- */
h1,h2,h3,h4,h5,h6 { font-family: 'Poppins', 'Segoe UI', sans-serif; color: var(--text-dark); line-height: 1.3; font-weight: 600; }
h1 { font-size: clamp(1.8rem, 4.4vw, 2.9rem); font-weight: 600; }
h2 { font-size: clamp(1.45rem, 3.1vw, 2.05rem); font-weight: 600; }
h3 { font-size: clamp(1.1rem, 2.3vw, 1.45rem); font-weight: 600; }
h4 { font-size: 1.1rem; }
p  { color: var(--text-body); margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

/* ----- Containers ----- */
.container    { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }
.container-sm { max-width: 860px;  margin: 0 auto; padding: 0 1.5rem; }

/* ----- Sections ----- */
.section      { padding: 5rem 0; }
.section-sm   { padding: 3rem 0; }
.bg-light     { background: var(--bg); }
.bg-blue      { background: var(--bg-blue); }
.bg-primary   { background: var(--primary); }
.bg-primary-dark { background: var(--primary-dark); }

.section-label {
  display: inline-block;
  background: var(--primary-pale);
  color: var(--primary);
  font-size: .72rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  padding: .35rem 1rem; border-radius: 100px;
  margin-bottom: 1rem;
}

.section-title    { margin-bottom: .9rem; }
.section-subtitle { color: var(--text-light); font-size: 1.05rem; max-width: 640px; line-height: 1.75; }
.section-header   { margin-bottom: 3rem; }
.section-header.centered { text-align: center; }
.section-header.centered .section-subtitle { margin: 0 auto; }

/* ----- Buttons ----- */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .85rem 2rem; border-radius: 9px;
  font-weight: 600; font-size: .93rem; border: 2px solid transparent;
  transition: var(--tr); white-space: nowrap; cursor: pointer; font-family: inherit;
}
.btn-lg  { padding: 1rem 2.5rem; font-size: 1rem; }
.btn-sm  { padding: .55rem 1.4rem; font-size: .85rem; }

.btn-primary { background: var(--primary-light); color: var(--white); border-color: var(--primary-light); }
.btn-primary:hover { background: var(--primary); border-color: var(--primary); transform: translateY(-2px); box-shadow: 0 6px 22px rgba(13,113,195,.4); }

.btn-dark { background: var(--primary); color: var(--white); border-color: var(--primary); }
.btn-dark:hover { background: var(--primary-dark); border-color: var(--primary-dark); transform: translateY(-2px); box-shadow: 0 6px 22px rgba(0,85,165,.45); }

.btn-outline { background: transparent; color: var(--white); border-color: rgba(255,255,255,.7); }
.btn-outline:hover { background: var(--white); color: var(--primary); border-color: var(--white); transform: translateY(-2px); }

.btn-outline-blue { background: transparent; color: var(--primary); border-color: var(--primary); }
.btn-outline-blue:hover { background: var(--primary); color: var(--white); transform: translateY(-2px); }

.btn-white { background: var(--white); color: var(--primary); border-color: var(--white); }
.btn-white:hover { background: transparent; color: var(--white); transform: translateY(-2px); }

.btn-whatsapp { background: var(--whatsapp); color: var(--white); border-color: var(--whatsapp); }
.btn-whatsapp:hover { background: #1EBE57; border-color: #1EBE57; transform: translateY(-2px); }

/* ----- Logo (PNG image) ----- */
.brand-logo {
  display: inline-flex; align-items: center;
  text-decoration: none;
}
.brand-logo img {
  height: 70px; width: auto;
  display: block;
  transition: var(--tr);
}
.nav.scrolled .brand-logo img { height: 54px; }
.footer .brand-logo img { height: 90px; }
/* white variant for dark backgrounds (footer): convert PNG to white via filter */
.brand-logo.is-light img {
  filter: brightness(0) invert(1);
  opacity: .95;
}

/* ----- Navigation ----- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  padding: .9rem 0; transition: var(--tr);
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid transparent;
}
.nav.scrolled { box-shadow: 0 2px 24px rgba(0,0,0,.07); border-bottom-color: var(--border); padding: .65rem 0; }
.nav.transparent { background: transparent; backdrop-filter: none; border: none; }
.nav.transparent .nav-link { color: rgba(255,255,255,.92); }
.nav.transparent .brand-logo img { filter: brightness(0) invert(1); opacity: .95; }
.nav.transparent.scrolled { background: rgba(255,255,255,.96); backdrop-filter: blur(8px); }
.nav.transparent.scrolled .nav-link  { color: var(--text-dark); }
.nav.transparent.scrolled .brand-logo img { filter: none; opacity: 1; }

.nav-inner { display: flex; align-items: center; justify-content: space-between; }
.nav-menu  { display: flex; align-items: center; gap: 1.9rem; }
.nav-link {
  font-size: .88rem; font-weight: 500;
  color: var(--text-dark); transition: var(--tr); position: relative;
  padding: .25rem 0;
}
.nav-link::after {
  content: ''; position: absolute; bottom: -3px; left: 0;
  width: 0; height: 2px; background: var(--primary-light); transition: var(--tr);
}
.nav-link:hover::after, .nav-link.active::after { width: 100%; }
.nav-link:hover { color: var(--primary-light); }

/* Dropdown */
.nav-has-dropdown { position: relative; }
.dropdown-toggle  { display: flex; align-items: center; gap: .3rem; cursor: pointer; }
.dropdown-arrow   { transition: var(--tr); }
.nav-has-dropdown:hover .dropdown-arrow { transform: rotate(180deg); }

.dropdown-menu {
  position: absolute; top: calc(100% + 1rem); left: 50%;
  transform: translateX(-50%);
  background: var(--white); border-radius: var(--radius);
  box-shadow: var(--shadow-md); padding: .6rem;
  min-width: 290px; border: 1px solid var(--border);
  opacity: 0; visibility: hidden; transition: var(--tr);
}
.nav-has-dropdown:hover .dropdown-menu {
  opacity: 1; visibility: visible; top: calc(100% + .3rem);
}
.dropdown-group-label {
  font-size: .65rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--text-light); padding: .6rem 1rem .35rem;
}
.dropdown-item {
  display: flex; align-items: center; gap: .8rem;
  padding: .6rem 1rem; border-radius: 9px;
  color: var(--text-dark); font-size: .87rem; font-weight: 500;
  transition: var(--tr);
}
.dropdown-item:hover { background: var(--primary-pale); color: var(--primary); }
.dropdown-item-icon {
  width: 32px; height: 32px; background: var(--primary-pale); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--primary); flex-shrink: 0; font-size: .82rem;
}
.dropdown-divider { height: 1px; background: var(--border); margin: .35rem .25rem; }

.lang-toggle {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .35rem .75rem; border-radius: 100px;
  background: var(--primary-pale); color: var(--primary);
  font-size: .72rem; font-weight: 700; letter-spacing: .05em;
  transition: var(--tr);
}
.lang-toggle:hover { background: var(--primary); color: var(--white); }
.nav.transparent:not(.scrolled) .lang-toggle {
  background: rgba(255,255,255,.15); color: var(--white);
  backdrop-filter: blur(4px);
}

.nav-cta-btn { padding: .55rem 1.3rem !important; font-size: .82rem !important; }

/* Hamburger */
.nav-hamburger {
  display: none; flex-direction: column; gap: 5px;
  padding: 4px; background: none; border: none; cursor: pointer;
}
.nav-hamburger span {
  display: block; width: 24px; height: 2px;
  background: var(--text-dark); border-radius: 2px; transition: var(--tr);
}
.nav.transparent:not(.scrolled) .nav-hamburger span { background: var(--white); }

/* Mobile overlay */
.mobile-overlay {
  display: none; position: fixed; inset: 0; z-index: 1100;
  background: var(--primary-dark); flex-direction: column;
  justify-content: flex-start; align-items: center; gap: 1rem;
  padding: 5rem 1.5rem 2rem; overflow-y: auto;
}
.mobile-overlay.open { display: flex; }
.mobile-close {
  position: absolute; top: 1.25rem; right: 1.5rem;
  color: var(--white); font-size: 1.7rem; background: none;
  border: none; cursor: pointer; line-height: 1;
}
.mobile-nav-link {
  color: var(--white); font-family: 'Poppins', sans-serif;
  font-size: 1.3rem; font-weight: 700; transition: var(--tr);
}
.mobile-nav-link:hover { color: var(--primary-light); }
.mobile-sub-label {
  color: rgba(255,255,255,.5); font-size: .7rem;
  font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
  margin-top: .5rem;
}
.mobile-sub { display: flex; flex-direction: column; align-items: center; gap: .55rem; }
.mobile-sub-link {
  color: rgba(255,255,255,.78); font-size: .98rem; font-weight: 500; transition: var(--tr);
}
.mobile-sub-link:hover { color: var(--primary-light); }
.mobile-divider { width: 50px; height: 1px; background: rgba(255,255,255,.2); margin: .5rem 0; }

/* ----- WhatsApp floating ----- */
.whatsapp-float {
  position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 998;
  width: 58px; height: 58px; border-radius: 50%;
  background: var(--whatsapp); color: white; font-size: 1.7rem;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 24px rgba(37,211,102,.45);
  opacity: 0; visibility: hidden; transform: translateY(20px) scale(.8);
  transition: var(--tr);
}
.whatsapp-float.visible { opacity: 1; visibility: visible; transform: translateY(0) scale(1); }
.whatsapp-float:hover   { transform: scale(1.08); box-shadow: 0 8px 30px rgba(37,211,102,.55); }
.whatsapp-float::before {
  content: ''; position: absolute; inset: 0; border-radius: 50%;
  background: var(--whatsapp); opacity: .5; z-index: -1;
  animation: waPulse 2s ease-out infinite;
}
@keyframes waPulse {
  0%   { transform: scale(1);   opacity: .5; }
  100% { transform: scale(1.6); opacity: 0;  }
}

/* ----- HERO (Home) ----- */
.hero {
  min-height: 100vh; display: flex; align-items: center;
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 60%, #1A4F8A 100%);
  position: relative; overflow: hidden; padding: 8rem 0 5rem;
}
.hero::before {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 80% 50%, rgba(13,113,195,.25) 0%, transparent 60%),
                    radial-gradient(circle at 20% 80%, rgba(255,255,255,.04) 0%, transparent 50%);
}
.hero-cover::before { display: none; }
.hero-grid {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.92); font-size: .76rem; font-weight: 700;
  padding: .35rem 1rem; border-radius: 100px; margin-bottom: 1.5rem;
  backdrop-filter: blur(4px); letter-spacing: .05em; text-transform: uppercase;
}
.hero-badge span { width: 6px; height: 6px; background: #4A9CDF; border-radius: 50%; }
.hero h1 {
  color: var(--white); margin-bottom: 1.4rem;
  font-weight: 500;
  font-size: clamp(1.7rem, 3.8vw, 2.55rem);
  line-height: 1.28;
  letter-spacing: -.005em;
}
.hero h1 em     { font-style: normal; color: #4A9CDF; font-weight: 600; }
.hero .lead     { color: rgba(255,255,255,.82); font-size: 1.05rem; line-height: 1.75; margin-bottom: 2rem; }
.hero-bullets {
  display: flex; flex-wrap: wrap; gap: .8rem;
  margin-top: 2.5rem; justify-content: center;
}
.hero-bullets-inline { margin-top: 1.6rem; justify-content: flex-start; }
.hero-bullet {
  display: inline-flex; align-items: center; gap: .55rem;
  background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.22);
  color: var(--white); font-size: .82rem; font-weight: 600;
  padding: .55rem 1.1rem; border-radius: 100px;
  backdrop-filter: blur(6px); transition: var(--tr);
  text-decoration: none;
}
.hero-bullet:hover { background: rgba(255,255,255,.2); transform: translateY(-2px); }
.hero-bullet i { color: #6EB4E8; font-size: .78rem; }

/* Stronger chips on hero carousel — white pills with shadow */
.hero-bullets-strong { margin-top: 2.4rem; gap: .85rem; }
.hero-bullets-strong .hero-bullet {
  background: rgba(255,255,255,.97);
  border: 1px solid rgba(255,255,255,1);
  color: var(--primary-dark);
  font-weight: 600;
  font-size: .88rem;
  padding: .85rem 1.35rem;
  box-shadow: 0 10px 28px rgba(0,0,0,.22);
  backdrop-filter: none;
}
.hero-bullets-strong .hero-bullet i { color: var(--primary); font-size: .9rem; }
.hero-bullets-strong .hero-bullet:hover {
  background: var(--primary);
  color: var(--white);
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(0,0,0,.3);
}
.hero-bullets-strong .hero-bullet:hover i { color: var(--white); }

/* Uniform chip widths in hero (all chips equal size) */
.hero-bullets-uniform { justify-content: center; gap: .85rem; }
.hero-bullets-uniform .hero-bullet {
  flex: 0 0 auto;
  width: 260px;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Yellow "REACTIVO CERO TM" diagonal ribbon on featured chips */
.hero-bullet.has-rc-flag {
  border-radius: 100px;
  overflow: hidden;
}
.hero-bullet .rc-flag {
  position: absolute;
  top: 16px;
  right: -36px;
  width: 120px;
  background: #FFD93D;
  color: #1A2433;
  font-size: .4rem;
  font-weight: 800;
  letter-spacing: 0;
  padding: 3px 0;
  text-align: center;
  transform: rotate(45deg);
  transform-origin: center center;
  box-shadow: 0 2px 6px rgba(0,0,0,.25);
  pointer-events: none;
  text-transform: uppercase;
  line-height: 1.1;
  white-space: nowrap;
}
.hero-bullet:hover .rc-flag { background: #FFE066; }

.hero-cta { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }
.hero-cta-bottom { margin-top: 3rem; }

/* ----- HERO CAROUSEL ----- */
.hero-carousel {
  position: absolute; inset: 0; overflow: hidden; z-index: 0;
}
.hero-slide {
  position: absolute; inset: 0;
  opacity: 0;
  transition: opacity 1.5s ease;
}
.hero-slide.active { opacity: 1; }
.hero-slide img {
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.04);
}
.hero-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(135deg, rgba(0,30,72,.86) 0%, rgba(0,55,120,.74) 50%, rgba(0,30,72,.88) 100%);
  backdrop-filter: blur(2px);
  z-index: 1;
}
.hero-cover .container { position: relative; z-index: 2; }
.hero-content.centered { text-align: center; max-width: 940px; margin: 0 auto; }
.hero-content.centered .hero-badge { margin-left: auto; margin-right: auto; }

/* Hero right — visual card */
.hero-visual {
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius); padding: 2rem; backdrop-filter: blur(8px);
  position: relative; z-index: 1;
}
.hero-visual-title {
  font-family: 'Poppins', sans-serif; font-size: .72rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: #4A9CDF;
  margin-bottom: 1.25rem;
}
.hero-service-list { display: flex; flex-direction: column; gap: .6rem; }
.hero-service-item {
  display: flex; align-items: center; gap: .85rem;
  padding: .8rem .95rem; border-radius: 10px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.08);
  transition: var(--tr); cursor: default;
}
.hero-service-item:hover { background: rgba(255,255,255,.12); transform: translateX(4px); }
.hs-icon {
  width: 36px; height: 36px; border-radius: 9px; background: var(--primary-light);
  display: flex; align-items: center; justify-content: center;
  color: white; font-size: .9rem; flex-shrink: 0;
}
.hs-icon.dark { background: var(--primary-dark); }
.hs-icon.med  { background: var(--primary); }
.hs-icon.lt   { background: #4A9CDF; }
.hs-label { font-size: .85rem; font-weight: 600; color: var(--white); }
.hs-sub   { font-size: .72rem; color: rgba(255,255,255,.55); }
.hero-divider { border: none; border-top: 1px solid rgba(255,255,255,.1); margin: 1.25rem 0; }
.hero-metrics { display: grid; grid-template-columns: repeat(3,1fr); gap: .75rem; }
.hm-item      { text-align: center; }
.hm-num {
  font-family: 'Poppins', sans-serif; font-size: 1.7rem; font-weight: 800;
  color: #4A9CDF; line-height: 1; display: block;
}
.hm-label { font-size: .7rem; color: rgba(255,255,255,.6); }

/* ----- ABOUT (Home) ----- */
.about-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center;
}
.about-tag  { color: var(--primary); font-weight: 700; font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; margin-bottom: .75rem; }
.about-text h2 { margin-bottom: 1.25rem; }
.about-text p  { font-size: 1rem; line-height: 1.8; color: var(--text-body); }
.about-boxes   { display: grid; grid-template-columns: 1fr 1fr; gap: .9rem; margin-top: 2rem; }
.about-box {
  background: var(--bg-blue); border-radius: var(--radius-sm);
  padding: 1.1rem 1.25rem; border-left: 3px solid var(--primary-light);
}
.about-box h5  { font-size: .9rem; color: var(--text-dark); margin-bottom: .25rem; }
.about-box p   { font-size: .82rem; color: var(--text-light); margin: 0; }

.about-visual { position: relative; height: 460px; }
.av-card-main {
  position: absolute; inset: 0;
  background: linear-gradient(145deg, var(--primary) 0%, var(--primary-dark) 100%);
  border-radius: var(--radius); overflow: hidden; padding: 2.5rem;
  display: flex; flex-direction: column; justify-content: space-between;
}
.av-card-main::before {
  content: ''; position: absolute; top: -70px; right: -70px;
  width: 240px; height: 240px; background: rgba(13,113,195,.25); border-radius: 50%;
}
.av-card-main::after {
  content: ''; position: absolute; bottom: -50px; left: -50px;
  width: 180px; height: 180px; background: rgba(255,255,255,.05); border-radius: 50%;
}
.av-label {
  font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: #4A9CDF; position: relative; z-index: 1;
}
.av-heading {
  font-family: 'Poppins', sans-serif; font-size: 1.45rem; font-weight: 800;
  color: var(--white); line-height: 1.35; position: relative; z-index: 1;
}
.av-heading span { color: #4A9CDF; }
.av-stats {
  display: grid; grid-template-columns: repeat(3,1fr); gap: .75rem;
  position: relative; z-index: 1;
}
.av-stat {
  background: rgba(255,255,255,.08); border-radius: 10px;
  padding: .9rem .65rem; text-align: center;
}
.av-stat-n {
  font-family: 'Poppins', sans-serif; font-size: 1.55rem; font-weight: 800;
  color: #4A9CDF; display: block; line-height: 1;
}
.av-stat-l { font-size: .68rem; color: rgba(255,255,255,.62); line-height: 1.4; }

/* ----- SOLUTIONS CARDS ----- */
.solutions-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.4rem; }
.solutions-grid.cols-5 { grid-template-columns: repeat(5,1fr); }
.solutions-grid.cols-4 { grid-template-columns: repeat(4,1fr); }
.sol-card {
  background: var(--white); border-radius: var(--radius);
  padding: 1.75rem 1.5rem; box-shadow: var(--shadow);
  border: 1px solid var(--border); position: relative;
  overflow: hidden; transition: var(--tr);
  display: flex; flex-direction: column;
}
.sol-card::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 4px; background: var(--primary-light); transform: scaleX(0); transition: var(--tr);
}
.sol-card:hover { transform: translateY(-7px); box-shadow: var(--shadow-md); }
.sol-card:hover::after { transform: scaleX(1); }
.sol-icon {
  width: 52px; height: 52px; border-radius: 13px;
  background: var(--primary-pale); display: flex; align-items: center;
  justify-content: center; font-size: 1.35rem; color: var(--primary);
  margin-bottom: 1.25rem; transition: var(--tr);
}
.sol-card:hover .sol-icon { background: var(--primary); color: var(--white); }
.sol-card h3  { font-size: 1.02rem; margin-bottom: .55rem; line-height: 1.35; }
.sol-card p   { font-size: .85rem; color: var(--text-light); margin-bottom: 1.25rem; line-height: 1.65; flex-grow: 1; }
.sol-link {
  display: inline-flex; align-items: center; gap: .4rem;
  color: var(--primary); font-size: .82rem; font-weight: 700; transition: var(--tr);
  text-transform: uppercase; letter-spacing: .04em;
}
.sol-link:hover { gap: .7rem; color: var(--primary-light); }

/* ----- WHY BHRS ----- */
.why-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 2rem; }
.why-item {
  display: flex; gap: 1.25rem; align-items: flex-start;
  padding: 1.5rem 1.5rem; background: var(--white); border-radius: var(--radius);
  border: 1px solid var(--border); transition: var(--tr);
}
.why-item:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--border-blue); }
.why-icon {
  width: 50px; height: 50px; background: var(--primary-pale); border-radius: 13px;
  display: flex; align-items: center; justify-content: center;
  color: var(--primary); font-size: 1.25rem; flex-shrink: 0;
}
.why-text h4 { margin-bottom: .35rem; font-size: 1.02rem; }
.why-text p  { font-size: .88rem; color: var(--text-light); margin: 0; line-height: 1.65; }

/* ----- STATS ----- */
.stats-section {
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  padding: 5rem 0; position: relative; overflow: hidden;
}
.stats-section::before {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 30% 50%, rgba(13,113,195,.2) 0%, transparent 50%),
                    radial-gradient(circle at 70% 30%, rgba(255,255,255,.04) 0%, transparent 50%);
}
.stats-inner { position: relative; z-index: 1; }
.stats-grid  { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; text-align: center; }
.stats-grid-4 { grid-template-columns: repeat(4,1fr); gap: 1.5rem; }
.stat-item   { padding: 1.25rem 1rem; }
.stat-num {
  font-family: 'Poppins', sans-serif; font-size: 3.2rem; font-weight: 800;
  color: #4A9CDF; display: block; line-height: 1; margin-bottom: .5rem;
}
.stat-label  { color: rgba(255,255,255,.78); font-size: .95rem; font-weight: 500; line-height: 1.5; }

/* ----- DECISION PLECA (fondo claro) ----- */
.pleca {
  background: var(--bg);
  padding: 5rem 0; position: relative; overflow: hidden;
}
.pleca::before {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 90% 20%, rgba(0,85,165,.05) 0%, transparent 50%),
                    radial-gradient(circle at 10% 80%, rgba(13,113,195,.04) 0%, transparent 50%);
}
.pleca-inner { position: relative; z-index: 1; }
.pleca-text     { text-align: center; }
.pleca-text h2  { color: var(--text-dark); margin-bottom: 1rem; }
.pleca-text p   { color: var(--text-body); font-size: 1.05rem; margin: 0 auto 2.5rem; max-width: 720px; line-height: 1.75; }
.needs-grid {
  display: grid; grid-template-columns: repeat(2,1fr); gap: .85rem;
  max-width: 880px; margin: 0 auto 2.5rem;
}
.need-item {
  display: flex; align-items: center; gap: .85rem;
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: .95rem 1.15rem;
  transition: var(--tr); box-shadow: 0 2px 8px rgba(0,85,165,.04);
}
.need-item:hover { border-color: var(--primary-light); transform: translateX(3px); box-shadow: 0 4px 16px rgba(0,85,165,.1); }
.need-icon {
  width: 32px; height: 32px; background: var(--primary);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  color: var(--white); font-size: .78rem; flex-shrink: 0;
}
.need-text { color: var(--text-dark); font-size: .92rem; font-weight: 500; }
.pleca-cta { text-align: center; }

/* ----- CONTACT FORM ----- */
.contact-form-section { background: var(--bg); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.7fr; gap: 4rem; align-items: start; }
.contact-info h2 { margin-bottom: 1rem; }
.contact-info > p { color: var(--text-light); margin-bottom: 2.5rem; line-height: 1.75; }
.contact-detail { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.25rem; }
.cd-icon {
  width: 44px; height: 44px; background: var(--primary-pale); border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--primary); font-size: 1.05rem; flex-shrink: 0;
}
.cd-text span { display: block; font-size: .75rem; color: var(--text-light); }
.cd-text a, .cd-text strong { font-weight: 600; color: var(--text-dark); transition: var(--tr); }
.cd-text a:hover { color: var(--primary); }
.social-row { display: flex; gap: .6rem; margin-top: 2rem; }
.social-btn {
  width: 42px; height: 42px; background: var(--primary); border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--white); font-size: .9rem; transition: var(--tr);
}
.social-btn:hover { background: var(--primary-light); transform: translateY(-2px); }

.form-card {
  background: var(--white); border-radius: var(--radius);
  padding: 2.5rem; box-shadow: var(--shadow); border: 1px solid var(--border);
}
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.form-group { display: flex; flex-direction: column; gap: .35rem; }
.form-group.span2 { grid-column: 1/-1; }
.form-group label { font-size: .82rem; font-weight: 600; color: var(--text-dark); }
.form-group input,
.form-group select,
.form-group textarea {
  padding: .75rem 1rem; border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  font-size: .93rem; font-family: inherit; color: var(--text-dark);
  background: var(--white); outline: none; transition: var(--tr);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--primary-light); box-shadow: 0 0 0 3px rgba(13,113,195,.15);
}
.form-group textarea { resize: vertical; min-height: 120px; }
.form-group select   { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23718096' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.5rem; }

/* ----- FOOTER ----- */
.footer { background: var(--primary-dark); padding: 4.5rem 0 2rem; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 3rem; margin-bottom: 3rem; }
.footer-desc { color: rgba(255,255,255,.55); font-size: .86rem; line-height: 1.75; margin: 1.25rem 0 1.75rem; }
.footer-social { display: flex; gap: .6rem; }
.footer-social-btn {
  width: 38px; height: 38px; background: rgba(255,255,255,.08); border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.7); font-size: .85rem; transition: var(--tr);
}
.footer-social-btn:hover { background: var(--primary-light); color: var(--white); }
.footer-col h5 {
  color: var(--white); font-size: .8rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em; margin-bottom: 1.25rem;
}
.footer-links { display: flex; flex-direction: column; gap: .55rem; }
.footer-link { color: rgba(255,255,255,.55); font-size: .85rem; transition: var(--tr); }
.footer-link:hover { color: var(--primary-light); padding-left: 3px; }
.footer-contact-item { display: flex; gap: .75rem; margin-bottom: .75rem; font-size: .85rem; align-items: flex-start; }
.footer-contact-item i { color: var(--primary-light); flex-shrink: 0; margin-top: 3px; }
.footer-contact-item a { color: rgba(255,255,255,.65); transition: var(--tr); }
.footer-contact-item a:hover { color: var(--white); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.07); padding-top: 2rem;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
}
.footer-bottom p { color: rgba(255,255,255,.35); font-size: .78rem; margin: 0; }

/* ----- INNER PAGE HERO ----- */
.hero-inner {
  min-height: 42vh; display: flex; align-items: center;
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  padding: 8.5rem 0 4rem; position: relative; overflow: hidden;
}
.hero-inner::before {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 75% 50%, rgba(13,113,195,.25) 0%, transparent 55%);
}
.hero-inner-content { position: relative; z-index: 2; }
.breadcrumb { display: flex; align-items: center; gap: .5rem; margin-bottom: 1rem; font-size: .82rem; color: rgba(255,255,255,.6); flex-wrap: wrap; }
.breadcrumb a { color: rgba(255,255,255,.6); transition: var(--tr); }
.breadcrumb a:hover { color: #4A9CDF; }
.bc-sep { color: rgba(255,255,255,.3); }
.hero-inner h1 { color: var(--white); margin-bottom: .75rem; font-weight: 500; }
.hero-inner .hero-sub { color: rgba(255,255,255,.82); font-size: 1rem; max-width: 660px; line-height: 1.7; }

/* hero-inner with blurred image background */
.hero-inner-bg {
  position: absolute; inset: 0; z-index: 0; overflow: hidden;
}
.hero-inner-bg img {
  width: 100%; height: 100%; object-fit: cover;
  transform: scale(1.04);
}
.hero-inner-bg::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(135deg, rgba(0,30,72,.88) 0%, rgba(0,55,120,.78) 50%, rgba(0,30,72,.9) 100%);
  backdrop-filter: blur(2px);
}
.hero-inner.hero-inner-image::before { display: none; }
.hero-inner.hero-inner-image h1 {
  font-size: clamp(1.45rem, 3.2vw, 2.05rem);
  font-weight: 500;
  letter-spacing: -.005em;
}
.hero-inner.hero-inner-image .hero-sub { font-size: .98rem; }

/* Reactivo Cero pill (bottom-right of hero-inner on Recl. Operativo + HR RPO) */
.hero-inner .rc-pill {
  position: absolute;
  right: 2.2rem;
  bottom: 1.6rem;
  z-index: 3;
  display: inline-flex; align-items: center; gap: .55rem;
  background: #FFD93D;
  color: #1A2433;
  font-weight: 800;
  font-size: .82rem;
  letter-spacing: .04em;
  padding: .7rem 1.25rem;
  border-radius: 100px;
  text-transform: uppercase;
  box-shadow: 0 8px 22px rgba(0,0,0,.28);
  transition: var(--tr);
  text-decoration: none;
}
.hero-inner .rc-pill i { color: #1A2433; font-size: .85rem; }
.hero-inner .rc-pill:hover {
  background: #FFE066;
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(0,0,0,.34);
}

/* ----- SERVICE PAGE COMPONENTS ----- */
.service-lead { padding: 4rem 0; }
.service-lead-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.service-visual {
  background: linear-gradient(145deg, var(--primary) 0%, var(--primary-dark) 100%);
  border-radius: var(--radius); padding: 3rem;
  min-height: 340px; display: flex; flex-direction: column; justify-content: center;
  position: relative; overflow: hidden;
}
.service-visual::before {
  content: ''; position: absolute; top:-70px; right:-70px;
  width:240px; height:240px; background:rgba(13,113,195,.25); border-radius:50%;
}
.service-visual::after {
  content: ''; position: absolute; bottom:-50px; left:-50px;
  width:180px; height:180px; background:rgba(255,255,255,.05); border-radius:50%;
}
.sv-big-icon {
  font-size: 2.4rem; margin-bottom: 1.5rem; position: relative; z-index:1;
  width: 72px; height: 72px; border-radius: 16px;
  background: rgba(255,255,255,.12); display: flex;
  align-items: center; justify-content: center; color: white;
}
.sv-title { color: var(--white); font-size: 1.6rem; margin-bottom: .75rem; position: relative; z-index:1; }
.sv-desc  { color: rgba(255,255,255,.78); font-size: .95rem; line-height: 1.75; position: relative; z-index:1; }

.service-text h2  { margin-bottom: 1.25rem; }
.service-text p   { font-size: 1rem; line-height: 1.8; color: var(--text-body); }

/* Checklist */
.checklist { display: flex; flex-direction: column; gap: .7rem; }
.checklist-item {
  display: flex; align-items: flex-start; gap: .8rem;
  font-size: .93rem; color: var(--text-body); line-height: 1.6;
}
.check-icon {
  width: 22px; height: 22px; background: var(--primary); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 1px;
}
.check-icon i { color: white; font-size: .62rem; }

/* Audience */
.audience-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 1rem; }
.audience-item {
  display: flex; align-items: flex-start; gap: .9rem;
  padding: 1.25rem 1.4rem; border-radius: var(--radius-sm);
  background: var(--white); border: 1px solid var(--border);
  box-shadow: var(--shadow); transition: var(--tr);
}
.audience-item:hover { transform: translateY(-3px); border-color: var(--primary-light); }
.aud-icon {
  width: 38px; height: 38px; background: var(--primary-pale); border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  color: var(--primary); font-size: .95rem; flex-shrink: 0;
}
.aud-text strong { display: block; font-size: .88rem; color: var(--text-dark); margin-bottom: .2rem; }
.aud-text span   { font-size: .8rem; color: var(--text-light); }

/* Benefits */
.benefits-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 1.2rem; }
.benefit-card {
  background: var(--white); border-radius: var(--radius-sm);
  padding: 1.6rem 1.4rem; box-shadow: var(--shadow);
  border: 1px solid var(--border); text-align: center; transition: var(--tr);
}
.benefit-card:hover { transform: translateY(-4px); border-color: var(--primary-light); box-shadow: var(--shadow-md); }
.benefit-icon-wrap {
  width: 52px; height: 52px; margin: 0 auto .85rem;
  background: var(--primary-pale); color: var(--primary);
  border-radius: 13px; display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem;
}
.benefit-card h4 { font-size: .92rem; margin-bottom: .3rem; }
.benefit-card p  { font-size: .8rem; color: var(--text-light); margin: 0; line-height: 1.55; }

/* Process steps */
.process-list { display: flex; flex-direction: column; gap: 1rem; max-width: 780px; margin: 0 auto; }
.process-item {
  display: flex; gap: 1.5rem; align-items: flex-start;
  padding: 1.6rem 1.75rem; background: var(--white); border-radius: var(--radius);
  box-shadow: var(--shadow); border: 1px solid var(--border);
  transition: var(--tr); position: relative;
}
.process-item:not(:last-child)::after {
  content: ''; position: absolute;
  left: 2.95rem; bottom: -1rem; width: 2px; height: 1rem; background: var(--border-blue);
}
.process-item:hover { transform: translateX(6px); }
.process-item:hover .step-num { background: var(--primary-light); }
.step-num {
  width: 46px; height: 46px; background: var(--primary);
  border-radius: 11px; display: flex; align-items: center; justify-content: center;
  color: var(--white); font-family: 'Poppins',sans-serif; font-weight: 800;
  font-size: 1.1rem; flex-shrink: 0; transition: var(--tr);
}
.step-content h4 { margin-bottom: .35rem; }
.step-content p  { font-size: .88rem; color: var(--text-light); margin: 0; }

/* Distinctions */
.distinctions-list { display: flex; flex-direction: column; gap: 1rem; }
.distinction-item {
  display: flex; gap: 1.25rem; align-items: flex-start;
  padding: 1.4rem 1.6rem; background: var(--white); border-radius: var(--radius);
  box-shadow: var(--shadow); border: 1px solid var(--border);
  transition: var(--tr); border-left: 4px solid var(--border);
}
.distinction-item:hover { transform: translateX(6px); border-left-color: var(--primary); }
.dist-icon {
  width: 46px; height: 46px; background: var(--primary-pale); border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  color: var(--primary); font-size: 1.2rem; flex-shrink: 0;
}
.dist-text h4 { margin-bottom: .35rem; }
.dist-text p  { font-size: .88rem; color: var(--text-light); margin: 0; line-height: 1.65; }

/* Areas grid (Reclutamiento Profesional) */
.areas-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 1rem;
}
.area-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.5rem 1rem; text-align: center;
  transition: var(--tr);
}
.area-card:hover { transform: translateY(-4px); border-color: var(--primary-light); box-shadow: var(--shadow-md); }
.area-icon {
  width: 48px; height: 48px; margin: 0 auto .75rem;
  background: var(--primary-pale); color: var(--primary);
  border-radius: 12px; display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
}
.area-card span { font-size: .85rem; font-weight: 600; color: var(--text-dark); }

/* Reactivo Cero Block */
.reactivo-cero {
  background: linear-gradient(135deg, var(--primary-light) 0%, var(--primary) 100%);
  border-radius: var(--radius); padding: 2.5rem; color: var(--white);
  position: relative; overflow: hidden;
}
.reactivo-cero::before {
  content: ''; position: absolute; top: -60px; right: -60px;
  width: 220px; height: 220px; background: rgba(255,255,255,.08); border-radius: 50%;
}
.rc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; align-items: center; }
.rc-label {
  display: inline-block; background: rgba(255,255,255,.18); color: var(--white);
  font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  padding: .35rem 1rem; border-radius: 100px; margin-bottom: 1rem;
}
.rc-title { color: var(--white); font-size: 1.7rem; margin-bottom: 1rem; position: relative; z-index: 1; }
.rc-desc  { color: rgba(255,255,255,.88); margin-bottom: 1.5rem; font-size: .95rem; line-height: 1.75; position: relative; z-index: 1; }
.rc-list  { display: flex; flex-direction: column; gap: .55rem; margin-bottom: 1.75rem; position: relative; z-index: 1; }
.rc-list li {
  display: flex; align-items: center; gap: .7rem;
  color: rgba(255,255,255,.92); font-size: .9rem;
}
.rc-list li i { color: #4A9CDF; }
.rc-video-wrap {
  position: relative; aspect-ratio: 4/5;
  max-width: 380px; margin: 0 auto;
  border-radius: var(--radius); overflow: hidden;
  background: var(--primary-dark); border: 3px solid rgba(255,255,255,.2);
  box-shadow: 0 12px 36px rgba(0,0,0,.3);
  transition: var(--tr);
}
.rc-video-wrap:hover { transform: translateY(-3px); box-shadow: 0 18px 44px rgba(0,0,0,.4); }
.rc-cover-img img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.rc-cover-play {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.3) 100%);
  opacity: 0; transition: opacity .3s ease;
  pointer-events: none;
}
.rc-cover-img:hover .rc-cover-play { opacity: 1; }
.rc-cover-play .rc-play-icon {
  width: 70px; height: 70px; font-size: 1.7rem;
}
.rc-video-placeholder {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: .85rem;
  color: rgba(255,255,255,.85); text-align: center; padding: 1.5rem;
}
.rc-play-icon {
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(255,255,255,.95); color: var(--primary);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; padding-left: 5px;
  box-shadow: 0 6px 22px rgba(0,0,0,.25);
}
.rc-play-link {
  font-size: .85rem; color: rgba(255,255,255,.95);
  border-bottom: 1px dashed rgba(255,255,255,.4); padding-bottom: 2px;
}

/* Reactivo Cero — Reels-style cover (portada) */
.rc-video-cover {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 30% 30%, rgba(74,156,223,.45) 0%, transparent 55%),
    radial-gradient(circle at 70% 80%, rgba(255,217,61,.18) 0%, transparent 50%),
    linear-gradient(170deg, var(--primary) 0%, var(--primary-dark) 70%, #062544 100%);
  display: flex; flex-direction: column;
  align-items: center; justify-content: space-between;
  padding: 1.2rem 1rem 1.4rem;
  text-align: center;
  transition: var(--tr);
}
.rc-video-cover::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,.35) 100%);
  pointer-events: none;
}
.rc-video-wrap:hover .rc-video-cover { transform: scale(1.01); }
.rc-reels-tag {
  align-self: flex-start;
  background: rgba(0,0,0,.45); color: var(--white);
  font-size: .68rem; font-weight: 700; letter-spacing: .04em;
  padding: .35rem .8rem; border-radius: 100px;
  display: inline-flex; align-items: center; gap: .4rem;
  backdrop-filter: blur(6px);
  position: relative; z-index: 2;
}
.rc-reels-tag i { color: #FF3B62; font-size: .75rem; }
.rc-cover-stat {
  display: flex; flex-direction: column; align-items: center; gap: .3rem;
  margin: auto 0; position: relative; z-index: 2;
}
.rc-cover-num {
  font-family: 'Poppins', sans-serif;
  font-size: 3.6rem; font-weight: 800;
  color: #FFD93D;
  line-height: 1; letter-spacing: -.025em;
  text-shadow: 0 3px 10px rgba(0,0,0,.4);
}
.rc-cover-text {
  font-size: .92rem; font-weight: 600;
  color: var(--white);
  text-shadow: 0 1px 4px rgba(0,0,0,.5);
  max-width: 85%; line-height: 1.35;
}
.rc-cover-cta {
  display: flex; flex-direction: column; align-items: center; gap: .55rem;
  position: relative; z-index: 2;
}
.rc-cover-cta .rc-play-icon { width: 52px; height: 52px; font-size: 1.2rem; }
.rc-cover-cta .rc-play-link { font-size: .8rem; }

/* Modalidades de nómina */
.modalities-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.modality-card {
  background: var(--white); border-radius: var(--radius);
  border: 1px solid var(--border); padding: 2rem; transition: var(--tr);
  box-shadow: var(--shadow);
}
.modality-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--primary-light); }
.mod-header {
  display: flex; align-items: center; gap: 1rem; margin-bottom: 1.25rem;
  padding-bottom: 1.25rem; border-bottom: 1px solid var(--border);
}
.mod-icon {
  width: 56px; height: 56px; border-radius: 14px;
  background: var(--primary-pale); color: var(--primary);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; flex-shrink: 0;
}
.mod-header h3 { margin: 0; font-size: 1.1rem; }
.mod-header span { font-size: .75rem; color: var(--text-light); }
.modality-card > p { font-size: .9rem; color: var(--text-light); line-height: 1.7; margin-bottom: 1rem; }
.mod-features { display: flex; flex-direction: column; gap: .55rem; }

/* Complementary card (used as inline) */
.comp-card-mini {
  background: var(--white); border-radius: var(--radius);
  border: 1px solid var(--border); padding: 2rem;
  box-shadow: var(--shadow); text-align: center; transition: var(--tr);
}
.comp-card-mini:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.comp-card-mini .area-icon { width: 60px; height: 60px; font-size: 1.5rem; }
.comp-card-mini h3 { margin-bottom: .5rem; font-size: 1.1rem; }
.comp-card-mini p { font-size: .88rem; color: var(--text-light); margin-bottom: 1.25rem; line-height: 1.65; }

/* ----- Image blocks ----- */
.img-block {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 4rem; align-items: center;
}
.img-block.reverse { direction: rtl; }
.img-block.reverse > * { direction: ltr; }
.img-block-frame {
  position: relative; border-radius: var(--radius);
  overflow: hidden; aspect-ratio: 4/3; box-shadow: var(--shadow-md);
  background: var(--primary-pale);
}
.img-block-frame img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s ease;
}
.img-block-frame:hover img { transform: scale(1.04); }
.img-block-frame::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, transparent 60%, rgba(0,85,165,.12) 100%);
  pointer-events: none;
}
.img-block-badge {
  position: absolute; bottom: 1.25rem; left: 1.25rem;
  background: rgba(255,255,255,.95); backdrop-filter: blur(4px);
  border-radius: 10px; padding: .85rem 1.1rem;
  display: flex; align-items: center; gap: .75rem;
  box-shadow: var(--shadow);
}
.img-block-badge-icon {
  width: 36px; height: 36px; border-radius: 9px;
  background: var(--primary); color: white;
  display: flex; align-items: center; justify-content: center;
  font-size: .95rem; flex-shrink: 0;
}
.img-block-badge strong { display: block; font-size: .82rem; color: var(--text-dark); }
.img-block-badge span   { font-size: .72rem; color: var(--text-light); }

/* Hero image variant */
.hero-image-frame {
  border-radius: var(--radius); overflow: hidden;
  position: relative; aspect-ratio: 4/3.4;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
  border: 4px solid rgba(255,255,255,.1);
}
.hero-image-frame img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.hero-image-frame::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, transparent 50%, rgba(0,85,165,.25) 100%);
}

/* CTA Section */
.cta-block {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  padding: 5.5rem 0; text-align: center; position: relative; overflow: hidden;
}
.cta-block::before {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 30% 50%, rgba(13,113,195,.2) 0%, transparent 50%),
                    radial-gradient(circle at 70% 50%, rgba(255,255,255,.04) 0%, transparent 50%);
}
.cta-inner { position: relative; z-index: 1; }
.cta-block h2 { color: var(--white); margin-bottom: 1rem; }
.cta-block p  { color: rgba(255,255,255,.78); font-size: 1.08rem; max-width: 580px; margin: 0 auto 2.5rem; line-height: 1.75; }
.cta-buttons  { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ----- PROCESS FLOW (horizontal con steps) ----- */
.process-flow {
  position: relative;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1.25rem;
  margin-top: 2.5rem;
  padding-top: 1rem;
}
.process-flow.cols-5 { grid-template-columns: repeat(5, 1fr); }
.process-flow.cols-4 { grid-template-columns: repeat(4, 1fr); }
.process-flow.cols-7 { grid-template-columns: repeat(7, 1fr); }
.process-flow.cols-8 { grid-template-columns: repeat(8, 1fr); }
.process-flow.cols-9 { grid-template-columns: repeat(9, 1fr); }
.process-flow::before {
  content: '';
  position: absolute;
  top: 36px; left: 8%; right: 8%; height: 2px;
  background: repeating-linear-gradient(to right, var(--border-blue) 0, var(--border-blue) 6px, transparent 6px, transparent 12px);
  z-index: 0;
}
.pstep {
  position: relative; z-index: 1;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
}
.pstep-num {
  width: 54px; height: 54px;
  background: var(--white);
  border: 2.5px solid var(--primary);
  color: var(--primary);
  border-radius: 50%;
  font-family: 'Poppins', sans-serif;
  font-weight: 800; font-size: 1.05rem;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 1rem;
  box-shadow: 0 4px 12px rgba(0,85,165,.12);
  transition: var(--tr);
}
.pstep:hover .pstep-num {
  background: var(--primary); color: white;
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0,85,165,.25);
}
.pstep-icon {
  width: 44px; height: 44px;
  background: var(--primary-pale);
  color: var(--primary);
  border-radius: 11px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1.05rem;
  margin-bottom: .75rem;
  transition: var(--tr);
}
.pstep:hover .pstep-icon { background: var(--primary); color: white; }
.pstep h4 {
  font-size: .9rem; margin-bottom: .35rem;
  color: var(--text-dark); line-height: 1.3;
}
.pstep p {
  font-size: .78rem; color: var(--text-light);
  margin: 0; line-height: 1.5;
}

/* ----- FLIP CARDS (Lo que nos distingue) ----- */
.flip-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.5rem;
}
.flip-card {
  perspective: 1100px;
  height: 240px;
  cursor: pointer;
}
.flip-inner {
  position: relative;
  width: 100%; height: 100%;
  transform-style: preserve-3d;
  transition: transform .75s cubic-bezier(.4, .0, .2, 1);
}
.flip-card:hover .flip-inner,
.flip-card:focus-within .flip-inner { transform: rotateY(180deg); }
.flip-front, .flip-back {
  position: absolute; inset: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  border-radius: var(--radius);
  padding: 1.75rem 1.5rem;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center;
}
.flip-front {
  background: var(--white);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  transition: border-color .3s ease;
}
.flip-card:hover .flip-front { border-color: var(--primary-light); }
.flip-back {
  background: linear-gradient(145deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: var(--white);
  transform: rotateY(180deg);
  box-shadow: var(--shadow-md);
}
.flip-front-icon {
  width: 64px; height: 64px;
  border-radius: 16px;
  background: var(--primary-pale);
  color: var(--primary);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem;
  margin-bottom: 1.25rem;
  transition: var(--tr);
}
.flip-card:hover .flip-front-icon { background: var(--primary); color: white; transform: scale(1.05); }
.flip-front h4 {
  font-size: 1.05rem; color: var(--text-dark);
  margin: 0;
}
.flip-back-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: rgba(255,255,255,.18);
  color: white;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  margin-bottom: .85rem;
}
.flip-back h4 {
  color: white; font-size: 1rem; margin-bottom: .55rem;
}
.flip-back p {
  color: rgba(255,255,255,.92);
  font-size: .85rem; line-height: 1.55; margin: 0;
}

/* "Qué hacemos" 5 cards centradas (3 + 2 centradas) */
.solutions-grid.center-last {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.4rem;
}
.solutions-grid.center-last > .sol-card:nth-child(4),
.solutions-grid.center-last > .sol-card:nth-child(5) {
  grid-column: span 1;
}
.solutions-grid.center-last > .sol-card:nth-child(4) {
  grid-column: 1 / span 1;
  justify-self: end;
  width: 100%;
  max-width: 380px;
  grid-row: 2;
  grid-column-start: 1;
}
/* Simpler: use 6-col grid for proper centering of last row */
.solutions-grid.cards-5 {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1.4rem;
}
.solutions-grid.cards-5 > .sol-card:nth-child(1),
.solutions-grid.cards-5 > .sol-card:nth-child(2),
.solutions-grid.cards-5 > .sol-card:nth-child(3) {
  grid-column: span 2;
}
.solutions-grid.cards-5 > .sol-card:nth-child(4) {
  grid-column: 2 / span 2;
}
.solutions-grid.cards-5 > .sol-card:nth-child(5) {
  grid-column: 4 / span 2;
}

/* ----- ANIMATIONS ----- */
.fade-up { opacity: 0; transform: translateY(28px); transition: opacity .6s ease, transform .6s ease; }
.fade-up.visible { opacity: 1; transform: translateY(0); }
.d1 { transition-delay: .1s; } .d2 { transition-delay: .2s; }
.d3 { transition-delay: .3s; } .d4 { transition-delay: .4s; }

/* ----- UTILITIES ----- */
.text-center { text-align: center; }
.text-blue   { color: var(--primary) !important; }
.text-white  { color: var(--white) !important; }
.mt1 { margin-top: 1rem; } .mt2 { margin-top: 2rem; } .mt3 { margin-top: 3rem; }

/* ====================================================
   RESPONSIVE
   ==================================================== */
@media (max-width: 1100px) {
  .solutions-grid          { grid-template-columns: repeat(2,1fr); }
  .solutions-grid.cols-5,
  .solutions-grid.cols-4   { grid-template-columns: repeat(2,1fr); }
  .footer-grid             { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .stats-grid              { grid-template-columns: repeat(3,1fr); }
  .stats-grid.stats-grid-4 { grid-template-columns: repeat(2,1fr); }
  .process-flow,
  .process-flow.cols-5,
  .process-flow.cols-4,
  .process-flow.cols-7,
  .process-flow.cols-8,
  .process-flow.cols-9     { grid-template-columns: repeat(3,1fr); gap: 1.75rem; }
  .process-flow::before    { display: none; }
  .solutions-grid.cards-5  { grid-template-columns: repeat(2,1fr); }
  .solutions-grid.cards-5 > .sol-card { grid-column: span 1 !important; }
  .solutions-grid.cards-5 > .sol-card:nth-child(4),
  .solutions-grid.cards-5 > .sol-card:nth-child(5) { grid-column: span 1 !important; grid-row: auto !important; }
}

@media (max-width: 900px) {
  .hero-grid          { grid-template-columns: 1fr; }
  .hero-visual        { display: none; }
  .about-grid         { grid-template-columns: 1fr; }
  .about-visual       { display: none; }
  .why-grid           { grid-template-columns: 1fr; }
  .stats-grid         { grid-template-columns: repeat(3,1fr); }
  .stats-grid.stats-grid-4 { grid-template-columns: repeat(2,1fr); }
  .contact-grid       { grid-template-columns: 1fr; }
  .service-lead-grid  { grid-template-columns: 1fr; }
  .service-visual     { display: none; }
  .modalities-grid    { grid-template-columns: 1fr; }
  .rc-grid            { grid-template-columns: 1fr; }
  .needs-grid         { grid-template-columns: 1fr; }
  .img-block          { grid-template-columns: 1fr; gap: 2.5rem; }
  .img-block.reverse  { direction: ltr; }
}

@media (max-width: 768px) {
  .process-flow,
  .process-flow.cols-5,
  .process-flow.cols-4,
  .process-flow.cols-7,
  .process-flow.cols-8,
  .process-flow.cols-9     { grid-template-columns: repeat(2,1fr); }
  .nav-menu, .nav-cta-btn  { display: none; }
  .nav-hamburger           { display: flex; }
  .solutions-grid,
  .solutions-grid.cols-5,
  .solutions-grid.cols-4   { grid-template-columns: 1fr; }
  .stats-grid              { grid-template-columns: 1fr; }
  .form-grid               { grid-template-columns: 1fr; }
  .form-group.span2        { grid-column: 1; }
  .footer-grid             { grid-template-columns: 1fr; }
  .footer-bottom           { flex-direction: column; text-align: center; }
  .hero-cta                { flex-direction: column; align-items: stretch; }
  .hero-cta .btn           { justify-content: center; }
  .hero-bullets-uniform .hero-bullet { width: 100%; max-width: 320px; }
  .hero-inner .rc-pill     { right: 1rem; bottom: 1rem; font-size: .72rem; padding: .55rem 1rem; }
  .about-boxes             { grid-template-columns: 1fr; }
  .cta-buttons             { flex-direction: column; align-items: center; }
  .whatsapp-float          { width: 52px; height: 52px; bottom: 1rem; right: 1rem; font-size: 1.5rem; }
}

@media (max-width: 480px) {
  .section    { padding: 3.5rem 0; }
  .stat-num   { font-size: 2.2rem; }
  .form-card  { padding: 1.75rem; }
}

/* ============================================================
   Contact Form 7 - styling alineado con BHRS
   ============================================================ */

.wpcf7-form .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.25rem; }
.wpcf7-form .form-group { display: flex; flex-direction: column; gap: .4rem; }
.wpcf7-form .form-group.span2 { grid-column: 1 / -1; }
.wpcf7-form .form-group label {
  font-size: .82rem; font-weight: 600; color: var(--text-dark);
}

/* Inputs, select y textarea de CF7 */
.wpcf7-form .wpcf7-form-control-wrap { display: block; width: 100%; }
.wpcf7-form input.wpcf7-form-control,
.wpcf7-form select.wpcf7-form-control,
.wpcf7-form textarea.wpcf7-form-control {
  width: 100%;
  padding: .85rem 1rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  font-size: .93rem;
  font-family: inherit;
  color: var(--text-dark);
  background: var(--white);
  outline: none;
  transition: var(--tr);
  box-sizing: border-box;
}
.wpcf7-form input.wpcf7-form-control:focus,
.wpcf7-form select.wpcf7-form-control:focus,
.wpcf7-form textarea.wpcf7-form-control:focus {
  border-color: var(--primary-light);
  box-shadow: 0 0 0 3px rgba(13,113,195,.15);
}
.wpcf7-form textarea.wpcf7-form-control { resize: vertical; min-height: 130px; }
.wpcf7-form select.wpcf7-form-control {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23718096' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}

/* Submit button alineado con btn-primary del sitio */
.wpcf7-form input.wpcf7-submit,
.wpcf7-form button.wpcf7-submit {
  display: inline-flex; align-items: center; justify-content: center;
  width: 100%;
  padding: .95rem 1.6rem;
  background: var(--primary);
  color: var(--white);
  border: 2px solid transparent;
  border-radius: 100px;
  font-size: .95rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: var(--tr);
  margin-top: .5rem;
}
.wpcf7-form input.wpcf7-submit:hover,
.wpcf7-form button.wpcf7-submit:hover {
  background: var(--primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(0,85,165,.32);
}

/* Spinner del submit */
.wpcf7-spinner { vertical-align: middle; margin-left: .6rem; }

/* Mensajes de validacion */
.wpcf7-not-valid-tip {
  color: #d63638;
  font-size: .78rem;
  margin-top: .35rem;
  display: block;
}
.wpcf7-form input.wpcf7-form-control.wpcf7-not-valid,
.wpcf7-form select.wpcf7-form-control.wpcf7-not-valid,
.wpcf7-form textarea.wpcf7-form-control.wpcf7-not-valid {
  border-color: #d63638;
  box-shadow: 0 0 0 3px rgba(214,54,56,.12);
}

/* Mensaje de respuesta (exito/error) */
.wpcf7-form .wpcf7-response-output {
  margin: 1.25rem 0 0 !important;
  padding: .95rem 1.15rem !important;
  border-radius: 10px !important;
  font-size: .88rem;
  line-height: 1.5;
  border-width: 1px !important;
}
.wpcf7 form.sent .wpcf7-response-output {
  background: #e6f7ec; border-color: #b8e0c4 !important; color: #1d6b35;
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output {
  background: #fdecec; border-color: #f3c2c2 !important; color: #8b1a1a;
}

/* Responsive */
@media (max-width: 600px) {
  .wpcf7-form .form-grid { grid-template-columns: 1fr; }
  .wpcf7-form .form-group.span2 { grid-column: 1; }
}
