/* ===========================
   BiTherm – Industrial Premium (Light)
   Full CSS
   =========================== */

:root{
  /* Surfaces */
  --bg: #f5f7fb;
  --surface: #ffffff;
  --surface-2: #fbfcfe;

  /* Text */
  --text: #0b1b2b;
  --muted: #526170;
  --muted-2:#6b7a8a;

  /* Brand */
  --brand: #0070a1;     /* corporate blue */
  --brand-2: #6c9128;   /* corporate green */
  --brand-soft: rgba(0,112,161,.12);
  --brand-2-soft: rgba(108,145,40,.14);

  /* Borders & Shadows */
  --line: rgba(11,27,43,.10);
  --line-2: rgba(11,27,43,.06);
  --shadow-sm: 0 6px 18px rgba(13, 29, 46, .08);
  --shadow-md: 0 14px 34px rgba(13, 29, 46, .12);

  /* Layout */
  --radius: 16px;
  --radius-lg: 22px;
  --max: 1240px;
  --pad: 22px;

  /* Typography */
  --font: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family: var(--font);
  background:
    radial-gradient(1200px 700px at 15% -10%, var(--brand-soft), transparent 55%),
    radial-gradient(900px 600px at 90% 0%, var(--brand-2-soft), transparent 55%),
    linear-gradient(180deg, var(--bg) 0%, #ffffff 60%);
  color: var(--text);
  line-height: 1.55;
}

/* Links / Media */
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* Containers */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad);}
.section{padding:84px 0}
.section.sm{padding:56px 0}
.section-alt{
  background:
    radial-gradient(900px 420px at 10% 20%, rgba(0,112,161,.08), transparent 60%),
    radial-gradient(800px 420px at 90% 10%, rgba(108,145,40,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(250,252,255,.98));
  border-top: 1px solid var(--line-2);
  border-bottom: 1px solid var(--line-2);
}
.section-contrast-blue{
  background:
    radial-gradient(900px 420px at 15% 20%, rgba(0,112,161,.22), transparent 60%),
    linear-gradient(180deg, rgba(0,112,161,.08), rgba(0,112,161,.04));
  border-top: 1px solid rgba(0,112,161,.14);
  border-bottom: 1px solid rgba(0,112,161,.10);
}
.section-contrast-green{
  background:
    radial-gradient(900px 420px at 85% 10%, rgba(108,145,40,.22), transparent 60%),
    linear-gradient(180deg, rgba(108,145,40,.08), rgba(108,145,40,.04));
  border-top: 1px solid rgba(108,145,40,.14);
  border-bottom: 1px solid rgba(108,145,40,.10);
}
.section-contrast-mix{
  background:
    radial-gradient(900px 420px at 12% 20%, rgba(0,112,161,.20), transparent 60%),
    radial-gradient(900px 420px at 88% 10%, rgba(108,145,40,.20), transparent 60%),
    linear-gradient(180deg, rgba(0,112,161,.06), rgba(108,145,40,.04));
  border-top: 1px solid rgba(11,27,43,.08);
  border-bottom: 1px solid rgba(11,27,43,.08);
}
.section-evolution{
  background:
    radial-gradient(1000px 480px at 15% 10%, rgba(0,112,161,.12), transparent 60%),
    radial-gradient(1000px 480px at 85% 20%, rgba(108,145,40,.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(250,252,255,.98));
  border-top: 1px solid var(--line-2);
  border-bottom: 1px solid var(--line-2);
}
.section-awards{
  background:
    radial-gradient(900px 420px at 10% 20%, rgba(0,112,161,.12), transparent 60%),
    radial-gradient(900px 420px at 90% 10%, rgba(108,145,40,.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(250,252,255,.98));
  border-top: 1px solid var(--line-2);
  border-bottom: 1px solid var(--line-2);
}
.section-references{
  background:
    radial-gradient(900px 420px at 15% 10%, rgba(0,112,161,.12), transparent 60%),
    radial-gradient(900px 420px at 85% 20%, rgba(108,145,40,.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(250,252,255,.98));
  border-top: 1px solid var(--line-2);
  border-bottom: 1px solid var(--line-2);
}
.refs-grid{
  display:grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.ref-card{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 12px 14px;
  box-shadow: var(--shadow-sm);
}
.ref-card[open]{
  border-color: rgba(0,112,161,.22);
  box-shadow: 0 14px 30px rgba(0,112,161,.12);
}
.ref-header{
  list-style: none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  cursor: pointer;
  font-weight: 900;
  color: var(--text);
}
.ref-header::-webkit-details-marker{display:none}
.ref-meta{
  color: var(--muted);
  font-weight: 700;
  font-size: .9rem;
}
.ref-list{
  margin: 10px 0 0;
  padding-left: 18px;
  color: var(--muted);
}
.ref-list li{margin: 6px 0;}
@media (max-width: 900px){
  .refs-grid{grid-template-columns: 1fr;}
}
.awards-grid{
  display:grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.award-card{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: var(--shadow-sm);
  text-align: center;
}
.award-card img{
  height: 110px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  margin: 4px auto 10px;
}
.award-medals{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  margin: 4px 0 10px;
}
.award-medals img{
  height: 64px;
  margin: 0;
}
.award-card h3{
  margin: 0 0 6px;
  font-size: 1rem;
}
.award-card .small{
  margin: 0;
}
@media (max-width: 900px){
  .awards-grid{grid-template-columns: 1fr;}
  .award-card img{height: 96px;}
  .award-medals img{height: 56px;}
}
.timeline{
  margin-top: 22px;
  display:grid;
  gap: 16px;
}
.timeline-item{
  display:grid;
  grid-template-columns: 140px 1fr;
  gap: 16px;
  align-items: start;
}
.timeline-badge{
  align-self: stretch;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 14px;
  font-weight: 900;
  letter-spacing: .02em;
  color: #ffffff;
  background: linear-gradient(135deg, var(--brand), #0b88c2);
  min-height: 64px;
  box-shadow: 0 10px 24px rgba(0,112,161,.18);
}
.timeline-card{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: var(--shadow-sm);
}
.timeline-card h3{
  margin: 0 0 8px;
  font-size: 1.02rem;
  letter-spacing: -0.01em;
}
.timeline-card ul{
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
}
.timeline-card li{
  margin: 6px 0;
}
.timeline-item.highlight .timeline-badge{
  background: linear-gradient(135deg, var(--brand-2), #7aa13a);
  box-shadow: 0 10px 24px rgba(108,145,40,.18);
}
.timeline-item.highlight .timeline-card{
  border-color: rgba(108,145,40,.28);
  box-shadow: 0 16px 34px rgba(108,145,40,.12);
}
.evolution-claims{
  margin-top: 22px;
  display:grid;
  gap: 8px;
}
.evolution-claim{
  text-align:center;
  font-weight: 900;
  letter-spacing: .01em;
}
.evolution-claim.strong{
  color: var(--brand);
  font-size: 1.1rem;
}
.evolution-claim.accent{
  color: var(--brand-2);
  font-size: 1.02rem;
}
@media (max-width: 900px){
  .timeline-item{
    grid-template-columns: 1fr;
  }
  .timeline-badge{
    justify-self: start;
    min-height: 44px;
    padding: 0 14px;
  }
}
.hr{border:0;border-top:1px solid var(--line); margin:0}

/* Type scale */
.kicker{
  color: var(--brand-2);
  font-weight: 800;
  letter-spacing: .10em;
  text-transform: uppercase;
  font-size: .78rem;
}
.h1{
  font-size: clamp(2.0rem, 3.2vw, 3.05rem);
  line-height: 1.12;
  margin: .55rem 0 1.1rem;
  letter-spacing: -0.02em;
  font-weight: 800;
}
.h2{
  font-size: clamp(1.55rem, 2.3vw, 2.15rem);
  line-height: 1.18;
  margin: .4rem 0 1rem;
  letter-spacing: -0.01em;
  font-weight: 800;
}
.p{
  color: var(--muted);
  font-size: 1.05rem;
  max-width: 70ch;
  font-weight: 400;
}
.small{
  font-size: .92rem;
  color: var(--muted-2);
}

/* ===========================
   Utilities (Layout/Spacing)
   =========================== */
.u-mt-8{margin-top:8px;}
.u-mt-10{margin-top:10px;}
.u-mt-12{margin-top:12px;}
.u-mt-14{margin-top:14px;}
.u-mt-16{margin-top:16px;}
.u-mt-18{margin-top:18px;}
.u-mt-20{margin-top:20px;}
.u-mt-22{margin-top:22px;}
.u-pad-18{padding:18px;}
.u-card-media{padding:0; overflow:hidden;}
.u-flex-wrap-gap{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.u-flex-end-wrap{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.u-divider-14{
  margin:14px 0;
}

/* Shared hero/background helpers moved from page-level <style> blocks */
.scroll-smooth{scroll-behavior:smooth;}
.hero-bg{
  background-image: linear-gradient(rgba(15, 23, 42, 0.68), rgba(15, 23, 42, 0.56)), url("../img/backgrounds/hero-bg.png");
  background-size: 125%;
  background-position: center 35%;
}
.hero-bg-en{
  background-image: linear-gradient(rgba(15, 23, 42, 0.85), rgba(15, 23, 42, 0.75)), url("https://images.unsplash.com/photo-1565514020126-11444d32de78?ixlib=rb-1.2.1&auto=format&fit=crop&w=1950&q=80");
}
.hero-overlay-grid{
  background-image: radial-gradient(#3b82f6 1px, transparent 1px);
  background-size: 32px 32px;
}
.contact-hero-bg{
  background-color: #0f172a;
  background-image: radial-gradient(#1e293b 1px, transparent 1px);
  background-size: 32px 32px;
}

/* ===========================
   Tailwind Color Fallbacks
   Keep custom btm* utilities consistent across pages.
   =========================== */
.bg-btmDark{background-color:#1e293b;}
.bg-btmBlue{background-color:#0070a1;}
.text-btmGreen{color:#6c9128;}
.border-btmGreen{border-color:#6c9128;}
.border-btmBlue{border-color:#0070a1;}
.hover\:bg-btmGreen:hover{background-color:#6c9128;}
.hover\:text-btmGreen:hover{color:#6c9128;}
.hover\:text-btmBlue:hover{color:#0070a1;}
.group:hover .group-hover\:bg-btmGreen{background-color:#6c9128;}
.from-btmBlue{
  --tw-gradient-from:#0070a1 var(--tw-gradient-from-position);
  --tw-gradient-to:rgb(0 112 161 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to);
}
.via-btmGreen{
  --tw-gradient-to:rgb(108 145 40 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops:var(--tw-gradient-from),#6c9128 var(--tw-gradient-via-position),var(--tw-gradient-to);
}
.to-btmBlue{--tw-gradient-to:#0070a1 var(--tw-gradient-to-position);}
.claims{
  margin: 12px 0 14px;
  display:grid;
  gap: 8px;
  max-width: 70ch;
}
.claim{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(0,112,161,.10);
  border: 1px solid rgba(0,112,161,.18);
  color: #184457;
  font-weight: 800;
  letter-spacing: .02em;
  font-size: .9rem;
}
@media (max-width: 900px){
  .claim{
    border-radius: 14px;
  }
}

/* ===========================
   Buttons
   =========================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  padding: 11px 16px;
  border-radius: 999px;
  border:1px solid rgba(11,27,43,.12);
  background: #fff;
  color: var(--text);
  white-space: nowrap;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  font-weight: 800;
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset;
}
.btn:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
  border-color: rgba(11,27,43,.16);
}
.btn.primary{
  background: linear-gradient(135deg, var(--brand), #0b88c2);
  border-color: transparent;
  color: #ffffff;
  box-shadow: 0 12px 28px rgba(0,112,161,.24);
}
.btn.primary:hover{
  box-shadow: 0 16px 34px rgba(0,112,161,.28);
}
.btn.ghost{
  background: transparent;
  border-color: rgba(11,27,43,.14);
}

/* ===========================
   Badge / Metric
   =========================== */
.badge{
  display:inline-flex;
  gap:.5rem;
  align-items:center;
  padding: 8px 12px;
  border-radius: 999px;
  border:1px solid rgba(0,112,161,.18);
  background: rgba(255,255,255,.85);
  color: #33566b;
  font-size: .92rem;
  backdrop-filter: blur(8px);
}
.metrics{display:flex; gap:10px; flex-wrap:wrap; margin-top:16px}
.metric{
  padding: 10px 12px;
  border-radius: 14px;
  border:1px solid rgba(11,27,43,.08);
  background: rgba(255,255,255,.86);
  box-shadow: 0 8px 20px rgba(13,29,46,.06);
}
.metric b{display:block}
.metric span{color:var(--muted); font-size:.9rem}

/* ===========================
   Grid
   =========================== */
.grid{display:grid; gap:18px;}
.grid.two{grid-template-columns: repeat(2, minmax(0,1fr));}
.grid.three{grid-template-columns: repeat(3, minmax(0,1fr));}
.grid.four{grid-template-columns: repeat(4, minmax(0,1fr));}
@media (max-width: 900px){
  .grid.two,.grid.three,.grid.four{grid-template-columns: 1fr}
}

/* ===========================
   Card
   =========================== */
.card{
  background: var(--surface);
  border: 1px solid rgba(11,27,43,.08);
  border-radius: var(--radius-lg);
  box-shadow: 0 14px 28px rgba(13,29,46,.08);
  padding: 20px;
}
.card.soft{
  box-shadow: none;
  background: var(--surface-2);
  border-color: rgba(11,27,43,.07);
}
.card h3{
  margin: .2rem 0 .45rem;
  font-size: 1.12rem;
  letter-spacing: -0.01em;
}
.card p{
  margin: .2rem 0 0;
  color: var(--muted);
}

/* ===========================
   Navbar
   =========================== */
.nav{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.92);
  border-bottom: 1px solid rgba(11,27,43,.08);
  backdrop-filter: blur(10px);
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height: 72px;
  gap: 18px;
}
.nav, .nav *{
  font-family: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  letter-spacing: 0;
}
.brand{
  display:flex;
  align-items:center;
  gap: .8rem;
  font-weight: 900;
  letter-spacing: -0.01em;
}
.brand img{
  height: 38px;
  width: auto;
  object-fit: contain;
}
.nav-links{
  display:flex;
  align-items:center;
  gap: 18px;
  margin-left: 10px;
  position: relative;
}
.nav-links a{
  padding: 10px 14px;
  border-radius: 999px;
  color: var(--muted);
  font-weight: 700;
  font-size: 15px;
}
.nav-links a.active{
  color: var(--brand-2);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 6px;
}
.nav-links a:hover{
  background: rgba(11,27,43,.04);
  color: var(--text);
}
.nav-cta{
  display:flex;
  align-items:center;
  gap: 10px;
}
.lang-switch{
  margin-left: 6px;
}
.lang-switch{
  position: relative;
}
.lang-toggle{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.7);
  font-weight: 800;
  font-size: .82rem;
  color: var(--text);
}
.lang-toggle .lang-chev{
  margin-left: 2px;
  display:inline-flex;
  align-items:center;
}
.lang-toggle img{
  width: 18px;
  height: 18px;
  border-radius: 999px;
}
.lang-chev{
  font-size: .7rem;
  color: var(--muted);
}
.lang-menu{
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  min-width: 120px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
  padding: 6px;
  display: none;
  z-index: 60;
}
.lang-switch.open .lang-menu{display:block;}
.lang-option{
  display:flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 8px;
  color: var(--text);
  font-weight: 800;
  font-size: .82rem;
}
.lang-option img{
  width: 18px;
  height: 18px;
  border-radius: 999px;
}
.lang-option:hover{
  background: rgba(11,27,43,.06);
}
.lang-option.active{
  background: rgba(0,112,161,.12);
  color: var(--brand);
}
.burger{display:none}

/* Mobile menu */
.mobile{
  display:none;
  padding: 10px 0 16px;
}
.mobile.open{display:block}
.mobile a{
  display:block;
  padding: 12px 10px;
  border-radius: 12px;
  color: var(--muted);
  font-weight: 850;
}
.mobile a.active{
  color: var(--brand-2);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
}
.mobile a:hover{
  background: rgba(11,27,43,.04);
  color: var(--text);
}

@media (max-width: 900px){
  .nav-links{display:none}
  .burger{display:inline-flex}
}

/* IMPORTANT:
   If you see "SolucionesProductoServicios..." under the navbar,
   it's usually the mobile menu showing. This improves separation. */
.mobile.open{
  border-top: 1px solid rgba(11,27,43,.08);
  margin-top: 8px;
}

.nav-product-flyout{
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  transform: translateX(-50%);
  width: min(980px, calc(100vw - 80px));
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,255,.98));
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 18px;
  box-shadow:
    0 28px 56px rgba(15,23,42,.20),
    0 1px 0 rgba(255,255,255,.85) inset;
  padding: 18px;
  z-index: 70;
  display: none;
  backdrop-filter: blur(4px);
}
.nav-product-flyout.open{
  display: block;
}
.nav-product-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.nav-product-col{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  background: #ffffff;
  padding: 14px 14px 12px;
  min-height: 240px;
}
.nav-product-title{
  display:block;
  margin: 0 0 10px;
  font-weight: 900;
  color: #132a44;
  font-size: 1rem;
  line-height: 1.25;
  letter-spacing: -.01em;
  border-radius: 10px;
  padding: 6px 8px;
  transition: background .2s ease, color .2s ease;
}
.nav-product-title:hover{
  background: rgba(128, 165, 35, .14);
  color: #2f4f11;
}
.nav-product-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display:grid;
  gap: 4px;
}
.nav-product-list a{
  display:flex;
  align-items:center;
  gap: 8px;
  border-radius: 10px;
  padding: 8px 9px;
  color: #334155;
  font-weight: 800;
  font-size: .85rem;
  line-height: 1.25;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.nav-product-list a::before{
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: rgba(71,85,105,.55);
  flex: 0 0 auto;
}
.nav-product-list a:hover{
  background: rgba(128, 165, 35, .14);
  color: #2f4f11;
  transform: translateX(2px);
}
.nav-product-list a:hover::before{
  background: #7fa323;
}
@media (max-width: 1120px){
  .nav-product-flyout{
    width: min(920px, calc(100vw - 40px));
  }
  .nav-product-grid{
    grid-template-columns: 1fr 1fr;
  }
  .nav-product-col:last-child{
    grid-column: 1 / -1;
    min-height: auto;
  }
}

.mobile-product{
  margin-top: 8px;
  border-top: 1px solid rgba(11,27,43,.08);
  padding-top: 8px;
}
.mobile-product-toggle{
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 10px;
  border: 0;
  background: transparent;
  color: var(--text);
  font-weight: 900;
  font-size: .95rem;
  border-radius: 12px;
  cursor: pointer;
}
.mobile-product-toggle:hover{
  background: rgba(11,27,43,.04);
}
.mobile-product-toggle .chev{
  color: #64748b;
  transition: transform .2s ease;
}
.mobile-product.open .mobile-product-toggle .chev{
  transform: rotate(180deg);
}
.mobile-product-panel{
  display: none;
  margin: 4px 0 6px;
  padding: 0 4px;
}
.mobile-product.open .mobile-product-panel{
  display: block;
}
.mobile-product-section{
  background: #f8fafc;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 12px;
  padding: 10px;
}
.mobile-product-section + .mobile-product-section{
  margin-top: 8px;
}
.mobile-product-section-title{
  display: block;
  color: #16324b;
  font-weight: 900;
  font-size: .86rem;
  margin-bottom: 6px;
}
.mobile-product-links{
  display: grid;
  gap: 2px;
}
.mobile-product-links a{
  display: block;
  border-radius: 8px;
  padding: 7px 8px;
  color: #334155;
  font-weight: 700;
  font-size: .82rem;
}
.mobile-product-links a:hover{
  background: rgba(128, 165, 35, .12);
  color: #2f4f11;
}

/* ===========================
   Hero
   =========================== */
.hero{padding: 66px 0 26px;}
.pilot-hero{
  position: relative;
  padding: 84px 0 56px;
  color: #e7eef6;
}
.pilot-hero-bg{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(9,15,20,.88), rgba(9,15,20,.76)),
    url("../img/backgrounds/hero-bg.png");
  background-size: cover;
  background-position: center;
}
.pilot-hero-grid{
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 28px;
  align-items: center;
}
.pilot-hero-copy{animation: rise .55s ease-out both;}
.pilot-hero-media{animation: rise .65s ease-out both;}
.pilot-badge{
  display:inline-flex;
  align-items:center;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0,112,161,.35);
  background: rgba(0,112,161,.18);
  color: #d8ecf7;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .72rem;
}
.pilot-title{
  font-size: clamp(2.2rem, 3.2vw, 3.2rem);
  line-height: 1.12;
  margin: 14px 0 12px;
  letter-spacing: -0.02em;
  color: #f4f7fb;
}
.pilot-lead{
  color: #c7d3df;
  font-size: 1.08rem;
  max-width: 65ch;
}
.pilot-claims{
  margin: 14px 0 16px;
  display:grid;
  gap: 8px;
}
.pilot-claims div{
  display:inline-flex;
  align-items:center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.22);
  color: #e7eef6;
  font-weight: 800;
  font-size: .9rem;
  letter-spacing: .02em;
}
.pilot-cta{display:flex; gap:10px; flex-wrap:wrap; margin-top: 6px;}
.pilot-proof{margin-top: 10px; color:#a9bbcb; font-weight: 700; font-size: .9rem;}
.pilot-scope{
  background: rgba(14,20,28,.78);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: 0 18px 44px rgba(0,0,0,.35);
}
.pilot-scope h3{
  margin: 0 0 12px;
  font-size: 1.02rem;
  color: #e7eef6;
}
.pilot-scope-item{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 10px 0;
}
.pilot-scope-item .dot{
  width:10px;height:10px;border-radius:999px;background: var(--brand);
  margin-top: 7px;flex:0 0 auto;
}
.pilot-scope-item b{color:#f2f6fb;}
.pilot-scope-item span{display:block;color:#a9bbcb;font-size:.92rem;}
.pilot-video{
  margin-top: 14px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(13,29,46,.35);
}
.pilot-video video{
  display:block;
  width:100%;
  height:100%;
  object-fit: cover;
}
.cta-card{
  border: 1px solid rgba(0,112,161,.18);
  box-shadow: 0 18px 40px rgba(0,112,161,.12);
}
.mini-chart{
  display:flex;
  gap: 8px;
  align-items:flex-end;
  height: 56px;
  margin-top: 12px;
}
.mini-bar{
  width: 18%;
  height: 60%;
  background: linear-gradient(180deg, rgba(0,112,161,.9), rgba(0,112,161,.35));
  border-radius: 6px;
}
.mini-bar:nth-child(2){height: 35%;}
.mini-bar:nth-child(3){height: 80%;}
.mini-bar:nth-child(4){height: 45%;}
.mini-bar:nth-child(5){height: 70%;}
@media (max-width: 900px){
  .pilot-hero-grid{grid-template-columns: 1fr;}
}
.hero-bna{
  position: relative;
  color: #e7eef6;
}
.hero-bna-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(9,15,20,.88), rgba(9,15,20,.78)),
    url("../img/backgrounds/hero-bg.png");
  background-size: cover;
  background-position: center;
}
.hero-bna-wrap{
  position: relative;
  z-index: 1;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 26px;
  align-items: center;
}
.hero-bna-left{animation: rise .55s ease-out both;}
.hero-bna-right{animation: rise .65s ease-out both;}
.h1-invert{color:#f4f7fb;}
.h2-invert{color:#f4f7fb;}
.p-invert{color:#c7d3df;}
.small-invert{color:#a9bbcb;}
.badge-invert{
  border-color: rgba(0,112,161,.35);
  background: rgba(0,112,161,.18);
  color: #d8ecf7;
}
.claim-invert{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.22);
  color: #e7eef6;
}
.hero-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.claims-compact .claim{
  padding: 7px 10px;
  font-size: .85rem;
}
.hero-benefits{
  margin: 12px 0 6px;
  display:grid;
  gap: 10px;
}
.hero-benefit{
  display:flex;
  gap: 12px;
  align-items:flex-start;
}
.benefit-icon{
  width: 18px;
  height: 18px;
  border-radius: 6px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size: .75rem;
  font-weight: 900;
  color: #fff;
  margin-top: 4px;
  flex: 0 0 auto;
}
.benefit-blue{background: var(--brand);}
.benefit-green{background: var(--brand-2);}
.hero-video-frame{
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 20px 50px rgba(0,0,0,.35);
}
.solutions-hero-dark .btn.ghost{
  color: #e7eef6;
  border-color: rgba(255,255,255,.35);
  background: rgba(255,255,255,.06);
}
.solutions-hero-dark .btn.ghost:hover{
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.5);
}
.bna-card{
  background: rgba(14,20,28,.78);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: 0 18px 44px rgba(0,0,0,.35);
}
.bna-card h3{
  margin: 0 0 12px;
  font-size: 1.02rem;
  color: #e7eef6;
}
.bna-item{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 10px 0;
}
.bna-item .small{color:#a9bbcb;}
.bna-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-top: 7px;
  flex: 0 0 auto;
}
.bna-dot-blue{background: var(--brand);}
.bna-dot-green{background: var(--brand-2);}
.hero-video{
  margin-top: 14px;
}
.hero-video.hero-visual-dynamic{
  width: 100%;
}
@media (max-width: 900px){
  .hero-bna-wrap{grid-template-columns: 1fr;}
}
.hero-wrap{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items: center;
}
@media (max-width: 900px){ .hero-wrap{grid-template-columns: 1fr} }

.hero-visual{
  border-radius: var(--radius-lg);
  border: 1px solid rgba(11,27,43,.10);
  overflow:hidden;
  background: #fff;
  box-shadow: 0 18px 40px rgba(7, 30, 46, .12);
}
.hero-visual img{
  width:100%;
  height:100%;
  object-fit: cover;
}

/* ===========================
   Logos row
   =========================== */
.logo-row{
  display:grid;
  grid-template-columns: repeat(6, minmax(0,1fr));
  gap: 12px;
  align-items: center;
}
.logo{
  height: 44px;
  border: 1px solid rgba(11,27,43,.10);
  background: rgba(255,255,255,.9);
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(11,27,43,.55);
  font-weight: 900;
  font-size: .9rem;
}
.logo img{
  max-height: 34px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  filter: saturate(1.05);
}
.logo-row-plain{
  gap: 24px;
}
.logo-plain{
  height: 64px;
  border: none;
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
}
.logo-plain img{
  max-height: 54px;
}
.logo-carousel{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(11,27,43,.08);
  background: linear-gradient(180deg, #ffffff, #f7fafc);
  padding: 18px 0;
}
.logo-carousel::before,
.logo-carousel::after{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 72px;
  pointer-events: none;
  z-index: 1;
}
.logo-carousel::before{
  left: 0;
  background: linear-gradient(90deg, #f8fafc 0%, rgba(248,250,252,0) 100%);
}
.logo-carousel::after{
  right: 0;
  background: linear-gradient(270deg, #f8fafc 0%, rgba(248,250,252,0) 100%);
}
.logo-carousel-track{
  display: flex;
  align-items: center;
  gap: 20px;
  width: max-content;
  animation: logo-scroll 36s linear infinite;
}
.logo-carousel:hover .logo-carousel-track{
  animation-play-state: paused;
}
.logo-carousel .logo-plain{
  min-width: 180px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: rgba(255,255,255,.95);
  border: 1px solid rgba(11,27,43,.07);
}
.logo-carousel .logo-plain img{
  max-height: 46px;
  max-width: 140px;
}
@keyframes logo-scroll{
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@media (max-width: 900px){
  .logo-row{grid-template-columns: repeat(2, minmax(0,1fr))}
  .logo-carousel::before,
  .logo-carousel::after{
    width: 34px;
  }
  .logo-carousel .logo-plain{
    min-width: 140px;
    height: 62px;
  }
  .logo-carousel .logo-plain img{
    max-height: 38px;
    max-width: 110px;
  }
}

/* ===========================
   Footer
   =========================== */
.footer{
  padding: 46px 0;
  border-top: 1px solid rgba(11,27,43,.08);
  background: #ffffff;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr .8fr .8fr;
  gap: 18px;
}
.footer a{color: var(--muted)}
.footer a:hover{color: var(--text)}
@media (max-width: 900px){
  .footer-grid{grid-template-columns: 1fr}
}

/* ===========================
   Forms
   =========================== */
.form{display:grid; gap: 12px;}
.input, .textarea{
  width:100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(11,27,43,.12);
  background: #ffffff;
  color: var(--text);
  outline:none;
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset;
}
.input:focus, .textarea:focus{
  border-color: rgba(0,112,161,.35);
  box-shadow: 0 0 0 4px rgba(0,112,161,.10);
}
.textarea{min-height: 140px; resize: vertical}

/* ===========================
   Minor polish
   =========================== */
::selection{background: rgba(0,112,161,.18);}

.bullets{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px 16px;
  margin-top:16px;
  max-width: 900px;
}
.bullet{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color: var(--muted);
  font-size: 1rem;
}
.bullet b{color: var(--text)}
.dot{
  width:10px;height:10px;
  border-radius:999px;
  background: var(--brand);
  margin-top: 7px;
  flex: 0 0 auto;
}
@media (max-width:900px){
  .bullets{grid-template-columns: 1fr;}
}

.card.featured{
  border-color: rgba(0,112,161,.22);
  box-shadow: 0 18px 44px rgba(0,112,161,.10);
}

/* --- Hero spacing --- */
.hero-like{
  padding-bottom: 16px;
}

/* --- Flow (Medición → Diagnóstico → OT) --- */
.flow{
  margin-top: 18px;
  display:grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: 12px;
  align-items: stretch;
}

.flow-step{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 14px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(11,27,43,.08);
  box-shadow: 0 12px 26px rgba(13,29,46,.06);
}

.flow-icon{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), #0b88c2);
  flex: 0 0 auto;
}

.flow-title{
  font-weight: 900;
  letter-spacing: -0.01em;
  margin-top: 1px;
}

.flow-desc{
  color: var(--muted);
  font-size: .95rem;
  margin-top: 3px;
}

.flow-arrow{
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(11,27,43,.35);
  font-weight: 900;
  font-size: 1.2rem;
  user-select:none;
}

@media (max-width: 900px){
  .flow{
    grid-template-columns: 1fr;
  }
  .flow-arrow{
    display:none;
  }
}

/* ===========================
   HERO dinámico (fondo + overlay)
=========================== */
.hero-dynamic{
  position: relative;
  overflow: hidden;
}
.hero-dynamic .hero-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(1000px 520px at 20% 10%, rgba(0,112,161,.18), transparent 60%),
    radial-gradient(900px 520px at 85% 18%, rgba(108,145,40,.16), transparent 55%),
    linear-gradient(180deg, rgba(245,247,251,.78), rgba(245,247,251,.88)),
    url("../img/backgrounds/hero-bg.png");
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.02);
  transform: scale(1.03);
  z-index: 0;
}
.hero-wrap-dynamic{
  position: relative;
  z-index: 1;
}
.hero-left{animation: rise .55s ease-out both;}
.hero-right{
  animation: rise .65s ease-out both;
  display:block;
}

/* Panel imagen + overlay */
.hero-visual-dynamic{
  position: relative;
  overflow: hidden;
  background: transparent;
  border-radius: 12px;
  box-shadow: 0 18px 50px rgba(13,29,46,.12);
  width: min(500px, 100%);
  aspect-ratio: 3 / 2;
}
.hero-visual-dynamic img,
.hero-visual-dynamic video{
  display:block;
  width:100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 0;
  box-shadow: none;
}
.hero-visual-dynamic::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.0) 0%, rgba(255,255,255,.06) 40%, rgba(255,255,255,.18) 100%),
    radial-gradient(700px 420px at 70% 18%, rgba(0,112,161,.14), transparent 60%);
  pointer-events:none;
}

/* IIoT card superpuesta */
.iiot-card{
  position: absolute;
  right: 16px;
  bottom: 16px;
  width: min(360px, 92%);
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(11,27,43,.12);
  border-radius: 16px;
  box-shadow: 0 20px 50px rgba(7, 30, 46, .16);
  padding: 12px 12px;
  backdrop-filter: blur(8px);
}
.iiot-title{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap: 10px;
  padding: 4px 6px 10px;
  border-bottom: 1px solid rgba(11,27,43,.08);
}
.iiot-title b{letter-spacing:-.01em;}
.iiot-title span{color: var(--muted); font-weight: 800; font-size: .78rem; text-transform: uppercase; letter-spacing: .5px;}

.iiot-flow{display:grid; gap:8px; padding: 10px 6px 4px;}
.iiot-node{display:flex; gap:10px; align-items:center;}
.iiot-dot{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: rgba(0,112,161,.10);
  border: 1px solid rgba(0,112,161,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  color: rgba(11,27,43,.88);
  flex: 0 0 auto;
}
.iiot-node b{display:block;}
.iiot-arrow{
  text-align:center;
  color: rgba(11,27,43,.35);
  font-weight: 900;
  margin: -2px 0;
}

.hero-note{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color: #3f5b6d;
  margin-top: 10px;
  font-weight: 600;
}
.hero-note .dot{
  width:10px;height:10px;border-radius:999px;
  background: var(--brand);
  margin-top: 7px;
}

/* ===========================
   Cards con imagen (Cómo funciona)
=========================== */
.card-media{padding:0; overflow:hidden;}
.card-media .card-top{position:relative;}
.card-media img{
  width:100%;
  height: 160px;
  object-fit: cover;
  display:block;
  filter: saturate(1.03) contrast(1.02);
}
.card-media .chip{
  position:absolute;
  left: 12px;
  bottom: 12px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(11,27,43,.10);
  padding: 7px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: .82rem;
  box-shadow: 0 10px 22px rgba(13,29,46,.10);
}
.card-media .card-body{padding: 16px 16px 18px;}
.card-media .card-body p{margin:0; color: var(--muted);}

/* ===========================
   Animaciones suaves (sin marear)
=========================== */
@keyframes rise{
  from{transform: translateY(10px); opacity:0;}
  to{transform: translateY(0); opacity:1;}
}
@media (prefers-reduced-motion: reduce){
  .hero-left,.hero-right{animation:none;}
}

.brand img{
  height: 34px;
  width: auto;
  display: block;
  object-fit: contain;
}

/* Mejor integración visual de imágenes PNG */
.hero-visual-dynamic img,
.card-media img{
  background: #f7f9fc;
}

.hero {
  background-image:
    radial-gradient(circle at 20% 30%, rgba(0,112,161,.10), transparent 40%),
    radial-gradient(circle at 80% 60%, rgba(108,145,40,.10), transparent 45%);
}

.hero-visual {
  padding-left: 24px;
}

.hero-visual.hero-visual-dynamic{
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.card-step {
  position: relative;
}

.card-step:not(:last-child)::after {
  content: "→";
  position: absolute;
  right: -22px;
  top: 50%;
  transform: translateY(-50%);
  color: #cbd5e1;
  font-size: 20px;
}

/* Accessibility */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* ===========================
   Soluciones - generaciones + videos
   =========================== */
.gen-section{margin-top: 24px;}
.gen-timeline{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(7, minmax(160px, 1fr));
  gap: 16px;
  position: relative;
}
.gen-timeline::before{
  content:"";
  position:absolute;
  left: 0;
  right: 0;
  top: 18px;
  height: 2px;
  background: linear-gradient(90deg, rgba(0,112,161,.25), rgba(108,145,40,.25));
  z-index: 0;
}
.gen-node{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px;
  text-align: left;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  position: relative;
  z-index: 1;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.gen-node:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(0,112,161,.12);
  border-color: rgba(0,112,161,.25);
}
.gen-node.gen-active{
  border-color: rgba(0,112,161,.45);
  box-shadow: 0 20px 38px rgba(0,112,161,.18);
}
.gen-node.gen-active .gen-dot{
  background: #6c9128;
  animation: genPulse 1.6s ease-in-out infinite;
}
.gen-dot{
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--brand), #0b88c2);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  margin-bottom: 10px;
  box-shadow: 0 10px 22px rgba(0,112,161,.2);
}
.gen-title{
  display:block;
  font-weight: 900;
  margin-bottom: 4px;
}
.gen-sub{
  display:block;
  color: var(--muted);
  font-size: .9rem;
}
.sww-highlight{
  margin-top: 36px;
  padding: 28px;
  border-radius: 24px;
  background:
    linear-gradient(120deg, rgba(0,112,161,.08), rgba(108,145,40,.08)),
    #fff;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 18px 36px rgba(15,23,42,.08);
}
.tm{
  font-size: .55em;
  vertical-align: super;
  line-height: 0;
  letter-spacing: .02em;
}
.sww-highlight-dark{
  background:
    radial-gradient(1200px 420px at 10% 0%, rgba(0,112,161,.28), transparent 60%),
    radial-gradient(1200px 420px at 90% 100%, rgba(108,145,40,.22), transparent 60%),
    linear-gradient(180deg, #0d1824, #132235);
  border: 1px solid rgba(148,163,184,.24);
  box-shadow: 0 24px 44px rgba(9,15,20,.36);
}
.sww-highlight-dark .h2,
.sww-highlight-dark .p,
.sww-highlight-dark .small,
.sww-highlight-dark b{
  color: #e6eef7;
}
.sww-highlight-dark .kicker{
  color: #9cc248;
}
.sww-highlight-dark .sww-card{
  background: rgba(15,23,42,.64);
  border-color: rgba(148,163,184,.26);
  box-shadow: 0 16px 30px rgba(2,6,23,.35);
}
.sww-highlight-dark .sww-diagram{
  background: linear-gradient(180deg, rgba(30,41,59,.86), rgba(15,23,42,.82));
}
.sww-highlight-dark .sww-diagram-title,
.sww-highlight-dark .sww-diagram-foot{
  color: #dbe7f5;
}
.sww-highlight-dark .sww-node{
  color: #e6eef7;
  background: rgba(14,165,233,.12);
  border-color: rgba(56,189,248,.30);
}
.sww-highlight-dark .sww-quote{
  color: #dbe7f5;
  background: linear-gradient(135deg, rgba(108,145,40,.18), rgba(0,112,161,.22));
}
.sww-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 28px;
  align-items: center;
}
.sww-points{
  display:grid;
  gap: 12px;
  margin-top: 18px;
}
.sww-point{
  display:grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  align-items: start;
}
.sww-dot{
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: #6c9128;
  margin-top: 6px;
  box-shadow: 0 6px 14px rgba(108,145,40,.25);
}
.sww-dot-green{background:#6c9128;}
.sww-dot-blue{background:#0070a1;}
.sww-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 20px;
}
.sww-visual{
  display:grid;
  gap: 16px;
}
.sww-card{
  background: #fff;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 14px 28px rgba(15,23,42,.08);
  padding: 18px;
}
.sww-diagram{
  background: linear-gradient(180deg, #f7fbff, #ffffff);
}
.sww-diagram-title{
  font-weight: 800;
  margin-bottom: 12px;
  color: #0b2a3a;
}
.sww-diagram-body{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 10px;
  align-items: center;
}
.sww-node{
  text-align:center;
  padding: 10px 8px;
  border-radius: 12px;
  background: rgba(0,112,161,.08);
  color: #0b2a3a;
  font-weight: 700;
  font-size: .9rem;
  border: 1px solid rgba(0,112,161,.15);
}
.sww-line{
  height: 2px;
  background: linear-gradient(90deg, rgba(0,112,161,.3), rgba(108,145,40,.3));
  grid-column: span 4;
  border-radius: 999px;
}
.sww-diagram-foot{
  margin-top: 10px;
  font-size: .85rem;
  color: var(--muted);
}
.sww-stats{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.sww-stat{
  background: #0b2a3a;
  color: #fff;
  border-radius: 14px;
  padding: 14px;
  text-align: center;
}
.sww-stat-value{
  display:block;
  font-weight: 900;
  font-size: 1.2rem;
}
.sww-stat-label{
  font-size: .85rem;
  color: rgba(255,255,255,.75);
}
.sww-quote{
  font-size: .95rem;
  color: #0b2a3a;
  background: linear-gradient(135deg, rgba(108,145,40,.08), rgba(0,112,161,.08));
}
@media (max-width: 980px){
  .sww-grid{grid-template-columns: 1fr;}
  .sww-stats{grid-template-columns: 1fr;}
  .sww-diagram-body{grid-template-columns: 1fr;}
  .sww-line{display:none;}
}
.faq-table{
  margin-top: 34px;
  padding: 26px;
  border-radius: 22px;
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 16px 30px rgba(15,23,42,.08);
}
.faq-table-header{
  display:flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-end;
  flex-wrap: wrap;
}
.faq-search{
  display:flex;
  flex-direction: column;
  gap: 6px;
  min-width: 220px;
}
.faq-search input{
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(15,23,42,.15);
  outline: none;
}
.faq-table-grid{
  margin-top: 18px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(15,23,42,.08);
}
.faq-table-row{
  display:grid;
  grid-template-columns: 1.1fr 1.4fr;
  gap: 16px;
  padding: 14px 16px;
  background: #fff;
  border-top: 1px solid rgba(15,23,42,.08);
}
.faq-table-row:first-child{border-top: none;}
.faq-table-row:nth-child(odd){
  background: rgba(0,112,161,.04);
}
.faq-q{
  font-weight: 700;
  color: #0b2a3a;
}
.faq-a{
  color: #1f2937;
}
.faq-empty{
  padding: 18px;
  text-align: center;
  color: var(--muted);
}
@media (max-width: 900px){
  .faq-table-row{
    grid-template-columns: 1fr;
  }
}

.solutions-outro{
  border-radius: 24px;
  padding: 26px;
  border: 1px solid rgba(15,23,42,.10);
  background:
    radial-gradient(900px 280px at 0% 0%, rgba(0,112,161,.10), transparent 60%),
    radial-gradient(900px 280px at 100% 100%, rgba(108,145,40,.10), transparent 60%),
    #ffffff;
  box-shadow: 0 20px 38px rgba(15,23,42,.10);
}
.solutions-outro-head .h2{
  margin-bottom: .6rem;
}
.solutions-outro-head .p{
  max-width: 76ch;
  margin-top: 0;
}
.solutions-outro-grid{
  margin-top: 18px;
  display:grid;
  grid-template-columns: 1.35fr .95fr;
  gap: 18px;
  align-items: stretch;
}
.solutions-outro-steps{
  display:grid;
  gap: 12px;
}
.solutions-step-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  padding: 16px;
  background: rgba(255,255,255,.88);
}
.solutions-step-index{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 40px;
  height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 900;
  letter-spacing: .05em;
  color: #0b2a3a;
  background: linear-gradient(135deg, rgba(108,145,40,.26), rgba(0,112,161,.24));
}
.solutions-step-card h3{
  margin: 8px 0 4px;
  font-size: 1.02rem;
}
.solutions-step-card p{
  margin: 0;
  color: var(--muted);
}
.solutions-outro-panel{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  padding: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,255,.96));
  display:flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 14px;
}
.solutions-outro-kpis{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.solutions-kpi{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 12px;
  padding: 12px;
  background: #fff;
}
.solutions-kpi-value{
  display:block;
  font-weight: 900;
  color: #0b2a3a;
  line-height: 1.15;
}
.solutions-kpi-label{
  display:block;
  margin-top: 3px;
  color: var(--muted);
  font-size: .9rem;
}
.solutions-outro-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.solutions-outro-actions .btn{
  flex: 1 1 220px;
  text-align: center;
}
@media (max-width: 980px){
  .solutions-outro-grid{
    grid-template-columns: 1fr;
  }
}
@media (max-width: 640px){
  .solutions-outro{
    padding: 18px;
    border-radius: 18px;
  }
}
.gen-carousel{
  margin: 24px auto 0;
  max-width: 1060px;
  position: relative;
}
.carousel-track{
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  border: none;
  box-shadow: none;
  background: transparent;
}
.carousel-slide{
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateY(10px) scale(.98);
  transition: opacity .35s ease, transform .35s ease;
  pointer-events: none;
  display:flex;
  flex-direction: column;
  justify-content: flex-end;
}
.carousel-slide.is-active{
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.carousel-slide img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 10px;
  animation: carouselFloat 10s ease-in-out infinite;
}
.carousel-slide video{
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  border-radius: 10px;
  display:block;
  background: transparent;
  transform: translateZ(0);
  backface-visibility: hidden;
}
.carousel-slide figcaption{
  position: absolute;
  left: 18px;
  bottom: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(9,15,20,.7);
  color: #e6eef7;
  font-size: .9rem;
  font-weight: 600;
  letter-spacing: .01em;
}
.carousel-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(9,15,20,.6);
  color: #fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 26px;
  z-index: 2;
  transition: transform .2s ease, background .2s ease;
}
.carousel-btn:hover{
  transform: translateY(-50%) scale(1.06);
  background: rgba(9,15,20,.8);
}
.carousel-btn.prev{left: -18px;}
.carousel-btn.next{right: -18px;}
.carousel-dots{
  display:flex;
  justify-content:center;
  gap: 8px;
  margin-top: 14px;
}
.carousel-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,112,161,.4);
  background: transparent;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.carousel-dot.is-active{
  background: var(--brand);
  border-color: var(--brand);
  transform: scale(1.15);
}
.carousel-dot:hover{
  transform: scale(1.1);
}
.gen-section .carousel-dots button{
  cursor: pointer;
}
@keyframes carouselFloat{
  0%{transform: scale(1) translateY(0);}
  50%{transform: scale(1.03) translateY(-6px);}
  100%{transform: scale(1) translateY(0);}
}
@keyframes genPulse{
  0%{box-shadow: 0 0 0 0 rgba(0,112,161,.35);}
  70%{box-shadow: 0 0 0 10px rgba(0,112,161,0);}
  100%{box-shadow: 0 0 0 0 rgba(0,112,161,0);}
}
.solutions-hero-dark{
  position: relative;
  overflow: hidden;
  padding: 84px 0 56px;
  color: #e7eef6;
}
.solutions-hero-dark-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(9,15,20,.68), rgba(9,15,20,.56)),
    url("../img/Images%20cabeceras/header_solutions.png");
  background-size: cover;
  background-position: center;
}
.solutions-hero-dark-grid{
  position: relative;
  z-index: 1;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items: center;
}
.solutions-hero-dark-grid.no-media{
  grid-template-columns: 1fr;
}
.solutions-hero-dark-left .p{
  max-width: 70ch;
}
.solutions-hero-dark-right{
  display:flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-end;
}
.solutions-hero-dark-right .hero-video-frame{
  width: min(100%, 560px);
  max-width: 560px;
}
.solutions-hero-dark-right .product-proof{
  width: min(100%, 560px);
  max-width: 560px;
}
.solutions-hero-dark .hero-visual-dynamic.hero-video-frame{
  width: min(100%, 560px);
  max-width: 560px;
  aspect-ratio: 5 / 3;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(10,18,28,.34);
  backdrop-filter: blur(3px);
  box-shadow: 0 16px 36px rgba(3,10,18,.42);
}
@media (max-width: 900px){
  .solutions-hero-dark-grid{grid-template-columns: 1fr;}
  .solutions-hero-dark-right{align-items: center;}
  .solutions-hero-dark .hero-visual-dynamic.hero-video-frame{
    width: 100%;
    max-width: none;
    aspect-ratio: 16 / 9;
  }
  .solutions-video-layout{
    grid-template-columns: 1fr;
  }
}
@media (max-width: 1200px){
  .gen-timeline{grid-template-columns: repeat(3, minmax(0,1fr));}
}
@media (max-width: 900px){
  .gen-timeline{grid-template-columns: 1fr;}
  .gen-timeline::before{display:none;}
  .carousel-btn.prev{left: 6px;}
  .carousel-btn.next{right: 6px;}
  .carousel-track{aspect-ratio: 4 / 3;}
}
.arch-section{margin-top: 28px;}
.video-carousel{
  margin-top: 14px;
  display:flex;
  gap: 16px;
  overflow-x: auto;
  padding-bottom: 6px;
  scroll-snap-type: x mandatory;
}
.video-card{
  min-width: 320px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 10px;
  box-shadow: var(--shadow-sm);
  scroll-snap-align: start;
}
.video-card-main{
  max-width: 720px;
}
.solutions-hero-dark .video-card{
  background: rgba(255,255,255,.92);
}
.solutions-video{
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 12px;
  display:block;
  background: #000;
  border: none;
  outline: none;
}
.video-card b{
  display:block;
  margin-top: 8px;
  font-size: .95rem;
}
.video-stage{
  margin-top: 14px;
}
.solutions-video-layout{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 14px;
  align-items: start;
}
.solutions-kpi-panel{
  margin: 0;
}
.solutions-kpi-panel .product-proof-kpis{
  grid-template-columns: 1fr;
}
.video-card-main{
  max-width: 920px;
  margin: 0 auto;
}
.video-card video{
  width: 100%;
  border-radius: 12px;
  display:block;
  background: #000;
}
.video-card b{
  display:block;
  margin-top: 8px;
  font-size: .95rem;
}

/* ===========================
   Product Page
   =========================== */
.product-hero{
  position: relative;
  overflow: hidden;
  padding: 84px 0 56px;
  color: #e7eef6;
}
.product-hero-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(1100px 520px at 15% 0%, rgba(0,112,161,.34), transparent 62%),
    radial-gradient(1000px 480px at 85% 100%, rgba(108,145,40,.24), transparent 60%),
    linear-gradient(180deg, rgba(9,15,20,.90), rgba(9,15,20,.78)),
    url("../img/backgrounds/hero.png");
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.03);
}
.product-hero-bg-products{
  background:
    radial-gradient(1100px 520px at 15% 0%, rgba(0,112,161,.32), transparent 62%),
    radial-gradient(1000px 480px at 85% 100%, rgba(108,145,40,.20), transparent 60%),
    linear-gradient(180deg, rgba(9,15,20,.62), rgba(9,15,20,.46)),
    url("../img/Images%20cabeceras/header_products.png");
  background-size: cover;
  background-position: center;
}
.product-hero-bg-services{
  background:
    radial-gradient(1100px 520px at 15% 0%, rgba(0,112,161,.30), transparent 62%),
    radial-gradient(1000px 480px at 85% 100%, rgba(108,145,40,.18), transparent 60%),
    linear-gradient(180deg, rgba(9,15,20,.52), rgba(9,15,20,.36)),
    url("../img/Images%20cabeceras/header_services.png");
  background-size: cover;
  background-position: center;
}
.product-hero-grid{
  position: relative;
  z-index: 1;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items: center;
}
.product-hero-grid.no-media{
  grid-template-columns: 1fr;
}
.product-hero-products .product-hero-grid > div:first-child{
  margin-left: -52px;
}
.product-hero-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 20px;
}
.product-hero-actions .btn.ghost{
  background: transparent;
  color: #e6eef7;
  border-color: rgba(226,232,240,.35);
}
.product-hero-actions .btn.ghost:hover{
  background: rgba(226,232,240,.10);
}
.product-hero-visual{
  display:flex;
  flex-direction: column;
  align-items: flex-end;
}

.product-highlight{
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 24px;
  padding: 24px;
  box-shadow: 0 18px 34px rgba(15,23,42,.08);
}
.product-options-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.product-option-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  padding: 16px;
  background: #eef2f6;
  box-shadow: var(--shadow-sm);
  display:grid;
  gap: 10px;
  color: inherit;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.product-option-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 30px rgba(15,23,42,.12);
  border-color: rgba(0,112,161,.28);
}
.product-option-image{
  width: 100%;
  height: 220px;
  object-fit: contain;
  object-position: center;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.12);
  background: #ffffff;
  padding: 10px;
}
.product-option-tag{
  display:inline-flex;
  width: fit-content;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #0b2a3a;
  background: linear-gradient(135deg, rgba(108,145,40,.26), rgba(0,112,161,.22));
  border-radius: 999px;
  padding: 5px 10px;
}
.product-option-card h3{
  margin: 0;
  font-size: 1.12rem;
  font-weight: 900;
  color: #0b2a3a;
}
.product-option-card p{
  margin: 0;
  color: #334155;
  line-height: 1.4;
}
.product-option-cta{
  display:inline-flex;
  width: fit-content;
  margin-top: 2px;
  align-items:center;
  justify-content:center;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.16);
  font-weight: 800;
  color: #0b2a3a;
  background: rgba(255,255,255,.7);
}
.products-portfolio-dark{
  background:
    radial-gradient(1100px 520px at 10% 0%, rgba(0,112,161,.22), transparent 60%),
    radial-gradient(1000px 520px at 90% 10%, rgba(108,145,40,.16), transparent 62%),
    linear-gradient(180deg, #09111b 0%, #0b1521 100%);
  border-top: 1px solid rgba(148,163,184,.18);
  border-bottom: 1px solid rgba(148,163,184,.14);
}
.products-portfolio-dark .kicker{
  color: #9fc956;
}
.products-portfolio-dark .h2{
  color: #eef5fd;
}
.products-portfolio-dark .p{
  color: #b9c8d8;
}
.products-portfolio-dark .product-option-card{
  border-color: rgba(15,23,42,.10);
  background: #eef2f6;
  box-shadow: var(--shadow-sm);
}
.products-portfolio-dark .product-option-card:hover{
  border-color: rgba(0,112,161,.28);
  box-shadow: 0 18px 30px rgba(15,23,42,.12);
}
.products-portfolio-dark .product-option-image{
  border-color: rgba(15,23,42,.12);
  background: #ffffff;
}
.products-portfolio-dark .product-option-tag{
  border: 0;
  background: linear-gradient(135deg, rgba(108,145,40,.26), rgba(0,112,161,.22));
  color: #0b2a3a;
}
.products-portfolio-dark .product-option-card h3{
  color: #0b2a3a;
}
.products-portfolio-dark .product-option-card p{
  color: #334155;
}
.products-portfolio-dark .product-option-cta{
  border-color: rgba(15,23,42,.16);
  color: #0b2a3a;
  background: rgba(255,255,255,.7);
}
.products-portfolio-dark .product-option-card:hover .product-option-cta{
  border-color: rgba(0,112,161,.28);
  color: #0b2a3a;
  background: #ffffff;
}
.product-highlight-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 20px;
  align-items: center;
}
.product-feature-list{
  margin-top: 16px;
  display:grid;
  gap: 10px;
}
.product-feature-item{
  display:grid;
  grid-template-columns: 1fr;
  gap: 2px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(248,251,255,.9);
}
.product-panel{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(15,23,42,.12);
  box-shadow: 0 14px 28px rgba(15,23,42,.10);
}
.product-panel img{
  width:100%;
  display:block;
}

.product-proof{
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 22px;
  padding: 22px;
  background: #fff;
  box-shadow: 0 16px 30px rgba(15,23,42,.08);
}
.product-proof-kpis{
  margin-top: 0;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.product-proof-kpi{
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.10);
  padding: 12px;
  background: linear-gradient(180deg, rgba(0,112,161,.08), rgba(108,145,40,.06));
}
.product-proof-kpi .value{
  display:block;
  font-weight: 900;
  color: #0b2a3a;
}
.product-proof-kpi .label{
  display:block;
  font-size: .9rem;
  color: var(--muted);
}
.product-inline-cta{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.services-benefits{
  padding-top: 26px;
  padding-bottom: 24px;
}

.product-flow{
  margin-top: 16px;
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
}
.product-flow-step{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 14px;
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.product-flow-step span{
  display:inline-flex;
  font-size: .74rem;
  font-weight: 900;
  padding: 4px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(108,145,40,.24), rgba(0,112,161,.2));
  color: #0b2a3a;
}
.product-flow-step h3{
  margin: 10px 0 4px;
  font-size: 1rem;
}
.product-flow-step p{
  margin: 0;
  color: var(--muted);
}

.services-method-dark{
  background:
    radial-gradient(1100px 520px at 10% 0%, rgba(0,112,161,.22), transparent 60%),
    radial-gradient(1000px 520px at 90% 10%, rgba(108,145,40,.16), transparent 62%),
    linear-gradient(180deg, #09111b 0%, #0b1521 100%);
  border-top: 1px solid rgba(148,163,184,.18);
  border-bottom: 1px solid rgba(148,163,184,.14);
}
.services-method-dark .kicker{
  color: #9fc956;
}
.services-method-dark .h2{
  color: #eef5fd;
}
.services-method-dark .product-flow-step{
  border: 1px solid rgba(148,163,184,.24);
  background: linear-gradient(180deg, rgba(12,22,33,.92), rgba(10,18,28,.94));
  box-shadow: 0 14px 28px rgba(0,0,0,.32);
}
.services-method-dark .product-flow-step span{
  border: 2px solid rgba(125,211,252,.62);
  background: rgba(11,23,34,.92);
  color: #e8f3ff;
  padding: 2px 10px;
}
.services-method-dark .product-flow-step h3{
  color: #f1f7ff;
}
.services-method-dark .product-flow-step p{
  color: #b9c8d8;
}

.product-modules{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
}
.product-module-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 14px;
  background: #fff;
}
.product-module-card h3{
  margin: 0 0 4px;
  font-size: 1rem;
}
.product-module-card p{
  margin: 0;
  color: var(--muted);
}

.product-integrations{
  margin-top: 16px;
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
}
.product-integration{
  border: 1px dashed rgba(15,23,42,.22);
  border-radius: 12px;
  padding: 14px;
  text-align: center;
  font-weight: 800;
  color: #0b2a3a;
  background: rgba(255,255,255,.8);
}

.product-cases{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.product-case-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 14px;
  background: #fff;
}
.product-case-card h3{
  margin: 0 0 6px;
  font-size: 1rem;
}
.product-case-card p{
  margin: 0;
  color: var(--muted);
}

.product-cta-final{
  padding-top: 56px;
  padding-bottom: 88px;
}
.product-cta-final-card{
  border-radius: 24px;
  border: 1px solid rgba(148,163,184,.28);
  padding: 24px;
  background:
    radial-gradient(900px 280px at 0% 10%, rgba(0,112,161,.26), transparent 60%),
    radial-gradient(900px 280px at 100% 90%, rgba(108,145,40,.22), transparent 60%),
    linear-gradient(180deg, #0d1824, #122338);
  box-shadow: 0 22px 42px rgba(9,15,20,.34);
}
.product-cta-actions{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.product-cta-actions .btn{
  min-width: 180px;
  text-align: center;
}

.category-variants-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.category-variant-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 14px;
  background: #fff;
  box-shadow: var(--shadow-sm);
  display:grid;
  gap: 10px;
}
.category-variant-card h3{
  margin: 0;
  font-size: 1.02rem;
  font-weight: 900;
  color: #0b2a3a;
}
.category-variant-card p{
  margin: 0;
  color: var(--muted);
}
.steam-categories-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
.steam-category-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  background: #fff;
  padding: 16px;
  box-shadow: var(--shadow-sm);
  text-align: center;
}
.steam-category-card img{
  width: 100%;
  height: 190px;
  object-fit: contain;
  object-position: center;
}
.steam-category-card h3{
  margin: 8px 0 0;
  font-size: 1.02rem;
  font-weight: 900;
  color: #0b2a3a;
}
.valves-grid{
  grid-template-columns: repeat(6, minmax(0,1fr));
  gap: 16px;
}
.valves-card{
  grid-column: span 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 330px;
}
.valves-card img{
  height: 220px;
  object-fit: contain;
  object-position: center;
}
.valves-grid .valves-card:nth-child(4){
  grid-column: 2 / span 2;
}
.valves-grid .valves-card:nth-child(5){
  grid-column: 4 / span 2;
}
.steam-category-link{
  display: block;
  color: inherit;
  text-decoration: none;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.steam-category-link:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 30px rgba(15,23,42,.14);
  border-color: rgba(0,112,161,.30);
}
.steam-category-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top: 12px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.15);
  background: rgba(255,255,255,.9);
  font-size: .84rem;
  font-weight: 900;
  color: #0b2a3a;
}

.trap-detail-hero{
  display:grid;
  grid-template-columns: .7fr 1.3fr;
  gap: 22px;
  align-items: center;
}
.trap-detail-media{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  padding: 20px;
  background: #ffffff;
  box-shadow: var(--shadow-sm);
}
.trap-detail-media img{
  width: 100%;
  max-height: 360px;
  object-fit: contain;
}
.trap-summary{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  padding: 20px;
  background: #ffffff;
  box-shadow: var(--shadow-sm);
}
.trap-summary-grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px;
}
.trap-summary-kpi{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 12px;
  padding: 10px 12px;
  background: rgba(248,251,255,.9);
}
.trap-summary-kpi b{
  display:block;
  color: #0b2a3a;
}
.trap-summary-kpi span{
  color: var(--muted);
  font-size: .86rem;
}
.trap-tabs{
  margin-top: 20px;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.trap-tabs-nav{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 14px;
  border-bottom: 1px solid rgba(15,23,42,.09);
  background: #f8fafc;
}
.trap-tab-btn{
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.12);
  background: #ffffff;
  color: #0b2a3a;
  font-weight: 800;
  font-size: .9rem;
}
.trap-tab-btn.active{
  border-color: rgba(0,112,161,.34);
  background: rgba(0,112,161,.12);
}
.trap-tab-panel{
  display:none;
  padding: 18px;
}
.trap-tab-panel.active{
  display:block;
}
.trap-table-wrap{
  overflow-x:auto;
}
.trap-table{
  width: 100%;
  min-width: 880px;
  border-collapse: collapse;
}
.trap-table th,
.trap-table td{
  border-bottom: 1px solid rgba(15,23,42,.12);
  padding: 12px;
  text-align: left;
}
.trap-table th{
  font-size: .84rem;
  color: #334155;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.trap-table td:first-child{
  font-weight: 900;
  color: #0b2a3a;
}
.trap-list{
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
}
.trap-list li{
  margin: 8px 0;
}
.trap-docs{
  display:grid;
  gap: 10px;
}
.trap-doc{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(248,251,255,.92);
}
.trap-doc b{
  color:#0b2a3a;
}
.trap-doc small{
  color: var(--muted);
}
.trap-doc .btn{
  padding: 8px 12px;
}
.category-placeholder{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  padding: 24px;
  background: #ffffff;
  box-shadow: var(--shadow-sm);
}

/* ===========================
   Equipos Monitorizacion Page
   =========================== */
.emon-hero{
  position: relative;
  overflow: hidden;
  padding: 84px 0 56px;
  color: #e7eef6;
}
.emon-hero-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 380px at 10% 0%, rgba(0,112,161,.28), transparent 60%),
    radial-gradient(900px 380px at 100% 100%, rgba(108,145,40,.20), transparent 60%),
    linear-gradient(180deg, rgba(9,15,20,.9), rgba(9,15,20,.8)),
    url("../img/backgrounds/hero-bg.png");
  background-size: cover;
  background-position: center;
}
.emon-hero-bg-equipos{
  background:
    radial-gradient(900px 380px at 10% 0%, rgba(0,112,161,.28), transparent 60%),
    radial-gradient(900px 380px at 100% 100%, rgba(108,145,40,.20), transparent 60%),
    linear-gradient(180deg, rgba(9,15,20,.9), rgba(9,15,20,.8)),
    url("../img/Images%20cabeceras/cabecera-equipos-monitorizacion.jpg");
  background-size: cover;
  background-position: center;
}
.emon-hero-bg-purgadores{
  background:
    radial-gradient(900px 380px at 10% 0%, rgba(0,112,161,.28), transparent 60%),
    radial-gradient(900px 380px at 100% 100%, rgba(108,145,40,.20), transparent 60%),
    linear-gradient(180deg, rgba(9,15,20,.9), rgba(9,15,20,.8)),
    url("../img/Images%20cabeceras/cabecera-steam-traps.jpg");
  background-size: cover;
  background-position: center;
}
.emon-hero-content{
  position: relative;
  z-index: 1;
}
.emon-tech-tags{
  margin-top: 16px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.emon-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 800;
  font-size: .85rem;
  color: #e6eef7;
  border: 1px solid rgba(226,232,240,.28);
  background: rgba(15,23,42,.36);
}
.emon-tag:hover{
  background: rgba(0,112,161,.36);
}
.emon-section{
  border: 1px solid rgba(15,23,42,.09);
  border-radius: 22px;
  padding: 20px;
  background: #ffffff;
  box-shadow: 0 14px 30px rgba(15,23,42,.08);
  border-top-width: 5px;
}
.emon-band{
  border-top: 1px solid rgba(15,23,42,.08);
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.emon-band-lora{
  background:
    radial-gradient(1200px 420px at 10% 0%, rgba(16,185,129,.10), transparent 62%),
    linear-gradient(180deg, #f5fbf8, #f8fcfa);
}
.emon-band-lte{
  background:
    radial-gradient(1200px 420px at 10% 0%, rgba(59,130,246,.10), transparent 62%),
    linear-gradient(180deg, #f5f9ff, #f8fbff);
}
.emon-band-isa{
  background:
    radial-gradient(1200px 420px at 10% 0%, rgba(245,158,11,.11), transparent 62%),
    linear-gradient(180deg, #fffaf2, #fffcf7);
}
.emon-band-rs485{
  background:
    radial-gradient(1200px 420px at 10% 0%, rgba(100,116,139,.10), transparent 62%),
    linear-gradient(180deg, #f6f8fb, #fafbfd);
}
.emon-band-lora .emon-section{
  border-color: rgba(16,185,129,.28);
  border-top-color: rgba(5,150,105,.75);
}
.emon-band-lte .emon-section{
  border-color: rgba(59,130,246,.28);
  border-top-color: rgba(37,99,235,.78);
}
.emon-band-isa .emon-section{
  border-color: rgba(245,158,11,.30);
  border-top-color: rgba(217,119,6,.78);
}
.emon-band-rs485 .emon-section{
  border-color: rgba(100,116,139,.32);
  border-top-color: rgba(71,85,105,.80);
}
.emon-section-head{
  display:flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.emon-tech-media{
  display:flex;
  align-items:center;
  justify-content:center;
  min-width: 160px;
  padding: 8px 12px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.10);
  background: #f8fbff;
}
.emon-tech-logo{
  max-width: 150px;
  max-height: 52px;
  width: auto;
  height: auto;
  object-fit: contain;
}
.emon-grid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.emon-grid-2{
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.emon-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  overflow: hidden;
  background: #f8fafd;
  box-shadow: var(--shadow-sm);
}
.emon-card-top{
  padding: 12px;
  border-bottom: 1px solid rgba(15,23,42,.08);
  background: #ffffff;
}
.emon-card-top img{
  width: 100%;
  height: 180px;
  object-fit: contain;
}
.emon-card-body{
  padding: 14px;
  display:grid;
  gap: 10px;
}
.emon-card-body h3{
  margin: 0;
  font-weight: 900;
  color: #0b2a3a;
}
.emon-card-body p{
  margin: 0;
  color: var(--muted);
}

.detector-hero{
  position: relative;
  color: #e7eef6;
  padding: 82px 0 56px;
}
.detector-hero-bg{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(9,15,20,.84), rgba(9,15,20,.74)),
    url("../img/Images%20cabeceras/cabecera-steam-traps.jpg");
  background-size: cover;
  background-position: center;
}
.detector-hero-grid{
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 28px;
  align-items: center;
}
.detector-kpis{
  margin-top: 14px;
  display: grid;
  gap: 10px;
}
.detector-kpi{
  display: grid;
  gap: 4px;
  background: rgba(12,22,34,.7);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 12px;
  padding: 10px 12px;
}
.detector-kpi strong{
  color: #f4f7fb;
}
.detector-kpi span{
  color: #c2d2e2;
  font-size: .92rem;
}
.detector-hero-media{
  border-radius: 18px;
  background: rgba(255,255,255,.94);
  padding: 12px;
  box-shadow: 0 22px 48px rgba(0,0,0,.35);
  overflow: hidden;
}
.detector-hero-carousel{
  position: relative;
}
.detector-hero-slide{
  display: none;
}
.detector-hero-slide.is-active{
  display: block;
}
.detector-hero-media img{
  width: 100%;
  height: 320px;
  object-fit: cover;
  border-radius: 12px;
}
.detector-hero-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 0;
  background: rgba(255,255,255,.84);
  color: #0b2a3a;
  font-size: 1.4rem;
  font-weight: 900;
  line-height: 1;
  display: grid;
  place-items: center;
}
.detector-btn-light{
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.42);
  color: #f8fbff;
}
.detector-btn-light:hover{
  background: rgba(255,255,255,.2);
  color: #ffffff;
}
.detector-hero-prev{
  left: 8px;
}
.detector-hero-next{
  right: 8px;
}
.detector-hero-dots{
  position: absolute;
  left: 50%;
  bottom: 10px;
  transform: translateX(-50%);
  display: flex;
  gap: 7px;
}
.detector-hero-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: 0;
  background: rgba(15,23,42,.28);
}
.detector-hero-dot.is-active{
  background: #7fa323;
}

.detector-value{
  background: linear-gradient(180deg, #f4f8fc 0%, #eef4fa 100%);
  border-top: 1px solid rgba(15,23,42,.06);
  border-bottom: 1px solid rgba(15,23,42,.06);
}
.detector-value-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
.detector-value-card{
  background: #ffffff;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 16px;
  box-shadow: var(--shadow-sm);
}
.detector-value-card h3{
  margin: 0 0 8px;
  font-size: 1.05rem;
  color: #0b2a3a;
}
.detector-value-card ul{
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 7px;
  color: #475569;
}

.detector-model-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}
.detector-model-card{
  background: #ffffff;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 18px;
  box-shadow: var(--shadow-sm);
  display: grid;
  gap: 11px;
}
.detector-model-card-accent{
  border-color: rgba(128,165,35,.34);
  box-shadow: 0 12px 26px rgba(128,165,35,.14);
}
.detector-model-visual{
  border: 1px solid rgba(15,23,42,.10);
  background: #f8fafc;
  border-radius: 12px;
  padding: 10px;
}
.detector-model-visual img{
  width: 100%;
  height: 250px;
  object-fit: contain;
}
.detector-model-head{
  display: grid;
  gap: 5px;
}
.detector-model-tag{
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(0,112,161,.10);
  color: #135574;
  font-weight: 800;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.detector-model-head h3{
  margin: 0;
  font-size: 1.35rem;
  color: #0b2a3a;
}
.detector-model-card p{
  margin: 0;
  color: #475569;
}
.detector-model-card ul{
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 7px;
  color: #475569;
}

.detector-docs{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  background: #f8fbff;
  padding: 16px;
}
.detector-docs-head{
  margin-bottom: 12px;
}
.detector-docs-head h3{
  margin: 0;
  color: #0b2a3a;
  font-size: 1.05rem;
}
.detector-docs-head p{
  margin: 6px 0 0;
  color: #64748b;
}
.detector-docs-links{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.detector-doc-link{
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid rgba(15,23,42,.12);
  color: #113452;
  font-weight: 800;
  font-size: .85rem;
}
.detector-doc-link:hover{
  background: rgba(128,165,35,.14);
  color: #2f4f11;
}
.detector-legacy-note{
  border: 1px dashed rgba(100,116,139,.32);
  background: rgba(241,245,249,.75);
  border-radius: 12px;
  padding: 10px 12px;
}
.detector-legacy-note p{
  margin: 0;
  color: #64748b;
  font-size: .9rem;
}
.detector-legacy-note strong{
  color: #475569;
}
.detector-eol{
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: 999px;
  margin-right: 6px;
  background: rgba(100,116,139,.16);
  color: #64748b;
  font-weight: 800;
  font-size: .72rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.detector-cta-final .kicker{
  color: #9cc14e;
}
.detector-cta-final .product-cta-final-card h3{
  color: #f4f7fb;
}
.detector-cta-final .product-cta-final-card p{
  color: #d4dee9;
}
.detector-cta-final .btn.ghost{
  border-color: rgba(255,255,255,.44);
  color: #f4f7fb;
  background: rgba(255,255,255,.06);
}
.detector-cta-final .btn.ghost:hover{
  background: rgba(255,255,255,.14);
}

@media (max-width: 980px){
  .product-hero-grid,
  .product-highlight-grid{
    grid-template-columns: 1fr;
  }
  .product-hero-products .product-hero-grid > div:first-child{
    margin-left: 0;
  }
  .product-hero-visual{
    align-items: center;
  }
  .product-proof-kpis{
    grid-template-columns: 1fr;
  }
  .product-flow{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
  .product-options-grid{
    grid-template-columns: 1fr;
  }
  .product-modules{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
  .product-integrations{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
  .product-cases{
    grid-template-columns: 1fr;
  }
  .category-variants-grid{
    grid-template-columns: 1fr;
  }
  .steam-categories-grid{
    grid-template-columns: 1fr;
  }
  .valves-grid{
    grid-template-columns: 1fr;
  }
  .valves-card{
    grid-column: auto;
    min-height: auto;
  }
  .valves-grid .valves-card:nth-child(4),
  .valves-grid .valves-card:nth-child(5){
    grid-column: auto;
  }
  .valves-card img{
    height: 190px;
  }
  .trap-detail-hero{
    grid-template-columns: 1fr;
  }
  .trap-summary-grid{
    grid-template-columns: 1fr;
  }
  .emon-grid,
  .emon-grid-2{
    grid-template-columns: 1fr;
  }
  .emon-tech-media{
    min-width: 0;
    width: 100%;
  }
  .detector-hero-grid{
    grid-template-columns: 1fr;
  }
  .detector-hero-media img{
    height: 260px;
  }
  .detector-value-grid{
    grid-template-columns: 1fr;
  }
  .detector-model-grid{
    grid-template-columns: 1fr;
  }
}
@media (max-width: 900px){
  .services-benefits{
    padding-top: 16px;
    padding-bottom: 14px;
  }
}
@media (max-width: 640px){
  .product-hero{
    padding: 74px 0 46px;
  }
  .product-option-image{
    height: 180px;
  }
  .product-flow{
    grid-template-columns: 1fr;
  }
  .product-modules{
    grid-template-columns: 1fr;
  }
}

/* ===========================
   Dark mode
   =========================== */
@media (prefers-color-scheme: dark){
  :root{
    --bg: #0c1218;
    --surface: #121a22;
    --surface-2: #0f171f;
    --text: #e7eef6;
    --muted: #b2c0cf;
    --muted-2:#8ea2b6;
    --line: rgba(231,238,246,.12);
    --line-2: rgba(231,238,246,.06);
    --shadow-sm: 0 8px 20px rgba(0,0,0,.35);
    --shadow-md: 0 18px 40px rgba(0,0,0,.45);
  }

  body{
    background:
      radial-gradient(1200px 700px at 15% -10%, rgba(0,112,161,.18), transparent 55%),
      radial-gradient(900px 600px at 90% 0%, rgba(108,145,40,.18), transparent 55%),
      linear-gradient(180deg, #0c1218 0%, #0b1117 60%);
    color: var(--text);
  }

  .nav{
    background: rgba(12,18,24,.9);
    border-bottom: 1px solid var(--line);
  }
  .lang-switch{
    background: rgba(18,26,34,.8);
    border-color: rgba(231,238,246,.14);
  }
  .lang-toggle{
    background: rgba(18,26,34,.8);
    border-color: rgba(231,238,246,.14);
    color: var(--muted);
  }
  .lang-menu{
    background: #0f171f;
    border-color: rgba(231,238,246,.14);
  }
  .lang-option:hover{
    background: rgba(231,238,246,.08);
  }

  .card,
  .metric,
  .iiot-card,
  .logo{
    background: var(--surface);
    border-color: var(--line);
    box-shadow: var(--shadow-sm);
  }
  .card.soft{
    background: var(--surface-2);
    border-color: var(--line-2);
  }

  .badge{
    background: rgba(18,26,34,.75);
    color: var(--muted);
    border-color: rgba(0,112,161,.35);
  }

  .nav-links a{
    color: var(--muted);
  }
  .nav-links a:hover{
    background: rgba(231,238,246,.08);
    color: var(--text);
  }

  .btn{
    background: #111a22;
    border-color: rgba(231,238,246,.14);
    color: var(--text);
    box-shadow: none;
  }
  .btn.ghost{
    background: transparent;
  }

  .input, .textarea{
    background: #0f171f;
    color: var(--text);
    border-color: rgba(231,238,246,.14);
    box-shadow: none;
  }
  .input::placeholder, .textarea::placeholder{
    color: var(--muted-2);
  }
  .input:focus, .textarea:focus{
    border-color: rgba(0,112,161,.55);
    box-shadow: 0 0 0 4px rgba(0,112,161,.20);
  }

  .hero-visual,
  .hero-visual-dynamic{
    background: #0f171f;
    border-color: var(--line);
  }
  .hero-visual-dynamic::after{
    background:
      linear-gradient(180deg, rgba(0,0,0,.0) 0%, rgba(0,0,0,.08) 45%, rgba(0,0,0,.22) 100%),
      radial-gradient(700px 420px at 70% 18%, rgba(0,112,161,.18), transparent 60%);
  }

  .footer{
    background: #0c1218;
    border-top: 1px solid var(--line);
  }
}

/* ===========================
   Projects Page Variant
   =========================== */
.projectx-hero{
  position: relative;
  overflow: hidden;
  padding: 78px 0 52px;
}
.projectx-hero-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(118deg, rgba(8,14,22,.94) 0%, rgba(9,22,35,.90) 47%, rgba(21,43,61,.86) 100%),
    url("../img/backgrounds/hero-bg.png");
  background-size: cover;
  background-position: center;
}
.projectx-hero-bg-projects{
  background:
    linear-gradient(118deg, rgba(8,14,22,.54) 0%, rgba(9,22,35,.44) 47%, rgba(21,43,61,.34) 100%),
    url("../img/Images%20cabeceras/header_projects.png");
  background-size: cover;
  background-position: 70% 74%;
  background-repeat: no-repeat;
}
.projectx-hero-wrap{
  position: relative;
  z-index: 1;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  align-items: stretch;
}
.projectx-hero-wrap.no-panel{
  grid-template-columns: 1fr;
}
.projectx-hero-copy{padding-right:10px;}
.projectx-hero-panel{
  border: 1px solid rgba(226,232,240,.18);
  border-radius: 18px;
  padding: 18px;
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(6px);
}
.projectx-hero-panel h2{
  color:#f3f8fd;
  margin:0 0 12px;
  font-size:1.08rem;
  font-weight:800;
}
.projectx-kpi-list{display:grid; gap:10px;}
.projectx-kpi-list article{
  border-radius: 12px;
  border: 1px solid rgba(226,232,240,.18);
  background: rgba(15,23,42,.36);
  padding: 12px;
}
.projectx-kpi-list b{display:block; color:#e2f5ff; font-size:1.05rem;}
.projectx-kpi-list span{color:#b9ccdc; font-size:.9rem;}
.projectx-hero-actions{display:flex; gap:10px; flex-wrap:wrap; margin-top:16px;}
.projectx-hero .btn.ghost{
  color: #e8f1f9;
  border-color: rgba(226,232,240,.44);
  background: rgba(255,255,255,.06);
}
.projectx-hero .btn.ghost:hover{
  color: #ffffff;
  background: rgba(255,255,255,.16);
  border-color: rgba(226,232,240,.62);
}
.projectx-indicators{
  padding-top: 18px;
  padding-bottom: 22px;
}
.projectx-objective{
  padding-top: 12px;
  padding-bottom: 22px;
}
.projectx-indicators .projectx-hero-panel{
  border-color: rgba(15,23,42,.12);
  background: linear-gradient(180deg, #ffffff, #f4f9fd);
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
}
.projectx-indicators .projectx-hero-panel h2{
  color:#0b2a3a;
}
.projectx-indicators .projectx-kpi-list{
  grid-template-columns: repeat(3, minmax(0,1fr));
}
.projectx-indicators .projectx-kpi-list article{
  background: rgba(248,251,255,.95);
  border-color: rgba(15,23,42,.10);
}
.projectx-indicators .projectx-kpi-list b{
  color:#0b2a3a;
}
.projectx-indicators .projectx-kpi-list span{
  color: var(--muted);
}
.projectx-objective-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 18px;
  align-items:start;
}
.projectx-objective-compact{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  background:
    radial-gradient(640px 180px at 0% 0%, rgba(0,112,161,.12), transparent 62%),
    linear-gradient(180deg, #ffffff, #f4f9fd);
  box-shadow: 0 14px 26px rgba(15,23,42,.08);
  padding: 16px 18px;
}
.projectx-objective-compact .h2{
  margin-top: 4px;
  margin-bottom: 8px;
  max-width: 24ch;
}
.projectx-objective-compact .p{
  margin: 0;
  max-width: 76ch;
}
.projectx-objective-tags{
  margin-top: 12px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.projectx-objective-tags span{
  border:1px solid rgba(0,112,161,.22);
  background: rgba(0,112,161,.08);
  color:#0b4c73;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: .82rem;
  font-weight: 700;
}
.projectx-note-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  background:
    radial-gradient(560px 180px at 0% 0%, rgba(0,112,161,.10), transparent 62%),
    linear-gradient(180deg, #ffffff, #f4f9fd);
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
  padding: 20px;
}
.projectx-note-card h3{
  margin:0 0 12px;
  font-size:1.08rem;
  color:#0b2a3a;
}
.projectx-scope-list{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.projectx-scope-list li{
  display:grid;
  grid-template-columns: 34px 1fr;
  gap:10px;
  align-items:start;
  border:1px solid rgba(15,23,42,.08);
  background: rgba(255,255,255,.84);
  border-radius: 12px;
  padding:10px;
}
.projectx-scope-list .ico{
  width:34px;
  height:34px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.72rem;
  font-weight:900;
  color:#0b4c73;
  background: rgba(0,112,161,.14);
  border:1px solid rgba(0,112,161,.24);
}
.projectx-scope-list b{
  display:block;
  font-size:.95rem;
  color:#0f172a;
  margin-bottom:2px;
}
.projectx-scope-list span{
  color: var(--muted);
  font-size:.9rem;
  line-height:1.35;
}
.projectx-method .h2{max-width:24ch;}
.projectx-method{
  padding-top: 54px;
  padding-bottom: 34px;
  background:
    radial-gradient(1100px 520px at 8% 0%, rgba(0,112,161,.22), transparent 60%),
    radial-gradient(1000px 520px at 92% 10%, rgba(108,145,40,.16), transparent 62%),
    linear-gradient(180deg, #09111b 0%, #0b1521 100%);
  border-top: 1px solid rgba(148,163,184,.18);
  border-bottom: 1px solid rgba(148,163,184,.14);
}
.projectx-method .kicker{
  color: #9fc956;
}
.projectx-method .h2{
  color: #eef5fd;
}
.projectx-timeline{
  position:relative;
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 10px;
}
.projectx-timeline::before{display:none;}
.projectx-step{
  position:relative;
  display:grid;
  grid-template-columns: 1fr;
  gap:8px;
  align-items:start;
}
.projectx-step .idx{
  height:34px;
  width:34px;
  border-radius:999px;
  border:2px solid rgba(125,211,252,.62);
  background: rgba(11,23,34,.92);
  color:#e8f3ff;
  font-weight:900;
  font-size:.72rem;
  letter-spacing:.04em;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:1;
  margin-left: 2px;
}
.projectx-step > div{
  border:1px solid rgba(148,163,184,.24);
  border-radius:14px;
  background: linear-gradient(180deg, rgba(12,22,33,.92), rgba(10,18,28,.94));
  padding:12px;
  box-shadow: 0 14px 28px rgba(0,0,0,.32);
}
.projectx-step h3{
  margin:0 0 4px;
  font-size:1.02rem;
  color:#f1f7ff;
}
.projectx-step p{
  margin:0;
  color:#b9c8d8;
}
.projectx-mosaic{
  display:grid;
  grid-template-columns: repeat(12, minmax(0,1fr));
  gap:12px;
}
.projectx-case{
  grid-column: span 4;
  border:1px solid rgba(15,23,42,.10);
  border-radius:16px;
  background:#ffffff;
  padding:14px;
  box-shadow:var(--shadow-sm);
}
.projectx-case.case-lg{grid-column: span 6; background: linear-gradient(180deg, #f7fbff, #ffffff);}
.projectx-case.case-wide{grid-column: span 8;}
.projectx-case h3{margin:0 0 6px; font-size:1.02rem;}
.projectx-case p{margin:0; color:var(--muted);}
.projectx-ref-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
.projectx-ref-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  background: #ffffff;
  padding: 16px;
  box-shadow: 0 12px 24px rgba(15,23,42,.06);
  display:grid;
  gap: 11px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  position: relative;
  overflow: hidden;
}
.projectx-ref-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 20px 34px rgba(15,23,42,.10);
  border-color: rgba(0,112,161,.24);
}
.projectx-ref-card::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  right:0;
  height: 3px;
  background: linear-gradient(90deg, rgba(0,112,161,.8), rgba(108,145,40,.65));
}
.projectx-ref-card header{
  display:flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
}
.projectx-ref-card h3{
  margin:0;
  font-size:1.04rem;
  color:#0b2a3a;
}
.projectx-ref-place{
  display:inline-flex;
  align-items:center;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0,112,161,.10);
  border: 1px solid rgba(0,112,161,.18);
  color:#184457;
  font-size:.78rem;
  font-weight: 800;
  white-space: nowrap;
}
.projectx-ref-card p{
  margin:0;
  color: var(--muted);
}
.projectx-ref-tech{
  display:flex;
  gap: 6px;
  flex-wrap: wrap;
}
.projectx-ref-tech span{
  display:inline-flex;
  align-items:center;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(15,23,42,.06);
  border: 1px solid rgba(15,23,42,.12);
  color: #24425a;
  font-size: .75rem;
  font-weight: 700;
}
.projectx-ref-facts{
  margin: 0;
  padding-left: 18px;
  display:grid;
  gap: 5px;
  color: var(--muted);
  font-size: .88rem;
}
.projectx-ref-facts li::marker{
  color: rgba(0,112,161,.75);
}
.projectx-ref-meta{
  border-top: 1px dashed rgba(15,23,42,.14);
  padding-top: 9px;
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 10px;
  font-size: .82rem;
}
.projectx-ref-meta span{
  color: var(--muted);
}
.projectx-ref-meta b{
  color:#0b2a3a;
  font-size:.8rem;
  padding: 4px 9px;
  border-radius: 999px;
  border: 1px solid rgba(108,145,40,.28);
  background: rgba(108,145,40,.10);
  white-space: nowrap;
}
.projectx-ref-lead{
  max-width: 84ch;
  font-size: 1rem;
}
.projectx-cases{
  padding-top: 36px;
}
.projectx-techband{background: linear-gradient(180deg, #0f1b29, #17283a);}
.projectx-techband .kicker,.projectx-techband .h2,.projectx-techband .p{color:#dce8f4;}
.projectx-techband-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px; align-items:center;}
.projectx-clients{
  padding-top: 28px;
  padding-bottom: 26px;
}
.projectx-final{
  padding-top: 20px;
  padding-bottom: 56px;
}
.projectx-final-card{
  border-radius:22px;
  border:1px solid rgba(15,23,42,.12);
  background: linear-gradient(130deg, #ffffff 0%, #f0f7fb 65%, #ebf6ef 100%);
  box-shadow:0 18px 34px rgba(15,23,42,.11);
  padding:24px;
}
.projectx-final-card h3{
  margin:8px 0 0;
  font-size: clamp(1.4rem, 2vw, 1.95rem);
  letter-spacing:-0.01em;
  max-width:30ch;
}

@media (max-width: 900px){
  .projectx-hero-wrap,
  .projectx-objective-grid,
  .projectx-techband-grid{
    grid-template-columns:1fr;
  }
  .projectx-hero-copy{padding-right:0;}
  .projectx-method{
    padding-top: 36px;
    padding-bottom: 18px;
  }
  .projectx-cases{
    padding-top: 20px;
  }
  .projectx-timeline{
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .projectx-step{
    grid-template-columns: 56px 1fr;
    gap:10px;
  }
  .projectx-step .idx{
    height:42px;
    width:42px;
    font-size:.78rem;
    margin-left: 0;
  }
  .projectx-step > div{
    padding:14px;
  }
  .projectx-indicators{
    padding-top: 14px;
    padding-bottom: 12px;
  }
  .projectx-objective{
    padding-top: 12px;
    padding-bottom: 14px;
  }
  .projectx-objective-compact{
    padding: 14px;
  }
  .projectx-objective-compact .h2{
    max-width: none;
    font-size: clamp(1.45rem, 6vw, 1.95rem);
  }
  .projectx-objective-tags{
    gap:6px;
  }
  .projectx-scope-list li{
    grid-template-columns: 30px 1fr;
    gap:8px;
    padding:9px;
  }
  .projectx-scope-list .ico{
    width:30px;
    height:30px;
  }
  .projectx-indicators .projectx-kpi-list{
    grid-template-columns: 1fr;
  }
  .projectx-clients{
    padding-top: 16px;
    padding-bottom: 14px;
  }
  .projectx-final{
    padding-top: 12px;
    padding-bottom: 32px;
  }
  .projectx-ref-grid{
    grid-template-columns: 1fr;
  }
  .projectx-ref-card header{
    flex-direction: column;
    align-items: flex-start;
  }
  .projectx-ref-tech{
    gap: 5px;
  }
  .projectx-ref-meta{
    flex-direction: column;
    align-items: flex-start;
  }
  .projectx-mosaic{grid-template-columns: repeat(1, minmax(0,1fr));}
  .projectx-case,
  .projectx-case.case-lg,
  .projectx-case.case-wide{grid-column:auto;}
}

/* ===========================
   Ultrasonidos Page
   =========================== */
.ultra-hero{
  position: relative;
  overflow: hidden;
  padding: 78px 0 52px;
}
.ultra-hero-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(118deg, rgba(8,14,22,.62) 0%, rgba(9,22,35,.50) 47%, rgba(21,43,61,.40) 100%),
    url("../img/Images%20cabeceras/header_ultrasounds.png");
  background-size: cover;
  background-position: 62% 58%;
  background-repeat: no-repeat;
}
.ultra-hero-grid{
  position: relative;
  z-index: 1;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 16px;
  align-items: start;
}
.ultra-hero-panel{
  border: 1px solid rgba(226,232,240,.24);
  border-radius: 16px;
  background: rgba(11,18,28,.46);
  padding: 16px;
  backdrop-filter: blur(5px);
}
.ultra-hero-panel h2{
  margin:0 0 10px;
  color:#eaf3fc;
  font-size:1.04rem;
}
.ultra-hero-panel ul{
  margin:0;
  padding-left: 18px;
  display:grid;
  gap: 8px;
  color:#c4d4e3;
}
.ultra-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
.ultra-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  background: #ffffff;
  padding: 16px;
  box-shadow: var(--shadow-sm);
}
.ultra-card h3{
  margin:0 0 8px;
  font-size:1.06rem;
  color:#0b2a3a;
}
.ultra-card p{
  margin:0;
  color: var(--muted);
}
.ultra-proof{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 16px 30px rgba(15,23,42,.08);
  padding: 16px;
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 10px;
  align-items: center;
}
.ultra-proof-kpi{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 12px;
  padding: 12px;
  background: #f8fbff;
}
.ultra-proof-kpi .label{
  display:block;
  color: var(--muted);
  font-size: .85rem;
}
.ultra-proof-kpi .value{
  display:block;
  color:#0b2a3a;
  font-size: clamp(1.55rem, 2.2vw, 2.05rem);
  font-weight: 900;
}
.ultra-proof-kpi.highlight{
  background: linear-gradient(180deg, rgba(0,112,161,.12), rgba(108,145,40,.10));
  border-color: rgba(0,112,161,.30);
}
.ultra-proof-sep{
  font-size: .82rem;
  font-weight: 800;
  color: var(--muted);
  padding: 0 4px;
}
.ultra-rec-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
}
.ultra-recommend{
  padding-top: 42px;
  padding-bottom: 22px;
}
.ultra-rec-card{
  border: 1px solid rgba(125,211,252,.24);
  border-radius: 14px;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(0,112,161,.18), transparent 60%),
    radial-gradient(120% 120% at 100% 100%, rgba(108,145,40,.14), transparent 62%),
    linear-gradient(180deg, #0f1f2e, #142839);
  padding: 14px;
  box-shadow: 0 14px 28px rgba(6,14,24,.35);
}
.ultra-rec-card h3{
  margin:0 0 6px;
  font-size:1rem;
  color:#f1f6fb;
}
.ultra-rec-card p{
  margin:0;
  color: #c8d8e8;
}
.ultra-cta{
  padding-top: 18px;
  padding-bottom: 76px;
}
.ultra-cta-card{
  border-radius: 20px;
  border: 1px solid rgba(15,23,42,.12);
  background: linear-gradient(130deg, #ffffff 0%, #f0f7fb 65%, #ebf6ef 100%);
  box-shadow: 0 18px 34px rgba(15,23,42,.11);
  padding: 22px;
}
.ultra-cta-card h3{
  margin: 8px 0 10px;
  font-size: clamp(1.38rem, 2vw, 1.86rem);
  letter-spacing:-0.01em;
  max-width: 26ch;
}

@media (max-width: 980px){
  .ultra-hero-grid,
  .ultra-grid,
  .ultra-rec-grid{
    grid-template-columns: 1fr;
  }
  .ultra-recommend{
    padding-top: 28px;
    padding-bottom: 10px;
  }
  .ultra-proof{
    grid-template-columns: 1fr;
  }
  .ultra-proof-sep{display:none;}
  .ultra-cta{
    padding-top: 28px;
    padding-bottom: 40px;
  }
}

/* ===========================
   Noticias Page
   =========================== */
.news-hero{
  position: relative;
  overflow: hidden;
  padding: 76px 0 52px;
}
.news-hero-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(115deg, rgba(7,18,30,.44) 0%, rgba(9,23,37,.34) 52%, rgba(20,45,63,.30) 100%),
    url("../img/Images%20cabeceras/header_news.png");
  background-size: 100% auto;
  background-position: center 36%;
  background-repeat: no-repeat;
}
.news-hero-wrap{
  position: relative;
  z-index: 1;
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: stretch;
}
.news-hero-copy{
  max-width: 74ch;
}
.news-feed-section{
  padding-top: 36px;
  padding-bottom: 78px;
}
.news-toolbar{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff, #f8fbfe);
  box-shadow: 0 14px 28px rgba(15,23,42,.08);
  padding: 14px;
  display:grid;
  gap: 12px;
}
.news-search-wrap{
  display:grid;
  gap: 6px;
}
.news-search-wrap label{
  font-size: .83rem;
  font-weight: 800;
  color: #475569;
}
.news-search-wrap input{
  width: 100%;
  height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.16);
  background: #ffffff;
  color: #0f172a;
  font-size: .96rem;
  padding: 0 14px;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
}
.news-search-wrap input:focus{
  border-color: rgba(0,112,161,.65);
  box-shadow: 0 0 0 4px rgba(0,112,161,.16);
}
.news-controls{
  display:grid;
  gap: 10px;
}
.news-year-filter,
.news-topic-filter{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}
.news-year-filter button,
.news-topic-filter button{
  border: 1px solid rgba(15,23,42,.16);
  background: #ffffff;
  color: #334155;
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 800;
  padding: 6px 12px;
  transition: all .16s ease;
}
.news-year-filter button:hover,
.news-topic-filter button:hover{
  transform: translateY(-1px);
  border-color: rgba(0,112,161,.38);
}
.news-year-filter button.is-active,
.news-topic-filter button.is-active{
  background: linear-gradient(135deg, #0070a1, #0b88c2);
  border-color: transparent;
  color: #ffffff;
  box-shadow: 0 8px 18px rgba(0,112,161,.24);
}
.news-results{
  margin: 14px 2px 0;
  color: #64748b;
  font-size: .9rem;
  font-weight: 700;
}
.news-feed{
  margin-top: 14px;
  display:flex;
  flex-direction: column;
  gap: 14px;
}
.news-card{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  background: #ffffff;
  padding: 16px;
  box-shadow: 0 12px 24px rgba(15,23,42,.06);
  display:grid;
  gap: 10px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.news-card:hover{
  transform: translateY(-2px);
  border-color: rgba(0,112,161,.22);
  box-shadow: 0 18px 30px rgba(15,23,42,.10);
}
.news-card.featured{
  grid-column: auto !important;
  background:
    radial-gradient(130% 140% at 0% 0%, rgba(0,112,161,.08), transparent 56%),
    radial-gradient(120% 140% at 100% 100%, rgba(108,145,40,.10), transparent 62%),
    #ffffff;
}
.news-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}
.news-meta span:first-child{
  font-size: .84rem;
  font-weight: 800;
  color: #64748b;
}
.news-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,112,161,.18);
  background: rgba(0,112,161,.10);
  color: #1f4f67;
  font-size: .74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.news-card h2{
  margin: 0;
  font-size: clamp(1.12rem, 1.8vw, 1.35rem);
  line-height: 1.25;
  color: #0b243f;
  text-transform: uppercase;
}
.news-card p{
  margin: 0;
  color: #4b5d72;
}
.news-rich-copy{
  display:grid;
  gap: 8px;
}
.news-rich-copy p{
  margin: 0;
  color: #4b5d72;
}
.news-rich-copy a{
  color: #0b6e9a;
  font-weight: 800;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}
.news-rich-copy a:hover{
  color: #5d8225;
}
.news-rich-copy ul{
  margin: 0;
  padding-left: 20px;
  color: #4b5d72;
  list-style: disc;
  list-style-position: outside;
}
.news-rich-copy ol{
  margin: 0;
  padding-left: 22px;
  color: #4b5d72;
  list-style: decimal;
  list-style-position: outside;
}
.news-rich-copy li{
  margin: 0 0 6px 0;
  display: list-item;
}
.news-rich-copy li::marker{
  color: rgba(0,112,161,.75);
}
.news-media{
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.12);
  background: #000000;
  box-shadow: 0 10px 20px rgba(15,23,42,.12);
}
.news-media-small{
  width: min(720px, 100%);
  display: block;
  margin-inline: auto;
}
.news-media-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
}
.news-media-image{
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.12);
  background: #ffffff;
  box-shadow: 0 10px 20px rgba(15,23,42,.10);
}
.news-split{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 14px;
  align-items: start;
}
.news-figure{
  margin: 0;
  display: grid;
  gap: 8px;
}
.news-media-caption{
  margin: 0;
  color: #64748b;
  font-size: .82rem;
  line-height: 1.45;
}
.news-media-image-small{
  width: min(620px, 100%);
  display: block;
  margin-inline: auto;
}
.news-media-image-press{
  width: min(500px, 100%);
  display: block;
  margin-inline: auto;
}
.news-media-image-medium{
  width: min(680px, 100%);
  display: block;
  margin-inline: auto;
}
.news-card a{
  width: fit-content;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.16);
  color: #103450;
  font-size: .84rem;
  font-weight: 800;
  background: #ffffff;
}
.news-card a:hover{
  border-color: rgba(108,145,40,.48);
  background: rgba(108,145,40,.12);
  color: #355516;
}
.news-empty{
  display:none;
  margin-top: 14px;
  border: 1px dashed rgba(15,23,42,.20);
  border-radius: 14px;
  padding: 14px;
  text-align: center;
  color: #64748b;
  background: rgba(255,255,255,.66);
}

@media (max-width: 980px){
  .news-hero-wrap{
    grid-template-columns: 1fr;
  }
  .news-feed{
    display:flex;
    flex-direction: column;
  }
  .news-card.featured{
    grid-column: auto !important;
  }
  .news-split{
    grid-template-columns: 1fr;
  }
  .news-media-grid{
    grid-template-columns: 1fr;
  }
}

/* ===========================
   Noticias Dark Premium Theme
   =========================== */
.news-page{
  background:
    radial-gradient(1200px 700px at 10% -10%, rgba(0,112,161,.26), transparent 60%),
    radial-gradient(1000px 620px at 90% 0%, rgba(108,145,40,.16), transparent 62%),
    linear-gradient(180deg, #0b121b 0%, #0d1621 55%, #0f1924 100%);
  color: #e9f0f7;
}
.news-page .nav{
  background: rgba(255,255,255,.92);
  border-bottom-color: rgba(11,27,43,.08);
}
.news-page .nav-links a{
  color: var(--muted);
}
.news-page .nav-links a:hover{
  color: var(--text);
  background: rgba(11,27,43,.04);
}
.news-page .nav-links a.active{
  color: var(--brand-2);
}
.news-page .lang-toggle{
  background: rgba(255,255,255,.7);
  border-color: var(--line);
  color: var(--text);
}
.news-page .lang-menu{
  background: var(--surface);
  border-color: var(--line);
}
.news-page .news-feed-section{
  background:
    radial-gradient(1200px 700px at 0% 0%, rgba(16,28,42,.54), transparent 58%),
    linear-gradient(180deg, #0c141f 0%, #0d1622 100%);
}
.news-page .news-toolbar{
  border-color: rgba(148,163,184,.18);
  background: linear-gradient(180deg, rgba(20,31,46,.84), rgba(15,25,38,.86));
  box-shadow: 0 20px 34px rgba(0,0,0,.35);
}
.news-page .news-search-wrap label{
  color: #c1cfdd;
}
.news-page .news-search-wrap input{
  border-color: rgba(148,163,184,.22);
  background: rgba(18,29,43,.92);
  color: #edf4fb;
  box-shadow: none;
}
.news-page .news-search-wrap input::placeholder{
  color: #8da0b3;
}
.news-page .news-year-filter button,
.news-page .news-topic-filter button{
  border-color: rgba(148,163,184,.24);
  background: rgba(22,34,48,.86);
  color: #c6d2df;
}
.news-page .news-year-filter button:hover,
.news-page .news-topic-filter button:hover{
  border-color: rgba(125,211,252,.45);
  color: #f0f7ff;
}
.news-page .news-results{
  color: #90a4b7;
}
.news-page .news-card{
  border-color: rgba(148,163,184,.18);
  background:
    linear-gradient(180deg, rgba(22,34,48,.88), rgba(16,27,40,.90));
  box-shadow: 0 20px 34px rgba(0,0,0,.28);
}
.news-page .news-card:hover{
  border-color: rgba(125,211,252,.30);
  box-shadow: 0 24px 40px rgba(0,0,0,.38);
}
.news-page .news-card.featured{
  background:
    radial-gradient(130% 140% at 0% 0%, rgba(0,112,161,.18), transparent 56%),
    radial-gradient(120% 140% at 100% 100%, rgba(108,145,40,.16), transparent 62%),
    linear-gradient(180deg, rgba(22,34,48,.92), rgba(17,28,41,.93));
}
.news-page .news-meta span:first-child{
  color: #9eb0c3;
}
.news-page .news-tag{
  border-color: rgba(125,211,252,.32);
  background: rgba(0,112,161,.22);
  color: #d5eefb;
}
.news-page .news-card h2{
  color: #f3f8ff;
  border-left: 3px solid rgba(108,145,40,.9);
  padding-left: 10px;
}
.news-page .news-card p,
.news-page .news-rich-copy p,
.news-page .news-rich-copy ul,
.news-page .news-rich-copy ol,
.news-page .news-media-caption{
  color: #b7c7d8;
}
.news-page .news-rich-copy li::marker{
  color: #84d7ff;
}
.news-page .news-card a{
  border-color: rgba(148,163,184,.28);
  color: #d9e7f5;
  background: rgba(15,23,34,.70);
}
.news-page .news-card a:hover{
  border-color: rgba(108,145,40,.54);
  color: #e9f6d1;
  background: rgba(108,145,40,.18);
}
.news-page .news-media{
  border-color: rgba(148,163,184,.20);
  box-shadow: 0 16px 28px rgba(0,0,0,.35);
}
.news-page .news-empty{
  border-color: rgba(148,163,184,.26);
  color: #9eb0c3;
  background: rgba(10,16,24,.72);
}

.resources-hero{
  position: relative;
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 20px;
  padding: 28px;
  background:
    radial-gradient(90% 120% at 0% 0%, rgba(0,112,161,.14), transparent 62%),
    radial-gradient(80% 120% at 100% 100%, rgba(108,145,40,.16), transparent 64%),
    linear-gradient(180deg, #f8fbff, #eef4f8);
}
.resources-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.resource-tool{
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,255,.98));
  padding: 18px 18px 16px;
  box-shadow: 0 12px 24px rgba(15,23,42,.06);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.resource-tool:hover{
  transform: translateY(-3px);
  border-color: rgba(0,112,161,.35);
  box-shadow: 0 18px 30px rgba(15,23,42,.10);
}
.resource-tool h3{
  margin: 0;
  color: #0f172a;
  font-size: 1.7rem;
  line-height: 1.1;
}
.resource-tool p{
  margin: 0;
  color: #475569;
}
.resource-list{
  margin: 0;
  padding-left: 0;
  list-style: none;
  color: #334155;
  display: grid;
  gap: 6px;
}
.resource-list li{
  position: relative;
  padding-left: 16px;
}
.resource-list li::before{
  content: "";
  position: absolute;
  left: 0;
  top: .56em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(0,112,161,.55);
}
.resource-tool .btn{
  margin-top: auto;
  width: fit-content;
}
.resource-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.resource-icon{
  min-width: 40px;
  height: 40px;
  border-radius: 10px;
  border: 1px solid rgba(0,112,161,.24);
  background: linear-gradient(180deg, rgba(0,112,161,.14), rgba(108,145,40,.12));
  color: #0b4c73;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .06em;
}
.resource-tool .pill{
  width: fit-content;
  font-weight: 700;
  font-size: .78rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  border: 1px solid rgba(0,112,161,.28);
  color: #0b4c73;
  background: rgba(0,112,161,.08);
  border-radius: 999px;
  padding: 5px 10px;
}
.resource-tool-primary{
  border-color: rgba(0,112,161,.28);
  background:
    radial-gradient(130% 120% at 100% 0%, rgba(0,112,161,.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.99), rgba(244,249,255,.98));
}
.resource-tool-soon{
  opacity: .84;
}

.tool-page-head{
  margin-bottom: 16px;
}
.tool-back{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #0b4c73;
  font-weight: 700;
  text-decoration: none;
}
.tool-back:hover{
  color: #0a678f;
}
.tool-layout{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 14px;
}
.tool-panel{
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 14px;
  background: #fff;
  padding: 16px;
}
.tool-list{
  margin: 10px 0 0;
  padding-left: 18px;
  color: #334155;
}
.calc-form{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.calc-field label{
  display: block;
  font-size: .85rem;
  color: #334155;
  margin-bottom: 4px;
  font-weight: 600;
}
.calc-field input{
  width: 100%;
  border: 1px solid rgba(15,23,42,.18);
  border-radius: 10px;
  padding: 9px 10px;
  font: inherit;
}
.calc-results{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.calc-result{
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 12px;
  background: #f8fafc;
  padding: 12px;
}
.calc-result .small{
  margin: 0 0 6px;
}
.calc-result strong{
  font-size: 1.12rem;
  color: #0f172a;
}

.maso-shell{
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 18px;
  background:
    radial-gradient(900px 300px at 0% 0%, rgba(0,112,161,.08), transparent 58%),
    radial-gradient(900px 300px at 100% 0%, rgba(108,145,40,.10), transparent 58%),
    #f7f9fc;
  padding: 22px;
  box-shadow: 0 16px 34px rgba(13, 29, 46, .10);
}
.maso-stepper{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.maso-step{
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 999px;
  background: #ffffff;
  color: #5a6a7b;
  font-weight: 700;
  font-size: .92rem;
  padding: 8px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: center;
}
.maso-step span{
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .82rem;
}
.maso-step.is-active{
  border-color: rgba(0,112,161,.36);
  color: #0b4c73;
  background: rgba(0,112,161,.09);
}
.maso-step.is-active span{
  background: #0070a1;
  border-color: #0070a1;
  color: #fff;
}
.maso-phase{
  display: grid;
  gap: 18px;
}
.maso-heading{
  text-align: center;
}
.maso-heading .h1,
.maso-heading .h2{
  margin-bottom: 6px;
  color: #1f83c3;
  max-width: 34ch;
  margin-left: auto;
  margin-right: auto;
}
.maso-heading .h1{
  font-size: clamp(2rem, 3vw, 3.1rem);
  line-height: 1.16;
}
.maso-subtitle{
  color: #1f83c3;
  font-size: 1.08rem;
  line-height: 1.25;
  margin: 0;
  font-weight: 800;
}
.maso-note{
  margin: 6px auto 0;
  max-width: 82ch;
  font-size: 1.02rem;
  font-weight: 600;
}
.maso-form{
  display: grid;
  gap: 12px;
}
.maso-form-intro{
  grid-template-columns: 1fr;
  max-width: 500px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 14px;
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
}
.maso-form-settings{
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  padding: 12px;
  background: #ffffff;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  box-shadow: 0 10px 24px rgba(15,23,42,.05);
}
.maso-field{
  display: grid;
  gap: 6px;
}
.maso-field span{
  font-size: 1.02rem;
  color: #0f172a;
  font-weight: 600;
}
.maso-field input,
.maso-field select{
  width: 100%;
  border: 1px solid rgba(15,23,42,.20);
  border-radius: 10px;
  padding: 10px 12px;
  font: inherit;
  background: #fff;
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}
.maso-field input:focus,
.maso-field select:focus{
  outline: none;
  border-color: rgba(0,112,161,.55);
  box-shadow: 0 0 0 3px rgba(0,112,161,.14);
}
.maso-field input.is-invalid,
.maso-field select.is-invalid{
  background: #ffe2ea;
  border-color: #d9044f;
}
.maso-rows{
  display: grid;
  gap: 14px;
}
.maso-row{
  border: 1px solid rgba(15,23,42,.15);
  border-radius: 14px;
  background: #fff;
  padding: 14px;
  display: grid;
  gap: 12px;
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
}
.maso-row-title{
  margin: 0;
  font-size: .82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #607080;
}
.maso-row-head{
  display: grid;
  gap: 12px;
  grid-template-columns: 70px repeat(3, minmax(0, 1fr));
  align-items: end;
}
.maso-row-item{
  font-size: 1.05rem;
  font-weight: 800;
  color: #0b4c73;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border-radius: 10px;
  background: rgba(0,112,161,.09);
  border: 1px solid rgba(0,112,161,.18);
}
.maso-row-data{
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.maso-actions{
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
}
.maso-actions .btn{
  text-transform: uppercase;
  min-width: 168px;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: .01em;
  box-shadow: none;
}
.maso-actions .btn.primary{
  background: linear-gradient(135deg, #0070a1, #0d89c5);
  border: 1px solid #0070a1;
  color: #fff;
}
.maso-actions .btn.primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 22px rgba(0,112,161,.2);
}
.maso-actions .btn.ghost{
  background: #f7f9fc;
  border-color: rgba(15,23,42,.16);
  color: #0b1b2b;
}
.maso-footnote{
  margin: 0;
  text-align: center;
  color: #1e293b;
  font-size: 1.02rem;
}
.maso-results{
  max-width: 480px;
  margin: 0 auto;
  text-align: left;
  background: #fff;
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 14px;
  padding: 18px;
  box-shadow: 0 12px 24px rgba(15,23,42,.08);
}
.maso-results p:not(.small){
  margin: 0 0 10px;
  font-size: 1.1rem;
  line-height: 1.35;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
}
.maso-results p:last-child{
  margin-bottom: 0;
}
.maso-results .small{
  font-size: 1rem;
  text-align: center;
  color: #5a6a7b;
}
.maso-kyoto-note{
  margin: 2px auto 0;
  max-width: 92ch;
  text-align: center;
  color: #0b4c73;
  font-size: .98rem;
  font-style: italic;
  font-weight: 700;
  line-height: 1.5;
}

.cad-viewer-card .p{
  max-width: 82ch;
}
.cad-shell{
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 14px;
}
.cad-tree{
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 14px;
  background: linear-gradient(180deg, #f8fafc, #f1f5f9);
  overflow: hidden;
  min-height: 330px;
}
.cad-tree-head{
  padding: 12px 14px;
  font-weight: 700;
  color: #0f172a;
  border-bottom: 1px solid rgba(15,23,42,.1);
  background: rgba(255,255,255,.75);
}
.cad-tree-body{
  padding: 8px;
  max-height: 420px;
  overflow: auto;
}
.cad-group{
  margin-bottom: 6px;
}
.cad-group-title{
  width: 100%;
  text-align: left;
  border: 0;
  background: transparent;
  padding: 8px 10px;
  border-radius: 10px;
  font-weight: 700;
  color: #0f172a;
  cursor: pointer;
}
.cad-group.open .cad-group-title{
  background: rgba(0,112,161,.1);
}
.cad-group-list{
  display: none;
  margin: 4px 0 8px;
  padding: 0 0 0 6px;
}
.cad-group.open .cad-group-list{
  display: block;
}
.cad-item{
  width: 100%;
  text-align: left;
  border: 1px solid rgba(15,23,42,.1);
  background: #fff;
  color: #0f172a;
  border-radius: 9px;
  padding: 7px 10px;
  margin-bottom: 6px;
  cursor: pointer;
  font-size: .88rem;
}
.cad-item:hover{
  border-color: rgba(0,112,161,.35);
}
.cad-item.active{
  border-color: rgba(0,112,161,.5);
  background: rgba(0,112,161,.12);
  color: #0b3a56;
}
.cad-subgroup{
  border: 1px solid rgba(15,23,42,.1);
  border-radius: 10px;
  background: #fff;
  margin-bottom: 7px;
  overflow: hidden;
}
.cad-subgroup-title{
  width: 100%;
  border: 0;
  border-bottom: 1px solid rgba(15,23,42,.08);
  background: #f8fafc;
  color: #0f172a;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
  text-align: left;
  cursor: pointer;
}
.cad-subgroup-name{
  font-weight: 700;
}
.cad-subgroup-meta{
  font-size: .75rem;
  color: #64748b;
}
.cad-subgroup.is-disabled .cad-subgroup-title{
  color: #8fa0b3;
  cursor: not-allowed;
}
.cad-subgroup.is-disabled .cad-subgroup-meta{
  color: #94a3b8;
}
.cad-model-list{
  display: none;
  padding: 8px;
  background: #fff;
}
.cad-subgroup.open .cad-model-list{
  display: block;
}
.cad-item.is-disabled{
  opacity: .56;
  cursor: not-allowed;
  color: #64748b;
  background: #f8fafc;
}
.cad-item.is-disabled:hover{
  border-color: rgba(15,23,42,.1);
}
.cad-main{
  min-width: 0;
}
.cad-stage{
  border: 1px solid rgba(15,23,42,.16);
  border-radius: 14px;
  background:
    radial-gradient(900px 320px at 0% 0%, rgba(0,112,161,.08), transparent 58%),
    linear-gradient(180deg, #f8fbff, #eef3f8);
  min-height: 300px;
  max-height: 360px;
  width: 100%;
  position: relative;
  overflow: hidden;
}
.cad-stage canvas{
  display:block;
  width:100%;
  height:100%;
}
.cad-stage.is-empty::before{
  content: "Carga un archivo .GLTF/.GLB/.STL o .STEP/.STP para iniciar el visor";
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%, -50%);
  color: #64748b;
  font-weight: 700;
  font-size: .92rem;
  text-align:center;
  width: min(320px, 90%);
}
@media (max-width: 900px){
  .resources-grid{
    grid-template-columns: 1fr;
  }
  .tool-layout{
    grid-template-columns: 1fr;
  }
  .calc-form{
    grid-template-columns: 1fr;
  }
  .calc-results{
    grid-template-columns: 1fr;
  }
  .maso-subtitle{
    font-size: 1rem;
  }
  .maso-note{
    font-size: .92rem;
  }
  .maso-stepper{
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .maso-form-settings{
    grid-template-columns: 1fr;
  }
  .maso-row-head{
    grid-template-columns: 1fr;
  }
  .maso-row-item{
    justify-content: flex-start;
  }
  .maso-row-data{
    grid-template-columns: 1fr;
  }
  .maso-actions .btn{
    min-width: 140px;
  }
  .maso-footnote{
    font-size: 1rem;
  }
  .maso-results p{
    font-size: 1.05rem;
  }
  .maso-kyoto-note{
    font-size: .9rem;
  }
  .cad-shell{
    grid-template-columns: 1fr;
  }
  .cad-tree{
    min-height: 220px;
  }
  .cad-stage{
    min-height: 260px;
    max-height: 300px;
  }
}


