/* ─── RESET & BASE ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Inter', sans-serif;
  color: #54585A;
  background: #FFFFFF;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }

/* ─── TOKENS ───────────────────────────────────────────────────────────── */
:root {
  --navy:   #1B2A6B;
  --blue:   #2D6DB5;
  --red:    #CC2529;
  --green:  #1A9B5F;
  --gray:   #54585A;
  --muted:  #7A8DAA;
  --bg-alt: #F7F9FC;
  --white:  #FFFFFF;
  --border: rgba(27,42,107,0.12);
  --radius: 6px;
  --shadow: 0 2px 12px rgba(27,42,107,0.08);
  --transition: 180ms ease;
}

/* ─── UTILITIES ────────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}
.section { padding: 80px 0; }
.section--alt { background: var(--bg-alt); }
.section--navy { background: var(--navy); color: var(--white); }
.section-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 10px;
}
.section-label--light { color: rgba(255,255,255,0.55); }
.section-title {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  color: var(--navy);
  line-height: 1.2;
  margin-bottom: 16px;
}
.section-title--light { color: var(--white); }
.section-intro {
  font-size: 1rem;
  color: var(--muted);
  max-width: 580px;
  margin-bottom: 48px;
}
.section-intro--light { color: rgba(255,255,255,0.72); }
/* ── Breaking news ticker ─────────────────────────────── */
.ticker-bar {
  display: flex;
  align-items: center;
  background: var(--navy);
  color: var(--white);
  text-decoration: none;
  height: 40px;
  overflow: hidden;
  cursor: pointer;
  transition: background 200ms ease;
}
.ticker-bar:hover { background: #14206a; }

.ticker-bar__tag {
  flex-shrink: 0;
  background: var(--red);
  color: var(--white);
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0 14px;
  height: 100%;
  display: flex;
  align-items: center;
  white-space: nowrap;
}

.ticker-bar__track {
  flex: 1;
  overflow: hidden;
  height: 100%;
  display: flex;
  align-items: center;
}

.ticker-bar__inner {
  display: flex;
  width: max-content;
  animation: ticker-scroll 18s linear infinite;
}

.ticker-bar__inner span {
  white-space: nowrap;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: rgba(255,255,255,0.92);
  padding-right: 0;
}

.ticker-bar:hover .ticker-bar__inner { animation-play-state: paused; }

.ticker-bar__arrow {
  flex-shrink: 0;
  padding: 0 16px;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.5);
  transition: color 200ms ease, transform 200ms ease;
}
.ticker-bar:hover .ticker-bar__arrow {
  color: var(--white);
  transform: translateY(3px);
}

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

/* ─── BRANDS BAR ───────────────────────────────────────────────────────── */
.brands-bar {
  background: var(--white);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 28px 0;
}
.brands-bar__label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: center;
  margin-bottom: 20px;
}
.brands-bar__grid {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
}
.brands-bar__item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 32px;
  border-right: 1px solid var(--border);
  transition: background 200ms;
}
.brands-bar__item:last-child { border-right: none; }
.brands-bar__item:hover { background: var(--bg-alt); }
.brands-bar__img {
  height: 36px;
  width: auto;
  max-width: 120px;
  object-fit: contain;
  filter: grayscale(100%) opacity(0.55);
  transition: filter 280ms ease;
}
.brands-bar__item:hover .brands-bar__img {
  filter: grayscale(0%) opacity(1);
}
@media (max-width: 768px) {
  .brands-bar__grid { flex-wrap: wrap; }
  .brands-bar__item { padding: 12px 20px; border-right: none; border-bottom: 1px solid var(--border); width: 33.33%; }
  .brands-bar__item:last-child { border-bottom: none; }
  .brands-bar__img { height: 28px; max-width: 90px; }
}

.divider {
  width: 44px;
  height: 3px;
  background: var(--red);
  margin-bottom: 28px;
}
.divider--light { background: rgba(255,255,255,0.35); }

/* ─── BUTTONS ──────────────────────────────────────────────────────────── */
.btn {
  display: inline-block;
  padding: 13px 28px;
  font-family: 'Inter', sans-serif;
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  border-radius: var(--radius);
  border: 2px solid transparent;
  cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
  line-height: 1;
}
.btn--red {
  background: var(--red);
  color: var(--white);
  border-color: var(--red);
}
.btn--red:hover { background: #a81e22; border-color: #a81e22; transform: translateY(-1px); }
.btn--navy {
  background: var(--navy);
  color: var(--white);
  border-color: var(--navy);
}
.btn--navy:hover { background: #14204f; border-color: #14204f; transform: translateY(-1px); }
.btn--outline-white {
  background: transparent;
  color: var(--white);
  border-color: rgba(255,255,255,0.5);
}
.btn--outline-white:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--white);
}

/* ─── NAVBAR ───────────────────────────────────────────────────────────── */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(27,42,107,0.08);
  height: 68px;
  display: flex;
  align-items: center;
}
.navbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}
/* ── Logo size increase for stronger brand presence ── */
.navbar__logo img {
  height: 52px;
  width: auto;
}
.navbar__nav {
  display: flex;
  align-items: center;
  gap: 32px;
  list-style: none;
}
.navbar__nav a {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--navy);
  transition: color var(--transition);
}
.navbar__nav a:hover,
.navbar__nav a.active { color: var(--blue); }
.navbar__cta { display: flex; }
.navbar__hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
  background: none;
  border: none;
}
.navbar__hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--navy);
  border-radius: 2px;
  transition: transform var(--transition), opacity var(--transition);
}
.navbar__mobile {
  display: none;
  position: fixed;
  top: 68px; left: 0; right: 0;
  background: var(--white);
  border-bottom: 1px solid rgba(27,42,107,0.1);
  padding: 16px 24px 24px;
  flex-direction: column;
  gap: 4px;
  z-index: 999;
}
.navbar__mobile.open { display: flex; }
.navbar__mobile a {
  padding: 10px 0;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--navy);
  border-bottom: 1px solid var(--bg-alt);
}
.navbar__mobile .btn { margin-top: 12px; width: 100%; text-align: center; }

/* ─── HERO ─────────────────────────────────────────────────────────────── */
.hero {
  padding-top: 134px;
  padding-bottom: 80px;
  background: var(--white);
}
.hero__content { max-width: 680px; }
.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(45,109,181,0.08);
  color: var(--blue);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 100px;
  margin-bottom: 24px;
}
.hero__badge-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--blue);
}
.hero__headline {
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 800;
  color: var(--navy);
  line-height: 1.1;
  margin-bottom: 20px;
}
.hero__headline span { color: var(--red); }
.hero__subheadline {
  font-size: clamp(1rem, 2vw, 1.2rem);
  color: var(--muted);
  max-width: 540px;
  margin-bottom: 36px;
  line-height: 1.65;
}
.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 56px;
}
.hero__pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.hero__pillar {
  background: var(--bg-alt);
  border-radius: var(--radius);
  padding: 20px 18px;
  border-left: 3px solid var(--blue);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.hero__pillar:hover { border-color: var(--navy); box-shadow: var(--shadow); }
.hero__pillar-title {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 6px;
}
.hero__pillar-text {
  font-size: 0.8rem;
  color: var(--muted);
  line-height: 1.5;
}

/* Hero dark variant */
.hero--dark {
  background: var(--navy);
  position: relative;
  overflow: hidden;
}
.hero--dark::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  pointer-events: none;
}
.hero--dark::after {
  content: '';
  position: absolute;
  top: -30%;
  right: -10%;
  width: 55%;
  height: 120%;
  background: radial-gradient(ellipse at center, rgba(45,109,181,0.18) 0%, transparent 68%);
  pointer-events: none;
}
.hero--dark .hero__badge {
  background: rgba(64,150,255,0.15);
  color: rgba(255,255,255,0.85);
  border: 1px solid rgba(64,150,255,0.3);
}
.hero--dark .hero__badge-dot { background: var(--blue); }
.hero--dark .hero__headline { color: var(--white); }
.hero--dark .hero__headline span { color: #FF6B6B; }
.hero--dark .hero__subheadline { color: rgba(255,255,255,0.65); }
.hero--dark .hero__pillar {
  background: rgba(255,255,255,0.05);
  border-color: rgba(64,150,255,0.4);
}
.hero--dark .hero__pillar:hover {
  background: rgba(255,255,255,0.08);
  border-color: var(--blue);
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}
.hero--dark .hero__pillar-title { color: var(--white); }
.hero--dark .hero__pillar-text { color: rgba(255,255,255,0.55); }

/* ─── PROPUESTA DE VALOR ───────────────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}
.stat-card {
  background: var(--white);
  border-radius: var(--radius);
  padding: 32px 24px;
  box-shadow: var(--shadow);
  border-top: 3px solid var(--blue);
  transition: transform var(--transition), box-shadow var(--transition);
}
.stat-card:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(27,42,107,0.12); }
.stat-card--green { border-top-color: var(--green); }
.stat-card__number {
  font-size: clamp(1.5rem, 2.5vw, 2.2rem);
  font-weight: 800;
  color: var(--blue);
  line-height: 1;
  white-space: nowrap;
  margin-bottom: 6px;
}
.stat-card__number span { color: var(--red); }
.stat-card__label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 10px;
}
.stat-card__desc {
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.55;
}
.stat-card__number[data-target] {
  transition: opacity 400ms ease;
}
.stat-card.is-counting .stat-card__number {
  opacity: 1;
}

/* ─── SERVICIOS ────────────────────────────────────────────────────────── */
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.service-card {
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition);
}
.service-card:hover { transform: translateY(-4px); box-shadow: 0 12px 36px rgba(27,42,107,0.14); }

/* Header band */
.service-card__head {
  background: var(--navy);
  padding: 24px 28px 20px;
  display: flex;
  align-items: flex-end;
  gap: 16px;
}
.service-card__index {
  font-size: 2.8rem;
  font-weight: 800;
  color: rgba(255,255,255,0.12);
  line-height: 1;
  letter-spacing: -2px;
  flex-shrink: 0;
}
.service-card__head-text {}
.service-card__category {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 4px;
}
.service-card__title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--white);
  line-height: 1.3;
  text-align: left;
}

/* Body */
.service-card__body {
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.service-card__lead {
  font-size: 0.875rem;
  color: var(--gray);
  line-height: 1.65;
  margin-bottom: 16px;
}
.service-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.service-list li {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: 0.84rem;
  color: var(--gray);
  line-height: 1.5;
}
.service-list li::before {
  content: '';
  display: block;
  min-width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--blue);
  margin-top: 6px;
  flex-shrink: 0;
}
.service-card__note {
  font-size: 0.78rem;
  color: var(--muted);
  font-style: italic;
  line-height: 1.6;
  margin-top: 16px;
  padding: 12px 14px;
  background: var(--bg-alt);
  border-radius: var(--radius);
  border-left: 3px solid var(--blue);
}
.service-card__badge {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(27,42,107,0.08);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--blue);
}
.service-card__badge img {
  height: 20px;
  width: auto;
  object-fit: contain;
}

/* ─── INNIO CERT BADGE ─────────────────────────────────────────────────── */
.innio-cert {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 14px;
  padding: 10px 14px;
  background: linear-gradient(135deg, rgba(45,109,181,0.06), rgba(27,42,107,0.04));
  border: 1px solid rgba(45,109,181,0.2);
  border-left: 3px solid var(--blue);
  border-radius: 8px;
}
.innio-cert__icon { flex-shrink: 0; }
.innio-cert__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.innio-cert__brand {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--navy);
}
.innio-cert__scope {
  font-size: 0.7rem;
  color: var(--muted);
  font-weight: 500;
}

/* ─── DIAGNÓSTICO ──────────────────────────────────────────────────────── */
.diag-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-bottom: 48px;
}
.diag-phase {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius);
  padding: 32px 28px;
}
.diag-phase__step {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 8px;
}
.diag-phase__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 6px;
}
.diag-phase__sub {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.5);
  margin-bottom: 20px;
}
.diag-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 9px;
}
.diag-list li {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: 0.875rem;
  color: rgba(255,255,255,0.82);
  line-height: 1.5;
}
.diag-list li::before {
  content: '';
  display: block;
  min-width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--red);
  margin-top: 7px;
}
.diag-cta { text-align: center; }

/* ─── SECTORES — CARD GRID (JENBACHER-STYLE) ────────────────────────────── */
.sector-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.sector-card {
  position: relative;
  display: block;
  aspect-ratio: 4/3;
  overflow: hidden;
  cursor: pointer;
  text-decoration: none;
  border-radius: 12px;
  outline: none;
  background: #0a1e35;
  transition: box-shadow 350ms ease, transform 350ms ease;
}
/* Bottom gradient for text readability */
.sector-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.1) 45%, transparent 100%);
  pointer-events: none;
  z-index: 1;
}
.sector-card:hover,
.sector-card:focus,
.sector-card:focus-visible {
  outline: none;
  box-shadow: 0 16px 40px rgba(0,0,0,0.35);
  transform: translateY(-3px);
}

/* Image */
.sector-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 500ms ease;
  border: none;
  box-shadow: none;
}
.sector-card:hover .sector-card__img {
  transform: scale(1.06);
}

.sector-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 18px 20px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 10px;
  z-index: 2;
}

.sector-card__name {
  color: #fff;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.2;
  flex: 1;
  text-shadow: 0 1px 4px rgba(0,0,0,0.4);
}

.sector-card__arrow {
  color: rgba(255,255,255,0.6);
  font-size: 1.4rem;
  line-height: 1;
  flex-shrink: 0;
  transition: transform var(--transition), color var(--transition);
}

.sector-card:hover .sector-card__arrow,
.sector-card.active .sector-card__arrow {
  transform: translateX(5px);
  color: #fff;
}

.sector-card.active { outline: none; }

.sector-card__priority-tag {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--red);
  color: #fff;
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 3px;
  z-index: 3;
}

/* ── Sector detail panel ── */
.sector-detail {
  margin-top: 3px;
  background: var(--white);
  border-radius: 0 0 var(--radius) var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  animation: sectorSlide 260ms ease;
}

@keyframes sectorSlide {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.sector-detail__inner {
  padding: 36px 40px;
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 40px;
}

.sector-detail__header {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(27,42,107,0.08);
  margin-bottom: 26px;
}

.sector-detail__num {
  font-size: 2.8rem;
  font-weight: 800;
  color: rgba(27,42,107,0.1);
  line-height: 1;
  flex-shrink: 0;
  padding-top: 2px;
}

.sector-detail__title {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--navy);
  line-height: 1.2;
  margin-bottom: 5px;
}

.sector-detail__sub {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.sector-detail__close {
  margin-left: auto;
  flex-shrink: 0;
  background: none;
  border: 1px solid rgba(27,42,107,0.14);
  border-radius: var(--radius);
  font-family: 'Inter', sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  padding: 7px 14px;
  white-space: nowrap;
  transition: color var(--transition), background var(--transition), border-color var(--transition);
}
.sector-detail__close:hover {
  color: var(--navy);
  background: rgba(27,42,107,0.05);
  border-color: rgba(27,42,107,0.22);
}

.sector-detail__fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 28px;
  margin-bottom: 22px;
}

.sector-detail__field-label {
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 5px;
}

.sector-detail__field-text {
  font-size: 0.9rem;
  color: var(--gray);
  line-height: 1.55;
}

.sector-detail__message {
  font-size: 1rem;
  font-weight: 600;
  font-style: italic;
  color: var(--navy);
  border-left: 3px solid var(--red);
  padding-left: 16px;
  line-height: 1.5;
}

.sector-detail__kpi {
  background: rgba(27,42,107,0.04);
  border: 1px solid rgba(27,42,107,0.1);
  border-left: 4px solid var(--blue);
  border-radius: var(--radius);
  padding: 18px 20px;
  margin-bottom: 18px;
}
.sector-detail__kpi--red {
  background: rgba(204,37,41,0.04);
  border-color: rgba(204,37,41,0.12);
  border-left-color: var(--red);
}

.sector-detail__kpi-label {
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 8px;
}
.sector-detail__kpi--red .sector-detail__kpi-label { color: var(--red); }

.sector-detail__kpi-text {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--navy);
  line-height: 1.5;
}

.sector-detail__badge {
  font-size: 0.72rem;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 20px;
}

.sector-detail__cta {
  display: block;
  text-align: center;
  width: 100%;
}

/* Small button modifier */
.btn--sm {
  padding: 10px 20px;
  font-size: 0.8rem;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* ─── CICLO DE VIDA ────────────────────────────────────────────────────── */
.lifecycle-banner {
  background: rgba(204,37,41,0.07);
  border: 1px solid rgba(204,37,41,0.18);
  border-radius: var(--radius);
  padding: 32px 36px;
  margin-bottom: 40px;
}
.lifecycle-banner__label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 10px;
}
.lifecycle-banner__text {
  font-size: 0.95rem;
  color: var(--gray);
  max-width: 720px;
  line-height: 1.65;
}
.lifecycle-banner__text strong { color: var(--navy); }

/* ─── TIMELINE ─────────────────────────────────────────────────────────── */
.timeline-wrap {
  margin-bottom: 40px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 8px;
}
.timeline {
  min-width: 720px;
}
/* ── Shared column grid (5 cols, used both above and below rail) ── */
.timeline__grid,
.timeline__minor-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}
/* ── Above-rail milestones: card → stem → dot ── */
.timeline__milestone {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.timeline__card {
  width: 100%;
  background: var(--white);
  border: 1px solid rgba(27,42,107,0.1);
  border-radius: var(--radius);
  padding: 14px 12px;
  text-align: center;
  box-shadow: var(--shadow);
  transition: transform var(--transition), box-shadow var(--transition);
}
.timeline__card:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(27,42,107,0.12); }
.timeline__card--danger {
  border-color: rgba(204,37,41,0.3);
  background: rgba(204,37,41,0.04);
}
.timeline__card--danger:hover { box-shadow: 0 6px 20px rgba(204,37,41,0.15); }
.timeline__hours {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--navy);
  line-height: 1;
  margin-bottom: 4px;
}
.timeline__card--danger .timeline__hours { color: var(--red); }
.timeline__event {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.4;
}
.timeline__card--danger .timeline__event { font-weight: 700; color: var(--red); }
/* Stem: fills space between card and dot */
.timeline__stem {
  width: 2px;
  flex: 1;
  min-height: 14px;
  background: rgba(27,42,107,0.15);
}
.timeline__milestone:last-child .timeline__stem { background: rgba(204,37,41,0.3); }
/* Dot sits on rail */
.timeline__dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--blue);
  border: 3px solid var(--white);
  box-shadow: 0 0 0 2px var(--blue);
  flex-shrink: 0;
}
.timeline__dot--danger {
  width: 20px; height: 20px;
  background: var(--red);
  box-shadow: 0 0 0 2px var(--red), 0 0 0 5px rgba(204,37,41,0.15);
  border: 3px solid var(--white);
}

/* ── The horizontal rail (normal flow, between grids) ── */
.timeline__rail {
  height: 4px;
  border-radius: 2px;
  margin: 0 20px;
  background: linear-gradient(90deg,
    var(--blue) 0%,
    var(--blue) 74%,
    var(--red)  74%,
    var(--red)  100%
  );
}

/* ── Below-rail minor maintenance: dot → stem → card ── */
.timeline__minor-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}
/* Only place items in cols 1 and 2 */
.timeline__minor-item:first-child { grid-column: 1; }
.timeline__minor-item:last-child  { grid-column: 2; }
/* Dot sits on the rail (top of minor item) */
.timeline__minor-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(45,109,181,0.55);
  border: 2px solid var(--white);
  box-shadow: 0 0 0 1.5px rgba(45,109,181,0.55);
  flex-shrink: 0;
}
/* Stem drops down to card */
.timeline__minor-stem {
  width: 2px;
  height: 22px;
  background: rgba(27,42,107,0.12);
  flex-shrink: 0;
}
/* Minor card (below rail) */
.timeline__minor-card {
  width: 100%;
  background: var(--bg-alt);
  border: 1px solid rgba(27,42,107,0.08);
  border-top: 2px solid rgba(45,109,181,0.35);
  border-radius: var(--radius);
  padding: 14px 12px;
  transition: border-top-color var(--transition), box-shadow var(--transition);
}
.timeline__minor-card:hover {
  border-top-color: var(--blue);
  box-shadow: 0 4px 14px rgba(27,42,107,0.09);
}
.timeline__minor-hours {
  font-size: 0.85rem;
  font-weight: 800;
  color: var(--navy);
  line-height: 1;
  margin-bottom: 5px;
}
.timeline__minor-label {
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 8px;
}
.timeline__minor-text {
  font-size: 0.78rem;
  color: var(--gray);
  line-height: 1.55;
}
/* Label separating major from minor zones */
.timeline__zone-label {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.timeline__zone-label--above { color: var(--navy); }
.timeline__zone-label--below { color: var(--muted); margin-top: 6px; }
.timeline-warning {
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(204,37,41,0.06);
  border-left: 4px solid var(--red);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 14px 20px;
  margin-bottom: 32px;
  font-size: 0.875rem;
  color: var(--gray);
}
.timeline-warning-icon {
  font-size: 1.3rem;
  line-height: 1;
  color: var(--red);
  font-weight: 800;
}
.lifecycle-cta { text-align: center; }

/* ─── SOCIO TÉCNICO ────────────────────────────────────────────────────── */
.partner-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
}
.partner-lead {
  font-size: 1rem;
  color: var(--navy);
  font-weight: 500;
  line-height: 1.7;
  margin-bottom: 16px;
}
.partner-body {
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.7;
}
.partner-pillars {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.partner-item {
  background: var(--white);
  border-radius: var(--radius);
  padding: 20px 18px;
  box-shadow: var(--shadow);
  border-top: 2px solid var(--blue);
}
.partner-item__label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 8px;
}
.partner-item__text {
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.55;
}

/* ─── CONTACTO ─────────────────────────────────────────────────────────── */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 48px;
  align-items: start;
}
.contact-grid--solo {
  grid-template-columns: 1fr;
  max-width: 560px;
  margin-top: 0;
}
#contacto .section-intro {
  margin-bottom: 20px;
}
.contact-info {}
.contact-info__identity {
  margin-bottom: 28px;
  line-height: 1;
}
.contact-info__name {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 2px;
}
.contact-info__role {
  font-size: 0.875rem;
  color: var(--muted);
  margin-bottom: 0;
}
.contact-details {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.contact-detail {
  display: flex;
  align-items: baseline;
  gap: 12px;
  line-height: 1.4;
}
.contact-detail__label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue);
  min-width: 48px;
  margin-top: 2px;
}
.contact-detail__value {
  font-size: 0.9rem;
  color: var(--gray);
}
.contact-detail__value a { color: var(--navy); font-weight: 500; }
.contact-detail__value a:hover { color: var(--blue); }

.contact-form {
  background: var(--bg-alt);
  border-radius: var(--radius);
  padding: 36px 32px;
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.form-group:last-child { margin-bottom: 0; }
.form-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--navy);
  letter-spacing: 0.03em;
}
.form-control {
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  color: var(--gray);
  background: var(--white);
  border: 1px solid rgba(27,42,107,0.15);
  border-radius: var(--radius);
  padding: 10px 14px;
  outline: none;
  width: 100%;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.form-control:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(45,109,181,0.1);
}
textarea.form-control { resize: vertical; min-height: 100px; }
.form-submit { width: 100%; margin-top: 8px; }
.form-success {
  display: none;
  text-align: center;
  padding: 24px 20px;
  background: rgba(27,42,107,0.05);
  border: 1px solid rgba(27,42,107,0.1);
  border-radius: var(--radius);
  font-size: 0.9rem;
  color: var(--navy);
  line-height: 1.6;
}
.form-error {
  display: none;
  padding: 14px 18px;
  background: rgba(204,37,41,0.05);
  border: 1px solid rgba(204,37,41,0.2);
  border-radius: var(--radius);
  font-size: 0.85rem;
  color: var(--red);
  line-height: 1.55;
}
.form-error a { color: var(--red); text-decoration: underline; }

/* ─── MISIÓN Y VALORES ─────────────────────────────────────────────────── */
.mision-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 8px;
}
.mision-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius);
  padding: 36px 30px 32px;
  position: relative;
  overflow: hidden;
  transition: background var(--transition), border-color var(--transition), transform var(--transition);
  border-top: 3px solid rgba(45,109,181,0.6);
}
.mision-card--accent {
  background: rgba(255,255,255,0.09);
  border-top-color: var(--red);
}
.mision-card:last-child {
  border-top-color: rgba(255,255,255,0.3);
}
.mision-card:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.2);
  transform: translateY(-3px);
}
/* Ghost index number */
.mision-card__index {
  font-size: 4rem;
  font-weight: 800;
  color: rgba(255,255,255,0.06);
  line-height: 1;
  letter-spacing: -3px;
  margin-bottom: 14px;
  user-select: none;
}
/* Label chip */
.mision-card__label {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 100px;
  padding: 4px 12px;
  margin-bottom: 18px;
}
.mision-card--accent .mision-card__label {
  color: rgba(255,255,255,0.75);
  background: rgba(204,37,41,0.2);
  border-color: rgba(204,37,41,0.3);
}
/* Quote text */
.mision-card__text {
  font-size: 0.925rem;
  color: rgba(255,255,255,0.78);
  line-height: 1.8;
  font-style: italic;
}
.mision-card__text::before {
  content: '\201C';
  font-size: 1.4rem;
  font-style: normal;
  color: rgba(255,255,255,0.25);
  line-height: 0;
  vertical-align: -0.35em;
  margin-right: 3px;
}
.mision-card__text::after {
  content: '\201D';
  font-size: 1.4rem;
  font-style: normal;
  color: rgba(255,255,255,0.25);
  line-height: 0;
  vertical-align: -0.35em;
  margin-left: 3px;
}

/* ── Beneficio Fiscal ─────────────────────────────── */
.fiscal-legal {
  background: var(--navy);
  border-left: 4px solid var(--blue);
  border-radius: 10px;
  padding: 24px 32px;
  margin: 36px 0 48px;
}
.fiscal-legal__label {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 10px;
}
.fiscal-legal__text {
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(255,255,255,0.88);
  font-style: italic;
}
.fiscal-points {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-bottom: 48px;
}
.fiscal-point {
  border-top: 3px solid var(--blue);
  padding-top: 20px;
}
.fiscal-point__title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 10px;
  line-height: 1.3;
}
.fiscal-point__text {
  font-size: 0.9rem;
  color: var(--gray);
  line-height: 1.65;
}
.fiscal-cta { text-align: center; }

/* ─── MODAL CALCULADORA FISCAL ─────────────────────────────────────────── */
.fc-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,10,30,0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 9000;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.fc-overlay.is-open { display: flex; }

.fc-modal {
  background: var(--navy);
  border-radius: 20px;
  width: 100%;
  max-width: 780px;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,0.5);
  animation: fc-in 260ms cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes fc-in {
  from { opacity: 0; transform: scale(0.92) translateY(16px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.fc-modal__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 32px 36px 24px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.fc-modal__tag {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--blue);
  background: rgba(64,150,255,0.12);
  border: 1px solid rgba(64,150,255,0.25);
  padding: 3px 10px;
  border-radius: 4px;
  margin-bottom: 12px;
}
.fc-modal__title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--white);
  line-height: 1.2;
  margin-bottom: 6px;
}
.fc-modal__sub {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.4);
}
.fc-modal__close {
  background: rgba(255,255,255,0.07);
  border: none;
  color: rgba(255,255,255,0.6);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 0.9rem;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 150ms, color 150ms;
  display: flex;
  align-items: center;
  justify-content: center;
}
.fc-modal__close:hover { background: rgba(255,255,255,0.14); color: var(--white); }

.fc-modal__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

/* Inputs side */
.fc-modal__inputs {
  padding: 32px 36px;
  display: flex;
  flex-direction: column;
  gap: 32px;
  border-right: 1px solid rgba(255,255,255,0.07);
}
.fc-field { display: flex; flex-direction: column; gap: 10px; }
.fc-label {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.fc-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  padding: 11px 16px;
  transition: border-color 150ms;
}
.fc-input-row:focus-within { border-color: rgba(64,150,255,0.5); }
.fc-unit {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.35);
  flex-shrink: 0;
}
.fc-input {
  background: none;
  border: none;
  outline: none;
  color: var(--white);
  font-size: 1.05rem;
  font-weight: 600;
  font-family: inherit;
  width: 100%;
  -moz-appearance: textfield;
}
.fc-input--sm { width: 56px; }
.fc-input::-webkit-outer-spin-button,
.fc-input::-webkit-inner-spin-button { -webkit-appearance: none; }

.fc-range {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 4px;
  background: rgba(255,255,255,0.1);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
}
.fc-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--blue);
  cursor: pointer;
  box-shadow: 0 0 0 4px rgba(64,150,255,0.15);
  transition: box-shadow 150ms, transform 150ms;
}
.fc-range::-webkit-slider-thumb:hover {
  box-shadow: 0 0 0 6px rgba(64,150,255,0.25);
  transform: scale(1.1);
}
.fc-range::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--blue);
  border: none;
  cursor: pointer;
}
.fc-range-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.7rem;
  color: rgba(255,255,255,0.25);
}
.fc-inv-calc {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.5);
  margin: 0;
  line-height: 1.5;
}
.fc-inv-calc strong {
  color: rgba(255,255,255,0.85);
  font-size: 0.9rem;
}
.fc-inv-note {
  font-size: 0.68rem;
  color: rgba(255,255,255,0.3);
}

/* Results side */
.fc-modal__results {
  padding: 32px 36px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  justify-content: center;
}
.fc-kpi { display: flex; flex-direction: column; gap: 4px; }
.fc-kpi--main {
  background: rgba(64,150,255,0.08);
  border: 1px solid rgba(64,150,255,0.2);
  border-radius: 12px;
  padding: 20px;
}
.fc-kpi__label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
}
.fc-kpi--main .fc-kpi__label { color: var(--blue); }
.fc-kpi__value {
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--white);
  letter-spacing: -0.03em;
  line-height: 1.1;
}
.fc-kpi__value--md { font-size: 1.5rem; }
.fc-kpi__note {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.35);
}

/* Footer */
.fc-modal__foot {
  padding: 20px 36px;
  border-top: 1px solid rgba(255,255,255,0.07);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
#fc-cta { white-space: nowrap; }
.fc-disclaimer {
  font-size: 0.73rem;
  color: rgba(255,255,255,0.25);
  line-height: 1.5;
  max-width: 400px;
}

@media (max-width: 640px) {
  .fc-modal__body { grid-template-columns: 1fr; }
  .fc-modal__inputs { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.07); padding: 24px 20px; }
  .fc-modal__results { padding: 24px 20px; }
  .fc-modal__head { padding: 24px 20px 18px; }
  .fc-modal__foot { flex-direction: column; align-items: stretch; padding: 20px; }
  .fc-kpi__value { font-size: 1.8rem; }
}

/* ─── FOOTER ───────────────────────────────────────────────────────────── */
.footer {
  background: var(--navy);
  color: rgba(255,255,255,0.7);
  padding: 24px 0 16px;
}
.footer__inner {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 20px;
}
.footer__brand {}
.footer__logo {
  height: 28px;
  width: auto;
  margin-bottom: 14px;
  filter: brightness(0) invert(1);
}
.footer__tagline {
  font-size: 0.72rem;
  line-height: 1.5;
  color: rgba(255,255,255,0.55);
  max-width: 260px;
}
.footer__col-title {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.35);
  margin-bottom: 8px;
}
.footer__links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.footer__links li a {
  display: block;
  padding: 0;
  line-height: 1.4;
}
.footer__links a {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.65);
  transition: color var(--transition);
}
.footer__links a:hover { color: var(--white); }
.footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.footer__copy {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.35);
}
.footer__legal {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.35);
}
.footer__address {
  font-size: 0.7rem;
  font-style: normal;
  line-height: 1.6;
  color: rgba(255,255,255,0.45);
  margin-top: 10px;
}

.footer__socials {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}
.footer__social {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 6px;
  background: rgba(255,255,255,0.07);
  color: rgba(255,255,255,0.55);
  transition: background var(--transition), color var(--transition);
}
.footer__social:hover {
  background: rgba(255,255,255,0.15);
  color: var(--white);
}

/* ─── SECTOR PAGES ──────────────────────────────────────────────────────── */
.sector-hero {
  position: relative;
  padding: 140px 0 72px;
  overflow: hidden;
}
.sector-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}
.sector-hero--alimentaria .sector-hero__bg { background: linear-gradient(135deg, #1B2A6B 0%, #0e5460 100%); }
.sector-hero--textil      .sector-hero__bg { background: linear-gradient(135deg, #3d2065 0%, #1B2A6B 100%); }
.sector-hero--ceramica    .sector-hero__bg { background: linear-gradient(135deg, #7a1010 0%, #CC2529 100%); }
.sector-hero--quimica     .sector-hero__bg { background: linear-gradient(135deg, #0d3d3a 0%, #1B2A6B 100%); }
.sector-hero--bebidas     .sector-hero__bg { background: linear-gradient(135deg, #184023 0%, #2D6DB5 100%); }
.sector-hero--datos       .sector-hero__bg { background: linear-gradient(135deg, #060d18 0%, #1B2A6B 100%); }
.sector-hero--papel       .sector-hero__bg { background: linear-gradient(135deg, #263d1a 0%, #1B2A6B 100%); }

.sector-hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.28);
}

.sector-hero__content {
  position: relative;
  z-index: 1;
  color: var(--white);
}

.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.62);
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.breadcrumb a {
  color: rgba(255,255,255,0.62);
  transition: color var(--transition);
}
.breadcrumb a:hover { color: var(--white); }
.breadcrumb__sep { opacity: 0.4; font-size: 0.85rem; }
.breadcrumb__current { color: rgba(255,255,255,0.88); }

.sector-hero__priority {
  display: inline-block;
  background: var(--red);
  color: var(--white);
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 3px;
  margin-bottom: 16px;
}

.sector-hero__num {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: 10px;
}

.sector-hero__title {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  line-height: 1.1;
  margin-bottom: 12px;
}

.sector-hero__sub {
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.62);
}

/* ── Sector page 2-col layout ── */
.sector-page__layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 48px;
  align-items: start;
}

.sector-page__main .sector-detail__fields {
  margin-bottom: 32px;
}

/* ── Sector intro paragraph ── */
.sector-intro {
  font-size: 1.05rem;
  color: var(--gray);
  line-height: 1.75;
  max-width: 72ch;
  margin-bottom: 40px;
}

/* ── Por qué cogeneración section ── */
.sector-por-que {
  background: var(--bg-alt);
  padding: 56px 0;
}
.sector-por-que__inner {
  max-width: 800px;
}
.sector-por-que__label {
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 10px;
}
.sector-por-que__title {
  font-size: clamp(1.25rem, 2.5vw, 1.6rem);
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 16px;
  line-height: 1.2;
}
.sector-por-que__text {
  font-size: 0.95rem;
  color: var(--gray);
  line-height: 1.8;
}

/* ── Sector CTA strip ── */
.sector-cta-strip {
  background: var(--navy);
  padding: 64px 0;
  text-align: center;
  color: var(--white);
}
.sector-cta-strip__title {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  font-weight: 800;
  margin-bottom: 10px;
}
.sector-cta-strip__sub {
  font-size: 1rem;
  color: rgba(255,255,255,0.68);
  max-width: 520px;
  margin: 0 auto 28px;
  line-height: 1.6;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .sector-page__layout { grid-template-columns: 1fr; gap: 28px; }
  .sector-hero { padding: 120px 0 52px; }
}

/* ─── RESPONSIVE ───────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .sector-grid { grid-template-columns: repeat(2, 1fr); }
  .sector-detail__inner { grid-template-columns: 1fr 280px; gap: 28px; }
}

@media (max-width: 768px) {
  .section { padding: 56px 0; }

  /* Nav */
  .navbar__nav, .navbar__cta { display: none; }
  .navbar__hamburger { display: flex; }

  /* Hero */
  .hero { padding-top: 100px; }
  .hero__pillars { grid-template-columns: 1fr; gap: 12px; }

  /* Stats */
  .stats-grid { grid-template-columns: 1fr 1fr; }

  /* Services */
  .services-grid { grid-template-columns: 1fr; }

  /* Diag */
  .diag-grid { grid-template-columns: 1fr; gap: 20px; }

  /* Sectors — card grid responsive */
  .sector-grid { grid-template-columns: repeat(2, 1fr); }
  .sector-detail__inner { grid-template-columns: 1fr; }
  .sector-detail__inner { padding: 24px 20px; }

  /* Misión y Valores */
  .mision-grid { grid-template-columns: 1fr; gap: 16px; }

  /* Partner */
  .partner-grid { grid-template-columns: 1fr; gap: 28px; }
  .partner-pillars { grid-template-columns: 1fr 1fr; }

  /* Beneficio Fiscal */
  .fiscal-points { grid-template-columns: 1fr; gap: 24px; }
  .fiscal-legal { padding: 20px 20px; }

  /* Contact */
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }

  /* Footer */
  .footer__inner { grid-template-columns: 1fr; gap: 28px; }
  .footer__bottom { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 480px) {
  .stats-grid { grid-template-columns: 1fr; }
  .sector-grid { grid-template-columns: 1fr; }
  .sector-detail__fields { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .partner-pillars { grid-template-columns: 1fr; }
  .hero__actions { flex-direction: column; }
  .hero__actions .btn { text-align: center; }
  .calc-wrapper { grid-template-columns: 1fr; }
  .calc-kpis    { grid-template-columns: 1fr 1fr; }
  .maint-field-row { grid-template-columns: 1fr; }
  .calc-right-col { margin-top: 0; }
}

/* ─── CALCULADORA ──────────────────────────────────────────────────────── */
.calc-wrapper {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 32px;
  align-items: start;
}
.calc-right-col { display: flex; flex-direction: column; gap: 0; }
.calc-req { color: var(--red); font-weight: 800; }

.calc-panel {
  background: var(--white);
  border-radius: var(--radius);
  padding: 28px;
  box-shadow: var(--shadow);
}
.calc-panel--results { border-top: 3px solid var(--blue); }

.calc-panel__title {
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--navy);
  margin-bottom: 20px;
}

.calc-field { margin-bottom: 16px; }
.calc-field--highlight {
  background: rgba(27,42,107,0.04);
  border: 1px solid rgba(27,42,107,0.1);
  border-left: 3px solid var(--blue);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 20px;
}

.calc-label {
  display: block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
}

.calc-input-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.calc-affix {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--muted);
  white-space: nowrap;
}
.calc-input {
  flex: 1;
  border: 1px solid rgba(27,42,107,0.2);
  border-radius: 6px;
  padding: 8px 10px;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--navy);
  background: var(--bg-alt);
  transition: border-color var(--transition);
  min-width: 0;
}
.calc-input:focus {
  outline: none;
  border-color: var(--blue);
  background: var(--white);
}
.calc-hint {
  font-size: 0.68rem;
  color: var(--muted);
  margin-top: 6px;
  line-height: 1.4;
}

.calc-cta { width: 100%; margin-top: 8px; }
.calc-disclaimer {
  font-size: 0.65rem;
  color: var(--muted);
  margin-top: 10px;
  line-height: 1.5;
  text-align: center;
}

/* KPIs */
.calc-kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}
.calc-kpi {
  background: var(--bg-alt);
  border-radius: 8px;
  padding: 14px 16px;
  border-left: 3px solid var(--blue);
}
.calc-kpi__val {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--navy);
  line-height: 1;
  margin-bottom: 4px;
}
.calc-kpi__lbl {
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}

/* Gráfica */
.calc-chart-wrap { margin-bottom: 20px; }
.calc-chart-label {
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 8px;
}
.calc-chart { display: block; width: 100%; border-radius: 6px; }

/* CO2 */
.calc-co2 {
  background: rgba(26,155,95,0.06);
  border: 1px solid rgba(26,155,95,0.2);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 20px;
}
.calc-co2-inner { display: flex; align-items: center; gap: 12px; }
.calc-co2-icon  { font-size: 1.4rem; }
.calc-co2-val   { font-size: 1rem; font-weight: 800; color: var(--green); }
.calc-co2-lbl   { font-size: 0.8rem; color: var(--muted); }

/* Smart CTA */
.calc-smart-cta {
  background: rgba(27,42,107,0.04);
  border-radius: 10px;
  padding: 18px 20px;
  margin-bottom: 16px;
  text-align: center;
}
.calc-smart-cta--green {
  background: rgba(26,155,95,0.06);
  border: 1px solid rgba(26,155,95,0.25);
}
.calc-smart-cta p { font-size: 0.85rem; color: var(--muted); margin-bottom: 14px; }
.calc-smart-badge {
  display: inline-block;
  background: var(--green);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 20px;
  margin-bottom: 10px;
}
.calc-smart-cta .btn { width: 100%; }

.calc-pdf {
  width: 100%;
  font-size: 0.8rem;
}

/* Instrucciones */
.calc-instructions { border-top: 3px solid var(--navy); }
.calc-guide {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.calc-guide__item {
  padding: 12px 0;
  border-bottom: 1px solid rgba(27,42,107,0.07);
}
.calc-guide__item--sector {
  background: rgba(27,42,107,0.03);
  border-radius: 6px;
  padding: 12px 10px;
  border: 1px solid rgba(27,42,107,0.1);
  border-left: 3px solid var(--blue);
  margin-top: 4px;
  border-bottom: none;
}
.calc-guide__field {
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--navy);
  margin-bottom: 4px;
}
.calc-guide__text {
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.55;
}
.calc-guide__note {
  margin-top: 16px;
  font-size: 0.72rem;
  color: var(--muted);
  font-style: italic;
  line-height: 1.5;
  background: rgba(27,42,107,0.03);
  border-radius: 6px;
  padding: 10px 12px;
}

/* ─── DASHBOARD MANTENIMIENTO ───────────────────────────────────────────── */
.maint-dashboard {
  margin-top: 32px;
  border: 1px solid rgba(27,42,107,0.1);
  border-radius: var(--radius);
  overflow: hidden;
}
.maint-toggle {
  width: 100%;
  background: rgba(27,42,107,0.04);
  border: none;
  padding: 14px 20px;
  text-align: left;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--navy);
  cursor: pointer;
  transition: background var(--transition);
}
.maint-toggle:hover { background: rgba(27,42,107,0.08); }

.maint-body { padding: 24px; }
.maint-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 4px;
}
.maint-field { }

.maint-results { margin-top: 20px; }
.maint-bars { display: flex; flex-direction: column; gap: 18px; }

.maint-bar-item { }
.maint-bar-header {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--navy);
  margin-bottom: 6px;
}
.maint-track {
  height: 10px;
  background: rgba(27,42,107,0.08);
  border-radius: 10px;
  overflow: hidden;
}
.maint-fill {
  height: 100%;
  border-radius: 10px;
  transition: width 600ms ease;
}
.maint-fill--blue  { background: var(--blue); }
.maint-fill--navy  { background: var(--navy); }
.maint-bar-sub {
  font-size: 0.65rem;
  color: var(--muted);
  margin-top: 4px;
}

/* ─── FAQ ───────────────────────────────────────────────────────────────── */
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 48px;
  border-top: 1px solid var(--border);
}
.faq-item {
  border-bottom: 1px solid var(--border);
}
.faq-q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 22px 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: 1rem;
  font-weight: 600;
  color: var(--navy);
  font-family: inherit;
  transition: color 200ms;
}
.faq-q:hover { color: var(--blue); }
.faq-q[aria-expanded="true"] { color: var(--blue); }
.faq-icon {
  font-size: 1.4rem;
  font-weight: 300;
  color: var(--blue);
  flex-shrink: 0;
  transition: transform 280ms ease;
  line-height: 1;
}
.faq-q[aria-expanded="true"] .faq-icon { transform: rotate(45deg); }
.faq-a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 300ms ease;
}
.faq-a.is-open {
  grid-template-rows: 1fr;
}
.faq-a > p {
  overflow: hidden;
  font-size: 0.92rem;
  line-height: 1.72;
  color: var(--gray);
  padding-bottom: 0;
  transition: padding-bottom 300ms ease;
}
.faq-a.is-open > p {
  padding-bottom: 22px;
}

/* ─── WHATSAPP FLOTANTE ─────────────────────────────────────────────────── */
.wa-btn {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 8000;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25D366;
  color: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,0.4);
  transition: transform 200ms ease, box-shadow 200ms ease;
}
.wa-btn:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 28px rgba(37,211,102,0.55);
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE GLOBAL — Mobile-first enhancements
   Breakpoints: 1100 · 960 · 768 (adiciones) · 640 (adiciones) · 480 (adiciones) · 375
   ══════════════════════════════════════════════════════════════════════════ */

/* ── 1100px: Tablet landscape ───────────────────────────────────────────── */
@media (max-width: 1100px) {
  .stats-grid { grid-template-columns: repeat(3, 1fr); }
  .footer__inner { grid-template-columns: 1fr 1fr; gap: 32px; }
}

/* ── 960px: Tablet portrait ─────────────────────────────────────────────── */
@media (max-width: 960px) {
  .contact-form { padding: 28px 24px; }
  .lifecycle-banner { padding: 24px 28px; }
  .fiscal-legal { padding: 20px 24px; }
}

/* ── 768px additions ─────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  /* Container */
  .container { padding: 0 20px; }

  /* Typography */
  .section-intro { max-width: 100%; }

  /* Navbar logo */
  .navbar__logo img { height: 44px; }

  /* Hero */
  .hero { padding-top: 90px; padding-bottom: 52px; }

  /* Brands bar: 2 por fila */
  .brands-bar { padding: 20px 0; }
  .brands-bar__item {
    width: 50%;
    padding: 12px 16px;
    border-right: none;
    border-bottom: 1px solid var(--border);
  }
  .brands-bar__item:nth-child(odd)  { border-right: 1px solid var(--border); }
  .brands-bar__item:nth-child(even) { border-right: none; }
  .brands-bar__item:last-child,
  .brands-bar__item:nth-last-child(2):nth-child(odd) { border-bottom: none; }

  /* Fiscal modal: bottom-sheet en mobile */
  .fc-overlay { padding: 0; align-items: flex-end; }
  .fc-modal {
    border-radius: 20px 20px 0 0;
    max-height: 92vh;
    overflow-y: auto;
  }

  /* Contact form */
  .contact-form { padding: 24px 20px; }

  /* Lifecycle banner */
  .lifecycle-banner { padding: 20px 22px; }

  /* CTA strip */
  .sector-cta-strip { padding: 44px 0; }

  /* ── Timeline: layout vertical ───────────────────────────────────────── */
  .timeline-wrap { overflow-x: visible; padding-bottom: 0; }
  .timeline { min-width: 0; }

  /* Ocultar etiquetas de zona y rail horizontal */
  .timeline__zone-label { display: none; }
  .timeline__rail { display: none; }

  /* Grid de hitos: columna vertical */
  .timeline__grid {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }

  /* Cada hito: dot | card en fila */
  .timeline__milestone {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 14px;
  }
  .timeline__dot {
    order: -1;
    position: static;
    transform: none;
    flex-shrink: 0;
  }
  .timeline__stem { display: none; }
  .timeline__card {
    flex: 1;
    text-align: left;
    padding: 12px 14px;
  }

  /* Grid de mantenimientos menores: columna vertical */
  .timeline__minor-grid {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 12px;
  }
  .timeline__minor-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 14px;
  }
  .timeline__minor-dot  { order: -1; display: block; flex-shrink: 0; }
  .timeline__minor-stem { display: none; }
  .timeline__minor-card { flex: 1; }
}

/* ── 640px additions ─────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .navbar__logo img { height: 40px; }
  .hero { padding-top: 82px; padding-bottom: 44px; }
  .sector-hero { padding: 106px 0 44px; }

  /* FC modal footer: stack botones */
  .fc-modal__foot {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    padding: 16px 20px;
  }
  .fc-disclaimer { max-width: 100%; }
  #fc-cta { text-align: center; }
}

/* ── 480px additions ─────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  /* Base */
  .container { padding: 0 16px; }
  .section   { padding: 40px 0; }

  /* Navbar */
  .navbar { height: 60px; }
  .navbar__mobile { top: 60px; }
  .navbar__logo img { height: 36px; }

  /* Hero */
  .hero { padding-top: 74px; padding-bottom: 36px; }
  .hero__actions .btn { text-align: center; }

  /* Sector hero */
  .sector-hero { padding: 94px 0 36px; }
  .sector-hero__title { font-size: clamp(1.65rem, 8vw, 2.4rem); }

  /* Stats: 2 columnas (override 1-col existente) */
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .stat-card  { padding: 20px 16px; }
  .stat-card__number { font-size: 1.5rem; white-space: normal; }

  /* Brands */
  .brands-bar__img { height: 24px; max-width: 76px; }

  /* Services */
  .service-card__head { padding: 18px 20px 14px; }
  .service-card__body { padding: 18px 20px; }

  /* Contact form */
  .contact-form { padding: 20px 16px; }

  /* Lifecycle banner */
  .lifecycle-banner { padding: 16px; }
  .lifecycle-banner__text { font-size: 0.88rem; }

  /* Timeline */
  .timeline__hours  { font-size: 0.95rem; }
  .timeline__event  { font-size: 0.68rem; }
  .timeline-warning { padding: 12px 14px; font-size: 0.8rem; }
  .timeline-warning-icon { font-size: 1rem; }

  /* Mision cards */
  .mision-card { padding: 24px 20px; }

  /* Diag phases */
  .diag-phase { padding: 24px 20px; }

  /* CTA strip */
  .sector-cta-strip       { padding: 32px 0; }
  .sector-cta-strip__title { font-size: 1.3rem; }
  .sector-cta-strip__sub   { font-size: 0.875rem; }

  /* Footer */
  .footer { padding: 28px 0 16px; }
  .footer__inner { gap: 20px; }

  /* WhatsApp */
  .wa-btn { bottom: 16px; right: 14px; width: 48px; height: 48px; }

  /* FAQ */
  .faq-q    { font-size: 0.9rem; padding: 16px 0; gap: 12px; }
  .faq-list { margin-top: 28px; }

  /* FC modal */
  .fc-modal__head  { padding: 20px 20px 16px; }
  .fc-modal__title { font-size: 1.2rem; }
  .fc-modal__inputs,
  .fc-modal__results { padding: 20px 20px; }
  .fc-kpi__value   { font-size: 1.8rem; }
}

/* ── 375px: iPhone SE / pantallas muy pequeñas ───────────────────────────── */
@media (max-width: 375px) {
  .container { padding: 0 14px; }
  .navbar__logo img  { height: 32px; }
  .hero__headline    { font-size: 2rem; }
  .section-title     { font-size: 1.4rem; }
  .stat-card__number { font-size: 1.3rem; }
  .btn               { padding: 11px 18px; font-size: 0.82rem; }
  .sector-cta-strip__title { font-size: 1.15rem; }
  .faq-q { font-size: 0.85rem; }
}

/* ─── PRINT / PDF ───────────────────────────────────────────────────────── */
/* Ocultos en pantalla, visibles solo al imprimir */
.calc-print-header,
.calc-print-hrule,
.calc-print-footer { display: none; }

@media print {
  nav, .sector-hero, .sector-page__main, .sector-page__sidebar,
  .sector-cta-strip, .footer, .calc-panel--inputs,
  .maint-dashboard, .calc-pdf, .calc-smart-cta .btn,
  .calc-instructions { display: none !important; }

  .calc-wrapper { grid-template-columns: 1fr; }
  .calc-panel--results {
    display: block !important;
    box-shadow: none !important;
    border: none !important;
    padding: 0 !important;
  }
  body { font-size: 12px; }

  /* ── Cabecera de impresión ── */
  .calc-print-header {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
  }
  .calc-print-header__brand {
    display: flex;
    align-items: center;
    gap: 12px;
  }
  .calc-print-logo { height: 38px; width: auto; }
  .calc-print-company {
    font-size: 17px;
    font-weight: 800;
    color: #1B2A6B;
    line-height: 1.1;
  }
  .calc-print-tagline {
    font-size: 9px;
    color: #7A8DAA;
    letter-spacing: 0.03em;
  }
  .calc-print-meta { text-align: right; }
  .calc-print-sector-name {
    font-size: 11px;
    font-weight: 700;
    color: #1B2A6B;
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .calc-print-date {
    font-size: 9px;
    color: #7A8DAA;
    margin-top: 2px;
  }
  .calc-print-hrule {
    display: block !important;
    height: 2px;
    background: #1B2A6B;
    margin-bottom: 22px;
  }

  /* ── Pie de impresión ── */
  .calc-print-footer { display: block !important; }
  .calc-print-footer__rule {
    height: 1px;
    background: #ddd;
    margin: 24px 0 16px;
  }
  .calc-print-footer__body {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .calc-print-sig__name {
    font-size: 13px;
    font-weight: 700;
    color: #1B2A6B;
    margin-bottom: 3px;
  }
  .calc-print-sig__title {
    font-size: 10px;
    color: #54585A;
  }
  .calc-print-sig__co {
    font-size: 9px;
    color: #7A8DAA;
    margin-top: 2px;
  }
  .calc-print-contact {
    text-align: right;
    font-size: 9.5px;
    color: #54585A;
    line-height: 1.65;
  }
  .calc-print-disclaimer {
    font-size: 8px;
    color: #9CA3AF;
    line-height: 1.5;
    border-top: 1px solid #eee;
    padding-top: 10px;
    margin-top: 14px;
  }
}

/* ===================================================
   QUIÉNES SOMOS — INTRO TEXT & STATS
   =================================================== */
.qs-lead {
  font-size: 1.12rem;
  line-height: 1.75;
  color: var(--gray);
  max-width: 820px;
  margin-bottom: 40px;
}
.qs-stats-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin: 0 0 40px;
}
.qs-stat {
  background: var(--bg-alt);
  border: 1px solid var(--border);
  border-left: 3px solid var(--navy);
  border-radius: var(--radius);
  padding: 20px 16px;
  text-align: center;
}
.qs-stat--red  { border-left-color: var(--red); }
.qs-stat--blue { border-left-color: var(--blue); }
.qs-stat--green{ border-left-color: var(--green); }
.qs-stat__num {
  font-size: 2.1rem;
  font-weight: 800;
  color: var(--navy);
  line-height: 1;
  margin-bottom: 6px;
}
.qs-stat__num span { color: var(--red); }
.qs-stat--red  .qs-stat__num { color: var(--red); }
.qs-stat--blue .qs-stat__num { color: var(--blue); }
.qs-stat--green.qs-stat__num { color: var(--green); }
.qs-stat__label {
  font-size: 0.75rem;
  color: var(--muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.qs-body-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-bottom: 0;
}
.qs-body-grid p {
  font-size: 0.95rem;
  line-height: 1.8;
  color: var(--gray);
  margin: 0 0 16px;
}
.qs-body-grid p:last-child { margin-bottom: 0; }
.qs-highlight {
  background: var(--navy);
  border-radius: var(--radius);
  padding: 28px 32px;
}
.qs-highlight__label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.45);
  margin-bottom: 12px;
}
.qs-highlight p {
  color: rgba(255,255,255,0.85) !important;
  font-size: 0.95rem;
  line-height: 1.8;
  margin: 0 0 16px !important;
}
.qs-highlight p:last-child { margin-bottom: 0 !important; }
.qs-highlight strong { color: #fff; font-weight: 700; }

/* ===================================================
   PROJECT TIMELINE (vertical, year-based)
   =================================================== */
.proj-timeline {
  margin-top: 48px;
  position: relative;
}
.proj-timeline__entry {
  display: grid;
  grid-template-columns: 72px 32px 1fr;
  gap: 0 16px;
  align-items: start;
}
.proj-timeline__year {
  text-align: right;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--navy);
  padding-top: 13px;
  line-height: 1;
  letter-spacing: -0.02em;
}
.proj-timeline__connector {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.proj-timeline__dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--navy);
  border: 3px solid #fff;
  box-shadow: 0 0 0 2px var(--navy);
  margin-top: 15px;
  flex-shrink: 0;
  z-index: 1;
}
.proj-timeline__stem {
  flex: 1;
  width: 2px;
  background: var(--border);
  min-height: 28px;
}
.proj-timeline__entry:last-child .proj-timeline__stem {
  background: transparent;
}
.proj-timeline__content {
  padding: 4px 0 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.proj-item {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 18px;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.proj-item:hover {
  border-color: rgba(27,42,107,0.35);
  box-shadow: var(--shadow);
}
.proj-item__header {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 6px;
}
.proj-item__location {
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--navy);
}
.proj-item__tag {
  font-size: 0.68rem;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.proj-item__tag--ceramica    { background:#FFF0DC; color:#8B4500; }
.proj-item__tag--textil      { background:#E4EEFF; color:#1B2A6B; }
.proj-item__tag--agro        { background:#E3F8ED; color:#1A7A50; }
.proj-item__tag--siderurgica { background:#EFEFEF; color:#444; }
.proj-item__tag--oil         { background:#FFF8DC; color:#7A5200; }
.proj-item__tag--madera      { background:#EDF8DC; color:#3D6B00; }
.proj-item__tag--plasticos   { background:#FFE8F8; color:#880060; }
.proj-item__tag--envases     { background:#DCF4FF; color:#005E7A; }
.proj-item__tag--biogas      { background:#E6F4E0; color:#2D6A1F; }
.proj-item__cap {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--red);
  margin-left: auto;
}
.proj-item__type {
  font-size: 0.75rem;
  color: var(--blue);
  font-weight: 600;
  background: rgba(45,109,181,0.08);
  padding: 1px 8px;
  border-radius: 4px;
  margin-bottom: 6px;
  display: inline-block;
}
.proj-item__desc {
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}

/* ===================================================
   EXPERIENCE CARDS GRID
   =================================================== */
.exp-intro-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 24px;
  margin-bottom: 32px;
}
.exp-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.exp-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition);
}
.exp-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(27,42,107,0.1);
}
.exp-card__top {
  padding: 12px 18px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.exp-card__sector {
  font-size: 0.68rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.exp-card__year {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--muted);
}
.exp-card__body {
  padding: 16px 18px 20px;
}
.exp-card__location {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 4px;
}
.exp-card__cap {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--red);
  margin-bottom: 8px;
}
.exp-card__type {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--blue);
  background: rgba(45,109,181,0.08);
  border-radius: 4px;
  padding: 2px 8px;
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.exp-card__desc {
  font-size: 0.82rem;
  line-height: 1.65;
  color: var(--muted);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.exp-section-label {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 40px 0 20px;
}
.exp-section-label__title {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--navy);
  white-space: nowrap;
}
.exp-section-label__line {
  flex: 1;
  height: 1px;
  background: var(--border);
}

/* Responsive overrides */
@media (max-width: 1024px) {
  .qs-stats-strip  { grid-template-columns: repeat(2, 1fr); }
  .qs-body-grid    { grid-template-columns: 1fr; }
  .exp-cards       { grid-template-columns: repeat(2, 1fr); }
  .exp-intro-grid  { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .qs-stats-strip           { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .exp-cards                { grid-template-columns: 1fr; }
  .proj-timeline__entry     { grid-template-columns: 52px 24px 1fr; gap: 0 10px; }
  .proj-timeline__year      { font-size: 0.85rem; }
  .proj-timeline__dot       { width: 12px; height: 12px; }
}
