/*
Theme Name: Industrial de Puertas Child
Theme URI: https://industrialdepuertas.es
Description: Tema hijo de GeneratePress para Industrial de Puertas - Soluciones industriales de puertas y sistemas de carga
Author: creaar.es
Author URI: https://creaar.es
Template: generatepress
Version: 1.0.0
Text Domain: generatepress-child
Tags: industrial, puertas, responsive, one-page
*/

/* Desarrollo web y diseño: https://creaar.es */

/* =========================================
   VARIABLES Y RESET
   ========================================= */
:root {
  --color-primary:       #D50000;
  --color-primary-dark:  #B00000;
  --color-dark:          #111418;
  --color-dark-2:        #1C244B;
  --color-dark-3:        #1a1a2e;
  --color-gray:          #2c2c3a;
  --color-gray-light:    #F2F2F2;
  --color-gray-mid:      #888899;
  --color-white:         #FFFFFF;
  --color-text:          #201F1F;
  --color-text-light:    #555566;
  --font-head:           'Poppins', sans-serif;
  --font-body:           'Roboto', sans-serif;
  --font-accent:         'Montserrat', sans-serif;
  --radius:              4px;
  --shadow:              0 8px 30px rgba(0,0,0,.12);
  --shadow-hover:        0 16px 50px rgba(0,0,0,.20);
  --transition:          all .35s cubic-bezier(.25,.46,.45,.94);
  --section-pad:         90px 0;
  --max-width:           1240px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.7;
  color: var(--color-text);
  background: var(--color-white);
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }

a { color: inherit; text-decoration: none; transition: var(--transition); }

ul { list-style: none; }

.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
}

/* =========================================
   SVG – CONTENCIÓN GLOBAL
   Los SVG inline sin atributos width/height se renderizan
   a 300×150 px por defecto. Estas reglas los contienen.
   ========================================= */

/* Todos los SVG dentro de contenedores de icono */
[class*="-icon"] svg,
[class*="-icon"] > svg {
  display: block;
  flex-shrink: 0;
  max-width: 100%;
  max-height: 100%;
  overflow: hidden;
}

/* ── Hero-features: límite duro pedido ── */
.hero-feature svg,
.hero-feature img,
.hero-features svg {
  width: 48px !important;
  height: 48px !important;
  max-width: 48px !important;
  max-height: 48px !important;
}
.hero-feature-icon {
  width: 64px !important;
  height: 64px !important;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Límite duro global para todos los SVG inline ── */
svg { max-width: 64px !important; max-height: 64px !important; overflow: hidden; }

/* Excepciones: iconos pequeños en contextos específicos */
.page-feature-card-icon svg  { max-width: 22px !important; max-height: 22px !important; }
.gallery-placeholder svg     { max-width: 24px !important; max-height: 24px !important; }
.dropdown-link svg           { max-width: 14px !important; max-height: 14px !important; }
.footer-social-link svg      { max-width: 20px !important; max-height: 20px !important; }
.contacto-detail-icon svg    { max-width: 20px !important; max-height: 20px !important; }
.footer-contact-item svg     { max-width: 16px !important; max-height: 16px !important; }
.btn svg                     { max-width: 18px !important; max-height: 18px !important; }
.nav-link svg                { max-width: 12px !important; max-height: 12px !important; }
.header-phone svg            { max-width: 16px !important; max-height: 16px !important; }
.header-top svg              { max-width: 14px !important; max-height: 14px !important; }
.nosotros-list-icon svg      { max-width: 18px !important; max-height: 18px !important; }
.process-icon svg            { max-width: 28px !important; max-height: 28px !important; }
.mobile-cta svg              { max-width: 18px !important; max-height: 18px !important; }
.back-top svg                { max-width: 20px !important; max-height: 20px !important; }
.page-intro-placeholder svg  { max-width: 64px !important; max-height: 64px !important; }
.hero-stat-icon svg          { max-width: 22px !important; max-height: 22px !important; }

/* =========================================
   ESTILOS PÁGINAS DE SERVICIO
   ========================================= */
.page-hero {
  position: relative;
  min-height: 60vh;
  display: flex;
  align-items: center;
  background: var(--color-dark);
  overflow: hidden;
  padding: 120px 0 80px;
}
.page-hero-bg {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(135deg, rgba(17,20,24,.92) 0%, rgba(28,36,75,.80) 100%);
  background-size: cover;
  background-position: center;
}
.page-hero-bg[style] {
  background-blend-mode: multiply;
}
.page-hero .container { position: relative; z-index: 2; }
.page-hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(213,0,0,.15);
  border: 1px solid rgba(213,0,0,.4);
  border-radius: 100px;
  padding: 6px 16px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: #ff7070;
  margin-bottom: 20px;
}
.page-hero h1 {
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  color: var(--color-white);
  margin-bottom: 18px;
  line-height: 1.1;
}
.page-hero h1 span { color: var(--color-primary); }
.page-hero p {
  font-size: 1.05rem;
  color: rgba(255,255,255,.7);
  max-width: 600px;
  line-height: 1.8;
  margin-bottom: 32px;
}
.page-hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.page-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .78rem;
  color: rgba(255,255,255,.45);
  margin-bottom: 28px;
}
.page-breadcrumb a { color: rgba(255,255,255,.5); }
.page-breadcrumb a:hover { color: var(--color-primary); }
.page-breadcrumb span { color: rgba(255,255,255,.25); }

/* Sección intro */
.page-intro { padding: var(--section-pad); background: var(--color-white); }
.page-intro-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.page-intro-img {
  border-radius: 10px;
  overflow: hidden;
  height: 440px;
  background: var(--color-gray-light);
  position: relative;
}
.page-intro-img img { width: 100%; height: 100%; object-fit: cover; }
.page-intro-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  background: linear-gradient(135deg, var(--color-dark) 0%, var(--color-dark-2) 100%);
  color: rgba(255,255,255,.2);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.page-intro-placeholder svg { width: 64px; height: 64px; }

/* Features grid */
.page-features { padding: var(--section-pad); background: var(--color-gray-light); }
.page-features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.page-feature-card {
  background: var(--color-white);
  border-radius: 10px;
  padding: 28px 24px;
  border: 1px solid rgba(0,0,0,.06);
  transition: var(--transition);
}
.page-feature-card:hover { box-shadow: var(--shadow); transform: translateY(-4px); }
.page-feature-card-icon {
  width: 48px;
  height: 48px;
  background: rgba(213,0,0,.08);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}
.page-feature-card-icon svg { width: 22px; height: 22px; color: var(--color-primary); }
.page-feature-card h4 { font-size: .95rem; color: var(--color-dark-2); margin-bottom: 8px; }
.page-feature-card p { font-size: .83rem; color: var(--color-text-light); line-height: 1.65; margin: 0; }

/* Specs table */
.page-specs { padding: var(--section-pad); background: var(--color-white); }
.specs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}
.specs-table th, .specs-table td {
  padding: 14px 20px;
  text-align: left;
  border-bottom: 1px solid rgba(0,0,0,.07);
}
.specs-table thead th {
  background: var(--color-dark-2);
  color: white;
  font-family: var(--font-head);
  font-size: .75rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.specs-table tbody tr:hover td { background: var(--color-gray-light); }
.specs-table td:first-child { color: var(--color-dark-2); font-weight: 600; }
.specs-table td:last-child { color: var(--color-text-light); }

/* Gallery */
.page-gallery { padding: var(--section-pad); background: var(--color-dark); }
.page-gallery .section-title { color: white; }
.page-gallery .section-subtitle { color: rgba(255,255,255,.6); }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto auto;
  gap: 12px;
}
.gallery-item {
  border-radius: var(--radius);
  overflow: hidden;
  background: rgba(255,255,255,.04);
  height: 200px;
  position: relative;
}
.gallery-item:first-child { grid-column: 1 / 3; height: 280px; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.gallery-item:hover img { transform: scale(1.05); }
.gallery-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.04);
  border: 1px dashed rgba(255,255,255,.1);
  color: rgba(255,255,255,.2);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  gap: 8px;
}
.gallery-placeholder svg { width: 20px; height: 20px; }

/* Service page responsive */
@media (max-width: 900px) {
  .page-intro-inner { grid-template-columns: 1fr; gap: 32px; }
  .page-features-grid { grid-template-columns: 1fr 1fr; }
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .gallery-item:first-child { grid-column: 1 / -1; }
}
@media (max-width: 600px) {
  .page-features-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-item:first-child { height: 200px; }
}

/* =========================================
   TIPOGRAFÍA
   ========================================= */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-head);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-dark-2);
}

h1 { font-size: clamp(2rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.6rem); }
h4 { font-size: 1.15rem; }

p { margin-bottom: 1rem; }

.section-tag {
  display: inline-block;
  font-family: var(--font-accent);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--color-primary);
  background: rgba(213,0,0,.08);
  padding: 5px 14px;
  border-radius: 2px;
  margin-bottom: 14px;
}

.section-title {
  font-size: clamp(1.7rem, 3vw, 2.5rem);
  margin-bottom: .6rem;
  color: var(--color-dark-2);
}

.section-title span { color: var(--color-primary); }

.section-subtitle {
  font-size: 1rem;
  color: var(--color-text-light);
  max-width: 640px;
  line-height: 1.75;
}

.section-header { margin-bottom: 56px; }
.section-header.centered { text-align: center; }
.section-header.centered .section-subtitle { margin: 0 auto; }

/* =========================================
   BOTONES
   ========================================= */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-head);
  font-size: .88rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 14px 30px;
  border-radius: var(--radius);
  border: 2px solid transparent;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}

.btn-primary {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}
.btn-primary:hover {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(213,0,0,.4);
  color: var(--color-white);
}

.btn-outline {
  background: transparent;
  color: var(--color-white);
  border-color: rgba(255,255,255,.5);
}
.btn-outline:hover {
  background: rgba(255,255,255,.1);
  border-color: var(--color-white);
  color: var(--color-white);
}

.btn-ghost {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn-ghost:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

.btn svg { width: 16px; height: 16px; flex-shrink: 0; }

/* =========================================
   GSAP – estados iniciales y utilidades
   ========================================= */

/*
 * Los elementos con [data-aos] son ocultados aquí mientras el JS carga.
 * GSAP los anima individualmente; si JS falla, la clase .gsap-ready
 * en <html> no se añade y los elementos se muestran con la transición CSS.
 */
[data-aos] {
  opacity: 0;
  transform: translateY(36px);
  transition: opacity .6s ease, transform .6s ease;
  will-change: transform, opacity;
}

/* Fallback si JS está desactivado o GSAP no carga */
.no-js [data-aos],
[data-aos].aos-animate {
  opacity: 1 !important;
  transform: none !important;
}

/* Variantes semánticas (usadas por el fallback CSS) */
[data-aos="fade-left"]  { transform: translateX(-40px); }
[data-aos="fade-right"] { transform: translateX(40px); }
[data-aos="zoom-in"]    { transform: scale(.9); }

/* GSAP gestiona la visibilidad del header al hacer scroll */
.site-header {
  will-change: transform;
}

/* Back-to-top: estado inicial oculto (GSAP lo revela) */
.back-top {
  opacity:    0;
  visibility: hidden;
  transform:  translateY(12px);
}

/* Proceso: pseudo-elemento se anima con custom property */
.proceso-steps {
  --line-progress: 0%;
}
.proceso-steps::before {
  right: calc(16.67% + 48px);  /* sobrescrito desde JS si hace falta */
  background: linear-gradient(
    90deg,
    var(--color-primary)    0%,
    var(--color-primary)    var(--line-progress),
    rgba(213,0,0,.15)       var(--line-progress),
    rgba(213,0,0,.15)       100%
  );
  transition: none; /* GSAP controla esto */
}

/* word-span: creados dinámicamente por splitByWords() */
.hero-title span,
.cta-band h2 span {
  display: inline-block;
  will-change: transform, opacity;
}

/* =========================================
   HEADER / NAVEGACIÓN
   ========================================= */
/* Eliminar línea encima del header (GeneratePress o tema padre) */
.site-header,
#masthead,
#site-header,
.site-header::before,
#masthead::before { border-top: none !important; outline: none !important; }

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: transparent;
  transition: background .4s ease, box-shadow .4s ease, padding .3s ease;
}

.site-header.scrolled {
  background: rgba(17,20,24,.97);
  box-shadow: 0 2px 20px rgba(0,0,0,.4);
}

.header-top {
  background: var(--color-primary);
  padding: 7px 0;
  font-size: .78rem;
  color: rgba(255,255,255,.9);
}

.header-top .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.header-top a {
  color: rgba(255,255,255,.9);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.header-top a:hover { color: #fff; }

.header-top-links { display: flex; gap: 20px; }

.header-main {
  padding: 18px 0;
}

.header-main .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}

/* Logo */
.site-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.logo-icon {
  width: 44px;
  height: 44px;
  background: var(--color-primary);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-icon svg { width: 26px; height: 26px; fill: white; }

.logo-text { line-height: 1.15; }

.logo-name {
  display: block;
  font-family: var(--font-head);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-white);
  letter-spacing: .02em;
}

.logo-tagline {
  display: block;
  font-size: .68rem;
  font-weight: 400;
  color: rgba(255,255,255,.55);
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* Menú de navegación */
.site-nav { flex: 1; }

.nav-menu {
  display: flex;
  align-items: center;
  gap: 4px;
  justify-content: center;
}

.nav-item { position: relative; }

.nav-link {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 10px 14px;
  font-family: var(--font-head);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: rgba(255,255,255,.85);
  border-radius: var(--radius);
  transition: var(--transition);
}
.nav-link:hover,
.nav-item.active > .nav-link {
  color: var(--color-white);
  background: rgba(255,255,255,.08);
}
.nav-link.active { color: var(--color-primary); }

.nav-link svg { width: 12px; height: 12px; transition: transform .25s; }
.nav-item:hover .nav-link svg { transform: rotate(180deg); }

/* Dropdown */
.dropdown {
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: var(--color-white);
  min-width: 230px;
  border-radius: var(--radius);
  box-shadow: 0 12px 40px rgba(0,0,0,.18);
  padding: 10px 0;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition);
  border-top: 3px solid var(--color-primary);
}

.nav-item:hover .dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.dropdown-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  font-size: .85rem;
  color: var(--color-text);
  font-weight: 500;
}
.dropdown-link:hover { color: var(--color-primary); background: var(--color-gray-light); }
.dropdown-link svg { width: 14px; height: 14px; flex-shrink: 0; color: var(--color-primary); }

/* CTA Header */
.header-cta {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-shrink: 0;
}

.header-phone {
  font-family: var(--font-head);
  font-size: .9rem;
  font-weight: 600;
  color: var(--color-white);
  display: flex;
  align-items: center;
  gap: 7px;
}
.header-phone svg { color: var(--color-primary); width: 16px; height: 16px; }
.header-phone:hover,
.header-phone:focus { color: var(--color-white) !important; opacity: .85; text-decoration: none; }
.header-phone:hover svg,
.header-phone:focus svg { color: var(--color-primary) !important; }

/* Hamburger */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 8px;
  background: none;
  border: none;
}
.hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--color-white);
  border-radius: 2px;
  transition: var(--transition);
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* =========================================
   HERO SECTION
   ========================================= */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--color-dark);
  padding-top: 90px;
}

.hero-bg {
  position: absolute;
  inset: 0;
  /* La imagen de fondo se inyecta vía inline style desde PHP (Customizer).
     El gradiente oscuro se aplica siempre encima. */
  background-image:
    linear-gradient(135deg, rgba(17,20,24,.88) 0%, rgba(28,36,75,.75) 50%, rgba(213,0,0,.15) 100%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(213,0,0,.12) 0%, transparent 60%);
}

.hero-pattern {
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 60px, rgba(255,255,255,.015) 60px, rgba(255,255,255,.015) 61px),
    repeating-linear-gradient(90deg, transparent, transparent 60px, rgba(255,255,255,.015) 60px, rgba(255,255,255,.015) 61px);
  pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 2;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 80px 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  width: 100%;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(213,0,0,.15);
  border: 1px solid rgba(213,0,0,.4);
  border-radius: 100px;
  padding: 6px 16px;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #ff6b6b;
  margin-bottom: 24px;
}

.hero-badge span { width: 6px; height: 6px; background: var(--color-primary); border-radius: 50%; animation: pulse 2s infinite; }

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .5; transform: scale(1.4); }
}

.hero-title {
  font-size: clamp(2.4rem, 5.5vw, 4rem);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.1;
  margin-bottom: 24px;
}

.hero-title em {
  font-style: normal;
  color: var(--color-primary);
  position: relative;
}

.hero-title em::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--color-primary);
  border-radius: 2px;
  opacity: .4;
}

.hero-desc {
  font-size: 1.05rem;
  color: rgba(255,255,255,.7);
  line-height: 1.8;
  margin-bottom: 36px;
  max-width: 520px;
}

.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 48px; }

.hero-stats {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
  padding-top: 36px;
  border-top: 1px solid rgba(255,255,255,.1);
}

.hero-stat-num {
  font-family: var(--font-head);
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--color-white);
  line-height: 1;
}
.hero-stat-num span { color: var(--color-primary); }
.hero-stat-label {
  font-size: .78rem;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-top: 4px;
}

/* =========================================
   HERO FEATURES – bloques imagen + hover
   ========================================= */
.hero-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  position: relative;
}

/* Cada bloque usa --feat-img inyectada por PHP inline style.
   Si no hay imagen se muestra un gradiente de reserva. */
.hero-feature {
  position: relative;
  height: 195px;
  border-radius: 10px;
  overflow: hidden;
  background-image: var(--feat-img, linear-gradient(135deg, #1a1a2e 0%, #2c2c3a 100%));
  background-size: cover;
  background-position: center;
  cursor: pointer;
}

/* Colores de reserva distintos por posición */
.hero-feature:nth-child(1) { --feat-fallback: linear-gradient(135deg, #1a1a2e 0%, #1C244B 100%); }
.hero-feature:nth-child(2) { --feat-fallback: linear-gradient(135deg, #111418 0%, #2c2c3a 100%); }
.hero-feature:nth-child(3) { --feat-fallback: linear-gradient(135deg, #2c2c3a 0%, #111418 100%); }
.hero-feature:nth-child(4) { --feat-fallback: linear-gradient(135deg, #1C244B 0%, #1a1a2e 100%); }

/* Overlay oscuro permanente (gradiente de abajo) */
.hero-feature::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,.90) 0%,
    rgba(0,0,0,.45) 50%,
    rgba(0,0,0,.15) 100%
  );
  transition: background .4s ease;
  z-index: 1;
}

/* Overlay rojo en hover */
.hero-feature:hover::before {
  background: linear-gradient(
    to top,
    rgba(180,0,0,.95) 0%,
    rgba(213,0,0,.75) 45%,
    rgba(100,0,0,.45) 100%
  );
}

/* Escala suave de la imagen al hover */
.hero-feature::after {
  content: '';
  position: absolute;
  inset: 0;
  background: inherit;
  background-size: cover;
  background-position: center;
  transition: transform .55s cubic-bezier(.25,.46,.45,.94);
  z-index: 0;
}
.hero-feature:hover::after { transform: scale(1.06); }

.hero-feature-inner {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 18px 16px;
}

.hero-feature-icon {
  width: 34px;
  height: 34px;
  background: rgba(255,255,255,.18);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 9px;
  overflow: hidden;          /* impide que el SVG se desborde */
  transition: background .35s, transform .35s;
  flex-shrink: 0;
}
.hero-feature:hover .hero-feature-icon {
  background: rgba(255,255,255,.3);
  transform: translateY(-3px);
}
.hero-feature-icon svg {
  width: 17px;
  height: 17px;
  max-width: 17px;   /* tope duro para SVGs sin atrib. width */
  max-height: 17px;
  color: #fff;
  display: block;
  flex-shrink: 0;
}

.hero-feature h4 {
  font-family: var(--font-head);
  font-size: .88rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.3;
  margin-bottom: 0;
  text-shadow: 0 1px 4px rgba(0,0,0,.6);
}

.hero-feature-desc {
  font-size: .74rem;
  color: rgba(255,255,255,.9);
  line-height: 1.5;
  margin: 0;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(6px);
  transition:
    max-height .42s ease,
    opacity    .35s ease,
    transform  .35s ease;
}
.hero-feature:hover .hero-feature-desc {
  max-height: 72px;
  opacity: 1;
  transform: translateY(0);
  margin-top: 6px;
}

/* Scroll indicator */
.hero-scroll {
  position: absolute;
  bottom: 36px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,.4);
  font-size: .7rem;
  letter-spacing: .15em;
  text-transform: uppercase;
}

.hero-scroll-line {
  width: 1px;
  height: 48px;
  background: linear-gradient(to bottom, rgba(213,0,0,.8), transparent);
  animation: scrollLine 1.8s infinite;
}

@keyframes scrollLine {
  0% { transform: scaleY(0); transform-origin: top; }
  50% { transform: scaleY(1); transform-origin: top; }
  50.01% { transform: scaleY(1); transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

/* =========================================
   TICKER / BANDA DE CARACTERÍSTICAS
   ========================================= */
.ticker-band {
  background: var(--color-primary);
  padding: 14px 0;
  overflow: hidden;
}

.ticker-inner {
  display: flex;
  gap: 48px;
  animation: ticker 25s linear infinite;
  width: max-content;
}

.ticker-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-head);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-white);
  white-space: nowrap;
}
.ticker-item svg { width: 14px; height: 14px; flex-shrink: 0; }
.ticker-dot { width: 4px; height: 4px; background: rgba(255,255,255,.4); border-radius: 50%; }

@keyframes ticker {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* =========================================
   PRODUCTOS
   ========================================= */
.productos { padding: var(--section-pad); background: var(--color-white); }

.productos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.producto-card {
  border-radius: 10px;
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: var(--transition);
  background: var(--color-white);
  border: 1px solid rgba(0,0,0,.06);
  display: flex;
  flex-direction: column;
}

.producto-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-6px);
}

.producto-img {
  position: relative;
  height: 210px;
  overflow: hidden;
  background: var(--color-dark);
}

.producto-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
}

.producto-card:hover .producto-img img { transform: scale(1.08); }

.producto-category {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--color-primary);
  color: white;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 2px;
}

.producto-img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-dark) 0%, var(--color-gray) 100%);
}

.producto-img-placeholder svg { width: 64px; height: 64px; color: rgba(255,255,255,.15); }

.producto-body {
  padding: 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.producto-body h3 {
  font-size: 1.1rem;
  color: var(--color-dark-2);
  margin-bottom: 10px;
}

.producto-body p {
  font-size: .85rem;
  color: var(--color-text-light);
  line-height: 1.6;
  flex: 1;
  margin-bottom: 18px;
}

.producto-features {
  margin-bottom: 20px;
}

.producto-feature {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .8rem;
  color: var(--color-text-light);
  padding: 4px 0;
}

.producto-feature::before {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--color-primary);
  border-radius: 50%;
  flex-shrink: 0;
}

.producto-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-head);
  font-size: .8rem;
  font-weight: 700;
  color: var(--color-primary);
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-top: auto;
  transition: var(--transition);
}
.producto-link svg { width: 14px; height: 14px; transition: transform .25s; }
.producto-card:hover .producto-link svg { transform: translateX(5px); }

/* =========================================
   NOSOTROS / ABOUT
   ========================================= */
.nosotros {
  padding: 120px 0;
  background: var(--color-gray-light);
  overflow: hidden;
}

.nosotros-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.nosotros-img-wrap {
  position: relative;
}

.nosotros-img-main {
  border-radius: 10px;
  overflow: hidden;
  box-shadow: var(--shadow);
  height: 480px;
  background: var(--color-dark);
}

.nosotros-img-main img { width: 100%; height: 100%; object-fit: cover; }

.nosotros-img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-dark-3) 0%, var(--color-dark-2) 100%);
}

.nosotros-img-placeholder svg { width: 80px; height: 80px; color: rgba(255,255,255,.1); }

.nosotros-badge {
  position: absolute;
  bottom: -24px;
  right: -24px;
  background: var(--color-primary);
  color: white;
  border-radius: 10px;
  padding: 24px 28px;
  text-align: center;
  box-shadow: 0 8px 32px rgba(213,0,0,.4);
}

.nosotros-badge-num {
  font-size: 2.8rem;
  font-weight: 800;
  line-height: 1;
  font-family: var(--font-head);
}
.nosotros-badge-label { font-size: .75rem; opacity: .85; text-transform: uppercase; letter-spacing: .1em; margin-top: 4px; }

.nosotros-content { padding-right: 20px; }

.nosotros-list { margin: 28px 0; display: flex; flex-direction: column; gap: 16px; }

.nosotros-list-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.nosotros-list-icon {
  width: 38px;
  height: 38px;
  background: rgba(213,0,0,.1);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}
.nosotros-list-icon svg { width: 18px; height: 18px; color: var(--color-primary); }

.nosotros-list-text h4 { font-size: .95rem; color: var(--color-dark-2); margin-bottom: 3px; }
.nosotros-list-text p { font-size: .82rem; color: var(--color-text-light); margin: 0; }

.nosotros-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 36px;
  padding-top: 36px;
  border-top: 1px solid rgba(0,0,0,.08);
}

.nosotros-stat { text-align: center; }
.nosotros-stat-num {
  font-family: var(--font-head);
  font-size: 2rem;
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
}
.nosotros-stat-label {
  font-size: .72rem;
  color: var(--color-text-light);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-top: 5px;
}

/* =========================================
   SERVICIOS
   ========================================= */
.servicios {
  padding: var(--section-pad);
  background: var(--color-dark);
  position: relative;
  overflow: hidden;
}

.servicios::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--color-primary), transparent);
}

.servicios .section-title { color: var(--color-white); }
.servicios .section-subtitle { color: rgba(255,255,255,.6); }
.servicios .section-tag { background: rgba(213,0,0,.2); }

.servicios-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.servicio-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px;
  padding: 32px 24px;
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}

.servicio-card::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--color-primary);
  transform: scaleX(0);
  transition: transform .35s ease;
}

.servicio-card:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(213,0,0,.3);
  transform: translateY(-5px);
}
.servicio-card:hover::before { transform: scaleX(1); }

.servicio-icon {
  width: 56px;
  height: 56px;
  background: rgba(213,0,0,.15);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  transition: var(--transition);
}
.servicio-card:hover .servicio-icon { background: rgba(213,0,0,.25); }
.servicio-icon svg { width: 26px; height: 26px; color: var(--color-primary); }

.servicio-card h3 { color: var(--color-white); font-size: 1rem; margin-bottom: 12px; }
.servicio-card p { font-size: .83rem; color: rgba(255,255,255,.55); line-height: 1.7; margin: 0; }

/* =========================================
   PROCESO EN 3 PASOS
   ========================================= */
.proceso { padding: var(--section-pad); background: var(--color-white); }

.proceso-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  position: relative;
}

.proceso-steps::before {
  content: '';
  position: absolute;
  top: 48px;
  left: calc(16.67% + 48px);
  right: calc(16.67% + 48px);
  height: 2px;
  background: linear-gradient(90deg, var(--color-primary), rgba(213,0,0,.3));
  z-index: 0;
}

.paso {
  text-align: center;
  padding: 40px 32px;
  position: relative;
  z-index: 1;
  transition: var(--transition);
}
.paso:hover { transform: translateY(-5px); }

.paso-num {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  background: var(--color-white);
  border: 3px solid var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 28px;
  font-family: var(--font-head);
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--color-primary);
  position: relative;
  box-shadow: 0 0 0 8px rgba(213,0,0,.06);
  transition: var(--transition);
}

.paso:hover .paso-num {
  background: var(--color-primary);
  color: white;
  box-shadow: 0 0 0 8px rgba(213,0,0,.15);
}

.paso-icon {
  position: absolute;
  bottom: -8px;
  right: -8px;
  width: 28px;
  height: 28px;
  background: var(--color-primary);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.paso-icon svg { width: 14px; height: 14px; color: white; }

.paso h3 { font-size: 1.2rem; margin-bottom: 12px; color: var(--color-dark-2); }
.paso p { font-size: .85rem; color: var(--color-text-light); line-height: 1.7; margin: 0; }

/* =========================================
   CLIENTES / LOGOS
   ========================================= */
.clientes {
  padding: 60px 0;
  background: var(--color-gray-light);
  border-top: 1px solid rgba(0,0,0,.06);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.clientes .section-header { margin-bottom: 40px; }

.clientes-logos {
  display: flex;
  gap: 32px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
}

.cliente-logo {
  background: var(--color-white);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--radius);
  padding: 16px 24px;
  filter: grayscale(1);
  opacity: .55;
  transition: var(--transition);
  min-width: 130px;
  max-width: 180px;
  text-align: center;
  font-family: var(--font-head);
  font-size: .88rem;
  font-weight: 700;
  color: var(--color-dark-2);
  letter-spacing: .05em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cliente-logo:hover { filter: grayscale(0); opacity: 1; transform: translateY(-3px); box-shadow: var(--shadow); }

/* Imágenes de logo desde /images/clientes/ */
.cliente-logo img {
  max-height: 44px;
  width: auto;
  max-width: 130px;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

/* =========================================
   TESTIMONIOS
   ========================================= */
.testimonios { padding: var(--section-pad); background: var(--color-white); }

.testimonios-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.testimonio-card {
  background: var(--color-gray-light);
  border-radius: 10px;
  padding: 32px 28px;
  border: 1px solid rgba(0,0,0,.05);
  transition: var(--transition);
  position: relative;
}

.testimonio-card:hover { box-shadow: var(--shadow); transform: translateY(-4px); }

.testimonio-stars {
  display: flex;
  gap: 4px;
  margin-bottom: 18px;
}
.testimonio-stars svg { width: 16px; height: 16px; color: #FFB800; fill: #FFB800; }

.testimonio-card p {
  font-size: .9rem;
  color: var(--color-text-light);
  line-height: 1.75;
  font-style: italic;
  margin-bottom: 24px;
}

.testimonio-author {
  display: flex;
  align-items: center;
  gap: 12px;
}

.testimonio-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-head);
  font-size: .9rem;
  font-weight: 700;
  color: white;
  flex-shrink: 0;
}

.testimonio-info h4 { font-size: .88rem; color: var(--color-dark-2); margin-bottom: 2px; }
.testimonio-info span { font-size: .75rem; color: var(--color-text-light); }

.testimonio-quote {
  position: absolute;
  top: 20px;
  right: 24px;
  font-size: 4rem;
  line-height: 1;
  color: rgba(213,0,0,.1);
  font-family: Georgia, serif;
  font-weight: 900;
}

/* =========================================
   BLOG
   ========================================= */
.blog { padding: var(--section-pad); background: var(--color-gray-light); }

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.blog-card {
  background: var(--color-white);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: var(--transition);
  border: 1px solid rgba(0,0,0,.05);
}

.blog-card:hover { box-shadow: var(--shadow-hover); transform: translateY(-5px); }

.blog-img {
  height: 200px;
  overflow: hidden;
  background: var(--color-dark);
  position: relative;
}

.blog-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.blog-card:hover .blog-img img { transform: scale(1.07); }

.blog-img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-dark-3), var(--color-gray));
}
.blog-img-placeholder svg { width: 48px; height: 48px; color: rgba(255,255,255,.1); }

.blog-cat {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--color-primary);
  color: white;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 2px;
}

.blog-body { padding: 24px; }

.blog-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: .72rem;
  color: var(--color-text-light);
  margin-bottom: 12px;
}
.blog-meta svg { width: 12px; height: 12px; }

.blog-body h3 {
  font-size: 1rem;
  margin-bottom: 10px;
  color: var(--color-dark-2);
  line-height: 1.4;
}
.blog-card:hover h3 { color: var(--color-primary); }

.blog-body p { font-size: .82rem; color: var(--color-text-light); line-height: 1.6; margin-bottom: 18px; }

.blog-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  font-weight: 700;
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.blog-link svg { width: 13px; height: 13px; transition: transform .25s; }
.blog-card:hover .blog-link svg { transform: translateX(4px); }

/* =========================================
   SECCIÓN CTA CENTRAL
   ========================================= */
.cta-band {
  padding: 100px 0;
  background:
    linear-gradient(135deg, rgba(17,20,24,.92) 0%, rgba(28,36,75,.88) 100%),
    url('assets/cta-bg.jpg') center/cover no-repeat;
  position: relative;
  overflow: hidden;
  text-align: center;
}

.cta-band::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(213,0,0,.18) 0%, transparent 65%);
}

.cta-band .container { position: relative; z-index: 1; }

.cta-band h2 {
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--color-white);
  margin-bottom: 18px;
}
.cta-band h2 span { color: var(--color-primary); }

.cta-band p {
  font-size: 1.05rem;
  color: rgba(255,255,255,.7);
  max-width: 560px;
  margin: 0 auto 36px;
}

.cta-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* =========================================
   CONTACTO
   ========================================= */
.contacto { padding: var(--section-pad); background: var(--color-white); }

.contacto-inner {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 64px;
  align-items: start;
}

.contacto-info h2 { margin-bottom: 18px; }

.contacto-info > p {
  color: var(--color-text-light);
  line-height: 1.75;
  margin-bottom: 36px;
}

.contacto-details { display: flex; flex-direction: column; gap: 20px; }

.contacto-detail {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.contacto-detail-icon {
  width: 46px;
  height: 46px;
  background: rgba(213,0,0,.08);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.contacto-detail-icon svg { width: 20px; height: 20px; color: var(--color-primary); }

.contacto-detail-text h4 { font-size: .9rem; color: var(--color-dark-2); margin-bottom: 3px; }
.contacto-detail-text p, .contacto-detail-text a {
  font-size: .85rem;
  color: var(--color-text-light);
  margin: 0;
}
.contacto-detail-text a:hover { color: var(--color-primary); }

/* Formulario */
.contacto-form {
  background: var(--color-gray-light);
  border-radius: 10px;
  padding: 40px;
  border: 1px solid rgba(0,0,0,.05);
}

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

.form-group { margin-bottom: 20px; }

.form-group label {
  display: block;
  font-family: var(--font-head);
  font-size: .78rem;
  font-weight: 600;
  color: var(--color-dark-2);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 13px 16px;
  font-family: var(--font-body);
  font-size: .88rem;
  color: var(--color-text);
  background: var(--color-white);
  border: 1.5px solid rgba(0,0,0,.12);
  border-radius: var(--radius);
  transition: var(--transition);
  outline: none;
  appearance: none;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(213,0,0,.1);
}

.form-group textarea { resize: vertical; min-height: 130px; }

.form-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 24px;
}

.form-check input[type="checkbox"] {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-top: 2px;
  accent-color: var(--color-primary);
  cursor: pointer;
}

.form-check label {
  font-size: .8rem;
  color: var(--color-text-light);
  cursor: pointer;
  line-height: 1.5;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}
.form-check label a { color: var(--color-primary); }

/* =========================================
   FOOTER
   ========================================= */
.site-footer {
  background: var(--color-dark);
  color: rgba(255,255,255,.65);
  font-size: .85rem;
}

.footer-top { padding: 72px 0 48px; }

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: 48px;
}

.footer-brand { padding-right: 16px; }

.footer-brand .site-logo { margin-bottom: 20px; }

.footer-brand p {
  font-size: .85rem;
  line-height: 1.75;
  color: rgba(255,255,255,.5);
  margin-bottom: 24px;
}

.footer-social {
  display: flex;
  gap: 10px;
}

.footer-social-link {
  width: 36px;
  height: 36px;
  background: rgba(255,255,255,.06);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.5);
  transition: var(--transition);
}
.footer-social-link:hover { background: var(--color-primary); color: white; }
.footer-social-link svg { width: 16px; height: 16px; }

.footer-col h4 {
  font-family: var(--font-head);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.footer-links { display: flex; flex-direction: column; gap: 10px; }

.footer-link {
  color: rgba(255,255,255,.5);
  font-size: .83rem;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: var(--transition);
}
.footer-link::before { content: '›'; color: var(--color-primary); font-size: 1rem; }
.footer-link:hover { color: var(--color-white); padding-left: 4px; }

.footer-contact-item {
  display: flex;
  gap: 12px;
  margin-bottom: 14px;
  align-items: flex-start;
}
.footer-contact-item svg { width: 16px; height: 16px; color: var(--color-primary); flex-shrink: 0; margin-top: 2px; }
.footer-contact-item span { color: rgba(255,255,255,.5); font-size: .83rem; line-height: 1.5; }
.footer-contact-item a { color: rgba(255,255,255,.5); }
.footer-contact-item a:hover { color: var(--color-white); }

.footer-divider {
  height: 1px;
  background: rgba(255,255,255,.06);
  margin: 0 24px;
}

.footer-bottom { padding: 20px 0; }

.footer-bottom .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.footer-bottom p {
  font-size: .78rem;
  color: rgba(255,255,255,.35);
  margin: 0;
}

.footer-bottom a { color: var(--color-primary); }

.footer-legal {
  display: flex;
  gap: 20px;
}

.footer-legal a {
  font-size: .75rem;
  color: rgba(255,255,255,.3);
  transition: var(--transition);
}
.footer-legal a:hover { color: rgba(255,255,255,.7); }

/* =========================================
   BACK TO TOP
   ========================================= */
.back-top {
  position: fixed;
  bottom: 32px;
  right: 32px;
  width: 44px;
  height: 44px;
  background: var(--color-primary);
  color: white;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: var(--transition);
  box-shadow: 0 4px 16px rgba(213,0,0,.4);
  cursor: pointer;
  border: none;
}
.back-top.visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-top:hover { background: var(--color-primary-dark); transform: translateY(-3px); }
.back-top svg { width: 20px; height: 20px; }

/* =========================================
   MOBILE OVERLAY MENU
   ========================================= */
.mobile-menu {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--color-dark);
  z-index: 999;
  padding: 90px 24px 40px;
  overflow-y: auto;
  transform: translateX(-100%);
  transition: transform .4s cubic-bezier(.25,.46,.45,.94);
}

.mobile-menu.open { transform: translateX(0); }

.mobile-nav-link {
  display: block;
  padding: 14px 0;
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 600;
  color: rgba(255,255,255,.8);
  border-bottom: 1px solid rgba(255,255,255,.07);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.mobile-nav-link:hover { color: var(--color-primary); padding-left: 8px; }

.mobile-cta { margin-top: 32px; }

/* =========================================
   RESPONSIVE
   ========================================= */
@media (max-width: 1100px) {
  .servicios-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}

@media (max-width: 900px) {
  :root { --section-pad: 64px 0; }

  .header-top { display: none; }

  .site-nav,
  .header-cta .btn,
  .header-phone { display: none; }

  .hamburger { display: flex; }

  .hero-content { grid-template-columns: 1fr; gap: 40px; padding: 60px 24px; }
  .hero-features { display: none; }
  .hero-stats { gap: 20px; }

  .nosotros-inner { grid-template-columns: 1fr; gap: 40px; }
  .nosotros-img-wrap { max-height: 360px; }
  .nosotros-img-main { height: 360px; }
  .nosotros-badge { bottom: -16px; right: 16px; }
  .nosotros-content { padding-right: 0; }

  .productos-grid { grid-template-columns: 1fr 1fr; }

  .proceso-steps { grid-template-columns: 1fr; }
  .proceso-steps::before { display: none; }

  .testimonios-grid { grid-template-columns: 1fr 1fr; }

  .blog-grid { grid-template-columns: 1fr 1fr; }

  .contacto-inner { grid-template-columns: 1fr; gap: 40px; }

  .footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 600px) {
  :root { --section-pad: 48px 0; }

  .productos-grid { grid-template-columns: 1fr; }
  .servicios-grid { grid-template-columns: 1fr; }
  .testimonios-grid { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }

  .hero-stats { flex-direction: column; gap: 16px; }
  .nosotros-stats { grid-template-columns: 1fr 1fr; }

  .footer-bottom .container { flex-direction: column; text-align: center; }
  .footer-legal { flex-wrap: wrap; justify-content: center; }

  .back-top { bottom: 20px; right: 20px; }
}
/* =========================================
   PARCHE – quitar franja roja y asegurar visibilidad del contador
   Pegar al FINAL del archivo
   ========================================= */

/* 1) Quitar por completo la franja roja superior */
.header-top {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  background: transparent !important;
  border: 0 !important;
}

/* 2) Asegurar que no quede ninguna línea roja ni borde encima del header */
body .site-header,
body #masthead,
body #site-header,
body .site-header::before,
body .site-header::after,
body #masthead::before,
body #masthead::after,
body #site-header::before,
body #site-header::after {
  border-top: 0 !important;
  outline: 0 !important;
  box-shadow: none;
}

/* 3) Recolocar el header principal si el tema dejaba hueco para la banda superior */
.site-header,
#masthead,
#site-header {
  top: 0 !important;
}

/* 4) Hacer que los bloques de estadísticas / contador se vean aunque falle la animación JS */
.hero-stats,
.hero-stat,
.hero-stat-num,
.hero-stat-label {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* 5) Si algún contador lleva data-aos, que no se quede oculto */
.hero-stats [data-aos],
.hero-stat [data-aos],
.hero-stat-num[data-aos],
.hero-stat-label[data-aos] {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* 6) Evitar saltos raros en la zona del hero por el cambio del header */
.hero {
  padding-top: 90px;
}
/* =========================================
   PARCHE – dar más aire a la sección NOSOTROS
   Pegar al FINAL del archivo
   ========================================= */

.nosotros {
  padding: 140px 0 !important;
}

.nosotros-inner {
  grid-template-columns: minmax(420px, 1fr) minmax(520px, 1.15fr) !important;
  gap: 110px !important;
  align-items: start !important;
}

.nosotros-img-wrap {
  padding-right: 10px;
}

.nosotros-content {
  padding-right: 0 !important;
  padding-left: 18px !important;
}

.nosotros .section-header,
.nosotros-content > p {
  max-width: 760px;
}

.nosotros .section-title {
  margin-bottom: 22px !important;
  line-height: 1.08 !important;
}

.nosotros-content > p {
  font-size: 1.08rem;
  line-height: 1.9;
  margin-bottom: 34px;
}

.nosotros-list {
  margin: 36px 0 0 !important;
  gap: 24px !important;
}

.nosotros-list-item {
  gap: 18px !important;
}

.nosotros-list-text h4 {
  margin-bottom: 8px !important;
}

.nosotros-list-text p {
  line-height: 1.75 !important;
}

.nosotros-stats {
  margin-top: 46px !important;
  padding-top: 42px !important;
  gap: 32px !important;
}

.nosotros-stat {
  text-align: left !important;
}

.nosotros-stat-label {
  margin-top: 10px !important;
  line-height: 1.5;
}

/* Ajuste tablet */
@media (max-width: 1024px) {
  .nosotros-inner {
    gap: 70px !important;
    grid-template-columns: 1fr 1fr !important;
  }

  .nosotros-content {
    padding-left: 0 !important;
  }
}

/* Ajuste móvil */
@media (max-width: 900px) {
  .nosotros {
    padding: 90px 0 !important;
  }

  .nosotros-inner {
    grid-template-columns: 1fr !important;
    gap: 42px !important;
  }

  .nosotros-img-wrap {
    padding-right: 0;
  }

  .nosotros-content {
    padding-left: 0 !important;
  }

  .nosotros .section-title {
    margin-bottom: 18px !important;
  }

  .nosotros-content > p {
    font-size: 1rem;
    line-height: 1.8;
  }

  .nosotros-stats {
    gap: 22px !important;
  }
}
/* =========================================
   PARCHE – dar más aire a la sección NOSOTROS
   Pegar al FINAL del archivo
   ========================================= */

.nosotros {
  padding: 140px 0 !important;
}

.nosotros-inner {
  grid-template-columns: minmax(420px, 1fr) minmax(520px, 1.15fr) !important;
  gap: 110px !important;
  align-items: start !important;
}

.nosotros-img-wrap {
  padding-right: 10px;
}

.nosotros-content {
  padding-right: 0 !important;
  padding-left: 18px !important;
}

.nosotros .section-header,
.nosotros-content > p {
  max-width: 760px;
}

.nosotros .section-title {
  margin-bottom: 22px !important;
  line-height: 1.08 !important;
}

.nosotros-content > p {
  font-size: 1.08rem;
  line-height: 1.9;
  margin-bottom: 34px;
}

.nosotros-list {
  margin: 36px 0 0 !important;
  gap: 24px !important;
}

.nosotros-list-item {
  gap: 18px !important;
}

.nosotros-list-text h4 {
  margin-bottom: 8px !important;
}

.nosotros-list-text p {
  line-height: 1.75 !important;
}

.nosotros-stats {
  margin-top: 46px !important;
  padding-top: 42px !important;
  gap: 32px !important;
}

.nosotros-stat {
  text-align: left !important;
}

.nosotros-stat-label {
  margin-top: 10px !important;
  line-height: 1.5;
}

/* Ajuste tablet */
@media (max-width: 1024px) {
  .nosotros-inner {
    gap: 70px !important;
    grid-template-columns: 1fr 1fr !important;
  }

  .nosotros-content {
    padding-left: 0 !important;
  }
}

/* Ajuste móvil */
@media (max-width: 900px) {
  .nosotros {
    padding: 90px 0 !important;
  }

  .nosotros-inner {
    grid-template-columns: 1fr !important;
    gap: 42px !important;
  }

  .nosotros-img-wrap {
    padding-right: 0;
  }

  .nosotros-content {
    padding-left: 0 !important;
  }

  .nosotros .section-title {
    margin-bottom: 18px !important;
  }

  .nosotros-content > p {
    font-size: 1rem;
    line-height: 1.8;
  }

  .nosotros-stats {
    gap: 22px !important;
  }
}
/* CTA BAND – asegurar visibilidad de botones */
.cta-band .btn {
  display: inline-flex !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.cta-band .btn-primary {
  background: #D50000 !important;
  color: #FFFFFF !important;
  border-color: #D50000 !important;
}

.cta-band .btn-outline {
  background: transparent !important;
  color: #FFFFFF !important;
  border: 2px solid rgba(255,255,255,.75) !important;
}

.cta-band .btn-outline:hover {
  background: #FFFFFF !important;
  color: #111418 !important;
  border-color: #FFFFFF !important;
}
/* =========================================
   PARCHE MÓVIL – NOSOTROS + CONTACTO
   Pegar al FINAL del style.css
   ========================================= */

/* ---------- TABLET ---------- */
@media (max-width: 1024px) {
  .nosotros {
    padding: 90px 0 !important;
  }

  .nosotros-inner {
    grid-template-columns: 1fr !important;
    gap: 54px !important;
    align-items: start !important;
  }

  .nosotros-img-wrap {
    max-width: 100%;
    margin: 0 auto;
  }

  .nosotros-img-main {
    height: 420px !important;
    border-radius: 14px !important;
    overflow: hidden;
  }

  .nosotros-img-main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .nosotros-badge {
    right: 18px !important;
    bottom: -18px !important;
    padding: 16px 18px !important;
  }

  .nosotros-content {
    padding: 0 !important;
  }

  .nosotros .section-title {
    line-height: 1.1 !important;
    margin-bottom: 18px !important;
  }

  .nosotros-content > p {
    font-size: 1rem !important;
    line-height: 1.85 !important;
    margin-bottom: 28px !important;
  }

  .nosotros-list {
    gap: 18px !important;
  }

  .nosotros-list-item {
    gap: 14px !important;
    align-items: flex-start !important;
  }

  .nosotros-list-text p {
    line-height: 1.7 !important;
  }

  .nosotros-stats {
    gap: 18px !important;
    margin-top: 32px !important;
    padding-top: 28px !important;
  }

  .contacto {
    padding: 90px 0 !important;
  }

  .contacto-inner {
    grid-template-columns: 1fr !important;
    gap: 38px !important;
  }

  .contacto-form {
    padding: 28px !important;
  }
}

/* ---------- MÓVIL ---------- */
@media (max-width: 767px) {
  .nosotros {
    padding: 72px 0 !important;
  }

  .nosotros-inner {
    gap: 38px !important;
  }

  .nosotros-img-wrap {
    max-height: none !important;
  }

  .nosotros-img-main {
    height: 300px !important;
    border-radius: 12px !important;
  }

  .nosotros-badge {
    position: absolute;
    right: 12px !important;
    bottom: 12px !important;
    padding: 12px 14px !important;
    border-radius: 10px !important;
    max-width: 150px;
  }

  .nosotros-badge-num {
    font-size: 1.45rem !important;
    line-height: 1 !important;
  }

  .nosotros-badge-label {
    font-size: .72rem !important;
    line-height: 1.35 !important;
  }

  .nosotros-content {
    padding: 0 !important;
  }

  .nosotros .section-tag {
    margin-bottom: 12px !important;
  }

  .nosotros .section-title {
    font-size: clamp(1.8rem, 7vw, 2.3rem) !important;
    line-height: 1.08 !important;
    margin-bottom: 16px !important;
  }

  .nosotros-content > p {
    font-size: .98rem !important;
    line-height: 1.8 !important;
    margin-bottom: 24px !important;
  }

  .nosotros-list {
    margin-top: 0 !important;
    gap: 16px !important;
  }

  .nosotros-list-item {
    gap: 12px !important;
  }

  .nosotros-list-icon {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
  }

  .nosotros-list-text h4 {
    font-size: .95rem !important;
    margin-bottom: 4px !important;
  }

  .nosotros-list-text p {
    font-size: .9rem !important;
    line-height: 1.65 !important;
  }

  .nosotros-stats {
    grid-template-columns: 1fr 1fr !important;
    gap: 14px !important;
    margin-top: 26px !important;
    padding-top: 22px !important;
  }

  .nosotros-stat {
    padding: 14px 12px !important;
    border-radius: 10px !important;
    background: #fff;
    border: 1px solid rgba(0,0,0,.06);
    text-align: center !important;
  }

  .nosotros-stat-num {
    font-size: 1.45rem !important;
    line-height: 1.05 !important;
  }

  .nosotros-stat-label {
    font-size: .74rem !important;
    line-height: 1.4 !important;
    margin-top: 6px !important;
  }

  .nosotros-content > div[style*="margin-top:36px"] {
    margin-top: 26px !important;
    gap: 10px !important;
  }

  .nosotros-content > div[style*="margin-top:36px"] .btn {
    width: 100%;
    justify-content: center;
  }

  .contacto {
    padding: 72px 0 !important;
  }

  .contacto-inner {
    gap: 28px !important;
  }

  .contacto .section-title {
    font-size: clamp(1.8rem, 7vw, 2.3rem) !important;
    line-height: 1.08 !important;
    margin-bottom: 14px !important;
  }

  .contacto-details {
    gap: 14px !important;
    margin-top: 24px !important;
  }

  .contacto-detail {
    gap: 12px !important;
    padding: 14px !important;
    background: #fff !important;
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 10px;
  }

  .contacto-detail-icon {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
  }

  .contacto-detail-icon svg {
    width: 18px !important;
    height: 18px !important;
  }

  .contacto-detail-text h4 {
    font-size: .86rem !important;
    margin-bottom: 4px !important;
  }

  .contacto-detail-text p,
  .contacto-detail-text a {
    font-size: .9rem !important;
    line-height: 1.6 !important;
    word-break: break-word;
  }

  .contacto-form {
    padding: 20px !important;
    border-radius: 12px !important;
  }

  .contacto-form h3 {
    font-size: 1.2rem !important;
    line-height: 1.3 !important;
    margin-bottom: 18px !important;
  }

  .form-row {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }

  .form-group {
    margin-bottom: 16px !important;
  }

  .form-group label {
    font-size: .72rem !important;
    margin-bottom: 7px !important;
  }

  .form-group input,
  .form-group select,
  .form-group textarea {
    min-height: 48px;
    padding: 13px 14px !important;
    font-size: 16px !important; /* evita zoom en iPhone */
    border-radius: 10px !important;
  }

  .form-group textarea {
    min-height: 130px !important;
  }

  .form-check {
    gap: 10px !important;
    margin-bottom: 20px !important;
    align-items: flex-start !important;
  }

  .form-check input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    margin-top: 3px !important;
  }

  .form-check label {
    font-size: .85rem !important;
    line-height: 1.55 !important;
  }

  #idp-contact-form .btn[type="submit"] {
    min-height: 50px;
    font-size: .9rem !important;
  }

  #form-response {
    font-size: .84rem !important;
    line-height: 1.5 !important;
  }

  .contacto iframe {
    height: 280px !important;
  }

  .contacto div[style*="height:360px"] {
    height: 280px !important;
    margin-top: 36px !important;
    border-radius: 12px !important;
  }
}

/* ---------- MÓVIL PEQUEÑO ---------- */
@media (max-width: 480px) {
  .nosotros-img-main {
    height: 260px !important;
  }

  .nosotros-badge {
    max-width: 132px;
    padding: 10px 12px !important;
  }

  .nosotros-badge-num {
    font-size: 1.25rem !important;
  }

  .nosotros-stats {
    grid-template-columns: 1fr !important;
  }

  .contacto-form {
    padding: 16px !important;
  }

  .contacto-detail {
    padding: 12px !important;
  }

  .contacto iframe,
  .contacto div[style*="height:360px"] {
    height: 240px !important;
  }
}
/* =========================================
   CONTACTO – responsive fino móvil
   ========================================= */

@media (max-width: 900px) {
  .contacto-inner {
    grid-template-columns: 1fr !important;
    gap: 36px !important;
  }
}

@media (max-width: 767px) {
  .contacto {
    padding: 72px 0 !important;
  }

  .contacto .section-title {
    font-size: clamp(1.8rem, 7vw, 2.3rem) !important;
    line-height: 1.08 !important;
    margin-bottom: 14px !important;
  }

  .contacto-details {
    gap: 14px !important;
    margin-top: 24px !important;
  }

  .contacto-detail {
    gap: 12px !important;
    padding: 14px !important;
    background: #fff !important;
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 10px;
  }

  .contacto-detail-icon {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
  }

  .contacto-detail-text h4 {
    font-size: .86rem !important;
    margin-bottom: 4px !important;
  }

  .contacto-detail-text p,
  .contacto-detail-text a {
    font-size: .92rem !important;
    line-height: 1.6 !important;
    word-break: break-word;
  }

  .contacto-form {
    padding: 20px !important;
    border-radius: 12px !important;
  }

  .contacto-form h3 {
    font-size: 1.2rem !important;
    line-height: 1.3 !important;
    margin-bottom: 18px !important;
  }

  .form-row {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }

  .form-group {
    margin-bottom: 16px !important;
  }

  .form-group label {
    font-size: .74rem !important;
    margin-bottom: 7px !important;
  }

  .form-group input,
  .form-group select,
  .form-group textarea {
    width: 100%;
    min-height: 48px;
    padding: 13px 14px !important;
    font-size: 16px !important;
    border-radius: 10px !important;
  }

  .form-group textarea {
    min-height: 130px !important;
  }

  .form-check {
    gap: 10px !important;
    margin-bottom: 20px !important;
    align-items: flex-start !important;
  }

  .form-check input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    margin-top: 3px !important;
  }

  .form-check label {
    font-size: .85rem !important;
    line-height: 1.55 !important;
  }

  #idp-contact-form .btn[type="submit"] {
    min-height: 50px;
    font-size: .92rem !important;
  }

  .contacto iframe,
  .contacto div[style*="height:360px"] {
    height: 280px !important;
    margin-top: 36px !important;
    border-radius: 12px !important;
  }
}

@media (max-width: 480px) {
  .contacto-form {
    padding: 16px !important;
  }

  .contacto-detail {
    padding: 12px !important;
  }

  .contacto iframe,
  .contacto div[style*="height:360px"] {
    height: 240px !important;
  }
}
/* =========================================
   BACK TO TOP – versión premium
   ========================================= */

.back-top {
	position: fixed;
	bottom: 24px;
	right: 24px;
	z-index: 999;

	display: flex;
	align-items: center;
	gap: 8px;

	padding: 12px 16px;
	border-radius: 50px;

	background: linear-gradient(135deg, #1c244b, #d50000);
	color: #fff;

	border: none;
	cursor: pointer;

	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: .5px;

	box-shadow: 0 10px 30px rgba(0,0,0,.25);

	opacity: 0;
	visibility: hidden;
	transform: translateY(20px) scale(.95);

	transition: all .3s ease;
}

/* icono */
.back-top-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
}

/* hover */
.back-top:hover {
	transform: translateY(0) scale(1.05);
	box-shadow: 0 14px 40px rgba(0,0,0,.35);
}

/* visible cuando haces scroll */
.back-top.active {
	opacity: 1;
	visibility: visible;
	transform: translateY(0) scale(1);
}

/* versión móvil */
@media (max-width: 767px) {
	.back-top {
		bottom: 18px;
		right: 18px;
		padding: 12px;
		border-radius: 50%;
	}

	.back-top-text {
		display: none;
	}
}
/* =========================================
   BACK TO TOP – minimal arrow
   ========================================= */

.back-top {
	position: fixed;
	bottom: 32px;
	right: 32px;
	width: 44px;
	height: 44px;

	display: flex;
	align-items: center;
	justify-content: center;

	cursor: pointer;
	z-index: 999;

	opacity: 0;
	pointer-events: none;

	transition: opacity .3s ease;
}

/* círculo sutil */
.back-top::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	background: rgba(0,0,0,.05);
	backdrop-filter: blur(6px);
	transition: all .3s ease;
}

/* flecha */
.arrow {
	width: 10px;
	height: 10px;
	border-left: 2px solid #1c244b;
	border-top: 2px solid #1c244b;
	transform: rotate(45deg);
	position: relative;
	top: 2px;
}

/* hover elegante */
.back-top:hover::before {
	background: rgba(0,0,0,.08);
	transform: scale(1.1);
}

/* visible */
.back-top.active {
	opacity: 1;
	pointer-events: auto;
}

/* móvil */
@media (max-width: 767px) {
	.back-top {
		bottom: 20px;
		right: 20px;
		width: 40px;
		height: 40px;
	}
}
/* =========================================
   BACK TO TOP – flecha minimal
   ========================================= */

.back-top {
  position: fixed;
  right: 24px;
  bottom: 24px;
  width: 54px;
  height: 54px;
  border-radius: 14px;
  background: #d50000;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 9999;
  box-shadow: 0 10px 28px rgba(213, 0, 0, 0.22);
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
}

.back-top .arrow {
  width: 12px;
  height: 12px;
  display: block;
  border-left: 3px solid #ffffff;
  border-top: 3px solid #ffffff;
  transform: rotate(45deg);
  margin-top: 4px;
}

.back-top:hover {
  box-shadow: 0 14px 34px rgba(213, 0, 0, 0.28);
}

@media (max-width: 767px) {
  .back-top {
    right: 18px;
    bottom: 18px;
    width: 50px;
    height: 50px;
    border-radius: 12px;
  }

  .back-top .arrow {
    width: 11px;
    height: 11px;
    border-left-width: 3px;
    border-top-width: 3px;
  }
}
.back-top {
  position: fixed;
  right: 24px;
  bottom: 24px;
  width: 54px;
  height: 54px;
  border-radius: 14px;
  background: #d50000;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 9999;
  box-shadow: 0 10px 28px rgba(213, 0, 0, 0.22);
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  pointer-events: auto !important;
}

.back-top .arrow {
  width: 12px;
  height: 12px;
  display: block;
  border-left: 3px solid #ffffff;
  border-top: 3px solid #ffffff;
  transform: rotate(45deg);
  margin-top: 4px;
}
/* =========================================
   FIX HEADER – evitar que se haga inmenso
   ========================================= */

/* Quitamos cualquier crecimiento raro */
.site-header,
#site-header,
#masthead {
  height: auto !important;
  min-height: 0 !important;
}

/* Si no usas la banda superior, mejor fuera del flujo */
.header-top {
  display: none !important;
}

/* Header principal compacto y estable */
.header-main {
  padding: 14px 0 !important;
}

.header-main .container {
  min-height: 72px !important;
  display: flex;
  align-items: center;
}

/* Estado al hacer scroll */
.site-header.scrolled .header-main,
#site-header.scrolled .header-main {
  padding: 10px 0 !important;
}

.site-header.scrolled .header-main .container,
#site-header.scrolled .header-main .container {
  min-height: 64px !important;
}

/* Evitar que logo o CTA estiren el header */
.site-logo,
.header-cta,
.site-nav {
  min-height: 0 !important;
  align-self: center;
}

.logo-icon {
  width: 40px !important;
  height: 40px !important;
}

.logo-name {
  font-size: 1rem !important;
}

.logo-tagline {
  font-size: .62rem !important;
}

/* En móvil más compacto todavía */
@media (max-width: 767px) {
  .header-main {
    padding: 10px 0 !important;
  }

  .header-main .container {
    min-height: 60px !important;
  }

  .logo-icon {
    width: 36px !important;
    height: 36px !important;
  }

  .logo-name {
    font-size: .92rem !important;
  }

  .logo-tagline {
    font-size: .56rem !important;
  }
}
/* Mejorar bloque de accesos directos inferior */
.site-footer + div {
  background: #f7f7f7 !important;
  color: #666 !important;
  font-size: 13px !important;
  line-height: 1.8 !important;
  padding: 18px 24px !important;
  border-top: 1px solid rgba(0,0,0,.06) !important;
  max-width: 100% !important;
}

.site-footer + div a,
.site-footer + div {
  text-align: center !important;
}
/* =========================================
   FOOTER SEO LINKS
   ========================================= */

.footer-seo {
  background: #f7f7f7;
  border-top: 1px solid rgba(0,0,0,.06);
  padding: 16px 0;
}

.footer-seo-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 13px;
  line-height: 1.7;
}

.footer-seo-label {
  font-weight: 700;
  color: #222;
}

.footer-seo a {
  color: #666;
  text-decoration: none;
  transition: color .2s ease;
}

.footer-seo a:hover {
  color: #d50000;
}

@media (max-width: 767px) {
  .footer-seo {
    padding: 14px 0;
  }

  .footer-seo-inner {
    font-size: 12px;
    gap: 8px 10px;
  }

  .footer-seo-label {
    width: 100%;
    margin-bottom: 2px;
  }
}
.header-main .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: nowrap;
}

.site-logo {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

.site-logo img {
	max-height: 48px;
	width: auto;
}

.site-nav {
	flex: 1;
}

.nav-menu {
	display: flex;
	align-items: center;
	gap: 20px;
	white-space: nowrap;
	margin: 0;
	padding: 0;
	list-style: none;
}

.header-cta {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-shrink: 0;
}

.nav-link,
.header-phone,
.btn {
	white-space: nowrap;
}
.page-cta-strip .btn,
.page-cta-strip a.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none;
}

.page-cta-strip .btn:first-child:hover {
  background: rgba(255,255,255,.92) !important;
  color: var(--color-primary) !important;
  border-color: rgba(255,255,255,.92) !important;
}

.page-cta-strip .btn:last-child:hover {
  background: #fff !important;
  color: var(--color-primary) !important;
  border-color: #fff !important;
}
/* Ajuste para que WhatsApp no se solape con el botón scroll */
.wa-float{
	bottom: 110px !important;
}

/* En móvil un poco menos de separación */
@media (max-width: 600px){
	.wa-float{
		bottom: 90px !important;
	}
}
/* =========================
   FOOTER PRO Y ORDENADO
   ========================= */

.site-footer .footer-grid{
	display:grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap:48px;
	align-items:start;
}

.site-footer .footer-brand{
	display:flex;
	flex-direction:column;
	align-items:flex-start;
	justify-content:flex-start;
}

.site-footer .footer-logo{
	display:block;
	margin-bottom:22px;
}

.site-footer .footer-logo img{
	display:block;
	height:220px !important;
	max-height:none !important;
	width:auto !important;
	max-width:100% !important;
	object-fit:contain;
}

/* Títulos columnas */
.site-footer .footer-col h4{
	text-align:center;
	margin-bottom:20px;
	font-size:1.1rem;
	font-weight:700;
	letter-spacing:.02em;
}

/* Listados centrados */
.site-footer .footer-links{
	list-style:none;
	margin:0;
	padding:0;
	text-align:center;
}

.site-footer .footer-links li{
	margin-bottom:12px;
}

.site-footer .footer-link{
	display:inline-block;
	text-decoration:none;
}

/* Columna de contacto centrada */
.site-footer .footer-col:last-child{
	text-align:center;
}

.site-footer .footer-contact-item{
	display:flex;
	align-items:flex-start;
	justify-content:center;
	gap:10px;
	margin-bottom:16px;
	text-align:left;
}

.site-footer .footer-contact-item svg{
	flex-shrink:0;
	margin-top:3px;
}

/* Texto de marca algo más elegante */
.site-footer .footer-brand p{
	max-width:520px;
	line-height:1.8;
	font-size:1.05rem;
	opacity:.9;
}

/* Footer bottom ordenado */
.site-footer .footer-bottom .container{
	display:flex;
	align-items:center;
	justify-content:space-between;
	gap:24px;
	flex-wrap:wrap;
}

.site-footer .footer-legal{
	display:flex;
	flex-wrap:wrap;
	gap:18px;
	justify-content:center;
}

/* Responsive */
@media (max-width: 1200px){
	.site-footer .footer-grid{
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 768px){
	.site-footer .footer-grid{
		grid-template-columns: 1fr;
		gap:34px;
	}

	.site-footer .footer-brand{
		align-items:center;
		text-align:center;
	}

	.site-footer .footer-logo img{
		height:160px !important;
	}

	.site-footer .footer-brand p{
		max-width:100%;
	}

	.site-footer .footer-contact-item{
		justify-content:center;
	}
}
.site-footer .footer-col:last-child{
	text-align:left !important;
	align-items:flex-start !important;
}

.site-footer .footer-col:last-child h4{
	text-align:left !important;
	width:100%;
}

.site-footer .footer-col:last-child .footer-contact-item{
	justify-content:flex-start !important;
	text-align:left !important;
	width:100%;
}

.site-footer .footer-col:last-child .footer-contact-item span,
.site-footer .footer-col:last-child .footer-contact-item a{
	text-align:left !important;
}
/* CHECKS FIJOS EN PÁGINAS DE SERVICIOS */
.page-template-page-instalacion .service-item,
.page-template-page-mantenimiento .service-item,
.page-template-page-reparaciones .service-item,
.page-template-page-automatizaciones .service-item,
.page-template-page-abrigos-de-muelle .service-item,
.page-template-page-accesorios-muelle .service-item,
.page-template-page-muelles-de-carga .service-item,
.page-template-page-puertas-rapidas .service-item,
.page-template-page-puertas-industriales .service-item,
.page-template-page-puertas-cortafuegos .service-item {
    display: flex;
    align-items: center;
    gap: 14px;
}

.page-template-page-instalacion .service-item .icon,
.page-template-page-mantenimiento .service-item .icon,
.page-template-page-reparaciones .service-item .icon,
.page-template-page-automatizaciones .service-item .icon,
.page-template-page-abrigos-de-muelle .service-item .icon,
.page-template-page-accesorios-muelle .service-item .icon,
.page-template-page-muelles-de-carga .service-item .icon,
.page-template-page-puertas-rapidas .service-item .icon,
.page-template-page-puertas-industriales .service-item .icon,
.page-template-page-puertas-cortafuegos .service-item .icon {
    width: 46px;
    min-width: 46px;
    max-width: 46px;
    height: 46px;
    min-height: 46px;
    max-height: 46px;
    flex: 0 0 46px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.page-template-page-instalacion .service-item .icon img,
.page-template-page-mantenimiento .service-item .icon img,
.page-template-page-reparaciones .service-item .icon img,
.page-template-page-automatizaciones .service-item .icon img,
.page-template-page-abrigos-de-muelle .service-item .icon img,
.page-template-page-accesorios-muelle .service-item .icon img,
.page-template-page-muelles-de-carga .service-item .icon img,
.page-template-page-puertas-rapidas .service-item .icon img,
.page-template-page-puertas-industriales .service-item .icon img,
.page-template-page-puertas-cortafuegos .service-item .icon img,

.page-template-page-instalacion .service-item .icon svg,
.page-template-page-mantenimiento .service-item .icon svg,
.page-template-page-reparaciones .service-item .icon svg,
.page-template-page-automatizaciones .service-item .icon svg,
.page-template-page-abrigos-de-muelle .service-item .icon svg,
.page-template-page-accesorios-muelle .service-item .icon svg,
.page-template-page-muelles-de-carga .service-item .icon svg,
.page-template-page-puertas-rapidas .service-item .icon svg,
.page-template-page-puertas-industriales .service-item .icon svg,
.page-template-page-puertas-cortafuegos .service-item .icon svg {
    width: 46px;
    height: 46px;
    object-fit: contain;
    display: block;
}
/* SOLO MÓVIL: fijar tamaño real de los iconos check */
@media (max-width: 768px) {

  .service-item,
  .servicio-item,
  .service-list li,
  .servicios-list li,
  .check-item,
  .icon-text-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
  }

  .service-item .icon,
  .servicio-item .icon,
  .service-list li .icon,
  .servicios-list li .icon,
  .check-item .icon,
  .icon-text-item .icon {
    width: 46px !important;
    min-width: 46px !important;
    max-width: 46px !important;
    height: 46px !important;
    min-height: 46px !important;
    max-height: 46px !important;
    flex: 0 0 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .service-item .icon img,
  .servicio-item .icon img,
  .service-list li .icon img,
  .servicios-list li .icon img,
  .check-item .icon img,
  .icon-text-item .icon img,
  .service-item .icon svg,
  .servicio-item .icon svg,
  .service-list li .icon svg,
  .servicios-list li .icon svg,
  .check-item .icon svg,
  .icon-text-item .icon svg {
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    min-height: 46px !important;
    max-width: 46px !important;
    max-height: 46px !important;
    display: block !important;
    object-fit: contain !important;
  }

  .service-item .text,
  .servicio-item .text,
  .service-list li span:last-child,
  .servicios-list li span:last-child,
  .check-item .text,
  .icon-text-item .text {
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }
}
.header-phone {
	background: #fff;
	color: #111; /* negro suave para buena lectura */
	padding: 10px 16px;
	border-radius: 8px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	text-decoration: none;
	box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

/* Icono */
.header-phone svg {
	color: #e30613; /* opcional: rojo corporativo */
}
.site-header .header-phone {
	background: #fff;
	color: #111;
	padding: 10px 16px;
	border-radius: 8px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	text-decoration: none;
	box-shadow: 0 4px 12px rgba(0,0,0,0.1);
	position: relative;
	z-index: 10;
}
/* Hover general en header */
.site-header a:hover {
	background: #fff;
	color: #111 !important;
}

/* Iconos dentro de links */
.site-header a:hover svg {
	color: #111 !important;
}
/* =========================================
   FIX FINAL – HERO TELÉFONO + HEADER HOVER
   ========================================= */

/* 1) El botón blanco del hero no existía como clase global.
   Lo definimos para todas las páginas de servicio. */
.page-hero .page-hero-actions .btn,
.page-hero .page-hero-actions a.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 56px;
  text-decoration: none;
}

.page-hero .page-hero-actions .btn-ghost-white,
.page-hero .page-hero-actions a.btn-ghost-white {
  background: rgba(255,255,255,.08) !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,.92) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.18);
}

.page-hero .page-hero-actions .btn-ghost-white svg,
.page-hero .page-hero-actions a.btn-ghost-white svg {
  color: #fff !important;
  fill: currentColor;
}

.page-hero .page-hero-actions .btn-ghost-white:hover,
.page-hero .page-hero-actions a.btn-ghost-white:hover,
.page-hero .page-hero-actions .btn-ghost-white:focus,
.page-hero .page-hero-actions a.btn-ghost-white:focus {
  background: #fff !important;
  color: var(--color-dark) !important;
  border-color: #fff !important;
}

.page-hero .page-hero-actions .btn-ghost-white:hover svg,
.page-hero .page-hero-actions a.btn-ghost-white:hover svg,
.page-hero .page-hero-actions .btn-ghost-white:focus svg,
.page-hero .page-hero-actions a.btn-ghost-white:focus svg {
  color: var(--color-dark) !important;
}

/* 2) Anular el parche incorrecto que volvía blancos TODOS los enlaces del header.
   Ese bloque era el que te rompía el menú y afectaba también al logo. */
.site-header a:hover,
.site-header a:focus {
  background: transparent !important;
}

.site-header .site-logo:hover,
.site-header .site-logo:focus,
.site-header .site-logo:hover .logo-name,
.site-header .site-logo:focus .logo-name,
.site-header .site-logo:hover .logo-tagline,
.site-header .site-logo:focus .logo-tagline {
  background: transparent !important;
  color: inherit !important;
}

/* 3) Restaurar hover correcto solo para navegación */
.site-header .nav-link:hover,
.site-header .nav-link:focus,
.site-header .nav-item.active > .nav-link,
.site-header .current-menu-item > .nav-link,
.site-header .current_page_item > .nav-link {
  color: var(--color-white) !important;
  background: rgba(255,255,255,.08) !important;
}

.site-header .nav-link:hover svg,
.site-header .nav-link:focus svg,
.site-header .nav-item.active > .nav-link svg,
.site-header .current-menu-item > .nav-link svg,
.site-header .current_page_item > .nav-link svg {
  color: currentColor !important;
}

/* 4) Restaurar logo y CTA del header */
.site-header .logo-name {
  color: var(--color-white) !important;
}

.site-header .logo-tagline {
  color: rgba(255,255,255,.55) !important;
}

.site-header .header-phone {
  background: transparent !important;
  color: var(--color-white) !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.site-header .header-phone svg {
  color: var(--color-primary) !important;
}

.site-header .header-phone:hover,
.site-header .header-phone:focus {
  background: transparent !important;
  color: var(--color-white) !important;
  opacity: .85;
}

.site-header .header-phone:hover svg,
.site-header .header-phone:focus svg {
  color: var(--color-primary) !important;
}

/* 5) Dropdown intacto */
.site-header .dropdown-link:hover,
.site-header .dropdown-link:focus {
  background: var(--color-gray-light) !important;
  color: var(--color-primary) !important;
}

.site-header .dropdown-link:hover svg,
.site-header .dropdown-link:focus svg {
  color: var(--color-primary) !important;
}
.page-gallery .gallery-item {
  aspect-ratio: 4 / 3;
  background: #111;
}

.page-gallery .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
/* =========================================
   ACCESORIOS MUELLE – fix definitivo catálogo
   ========================================= */

.page-new-services .container{
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 24px;
}

.page-new-services .services-grid{
	display:grid !important;
	grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
	gap:28px !important;
	align-items:stretch !important;
}

.page-new-services .service-card{
	width:100% !important;
	max-width:none !important;
	min-width:0 !important;
	display:flex !important;
	flex-direction:column !important;
	overflow:hidden !important;
}

.page-new-services .service-media{
	width:100% !important;
	padding:14px !important;
	box-sizing:border-box !important;
}

.page-new-services .service-media-grid{
	display:grid !important;
	gap:12px !important;
	width:100% !important;
}

.page-new-services .service-media-grid.is-single{
	grid-template-columns:1fr !important;
}

.page-new-services .service-media-grid.is-double{
	grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
}

.page-new-services .service-media-item{
	width:100% !important;
	height:260px !important;
	aspect-ratio:auto !important;
	max-height:260px !important;
	overflow:hidden !important;
	background:#f4f4f4 !important;
	display:flex !important;
	align-items:center !important;
	justify-content:center !important;
}

.page-new-services .service-media-item img{
	width:100% !important;
	height:100% !important;
	object-fit:contain !important;
	display:block !important;
}

@media (max-width: 991px){
	.page-new-services .services-grid{
		grid-template-columns:1fr !important;
	}
}

@media (max-width: 768px){
	.page-new-services .service-media-grid.is-double{
		grid-template-columns:1fr !important;
	}

	.page-new-services .service-media-item{
		height:220px !important;
		max-height:220px !important;
	}
}
/* =========================================
   ACCESORIOS MUELLE – tarjetas más compactas
   ========================================= */

.page-new-services .container{
	max-width: 1180px !important;
}

.page-new-services .services-grid{
	display:grid !important;
	grid-template-columns:repeat(2, minmax(320px, 520px)) !important;
	justify-content:center !important;
	gap:28px !important;
}

.page-new-services .service-card{
	width:100% !important;
	max-width:520px !important;
	margin:0 auto !important;
}

.page-new-services .service-media-item{
	height:240px !important;
	max-height:240px !important;
}

.page-new-services .service-body{
	padding:22px 22px 22px !important;
}

@media (max-width: 991px){
	.page-new-services .services-grid{
		grid-template-columns:minmax(320px, 520px) !important;
		justify-content:center !important;
	}

	.page-new-services .service-card{
		max-width:520px !important;
	}
}

@media (max-width: 576px){
	.page-new-services .container{
		padding:0 16px !important;
	}

	.page-new-services .services-grid{
		grid-template-columns:1fr !important;
	}

	.page-new-services .service-card{
		max-width:none !important;
	}

	.page-new-services .service-media-item{
		height:220px !important;
		max-height:220px !important;
	}
}
/* =========================================
   GLOBAL SERVICIOS – instalaciones realizadas
   mismas columnas + más altura + foto entera
   ========================================= */

.page-gallery .gallery-grid{
	display:grid !important;
	grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
	gap:16px !important;
	align-items:stretch !important;
}

.page-gallery .gallery-item,
.page-gallery .gallery-item:first-child{
	grid-column:auto !important;
	height:340px !important;          /* sube la altura global */
	min-height:340px !important;
	max-height:none !important;
	background:#111 !important;
	display:flex !important;
	align-items:center !important;
	justify-content:center !important;
	overflow:hidden !important;
}

.page-gallery .gallery-item img{
	width:100% !important;
	height:100% !important;
	object-fit:contain !important;    /* imagen entera */
	display:block !important;
	background:#111 !important;
}

/* móvil */
@media (max-width: 768px){
	.page-gallery .gallery-grid{
		grid-template-columns:1fr !important;
	}

	.page-gallery .gallery-item,
	.page-gallery .gallery-item:first-child{
		height:260px !important;
		min-height:260px !important;
	}
}