/* ============================================================
   SAC — Servicios Administrativos en Computación
   Cassiopeia Override CSS · Joomla 5.4.5
   Design: Enterprise Editorial — Gold Standard UX
   Typography: Poppins (headings) + Inter (body)
   v4.0 — WCAG 2.1 AA compliance + Performance
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Poppins:wght@700;800&display=swap');

/* ============================================================
   ACCESSIBILITY — Skip link, focus rings, screen-reader utilities
   ============================================================ */
.sac-skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: #0EA5E9;
  color: #fff;
  padding: 1rem 1.5rem;
  font-family: 'Inter', sans-serif;
  font-size: .875rem;
  font-weight: 600;
  text-decoration: none;
  z-index: 99999;
  transition: top .2s ease;
  border-radius: 0 0 4px 0;
}
.sac-skip-link:focus {
  top: 0;
  outline: 3px solid #fff;
  outline-offset: 2px;
}

/* Focus rings — keyboard navigation */
*:focus-visible {
  outline: 3px solid #0EA5E9 !important;
  outline-offset: 2px !important;
  border-radius: 2px;
}
a:focus:not(:focus-visible),
button:focus:not(:focus-visible) { outline: none; }

/* Screen reader only */
.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;
}

/* ============================================================
   CONTRAST FIXES — bump muted text to WCAG AA (4.5:1 min)
   Old: rgba(255,255,255,.32) = 2.8:1 FAIL
   New: rgba(255,255,255,.6) = ~6:1 PASS AA
   ============================================================ */
[class*="container-top-a"] [style*="rgba(255,255,255,.32)"],
[class*="container-bottom-a"] [style*="rgba(255,255,255,.45)"],
.container-footer [style*="rgba(255,255,255,.3)"],
.container-footer [style*="rgba(255,255,255,.4)"],
.container-footer [style*="rgba(255,255,255,.25)"],
.container-footer [style*="rgba(255,255,255,.2)"] {
  color: rgba(255,255,255,.62) !important;
}
/* Trust strip text contrast */
[class*="container-below-top"] span[style*="rgba(255,255,255,.5)"] {
  color: rgba(255,255,255,.72) !important;
}
/* Stats labels in hero — lift from .32 to .58 */
[class*="container-top-a"] p[style*="rgba(255,255,255,.32)"] {
  color: rgba(255,255,255,.58) !important;
}
/* Light-mode muted text — #94A3B8 on white is 3:1 (FAIL). Use #64748B (4.7:1 PASS) */
[style*="color:#94A3B8"],
[style*="color: #94A3B8"] {
  color: #64748B !important;
}

/* ============================================================
   TOUCH TARGETS — WCAG 2.5.5 / Apple HIG / Material (44x44 min)
   ============================================================ */
@media (max-width: 900px) {
  .sac-service-row {
    min-height: 56px !important;
    padding: 1.25rem 0 !important;
  }
  .sac-btn { min-height: 48px !important; }
  a[href^="tel:"], a[href^="mailto:"], a[href^="https://wa.me"] {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }
  /* Nav menu links bigger tap zones */
  .mod-menu > li > a { min-height: 44px !important; display: flex !important; align-items: center !important; }
}

/* ============================================================
   COMPONENT CLASSES — replace inline styles where possible
   ============================================================ */
.sac-section { padding: 6rem 2rem; }
.sac-section--dark { background: #0F172A; color: #fff; }
.sac-section--light { background: #fff; }
.sac-section--muted { background: #F8FAFC; }
.sac-container { max-width: 1200px; margin: 0 auto; }
.sac-h2 {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(2rem, 4.5vw, 3.75rem);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.05;
  color: #0F172A;
  margin: 0 0 1rem;
}
.sac-section--dark .sac-h2 { color: #fff; }

/* ============================================================
   PROCESS 1-2-3 SECTION
   ============================================================ */
.sac-process {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem;
  margin-top: 4rem;
}
.sac-process-step { position: relative; padding-top: 1rem; border-top: 2px solid #0369A1; }
.sac-process-step__num {
  font-family: 'Poppins', sans-serif;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 3px;
  color: #0369A1;
  margin: 0 0 1rem;
  display: block;
}
.sac-process-step__title {
  font-family: 'Poppins', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: #0F172A;
  margin: 0 0 .75rem;
  line-height: 1.2;
  letter-spacing: -.02em;
}
.sac-process-step__desc {
  font-family: 'Inter', sans-serif;
  font-size: .9rem;
  color: #475569;
  line-height: 1.65;
  margin: 0;
}
.sac-process-step__time {
  display: inline-block;
  margin-top: 1rem;
  font-family: 'Inter', sans-serif;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #94A3B8;
}
@media (max-width: 768px) {
  .sac-process { grid-template-columns: 1fr; gap: 2rem; }
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.sac-testimonials {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  margin-top: 3.5rem;
}
.sac-testimonial {
  background: #fff;
  border: 1px solid #E2E8F0;
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
}
.sac-testimonial__quote {
  font-family: 'Poppins', sans-serif;
  font-size: 1.15rem;
  font-weight: 500;
  color: #0F172A;
  line-height: 1.5;
  letter-spacing: -.01em;
  margin: 0 0 1.5rem;
  flex: 1;
}
.sac-testimonial__quote::before { content: '"'; color: #0EA5E9; margin-right: .15rem; }
.sac-testimonial__quote::after { content: '"'; color: #0EA5E9; margin-left: .15rem; }
.sac-testimonial__author {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-top: 1.5rem;
  border-top: 1px solid #E2E8F0;
}
.sac-testimonial__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, #0369A1, #0EA5E9);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: .95rem;
  flex-shrink: 0;
}
.sac-testimonial__name {
  font-family: 'Inter', sans-serif;
  font-size: .9rem;
  font-weight: 700;
  color: #0F172A;
  margin: 0;
  line-height: 1.2;
}
.sac-testimonial__role {
  font-family: 'Inter', sans-serif;
  font-size: .78rem;
  color: #64748B;
  margin: .25rem 0 0;
}
.sac-testimonial--placeholder {
  background: repeating-linear-gradient(45deg, #F8FAFC, #F8FAFC 8px, #fff 8px, #fff 16px);
  border-style: dashed;
  border-color: #94A3B8;
}
.sac-testimonial--placeholder .sac-testimonial__quote {
  color: #64748B;
  font-style: italic;
}
@media (max-width: 768px) {
  .sac-testimonials { grid-template-columns: 1fr; }
  .sac-testimonial { padding: 1.75rem; }
}

/* ============================================================
   CASE STUDIES TEASER
   ============================================================ */
.sac-cases {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  margin-top: 3rem;
}
.sac-case {
  background: #0F172A;
  color: #fff;
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  transition: transform var(--dur-fast) var(--ease);
  border: 1px solid #1E293B;
}
.sac-case:hover { transform: translateY(-3px); border-color: #0EA5E9; }
.sac-case__industry {
  font-family: 'Inter', sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #0EA5E9;
}
.sac-case__title {
  font-family: 'Poppins', sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: #fff;
  margin: 0;
  line-height: 1.3;
  letter-spacing: -.01em;
}
.sac-case__result {
  font-family: 'Poppins', sans-serif;
  font-size: 2.5rem;
  font-weight: 800;
  color: #0EA5E9;
  letter-spacing: -.03em;
  line-height: 1;
}
.sac-case__metric {
  font-family: 'Inter', sans-serif;
  font-size: .8rem;
  color: rgba(255,255,255,.62);
  margin-top: -.5rem;
}
.sac-case--placeholder {
  background: repeating-linear-gradient(45deg, #1E293B, #1E293B 8px, #0F172A 8px, #0F172A 16px);
  border-style: dashed;
  border-color: #475569;
  cursor: default;
}
.sac-case--placeholder:hover { transform: none; border-color: #475569; }
@media (max-width: 768px) {
  .sac-cases { grid-template-columns: 1fr; }
  .sac-case { padding: 1.75rem; }
}

/* --- Design Tokens --------------------------------------- */
:root {
  --sac-navy:     #0F172A;
  --sac-steel:    #1E293B;
  --sac-mid:      #334155;
  --sac-blue:     #0369A1;
  --sac-blue-md:  #0284C7;
  --sac-blue-lt:  #0EA5E9;
  --sac-sky:      #38BDF8;
  --sac-white:    #FFFFFF;
  --sac-bg:       #F8FAFC;
  --sac-text:     #0F172A;
  --sac-body:     #334155;
  --sac-muted:    #64748B;
  --sac-border:   #E2E8F0;
  --ease:         cubic-bezier(.4,0,.2,1);
  --dur-fast:     150ms;
  --dur-base:     250ms;
}

/* --- Reset & Base ---------------------------------------- */
html { scroll-behavior: smooth; }
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: var(--sac-body);
  background: var(--sac-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,h2,h3,h4,h5,h6 {
  font-family: 'Poppins', sans-serif;
  font-weight: 800;
  line-height: 1.06;
  letter-spacing: -0.025em;
  color: var(--sac-text);
}

a { color: var(--sac-blue); text-decoration: none; }
img { max-width: 100%; height: auto; }

/* ============================================================
   CASSIOPEIA STRUCTURAL OVERRIDES
   ============================================================ */

/* Remove default body bg */
#sp-main-body { background: transparent !important; }

/* Full-bleed positions — edge to edge */
.container-top-a,
.container-top-b,
.container-bottom-a {
  grid-column: full-start / full-end !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Cassiopeia card chrome removal for custom modules */
.container-top-a .card,    .container-top-a .card-body,
.container-top-b .card,    .container-top-b .card-body,
.container-bottom-a .card, .container-bottom-a .card-body {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* ============================================================
   HEADER — Minimal, sticky, dark
   ============================================================ */

.container-below-top {
  background: var(--sac-steel) !important;
  grid-column: full-start / full-end !important;
  width: 100% !important;
  max-width: 100% !important;
}
.container-below-top .card,
.container-below-top .card-body {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

.container-header {
  background: var(--sac-navy) !important;
  background-image: none !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: stretch !important;
  border-bottom: 1px solid rgba(255,255,255,.07) !important;
}

/* Logo column */
.container-header > .grid-child:not(.container-below-top):not(.container-nav) {
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  padding: .625rem 1.5rem !important;
}

/* Nav column */
.container-header > .grid-child.container-nav {
  flex: 1 !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  padding: .5rem 1.5rem .5rem 0 !important;
}

/* Navbar-brand: flex row (logo img + tagline) */
.container-header .navbar-brand {
  display: flex !important;
  align-items: center !important;
  gap: .75rem !important;
  text-decoration: none !important;
}

/* Logo image — transparent PNG */
.container-header .brand-logo img,
.container-header .navbar-brand img {
  height: 46px !important;
  width: auto !important;
  background: transparent !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  filter: drop-shadow(0 1px 4px rgba(0,0,0,.4)) !important;
  display: block !important;
}

/* Site description — small muted tagline, no pseudo-elements */
.container-header .site-description {
  font-family: 'Inter', sans-serif !important;
  font-size: .62rem !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,.38) !important;
  letter-spacing: .3px !important;
  line-height: 1.35 !important;
  max-width: 130px !important;
  display: block !important;
}
.container-header .site-description::before,
.container-header .site-description::after { content: none !important; display: none !important; }

/* Navigation links */
.mod-menu,
.navbar-nav {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 0 !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.mod-menu .nav-item > a,
.navbar-nav .nav-item > a,
.mod-menu > li > a {
  font-family: 'Inter', sans-serif !important;
  font-size: .75rem !important;
  font-weight: 600 !important;
  letter-spacing: .8px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.6) !important;
  text-decoration: none !important;
  padding: .625rem .9rem !important;
  display: block !important;
  position: relative !important;
  transition: color var(--dur-fast) var(--ease) !important;
  white-space: nowrap !important;
}

.mod-menu .nav-item > a:hover,
.mod-menu > li > a:hover { color: #fff !important; }
.mod-menu .nav-item.active > a,
.mod-menu > li.active > a { color: #fff !important; }

.mod-menu .nav-item.active > a::after,
.mod-menu > li.active > a::after {
  content: '';
  position: absolute;
  bottom: 0; left: .9rem; right: .9rem;
  height: 2px;
  background: var(--sac-blue-lt);
  border-radius: 0;
}

/* Breadcrumbs — hidden (clutters the editorial layout) */
.container-breadcrumbs { display: none !important; }

/* ============================================================
   ARTICLE / CONTENT (Quiénes Somos)
   ============================================================ */
/* Breadcrumbs — hidden everywhere */
.mod-breadcrumbs__wrapper,
.container-breadcrumbs,
nav.mod-breadcrumbs__wrapper { display: none !important; }

/* Article / content area — compact */
.com-content-article__body,
.item-page {
  max-width: 860px;
  margin: 0 auto;
  padding: 3.5rem 2rem 4rem !important;
}

/* Reduce the gap the component wrapper adds */
#sp-main-body > .grid-child { padding-top: 0 !important; padding-bottom: 0 !important; }
.container-main-top, .container-main-bottom { display: none !important; }

/* Hide article title (managed via menu params) */
.page-header h1,
.com-content-article .page-header { display: none !important; }

/* Article stat boxes — Accenture-style override: remove border, card chrome */
.item-page [style*="border-radius:8px"],
.item-page [style*="border: 1px solid"],
.item-page [style*="border:1px solid"] {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 .5rem !important;
}
/* Make stat numbers use our design tokens */
.item-page [style*="font-size:2rem"],
.item-page [style*="font-size: 2rem"] {
  font-family: 'Poppins', sans-serif !important;
  font-size: 2.5rem !important;
  font-weight: 800 !important;
  color: var(--sac-blue) !important;
  letter-spacing: -.03em !important;
  line-height: 1 !important;
}

/* Inline styles override for J3 legacy content */
[style*="color: #ff0000"],
[style*="color:#ff0000"] { color: var(--sac-blue) !important; }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.sac-reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .6s var(--ease), transform .6s var(--ease);
}
.sac-reveal.visible { opacity: 1; transform: translateY(0); }
.sac-reveal-d1 { transition-delay: .07s; }
.sac-reveal-d2 { transition-delay: .14s; }
.sac-reveal-d3 { transition-delay: .21s; }
.sac-reveal-d4 { transition-delay: .28s; }
.sac-reveal-d5 { transition-delay: .35s; }

/* ============================================================
   SAC COMPONENT CLASSES — Reusable
   ============================================================ */

/* Eyebrow label */
.sac-eyebrow {
  font-family: 'Poppins', sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: var(--sac-blue);
  margin: 0 0 1.25rem;
  display: block;
}
.sac-eyebrow-lt { color: var(--sac-blue-lt); }

/* Buttons — sharp corners (Accenture-style) */
.sac-btn {
  display: inline-flex;
  align-items: center;
  gap: .625rem;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: .875rem;
  letter-spacing: .3px;
  text-decoration: none;
  cursor: pointer;
  border: none;
  border-radius: 0;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.sac-btn-primary {
  background: var(--sac-blue);
  color: #fff;
  padding: .9rem 2rem;
}
.sac-btn-primary:hover { background: var(--sac-blue-md); color: #fff; text-decoration: none; }
.sac-btn-link {
  color: rgba(255,255,255,.75);
  padding-bottom: 2px;
  border-bottom: 1px solid rgba(255,255,255,.3);
  background: transparent;
}
.sac-btn-link:hover { color: #fff; border-bottom-color: rgba(255,255,255,.7); }

/* Service rows — editorial list (Accenture-style) */
.sac-service-list { border-top: 1px solid var(--sac-border); }

.sac-service-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 2rem 0;
  border-bottom: 1px solid var(--sac-border);
  text-decoration: none;
  color: inherit;
  gap: 2rem;
  cursor: pointer;
  transition: padding-left var(--dur-fast) var(--ease);
  border-left: 3px solid transparent;
}
.sac-service-row:hover {
  padding-left: 1.25rem;
  border-left-color: var(--sac-blue);
  text-decoration: none;
}
.sac-service-row:hover .sac-srv-name { color: var(--sac-blue); }
.sac-service-row:hover .sac-srv-arrow { transform: translateX(5px); }

.sac-srv-content { flex: 1; min-width: 0; }
.sac-srv-name {
  font-family: 'Poppins', sans-serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--sac-text);
  margin: 0 0 .3rem;
  line-height: 1.2;
  transition: color var(--dur-fast) var(--ease);
}
.sac-srv-desc {
  font-size: .88rem;
  color: var(--sac-muted);
  margin: 0;
  line-height: 1.55;
}
.sac-srv-arrow {
  flex-shrink: 0;
  color: var(--sac-blue);
  transition: transform var(--dur-fast) var(--ease);
}

/* Stats row */
.sac-stats {
  display: flex;
  gap: 4rem;
  flex-wrap: wrap;
  padding-top: 2.5rem;
  margin-top: 4.5rem;
  border-top: 1px solid rgba(255,255,255,.08);
}
.sac-stat-num {
  font-family: 'Poppins', sans-serif;
  font-size: 2.75rem;
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1;
  color: #fff;
  margin: 0;
}
.sac-stat-label {
  font-size: .67rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,.32);
  margin: .6rem 0 0;
}

/* ============================================================
   SOCIAL ICONS (footer)
   ============================================================ */
.sac-social {
  display: flex;
  gap: .65rem;
  margin-top: 1.5rem;
  flex-wrap: wrap;
}
.sac-social__link {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.62);
  transition: background .2s var(--ease), border-color .2s var(--ease), color .2s var(--ease), transform .2s var(--ease);
  text-decoration: none;
}
.sac-social__link:hover,
.sac-social__link:focus-visible {
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.25);
  color: #fff;
  transform: translateY(-2px);
}
.sac-social__link svg { display: block; }

/* ============================================================
   FOOTER — full-width, remove card chrome
   ============================================================ */
.container-footer,
footer.container-footer,
[class*="container-footer"] {
  grid-column: full-start / full-end !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}
.container-footer .card,
.container-footer .card-body,
[class*="container-footer"] .card,
[class*="container-footer"] .card-body {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Free inner Cassiopeia grid-child and module wrapper in footer */
.container-footer .grid-child,
.container-footer .mod-custom,
.container-footer .custom {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Article section — tighter top padding */
.com-content-article__body,
.item-page {
  padding-top: 2.5rem !important;
}

/* ============================================================
   SECONDARY BUTTON — outline ghost (paired with primary)
   ============================================================ */
.sac-btn-link {
  border: 1px solid rgba(255,255,255,.22) !important;
  border-bottom: 1px solid rgba(255,255,255,.22) !important;
  padding: .95rem 1.75rem !important;
  background: transparent;
  color: rgba(255,255,255,.85) !important;
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.sac-btn-link:hover {
  background: rgba(255,255,255,.06) !important;
  border-color: rgba(255,255,255,.5) !important;
  color: #fff !important;
}

/* ============================================================
   WHATSAPP PILL — expanded floating button with text + status
   ============================================================ */
.sac-wa-float {
  position: fixed !important;
  bottom: 1.5rem !important;
  left: 1.5rem !important;
  right: auto !important;
  width: auto !important;
  height: auto !important;
  border-radius: 100px !important;
  background: rgba(15, 23, 42, 0.92) !important;
  border: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35), 0 2px 6px rgba(0, 0, 0, 0.2) !important;
  display: flex !important;
  align-items: center;
  gap: 0.875rem;
  padding: 0.45rem 1.25rem 0.45rem 0.45rem !important;
  text-decoration: none;
  z-index: 9999;
  transition: transform 0.2s var(--ease), border-color 0.2s var(--ease), box-shadow 0.2s var(--ease);
}
.sac-wa-float:hover,
.sac-wa-float:focus-visible {
  transform: translateY(-2px) !important;
  border-color: rgba(34, 197, 94, 0.4);
  box-shadow: 0 14px 36px rgba(34, 197, 94, 0.25), 0 4px 10px rgba(0, 0, 0, 0.3) !important;
}
.sac-wa-float:active { transform: translateY(0) !important; }

/* Icon circle (green WhatsApp) */
.sac-wa-float svg {
  width: auto !important;
  height: auto !important;
}
.sac-wa-pill__icon {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #22C55E;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(34, 197, 94, 0.35);
}
.sac-wa-pill__icon svg {
  width: 22px !important;
  height: 22px !important;
}

/* Text block (title + status) */
.sac-wa-pill__text {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  white-space: nowrap;
}
.sac-wa-pill__title {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  font-weight: 600;
  color: #fff;
  line-height: 1.15;
  letter-spacing: -0.005em;
}
.sac-wa-pill__status {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.7rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: 0.2px;
}
.sac-wa-pill__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #22C55E;
  box-shadow: 0 0 8px rgba(34, 197, 94, 0.7);
  animation: sac-wa-pulse 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes sac-wa-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.45; transform: scale(0.85); }
}

/* Mobile: collapse to icon-only to save space */
@media (max-width: 600px) {
  .sac-wa-float {
    bottom: 1rem !important;
    left: 1rem !important;
    padding: 0.35rem !important;
    border-radius: 50% !important;
  }
  .sac-wa-pill__icon { width: 46px; height: 46px; }
  .sac-wa-pill__icon svg { width: 24px !important; height: 24px !important; }
  .sac-wa-pill__text { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .sac-wa-pill__dot { animation: none; }
}

/* ============================================================
   BACK-TO-TOP BUTTON
   ============================================================ */
.sac-back-top {
  position: fixed;
  bottom: 6.5rem;
  right: 1.75rem;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: rgba(15, 23, 42, .85);
  border: 1px solid rgba(255, 255, 255, .18);
  color: rgba(255, 255, 255, .92);
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0, 0, 0, .35);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  transition: opacity .25s var(--ease), transform .25s var(--ease), background .15s var(--ease), border-color .15s var(--ease);
  padding: 0;
}
.sac-back-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.sac-back-top:hover,
.sac-back-top:focus-visible {
  background: #0EA5E9;
  border-color: #0EA5E9;
  color: #fff;
  transform: translateY(-2px);
}
.sac-back-top:active { transform: translateY(0); }
.sac-back-top svg { display: block; }

@media (max-width: 600px) {
  .sac-back-top {
    bottom: 5rem;
    right: 1rem;
    width: 42px;
    height: 42px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .sac-back-top {
    transition: opacity .15s linear, visibility .15s linear !important;
    transform: none !important;
  }
}

/* ============================================================
   INDUSTRIES GRID — responsive
   ============================================================ */
@media (max-width: 1024px) {
  .sac-industries { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 480px) {
  .sac-industries { grid-template-columns: repeat(2, 1fr) !important; gap: .65rem !important; }
}

/* ============================================================
   RESPONSIVE — comprehensive
   ============================================================ */
@media (max-width: 900px) {
  .container-header > .grid-child:not(.container-below-top):not(.container-nav) {
    padding: .5rem 1rem !important;
  }
  .container-header > .grid-child.container-nav {
    padding: .375rem 1rem .375rem 0 !important;
  }
  .mod-menu > li > a {
    font-size: .68rem !important;
    padding: .5rem .55rem !important;
  }
  .sac-srv-name { font-size: 1.1rem !important; }
  .sac-srv-desc { font-size: .82rem !important; }
  .sac-service-row { padding: 1.5rem 0 !important; gap: 1rem !important; }
  .com-content-article__body,
  .item-page { padding: 2rem 1.25rem 3rem !important; }
}

@media (max-width: 768px) {
  /* Trust strip horizontal scroll */
  [class*="container-below-top"] > .grid-child > div {
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    padding: .6rem 1rem !important;
    gap: 1.25rem !important;
    -webkit-overflow-scrolling: touch;
  }
  [class*="container-below-top"] span { white-space: nowrap !important; flex-shrink: 0 !important; }

  /* Hero tighter padding */
  [class*="container-top-a"] > .grid-child > div {
    min-height: auto !important;
    padding: 5rem 1.25rem 3rem !important;
  }

  /* Hero CTAs — full width stack */
  [class*="container-top-a"] .sac-btn {
    width: 100% !important;
    justify-content: center !important;
  }
  [class*="container-top-a"] div[style*="flex-wrap:wrap"] {
    flex-direction: column !important;
    align-items: stretch !important;
    max-width: 320px !important;
    gap: .75rem !important;
  }

  /* Stats wrap 2x2 */
  [class*="container-top-a"] div[style*="border-top:1px solid rgba(255,255,255,.08)"] > div {
    flex: 1 0 calc(50% - 1rem) !important;
  }

  /* Services section padding */
  [class*="container-top-b"] > .grid-child > div { padding: 4rem 1.25rem !important; }

  /* CTA banner stacks */
  [class*="container-bottom-a"] > .grid-child > div > div {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .sac-cta-actions { align-items: stretch !important; width: 100%; }
  .sac-cta-actions a.sac-btn { width: 100% !important; justify-content: center !important; }
  [class*="container-bottom-a"] > .grid-child > div { padding: 4rem 1.25rem !important; }

  /* Footer */
  .container-footer .grid-child > div { padding: 3.5rem 1.25rem 0 !important; }
}

@media (max-width: 480px) {
  [class*="container-top-a"] h1 {
    font-size: clamp(2.4rem, 13vw, 3.8rem) !important;
    line-height: 1.02 !important;
  }
  .sac-srv-name { font-size: 1rem !important; }
  .sac-srv-desc { font-size: .78rem !important; }
  .sac-srv-arrow { width: 18px !important; height: 18px !important; }
  [class*="container-top-a"] [style*="font-size:2.75rem"] { font-size: 2rem !important; }
}

@media (max-width: 380px) {
  body { font-size: 15px; }
  [class*="container-top-a"] > .grid-child > div { padding: 4rem 1rem 2.5rem !important; }
}

@media (prefers-reduced-motion: reduce) {
  .sac-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; }
}

/* ============================================================
   HIDE JOOMLA ARTICLE CLUTTER
   Joomla muestra por defecto: "Details", "Hits: NNN", "Prev/Next"
   estos elementos NO aportan valor en un sitio editorial moderno
   ============================================================ */
.com-content-article__body .article-info,
.com-content-article__body dl.article-info,
.com-content-article__body .article-info-term,
.com-content-article__body .hits,
.com-content-article__body dt.article-info-term,
.com-content-article__body dd,
.com-content-article > .pagenavigation,
.com-content-article .pagenav-prev,
.com-content-article .pagenav-next,
.item-page .article-info,
.item-page dl.article-info,
.item-page .pagenavigation,
.item-page .pagenav,
.item-page .pager,
.item-page > nav.pager,
nav.pager.pagenav,
.pagenavbar,
.pagenav-prev, .pagenav-next {
  display: none !important;
}

/* ============================================================
   FULL-BLEED ARTICLE PAGES — Servicios (109), Clientes (110), Contactenos (111), RS (112)
   Joomla añade body.itemid-XXX que usamos para liberar las restricciones
   ============================================================ */

/* Body navy en páginas full-bleed para que no aparezcan gaps blancos */
body.itemid-109,
body.itemid-110,
body.itemid-111,
body.itemid-112 {
  background: #0F172A !important;
}

/* Header sin border-bottom (eliminar línea blanca/gris) */
.container-header {
  border-bottom: none !important;
}

/* Eliminar gaps de wrappers Joomla en inner pages */
body.itemid-109 .site-grid,
body.itemid-110 .site-grid,
body.itemid-111 .site-grid,
body.itemid-112 .site-grid {
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;
}
body.itemid-109 .container-component > nav,
body.itemid-110 .container-component > nav,
body.itemid-111 .container-component > nav,
body.itemid-112 .container-component > nav,
body.itemid-109 .mod-breadcrumbs__wrapper,
body.itemid-110 .mod-breadcrumbs__wrapper,
body.itemid-111 .mod-breadcrumbs__wrapper,
body.itemid-112 .mod-breadcrumbs__wrapper {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}
#system-message-container:empty {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* main element flush to header */
body.itemid-109 main,
body.itemid-110 main,
body.itemid-111 main,
body.itemid-112 main {
  margin: 0 !important;
  padding: 0 !important;
}

body.itemid-109,
body.itemid-110,
body.itemid-111,
body.itemid-112 {
  /* Force full-width wrapper — original marker for grid override block below */
}
body.itemid-109 .container-component,
body.itemid-110 .container-component,
body.itemid-111 .container-component,
body.itemid-112 .container-component,
body.itemid-120 .container-component,
body.itemid-122 .container-component,
body.itemid-123 .container-component {
  grid-column: full-start / full-end !important;
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}
body.itemid-109 .com-content,
body.itemid-110 .com-content,
body.itemid-111 .com-content,
body.itemid-112 .com-content,
body.itemid-120 .com-content,
body.itemid-122 .com-content,
body.itemid-123 .com-content,
body.itemid-109 .com-content-article,
body.itemid-110 .com-content-article,
body.itemid-111 .com-content-article,
body.itemid-112 .com-content-article,
body.itemid-120 .com-content-article,
body.itemid-122 .com-content-article,
body.itemid-123 .com-content-article,
body.itemid-109 .com-content-article__body,
body.itemid-110 .com-content-article__body,
body.itemid-111 .com-content-article__body,
body.itemid-112 .com-content-article__body,
body.itemid-120 .com-content-article__body,
body.itemid-122 .com-content-article__body,
body.itemid-123 .com-content-article__body,
body.itemid-109 .item-page,
body.itemid-110 .item-page,
body.itemid-111 .item-page,
body.itemid-112 .item-page,
body.itemid-120 .item-page,
body.itemid-122 .item-page,
body.itemid-123 .item-page {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* ============================================================
   RESPONSABILIDAD SOCIAL — Human editorial design
   Distinct from corporate pages: warmer, slower, story-driven
   ============================================================ */
.sac-rs-hero {
  background: linear-gradient(180deg, #0F172A 0%, #1E293B 100%);
  color: #fff;
  padding: 7rem 2rem 5rem;
  position: relative;
  overflow: hidden;
}
.sac-rs-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 30% 40%, rgba(245,158,11,.10) 0%, transparent 50%);
  pointer-events: none;
}
.sac-rs-hero__inner { max-width: 1100px; margin: 0 auto; position: relative; }
.sac-rs-hero__eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #F59E0B;
  margin: 0 0 1.75rem;
}
.sac-rs-hero__title {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(2.25rem, 5.5vw, 4.5rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -.025em;
  color: #fff;
  margin: 0 0 2rem;
  max-width: 22ch;
}
.sac-rs-hero__title em {
  font-style: normal;
  color: #FCD34D;
}
.sac-rs-hero__lead {
  font-family: 'Poppins', sans-serif;
  font-weight: 400;
  font-size: clamp(1.1rem, 1.8vw, 1.35rem);
  color: rgba(255,255,255,.85);
  line-height: 1.55;
  max-width: 56ch;
  margin: 0;
  letter-spacing: -.005em;
}

/* Story section — warm editorial */
.sac-rs-story {
  background: #FFFBF5;
  padding: 6rem 2rem;
}
.sac-rs-story__inner {
  max-width: 760px;
  margin: 0 auto;
}
.sac-rs-story__eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: #B45309;
  margin: 0 0 1.5rem;
}
.sac-rs-story__title {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(1.75rem, 3vw, 2.75rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.02em;
  color: #1C1917;
  margin: 0 0 2.5rem;
  max-width: 22ch;
}
.sac-rs-story__body p {
  font-family: 'Inter', sans-serif;
  font-size: 1.075rem;
  line-height: 1.78;
  color: #44403C;
  margin: 0 0 1.25rem;
}
.sac-rs-story__body p:first-of-type::first-letter {
  font-family: 'Poppins', sans-serif;
  font-size: 3.5rem;
  font-weight: 700;
  float: left;
  line-height: 1;
  padding: .15em .2em 0 0;
  color: #B45309;
}
.sac-rs-story__pull {
  font-family: 'Poppins', sans-serif;
  font-size: 1.35rem;
  font-weight: 500;
  line-height: 1.4;
  color: #1C1917;
  letter-spacing: -.01em;
  padding: 2rem 0 2rem 1.75rem;
  border-left: 3px solid #F59E0B;
  margin: 2.5rem 0;
  font-style: italic;
}

/* Villages section */
.sac-rs-villages {
  background: #fff;
  padding: 6rem 2rem;
}
.sac-rs-villages__inner { max-width: 1200px; margin: 0 auto; }
.sac-rs-villages__head {
  margin-bottom: 4rem;
  max-width: 50ch;
}
.sac-rs-villages__location {
  font-family: 'Inter', sans-serif;
  font-size: .85rem;
  color: #78716C;
  margin: 1rem 0 0;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.sac-rs-villages-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}
.sac-rs-village {
  background: #FFFBF5;
  border: 1px solid #FED7AA;
  padding: 2rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
  position: relative;
  min-height: 180px;
  transition: transform var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.sac-rs-village:hover { transform: translateY(-3px); border-color: #F59E0B; }
.sac-rs-village__num {
  font-family: 'Poppins', sans-serif;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  color: #B45309;
}
.sac-rs-village__name {
  font-family: 'Poppins', sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: #1C1917;
  line-height: 1.18;
  letter-spacing: -.02em;
  margin: 0;
}
.sac-rs-village__detail {
  font-family: 'Inter', sans-serif;
  font-size: .82rem;
  color: #78716C;
  line-height: 1.5;
  margin: auto 0 0;
}
@media (max-width: 1024px) { .sac-rs-villages-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .sac-rs-villages-grid { grid-template-columns: 1fr; } }

/* Process timeline */
.sac-rs-process {
  background: #FFFBF5;
  padding: 6rem 2rem;
}
.sac-rs-process__inner { max-width: 1100px; margin: 0 auto; }
.sac-rs-process__head { margin-bottom: 4rem; max-width: 50ch; }
.sac-rs-process-timeline {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem;
  position: relative;
}
.sac-rs-process-step {
  position: relative;
  padding-top: 2.5rem;
}
.sac-rs-process-step::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 48px;
  height: 48px;
  background: #FEF3C7;
  border: 2px solid #F59E0B;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sac-rs-process-step__num {
  position: absolute;
  top: 14px;
  left: 17px;
  font-family: 'Poppins', sans-serif;
  font-size: .95rem;
  font-weight: 800;
  color: #B45309;
  z-index: 1;
}
.sac-rs-process-step__period {
  font-family: 'Inter', sans-serif;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #B45309;
  margin: 5rem 0 .75rem;
}
.sac-rs-process-step__title {
  font-family: 'Poppins', sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: #1C1917;
  line-height: 1.18;
  letter-spacing: -.02em;
  margin: 0 0 1rem;
}
.sac-rs-process-step__desc {
  font-family: 'Inter', sans-serif;
  font-size: .95rem;
  color: #44403C;
  line-height: 1.65;
  margin: 0;
}
@media (max-width: 768px) {
  .sac-rs-process-timeline { grid-template-columns: 1fr; gap: 2rem; }
}

/* CTA */
.sac-rs-cta {
  background: #1C1917;
  color: #fff;
  padding: 6rem 2rem;
}
.sac-rs-cta__inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}
.sac-rs-cta__eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: #FCD34D;
  margin: 0 0 1.25rem;
}
.sac-rs-cta__title {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(1.75rem, 3.5vw, 3rem);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -.025em;
  color: #fff;
  margin: 0 0 1.25rem;
  max-width: 24ch;
  margin-left: auto;
  margin-right: auto;
}
.sac-rs-cta__lead {
  font-family: 'Inter', sans-serif;
  font-size: 1.05rem;
  color: rgba(255,255,255,.75);
  line-height: 1.65;
  max-width: 56ch;
  margin: 0 auto 2.5rem;
}
.sac-rs-cta__buttons {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .sac-rs-hero { padding: 4rem 1.25rem 3rem; }
  .sac-rs-story,
  .sac-rs-villages,
  .sac-rs-process,
  .sac-rs-cta { padding: 4rem 1.25rem; }
}

/* Default fallback for OTHER articles: keep narrow column for regular content */
.item-page {
  max-width: 860px;
  padding: 3rem 2rem;
  margin: 0 auto;
}

/* Hide article title h1 since we use custom heroes */
.item-page > .page-header,
.item-page > .page-header h1,
.com-content-article .page-header {
  display: none !important;
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.sac-contact-channels {
  background: #fff;
  padding: 5rem 2rem;
}
.sac-contact-channels__inner { max-width: 1200px; margin: 0 auto; }
.sac-contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 3rem;
}
.sac-contact-card {
  background: #fff;
  border: 1px solid #E2E8F0;
  padding: 2.5rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  text-decoration: none;
  color: inherit;
  transition: border-color var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.sac-contact-card:hover {
  border-color: #0369A1;
  transform: translateY(-3px);
  text-decoration: none;
}
.sac-contact-card--whatsapp {
  background: #0F172A;
  color: #fff;
  border-color: #1E293B;
}
.sac-contact-card--whatsapp:hover { border-color: #22C55E; }
.sac-contact-card__icon {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  background: #EFF6FF;
  color: #0369A1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.sac-contact-card--whatsapp .sac-contact-card__icon { background: #22C55E; color: #fff; }
.sac-contact-card__label {
  font-family: 'Inter', sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #64748B;
  margin: 0;
}
.sac-contact-card--whatsapp .sac-contact-card__label { color: rgba(255,255,255,.72); }
.sac-contact-card__value {
  font-family: 'Poppins', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: #0F172A;
  letter-spacing: -.02em;
  line-height: 1.15;
  margin: 0;
}
.sac-contact-card--whatsapp .sac-contact-card__value { color: #fff; }
.sac-contact-card__note {
  font-family: 'Inter', sans-serif;
  font-size: .85rem;
  color: #64748B;
  line-height: 1.5;
  margin: 0;
  flex: 1;
}
.sac-contact-card--whatsapp .sac-contact-card__note { color: rgba(255,255,255,.62); }
.sac-contact-card__cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: 'Inter', sans-serif;
  font-size: .85rem;
  font-weight: 600;
  color: #0369A1;
  margin-top: .5rem;
}
.sac-contact-card--whatsapp .sac-contact-card__cta { color: #22C55E; }
@media (max-width: 768px) {
  .sac-contact-grid { grid-template-columns: 1fr; gap: 1rem; }
  .sac-contact-card { padding: 1.75rem; }
  .sac-contact-channels { padding: 3rem 1.25rem; }
}

/* Contact form */
.sac-contact-form-section {
  background: #F8FAFC;
  padding: 6rem 2rem;
}
.sac-contact-form-section__inner {
  max-width: 720px;
  margin: 0 auto;
}
.sac-form {
  background: #fff;
  border: 1px solid #E2E8F0;
  padding: 2.5rem;
  margin-top: 2.5rem;
}
.sac-form__field {
  margin-bottom: 1.5rem;
}
.sac-form__label {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: .78rem;
  font-weight: 600;
  color: #334155;
  margin-bottom: .5rem;
  letter-spacing: .3px;
}
.sac-form__label--required::after { content: ' *'; color: #DC2626; }
.sac-form__input,
.sac-form__textarea {
  width: 100%;
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  color: #0F172A;
  background: #fff;
  border: 1px solid #E2E8F0;
  padding: .75rem 1rem;
  border-radius: 0;
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.sac-form__input:focus,
.sac-form__textarea:focus {
  outline: none;
  border-color: #0EA5E9;
  box-shadow: 0 0 0 3px rgba(14,165,233,.15);
}
.sac-form__textarea {
  min-height: 130px;
  resize: vertical;
  font-family: 'Inter', sans-serif;
}

/* Custom select with consistent design language */
.sac-form__select {
  width: 100%;
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  color: #0F172A;
  background: #fff;
  border: 1px solid #E2E8F0;
  padding: .75rem 2.5rem .75rem 1rem;
  border-radius: 0;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2.5'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 12px;
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.sac-form__select:focus {
  outline: none;
  border-color: #0EA5E9;
  box-shadow: 0 0 0 3px rgba(14,165,233,.15);
}

/* Submit button — loading state */
.sac-form__submit {
  position: relative;
  min-height: 52px;
}
.sac-form__submit[data-state="sending"] {
  pointer-events: none;
  background: #16A34A;
  opacity: .85;
}
.sac-form__submit[data-state="sending"] .sac-form__submit-text { opacity: 0; }
.sac-form__submit[data-state="sending"]::after {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: sac-spin .7s linear infinite;
}
.sac-form__submit[data-state="sent"] {
  background: #15803D;
  pointer-events: none;
}
.sac-form__submit[data-state="sent"] .sac-form__submit-text::before {
  content: '✓ ';
  margin-right: .3rem;
}
@keyframes sac-spin {
  to { transform: rotate(360deg); }
}

/* ============================================================
   CONTACT CARDS — emphasize WhatsApp as primary
   ============================================================ */
.sac-contact-grid {
  grid-template-columns: 1.4fr 1fr 1fr !important;
}
@media (max-width: 768px) {
  .sac-contact-grid { grid-template-columns: 1fr !important; }
}
.sac-contact-card--whatsapp {
  padding: 3rem 2.25rem !important;
  position: relative;
}
.sac-contact-card--whatsapp::before {
  content: 'Recomendado';
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  background: #22C55E;
  color: #fff;
  font-family: 'Inter', sans-serif;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: .25rem .65rem;
  border-radius: 100px;
}
.sac-contact-card__response {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-family: 'Inter', sans-serif;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .5px;
  color: #16A34A;
  margin-top: .5rem;
}
.sac-contact-card--whatsapp .sac-contact-card__response { color: #4ADE80; }
.sac-contact-card__response::before {
  content: '';
  width: 6px;
  height: 6px;
  background: currentColor;
  border-radius: 50%;
  display: inline-block;
  animation: sac-pulse 2s infinite;
}
@keyframes sac-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .4; }
}

/* ============================================================
   GOOGLE MAPS EMBED
   ============================================================ */
.sac-map-section {
  background: #F8FAFC;
  padding: 4rem 2rem;
}
.sac-map-section__inner { max-width: 1200px; margin: 0 auto; }
.sac-map-embed {
  width: 100%;
  height: 380px;
  border: 1px solid #E2E8F0;
  margin-top: 2rem;
  filter: grayscale(.3) contrast(1.05);
}
@media (max-width: 768px) {
  .sac-map-section { padding: 3rem 1.25rem; }
  .sac-map-embed { height: 280px; }
}
.sac-form__submit {
  width: 100%;
  background: #22C55E;
  color: #fff;
  border: none;
  padding: 1rem 1.5rem;
  font-family: 'Poppins', sans-serif;
  font-size: .95rem;
  font-weight: 600;
  letter-spacing: .3px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .625rem;
  transition: background var(--dur-fast) var(--ease);
}
.sac-form__submit:hover { background: #16A34A; }
.sac-form__hint {
  font-family: 'Inter', sans-serif;
  font-size: .78rem;
  color: #64748B;
  text-align: center;
  margin: 1rem 0 0;
  line-height: 1.5;
}
@media (max-width: 768px) {
  .sac-contact-form-section { padding: 3rem 1.25rem; }
  .sac-form { padding: 1.75rem; }
}

/* ============================================================
   HERO — World-class refinements
   ============================================================ */
.sac-hero {
  min-height: 88vh;
  background: #0F172A;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 6rem 2rem 4rem;
  position: relative;
  overflow: hidden;
}

/* Background layers — depth without imagery */
.sac-hero__bg-glow {
  position: absolute;
  top: 30%; left: -10%;
  width: 70%; height: 70%;
  background: radial-gradient(ellipse, rgba(14,165,233,.12) 0%, transparent 65%);
  pointer-events: none;
  z-index: 0;
  filter: blur(40px);
}
.sac-hero__bg-grid {
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 24px 24px;
  pointer-events: none;
  mask-image: radial-gradient(ellipse at center, black 40%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 40%, transparent 75%);
}
.sac-hero__accent {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, #0369A1 20%, #0EA5E9 50%, transparent 100%);
  background-size: 200% 100%;
  animation: sac-hero-line 6s linear infinite;
}
@keyframes sac-hero-line {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.sac-hero__inner {
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  position: relative;
  z-index: 1;
}

/* Eyebrow with active indicator */
.sac-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  font-family: 'Inter', sans-serif;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #0EA5E9;
  margin: 0 0 2rem;
  padding: .5rem 1rem .5rem .85rem;
  background: rgba(14,165,233,.08);
  border: 1px solid rgba(14,165,233,.18);
  border-radius: 100px;
}
.sac-hero__pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #22C55E;
  position: relative;
  box-shadow: 0 0 6px rgba(34,197,94,.6);
}
.sac-hero__pulse::after {
  content: '';
  position: absolute;
  inset: -3px;
  border: 2px solid #22C55E;
  border-radius: 50%;
  animation: sac-hero-ping 2s cubic-bezier(0, 0, 0.2, 1) infinite;
  opacity: 0;
}
@keyframes sac-hero-ping {
  0% { transform: scale(.5); opacity: 1; }
  100% { transform: scale(2.2); opacity: 0; }
}

/* Headline — forced 2 lines for maximum impact */
.sac-hero__title {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(2.75rem, 8vw, 6.5rem);
  font-weight: 800;
  line-height: 1.0;
  letter-spacing: -.035em;
  margin: 0 0 2rem;
  max-width: 100%;
}
.sac-hero__title-1 {
  display: block;
  color: #fff;
}
.sac-hero__title-2 {
  display: block;
  background: linear-gradient(135deg, #0EA5E9 0%, #38BDF8 60%, #7DD3FC 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  white-space: nowrap;
}
@media (max-width: 768px) {
  .sac-hero__title-2 { white-space: normal; }
}

/* Lead */
.sac-hero__lead {
  font-family: 'Inter', sans-serif;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255,255,255,.7);
  margin: 0 0 2.5rem;
  max-width: 56ch;
}
.sac-hero__lead strong { color: #fff; font-weight: 600; }

/* CTAs */
.sac-hero__ctas {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  flex-wrap: wrap;
  margin-bottom: 3.5rem;
}

/* Trusted-by row — REAL social proof */
.sac-hero__trusted {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin-bottom: 2.5rem;
}
.sac-hero__trusted-label {
  font-family: 'Inter', sans-serif;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(255,255,255,.42);
  margin: 0 0 1.25rem;
}
.sac-hero__trusted-logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2.5rem;
  font-family: 'Poppins', sans-serif;
  font-size: 1.05rem;
  font-weight: 600;
  color: rgba(255,255,255,.55);
  letter-spacing: -.005em;
}
.sac-hero__trusted-logos span {
  position: relative;
  white-space: nowrap;
  transition: color .2s ease;
}
.sac-hero__trusted-logos a { color: inherit; text-decoration: none; }
.sac-hero__trusted-logos a:hover span { color: #fff; }
.sac-hero__trusted-more {
  font-size: .82rem !important;
  font-weight: 500 !important;
  letter-spacing: .3px !important;
  color: #0EA5E9 !important;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}
@media (max-width: 768px) {
  .sac-hero__trusted-logos { gap: 1.25rem; font-size: .95rem; }
}

/* Stats row */
.sac-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2.5rem;
}
.sac-hero__stat {
  position: relative;
}
.sac-hero__stat-num {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(1.9rem, 3.2vw, 2.75rem);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1;
  color: #fff;
  margin: 0;
}
.sac-hero__stat-label {
  font-family: 'Inter', sans-serif;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  margin: .65rem 0 0;
}
@media (max-width: 768px) {
  .sac-hero { padding: 4rem 1.25rem 3rem; min-height: auto; }
  .sac-hero__stats { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
  .sac-hero__title { font-size: clamp(2.5rem, 12vw, 4rem) !important; }
  .sac-hero__lead { font-size: 1rem; }
}

/* Scroll cue */
.sac-hero__scroll-cue {
  position: absolute;
  bottom: 1.25rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'Inter', sans-serif;
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  animation: sac-bob 2.4s ease-in-out infinite;
}
.sac-hero__scroll-cue::after {
  content: '';
  width: 1px;
  height: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.3) 0%, transparent 100%);
}
@keyframes sac-bob {
  0%, 100% { transform: translate(-50%, 0); }
  50% { transform: translate(-50%, 6px); }
}
@media (max-width: 768px) {
  .sac-hero__scroll-cue { display: none; }
}

/* ============================================================
   CLIENTES PAGE — Editorial showcase
   ============================================================ */

/* When in article page, remove article body padding to let our full-bleed work */
.item-page.sac-clients-page,
body.sac-clients .com-content-article__body {
  padding: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
}

/* HERO of clientes page */
.sac-clients-hero {
  background: linear-gradient(160deg,#0F172A 0%,#0F172A 60%,#0c1829 100%);
  color: #fff;
  padding: 7rem 2rem 5rem;
  position: relative;
  overflow: hidden;
}
.sac-clients-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
}
.sac-clients-hero::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg,#0369A1 0%,#0EA5E9 40%,transparent 100%);
}
.sac-clients-hero__inner { max-width: 1200px; margin: 0 auto; position: relative; }
.sac-clients-hero__eyebrow {
  font-family: 'Inter',sans-serif;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #0EA5E9;
  margin: 0 0 1.5rem;
}
.sac-clients-hero__title {
  font-family: 'Poppins',sans-serif;
  font-size: clamp(2.5rem,6vw,5rem);
  font-weight: 800;
  line-height: 1.03;
  letter-spacing: -.035em;
  color: #fff;
  margin: 0 0 1.5rem;
  max-width: 18ch;
}
.sac-clients-hero__title em { color: #0EA5E9; font-style: normal; }
.sac-clients-hero__lead {
  font-family: 'Inter',sans-serif;
  font-size: 1.1rem;
  color: rgba(255,255,255,.62);
  line-height: 1.7;
  max-width: 60ch;
  margin: 0 0 3.5rem;
}
.sac-clients-stats {
  display: flex;
  gap: 4rem;
  flex-wrap: wrap;
  padding-top: 2.5rem;
  border-top: 1px solid rgba(255,255,255,.08);
}
.sac-clients-stat__num {
  font-family: 'Poppins',sans-serif;
  font-size: 2.5rem;
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1;
  color: #fff;
  margin: 0;
}
.sac-clients-stat__label {
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,.58);
  margin: .6rem 0 0;
}

/* PRESTIGE GRID — featured clients */
.sac-prestige {
  background: #fff;
  padding: 6rem 2rem;
}
.sac-prestige__inner { max-width: 1200px; margin: 0 auto; }
.sac-prestige__head {
  margin-bottom: 4rem;
  max-width: 60ch;
}
.sac-prestige__title {
  font-family: 'Poppins',sans-serif;
  font-size: clamp(1.75rem,3vw,2.75rem);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.1;
  color: #0F172A;
  margin: .5rem 0 1rem;
}
.sac-prestige__sub {
  font-family: 'Inter',sans-serif;
  font-size: 1rem;
  color: #475569;
  line-height: 1.65;
  margin: 0;
}
.sac-prestige-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 1px;
  background: #E2E8F0;
  border: 1px solid #E2E8F0;
}
@media (min-width: 1024px) {
  .sac-prestige-grid { grid-template-columns: repeat(4,1fr); }
}
.sac-prestige-card {
  background: #fff;
  padding: 2.5rem 2rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
  min-height: 200px;
  transition: background var(--dur-fast) var(--ease);
}
.sac-prestige-card:hover { background: #F8FAFC; }
.sac-prestige-card__tag {
  font-family: 'Inter',sans-serif;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #0369A1;
}
.sac-prestige-card__name {
  font-family: 'Poppins',sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  color: #0F172A;
  line-height: 1.2;
  letter-spacing: -.015em;
  margin: 0;
  flex: 1;
}
.sac-prestige-card__note {
  font-family: 'Inter',sans-serif;
  font-size: .8rem;
  color: #64748B;
  line-height: 1.5;
  margin: 0;
}

/* INDUSTRIES BREAKDOWN */
.sac-clients-industries {
  background: #F8FAFC;
  padding: 6rem 2rem;
}
.sac-clients-industries__inner { max-width: 1200px; margin: 0 auto; }
.sac-clients-industries__head {
  margin-bottom: 4rem;
  max-width: 60ch;
}
.sac-clients-industries__title {
  font-family: 'Poppins',sans-serif;
  font-size: clamp(1.75rem,3vw,2.75rem);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.1;
  color: #0F172A;
  margin: .5rem 0 1rem;
}
.sac-industry-block {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 3rem;
  padding: 2.5rem 0;
  border-top: 1px solid #E2E8F0;
  align-items: start;
}
.sac-industry-block:last-child { border-bottom: 1px solid #E2E8F0; }
.sac-industry-block__head {
  position: sticky;
  top: 100px;
}
.sac-industry-block__num {
  font-family: 'Poppins',sans-serif;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: 2px;
  color: #0EA5E9;
  margin: 0 0 .5rem;
}
.sac-industry-block__name {
  font-family: 'Poppins',sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: #0F172A;
  line-height: 1.2;
  letter-spacing: -.02em;
  margin: 0 0 .5rem;
}
.sac-industry-block__count {
  font-family: 'Inter',sans-serif;
  font-size: .8rem;
  color: #64748B;
  margin: 0;
}
.sac-industry-block__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.sac-industry-block__list li {
  font-family: 'Inter',sans-serif;
  font-size: .92rem;
  color: #334155;
  line-height: 1.5;
  padding: .65rem 0;
  border-bottom: 1px solid #E2E8F0;
}
.sac-industry-block__list li:last-child { border-bottom: none; }
.sac-industry-block__list strong {
  color: #0F172A;
  font-weight: 600;
}

@media (max-width: 768px) {
  .sac-clients-hero { padding: 5rem 1.25rem 3rem; }
  .sac-prestige { padding: 4rem 1.25rem; }
  .sac-clients-industries { padding: 4rem 1.25rem; }
  .sac-prestige-grid { grid-template-columns: 1fr; }
  .sac-industry-block { grid-template-columns: 1fr; gap: 1rem; padding: 2rem 0; }
  .sac-industry-block__head { position: static; }
  .sac-clients-stats { gap: 2rem; }
  .sac-clients-stat__num { font-size: 2rem; }
}

/* CTA close-out of clientes page */
.sac-clients-cta {
  background: #0F172A;
  padding: 6rem 2rem;
}
.sac-clients-cta__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 3rem;
  flex-wrap: wrap;
}
.sac-clients-cta h2 {
  font-family: 'Poppins',sans-serif;
  font-size: clamp(1.75rem,3.5vw,3rem);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.1;
  color: #fff;
  margin: .5rem 0 0;
  max-width: 18ch;
}
@media (max-width: 768px) {
  .sac-clients-cta { padding: 4rem 1.25rem; }
  .sac-clients-cta__inner { flex-direction: column; align-items: stretch; }
}

/* ============================================================
   SERVICE PAGE BANNER HERO
   Banner SVG inyectado como hero en /servicios/* pages
   ============================================================ */
.sac-service-banner {
  position: relative;
}
.sac-service-banner img {
  display: block;
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
}
/* Limita altura máxima del banner en pantallas anchas (evita que crezca demasiado) */
@media (min-width: 1400px) {
  .sac-service-banner img {
    max-height: 480px;
    object-fit: cover;
    object-position: center;
  }
}

/* ============================================================
   FIX: Servidores/Soporte/Redes (itemid-120/122/123) gap navy
   + UX/UI world-class enhancements
   ============================================================ */
body.itemid-120 .site-grid,
body.itemid-122 .site-grid,
body.itemid-123 .site-grid {
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;
}
body.itemid-120 main,
body.itemid-122 main,
body.itemid-123 main {
  margin: 0 !important;
  padding: 0 !important;
}
body.itemid-120 .container-component > nav,
body.itemid-122 .container-component > nav,
body.itemid-123 .container-component > nav,
body.itemid-120 .mod-breadcrumbs__wrapper,
body.itemid-122 .mod-breadcrumbs__wrapper,
body.itemid-123 .mod-breadcrumbs__wrapper {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}
body.itemid-120,
body.itemid-122,
body.itemid-123 {
  background: #0F172A;
}

/* Banner — transición suave navy → blanco con gradient */
.sac-service-banner {
  position: relative;
  background: #0F172A;
  line-height: 0;
}
.sac-service-banner::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 80px;
  background: linear-gradient(180deg, rgba(15,23,42,0) 0%, rgba(255,255,255,0.04) 60%, #ffffff 100%);
  pointer-events: none;
  z-index: 2;
}

/* Scroll cue indicator */
.sac-scroll-cue {
  position: absolute;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  z-index: 3;
  width: 28px;
  height: 44px;
  border: 2px solid rgba(14,165,233,0.6);
  border-radius: 14px;
  display: flex;
  justify-content: center;
  padding-top: 8px;
  pointer-events: none;
}
.sac-scroll-cue::before {
  content: '';
  display: block;
  width: 4px;
  height: 8px;
  background: #0EA5E9;
  border-radius: 2px;
  animation: sac-scroll-pulse 1.8s ease-in-out infinite;
}
@keyframes sac-scroll-pulse {
  0%   { transform: translateY(0);    opacity: 1; }
  50%  { transform: translateY(10px); opacity: 0.4; }
  100% { transform: translateY(0);    opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .sac-scroll-cue::before { animation: none; }
}

/* Card micro-interactions — sutil lift en hover */
.sac-card, .sac-soft-card, .sac-chip-card, .sac-cycle-step,
.sac-software-card, .sac-hardware-chip, .sac-cert-card {
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}
.sac-card:hover, .sac-soft-card:hover, .sac-chip-card:hover,
.sac-cycle-step:hover, .sac-software-card:hover,
.sac-hardware-chip:hover, .sac-cert-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(15,23,42,0.10);
  border-color: rgba(14,165,233,0.35);
}

/* Sección que sigue al banner — padding generoso para respirar */
body.itemid-120 .sac-service-banner + *,
body.itemid-122 .sac-service-banner + *,
body.itemid-123 .sac-service-banner + * {
  padding-top: 3.5rem;
}

/* ============================================================
   Clientes banner — CTA "VER LISTA COMPLETA" clickeable
   ============================================================ */
html { scroll-behavior: smooth; }
.sac-banner-cta {
  cursor: pointer;
  transition: background-color 180ms ease;
  border-radius: 4px;
}
.sac-banner-cta:hover,
.sac-banner-cta:focus-visible {
  background-color: rgba(14, 165, 233, 0.12);
  outline: 2px solid rgba(14, 165, 233, 0.45);
  outline-offset: -2px;
}
/* Scroll offset for sticky/fixed header */
#listado-clientes {
  scroll-margin-top: 80px;
}

/* ============================================================
   CREDENCIALES — Editorial world-class section (Redes)
   ============================================================ */
.sac-creds {
  background: linear-gradient(180deg, #0F172A 0%, #0B1322 100%);
  color: #fff;
  padding: 7rem 2rem;
  position: relative;
  overflow: hidden;
}
.sac-creds__top-line {
  position: absolute; top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, #0EA5E9 50%, transparent 100%);
  opacity: 0.55;
}
.sac-creds::before {
  content: ''; position: absolute; top: -200px; right: -200px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(14,165,233,0.08) 0%, transparent 70%);
  pointer-events: none;
}
.sac-creds__inner {
  max-width: 1180px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.sac-creds__header {
  margin-bottom: 5rem;
  max-width: 820px;
}
.sac-creds__title {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(2rem, 3.6vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.08;
  color: #fff;
  margin: 0.75rem 0 1.5rem;
}
.sac-creds__lead {
  font-family: 'Inter', sans-serif;
  font-size: 1.05rem;
  color: rgba(255,255,255,0.72);
  line-height: 1.7;
  margin: 0;
  max-width: 65ch;
}
.sac-creds__lead strong { color: #fff; font-weight: 700; }

/* Stat row */
.sac-creds__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255,255,255,0.10);
  border-bottom: 1px solid rgba(255,255,255,0.10);
  margin-bottom: 5rem;
}
.sac-creds__stat {
  padding: 2.5rem 1.75rem;
  border-right: 1px solid rgba(255,255,255,0.08);
  transition: background-color 240ms ease;
}
.sac-creds__stat:last-child { border-right: none; }
.sac-creds__stat:hover { background: rgba(14,165,233,0.05); }
.sac-creds__stat-num {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(1.4rem, 2vw, 1.75rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #0EA5E9;
  margin: 0 0 0.625rem;
  line-height: 1.1;
}
.sac-creds__stat-lbl {
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.55);
  margin: 0;
  line-height: 1.5;
}

/* Brands grid */
.sac-creds__brands-label {
  font-family: 'Inter', sans-serif;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.40);
  margin: 0 0 2rem;
}
.sac-creds__brands {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
.sac-creds__brand {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 2.5rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 130px;
  transition: background-color 260ms ease, border-color 260ms ease, transform 260ms ease;
}
.sac-creds__brand:hover {
  background: #fff;
  border-color: #fff;
  transform: translateY(-2px);
}
.sac-creds__brand img {
  max-height: 44px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: 0.72;
  transition: filter 260ms ease, opacity 260ms ease;
}
.sac-creds__brand:hover img {
  filter: none;
  opacity: 1;
}

/* Tablet */
@media (max-width: 900px) {
  .sac-creds { padding: 5rem 1.5rem; }
  .sac-creds__header { margin-bottom: 3rem; }
  .sac-creds__stats { grid-template-columns: repeat(2, 1fr); margin-bottom: 3.5rem; }
  .sac-creds__stat:nth-child(2) { border-right: none; }
  .sac-creds__stat:nth-child(1),
  .sac-creds__stat:nth-child(2) { border-bottom: 1px solid rgba(255,255,255,0.08); }
  .sac-creds__brands { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .sac-creds__stats { grid-template-columns: 1fr; }
  .sac-creds__stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.08); }
  .sac-creds__stat:last-child { border-bottom: none; }
  .sac-creds__brands { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .sac-creds__stat, .sac-creds__brand, .sac-creds__brand img { transition: none; }
}
