/* service.css — páginas genéricas (service.html / contact.html).
   Reusa el kit de secciones de strategic-partner.css (so-hero, eyebrow, cta-row,
   lead, so-cta). Rediseño "refined-energetic": grid de cards, alto contraste,
   hover que enriquece, y un set de FX de hero variados por categoría.
   Scopeado a .svc — NO toca home/strategic-partner/building-the-future. */

/* ====== HERO ====== */
.svc .so-hero { position: relative; overflow: hidden;
  padding-block: clamp(3.5rem, 9vw, 7rem) clamp(2.5rem, 6vw, 4.5rem); }
.svc .so-hero h1 { font-size: var(--fs-800); line-height: 1.04; letter-spacing: -.02em; }
.svc .so-hero .lead { max-width: 60ch; margin-inline: auto; color: var(--ws-text); opacity: .9; }
.svc .eyebrow { display: inline-flex; align-items: center; gap: .5rem; padding: .4rem .9rem;
  border: 1px solid var(--ws-glass-brd); border-radius: 999px; background: var(--ws-glass);
  font-size: .78rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--ws-mint); }
.svc .hero-chips { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; margin-top: var(--space-4); }
.svc .hero-chips span { display: inline-flex; align-items: center; gap: .4rem; padding: .35rem .8rem;
  border: 1px solid var(--ws-line); border-radius: 999px; background: var(--ws-surface-2);
  font-size: .82rem; color: var(--ws-text); }
.svc .hero-chips svg { width: 1em; height: 1em; color: var(--ws-cyan); }

/* --- FX de fondo del hero (un layer por categoría) --- */
.hero-fx-mesh, .hero-fx-beams, .hero-fx-grid { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.svc .so-hero .inner { position: relative; z-index: 2; }
/* gradient mesh (Cloud & Security) */
.hero-fx-mesh { overflow: hidden; }
.hero-fx-mesh::before, .hero-fx-mesh::after { content: ""; position: absolute; width: 55vw; height: 55vw;
  border-radius: 50%; filter: blur(90px); opacity: .45; }
.hero-fx-mesh::before { background: radial-gradient(circle, var(--ws-teal), transparent 70%);
  top: -22%; left: -8%; animation: fxMeshA 16s ease-in-out infinite alternate; }
.hero-fx-mesh::after { background: radial-gradient(circle, var(--ws-cyan), transparent 70%);
  bottom: -28%; right: -8%; animation: fxMeshB 20s ease-in-out infinite alternate; }
@keyframes fxMeshA { to { transform: translate(12%, 10%) scale(1.15); } }
@keyframes fxMeshB { to { transform: translate(-10%, -8%) scale(1.1); } }
/* diagonal beams (Industries) */
.hero-fx-beams { overflow: hidden; opacity: .5;
  background: repeating-linear-gradient(115deg, transparent 0 38px,
    color-mix(in srgb, var(--ws-cyan) 9%, transparent) 38px 40px);
  -webkit-mask-image: linear-gradient(to bottom, #000, transparent);
          mask-image: linear-gradient(to bottom, #000, transparent);
  animation: fxBeams 22s linear infinite; }
@keyframes fxBeams { to { background-position: 560px 0; } }
/* animated grid (Company / fallback) */
.hero-fx-grid { background-image:
    linear-gradient(var(--ws-line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--ws-line-soft) 1px, transparent 1px);
  background-size: 46px 46px;
  -webkit-mask-image: radial-gradient(ellipse at center, #000, transparent 75%);
          mask-image: radial-gradient(ellipse at center, #000, transparent 75%);
  animation: fxGrid 32s linear infinite; }
@keyframes fxGrid { to { background-position: 46px 46px; } }

/* ====== GRID DE CARDS ====== */
.svc-grid-h { text-align: center; margin: 0 0 var(--space-5); font-size: var(--fs-700); font-weight: 800;
  letter-spacing: -.02em; position: relative; padding-bottom: var(--space-3); }
.svc-grid-h::after { content: ""; position: absolute; left: 50%; bottom: 0; transform: translateX(-50%);
  width: 64px; height: 3px; border-radius: 2px; background: var(--ws-grad-brand); }
.svc-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-4);
  max-width: 1080px; margin-inline: auto; }
@media (max-width: 760px) { .svc-grid { grid-template-columns: 1fr; } }

.svc-card { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-5);
  scroll-margin-top: 88px; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.svc-card:hover { transform: translateY(-5px);
  box-shadow: 0 26px 54px -26px color-mix(in srgb, var(--ws-teal) 60%, transparent);
  border-color: color-mix(in srgb, var(--ws-cyan) 50%, transparent); }
.svc-card-h { font-size: var(--fs-500); font-weight: 700; margin: 0; letter-spacing: -.015em; color: var(--ws-text); }
.svc-card-h::after { content: ""; display: block; width: 34px; height: 3px; margin-top: .6rem;
  border-radius: 2px; background: var(--ws-grad-brand); opacity: .9; transition: width .25s ease; }
.svc-card:hover .svc-card-h::after { width: 56px; }
.svc-card p { color: var(--ws-text); line-height: 1.65; margin: 0; }
.svc-card p + p { margin-top: var(--space-2); }

/* badge de icono */
.svc-ic { width: 52px; height: 52px; display: inline-grid; place-items: center; border-radius: 14px;
  background: var(--ws-grad-brand); border: 1px solid var(--ws-glass-brd);
  box-shadow: 0 12px 30px -14px color-mix(in srgb, var(--ws-teal) 70%, transparent);
  transition: transform .25s ease; }
.svc-ic svg { width: 25px; height: 25px; color: #fff; }
.svc-card:hover .svc-ic { transform: translateY(-2px) scale(1.06); }

/* reveal escalonado dentro del grid */
.svc-grid > .reveal:nth-child(2) { transition-delay: .07s; }
.svc-grid > .reveal:nth-child(3) { transition-delay: .14s; }
.svc-grid > .reveal:nth-child(4) { transition-delay: .21s; }
.svc-grid > .reveal:nth-child(5) { transition-delay: .28s; }
.svc-grid > .reveal:nth-child(6) { transition-delay: .35s; }

/* ====== Listas / enlaces / imágenes dentro de cards ====== */
.svc-list { list-style: none; padding: 0; margin: var(--space-2) 0 0; display: grid; gap: .6rem; }
.svc-list li { display: flex; gap: .6rem; align-items: flex-start; color: var(--ws-text); line-height: 1.5; }
.svc-list li svg { color: var(--ws-mint); flex: 0 0 auto; width: 1.1em; height: 1.1em; margin-top: .15em; }

.svc-links { list-style: none; padding: 0; margin: var(--space-2) 0 0; display: grid; gap: .55rem; }
.svc-links a { display: flex; gap: .55rem; align-items: baseline; color: var(--ws-text); text-decoration: none; }
.svc-links a:hover { color: var(--ws-cyan); text-decoration: underline; }
.svc-links svg { color: var(--ws-cyan); flex: 0 0 auto; width: 1em; height: 1em; }

/* placeholder de imagen */
.svc-imgph { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .5rem;
  text-align: center; padding: var(--space-5) var(--space-4); margin: var(--space-2) 0 0;
  border: 2px dashed color-mix(in srgb, var(--ws-teal) 45%, transparent); border-radius: var(--radius);
  background: color-mix(in srgb, var(--ws-teal) 6%, transparent); color: var(--ws-muted); }
.svc-imgph svg { width: 2rem; height: 2rem; opacity: .7; }
.svc-imgph span { font-weight: 600; letter-spacing: .03em; text-transform: uppercase; font-size: .8rem; }
.svc-imgph em { font-style: normal; font-size: .95rem; max-width: 46ch; }

/* figura de imagen con filtro adaptable a tema */
.svc-fig { margin: var(--space-2) 0 0; border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--ws-line); background: var(--ws-surface-2); }
.svc-fig img { width: 100%; display: block; cursor: zoom-in; }
[data-theme="dark"] .svc-fig img { filter: brightness(.9) contrast(1.04) saturate(1.03); }

/* lightbox (imagen a tamaño completo al clic) */
.ws-lightbox { position: fixed; inset: 0; z-index: 9999; display: grid; place-items: center; padding: 4vmin;
  background: rgba(2,8,16,.86); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  opacity: 0; transition: opacity .2s ease; cursor: zoom-out; }
.ws-lightbox.open { opacity: 1; }
.ws-lightbox img { max-width: 95vw; max-height: 90vh; width: auto; height: auto; border-radius: 10px;
  background: #fff; box-shadow: 0 30px 80px -20px rgba(0,0,0,.85); cursor: default; }
.ws-lightbox-close { position: fixed; top: 16px; right: 24px; background: none; border: 0; color: #fff;
  font-size: 42px; line-height: 1; cursor: pointer; opacity: .85; }
.ws-lightbox-close:hover { opacity: 1; }
[data-theme="light"] .svc-fig img { filter: brightness(1.02) contrast(.99); }
.svc-fig.logos { background: var(--ws-surface); padding: var(--space-4); border-style: dashed; }
[data-theme="dark"] .svc-fig.logos img { filter: brightness(0) invert(1) opacity(.85); }
[data-theme="light"] .svc-fig.logos img { filter: none; }

/* stack layout (legal / largo): una columna legible */
.svc-grid.stack { grid-template-columns: 1fr; max-width: 820px; }
/* card solitaria: no flota en 2 columnas — se centra */
.svc-grid > .svc-card:only-child { grid-column: 1 / -1; max-width: 760px; margin-inline: auto; width: 100%; }

/* ====== Magazine: masonry de article cards (preview) ====== */
.mag-grid { columns: 2; column-gap: var(--space-4); max-width: 1080px; margin-inline: auto; }
@media (max-width: 760px) { .mag-grid { columns: 1; } }
.mag-card { display: block; break-inside: avoid; margin: 0 0 var(--space-4);
  background: var(--ws-surface); border: 1px solid var(--ws-line); border-radius: var(--radius);
  padding: var(--space-4); text-decoration: none; color: inherit;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.mag-card:hover { transform: translateY(-4px);
  box-shadow: 0 22px 46px -24px color-mix(in srgb, var(--ws-teal) 55%, transparent);
  border-color: color-mix(in srgb, var(--ws-cyan) 45%, transparent); }
.mag-thumb { width: 100%; height: auto; display: block; margin: 0 0 var(--space-3); border-radius: var(--radius); }
[data-theme="dark"] .mag-thumb { filter: brightness(.94) contrast(1.02); }
.mag-src { display: inline-block; font-size: .72rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--ws-cyan); margin-bottom: .5rem; }
.mag-title { font-size: var(--fs-400); font-weight: 700; line-height: 1.25; margin: 0 0 .5rem; color: var(--ws-text); }
.mag-ex { font-size: var(--fs-300); line-height: 1.55; color: var(--ws-text); opacity: .85; margin: 0 0 .8rem; }
.mag-more { display: inline-flex; align-items: center; gap: .4rem; font-size: .82rem; font-weight: 600; color: var(--ws-mint); }
.mag-more svg { width: 1em; height: 1em; transition: transform .2s ease; }
.mag-card:hover .mag-more svg { transform: translateX(3px); }

/* muro de logos de clientes (chips blancos para respetar el color de marca) */
.client-logos { display: grid; grid-template-columns: repeat(auto-fill, minmax(94px, 1fr)); gap: var(--space-2); margin-top: var(--space-2); }
.logo-chip { display: grid; place-items: center; background: #fff; border-radius: 10px; padding: 10px; aspect-ratio: 3 / 2;
  box-shadow: 0 4px 14px -8px rgba(0,0,0,.5); }
.logo-chip img { max-width: 100%; max-height: 100%; object-fit: contain; }

@media (prefers-reduced-motion: reduce) {
  .hero-fx-mesh::before, .hero-fx-mesh::after, .hero-fx-beams, .hero-fx-grid { animation: none; }
  .svc-card, .svc-ic { transition: none; }
}
