:root {
  /*
   * Paleta MRP oficial.
   * No introducir nuevos colores hexadecimales fuera de la paleta MRP sin autorización expresa.
   */
  --navy: #071827;
  --navy-2: #0b2a43;
  --navy-3: #123a5a;
  --ink: #101827;
  --muted: #64748b;
  --line: #dfe6ee;
  --soft: #f5f7fa;
  --white: #ffffff;
  --blue: #2f8cff;
  --cyan: #38bdf8;
  --gold: #cda24a;
  --gold-2: #e4be6a;
  --gold-soft: #f5ead0;
  --warm-white: #f8fafc;
  --text-secondary: #cbd5e1;
  --shadow-gray: #64748b;
  --radius: 8px;
  --shadow: 0 20px 60px rgba(4, 15, 34, .14);
  --shadow-strong: 0 26px 80px rgba(2, 9, 24, .28);
  --container: min(1180px, calc(100vw - 40px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--white);
  line-height: 1.65;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
p { margin: 0 0 1rem; }
h1, h2, h3 { margin: 0 0 .78em; line-height: 1.14; letter-spacing: 0; }
h1, .serif { font-family: "Source Serif 4", Georgia, serif; }
h2 { font-size: clamp(1.82rem, 3.15vw, 2.85rem); }
h3 { font-size: 1.25rem; }
.container { width: var(--container); margin-inline: auto; }
.section { padding: clamp(64px, 7.8vw, 110px) 0; }
.section-tight { padding: clamp(40px, 5.6vw, 72px) 0; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  color: var(--blue);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.eyebrow:before {
  content: "";
  width: 32px;
  height: 2px;
  background: var(--gold);
}
.lead {
  color: var(--muted);
  font-size: clamp(1.02rem, 1.42vw, 1.12rem);
  max-width: 760px;
  margin-bottom: 1.35rem;
}
.dark .lead, .dark p { color: #c9d5e6; }
.dark h1, .dark h2, .dark h3 { color: var(--white); }
.text-link {
  color: var(--blue);
  font-weight: 800;
  border-bottom: 1px solid rgba(205,162,74,.58);
}
.text-link:hover { color: var(--gold-2); }

.skip-link {
  position: absolute;
  left: -999px;
  top: 8px;
  z-index: 9999;
  padding: 8px 12px;
  background: var(--white);
}
.skip-link:focus { left: 8px; }
.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: linear-gradient(90deg, #071827 0%, #0B2A43 58%, #123A5A 100%);
  color: var(--white);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(47,140,255,.18);
}
.header-inner {
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 238px;
  padding-right: 8px;
}
.site-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 238px;
  padding-right: 8px;
  flex: 0 0 auto;
}
.brand-mark {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  font-size: .9rem;
  font-weight: 800;
  letter-spacing: .08em;
  color: var(--gold);
  border: 1px solid rgba(205,162,74,.5);
  border-radius: 50%;
  box-shadow: inset 0 0 0 4px rgba(47,140,255,.08);
}
.brand strong { display: block; font-size: 1.02rem; font-weight: 850; letter-spacing: .01em; white-space: nowrap; }
.brand small { display: block; color: #aebbd0; font-size: .71rem; margin-top: 0; white-space: nowrap; }
.brand-text {
  min-width: 0;
}
.brand-name {
  display: block;
  font-size: 1.02rem;
  font-weight: 850;
  letter-spacing: .01em;
  line-height: 1.12;
  white-space: nowrap;
}
.site-header .brand-name,
.site-header .brand strong,
.site-footer .footer-brand strong {
  color: #f8fafc;
}
.brand-tagline {
  display: block;
  color: #aebbd0;
  font-size: .71rem;
  margin-top: 0;
  white-space: nowrap;
}
.primary-nav {
  display: flex;
  align-items: center;
  gap: clamp(8px, .82vw, 16px);
  font-size: .85rem;
  font-weight: 700;
}
.nav-group {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.nav-group:after {
  content: "";
  position: absolute;
  top: 100%;
  left: -12px;
  right: -12px;
  height: 18px;
}
.primary-nav a {
  position: relative;
  color: #dce5f4;
  padding: 7px 1px;
  white-space: nowrap;
  transition: color .2s ease, border-color .2s ease, background .2s ease;
}
.primary-nav a:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 1px;
  height: 2px;
  background: linear-gradient(90deg, var(--cyan), var(--blue), var(--gold));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .22s ease;
}
.primary-nav a:hover,
.primary-nav a.is-active { color: var(--gold-2); }
.primary-nav a:hover:after,
.primary-nav a.is-active:after { transform: scaleX(1); }
.nav-submenu {
  position: absolute;
  top: calc(100% + 6px);
  left: 50%;
  z-index: 120;
  min-width: 230px;
  padding: 10px;
  display: grid;
  gap: 2px;
  background: linear-gradient(180deg, rgba(7,24,39,.98), rgba(11,42,67,.96));
  border: 1px solid rgba(47,140,255,.18);
  border-radius: 10px;
  box-shadow: 0 18px 38px rgba(3,10,24,.24);
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 4px);
  transition: opacity .18s ease, transform .18s ease;
}
.nav-group:hover .nav-submenu,
.nav-group:focus-within .nav-submenu {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}
.primary-nav .nav-subitem {
  display: block;
  padding: 10px 12px;
  color: #dce5f4;
  border-radius: 8px;
}
.primary-nav .nav-subitem:after {
  display: none;
}
.primary-nav .nav-subitem:hover,
.primary-nav .nav-subitem.is-active {
  color: var(--gold-2);
  background: rgba(47,140,255,.1);
}
.nav-cta, .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 12px 18px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  color: var(--navy) !important;
  font-weight: 800;
  border: 1px solid transparent;
  box-shadow: 0 14px 34px rgba(205, 162, 74, .26);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease, outline-color .18s ease;
}
.nav-cta {
  padding-inline: 14px;
  color: var(--navy) !important;
}
.primary-nav .nav-cta:after { display: none; }
.primary-nav .nav-cta.is-active {
  background: transparent;
  color: var(--gold) !important;
  border-color: rgba(205,162,74,.7);
  box-shadow: none;
}
.language-switcher {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 3px;
  border: 1px solid rgba(205,162,74,.34);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  box-shadow: 0 10px 24px rgba(3,10,24,.14) inset;
}
.language-switcher__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  min-height: 30px;
  padding: 5px 9px;
  border: 0;
  border-radius: 999px;
  color: #dce5f4;
  font-size: .74rem;
  letter-spacing: .04em;
  line-height: 1;
}
.language-switcher__link:after {
  display: none;
}
.language-switcher__link:hover,
.language-switcher__link:focus-visible {
  color: var(--gold-2);
  background: rgba(205,162,74,.1);
}
.language-switcher__link.is-active {
  color: var(--navy);
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  box-shadow: 0 8px 18px rgba(205,162,74,.18);
}
.nav-cta:hover,
.btn:not(.light):not(.secondary):hover {
  transform: translateY(-1px);
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
  box-shadow:
    0 20px 44px rgba(205,162,74,.38),
    0 0 28px rgba(47,140,255,.14),
    0 0 0 1px rgba(56,189,248,.18) inset;
}
.nav-cta:focus-visible,
.btn:not(.light):not(.secondary):focus-visible {
  outline: 2px solid rgba(56,189,248,.82);
  outline-offset: 3px;
  box-shadow:
    0 0 0 4px rgba(47,140,255,.18),
    0 18px 42px rgba(205,162,74,.3),
    0 0 0 1px rgba(56,189,248,.2) inset;
}
.nav-cta:active,
.btn:not(.light):not(.secondary):active {
  transform: translateY(0);
  box-shadow: 0 8px 22px rgba(7,24,39,.2);
}
.btn.secondary {
  background: transparent;
  border-color: rgba(255,255,255,.35);
  color: var(--white) !important;
  box-shadow: none;
}
.btn.secondary:hover {
  background: rgba(47,140,255,.11);
  border-color: rgba(56,189,248,.86);
  color: var(--cyan) !important;
  box-shadow:
    0 16px 34px rgba(47,140,255,.22),
    0 0 30px rgba(56,189,248,.22),
    0 0 0 1px rgba(56,189,248,.24) inset;
}
.btn.secondary:focus-visible {
  outline: 2px solid rgba(56,189,248,.82);
  outline-offset: 3px;
  box-shadow:
    0 0 0 4px rgba(47,140,255,.2),
    0 14px 30px rgba(56,189,248,.18);
}
.btn.light {
  background: var(--white);
  color: var(--navy) !important;
  box-shadow: none;
  border-color: rgba(47,140,255,.24);
}
.btn.light:not([aria-disabled="true"]):hover {
  background: var(--warm-white);
  border-color: rgba(56,189,248,.82);
  box-shadow:
    0 18px 38px rgba(47,140,255,.22),
    0 0 32px rgba(56,189,248,.24),
    0 0 0 1px rgba(56,189,248,.24) inset;
}
.btn.light:not([aria-disabled="true"]):focus-visible {
  outline: 2px solid rgba(56,189,248,.82);
  outline-offset: 3px;
  box-shadow:
    0 0 0 4px rgba(47,140,255,.2),
    0 16px 34px rgba(47,140,255,.18),
    0 0 22px rgba(56,189,248,.18);
}
.btn.light:not([aria-disabled="true"]):active {
  transform: translateY(0);
  box-shadow: 0 8px 22px rgba(11,42,67,.12);
}
.btn.gold {
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  color: var(--navy) !important;
  box-shadow: 0 14px 34px rgba(205,162,74,.26);
}
.menu-toggle {
  display: none;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255,255,255,.2);
  background: transparent;
  border-radius: var(--radius);
  transition: transform .18s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.menu-toggle:hover {
  background: rgba(47,140,255,.1);
  border-color: rgba(56,189,248,.58);
  box-shadow:
    0 12px 26px rgba(7,24,39,.16),
    0 0 22px rgba(56,189,248,.12);
}
.menu-toggle:focus-visible {
  outline: 2px solid rgba(56,189,248,.82);
  outline-offset: 3px;
  box-shadow:
    0 0 0 4px rgba(47,140,255,.16),
    0 0 20px rgba(56,189,248,.12);
}
.menu-toggle:active {
  transform: translateY(1px);
}
.menu-toggle span:not(.screen-reader-text) {
  display: block;
  width: 20px;
  height: 2px;
  margin: 5px auto;
  background: var(--white);
}

.hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 78% 30%, rgba(47,140,255,.28), transparent 30%),
    linear-gradient(120deg, rgba(7,24,39,.99), rgba(11,42,67,.9)),
    var(--navy);
  color: var(--white);
}
.hero:before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 72px 72px;
  opacity: .55;
}
.hero-grid {
  position: relative;
  min-height: min(690px, calc(100vh - 74px));
  display: grid;
  grid-template-columns: minmax(0, 1.14fr) minmax(360px, .86fr);
  gap: clamp(34px, 5vw, 66px);
  align-items: center;
  padding: clamp(40px, 5.2vw, 64px) 0;
}
.hero h1 {
  max-width: 820px;
  font-size: clamp(2.32rem, 4.15vw, 4.15rem);
  font-weight: 700;
  line-height: 1.09;
}
.hero-name {
  color: var(--gold);
  font-size: clamp(1.05rem, 1.7vw, 1.25rem);
  font-weight: 850;
  letter-spacing: .02em;
  margin: 22px 0 6px;
}
.hero-subtitle {
  color: #dce8f8;
  font-size: clamp(1rem, 1.55vw, 1.2rem);
  font-weight: 700;
  margin: 0 0 16px;
}
.hero-actions, .cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 28px;
}
.context-nav {
  position: relative;
  overflow: hidden;
  padding: clamp(18px, 2.2vw, 24px);
  border: 1px solid rgba(47,140,255,.14);
  border-radius: 14px;
  background:
    radial-gradient(circle at 12% 0%, rgba(47,140,255,.08), transparent 28%),
    linear-gradient(135deg, rgba(7,24,39,.94), rgba(11,42,67,.9) 58%, rgba(7,24,39,.96));
  box-shadow: 0 10px 24px rgba(3,10,24,.12);
}
.context-nav:before {
  content: "";
  position: absolute;
  top: 0;
  left: clamp(18px, 2.2vw, 24px);
  right: clamp(18px, 2.2vw, 24px);
  height: 1px;
  background: linear-gradient(90deg, rgba(56,189,248,.42), rgba(205,162,74,.34), transparent);
}
.context-nav:after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
  pointer-events: none;
}
.context-nav p {
  position: relative;
  max-width: 760px;
  margin: 0;
  color: #dce8f8;
  font-size: clamp(.98rem, 1.25vw, 1.08rem);
  line-height: 1.52;
  font-weight: 500;
}
.context-nav .cta-row {
  position: relative;
  margin-top: 16px;
}
.hero-card {
  position: relative;
  align-self: center;
  width: min(100%, 500px);
  justify-self: end;
  aspect-ratio: 4 / 5.05;
  min-height: 0;
  max-height: min(610px, calc(100vh - 142px));
  border-radius: 16px 16px 72px 16px;
  overflow: hidden;
  box-shadow: var(--shadow-strong);
  border: 1px solid rgba(205,162,74,.34);
  background: #071827;
}
.hero-card img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.hero-card:after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, transparent 58%, rgba(7,18,37,.46)),
    linear-gradient(90deg, rgba(205,162,74,.04), transparent 34%);
}
.trust-strip {
  position: relative;
  margin-top: -1px;
  background: linear-gradient(180deg, #fff, #f9fcff);
  border-bottom: 1px solid var(--line);
}
.trust-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
}
.trust-item {
  padding: 24px 18px 22px;
  border-left: 1px solid rgba(179,197,220,.54);
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,.74), rgba(248,251,255,.48));
}
.trust-item:before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 2px;
  background: linear-gradient(90deg, var(--gold), rgba(47,140,255,.82));
  opacity: .72;
}
.trust-item:last-child { border-right: 1px solid rgba(179,197,220,.54); }
.trust-item strong {
  display: block;
  color: var(--navy);
  font-size: clamp(1.05rem, 1.45vw, 1.34rem);
  line-height: 1.14;
  letter-spacing: -.01em;
}
.trust-item span {
  display: block;
  color: var(--muted);
  font-size: .82rem;
  line-height: 1.45;
  margin-top: 7px;
}

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 5.5vw, 82px); align-items: center; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.grid-5 { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; }
.cards { margin-top: 32px; }
.card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  background: var(--white);
  box-shadow: 0 10px 36px rgba(7, 18, 37, .06);
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.card h3, .service-card h3 { color: var(--navy); }
.card h3, .service-card h3 { margin-bottom: 12px; }
.card p, .service-card p { color: var(--muted); }
.card p, .service-card p { line-height: 1.58; }
.cards .card { min-height: 100%; }
.card:hover {
  transform: translateY(-2px);
  border-color: rgba(205,162,74,.58);
  box-shadow: 0 18px 48px rgba(7,20,38,.1);
}
body.home .home-specialties .cards {
  align-items: start;
  gap: 16px;
}
body.home .home-specialties .card {
  padding: 21px 22px 20px;
}
body.home .home-specialties .icon {
  margin-bottom: 12px;
}
body.home .home-specialties .card h3 {
  margin-bottom: 9px;
}
body.home .home-specialties .card p {
  line-height: 1.52;
}
body.home main#content > section:nth-of-type(6) {
  padding-bottom: clamp(42px, 4.8vw, 64px);
}
body.home main#content > section:nth-of-type(7) {
  padding-top: clamp(42px, 4.8vw, 64px);
}
.premium-card {
  border-top: 3px solid var(--gold);
  background: linear-gradient(180deg, #fff, #f8fafc);
}
.premium-card h3:before {
  content: "";
  display: block;
  width: 34px;
  height: 2px;
  margin-bottom: 14px;
  background: var(--gold);
}
.card.dark-card {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
  color: var(--white);
  box-shadow: none;
}
.icon {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(47, 128, 237, .11);
  color: var(--blue);
  font-weight: 900;
  margin-bottom: 16px;
  font-size: .78rem;
  border: 1px solid rgba(47,140,255,.18);
}
.media-frame {
  overflow: hidden;
  border-radius: 0 0 90px 0;
  box-shadow: var(--shadow-strong);
  border: 1px solid rgba(205,162,74,.18);
  background: var(--navy);
}
.media-frame.rounded { border-radius: var(--radius); }
.media-frame img { width: 100%; height: 100%; object-fit: cover; }
body.page-experiencia-profesional .media-frame {
  aspect-ratio: 3 / 4;
  max-height: 640px;
}
.legaltech-intro .media-frame {
  aspect-ratio: 4 / 3;
}
body.page-experiencia-profesional .media-frame img {
  object-fit: cover;
  object-position: center 28%;
}
body.page-experiencia-profesional .experience-journey {
  margin-top: 4px;
}
body.page-experiencia-profesional .experience-journey-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
  margin-top: 32px;
}
body.page-experiencia-profesional .experience-journey-card {
  position: relative;
  grid-column: span 2;
  min-height: 100%;
  padding: clamp(24px, 2.35vw, 30px);
  border: 1px solid rgba(179,197,220,.42);
  border-radius: 16px;
  border-top: 3px solid rgba(205,162,74,.74);
  background: linear-gradient(180deg, #fff, #f8fafc);
  box-shadow: 0 12px 34px rgba(7,24,39,.06);
}
body.page-experiencia-profesional .experience-journey-card--regulated {
  border-top-color: rgba(20,184,166,.74);
}
body.page-experiencia-profesional .experience-journey-card--academic {
  grid-column: 2 / 4;
  border-top-color: rgba(228,190,106,.92);
  box-shadow: 0 16px 40px rgba(7,24,39,.08);
}
body.page-experiencia-profesional .experience-journey-number {
  display: block;
  margin-bottom: 10px;
  color: var(--gold);
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .14em;
}
body.page-experiencia-profesional .experience-journey-label {
  display: block;
  margin-bottom: 10px;
  color: var(--navy-2);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}
body.page-experiencia-profesional .experience-journey-card h3 {
  margin-bottom: 13px;
  color: var(--navy);
  font-size: clamp(1.02rem, 1.2vw, 1.18rem);
  line-height: 1.32;
}
body.page-experiencia-profesional .experience-journey-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
}
body.page-experiencia-profesional .experience-journey-card p + p {
  margin-top: 12px;
}
body.page-experiencia-profesional .experience-journey-card strong {
  color: var(--navy-2);
  font-weight: 700;
}
body.page-experiencia-profesional .experience-evolution-section {
  padding-top: clamp(36px, 4.8vw, 68px);
  background:
    linear-gradient(180deg, rgba(248,250,252,.96), rgba(255,255,255,.98));
}
body.page-experiencia-profesional .experience-evolution-head {
  max-width: 980px;
  margin-bottom: clamp(30px, 4vw, 48px);
}
body.page-experiencia-profesional .experience-evolution-head .eyebrow {
  margin-bottom: 8px;
}
body.page-experiencia-profesional .experience-evolution-head h2 {
  max-width: 820px;
  margin-bottom: 10px;
  font-size: clamp(1.92rem, 3.2vw, 2.56rem);
  line-height: 1.08;
}
body.page-experiencia-profesional .experience-evolution-head .experience-evolution-subtitle {
  max-width: 700px;
  margin: 0 0 clamp(8px, 1vw, 12px);
  color: rgba(30, 41, 59, .78);
  font-family: "Source Serif 4", Georgia, serif;
  font-size: clamp(1.02rem, 1.3vw, 1.16rem);
  font-style: italic;
  font-weight: 600;
  line-height: 1.45;
}
body.page-experiencia-profesional .experience-evolution-flow {
  position: relative;
  max-width: 1040px;
  margin: 0 auto;
  padding-left: clamp(22px, 3vw, 34px);
}
body.page-experiencia-profesional .experience-evolution-flow:before {
  content: "";
  position: absolute;
  top: 4px;
  bottom: 8px;
  left: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--gold-2), var(--gold), rgba(56,189,248,.28));
  opacity: .72;
}
body.page-experiencia-profesional .experience-evolution-step {
  position: relative;
  display: grid;
  grid-template-columns: minmax(56px, .16fr) minmax(0, 1fr);
  gap: clamp(18px, 2.4vw, 32px);
  padding: clamp(22px, 3.2vw, 34px) 0;
  border-top: 1px solid rgba(179,197,220,.46);
}
body.page-experiencia-profesional .experience-evolution-step:first-child {
  border-top: 0;
  padding-top: 0;
}
body.page-experiencia-profesional .experience-evolution-step:before {
  content: "";
  position: absolute;
  left: calc(clamp(22px, 3vw, 34px) * -1 - 5px);
  top: clamp(28px, 3.2vw, 38px);
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: var(--warm-white);
  border: 2px solid var(--gold);
  box-shadow: 0 0 0 4px rgba(205,162,74,.12);
}
body.page-experiencia-profesional .experience-evolution-step:first-child:before {
  top: 4px;
}
body.page-experiencia-profesional .experience-evolution-step--current:before {
  border-color: rgba(56,189,248,.9);
  box-shadow: 0 0 0 4px rgba(56,189,248,.14);
}
body.page-experiencia-profesional .experience-evolution-number {
  color: var(--gold);
  font-size: .82rem;
  font-weight: 850;
  letter-spacing: .16em;
}
body.page-experiencia-profesional .experience-evolution-copy {
  max-width: 840px;
}
body.page-experiencia-profesional .experience-evolution-copy h3 {
  margin-bottom: 14px;
  color: var(--navy);
  font-size: clamp(1.22rem, 1.9vw, 1.62rem);
  line-height: 1.22;
}
body.page-experiencia-profesional .experience-evolution-copy p {
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.72;
}
body.page-experiencia-profesional .experience-evolution-copy p + p {
  margin-top: 14px;
}
body.page-experiencia-profesional .experience-evolution-today {
  margin-top: clamp(18px, 2.6vw, 26px);
  padding: clamp(20px, 2.8vw, 28px);
  border: 1px solid rgba(56,189,248,.2);
  border-left: 3px solid rgba(56,189,248,.72);
  border-radius: 14px;
  background:
    radial-gradient(circle at 100% 0%, rgba(56,189,248,.1), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
}
body.page-experiencia-profesional .experience-evolution-today h4 {
  margin-bottom: 12px;
  color: var(--navy-2);
  font-size: clamp(1.05rem, 1.35vw, 1.2rem);
  line-height: 1.25;
}
body.page-experiencia-profesional .experience-evolution-today strong {
  color: var(--navy);
  font-weight: 800;
}
.soft-band { background: var(--soft); }
.dark-band {
  background:
    radial-gradient(circle at 12% 15%, rgba(47,140,255,.23), transparent 28%),
    linear-gradient(120deg, var(--navy), var(--navy-2));
  color: var(--white);
}

.timeline {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 46px;
}
.timeline-item {
  position: relative;
  min-height: 220px;
  padding: 28px;
  border: 1px solid rgba(255,255,255,.12);
  border-left: 3px solid var(--gold);
  border-radius: var(--radius);
  background: rgba(255,255,255,.045);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
}
.timeline-year {
  display: block;
  color: var(--gold);
  font-family: "Source Serif 4", Georgia, serif;
  font-size: clamp(2.4rem, 4vw, 3.45rem);
  line-height: 1;
  margin-bottom: 20px;
}
.timeline-title {
  color: var(--white);
  font-size: 1rem;
  font-weight: 900;
  text-transform: uppercase;
}
.timeline-item p { margin-top: 10px; color: #c9d5e6; }
body.page-trayectoria-academica .academic-intro-lead {
  position: relative;
  max-width: 880px;
  margin: 6px 0 clamp(18px, 2.6vw, 26px);
  padding-top: 16px;
  color: var(--navy-3);
  font-size: clamp(1.06rem, 1.45vw, 1.18rem);
  font-weight: 600;
  line-height: 1.68;
}
body.page-trayectoria-academica .academic-intro-lead:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: min(180px, 42vw);
  height: 2px;
  background: linear-gradient(90deg, var(--gold-2), var(--gold), rgba(47,140,255,.42), rgba(56,189,248,.2));
}
body.page-trayectoria-academica .timeline {
  gap: 20px;
  margin-top: 38px;
}
body.page-trayectoria-academica .timeline-item {
  min-height: 0;
  padding: clamp(20px, 2.35vw, 26px);
  border-left-color: transparent;
  background:
    linear-gradient(135deg, rgba(255,255,255,.066), rgba(255,255,255,.035));
  box-shadow:
    0 16px 38px rgba(7,24,39,.18),
    -8px 0 20px rgba(11,42,67,.2);
}
body.page-trayectoria-academica .timeline-item:before {
  content: "";
  position: absolute;
  top: -1px;
  bottom: -1px;
  left: -1px;
  width: 3px;
  border-radius: var(--radius) 0 0 var(--radius);
  background: linear-gradient(180deg, var(--gold-2) 0%, var(--gold) 45%, rgba(205,162,74,.72) 100%);
  box-shadow: 0 0 18px rgba(205,162,74,.18);
}
body.page-trayectoria-academica .timeline-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 5px 7px;
  margin: 0 0 10px;
  color: var(--text-secondary);
  font-size: .84rem;
  font-weight: 700;
  line-height: 1.36;
}
body.page-trayectoria-academica .timeline-date {
  color: var(--gold-2);
  font-weight: 850;
}
body.page-trayectoria-academica .timeline-separator {
  color: rgba(205,162,74,.72);
}
body.page-trayectoria-academica .timeline-institution {
  color: var(--text-secondary);
}
body.page-trayectoria-academica .timeline-title {
  margin: 0 0 10px;
  color: var(--white);
  font-size: clamp(.94rem, 1.05vw, 1.04rem);
  line-height: 1.3;
  letter-spacing: .035em;
}
body.page-trayectoria-academica .timeline-text {
  margin: 0;
  color: #c9d5e6;
  font-size: .96rem;
  line-height: 1.58;
}
body.page-trayectoria-academica .salamanca-recognition {
  position: relative;
  overflow: hidden;
  padding: clamp(26px, 3.4vw, 42px);
  border-color: rgba(205,162,74,.26);
  border-top-width: 1px;
  background:
    radial-gradient(circle at 96% 5%, rgba(47,140,255,.18), transparent 32%),
    linear-gradient(135deg, rgba(7,24,39,.99), rgba(11,42,67,.96) 58%, rgba(18,58,90,.9));
  box-shadow: 0 24px 70px rgba(7,24,39,.18);
  color: var(--warm-white);
}
body.page-trayectoria-academica .salamanca-recognition:before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, var(--gold-2), var(--gold), rgba(47,140,255,.48), transparent);
}
body.page-trayectoria-academica .salamanca-recognition h3 {
  margin-bottom: 18px;
  color: var(--warm-white);
  font-size: clamp(1.28rem, 2vw, 1.62rem);
}
body.page-trayectoria-academica .salamanca-recognition h3:before {
  background: linear-gradient(90deg, var(--gold-2), var(--gold));
}
body.page-trayectoria-academica .salamanca-recognition p {
  color: var(--text-secondary);
}
body.page-trayectoria-academica .salamanca-recognition em {
  color: inherit;
}
body.page-trayectoria-academica .salamanca-recognition:hover {
  transform: none;
  border-color: rgba(228,190,106,.42);
  box-shadow: 0 24px 70px rgba(7,24,39,.2);
}
body.page-trayectoria-academica .salamanca-quote-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: clamp(18px, 2.4vw, 24px) 0 12px;
  color: var(--gold-2);
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}
body.page-trayectoria-academica .salamanca-quote-label:before {
  content: "";
  width: 30px;
  height: 1px;
  background: var(--gold);
}
body.page-trayectoria-academica .salamanca-quote {
  margin: 0 0 clamp(18px, 2.4vw, 26px);
  padding: clamp(20px, 2.8vw, 30px);
  border: 1px solid rgba(205,162,74,.22);
  border-left: 3px solid var(--gold);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 100% 0%, rgba(56,189,248,.08), transparent 34%),
    linear-gradient(135deg, rgba(248,250,252,.08), rgba(248,250,252,.035));
  box-shadow: inset 0 1px 0 rgba(248,250,252,.06), 0 16px 40px rgba(7,24,39,.22);
}
body.page-trayectoria-academica .salamanca-quote p {
  margin: 0;
  color: var(--warm-white);
  font-family: "Source Serif 4", Georgia, serif;
  font-size: clamp(1.02rem, 1.22vw, 1.14rem);
  font-style: italic;
  line-height: 1.68;
}
body.page-trayectoria-academica .salamanca-quote cite {
  display: block;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(205,162,74,.22);
  color: var(--text-secondary);
  font-size: .9rem;
  font-style: normal;
  line-height: 1.5;
}
body.page-trayectoria-academica .salamanca-quote cite strong {
  display: block;
  color: var(--gold-2);
  font-weight: 850;
}
body.page-trayectoria-academica .salamanca-quote cite span {
  display: block;
}
body.page-trayectoria-academica .unir-teaching-block {
  background:
    radial-gradient(circle at 14% 18%, rgba(47,140,255,.18), transparent 30%),
    linear-gradient(120deg, var(--navy), var(--navy-2) 58%, var(--navy-3));
}
body.page-trayectoria-academica .unir-teaching-block .lead {
  max-width: 900px;
}
body.page-trayectoria-academica .unir-teaching-grid {
  align-items: stretch;
}
body.page-trayectoria-academica .unir-teaching-card {
  position: relative;
  overflow: hidden;
  border-color: rgba(56,189,248,.2);
  background:
    radial-gradient(circle at 100% 0%, rgba(47,140,255,.1), transparent 32%),
    linear-gradient(135deg, rgba(248,250,252,.08), rgba(248,250,252,.035));
  box-shadow: inset 0 1px 0 rgba(248,250,252,.06), 0 16px 42px rgba(7,24,39,.18);
}
body.page-trayectoria-academica .unir-teaching-card:before {
  content: "";
  display: block;
  width: 38px;
  height: 2px;
  margin-bottom: 14px;
  background: linear-gradient(90deg, var(--gold-2), var(--gold), rgba(47,140,255,.54));
}
body.page-trayectoria-academica .unir-teaching-card h3 {
  color: var(--warm-white);
}
body.page-trayectoria-academica .unir-teaching-card p {
  color: var(--text-secondary);
}
body.page-trayectoria-academica .unir-teaching-card:hover {
  transform: translateY(-2px);
  border-color: rgba(228,190,106,.38);
  box-shadow: inset 0 1px 0 rgba(248,250,252,.08), 0 20px 52px rgba(7,24,39,.24);
}
body.page-trayectoria-academica .unir-evaluation {
  display: grid;
  grid-template-columns: minmax(150px, 210px) 1fr;
  gap: clamp(18px, 2.6vw, 30px);
  align-items: center;
  margin-top: clamp(22px, 3vw, 32px);
  padding: clamp(20px, 2.8vw, 30px);
  border: 1px solid rgba(205,162,74,.28);
  border-left: 3px solid var(--gold);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(7,24,39,.64), rgba(11,42,67,.42));
  box-shadow: inset 0 1px 0 rgba(248,250,252,.07), 0 18px 50px rgba(7,24,39,.22);
}
body.page-trayectoria-academica .unir-score {
  color: var(--gold-2);
  font-family: "Source Serif 4", Georgia, serif;
  font-size: clamp(2.12rem, 3.7vw, 3.35rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  white-space: nowrap;
}
body.page-trayectoria-academica .unir-evaluation h3 {
  margin-bottom: 8px;
  color: var(--warm-white);
  font-size: clamp(1.12rem, 1.8vw, 1.38rem);
}
body.page-trayectoria-academica .unir-evaluation p {
  margin: 0;
  color: var(--text-secondary);
  line-height: 1.6;
}
body.page-trayectoria-academica .academic-legaltech-block {
  background:
    radial-gradient(circle at 86% 12%, rgba(47,140,255,.08), transparent 28%),
    radial-gradient(circle at 12% 90%, rgba(205,162,74,.08), transparent 30%),
    linear-gradient(180deg, var(--warm-white), var(--white));
}
body.page-trayectoria-academica .academic-legaltech-block .lead {
  max-width: 920px;
}
body.page-trayectoria-academica .academic-tech-grid {
  align-items: stretch;
}
body.page-trayectoria-academica .academic-tech-card {
  position: relative;
  overflow: hidden;
  border-color: rgba(47,140,255,.16);
  background:
    radial-gradient(circle at 100% 0%, rgba(56,189,248,.09), transparent 34%),
    linear-gradient(180deg, rgba(248,250,252,.98), rgba(255,255,255,.98));
  box-shadow: 0 16px 42px rgba(7,24,39,.08);
}
body.page-trayectoria-academica .academic-tech-card:before {
  content: "";
  display: block;
  width: 40px;
  height: 2px;
  margin-bottom: 14px;
  background: linear-gradient(90deg, var(--blue), var(--cyan), var(--gold));
}
body.page-trayectoria-academica .academic-tech-card h3 {
  color: var(--navy);
}
body.page-trayectoria-academica .academic-tech-card p {
  color: var(--muted);
}
body.page-trayectoria-academica .academic-tech-card:hover {
  border-color: rgba(205,162,74,.42);
  box-shadow: 0 20px 54px rgba(7,24,39,.11), 0 0 0 1px rgba(56,189,248,.08);
}
body.page-trayectoria-academica .academic-tech-summary {
  margin: clamp(24px, 3.2vw, 36px) 0 0;
  padding: clamp(20px, 2.8vw, 28px);
  border: 1px solid rgba(205,162,74,.24);
  border-left: 3px solid var(--gold);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 100% 0%, rgba(47,140,255,.12), transparent 32%),
    linear-gradient(135deg, rgba(7,24,39,.98), rgba(11,42,67,.94));
  color: var(--text-secondary);
  box-shadow: 0 16px 44px rgba(7,24,39,.14);
  line-height: 1.62;
}
body.page-trayectoria-academica .academic-signature-section {
  position: relative;
  padding-top: clamp(14px, 2.2vw, 28px);
  padding-bottom: clamp(16px, 2.6vw, 32px);
  background: linear-gradient(180deg, var(--white), var(--warm-white));
}
body.page-trayectoria-academica .academic-signature-section:before {
  content: "";
  display: block;
  width: clamp(72px, 10vw, 140px);
  height: 2px;
  margin: 0 auto clamp(16px, 2vw, 24px);
  border-radius: 999px;
  background: linear-gradient(90deg, var(--gold), var(--gold-2), var(--cyan));
  opacity: .72;
}
body.page-trayectoria-academica .academic-signature-image {
  max-width: 840px;
  margin: 0 auto;
  overflow: hidden;
  border: 1px solid rgba(205,162,74,.18);
  border-radius: 14px;
  background: var(--warm-white);
  box-shadow: 0 18px 50px rgba(7,24,39,.11);
}
body.page-trayectoria-academica .academic-signature-image img {
  width: 100%;
  height: auto;
  display: block;
}
body.page-trayectoria-academica .academic-signature-quote {
  max-width: 960px;
  margin: clamp(16px, 2vw, 24px) auto 0;
  padding: 0 clamp(12px, 2vw, 20px);
}
body.page-trayectoria-academica .academic-signature-quote p {
  margin: 0;
  color: var(--navy-3);
  font-family: "Source Serif 4", Georgia, serif;
  font-size: clamp(1.08rem, 1.55vw, 1.34rem);
  font-style: italic;
  font-weight: 560;
  line-height: 1.44;
  text-align: center;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight {
  padding-top: clamp(10px, 1.5vw, 18px);
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav {
  max-width: 820px;
  margin: 0 auto;
  padding: clamp(14px, 1.7vw, 20px);
  border-color: rgba(56,189,248,.14);
  background:
    radial-gradient(circle at 50% 0%, rgba(47,140,255,.08), transparent 30%),
    linear-gradient(135deg, rgba(7,24,39,.92), rgba(11,42,67,.82));
  box-shadow: 0 10px 28px rgba(7,24,39,.1);
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav:before {
  left: clamp(14px, 1.7vw, 20px);
  right: clamp(14px, 1.7vw, 20px);
  background: linear-gradient(90deg, rgba(56,189,248,.38), rgba(228,190,106,.34), transparent);
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .cta-row {
  justify-content: center;
  gap: 10px;
  margin-top: 0;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn {
  min-height: 42px;
  padding: 10px 17px;
  border-radius: 999px;
  font-size: .9rem;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn:nth-child(1) {
  border-color: rgba(228,190,106,.72);
  box-shadow:
    0 16px 34px rgba(205,162,74,.3),
    0 0 24px rgba(228,190,106,.18),
    0 0 0 1px rgba(228,190,106,.28) inset;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn:nth-child(1):hover,
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn:nth-child(1):focus-visible {
  border-color: rgba(228,190,106,.9);
  box-shadow:
    0 20px 42px rgba(205,162,74,.4),
    0 0 30px rgba(228,190,106,.26),
    0 0 0 1px rgba(228,190,106,.36) inset;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn.light:nth-child(2) {
  border-color: rgba(20,184,166,.78);
  box-shadow:
    0 14px 30px rgba(20,184,166,.22),
    0 0 28px rgba(45,212,191,.24),
    0 0 0 1px rgba(20,184,166,.3) inset;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn.light:nth-child(2):hover,
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn.light:nth-child(2):focus-visible {
  border-color: rgba(45,212,191,.94);
  box-shadow:
    0 18px 38px rgba(20,184,166,.3),
    0 0 34px rgba(45,212,191,.34),
    0 0 0 1px rgba(45,212,191,.38) inset;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn.light:nth-child(3) {
  border-color: rgba(56,189,248,.86);
  box-shadow:
    0 16px 34px rgba(47,140,255,.24),
    0 0 32px rgba(56,189,248,.28),
    0 0 0 1px rgba(56,189,248,.28) inset;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn.light:nth-child(3):hover,
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .btn.light:nth-child(3):focus-visible {
  border-color: rgba(56,189,248,.96);
  box-shadow:
    0 20px 42px rgba(47,140,255,.32),
    0 0 38px rgba(56,189,248,.38),
    0 0 0 1px rgba(56,189,248,.4) inset;
}
body.page-sobre-mi .context-nav,
body.page-experiencia-profesional .context-nav,
body.page-legaltech .context-nav,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav,
body.page-libros .context-nav,
body.blog .context-nav {
  max-width: 820px;
  margin: 0 auto;
  padding: clamp(14px, 1.7vw, 20px);
  border-color: rgba(56,189,248,.14);
  background:
    radial-gradient(circle at 50% 0%, rgba(47,140,255,.08), transparent 30%),
    linear-gradient(135deg, rgba(7,24,39,.92), rgba(11,42,67,.82));
  box-shadow: 0 10px 28px rgba(7,24,39,.1);
}
body.page-sobre-mi .context-nav:before,
body.page-experiencia-profesional .context-nav:before,
body.page-legaltech .context-nav:before,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav:before,
body.page-libros .context-nav:before,
body.blog .context-nav:before {
  left: clamp(14px, 1.7vw, 20px);
  right: clamp(14px, 1.7vw, 20px);
  background: linear-gradient(90deg, rgba(56,189,248,.38), rgba(228,190,106,.34), transparent);
}
body.page-sobre-mi .context-nav .cta-row,
body.page-experiencia-profesional .context-nav .cta-row,
body.page-legaltech .context-nav .cta-row,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row,
body.page-libros .context-nav .cta-row,
body.blog .context-nav .cta-row {
  justify-content: center;
  gap: 10px;
}
body.page-sobre-mi .context-nav .cta-row .btn,
body.page-experiencia-profesional .context-nav .cta-row .btn,
body.page-legaltech .context-nav .cta-row .btn,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row .btn,
body.page-libros .context-nav .cta-row .btn,
body.blog .context-nav .cta-row .btn {
  min-height: 42px;
  padding: 10px 17px;
  border-radius: 999px;
  font-size: .9rem;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease, color .2s ease;
}
body.page-sobre-mi .context-nav .cta-row .btn:nth-child(1),
body.page-experiencia-profesional .context-nav .cta-row .btn:nth-child(1),
body.page-legaltech .context-nav .cta-row .btn:nth-child(1),
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row .btn:nth-child(1),
body.page-libros .context-nav .cta-row .btn:nth-child(1),
body.blog .context-nav .cta-row .btn:nth-child(1) {
  border-color: rgba(228,190,106,.72);
  box-shadow:
    0 16px 34px rgba(205,162,74,.3),
    0 0 24px rgba(228,190,106,.18),
    0 0 0 1px rgba(228,190,106,.28) inset;
}
body.page-sobre-mi .context-nav .cta-row .btn:nth-child(1):hover,
body.page-sobre-mi .context-nav .cta-row .btn:nth-child(1):focus-visible,
body.page-experiencia-profesional .context-nav .cta-row .btn:nth-child(1):hover,
body.page-experiencia-profesional .context-nav .cta-row .btn:nth-child(1):focus-visible,
body.page-legaltech .context-nav .cta-row .btn:nth-child(1):hover,
body.page-legaltech .context-nav .cta-row .btn:nth-child(1):focus-visible,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row .btn:nth-child(1):hover,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row .btn:nth-child(1):focus-visible,
body.page-libros .context-nav .cta-row .btn:nth-child(1):hover,
body.page-libros .context-nav .cta-row .btn:nth-child(1):focus-visible,
body.blog .context-nav .cta-row .btn:nth-child(1):hover,
body.blog .context-nav .cta-row .btn:nth-child(1):focus-visible {
  border-color: rgba(228,190,106,.9);
  box-shadow:
    0 20px 42px rgba(205,162,74,.4),
    0 0 30px rgba(228,190,106,.26),
    0 0 0 1px rgba(228,190,106,.36) inset;
}
body.page-sobre-mi .context-nav .cta-row .btn.light:nth-child(2),
body.page-experiencia-profesional .context-nav .cta-row .btn.light:nth-child(2),
body.page-legaltech .context-nav .cta-row .btn.light:nth-child(2) {
  border-color: rgba(20,184,166,.78);
  box-shadow:
    0 14px 30px rgba(20,184,166,.22),
    0 0 28px rgba(45,212,191,.24),
    0 0 0 1px rgba(20,184,166,.3) inset;
}
body.page-sobre-mi .context-nav .cta-row .btn.light:nth-child(2):hover,
body.page-sobre-mi .context-nav .cta-row .btn.light:nth-child(2):focus-visible,
body.page-experiencia-profesional .context-nav .cta-row .btn.light:nth-child(2):hover,
body.page-experiencia-profesional .context-nav .cta-row .btn.light:nth-child(2):focus-visible,
body.page-legaltech .context-nav .cta-row .btn.light:nth-child(2):hover,
body.page-legaltech .context-nav .cta-row .btn.light:nth-child(2):focus-visible {
  border-color: rgba(45,212,191,.94);
  box-shadow:
    0 18px 38px rgba(20,184,166,.3),
    0 0 34px rgba(45,212,191,.34),
    0 0 0 1px rgba(45,212,191,.38) inset;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row .btn.light:nth-child(2),
body.page-libros .context-nav .cta-row .btn.light:nth-child(2),
body.blog .context-nav .cta-row .btn.light:nth-child(2) {
  border-color: rgba(56,189,248,.86);
  box-shadow:
    0 16px 34px rgba(47,140,255,.24),
    0 0 32px rgba(56,189,248,.28),
    0 0 0 1px rgba(56,189,248,.28) inset;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row .btn.light:nth-child(2):hover,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row .btn.light:nth-child(2):focus-visible,
body.page-libros .context-nav .cta-row .btn.light:nth-child(2):hover,
body.page-libros .context-nav .cta-row .btn.light:nth-child(2):focus-visible,
body.blog .context-nav .cta-row .btn.light:nth-child(2):hover,
body.blog .context-nav .cta-row .btn.light:nth-child(2):focus-visible {
  border-color: rgba(56,189,248,.96);
  box-shadow:
    0 20px 42px rgba(47,140,255,.32),
    0 0 38px rgba(56,189,248,.38),
    0 0 0 1px rgba(56,189,248,.4) inset;
}
body.page-libros span.btn.light[aria-disabled="true"] {
  cursor: default;
  border-color: rgba(203,213,225,.5);
  background: rgba(248,250,252,.72);
  color: rgba(11,42,67,.66) !important;
  box-shadow: none;
  opacity: .86;
  pointer-events: none;
}
body.page-legaltech .context-nav .cta-row .btn,
body.blog .context-nav .cta-row .btn {
  flex: 0 1 210px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row .btn {
  flex: 0 1 230px;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .cta-row .btn,
body.page-libros .context-nav .cta-row .btn {
  flex: 0 1 210px;
}
body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .cta-row .btn {
  flex-basis: 245px;
  white-space: nowrap;
}
@media (min-width: 861px) {
  body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav {
    max-width: 740px;
    padding-inline: clamp(12px, 1.45vw, 18px);
  }
  body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .cta-row {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
  }
  body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .cta-row .btn {
    width: 100%;
    min-width: 0;
    flex: none;
    font-size: .9rem;
    white-space: nowrap;
  }
  body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .cta-row .btn:nth-child(1) {
    grid-column: 1 / 4;
  }
  body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .cta-row .btn:nth-child(2) {
    grid-column: 4 / 7;
  }
  body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav .cta-row .btn:nth-child(3) {
    grid-column: 3 / 5;
    justify-self: center;
  }
}

@media (min-width: 721px) {
  body.page-sobre-mi main#content > section.section.soft-band:nth-of-type(2) .lead {
    max-width: 860px;
    margin-bottom: clamp(24px, 3vw, 34px);
    font-size: clamp(1.08rem, 1.36vw, 1.2rem);
    line-height: 1.72;
  }
  body.page-sobre-mi main#content > section.section.soft-band:nth-of-type(4) {
    padding-bottom: clamp(42px, 4.8vw, 64px);
  }
  body.page-sobre-mi main#content > section.section-tight.soft-band:nth-of-type(5) {
    padding-top: clamp(26px, 3.6vw, 46px);
    padding-bottom: clamp(32px, 4.2vw, 54px);
  }
  body.page-sobre-mi .about-synthesis-card {
    min-height: 168px;
    padding: 24px 19px 19px;
  }
  body.page-sobre-mi .about-synthesis-card p {
    font-size: .95rem;
    line-height: 1.5;
  }
  body.page-trayectoria-academica .timeline {
    gap: 22px 24px;
    margin-top: 42px;
  }
  body.page-trayectoria-academica .timeline-item {
    padding: clamp(24px, 2.6vw, 30px);
  }
  body.page-trayectoria-academica .timeline-meta {
    margin-bottom: 12px;
    line-height: 1.42;
  }
  body.page-trayectoria-academica .timeline-title {
    margin-bottom: 12px;
    line-height: 1.34;
  }
  body.page-trayectoria-academica .timeline-text {
    line-height: 1.64;
  }
  body.page-trayectoria-academica .salamanca-recognition {
    padding: clamp(34px, 4vw, 48px);
  }
  body.page-trayectoria-academica .salamanca-recognition > p {
    max-width: 980px;
    line-height: 1.66;
  }
  body.page-trayectoria-academica .salamanca-quote-label {
    margin-top: clamp(22px, 2.8vw, 30px);
  }
  body.page-trayectoria-academica .salamanca-quote {
    margin-bottom: clamp(22px, 2.8vw, 30px);
    padding: clamp(24px, 3.1vw, 34px);
  }
  body.page-trayectoria-academica .salamanca-quote p {
    line-height: 1.72;
  }
}

.page-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(72px, 8vw, 104px) 0 clamp(48px, 6.2vw, 76px);
  background:
    radial-gradient(circle at 85% 18%, rgba(47,140,255,.25), transparent 28%),
    linear-gradient(120deg, rgba(7,24,39,.97), rgba(11,42,67,.86)),
    var(--navy);
  color: var(--white);
}
body.blog .page-hero,
body.page-libros .page-hero {
  background:
    radial-gradient(circle at 85% 18%, rgba(47,140,255,.25), transparent 28%),
    radial-gradient(circle at 12% 100%, rgba(56,189,248,.1), transparent 34%),
    linear-gradient(120deg, rgba(7,24,39,.97), rgba(18,58,90,.92)),
    var(--navy);
}
.page-hero.image-bg {
  background-size: cover;
  background-position: center 38%;
}
.page-hero h1 { font-size: clamp(2.35rem, 5.05vw, 4.45rem); max-width: 960px; }
.page-hero .lead { margin-top: 22px; }

.service-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 30px;
}
.service-card {
  padding: 25px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--white);
  box-shadow: 0 12px 34px rgba(7,20,38,.06);
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.service-card:hover {
  transform: translateY(-2px);
  border-color: rgba(205,162,74,.58);
  box-shadow: 0 18px 48px rgba(7,20,38,.1);
}
body.page-experiencia-profesional .experience-current-head {
  grid-column: 1 / -1;
  max-width: 900px;
  margin: 0 0 4px;
}
body.page-experiencia-profesional .experience-current-head .eyebrow {
  margin-bottom: 8px;
}
body.page-experiencia-profesional .experience-current-head h2 {
  max-width: 760px;
  margin-bottom: 0;
}

body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-hub > .container > .lead + p {
  max-width: 920px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-feature {
  position: relative;
  margin: clamp(30px, 4vw, 48px) 0 clamp(34px, 4.5vw, 56px);
  padding: clamp(24px, 3.2vw, 36px);
  border: 1px solid rgba(47,140,255,.16);
  border-radius: 14px;
  background:
    radial-gradient(circle at 100% 0%, rgba(47,140,255,.1), transparent 30%),
    linear-gradient(135deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
  box-shadow: 0 16px 42px rgba(7,20,38,.07);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-feature:before {
  content: "";
  position: absolute;
  top: 0;
  left: clamp(24px, 3vw, 36px);
  right: clamp(24px, 3vw, 36px);
  height: 2px;
  background: linear-gradient(90deg, var(--gold), rgba(47,140,255,.72), transparent);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-feature h3,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-method h3 {
  color: var(--navy);
  font-size: clamp(1.35rem, 2vw, 1.8rem);
  margin-bottom: 14px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-feature p,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-method p {
  max-width: 980px;
  color: var(--muted);
  line-height: 1.68;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-group-head {
  margin-top: clamp(34px, 5vw, 64px);
  padding-top: clamp(22px, 3vw, 34px);
  border-top: 1px solid rgba(179,197,220,.58);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-group-head h2 {
  margin-bottom: 12px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-group-head .lead {
  max-width: 900px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-head {
  margin-top: clamp(44px, 6vw, 76px);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-list {
  grid-template-columns: minmax(0, 1fr);
  max-width: 900px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-list .service-card {
  border-color: rgba(205,162,74,.32);
  background:
    radial-gradient(circle at 100% 0%, rgba(205,162,74,.08), transparent 32%),
    var(--white);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-method {
  margin-top: clamp(34px, 5vw, 58px);
  padding: clamp(22px, 3vw, 34px) 0 0;
  border-top: 1px solid rgba(47,140,255,.18);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-hub {
  background: linear-gradient(180deg, #fff, rgba(248,250,252,.98));
}
@media (min-width: 1024px) {
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-hub {
    padding-bottom: clamp(68px, 5vw, 78px);
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-hub + .section-tight {
    padding-top: clamp(42px, 3.5vw, 52px);
  }
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-intro {
  max-width: 980px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-intro h2,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-head h2,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow h2,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-head h2,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-fit-filter h2 {
  max-width: 900px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-intro > p:not(.lead) {
  max-width: 920px;
  color: var(--muted);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-head,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-section,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-fit-filter {
  margin-top: clamp(34px, 5vw, 62px);
  padding-top: clamp(22px, 3vw, 34px);
  border-top: 1px solid rgba(179,197,220,.58);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-list {
  display: grid;
  gap: 14px;
  margin-top: clamp(22px, 3.2vw, 34px);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-item {
  border: 1px solid rgba(179,197,220,.62);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.94));
  box-shadow: 0 12px 32px rgba(7,20,38,.055);
  overflow: hidden;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-item[open] {
  border-color: rgba(205,162,74,.5);
  box-shadow: 0 16px 40px rgba(7,20,38,.075);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-item--tech[open] {
  border-color: rgba(56,189,248,.46);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-item summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px 18px;
  align-items: center;
  padding: clamp(18px, 2.4vw, 24px);
  cursor: pointer;
  list-style: none;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-item summary::-webkit-details-marker {
  display: none;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-item summary:focus-visible {
  outline: 3px solid rgba(47,140,255,.36);
  outline-offset: -3px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-title {
  color: var(--navy);
  font-size: clamp(1.06rem, 1.42vw, 1.24rem);
  font-weight: 800;
  line-height: 1.25;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-summary {
  grid-column: 1 / 2;
  color: var(--muted);
  line-height: 1.58;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-action {
  grid-column: 2 / 3;
  grid-row: 1 / 3;
  align-self: center;
  color: var(--navy-2);
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-action:after {
  content: "+";
  display: inline-block;
  margin-left: 8px;
  color: var(--gold);
  font-size: 1.1rem;
  line-height: 1;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-item[open] .services-accordion-action:after {
  content: "-";
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 0 clamp(18px, 2.4vw, 24px) clamp(18px, 2.4vw, 24px);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content p {
  position: relative;
  margin: 0;
  padding: 18px 18px 17px;
  border: 1px solid rgba(179,197,220,.45);
  border-radius: 10px;
  background: rgba(255,255,255,.72);
  color: var(--muted);
  line-height: 1.6;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content p:before {
  content: attr(data-step);
  display: block;
  margin-bottom: 5px;
  color: rgba(205,162,74,.82);
  font-family: "Source Serif 4", Georgia, serif;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .1em;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content strong,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid strong {
  color: var(--navy-2);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content strong {
  display: inline-block;
  margin-bottom: 3px;
  font-size: .95rem;
  letter-spacing: .01em;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 15px;
  margin-top: clamp(20px, 3vw, 30px);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid article,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-grid article {
  padding: 20px;
  border: 1px solid rgba(179,197,220,.52);
  border-radius: 14px;
  background: var(--white);
  box-shadow: 0 12px 30px rgba(7,20,38,.05);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid span {
  display: block;
  margin-bottom: 7px;
  color: var(--gold);
  font-weight: 800;
  line-height: 1;
  letter-spacing: .12em;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid h3,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-grid h3 {
  color: var(--navy);
  font-size: 1.06rem;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid p,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-grid p,
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-fit-filter p {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-section {
  padding: clamp(24px, 3.4vw, 40px);
  border: 1px solid rgba(47,140,255,.14);
  border-radius: 16px;
  background:
    radial-gradient(circle at 100% 0%, rgba(47,140,255,.08), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,250,252,.96));
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-section .services-collab-head {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: clamp(20px, 3vw, 30px);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-grid article:nth-child(3) {
  border-color: rgba(56,189,248,.3);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-grid article:nth-child(5) {
  grid-column: 1 / -1;
  border-color: rgba(205,162,74,.28);
  background:
    linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,250,252,.96));
  box-shadow: 0 14px 34px rgba(7,20,38,.045);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-grid article:nth-child(5) p {
  max-width: 880px;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-fit-filter {
  max-width: 940px;
  margin-left: auto;
  margin-right: auto;
  padding: clamp(22px, 3vw, 32px);
  border: 1px solid rgba(205,162,74,.26);
  border-radius: 14px;
  background:
    radial-gradient(circle at 100% 0%, rgba(205,162,74,.1), transparent 32%),
    rgba(255,255,255,.82);
  text-align: center;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-fit-filter p {
  max-width: 780px;
  margin-left: auto;
  margin-right: auto;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .context-nav-lead {
  margin-top: 7px;
  color: rgba(220,232,248,.82);
  font-size: .94rem;
  font-weight: 400;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav {
  max-width: 900px;
  padding: clamp(20px, 2.35vw, 30px);
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav > p:first-child {
  max-width: 780px;
  margin-left: auto;
  margin-right: auto;
  font-size: clamp(1.04rem, 1.45vw, 1.26rem);
  font-weight: 750;
  line-height: 1.32;
}
body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .cta-row {
  margin-top: 18px;
}
@media (max-width: 720px) {
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .page-hero .container {
    width: var(--container);
    max-width: var(--container);
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .page-hero h1,
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .page-hero .lead {
    width: 100%;
    max-width: 100%;
  }
}

body.page-servicios .services-page-hero .lead {
  max-width: 880px;
}
body.page-servicios .services-brief {
  background: linear-gradient(180deg, #fff, rgba(248,250,252,.98));
}
body.page-servicios .services-brief-grid,
body.page-servicios .services-activation-grid {
  display: grid;
  grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: start;
}
body.page-servicios .services-brief-copy {
  max-width: 780px;
  color: var(--muted);
  font-size: clamp(1rem, 1.25vw, 1.08rem);
}
body.page-servicios .services-prevention {
  background: var(--warm-white);
}
body.page-servicios .services-prevention-panel {
  position: relative;
  padding: clamp(24px, 3.4vw, 40px);
  border: 1px solid rgba(47,140,255,.16);
  border-radius: 16px;
  background:
    radial-gradient(circle at 100% 0%, rgba(47,140,255,.08), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
  box-shadow: 0 16px 42px rgba(7,20,38,.07);
}
body.page-servicios .services-prevention-panel:before {
  content: "";
  position: absolute;
  top: 0;
  left: clamp(24px, 3vw, 36px);
  right: clamp(24px, 3vw, 36px);
  height: 2px;
  background: linear-gradient(90deg, var(--gold), rgba(47,140,255,.64), transparent);
}
body.page-servicios .services-prevention-panel h2,
body.page-servicios .services-section-head h2 {
  max-width: 860px;
}
body.page-servicios .services-prevention-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: clamp(20px, 3vw, 30px);
}
body.page-servicios .services-prevention-grid p {
  margin: 0;
  padding: 18px;
  border: 1px solid rgba(179,197,220,.55);
  border-radius: 12px;
  background: rgba(255,255,255,.74);
  color: var(--muted);
  line-height: 1.58;
}
body.page-servicios .services-prevention-grid strong,
body.page-servicios .services-module strong {
  color: var(--navy-2);
}
body.page-servicios .services-section-head {
  max-width: 920px;
  margin-bottom: clamp(28px, 4vw, 44px);
}
body.page-servicios .services-need-stack {
  display: grid;
  gap: clamp(24px, 4vw, 38px);
}
body.page-servicios .services-need-group {
  position: relative;
  display: grid;
  grid-template-columns: minmax(240px, .8fr) minmax(0, 1.4fr);
  gap: clamp(20px, 3.4vw, 38px);
  padding: clamp(22px, 3vw, 34px);
  border: 1px solid rgba(179,197,220,.48);
  border-radius: 16px;
  background: linear-gradient(180deg, #fff, rgba(248,250,252,.96));
  box-shadow: 0 14px 38px rgba(7,20,38,.06);
}
body.page-servicios .services-need-group:before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  border-radius: 16px 0 0 16px;
  background: var(--gold);
}
body.page-servicios .services-need-group--prevention:before {
  background: linear-gradient(180deg, var(--gold-2), rgba(20,184,166,.72));
}
body.page-servicios .services-need-group--tech:before {
  background: linear-gradient(180deg, var(--blue), var(--cyan));
}
body.page-servicios .services-need-head span {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--gold);
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}
body.page-servicios .services-need-group--tech .services-need-head span {
  color: var(--blue);
}
body.page-servicios .services-need-head h3 {
  color: var(--navy);
  font-size: clamp(1.26rem, 2vw, 1.72rem);
}
body.page-servicios .services-need-head p {
  margin: 0;
  color: var(--muted);
  line-height: 1.62;
}
body.page-servicios .services-module-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
body.page-servicios .services-need-group--legal .services-module-grid,
body.page-servicios .services-need-group--tech .services-module-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
body.page-servicios .services-module {
  padding: 18px;
  border: 1px solid rgba(179,197,220,.5);
  border-radius: 12px;
  background: rgba(255,255,255,.82);
}
body.page-servicios .services-module h4 {
  margin: 0 0 12px;
  color: var(--navy);
  font-size: 1rem;
  line-height: 1.28;
}
body.page-servicios .services-module ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
  color: var(--muted);
  font-size: .92rem;
  line-height: 1.48;
}
body.page-servicios .services-method-section {
  background: var(--warm-white);
}
body.page-servicios .services-method-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
body.page-servicios .services-method-steps article {
  padding: 20px;
  border: 1px solid rgba(179,197,220,.52);
  border-radius: 14px;
  background: var(--white);
  box-shadow: 0 12px 30px rgba(7,20,38,.05);
}
body.page-servicios .services-method-steps span {
  display: block;
  margin-bottom: 12px;
  color: var(--gold);
  font-weight: 800;
  letter-spacing: .12em;
}
body.page-servicios .services-method-steps h3 {
  color: var(--navy);
  font-size: 1.06rem;
}
body.page-servicios .services-method-steps p,
body.page-servicios .services-alert-list p {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
}
body.page-servicios .services-alert-list {
  display: grid;
  gap: 12px;
}
body.page-servicios .services-alert-list p {
  padding: 16px 18px;
  border: 1px solid rgba(47,140,255,.16);
  border-radius: 12px;
  background:
    linear-gradient(90deg, rgba(47,140,255,.06), rgba(255,255,255,.96));
}
body.page-servicios .context-nav {
  max-width: 820px;
  margin: 0 auto;
  padding: clamp(14px, 1.7vw, 20px);
  border-color: rgba(56,189,248,.14);
  background:
    radial-gradient(circle at 50% 0%, rgba(47,140,255,.08), transparent 30%),
    linear-gradient(135deg, rgba(7,24,39,.92), rgba(11,42,67,.82));
  box-shadow: 0 10px 28px rgba(7,24,39,.1);
}
body.page-servicios .context-nav:before {
  left: clamp(14px, 1.7vw, 20px);
  right: clamp(14px, 1.7vw, 20px);
  background: linear-gradient(90deg, rgba(56,189,248,.38), rgba(228,190,106,.34), transparent);
}
body.page-servicios .context-nav .context-nav-lead {
  margin-top: 7px;
  color: rgba(220,232,248,.82);
  font-size: .94rem;
  font-weight: 400;
}
body.page-servicios .context-nav .cta-row {
  justify-content: center;
  gap: 10px;
}
body.page-servicios .context-nav .cta-row .btn {
  flex: 0 1 210px;
  min-height: 42px;
  padding: 10px 17px;
  border-radius: 999px;
  font-size: .9rem;
}
body.page-servicios .context-nav .cta-row .btn:nth-child(1) {
  border-color: rgba(228,190,106,.72);
  box-shadow:
    0 16px 34px rgba(205,162,74,.3),
    0 0 24px rgba(228,190,106,.18),
    0 0 0 1px rgba(228,190,106,.28) inset;
}
body.page-servicios .context-nav .cta-row .btn.light:nth-child(2) {
  border-color: rgba(56,189,248,.86);
  box-shadow:
    0 16px 34px rgba(47,140,255,.24),
    0 0 32px rgba(56,189,248,.28),
    0 0 0 1px rgba(56,189,248,.28) inset;
}

body.page-sobre-mi .about-closing-quote {
  position: relative;
  margin: clamp(28px, 4vw, 44px) 0 0;
  padding: clamp(22px, 2.8vw, 32px);
  border-left: 3px solid var(--gold);
  border-radius: 14px;
  background:
    radial-gradient(circle at 100% 0%, rgba(205,162,74,.14), transparent 34%),
    linear-gradient(135deg, rgba(250,247,239,.98), rgba(246,250,255,.98));
  box-shadow: 0 16px 42px rgba(7,20,38,.08);
  color: var(--navy);
  font-family: var(--serif);
  font-size: clamp(1.14rem, 1.9vw, 1.62rem);
  font-style: italic;
  line-height: 1.42;
}
body.page-sobre-mi .soft-band {
  background:
    radial-gradient(circle at 0% 0%, rgba(47,140,255,.045), transparent 30%),
    linear-gradient(135deg, rgba(248,250,252,.98), rgba(245,247,250,.98));
  border-top: 1px solid rgba(47,140,255,.06);
  border-bottom: 1px solid rgba(205,162,74,.08);
}
body.page-sobre-mi strong {
  color: #173a5a;
  font-weight: 750;
}
body.page-sobre-mi em strong {
  color: inherit;
}
body.page-sobre-mi .about-dual-section h2 {
  font-size: clamp(1.72rem, 2.35vw, 2.34rem);
  line-height: 1.14;
  max-width: 18.5ch;
}
body.page-sobre-mi .about-closing-quote:before {
  content: "";
  position: absolute;
  top: 0;
  left: clamp(24px, 3vw, 36px);
  right: clamp(24px, 3vw, 36px);
  height: 1px;
  background: linear-gradient(90deg, rgba(205,162,74,.72), rgba(47,140,255,.36), transparent);
}
body.page-sobre-mi .about-synthesis-grid {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  align-items: stretch;
}
body.page-sobre-mi .about-synthesis-card {
  position: relative;
  overflow: hidden;
  min-height: 154px;
  padding: 22px 17px 17px;
  border-color: rgba(23,58,96,.14);
  border-top-color: rgba(205,162,74,.72);
  border-radius: 14px;
  background:
    radial-gradient(circle at 100% 0%, rgba(47,140,255,.08), transparent 38%),
    linear-gradient(180deg, rgba(255,252,245,.98), rgba(247,251,255,.97));
  box-shadow: 0 12px 30px rgba(7,20,38,.07);
}
body.page-sobre-mi .about-synthesis-card:before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 3px;
  background: linear-gradient(90deg, var(--gold), rgba(47,140,255,.7));
  opacity: .82;
}
body.page-sobre-mi .about-synthesis-card h3:before {
  display: none;
}
body.page-sobre-mi .about-synthesis-card h3 {
  margin-bottom: 7px;
  font-size: 1rem;
  line-height: 1.2;
}
body.page-sobre-mi .about-synthesis-card p {
  font-size: .93rem;
  line-height: 1.46;
}
body.page-sobre-mi .about-synthesis-card:hover {
  border-color: rgba(205,162,74,.52);
  box-shadow: 0 16px 38px rgba(7,20,38,.11);
}
body.page-sobre-mi .about-social-links,
body.page-contacto .contact-social-links,
body.page-contact .contact-social-links {
  display: flex;
  flex-wrap: wrap;
  gap: 11px;
  margin-top: 22px;
}
body.page-sobre-mi .about-social-links .text-link,
body.page-contacto .contact-social-links .text-link,
body.page-contact .contact-social-links .text-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 36px;
  padding: 8px 16px 8px 13px;
  border: 1px solid rgba(205,162,74,.24);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.88));
  color: var(--navy);
  font-size: .87rem;
  font-weight: 700;
  line-height: 1.1;
  text-decoration: none;
  box-shadow:
    0 12px 26px rgba(7,20,38,.06),
    inset 0 1px 0 rgba(255,255,255,.8);
  white-space: nowrap;
  transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease, color .2s ease;
}
body.page-sobre-mi .about-social-links .text-link:before,
body.page-contacto .contact-social-links .text-link:before,
body.page-contact .contact-social-links .text-link:before {
  content: "";
  display: inline-block;
  width: 3px;
  height: 16px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(205,162,74,.9), rgba(228,190,106,.46));
  box-shadow: 0 0 12px rgba(205,162,74,.18);
}
body.page-sobre-mi .about-social-links .text-link:nth-child(2):before,
body.page-contacto .contact-social-links .text-link:nth-child(2):before,
body.page-contact .contact-social-links .text-link:nth-child(2):before {
  background: linear-gradient(180deg, rgba(56,189,248,.88), rgba(47,140,255,.42));
  box-shadow: 0 0 12px rgba(56,189,248,.18);
}
body.page-sobre-mi .about-social-links .text-link:nth-child(3):before,
body.page-contacto .contact-social-links .text-link:nth-child(3):before,
body.page-contact .contact-social-links .text-link:nth-child(3):before {
  background: linear-gradient(180deg, rgba(205,162,74,.82), rgba(56,189,248,.42));
  box-shadow: 0 0 12px rgba(47,140,255,.16);
}
body.page-sobre-mi .about-social-links .text-link:hover,
body.page-sobre-mi .about-social-links .text-link:focus-visible,
body.page-contacto .contact-social-links .text-link:hover,
body.page-contacto .contact-social-links .text-link:focus-visible,
body.page-contact .contact-social-links .text-link:hover,
body.page-contact .contact-social-links .text-link:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(56,189,248,.42);
  background:
    linear-gradient(180deg, rgba(255,255,255,1), rgba(248,250,252,.94));
  color: var(--navy-2);
  box-shadow:
    0 14px 30px rgba(47,140,255,.13),
    0 0 0 1px rgba(205,162,74,.14),
    inset 0 1px 0 rgba(255,255,255,.86);
}
body.page-contacto .contact-social-links,
body.page-contact .contact-social-links {
  margin-top: 18px;
  margin-bottom: 4px;
}
body.page-contacto .contact-social-links .social-short,
body.page-contact .contact-social-links .social-short {
  display: none;
}
.site-footer .footer-social-links {
  display: grid;
  gap: 7px;
  margin-top: 14px;
}
.site-footer .footer-linkedin {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0;
}
.site-footer .footer-linkedin span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border: 1px solid rgba(86,225,255,.28);
  border-radius: 7px;
  background: rgba(47,140,255,.12);
  color: #dce8f8;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: -.02em;
}
.page-legaltech {
  background: linear-gradient(180deg, #071827, #0b2a43);
}
.legaltech-intro {
  background:
    radial-gradient(circle at 88% 12%, rgba(56,189,248,.17), transparent 30%),
    linear-gradient(180deg, rgba(7,24,39,.96), rgba(18,58,90,.96));
  color: var(--white);
}
.legaltech-intro p { color: #c9d5e6; }
.page-legaltech .legaltech-questions h2 { color: var(--white); }
.legaltech-intro .media-frame img {
  object-position: center 22%;
}
.ai-architecture {
  background:
    radial-gradient(circle at 82% 10%, rgba(56,189,248,.18), transparent 30%),
    linear-gradient(180deg, #071827, #0b2a43);
  border-top: 1px solid rgba(205,162,74,.15);
  border-bottom: 1px solid rgba(205,162,74,.15);
}
.ai-architecture-head {
  max-width: 960px;
}
.ai-architecture-head p {
  color: #c9d5e6;
  max-width: 860px;
}
.ai-quote {
  margin: 38px 0 0;
  padding: clamp(24px, 4vw, 38px);
  border-left: 3px solid var(--gold);
  background: rgba(255,255,255,.055);
  color: var(--white);
  font-family: "Source Serif 4", Georgia, serif;
  font-size: clamp(1.34rem, 2.25vw, 2.05rem);
  line-height: 1.22;
}
.ai-method-grid .dark-card {
  border-color: rgba(56,189,248,.18);
}
.ai-method-grid .dark-card h3 { color: var(--white); }
.ai-method-grid .dark-card p { color: #c9d5e6; }
.legaltech-panel {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(56,189,248,.18), transparent 38%),
    radial-gradient(circle at 12% 20%, rgba(56,189,248,.17), transparent 30%),
    linear-gradient(180deg, var(--navy-3) 0%, var(--navy-2) 30%, var(--navy) 100%);
}
.legaltech-panel .service-card {
  background: rgba(255,255,255,.055);
  border-color: rgba(56,189,248,.16);
  color: var(--white);
  box-shadow: none;
}
.legaltech-panel .service-card h3 { color: var(--white); }
.legaltech-panel .service-card p { color: #c9d5e6; }
.legaltech-focus {
  max-width: 880px;
}
.legaltech-focus p {
  font-size: clamp(1.06rem, 1.72vw, 1.22rem);
  color: #d7e2f2;
}
.book-card {
  display: grid;
  grid-template-rows: 250px auto;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--white);
  box-shadow: 0 16px 44px rgba(7,20,38,.08);
}
.book-cover {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
  background:
    linear-gradient(140deg, rgba(205,162,74,.08), transparent 42%),
    linear-gradient(135deg, var(--navy), var(--navy-3));
  color: var(--white);
  position: relative;
  overflow: hidden;
}
.book-cover:before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(205,162,74,.34);
}
.book-cover span {
  position: relative;
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border: 1px solid var(--gold);
  border-radius: 50%;
  color: var(--gold);
  font-family: "Source Serif 4", Georgia, serif;
  font-weight: 800;
  margin-bottom: auto;
}
.book-cover h3, .book-cover small { position: relative; }
.book-cover small {
  color: #c9d5e6;
  margin-top: 10px;
  font-weight: 700;
}
.badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 99px;
  background: var(--gold-soft);
  color: #6f5016;
  font-size: .78rem;
  font-weight: 800;
}
.tag-list { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }

.contact-box {
  padding: clamp(28px, 4vw, 44px);
  background: var(--white);
  border: 1px solid rgba(205,162,74,.26);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.contact-side {
  align-self: start;
  padding: clamp(26px, 4vw, 40px);
  border-left: 3px solid var(--gold);
  background: rgba(255,255,255,.72);
}
.contact-side h2 {
  font-size: clamp(1.68rem, 2.75vw, 2.38rem);
  line-height: 1.15;
}
.contact-side p {
  color: var(--muted);
}
.innovation-note {
  margin: 24px 0 20px;
  padding: 20px 22px;
  border-left: 3px solid var(--gold);
  background: linear-gradient(180deg, #fff, #f8fafc);
  box-shadow: 0 12px 34px rgba(7,20,38,.06);
}
.innovation-note strong {
  display: block;
  color: var(--navy);
  margin-bottom: 8px;
}
.innovation-note p {
  margin: 0;
  color: var(--muted);
}
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.field-full { grid-column: 1 / -1; }
label { display: block; font-weight: 800; margin-bottom: 7px; }
input, select, textarea {
  width: 100%;
  min-height: 48px;
  padding: 12px 14px;
  border: 1px solid #cbd5e1;
  border-radius: var(--radius);
  font: inherit;
  background: var(--white);
}
.privacy-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-weight: 700;
  color: var(--muted);
}
.privacy-check a {
  color: var(--blue);
  border-bottom: 1px solid rgba(205,162,74,.5);
}
.privacy-check input {
  width: 18px;
  min-height: 18px;
  height: 18px;
  margin-top: 4px;
  flex: 0 0 18px;
}
textarea { min-height: 150px; resize: vertical; }
textarea::placeholder { color: #7b8798; }
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
button:focus-visible,
a:focus-visible {
  outline: 3px solid rgba(47,140,255,.28);
  outline-offset: 2px;
}
button:focus:not(:focus-visible),
a:focus:not(:focus-visible) {
  outline: none;
}
.form-help {
  margin: -2px 0 2px;
  color: var(--muted);
  font-size: .92rem;
}
.turnstile-wrap {
  margin: 2px 0 8px;
}
.notice {
  padding: 14px 16px;
  border-radius: var(--radius);
  margin-bottom: 20px;
  background: #e8f7ef;
  color: #0f5132;
  border: 1px solid #badbcc;
}
.notice.error {
  background: #fff2f2;
  color: #842029;
  border-color: #f5c2c7;
}
.hidden-field {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.blog-grid {
  display: grid;
  grid-template-columns: 2fr .8fr;
  gap: 36px;
}
.post-list { display: grid; gap: 20px; }
.article-card {
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--white);
}
.article-card h2 { font-size: clamp(1.5rem, 2.8vw, 2.4rem); }
.meta { color: var(--muted); font-size: .9rem; margin: 12px 0; }
.sidebar {
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--soft);
  align-self: start;
}
.sidebar a { display: block; color: var(--muted); margin-top: 10px; }
.prose { max-width: 860px; }
.prose h1 { font-size: clamp(2.4rem, 5vw, 4.4rem); margin-bottom: 22px; }
.prose h2 { font-size: clamp(1.8rem, 3.4vw, 2.8rem); margin: 38px 0 14px; }
.prose ul { padding-left: 22px; }

.site-footer {
  background:
    linear-gradient(180deg, rgba(205,162,74,.16), rgba(205,162,74,0) 1px),
    radial-gradient(circle at 88% 20%, rgba(47,140,255,.17), transparent 32%),
    linear-gradient(135deg, #071827, #0b2a43 62%, #071827);
  color: #dce5f4;
  padding: 62px 0 30px;
  border-top: 1px solid rgba(205,162,74,.34);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr .7fr .8fr;
  gap: 46px;
  min-width: 0;
}
.site-footer h2 { font-size: 1rem; margin-bottom: 16px; color: var(--white); letter-spacing: .02em; }
.site-footer a {
  display: block;
  color: #d3e1f3;
  margin: 9px 0;
  overflow-wrap: anywhere;
}
.site-footer a:hover { color: var(--cyan); }
.site-footer .footer-subitem {
  margin: 6px 0 6px 14px;
  font-size: .92rem;
  color: #b7c9dd;
}
.site-footer .footer-subitem:before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 1px;
  margin-right: 8px;
  vertical-align: middle;
  background: rgba(205,162,74,.52);
}
.site-footer .brand,
.site-footer p,
.site-footer span,
.site-footer div {
  min-width: 0;
}
.footer-brand {
  align-items: flex-start;
}
.footer-brand > span:last-child {
  min-width: 0;
}
.footer-copy { color: #bdcadc; margin-top: 18px; max-width: 540px; line-height: 1.7; }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  margin-top: 46px;
  padding-top: 24px;
  border-top: 1px solid rgba(205,162,74,.22);
  color: #8f9db2;
  font-size: .9rem;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

body.page-en .primary-nav {
  gap: 10px;
  font-size: .8rem;
}
body.page-en .hero.en-hero {
  background:
    radial-gradient(circle at 18% 18%, rgba(56,189,248,.12), transparent 28%),
    linear-gradient(135deg, #071827 0%, #0b2a43 56%, #123a5a 100%);
}
body.page-en .en-hero .hero-grid {
  min-height: calc(100vh - 74px);
  padding-block: 58px;
}
body.page-en .en-hero h1 {
  max-width: 920px;
  font-size: 3.35rem;
}
body.page-en .en-hero .lead {
  max-width: 780px;
}
body.page-en .en-trust-strip .trust-item strong {
  font-size: 1.08rem;
}
body.page-en .en-positioning-section .lead,
body.page-en .en-collaboration-section .lead {
  max-width: 820px;
}
body.page-en .en-focus-section h2,
body.page-en .en-collaboration-section h2 {
  max-width: 860px;
}
body.page-en .en-focus-grid {
  align-items: stretch;
}
body.page-en .en-focus-card {
  padding: 22px;
}
body.page-en .en-focus-card h3 {
  min-height: 2.75em;
}
body.page-en .en-academic-section .media-frame {
  max-height: 560px;
}
body.page-en .en-academic-section .media-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
body.page-en .en-legaltech-section .media-frame {
  border-color: rgba(228,190,106,.28);
}
body.page-en .en-collaboration-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}
body.page-en .en-collaboration-list span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 8px 13px;
  border: 1px solid rgba(47,140,255,.18);
  border-radius: 999px;
  color: var(--navy-2);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.98));
  font-size: .88rem;
  font-weight: 800;
}
body.page-en .en-contact-panel {
  max-width: 900px;
  margin: 0 auto;
}
body.page-en .en-contact-panel .eyebrow,
body.page-en .en-contact-panel h2 {
  position: relative;
}
body.page-en .en-contact-panel h2 {
  max-width: 720px;
  color: var(--white);
}

@media (max-width: 1080px) {
  .menu-toggle { display: block; }
  .primary-nav {
    position: absolute;
    top: 74px;
    left: 0;
    right: 0;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 12px 20px 24px;
    background: linear-gradient(180deg, #071827 0%, #0B2A43 100%);
  }
  .primary-nav.is-open { display: flex; }
  .nav-group {
    display: block;
  }
  .nav-group:after {
    display: none;
  }
  .nav-submenu {
    position: static;
    min-width: 0;
    padding: 0 0 0 16px;
    display: grid;
    gap: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    transition: none;
  }
  .primary-nav a { padding: 13px 0; border-bottom: 1px solid rgba(255,255,255,.08); }
  .language-switcher {
    align-self: flex-start;
    margin-top: 12px;
  }
  .primary-nav .language-switcher__link {
    min-width: 42px;
    min-height: 36px;
    padding: 7px 12px;
    border-bottom: 0;
  }
  .primary-nav .nav-subitem {
    padding: 11px 0 11px 14px;
    color: #b9c7d9;
    border-radius: 0;
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  .primary-nav .nav-subitem:hover,
  .primary-nav .nav-subitem.is-active {
    color: var(--gold);
    background: transparent;
  }
  .primary-nav a:after { bottom: 0; }
  .nav-cta { margin-top: 10px; }
  .hero-grid, .grid-2, .blog-grid { grid-template-columns: 1fr; }
  .hero-grid { min-height: auto; }
  .hero-card {
    width: min(100%, 560px);
    max-height: none;
    justify-self: start;
    aspect-ratio: 4 / 4.9;
  }
  .trust-grid { grid-template-columns: repeat(3, 1fr); }
  .grid-4, .grid-5 { grid-template-columns: repeat(2, 1fr); }
  .timeline, .grid-3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 720px) {
  :root { --container: min(100vw - 32px, 1180px); }
  .header-inner { min-height: 74px; }
  .brand { min-width: 0; }
  .site-brand { min-width: 0; padding-right: 4px; }
  .brand-mark { width: 40px; height: 40px; font-size: .88rem; }
  .brand strong { font-size: .98rem; max-width: 205px; overflow: hidden; text-overflow: ellipsis; }
  .brand small { display: none; }
  .brand-name {
    font-size: .98rem;
    max-width: 205px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .brand-tagline { display: none; }
  .primary-nav { top: 74px; }
  h1, h2, h3 { line-height: 1.16; }
  h2 { font-size: clamp(1.58rem, 7vw, 2.25rem); }
  .hero h1, .page-hero h1 {
    font-size: clamp(1.86rem, 8.2vw, 2.85rem);
    line-height: 1.12;
  }
  .lead { font-size: 1rem; line-height: 1.62; }
  .page-hero { padding: 60px 0 42px; }
  .page-hero.image-bg { background-position: center 30%; }
  .hero-grid { padding-top: 30px; gap: 26px; }
  .section { padding: 50px 0; }
  .section-tight { padding: 34px 0; }
  body.page-experiencia-profesional main#content > section.section:first-of-type .container.grid-2 {
    gap: 18px;
  }
  body.page-experiencia-profesional main#content > section.section:first-of-type .container.grid-2 > div {
    display: contents;
  }
  body.page-experiencia-profesional main#content > section.section:first-of-type .container.grid-2 > div > .eyebrow {
    order: 1;
    margin-bottom: 0;
  }
  body.page-experiencia-profesional main#content > section.section:first-of-type .container.grid-2 > div > h2 {
    order: 2;
    margin-bottom: 0;
  }
  body.page-experiencia-profesional main#content > section.section:first-of-type .container.grid-2 > .media-frame {
    order: 3;
    margin: 6px 0 8px;
  }
  body.page-experiencia-profesional main#content > section.section:first-of-type .container.grid-2 > div > p {
    order: 4;
  }
  .hero-card {
    width: min(100%, 430px);
    aspect-ratio: 4 / 5.15;
    border-radius: 14px 14px 54px 14px;
  }
  .hero-card img { object-position: center top; }
  body.page-experiencia-profesional .media-frame {
    aspect-ratio: 4 / 4.45;
    max-height: 440px;
  }
  body.page-experiencia-profesional .experience-journey-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  body.page-experiencia-profesional .experience-journey-card,
  body.page-experiencia-profesional .experience-journey-card--academic {
    grid-column: auto;
    padding: 21px 20px;
  }
  body.page-experiencia-profesional .experience-journey-number {
    margin-bottom: 8px;
  }
  body.page-experiencia-profesional .experience-journey-label {
    margin-bottom: 8px;
  }
  body.page-experiencia-profesional .experience-evolution-head {
    margin-bottom: 24px;
  }
  body.page-experiencia-profesional .experience-evolution-head h2 {
    max-width: 100%;
    margin-bottom: 8px;
  }
  body.page-experiencia-profesional .experience-evolution-head .experience-evolution-subtitle {
    max-width: 100%;
    margin-bottom: 6px;
    font-size: 1rem;
    line-height: 1.42;
  }
  body.page-experiencia-profesional .experience-evolution-flow {
    padding-left: 18px;
  }
  body.page-experiencia-profesional .experience-evolution-step {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 22px 0;
  }
  body.page-experiencia-profesional .experience-evolution-step:before {
    left: -24px;
    top: 28px;
  }
  body.page-experiencia-profesional .experience-evolution-step:first-child:before {
    top: 2px;
  }
  body.page-experiencia-profesional .experience-evolution-number {
    margin-bottom: 2px;
  }
  body.page-experiencia-profesional .experience-evolution-copy h3 {
    margin-bottom: 12px;
  }
  body.page-experiencia-profesional .experience-evolution-copy p {
    font-size: .98rem;
    line-height: 1.64;
  }
  body.page-experiencia-profesional .experience-evolution-today {
    padding: 18px;
  }
  .legaltech-intro .media-frame {
    aspect-ratio: 4 / 3;
  }
  .ai-quote {
    margin-top: 28px;
    padding: 22px;
    font-size: 1.28rem;
    line-height: 1.24;
  }
  .card, .service-card, .contact-box { padding: 20px; }
  body.page-trayectoria-academica .salamanca-recognition {
    padding: 24px 20px;
  }
  body.page-trayectoria-academica .salamanca-quote {
    padding: 20px;
  }
  body.page-trayectoria-academica .salamanca-quote p {
    font-size: 1rem;
    line-height: 1.62;
  }
  body.page-trayectoria-academica .salamanca-quote cite {
    margin-top: 16px;
    padding-top: 14px;
    font-size: .88rem;
  }
  body.page-trayectoria-academica .unir-evaluation {
    grid-template-columns: 1fr;
  }
  body.page-trayectoria-academica .unir-score {
    font-size: clamp(2.05rem, 9vw, 2.7rem);
  }
  body.page-trayectoria-academica .academic-tech-summary {
    padding: 20px;
  }
  body.page-trayectoria-academica .academic-tech-card {
    padding: 18px;
  }
  body.page-trayectoria-academica .academic-tech-card:before {
    margin-bottom: 12px;
  }
  body.page-trayectoria-academica .academic-tech-card h3 {
    margin-bottom: 9px;
  }
  body.page-trayectoria-academica .academic-tech-card p {
    line-height: 1.5;
  }
  body.page-trayectoria-academica .academic-signature-section {
    padding-top: 18px;
    padding-bottom: 22px;
  }
  body.page-trayectoria-academica .academic-signature-section:before {
    margin-bottom: 18px;
  }
  body.page-trayectoria-academica .academic-signature-image {
    border-radius: 12px;
  }
  body.page-trayectoria-academica .academic-signature-quote {
    margin-top: 18px;
  }
  body.page-trayectoria-academica .academic-signature-quote p {
    font-size: clamp(1rem, 3.6vw, 1.16rem);
    line-height: 1.46;
  }
  body.page-trayectoria-academica .academic-signature-section + .section-tight {
    padding-top: 16px;
  }
  body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav {
    padding: 16px;
  }
  .contact-side { padding: 22px; }
  .contact-side h2 { font-size: clamp(1.5rem, 7vw, 2.15rem); }
  body.page-contacto .contact-social-links,
  body.page-contact .contact-social-links {
    gap: 8px;
    margin-top: 16px;
  }
  body.page-contacto .contact-social-links .text-link,
  body.page-contact .contact-social-links .text-link {
    min-height: 34px;
    padding: 7px 13px;
    font-size: .84rem;
    line-height: 1;
    white-space: nowrap;
  }
  body.page-contacto .contact-social-links .social-full,
  body.page-contact .contact-social-links .social-full {
    display: none;
  }
  body.page-contacto .contact-social-links .social-short,
  body.page-contact .contact-social-links .social-short {
    display: inline;
  }
  .card h3, .service-card h3 { margin-bottom: 10px; }
  .card p, .service-card p { font-size: .96rem; line-height: 1.55; }
  .cards { margin-top: 24px; }
  .context-nav {
    padding: 18px;
    border-radius: 12px;
  }
  .context-nav .cta-row {
    margin-top: 14px;
  }
  body.page-experiencia-profesional .experience-current-head {
    margin-bottom: 2px;
  }
  body.page-experiencia-profesional .experience-current-head .eyebrow {
    margin-bottom: 7px;
  }
  body.page-experiencia-profesional .experience-current-head h2 {
    max-width: none;
  }
  .service-list { margin-top: 24px; gap: 14px; }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-item summary,
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content,
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid,
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-grid {
    grid-template-columns: 1fr;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-list {
    gap: 12px;
    margin-top: 24px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-item summary {
    gap: 8px;
    padding: 17px 18px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-title {
    font-size: 1.04rem;
    line-height: 1.26;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-summary {
    line-height: 1.5;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-action {
    grid-column: auto;
    grid-row: auto;
    justify-self: start;
    margin-top: 2px;
    font-size: .72rem;
    letter-spacing: .035em;
    color: rgba(11,42,67,.78);
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-action:after {
    margin-left: 6px;
    font-size: .98rem;
    color: rgba(205,162,74,.76);
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-head,
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow,
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-section,
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-fit-filter {
    margin-top: 28px;
    padding-top: 18px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content {
    gap: 9px;
    padding: 0 14px 15px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content p {
    padding: 14px 15px;
    border-radius: 9px;
    font-size: .95rem;
    line-height: 1.48;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content p:before {
    margin-bottom: 3px;
    font-size: .72rem;
    letter-spacing: .09em;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-accordion-content strong {
    margin-bottom: 2px;
    font-size: .9rem;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid {
    gap: 10px;
    margin-top: 18px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid article {
    padding: 16px 15px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid span {
    margin-bottom: 6px;
    font-size: .86rem;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid h3 {
    margin-bottom: 7px;
    font-size: 1rem;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-workflow-grid p {
    font-size: .94rem;
    line-height: 1.48;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-section,
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-fit-filter {
    padding: 18px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-collab-grid {
    gap: 12px;
    margin-top: 18px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-fit-filter {
    margin-top: 26px;
    padding: 18px 17px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .services-fit-filter p {
    font-size: .94rem;
    line-height: 1.48;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav {
    margin-top: -2px;
  }
  body:is(.page-servicios-colaboracion, .page-services-collaboration) .context-nav .context-nav-lead {
    font-size: .95rem;
    line-height: 1.48;
  }
  body.page-servicios .services-brief-grid,
  body.page-servicios .services-activation-grid,
  body.page-servicios .services-need-group,
  body.page-servicios .services-module-grid,
  body.page-servicios .services-need-group--legal .services-module-grid,
  body.page-servicios .services-need-group--tech .services-module-grid,
  body.page-servicios .services-prevention-grid,
  body.page-servicios .services-method-steps {
    grid-template-columns: 1fr;
  }
  body.page-servicios .services-prevention-panel,
  body.page-servicios .services-need-group {
    padding: 20px;
    border-radius: 14px;
  }
  body.page-servicios .services-need-group:before {
    inset: 0 0 auto;
    width: auto;
    height: 3px;
    border-radius: 14px 14px 0 0;
  }
  body.page-servicios .services-module,
  body.page-servicios .services-method-steps article {
    padding: 17px;
  }
  body.page-servicios .services-module ul {
    font-size: .91rem;
  }
  body.page-servicios .context-nav .cta-row .btn {
    flex-basis: auto;
  }
  .timeline-year { margin-bottom: 16px; }
  .site-footer { padding: 42px 0 22px; }
  .footer-grid { gap: 20px; }
  .footer-copy {
    margin-top: 14px;
    line-height: 1.58;
  }
  .site-footer a {
    margin: 7px 0;
  }
  .site-footer .footer-social-links {
    gap: 6px;
    margin-top: 11px;
  }
  .footer-bottom { margin-top: 22px; padding-top: 16px; }
  .hero-actions .btn, .cta-row .btn { width: 100%; }
  .trust-grid, .grid-3, .grid-4, .grid-5, .timeline, .service-list, .footer-grid, .form-grid { grid-template-columns: 1fr; }
  .trust-item {
    border-right: 1px solid rgba(179,197,220,.54);
    padding: 18px 16px;
  }
  .timeline-item { min-height: auto; }
  .field-full { grid-column: auto; }
  .footer-bottom { flex-direction: column; }
}

@media (min-width: 721px) and (max-width: 1080px) and (orientation: landscape) {
  body.page-experiencia-profesional .media-frame {
    aspect-ratio: 4 / 4.3;
    max-height: 390px;
  }
  body.page-experiencia-profesional .experience-journey-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  body.page-experiencia-profesional .experience-journey-card,
  body.page-experiencia-profesional .experience-journey-card--academic {
    grid-column: auto;
  }
  .legaltech-intro .media-frame {
    aspect-ratio: 4 / 3;
  }
  .site-footer {
    padding-inline: 0;
  }
  .footer-grid {
    grid-template-columns: 1.2fr .8fr .8fr;
    gap: 28px;
  }
  .site-footer .brand strong,
  .site-footer .brand small,
  .footer-copy,
  .footer-bottom span {
    white-space: normal;
    overflow-wrap: anywhere;
  }
}

@media (max-width: 480px) {
  :root { --container: min(100vw - 28px, 1180px); }
  .site-brand { gap: 9px; }
  .site-brand .brand-mark { width: 38px; height: 38px; font-size: .84rem; }
  .brand-name {
    font-size: .93rem;
    max-width: 196px;
  }
  .hero h1, .page-hero h1 { font-size: clamp(1.78rem, 8.6vw, 2.5rem); }
  .hero-subtitle { font-size: .98rem; }
  .hero-grid { padding-top: 26px; }
  .hero-card {
    width: min(100%, 390px);
    aspect-ratio: 4 / 5.05;
    border-radius: 12px 12px 46px 12px;
  }
  .trust-item { padding: 17px 15px; }
  .trust-item strong { font-size: 1.02rem; }
  .trust-item span { font-size: .8rem; }
  .card, .service-card, .contact-box, .timeline-item { padding: 18px; }
  body.home .home-specialties .cards {
    gap: 12px;
  }
  body.home .home-specialties .card {
    padding: 16px;
  }
  body.home .home-specialties .icon {
    margin-bottom: 9px;
  }
  body.home .home-specialties .card p {
    font-size: .94rem;
    line-height: 1.46;
  }
  body.page-trayectoria-academica .salamanca-recognition {
    padding: 22px 18px;
  }
  body.page-trayectoria-academica .salamanca-recognition p {
    line-height: 1.56;
  }
  body.page-trayectoria-academica .salamanca-quote {
    padding: 18px;
  }
  body.page-trayectoria-academica .salamanca-quote p {
    font-size: .98rem;
    line-height: 1.58;
  }
  body.page-trayectoria-academica .unir-evaluation {
    padding: 18px 17px;
    gap: 14px;
  }
  body.page-trayectoria-academica .unir-score {
    font-size: clamp(1.92rem, 10vw, 2.45rem);
  }
  body.page-trayectoria-academica .unir-evaluation p {
    line-height: 1.55;
  }
  body.page-trayectoria-academica .academic-tech-summary {
    padding: 18px;
    line-height: 1.56;
  }
  body.page-trayectoria-academica .academic-tech-card {
    padding: 16px;
  }
  body.page-trayectoria-academica .academic-tech-card:before {
    width: 34px;
    margin-bottom: 10px;
  }
  body.page-trayectoria-academica .academic-tech-card h3 {
    margin-bottom: 8px;
  }
  body.page-trayectoria-academica .academic-tech-card p {
    line-height: 1.48;
  }
  body.page-trayectoria-academica .academic-signature-section {
    padding-top: 16px;
    padding-bottom: 20px;
  }
  body.page-trayectoria-academica .academic-signature-section:before {
    width: 84px;
    margin-bottom: 16px;
  }
  body.page-trayectoria-academica .academic-signature-image {
    border-radius: 10px;
    box-shadow: 0 14px 36px rgba(7,24,39,.1);
  }
  body.page-trayectoria-academica .academic-signature-quote {
    margin-top: 16px;
    padding: 0;
  }
  body.page-trayectoria-academica .academic-signature-quote p {
    font-size: .98rem;
    line-height: 1.44;
  }
  body.page-trayectoria-academica .academic-signature-section + .section-tight {
    padding-top: 14px;
  }
  body.page-trayectoria-academica .academic-signature-section + .section-tight .context-nav {
    padding: 14px;
  }
  .ai-quote { padding: 20px; font-size: 1.2rem; }
  .btn { min-height: 44px; padding: 11px 16px; }
  .site-footer { padding: 36px 0 20px; }
}

@media (max-width: 860px) {
  body.page-en .en-hero h1 {
    font-size: 2.45rem;
  }
  body.page-en .en-focus-card h3 {
    min-height: 0;
  }
}

@media (max-width: 520px) {
  body.page-en .en-hero h1 {
    font-size: 1.92rem;
  }
  body.page-en .en-hero .hero-grid {
    padding-block: 34px;
  }
  body.page-en .en-collaboration-list span {
    width: 100%;
  }
}

/* Mini Sprint Premium 2026-06-05: LegalTech CTA + footer refinement. */
body.page-legaltech .context-nav {
  max-width: 780px;
  padding: clamp(17px, 1.8vw, 22px);
  border-color: rgba(205,162,74,.2);
  background:
    radial-gradient(circle at 18% 0%, rgba(56,189,248,.12), transparent 34%),
    linear-gradient(135deg, rgba(7,24,39,.88), rgba(11,42,67,.76) 62%, rgba(7,24,39,.9));
  box-shadow:
    0 18px 44px rgba(3,10,24,.12),
    0 0 0 1px rgba(56,189,248,.06) inset,
    inset 0 1px 0 rgba(255,255,255,.06);
}

body.page-legaltech .context-nav:before {
  background: linear-gradient(90deg, transparent, rgba(56,189,248,.42), rgba(228,190,106,.36), transparent);
}

body.page-legaltech .context-nav p {
  margin-inline: auto;
  color: #e4ecf8;
  text-align: center;
}

body.page-legaltech .context-nav .cta-row {
  margin-top: 15px;
}

body.page-legaltech .context-nav .cta-row .btn:nth-child(1) {
  box-shadow:
    0 14px 30px rgba(205,162,74,.28),
    0 0 22px rgba(228,190,106,.16),
    0 0 0 1px rgba(228,190,106,.26) inset;
}

body.page-legaltech .context-nav .cta-row .btn.light:nth-child(2) {
  border-color: rgba(56,189,248,.68);
  box-shadow:
    0 12px 28px rgba(47,140,255,.18),
    0 0 22px rgba(56,189,248,.18),
    0 0 0 1px rgba(56,189,248,.22) inset;
}

/* Footer Premium Final 2026-06-05: cierre institucional elegante, subordinado al CTA. */
.site-footer {
  padding: 32px 0 14px;
  border-top-color: rgba(205,162,74,.22);
}

.footer-grid {
  grid-template-columns: 1.08fr .72fr .72fr;
  gap: 34px;
}

.site-footer .brand-mark {
  width: 34px;
  height: 34px;
  font-size: .7rem;
}

.site-footer .footer-brand strong {
  font-size: .9rem;
}

.site-footer h2 {
  margin-bottom: 6px;
  font-size: .8rem;
  letter-spacing: .035em;
  color: rgba(248,250,252,.9);
}

.site-footer a {
  margin: 3px 0;
  font-size: .8rem;
  line-height: 1.34;
  color: rgba(211,225,243,.82);
}

.site-footer .footer-subitem {
  margin: 1px 0 1px 10px;
  font-size: .7rem;
  color: rgba(183,201,221,.62);
}

.site-footer .footer-subitem:before {
  width: 7px;
  margin-right: 5px;
  background: rgba(205,162,74,.32);
}

.site-footer .brand small,
.site-footer .brand-tagline {
  display: block;
  max-width: 430px;
  white-space: normal;
  overflow-wrap: anywhere;
  color: rgba(174,187,208,.64);
  font-size: .58rem;
}

.footer-copy {
  max-width: 430px;
  margin-top: 8px;
  color: rgba(189,202,220,.7);
  font-size: .8rem;
  line-height: 1.42;
}

.site-footer .footer-social-links {
  gap: 4px;
  margin-top: 8px;
}

.site-footer .footer-linkedin {
  gap: 6px;
  font-size: .76rem;
  color: rgba(211,225,243,.78);
}

.site-footer .footer-linkedin span {
  width: 18px;
  height: 18px;
  border-radius: 5px;
  background: rgba(47,140,255,.07);
}

.footer-bottom {
  margin-top: 16px;
  padding-top: 11px;
  gap: 8px;
  color: rgba(143,157,178,.62);
  font-size: .68rem;
  line-height: 1.25;
}

@media (max-width: 1080px) {
  .site-footer {
    padding: 28px 0 12px;
  }

  .footer-grid {
    grid-template-columns: 1.1fr .72fr .72fr;
    gap: 24px;
  }

  .footer-copy {
    max-width: 390px;
  }

  .site-footer .brand small,
  .site-footer .brand-tagline {
    max-width: 340px;
  }
}

@media (max-width: 720px) {
  body.page-legaltech .context-nav {
    max-width: none;
    padding: 17px 16px;
  }

  body.page-legaltech .context-nav p {
    text-align: left;
  }

  body.page-legaltech .context-nav .cta-row {
    gap: 9px;
  }

  .site-footer {
    padding: 20px 0 10px;
  }

  .footer-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 10px 16px;
    align-items: start;
  }

  .footer-grid > div:first-child {
    grid-column: 1 / -1;
  }

  .site-footer .brand-mark {
    width: 31px;
    height: 31px;
    font-size: .66rem;
  }

  .site-footer .footer-brand strong {
    font-size: .82rem;
  }

  .footer-copy {
    max-width: 280px;
    margin-top: 5px;
    color: rgba(189,202,220,.66);
    font-size: .74rem;
    line-height: 1.27;
  }

  .site-footer h2 {
    margin-bottom: 4px;
    font-size: .72rem;
    color: rgba(248,250,252,.86);
  }

  .site-footer a {
    margin: 1px 0;
    font-size: .72rem;
    line-height: 1.24;
    color: rgba(211,225,243,.78);
  }

  .site-footer .footer-subitem {
    margin-left: 7px;
    font-size: .62rem;
    color: rgba(183,201,221,.58);
  }

  .site-footer .footer-social-links {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 3px 10px;
    margin-top: 7px;
  }

  .site-footer .footer-social-links .footer-linkedin:first-child {
    grid-column: 1 / -1;
  }

  .site-footer .footer-linkedin {
    min-width: 0;
    overflow-wrap: anywhere;
  }

  .footer-bottom {
    margin-top: 10px;
    padding-top: 8px;
    font-size: .66rem;
  }
}

@media (max-width: 480px) {
  body.page-legaltech .context-nav {
    padding: 16px 14px;
  }

  .site-footer {
    padding: 18px 0 9px;
  }

  .footer-grid {
    gap: 9px 14px;
  }
}

@media (min-width: 1201px) {
  .site-footer {
    padding-top: 36px;
    padding-bottom: 16px;
  }

  .footer-grid {
    gap: 44px;
  }
}

/* Footer 2.0 — Arquitectura Institucional MRP: firma final por capas. */
.site-footer--layered {
  padding: 34px 0 18px;
  border-top-color: rgba(205,162,74,.24);
}

.footer-signature {
  display: grid;
  gap: 13px;
}

.footer-layer {
  min-width: 0;
}

.footer-layer--identity {
  display: flex;
  justify-content: center;
}

.site-footer--layered .footer-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 11px;
  text-align: left;
}

.site-footer--layered .brand-mark {
  width: 36px;
  height: 36px;
  font-size: .72rem;
  box-shadow:
    inset 0 0 0 4px rgba(47,140,255,.08),
    0 0 18px rgba(205,162,74,.08);
}

.site-footer--layered .footer-brand strong {
  color: #f8fafc;
  font-size: .98rem;
  line-height: 1.08;
}

.site-footer--layered .footer-brand small {
  max-width: none;
  margin-top: 2px;
  color: rgba(174,187,208,.72);
  font-size: .66rem;
  line-height: 1.3;
  letter-spacing: .015em;
  white-space: normal;
  overflow-wrap: anywhere;
}

.footer-layer--contact {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px 18px;
}

.site-footer--layered .footer-contact-link,
.site-footer--layered .footer-social-link {
  display: inline-flex;
  align-items: center;
  width: auto;
  margin: 0;
  color: rgba(211,225,243,.82);
  font-size: .78rem;
  line-height: 1.25;
  text-decoration: none;
}

.site-footer--layered .footer-contact-link {
  color: rgba(248,250,252,.86);
  font-weight: 650;
}

.site-footer--layered .footer-social-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 7px 12px;
  margin: 0;
}

.site-footer--layered .footer-social-link {
  gap: 6px;
  color: rgba(211,225,243,.72);
}

.site-footer--layered .footer-social-link span[aria-hidden="true"] {
  display: grid;
  width: 17px;
  height: 17px;
  place-items: center;
  border: 1px solid rgba(56,189,248,.32);
  border-radius: 5px;
  background: rgba(47,140,255,.07);
  color: rgba(248,250,252,.82);
  font-size: .62rem;
  font-weight: 800;
  line-height: 1;
}

.footer-layer--nav,
.footer-legal-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.footer-layer--nav {
  gap: 4px 0;
  padding-top: 11px;
  border-top: 1px solid rgba(205,162,74,.18);
}

.site-footer--layered .footer-layer--nav a,
.site-footer--layered .footer-legal-links a {
  display: inline-flex;
  align-items: center;
  width: auto;
  margin: 0;
  overflow-wrap: anywhere;
  text-decoration: none;
}

.site-footer--layered .footer-layer--nav a {
  color: rgba(211,225,243,.78);
  font-size: .76rem;
  line-height: 1.3;
  font-weight: 580;
}

.site-footer--layered .footer-layer--nav a + a:before,
.site-footer--layered .footer-legal-links a + a:before {
  content: "·";
  margin: 0 9px;
  color: rgba(205,162,74,.45);
  font-weight: 700;
}

.footer-layer--legal {
  display: grid;
  gap: 9px;
}

.footer-legal-links {
  gap: 2px 0;
}

.site-footer--layered .footer-legal-links a {
  color: rgba(174,187,208,.58);
  font-size: .68rem;
  line-height: 1.25;
}

.site-footer--layered .footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin: 0;
  padding-top: 10px;
  border-top: 1px solid rgba(205,162,74,.16);
  color: rgba(143,157,178,.6);
  font-size: .66rem;
  line-height: 1.35;
}

.site-footer--layered a:hover {
  color: var(--cyan);
}

@media (max-width: 1080px) {
  .site-footer--layered {
    padding: 30px 0 16px;
  }

  .footer-signature {
    gap: 12px;
  }

  .footer-layer--nav {
    padding-top: 10px;
  }

  .site-footer--layered .footer-bottom {
    flex-direction: column;
    align-items: center;
    gap: 4px;
    text-align: center;
  }
}

@media (max-width: 720px) {
  .site-footer--layered {
    padding: 24px 0 14px;
  }

  .footer-signature {
    gap: 11px;
  }

  .footer-layer--identity {
    justify-content: flex-start;
  }

  .site-footer--layered .footer-brand {
    justify-content: flex-start;
  }

  .footer-layer--contact {
    justify-content: flex-start;
    gap: 8px 12px;
  }

  .site-footer--layered .footer-social-links,
  .footer-layer--nav,
  .footer-legal-links {
    justify-content: flex-start;
  }

  .footer-layer--nav {
    padding-top: 10px;
  }

  .site-footer--layered .footer-layer--nav a {
    font-size: .74rem;
  }

  .site-footer--layered .footer-legal-links a {
    font-size: .66rem;
  }

  .site-footer--layered .footer-layer--nav a + a:before {
    margin: 0 7px;
  }

  .site-footer--layered .footer-legal-links a + a:before {
    margin: 0 6px;
  }

  .site-footer--layered .footer-bottom {
    align-items: flex-start;
    text-align: left;
  }
}

@media (max-width: 420px) {
  .site-footer--layered .footer-brand {
    align-items: flex-start;
  }

  .site-footer--layered .footer-contact-link,
  .site-footer--layered .footer-social-link {
    font-size: .74rem;
  }

  .site-footer--layered .footer-layer--nav a + a:before,
  .site-footer--layered .footer-legal-links a + a:before {
    margin: 0 5px;
  }
}

/* Footer 2.0 refinement — firma LegalTech premium con cache-bust 1.3.03. */
.site-footer--layered {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(205,162,74,.2), rgba(205,162,74,0) 1px),
    linear-gradient(135deg, var(--navy) 0%, var(--navy-2) 52%, var(--navy) 100%);
}

.site-footer--layered:before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(205,162,74,.42), rgba(205,162,74,.14), transparent);
  opacity: .68;
}

.site-footer--layered:after {
  content: "";
  position: absolute;
  top: -90px;
  left: 50%;
  width: min(760px, 86vw);
  height: 170px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse, rgba(47,140,255,.055), transparent 68%);
  pointer-events: none;
}

.site-footer--layered .footer-signature {
  position: relative;
  z-index: 1;
}

.site-footer--layered .brand-mark {
  border-color: rgba(205,162,74,.62);
  background: rgba(7,24,39,.42);
  box-shadow:
    inset 0 0 0 4px rgba(47,140,255,.09),
    0 0 0 1px rgba(56,189,248,.08),
    0 12px 28px rgba(0,0,0,.18),
    0 0 22px rgba(205,162,74,.1);
}

.site-footer--layered .footer-brand strong {
  text-shadow: 0 0 18px rgba(56,189,248,.12);
}

.site-footer--layered .footer-brand small {
  color: rgba(190,205,226,.76);
}

.site-footer--layered .footer-contact-link {
  padding: 6px 12px;
  border: 1px solid rgba(205,162,74,.24);
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(7,24,39,.68), rgba(11,42,67,.32));
  box-shadow: 0 10px 26px rgba(0,0,0,.12), 0 0 18px rgba(205,162,74,.06);
}

.site-footer--layered .footer-social-link {
  padding: 5px 8px;
  border: 1px solid rgba(56,189,248,.16);
  border-radius: 999px;
  background: rgba(7,24,39,.24);
}

.site-footer--layered .footer-social-link span[aria-hidden="true"] {
  background: linear-gradient(135deg, rgba(47,140,255,.13), rgba(56,189,248,.08));
}

.site-footer--layered .footer-layer--nav {
  border-top: 0;
  background:
    linear-gradient(90deg, transparent, rgba(205,162,74,.28), rgba(56,189,248,.16), transparent) top / 100% 1px no-repeat;
}

.site-footer--layered .footer-layer--nav a {
  color: rgba(225,236,249,.84);
}

.site-footer--layered .footer-legal-links a {
  color: rgba(174,187,208,.62);
}

.site-footer--layered .footer-bottom {
  border-top-color: rgba(205,162,74,.2);
}

@media (max-width: 720px) {
  .site-footer--layered:after {
    top: -72px;
    width: 112vw;
  }

  .site-footer--layered .footer-contact-link {
    padding: 5px 10px;
  }

  .site-footer--layered .footer-social-link {
    padding: 4px 7px;
  }
}
