:root {
  --pd-black: #06111f;
  --pd-black-2: #071a2d;
  --pd-blue: #0b2f55;
  --pd-blue-2: #123f6f;
  --pd-orange: #f07a1f;
  --pd-orange-2: #ff9b3d;
  --pd-white: #ffffff;
  --pd-soft: #f6f7fb;
  --pd-muted: #a9b0bd;
  --pd-line: rgba(255,255,255,.12);
  --pd-shadow: 0 24px 80px rgba(0,0,0,.28);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--pd-black);
  color: var(--pd-white);
  font-family: Inter, Manrope, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.pd-container { width: min(1160px, calc(100% - 40px)); margin: 0 auto; }

.pd-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(7,26,45,.10);
  box-shadow: 0 10px 35px rgba(6,17,31,.08);
}
.pd-nav {
  width: min(1160px, calc(100% - 40px));
  margin: 0 auto;
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.pd-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.pd-brand img {
  width: 188px;
  height: auto;
  filter: drop-shadow(0 8px 18px rgba(7,26,45,.10));
}
.pd-nav-links { display: flex; align-items: center; gap: 26px; }
.pd-nav-links a {
  font-size: 14px;
  color: #09233d;
  font-weight: 750;
  letter-spacing: .02em;
  transition: color .2s ease, transform .2s ease, background .2s ease;
}
.pd-nav-links a:hover {
  color: var(--pd-orange);
  transform: translateY(-1px);
}
.pd-nav-cta {
  border: 1px solid rgba(240,122,31,.55);
  color: #09233d !important;
  padding: 10px 16px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(240,122,31,.16), rgba(240,122,31,.05));
  box-shadow: 0 10px 30px rgba(240,122,31,.12);
}
.pd-nav-cta:hover {
  color: #071a2d !important;
  background: linear-gradient(135deg, rgba(240,122,31,.28), rgba(255,155,61,.13));
}
.pd-menu-toggle { display: none; background: transparent; border: 0; padding: 8px; cursor: pointer; }
.pd-menu-toggle span { display: block; width: 24px; height: 2px; background: #09233d; margin: 5px 0; border-radius: 999px; }

.pd-hero {
  position: relative;
  overflow: hidden;
  min-height: calc(100vh - 78px);
  padding: 100px 0 86px;
  background:
    radial-gradient(circle at 80% 15%, rgba(240,122,31,.22), transparent 32%),
    radial-gradient(circle at 18% 70%, rgba(14,58,104,.48), transparent 34%),
    linear-gradient(135deg, #06111f 0%, #071a2d 45%, #0b2f55 100%);
}
.pd-hero-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.9), transparent 85%);
}
.pd-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 54px;
  align-items: center;
}
.pd-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--pd-orange-2);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 12px;
  margin-bottom: 18px;
}
.pd-kicker::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--pd-orange);
  box-shadow: 0 0 24px rgba(240,122,31,.8);
}
.pd-hero h1 {
  font-family: Manrope, Inter, sans-serif;
  font-size: clamp(42px, 6vw, 78px);
  line-height: .98;
  letter-spacing: -.06em;
  margin: 0 0 24px;
}
.pd-hero p {
  color: rgba(255,255,255,.72);
  font-size: clamp(16px, 2vw, 20px);
  max-width: 660px;
  margin: 0 0 34px;
}
.pd-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 42px; }
.pd-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 14px 22px;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: -.01em;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.pd-btn:hover { transform: translateY(-2px); }
.pd-btn-primary {
  color: #120802;
  background: linear-gradient(135deg, var(--pd-orange-2), var(--pd-orange));
  box-shadow: 0 18px 46px rgba(240,122,31,.26);
}
.pd-btn-secondary {
  color: #fff;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(255,255,255,.06);
}
.pd-trust-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  max-width: 650px;
}
.pd-trust-row div {
  border: 1px solid rgba(255,255,255,.11);
  background: rgba(255,255,255,.045);
  border-radius: 18px;
  padding: 18px;
}
.pd-trust-row strong { display: block; color: #fff; font-size: 32px; line-height: 1; }
.pd-trust-row span { display: block; color: var(--pd-muted); font-size: 12px; margin-top: 8px; text-transform: uppercase; letter-spacing: .08em; }

.pd-hero-panel {
  position: relative;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.1), rgba(255,255,255,.035));
  box-shadow: var(--pd-shadow);
  transform: rotate(1deg);
}
.pd-panel-top { display: flex; gap: 8px; padding: 16px 18px; border-bottom: 1px solid rgba(255,255,255,.1); background: rgba(0,0,0,.22); }
.pd-panel-top span { width: 11px; height: 11px; border-radius: 50%; background: var(--pd-orange); opacity: .9; }
.pd-panel-top span:nth-child(2) { background: #ffc66d; }
.pd-panel-top span:nth-child(3) { background: #3ccf91; }
.pd-panel-content { position: relative; min-height: 460px; padding: 24px; display: grid; place-items: center; }
.pd-panel-content img { width: 100%; height: 390px; object-fit: cover; border-radius: 22px; opacity: .82; filter: saturate(.9) contrast(1.08); }
.pd-orbit { position: absolute; width: 290px; height: 290px; border: 1px solid rgba(240,122,31,.4); border-radius: 50%; box-shadow: 0 0 80px rgba(240,122,31,.15); }
.pd-floating-card {
  position: absolute;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 18px;
  background: rgba(6,17,31,.90);
  backdrop-filter: blur(16px);
  padding: 16px 18px;
  box-shadow: 0 20px 50px rgba(0,0,0,.3);
}
.pd-floating-card strong { color: var(--pd-orange-2); font-size: 22px; display: block; }
.pd-floating-card span { color: rgba(255,255,255,.72); font-size: 13px; }
.pd-card-1 { top: 90px; left: 14px; }
.pd-card-2 { right: 16px; bottom: 80px; }

.pd-services, .pd-allies, .pd-about, .pd-cta { padding: 94px 0; }
.pd-services { background: var(--pd-soft); color: var(--pd-black); }
.pd-section-heading { max-width: 760px; margin-bottom: 42px; }
.pd-section-heading h2, .pd-allies h2, .pd-about h2, .pd-cta h2 {
  font-family: Manrope, Inter, sans-serif;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.05;
  letter-spacing: -.045em;
  margin: 0 0 16px;
}
.pd-section-heading p, .pd-allies p, .pd-about p, .pd-cta p { color: #5b6573; font-size: 18px; margin: 0; }
.pd-service-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.pd-service-card {
  background: #fff;
  border: 1px solid rgba(7,9,13,.08);
  border-radius: 24px;
  padding: 28px;
  box-shadow: 0 20px 50px rgba(7,9,13,.06);
  transition: transform .22s ease, box-shadow .22s ease;
}
.pd-service-card:hover { transform: translateY(-6px); box-shadow: 0 28px 70px rgba(7,9,13,.1); }
.pd-icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--pd-black), var(--pd-blue));
  color: var(--pd-orange-2);
  font-weight: 900;
  margin-bottom: 20px;
}
.pd-service-card h3 { margin: 0 0 12px; font-size: 21px; letter-spacing: -.02em; }
.pd-service-card p { color: #5b6573; margin: 0; }

.pd-allies { background: #fff; color: var(--pd-black); }
.pd-allies-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 54px; align-items: center; }
.pd-logo-wall { display: grid; gap: 18px; }
.pd-logo-wall img { background: #f8fafc; border: 1px solid rgba(7,9,13,.08); border-radius: 24px; padding: 28px; width: 100%; max-height: 150px; object-fit: contain; }

.pd-about {
  background:
    linear-gradient(rgba(7,9,13,.78), rgba(7,9,13,.86)),
    url('/wp-content/uploads/2018/05/PD-HomeP-03.jpg') center/cover fixed;
}
.pd-about-card {
  max-width: 820px;
  margin: 0 auto;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(18px);
  border-radius: 30px;
  padding: clamp(32px, 6vw, 64px);
  box-shadow: var(--pd-shadow);
}
.pd-link { display: inline-flex; margin-top: 24px; color: var(--pd-orange-2); font-weight: 800; }

.pd-cta { background: linear-gradient(135deg, #0a0d13, #071d38); }
.pd-cta-box {
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 30px;
  padding: clamp(28px, 5vw, 54px);
  display: flex;
  justify-content: space-between;
  gap: 28px;
  align-items: center;
  background: radial-gradient(circle at 80% 10%, rgba(240,122,31,.2), transparent 34%), rgba(255,255,255,.045);
}
.pd-cta p { color: rgba(255,255,255,.7); }

.pd-footer { background: #05070a; padding: 64px 0 40px; border-top: 1px solid rgba(255,255,255,.1); }
.pd-footer-grid { display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: 28px; align-items: start; }
.pd-footer-logo { width: 150px; margin-bottom: 18px; }
.pd-footer h4 { margin: 0 0 12px; color: #fff; }
.pd-footer p, .pd-footer a { display: block; color: rgba(255,255,255,.62); margin: 0 0 10px; }
.pd-footer a:hover { color: var(--pd-orange-2); }

#pollux-cookie-banner { position: fixed; left: 18px; right: 18px; bottom: 18px; z-index: 99999; display: none; background: rgba(10,13,20,.96); color: #e8e8f0; border: 1px solid rgba(255,255,255,.13); border-radius: 18px; padding: 18px; box-shadow: var(--pd-shadow); }
#pollux-cookie-banner.visible { display: block; }
.pollux-cookie-inner { max-width: 1160px; margin: 0 auto; display: flex; align-items: center; gap: 20px; justify-content: space-between; }
.pollux-cookie-text { flex: 1; font-size: 14px; color: rgba(255,255,255,.72); }
.pollux-cookie-text strong { display: block; color: #fff; margin-bottom: 4px; }
.pollux-cookie-text a { color: var(--pd-orange-2); text-decoration: underline; }
.pollux-cookie-actions, .pollux-config-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.pollux-btn { border: 1px solid rgba(255,255,255,.16); border-radius: 999px; padding: 10px 16px; cursor: pointer; color: #fff; background: rgba(255,255,255,.06); font-weight: 700; }
.pollux-btn-accept { background: var(--pd-orange); border-color: var(--pd-orange); color: #140802; }
#pollux-cookie-config { display: none; max-width: 1160px; margin: 16px auto 0; border-top: 1px solid rgba(255,255,255,.12); padding-top: 16px; }
#pollux-cookie-config.visible { display: block; }
.pollux-cookie-category { display: flex; justify-content: space-between; gap: 16px; padding: 12px 0; }
.pollux-cat-info strong { display: block; color: #fff; }
.pollux-cat-info span { color: rgba(255,255,255,.6); font-size: 13px; }
.pollux-toggle { position: relative; width: 44px; height: 24px; display: block; }
.pollux-toggle input { opacity: 0; }
.pollux-toggle-slider { position: absolute; inset: 0; border-radius: 999px; background: #353b48; }
.pollux-toggle-slider::before { content: ""; position: absolute; width: 18px; height: 18px; left: 3px; top: 3px; border-radius: 50%; background: #fff; transition: .2s; }
.pollux-toggle input:checked + .pollux-toggle-slider { background: var(--pd-orange); }
.pollux-toggle input:checked + .pollux-toggle-slider::before { transform: translateX(20px); }
#pollux-cookie-reopen { display: none; position: fixed; left: 16px; bottom: 16px; z-index: 99998; border: 1px solid rgba(255,255,255,.14); background: #111722; color: #fff; border-radius: 999px; padding: 8px 14px; cursor: pointer; }

#pollux-consent-modal { display: none; position: fixed; inset: 0; background: rgba(7,9,13,.78); z-index: 2147483647; align-items: center; justify-content: center; padding: 16px; }
#pollux-consent-modal.show { display: flex; }
#pollux-consent-modal .pcm-box { width: min(560px, 100%); max-height: 90vh; overflow-y: auto; background: #fff; color: #1a1f2b; border-radius: 22px; padding: 28px; box-shadow: var(--pd-shadow); }
#pollux-consent-modal h3 { margin: 0 0 6px; color: var(--pd-black); }
.pcm-sub, .pcm-small { color: #667085; }
.pcm-ia { background: #fff4e8; border-left: 4px solid var(--pd-orange); padding: 12px; border-radius: 10px; margin: 14px 0; }
.pcm-grid { background: #f4f6f8; border-radius: 12px; padding: 14px; margin: 12px 0; }
.pcm-check { display: flex; gap: 10px; margin: 16px 0; }
.pcm-actions { display: flex; justify-content: flex-end; gap: 10px; }
.pcm-actions button { border: 0; border-radius: 999px; padding: 11px 18px; font-weight: 800; cursor: pointer; }
.pcm-reject { background: #eef1f4; color: #3b4250; }
.pcm-accept { background: var(--pd-orange); color: #160900; }
.pcm-accept:disabled { opacity: .45; cursor: not-allowed; }

@media (max-width: 980px) {
  .pd-menu-toggle { display: block; }
  .pd-nav-links {
    position: absolute;
    top: 78px;
    left: 20px;
    right: 20px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    padding: 18px;
    border-radius: 22px;
    background: rgba(7,9,13,.97);
    border: 1px solid rgba(255,255,255,.13);
    box-shadow: var(--pd-shadow);
  }
  .pd-nav-links.is-open { display: flex; }
  .pd-hero { padding: 76px 0 64px; }
  .pd-hero-grid, .pd-allies-grid { grid-template-columns: 1fr; }
  .pd-hero-panel { transform: none; }
  .pd-service-grid { grid-template-columns: repeat(2, 1fr); }
  .pd-footer-grid { grid-template-columns: 1fr 1fr; }
  .pd-cta-box { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 620px) {
  .pd-container, .pd-nav { width: min(100% - 28px, 1160px); }
  .pd-brand img { width: 140px; }
  .pd-hero h1 { font-size: 38px; }
  .pd-trust-row, .pd-service-grid, .pd-footer-grid { grid-template-columns: 1fr; }
  .pd-panel-content { min-height: 340px; padding: 14px; }
  .pd-panel-content img { height: 280px; }
  .pd-floating-card { position: static; margin-top: 12px; }
  .pollux-cookie-inner { flex-direction: column; align-items: flex-start; }
}

.pd-nav-links a.active {
  color: #fff;
  background: rgba(255,255,255,.08);
}

/* =========================================================
   POLLUXDATA v10 - Corrección final de estructura
   - Inicio: header blanco, logo completo.
   - Páginas internas/services-page: header navy translúcido, estrella sola.
   - Footer compacto común.
   - Dropdown oculto correctamente.
   ========================================================= */

/* Dropdown común: oculto en desktop, visible en hover/click */
.pd-nav-dropdown {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  overflow: visible !important;
}

.pd-dropdown-toggle {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  font: inherit !important;
  font-size: 14px !important;
  font-weight: 750 !important;
  letter-spacing: .02em !important;
  color: #09233d !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
}

.pd-header:not(.pd-header--internal) .pd-dropdown-toggle:hover {
  color: var(--pd-orange) !important;
  transform: translateY(-1px);
}

.pd-dropdown-menu {
  position: absolute !important;
  top: calc(100% + 18px) !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(8px) !important;
  min-width: 250px !important;
  display: block !important;
  padding: 14px !important;
  background: rgba(255,255,255,.98) !important;
  border: 1px solid rgba(7,26,45,.10) !important;
  border-top: 3px solid var(--pd-orange) !important;
  border-radius: 0 0 18px 18px !important;
  box-shadow: 0 24px 60px rgba(6,17,31,.18) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transition: .22s ease !important;
  z-index: 100000 !important;
}

.pd-dropdown-menu a {
  display: block !important;
  padding: 13px 16px !important;
  border-radius: 12px !important;
  color: #09233d !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
  transform: none !important;
}

.pd-dropdown-menu a:hover {
  color: var(--pd-orange) !important;
  background: rgba(240,122,31,.10) !important;
}

.pd-nav-dropdown:hover .pd-dropdown-menu,
.pd-nav-dropdown:focus-within .pd-dropdown-menu,
.pd-nav-dropdown.open .pd-dropdown-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateX(-50%) translateY(0) !important;
}

/* Header interno: solo páginas internas, no afecta inicio */
.pd-header.pd-header--internal {
  background: rgba(6,17,31,.94) !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  box-shadow: 0 16px 44px rgba(0,0,0,.18) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

.pd-header.pd-header--internal .pd-brand img,
.pd-header.pd-header--internal .pd-brand--mark img,
.pd-header.pd-header--internal .pd-brand--star img {
  width: 74px !important;
  max-width: 74px !important;
  height: 74px !important;
  max-height: 74px !important;
  object-fit: contain !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  filter: drop-shadow(0 0 18px rgba(240,122,31,.25)) !important;
}

.pd-header.pd-header--internal .pd-nav-links a,
.pd-header.pd-header--internal .pd-dropdown-toggle {
  color: #dbe6f5 !important;
}

.pd-header.pd-header--internal .pd-nav-links a:hover,
.pd-header.pd-header--internal .pd-dropdown-toggle:hover {
  color: #ffffff !important;
}

.pd-header.pd-header--internal .pd-dropdown-toggle.active,
.pd-header.pd-header--internal .pd-nav-links a.active,
.pd-header.pd-header--internal .pd-nav-links a[aria-current="page"] {
  color: #ffffff !important;
  background: rgba(255,255,255,.09) !important;
  padding: 13px 18px !important;
  border-radius: 999px !important;
  transform: none !important;
}

.pd-header.pd-header--internal .pd-nav-cta {
  color: #ffffff !important;
  border-color: rgba(240,122,31,.46) !important;
  background: rgba(240,122,31,.06) !important;
}

.pd-header.pd-header--internal .pd-dropdown-menu {
  background: rgba(6,17,31,.97) !important;
  border-color: rgba(255,255,255,.12) !important;
  border-top-color: var(--pd-orange) !important;
  box-shadow: 0 26px 70px rgba(0,0,0,.32) !important;
}

.pd-header.pd-header--internal .pd-dropdown-menu a {
  color: #dbe6f5 !important;
}

.pd-header.pd-header--internal .pd-dropdown-menu a:hover {
  color: #ffffff !important;
  background: rgba(240,122,31,.14) !important;
}

.pd-header.pd-header--internal .pd-menu-toggle span {
  background: #ffffff !important;
}

/* Footer común más delgado/compacto */
.pd-footer {
  background: #02070d !important;
  color: #b8c5d8 !important;
  padding: 48px 0 34px !important;
  border-top: 1px solid rgba(255,255,255,.08) !important;
}

.pd-footer-grid {
  display: grid !important;
  grid-template-columns: 1.25fr 1fr 1fr .8fr 1fr !important;
  gap: 34px !important;
  align-items: start !important;
  text-align: left !important;
}

.pd-footer-logo {
  width: 145px !important;
  height: auto !important;
  margin: 0 0 20px !important;
}

.pd-footer h4 {
  margin: 0 0 12px !important;
  color: #ffffff !important;
  font-size: .98rem !important;
  font-weight: 900 !important;
}

.pd-footer p,
.pd-footer a {
  display: block !important;
  color: rgba(255,255,255,.68) !important;
  margin: 0 0 8px !important;
  font-size: .95rem !important;
  line-height: 1.55 !important;
}

.pd-footer a:hover {
  color: var(--pd-orange-2) !important;
}

/* Servicios: estilos aislados para no dañar Inicio */
.services-page .pd-section {
  padding: 96px 0;
  position: relative;
}
.services-page .pd-section.white { background: #ffffff; color: #06111f; }
.services-page .pd-section.soft { background: var(--pd-soft); color: #06111f; }
.services-page .pd-section.dark {
  color: #fff;
  background:
    radial-gradient(circle at 88% 12%, rgba(240,122,31,.16), transparent 32%),
    linear-gradient(135deg, #06111f, #071a2d 58%, #0b2f55);
  overflow: hidden;
}
.services-page .pd-section.dark::before,
.services-page .pd-services-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 44px 44px;
  opacity: .55;
  pointer-events: none;
}
.services-page .pd-services-hero {
  position: relative;
  min-height: calc(100vh - 78px);
  display: grid;
  place-items: center;
  padding: 100px 0 88px;
  color: #fff;
  background:
    radial-gradient(circle at 82% 24%, rgba(240,122,31,.18), transparent 34%),
    linear-gradient(135deg, rgba(6,17,31,.98), rgba(8,33,61,.92));
  overflow: hidden;
}
.services-page .pd-hero-inner {
  position: relative;
  z-index: 2;
  width: min(1160px, calc(100% - 40px));
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 58px;
  align-items: center;
}
.services-page .pd-services-hero h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(4rem, 8.3vw, 8rem);
  line-height: .9;
  letter-spacing: -.075em;
  font-weight: 950;
}
.services-page .pd-services-hero h1 span { color: #ffc08f; }
.services-page .pd-services-hero p {
  max-width: 720px;
  margin: 30px 0 0;
  color: #c8d4e6;
  font-size: clamp(1rem, 1.5vw, 1.18rem);
  line-height: 1.8;
}
.services-page .pd-actions { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 34px; }
.services-page .pd-btn.primary { color: #120802; background: linear-gradient(135deg, var(--pd-orange-2), var(--pd-orange)); box-shadow: 0 18px 46px rgba(240,122,31,.26); }
.services-page .pd-btn.secondary { color: #fff; border: 1px solid rgba(255,255,255,.15); background: rgba(255,255,255,.06); }
.services-page .pd-visual { position: relative; min-height: 510px; }
.services-page .pd-window {
  position: absolute;
  inset: 38px 0 auto auto;
  width: min(660px, 100%);
  height: 420px;
  border-radius: 28px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: 0 36px 110px rgba(0,0,0,.35);
  overflow: hidden;
  backdrop-filter: blur(12px);
}
.services-page .pd-window-top { height: 58px; background: rgba(255,255,255,.08); border-bottom: 1px solid rgba(255,255,255,.12); display: flex; align-items: center; gap: 10px; padding: 0 22px; }
.services-page .pd-dot { width: 14px; height: 14px; border-radius: 50%; }
.services-page .pd-dot:nth-child(1) { background: var(--pd-orange); }
.services-page .pd-dot:nth-child(2) { background: #ffd166; }
.services-page .pd-dot:nth-child(3) { background: #4fd18b; }
.services-page .pd-window-body { padding: 34px; display: grid; gap: 18px; }
.services-page .pd-line { height: 16px; border-radius: 999px; background: rgba(255,255,255,.17); overflow: hidden; }
.services-page .pd-line::after { content: ""; display: block; height: 100%; width: var(--w, 70%); border-radius: inherit; background: linear-gradient(90deg, rgba(240,122,31,.95), rgba(255,155,61,.55)); animation: servicePulseLine 4.4s ease-in-out infinite; }
.services-page .pd-line.muted::after { background: rgba(255,255,255,.28); }
.services-page .pd-line:nth-child(1) { --w: 90%; }
.services-page .pd-line:nth-child(2) { --w: 72%; }
.services-page .pd-line:nth-child(3) { --w: 84%; }
.services-page .pd-line:nth-child(4) { --w: 58%; }
.services-page .pd-line:nth-child(5) { --w: 82%; }
.services-page .pd-line:nth-child(6) { --w: 70%; }
@keyframes servicePulseLine { 0%,100% { opacity:.75; transform:scaleX(.97); transform-origin:left; } 50% { opacity:1; transform:scaleX(1); } }
.services-page .pd-floating-card {
  position: absolute;
  left: 28px;
  bottom: 56px;
  width: min(420px, calc(100% - 40px));
  padding: 28px;
  border-radius: 26px;
  background: rgba(6,17,31,.94);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 30px 80px rgba(0,0,0,.32);
  color: #fff;
  animation: serviceFloatCard 5s ease-in-out infinite;
}
@keyframes serviceFloatCard { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-12px); } }
.services-page .pd-floating-card small { display:block; color:var(--pd-orange); text-transform:uppercase; letter-spacing:.24em; font-weight:900; margin-bottom:14px; }
.services-page .pd-floating-card strong { display:block; font-size:1.35rem; margin-bottom:12px; color:#fff; }
.services-page .pd-floating-card p { margin:0; color:#b8c5d8; font-size:.98rem; line-height:1.65; }
.services-page .pd-grid { display: grid; gap: 24px; }
.services-page .pd-grid.cols-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.services-page .pd-grid.cols-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.services-page .pd-card {
  background: #fff;
  border: 1px solid rgba(7,26,45,.09);
  border-radius: 28px;
  padding: clamp(26px, 3vw, 38px);
  box-shadow: 0 20px 70px rgba(7,26,45,.08);
}
.services-page .pd-card.dark { color: #fff; background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); }
.services-page .pd-card h3 { margin: 0 0 12px; font-size: 1.55rem; line-height: 1.15; color: #06111f; }
.services-page .pd-card.dark h3 { color: #fff; }
.services-page .pd-card p, .services-page .pd-card li { color: #5e6f86; line-height: 1.7; }
.services-page .pd-card.dark p, .services-page .pd-card.dark li { color: #c8d4e6; }
.services-page .pd-card ul { margin: 18px 0 0; padding-left: 20px; }
.services-page .pd-card li::marker { color: var(--pd-orange); }
.services-page .pd-section-title { max-width: 850px; margin-bottom: 52px; }
.services-page .pd-section-title.center { text-align: center; margin-left: auto; margin-right: auto; }
.services-page .pd-section-title h2 { margin: 0; font-size: clamp(2.4rem, 4.4vw, 5rem); line-height: .96; letter-spacing: -.06em; font-weight: 950; color: #06111f; }
.services-page .pd-section.dark .pd-section-title h2 { color: #fff; }
.services-page .pd-section-title p { margin: 18px 0 0; color: #5e6f86; font-size: 1.08rem; line-height: 1.8; }
.services-page .pd-section.dark .pd-section-title p { color: #c8d4e6; }
.services-page .pd-feature { display: grid; grid-template-columns: .9fr 1.1fr; gap: 48px; align-items: center; }
.services-page .pd-logo-card img { width: min(420px, 100%); margin: 0 auto 24px; padding: 26px; border-radius: 22px; background: rgba(255,255,255,.08); }
.services-page .pd-media-card { overflow: hidden; padding: 0; }
.services-page .pd-media-card > img { width: 100%; height: 190px; object-fit: contain; padding: 28px; background: #f7f8fb; border-bottom: 1px solid rgba(7,26,45,.08); }
.services-page .pd-media-card .pd-card-body { padding: 30px; }
.services-page .pd-visual-pills { display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }
.services-page .pd-pill { display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px; border:1px solid rgba(7,26,45,.10); background:#fff; font-weight:800; color:#102033; }
.services-page .pd-pill::before { content:""; width:7px; height:7px; border-radius:50%; background:var(--pd-orange); }
.services-page .pd-section.dark .pd-pill { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.12); color:#fff; }

/* Contacto final de páginas internas */
.services-page .pd-contact-final,
.pd-internal-page .pd-contact-final {
  background:#f1f0eb;
  color:#06111f;
  padding:88px 0;
  overflow:hidden;
}
.services-page .pd-contact-final::before,
.pd-internal-page .pd-contact-final::before {
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 12% 20%, rgba(240,122,31,.10), transparent 30%), radial-gradient(circle at 85% 18%, rgba(11,47,85,.09), transparent 34%);
  pointer-events:none;
}
.services-page .pd-contact-final-grid,
.pd-internal-page .pd-contact-final-grid { position:relative; z-index:2; display:grid; grid-template-columns:.95fr 1.05fr; gap:34px; align-items:stretch; }
.services-page .pd-contact-info-card,
.services-page .pd-chat-info-card,
.pd-internal-page .pd-contact-info-card,
.pd-internal-page .pd-chat-info-card { border-radius:32px; padding:clamp(30px, 4vw, 54px); box-shadow:0 28px 90px rgba(7,26,45,.10); }
.services-page .pd-contact-info-card,
.pd-internal-page .pd-contact-info-card { background:rgba(255,255,255,.86); border:1px solid rgba(7,26,45,.08); }
.services-page .pd-chat-info-card,
.pd-internal-page .pd-chat-info-card { background:radial-gradient(circle at 86% 18%, rgba(240,122,31,.18), transparent 32%), linear-gradient(135deg, #020812, #06111f 58%, #071a2d); color:#fff; border:1px solid rgba(255,255,255,.10); box-shadow:0 34px 110px rgba(0,0,0,.26); }
.services-page .pd-contact-info-card h2,
.services-page .pd-chat-info-card h2,
.pd-internal-page .pd-contact-info-card h2,
.pd-internal-page .pd-chat-info-card h2 { margin:0 0 20px; font-size:clamp(2.25rem,4.2vw,4.55rem); line-height:.96; letter-spacing:-.055em; font-weight:950; }
.services-page .pd-contact-info-card p,
.pd-internal-page .pd-contact-info-card p { color:#5b687c; line-height:1.75; margin:0 0 30px; }
.services-page .pd-contact-list-final,
.pd-internal-page .pd-contact-list-final { display:grid; gap:14px; margin-top:24px; }
.services-page .pd-contact-row,
.pd-internal-page .pd-contact-row { display:grid; gap:4px; padding:16px 18px; border-radius:18px; background:#fff; border:1px solid rgba(7,26,45,.08); }
.services-page .pd-contact-row span,
.pd-internal-page .pd-contact-row span { color:var(--pd-orange); font-size:.78rem; font-weight:950; text-transform:uppercase; letter-spacing:.12em; }
.services-page .pd-contact-row strong,
.pd-internal-page .pd-contact-row strong { color:#06111f; font-size:1.02rem; line-height:1.55; }
.services-page .pd-chat-icon-final,
.pd-internal-page .pd-chat-icon-final { width:78px; height:78px; border-radius:22px; background:linear-gradient(135deg,#d94a38,#f07a1f); margin-bottom:30px; position:relative; box-shadow:0 18px 42px rgba(240,122,31,.24); }
.services-page .pd-chat-icon-final::before,
.pd-internal-page .pd-chat-icon-final::before { content:""; position:absolute; left:25px; top:27px; width:28px; height:20px; border:3px solid #fff; border-radius:4px; transform:skewX(-8deg); }
.services-page .pd-chat-info-card p,
.pd-internal-page .pd-chat-info-card p { color:#d6e0ef; line-height:1.8; font-size:1.04rem; max-width:760px; margin-bottom:28px; }
.services-page .pd-chat-steps-final,
.pd-internal-page .pd-chat-steps-final { list-style:none; padding:0; margin:24px 0 28px; display:grid; gap:14px; }
.services-page .pd-chat-steps-final li,
.pd-internal-page .pd-chat-steps-final li { display:grid; grid-template-columns:42px 1fr; align-items:center; gap:14px; color:#f4f8ff; font-weight:850; line-height:1.45; }
.services-page .pd-chat-steps-final li span,
.pd-internal-page .pd-chat-steps-final li span { width:42px; height:42px; border-radius:50%; display:grid; place-items:center; background:linear-gradient(135deg,#d94a38,#f07a1f); color:#fff; font-weight:950; font-size:.9rem; }
.services-page .pd-chat-status-final,
.pd-internal-page .pd-chat-status-final { display:inline-flex; align-items:center; gap:10px; color:#cdd8e8; font-weight:750; }
.services-page .pd-chat-status-final span,
.pd-internal-page .pd-chat-status-final span { width:12px; height:12px; border-radius:50%; background:#31d887; box-shadow:0 0 0 8px rgba(49,216,135,.10); }

/* Botón chat uniforme */
.chat-window-toggle,
[class*="chat-window-toggle"] {
  width: 68px !important;
  height: 68px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--pd-orange), var(--pd-orange-2)) !important;
  box-shadow: 0 22px 54px rgba(240,122,31,.34) !important;
}

/* Responsive */
@media (max-width: 1100px) {
  .pd-footer-grid { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
  .services-page .pd-grid.cols-3 { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .services-page .pd-feature,
  .services-page .pd-hero-inner,
  .services-page .pd-contact-final-grid { grid-template-columns: 1fr; }
  .services-page .pd-visual { min-height: 430px; }
  .services-page .pd-window { position: relative; inset: auto; width: 100%; }
  .services-page .pd-floating-card { right: 24px; bottom: 24px; }
}

@media (max-width: 760px) {
  .pd-menu-toggle { display: block; }
  .pd-nav-links {
    position: absolute !important;
    top: 78px !important;
    left: 20px !important;
    right: 20px !important;
    display: none !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
    padding: 18px !important;
    border-radius: 0 0 22px 22px !important;
    background: rgba(6,17,31,.98) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    box-shadow: 0 26px 70px rgba(0,0,0,.32) !important;
  }
  .pd-nav-links.open,
  .pd-nav-links.is-open { display: flex !important; }
  .pd-nav-links > a,
  .pd-dropdown-toggle { color: #fff !important; padding: 15px 12px !important; }
  .pd-dropdown-menu {
    position: static !important;
    transform: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    min-width: 0 !important;
    box-shadow: none !important;
    border: 0 !important;
    border-left: 3px solid var(--pd-orange) !important;
    border-radius: 0 !important;
    padding: 8px 0 8px 14px !important;
    background: transparent !important;
  }
  .pd-dropdown-menu a { color: #dbe6f5 !important; }
  .services-page .pd-services-hero { padding: 72px 0; }
  .services-page .pd-services-hero h1 { font-size: clamp(3rem, 14vw, 4.2rem); }
  .services-page .pd-grid.cols-2,
  .services-page .pd-grid.cols-3 { grid-template-columns: 1fr; }
  .pd-footer-grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .pd-footer { padding: 42px 0 30px !important; }
  .services-page .pd-contact-info-card,
  .services-page .pd-chat-info-card { padding: 28px 22px; border-radius: 24px; }
}


/* === PATCH SERVICIOS V11: contacto más sobrio + chat correcto + footer delgado === */

/* 1) Botón flotante de chat: posición correcta y símbolo visible */
.chat-window-toggle,
button.chat-window-toggle,
[class*="chat-window-toggle"] {
  position: fixed !important;
  right: 34px !important;
  bottom: 34px !important;
  left: auto !important;
  top: auto !important;
  z-index: 99998 !important;

  width: 68px !important;
  height: 68px !important;
  min-width: 68px !important;
  min-height: 68px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  border: 0 !important;
  border-radius: 50% !important;
  cursor: pointer !important;

  background: linear-gradient(135deg, var(--pd-orange), var(--pd-orange-2)) !important;
  box-shadow: 0 22px 54px rgba(240,122,31,.34) !important;
  overflow: visible !important;
}

.chat-window-toggle::before,
button.chat-window-toggle::before,
[class*="chat-window-toggle"]::before {
  content: "" !important;
  display: block !important;
  width: 30px !important;
  height: 22px !important;
  background: #06111f !important;
  border-radius: 14px 14px 14px 4px !important;
  transform: translateY(2px) !important;
}

.chat-window-toggle::after,
button.chat-window-toggle::after,
[class*="chat-window-toggle"]::after {
  content: "" !important;
  position: absolute !important;
  width: 10px !important;
  height: 10px !important;
  right: 22px !important;
  bottom: 22px !important;
  background: #06111f !important;
  clip-path: polygon(0 0, 100% 0, 0 100%) !important;
  transform: rotate(6deg) !important;
}

/* Evita que el widget externo pinte medio círculo o desplace el botón */
.chat-window-toggle > *,
button.chat-window-toggle > * {
  display: none !important;
}

/* 2) Sección contacto de Servicios: menos grande, más elegante y sin espacios raros */
.services-page .pd-contact-final,
.pd-internal-page .pd-contact-final {
  padding: 72px 0 76px !important;
  background:
    radial-gradient(circle at 15% 16%, rgba(240,122,31,.07), transparent 30%),
    radial-gradient(circle at 85% 12%, rgba(11,47,85,.08), transparent 34%),
    #f1f0eb !important;
}

.services-page .pd-contact-final-grid,
.pd-internal-page .pd-contact-final-grid {
  width: min(1180px, calc(100% - 42px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr) !important;
  gap: 26px !important;
  align-items: stretch !important;
}

.services-page .pd-contact-info-card,
.services-page .pd-chat-info-card,
.pd-internal-page .pd-contact-info-card,
.pd-internal-page .pd-chat-info-card {
  border-radius: 28px !important;
  padding: clamp(28px, 3.2vw, 42px) !important;
  box-shadow: 0 26px 70px rgba(7,26,45,.10) !important;
}

.services-page .pd-contact-info-card,
.pd-internal-page .pd-contact-info-card {
  background: rgba(255,255,255,.88) !important;
  border: 1px solid rgba(7,26,45,.08) !important;
}

.services-page .pd-chat-info-card,
.pd-internal-page .pd-chat-info-card {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  background:
    radial-gradient(circle at 92% 8%, rgba(240,122,31,.16), transparent 32%),
    linear-gradient(135deg, #02070d 0%, #06111f 58%, #071a2d 100%) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  color: #fff !important;
}

.services-page .pd-contact-info-card h2,
.services-page .pd-chat-info-card h2,
.pd-internal-page .pd-contact-info-card h2,
.pd-internal-page .pd-chat-info-card h2 {
  margin: 0 0 18px !important;
  font-size: clamp(2rem, 3.15vw, 3.45rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -.045em !important;
  font-weight: 950 !important;
}

.services-page .pd-contact-info-card p,
.pd-internal-page .pd-contact-info-card p {
  max-width: 620px !important;
  margin: 0 0 24px !important;
  color: #5b687c !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
}

.services-page .pd-contact-list-final,
.pd-internal-page .pd-contact-list-final {
  display: grid !important;
  gap: 10px !important;
  margin-top: 18px !important;
}

.services-page .pd-contact-row,
.pd-internal-page .pd-contact-row {
  padding: 13px 16px !important;
  border-radius: 16px !important;
  background: #ffffff !important;
  border: 1px solid rgba(7,26,45,.08) !important;
}

.services-page .pd-contact-row span,
.pd-internal-page .pd-contact-row span {
  display: block !important;
  margin-bottom: 4px !important;
  color: var(--pd-orange) !important;
  font-size: .72rem !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
  letter-spacing: .14em !important;
}

.services-page .pd-contact-row strong,
.pd-internal-page .pd-contact-row strong {
  display: block !important;
  color: var(--pd-black) !important;
  font-size: .98rem !important;
  line-height: 1.45 !important;
}

.services-page .pd-chat-icon-final,
.pd-internal-page .pd-chat-icon-final {
  width: 58px !important;
  height: 58px !important;
  border-radius: 18px !important;
  margin-bottom: 24px !important;
  background: linear-gradient(135deg, #d94a38, #f47b20) !important;
  position: relative !important;
  box-shadow: 0 18px 42px rgba(240,122,31,.22) !important;
}

.services-page .pd-chat-icon-final::before,
.pd-internal-page .pd-chat-icon-final::before {
  content: "" !important;
  position: absolute !important;
  left: 18px !important;
  top: 20px !important;
  width: 22px !important;
  height: 16px !important;
  border: 2px solid #fff !important;
  border-radius: 3px !important;
  transform: skewX(-8deg) !important;
}

.services-page .pd-chat-info-card p,
.pd-internal-page .pd-chat-info-card p {
  max-width: 760px !important;
  margin: 0 0 24px !important;
  color: #d6e0ef !important;
  font-size: 1rem !important;
  line-height: 1.68 !important;
}

.services-page .pd-chat-steps-final,
.pd-internal-page .pd-chat-steps-final {
  list-style: none !important;
  padding: 0 !important;
  margin: 18px 0 22px !important;
  display: grid !important;
  gap: 10px !important;
}

.services-page .pd-chat-steps-final li,
.pd-internal-page .pd-chat-steps-final li {
  display: grid !important;
  grid-template-columns: 34px 1fr !important;
  align-items: center !important;
  gap: 12px !important;
  color: #f4f8ff !important;
  font-weight: 850 !important;
  font-size: .96rem !important;
  line-height: 1.42 !important;
}

.services-page .pd-chat-steps-final li span,
.pd-internal-page .pd-chat-steps-final li span {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  display: grid !important;
  place-items: center !important;
  background: linear-gradient(135deg, #d94a38, #f47b20) !important;
  color: #ffffff !important;
  font-weight: 950 !important;
  font-size: .82rem !important;
}

.services-page .pd-chat-status-final,
.pd-internal-page .pd-chat-status-final {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  color: #cdd8e8 !important;
  font-weight: 750 !important;
  font-size: .96rem !important;
}

.services-page .pd-chat-status-final span,
.pd-internal-page .pd-chat-status-final span {
  width: 11px !important;
  height: 11px !important;
  border-radius: 50% !important;
  background: #31d887 !important;
  box-shadow: 0 0 0 8px rgba(49,216,135,.10) !important;
}

/* 3) Footer más compacto, sin dejar un bloque excesivamente alto */
.pd-footer {
  padding: 46px 0 34px !important;
}

.pd-footer-grid {
  gap: 24px !important;
}

.pd-footer-logo {
  width: 138px !important;
  margin-bottom: 16px !important;
}

.pd-footer p,
.pd-footer a {
  margin-bottom: 8px !important;
  line-height: 1.5 !important;
}

@media (max-width: 920px) {
  .services-page .pd-contact-final-grid,
  .pd-internal-page .pd-contact-final-grid {
    grid-template-columns: 1fr !important;
  }

  .services-page .pd-contact-final,
  .pd-internal-page .pd-contact-final {
    padding: 58px 0 64px !important;
  }
}

@media (max-width: 640px) {
  .chat-window-toggle,
  button.chat-window-toggle,
  [class*="chat-window-toggle"] {
    right: 20px !important;
    bottom: 22px !important;
    width: 60px !important;
    height: 60px !important;
    min-width: 60px !important;
    min-height: 60px !important;
  }

  .services-page .pd-contact-info-card h2,
  .services-page .pd-chat-info-card h2,
  .pd-internal-page .pd-contact-info-card h2,
  .pd-internal-page .pd-chat-info-card h2 {
    font-size: 2rem !important;
  }
}

/* === END PATCH SERVICIOS V11 === */


/* === PATCH SERVICIOS V13: conservar contacto anterior + chat correcto === */

/* Mantiene el bloque de contacto anterior, pero controla que no se desborde */
.services-page .pd-contact-final .pd-contact-info-card h2,
.services-page .pd-contact-final .pd-chat-info-card h2 {
  max-width: 760px !important;
}

.services-page .pd-contact-final .pd-chat-info-card {
  overflow: hidden !important;
}

/* Botón flotante de chat con símbolo visible */
.chat-window-toggle,
button.chat-window-toggle,
[class*="chat-window-toggle"] {
  position: fixed !important;
  right: 34px !important;
  bottom: 34px !important;
  left: auto !important;
  top: auto !important;
  z-index: 99998 !important;
  width: 68px !important;
  height: 68px !important;
  min-width: 68px !important;
  min-height: 68px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 0 !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  background: linear-gradient(135deg, var(--pd-orange), var(--pd-orange-2)) !important;
  box-shadow: 0 22px 54px rgba(240,122,31,.34) !important;
  overflow: visible !important;
}

.chat-window-toggle::before,
button.chat-window-toggle::before,
[class*="chat-window-toggle"]::before {
  content: "" !important;
  display: block !important;
  width: 30px !important;
  height: 22px !important;
  background: #06111f !important;
  border-radius: 14px 14px 14px 4px !important;
  transform: translateY(2px) !important;
}

.chat-window-toggle::after,
button.chat-window-toggle::after,
[class*="chat-window-toggle"]::after {
  content: "" !important;
  position: absolute !important;
  width: 10px !important;
  height: 10px !important;
  right: 22px !important;
  bottom: 22px !important;
  background: #06111f !important;
  clip-path: polygon(0 0, 100% 0, 0 100%) !important;
  transform: rotate(6deg) !important;
}

.chat-window-toggle > *,
button.chat-window-toggle > * {
  display: none !important;
}

/* Footer delgado */
.pd-footer {
  padding-top: 38px !important;
  padding-bottom: 28px !important;
}

/* === END PATCH SERVICIOS V13 === */


/* === PATCH SERVICIOS V14: contacto igual al ejemplo Oracle === */

.services-page .pd-contact-final .pd-contact-final-grid {
  align-items: stretch !important;
}

.services-page .pd-contact-final .pd-contact-info-card {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

.services-page .pd-contact-final .pd-contact-info-card h2 {
  font-size: clamp(3rem, 5.2vw, 5.9rem) !important;
  line-height: .95 !important;
  letter-spacing: -.06em !important;
  margin-bottom: 24px !important;
  color: #242424 !important;
}

.services-page .pd-contact-final .pd-contact-info-card p {
  font-size: 1.08rem !important;
  line-height: 1.75 !important;
  color: #5d6674 !important;
  max-width: 720px !important;
  margin-bottom: 34px !important;
}

.services-page .pd-contact-list-oracle {
  display: grid !important;
  gap: 16px !important;
  margin-top: 10px !important;
}

.services-page .pd-contact-item-oracle {
  display: grid !important;
  grid-template-columns: 52px 1fr !important;
  align-items: center !important;
  gap: 16px !important;
}

.services-page .pd-contact-item-icon {
  width: 52px !important;
  height: 52px !important;
  border-radius: 12px !important;
  display: grid !important;
  place-items: center !important;
  background: #ffffff !important;
  border: 1px solid rgba(7,26,45,.08) !important;
  color: #e24d3e !important;
  font-weight: 950 !important;
  box-shadow: 0 14px 36px rgba(7,26,45,.06) !important;
}

.services-page .pd-contact-item-oracle strong {
  color: #06111f !important;
  font-weight: 950 !important;
  font-size: 1.08rem !important;
  line-height: 1.35 !important;
}

.services-page .pd-contact-final .pd-chat-info-card h2 {
  font-size: clamp(2.4rem, 4vw, 4.35rem) !important;
  line-height: 1.03 !important;
  letter-spacing: -.05em !important;
}

@media (max-width: 920px) {
  .services-page .pd-contact-final .pd-contact-info-card h2 {
    font-size: clamp(2.4rem, 10vw, 4rem) !important;
  }
}

/* === END PATCH SERVICIOS V14 === */


/* === PATCH SERVICIOS V15: tarjetas de contacto más bajas + limpieza visual === */

/* Contacto más compacto, sin cambiar el texto */
.services-page .pd-contact-final {
  padding: 46px 0 50px !important;
}

.services-page .pd-contact-final .pd-contact-final-grid {
  grid-template-columns: minmax(0, .92fr) minmax(0, 1fr) !important;
  gap: 22px !important;
  align-items: stretch !important;
}

.services-page .pd-contact-final .pd-contact-info-card,
.services-page .pd-contact-final .pd-chat-info-card {
  min-height: 0 !important;
  padding: clamp(22px, 2.4vw, 34px) !important;
  border-radius: 24px !important;
}

.services-page .pd-contact-final .pd-contact-info-card h2 {
  font-size: clamp(2.2rem, 3.7vw, 4.4rem) !important;
  line-height: .96 !important;
  margin-bottom: 16px !important;
}

.services-page .pd-contact-final .pd-chat-info-card h2 {
  font-size: clamp(2rem, 3.25vw, 3.9rem) !important;
  line-height: 1.02 !important;
  margin-bottom: 16px !important;
}

.services-page .pd-contact-final .pd-contact-info-card p,
.services-page .pd-contact-final .pd-chat-info-card p {
  font-size: .98rem !important;
  line-height: 1.55 !important;
  margin-bottom: 20px !important;
}

.services-page .pd-contact-list-oracle {
  gap: 11px !important;
  margin-top: 4px !important;
}

.services-page .pd-contact-item-oracle {
  grid-template-columns: 44px 1fr !important;
  gap: 12px !important;
}

.services-page .pd-contact-item-icon {
  width: 44px !important;
  height: 44px !important;
  border-radius: 11px !important;
}

.services-page .pd-contact-item-oracle strong {
  font-size: 1rem !important;
}

.services-page .pd-chat-icon-final {
  width: 54px !important;
  height: 54px !important;
  border-radius: 17px !important;
  margin-bottom: 18px !important;
}

.services-page .pd-chat-steps-final {
  gap: 10px !important;
  margin: 18px 0 16px !important;
}

.services-page .pd-chat-steps-final li {
  grid-template-columns: 34px 1fr !important;
  gap: 12px !important;
  font-size: .94rem !important;
  line-height: 1.35 !important;
}

.services-page .pd-chat-steps-final li span {
  width: 34px !important;
  height: 34px !important;
  font-size: .82rem !important;
}

.services-page .pd-chat-status-final {
  font-size: .94rem !important;
}

/* Oculta posibles restos de imágenes/tarjetas eliminadas si quedan por caché de estilos */
.services-page img[alt*="Quest"],
.services-page img[alt*="Mongo"],
.services-page img[alt*="Hadoop"],
.services-page img[alt*="Spark"],
.services-page img[alt*="Cloud Computing"] {
  display: none !important;
}

/* Footer delgado */
.pd-footer {
  padding-top: 34px !important;
  padding-bottom: 24px !important;
}

/* === END PATCH SERVICIOS V15 === */


/* === PATCH SERVICIOS V16: header sin burbuja + Oracle Stack estético === */

/* Evita desbordes horizontales que cortan títulos o tarjetas */
html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

/* HEADER INTERNO: estrella sola, sin cuadro blanco/burbuja */
.services-page .pd-header--internal,
.pd-internal .pd-header--internal,
.pd-internal-page .pd-header--internal {
  background: rgba(6, 17, 31, .94) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  box-shadow: 0 16px 42px rgba(2,7,13,.22) !important;
}

.services-page .pd-header--internal .pd-nav,
.pd-internal .pd-header--internal .pd-nav,
.pd-internal-page .pd-header--internal .pd-nav {
  min-height: 78px !important;
  width: min(1160px, calc(100% - 40px)) !important;
}

.services-page .pd-header--internal .pd-brand,
.services-page .pd-header--internal .pd-brand--mark,
.pd-internal .pd-header--internal .pd-brand,
.pd-internal .pd-header--internal .pd-brand--mark,
.pd-internal-page .pd-header--internal .pd-brand,
.pd-internal-page .pd-header--internal .pd-brand--mark {
  width: 74px !important;
  height: 74px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.services-page .pd-header--internal .pd-brand img,
.services-page .pd-header--internal .pd-brand--mark img,
.pd-internal .pd-header--internal .pd-brand img,
.pd-internal .pd-header--internal .pd-brand--mark img,
.pd-internal-page .pd-header--internal .pd-brand img,
.pd-internal-page .pd-header--internal .pd-brand--mark img {
  display: block !important;
  width: 72px !important;
  height: 72px !important;
  max-width: 72px !important;
  max-height: 72px !important;
  object-fit: contain !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  filter: drop-shadow(0 0 18px rgba(240,122,31,.22)) !important;
}

/* Si alguna regla anterior dibujaba una burbuja o fondo sobre el logo */
.services-page .pd-header--internal .pd-brand::before,
.services-page .pd-header--internal .pd-brand::after,
.services-page .pd-header--internal .pd-brand--mark::before,
.services-page .pd-header--internal .pd-brand--mark::after {
  content: none !important;
  display: none !important;
}

/* Sección Oracle Stack: más equilibrada, sin texto cortado */
.services-page .pd-section.dark {
  position: relative !important;
  overflow: hidden !important;
  padding: clamp(64px, 7vw, 104px) 0 !important;
  background:
    radial-gradient(circle at 78% 22%, rgba(240,122,31,.12), transparent 32%),
    linear-gradient(135deg, #06111f 0%, #08213d 62%, #071a2d 100%) !important;
}

.services-page .pd-section.dark::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px) !important;
  background-size: 44px 44px !important;
  pointer-events: none !important;
  opacity: .55 !important;
}

.services-page .pd-section.dark .pd-wrap {
  position: relative !important;
  z-index: 2 !important;
  width: min(1180px, calc(100% - 44px)) !important;
  margin: 0 auto !important;
}

.services-page .pd-section.dark .pd-feature {
  display: grid !important;
  grid-template-columns: minmax(300px, .78fr) minmax(430px, 1.22fr) !important;
  gap: clamp(28px, 5vw, 62px) !important;
  align-items: center !important;
}

.services-page .pd-section.dark .pd-section-title {
  max-width: 430px !important;
  margin: 0 !important;
}

.services-page .pd-section.dark .pd-section-title h2 {
  font-size: clamp(2.35rem, 4.2vw, 4.9rem) !important;
  line-height: .92 !important;
  letter-spacing: -.055em !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

.services-page .pd-section.dark .pd-section-title p {
  max-width: 410px !important;
  font-size: 1rem !important;
  line-height: 1.7 !important;
  color: #c9d7e8 !important;
}

/* Tarjeta Oracle más limpia y compacta */
.services-page .pd-section.dark .pd-logo-card {
  width: 100% !important;
  max-width: 690px !important;
  justify-self: end !important;
  padding: clamp(26px, 3.2vw, 44px) !important;
  border-radius: 30px !important;
  background:
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.035)) !important;
  border: 1px solid rgba(255,255,255,.13) !important;
  box-shadow: 0 28px 80px rgba(0,0,0,.24) !important;
}

.services-page .pd-section.dark .pd-logo-card img {
  display: block !important;
  width: min(360px, 78%) !important;
  height: auto !important;
  margin: 0 auto 26px !important;
  padding: 22px 32px !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.075) !important;
  box-shadow: none !important;
}

.services-page .pd-section.dark .pd-logo-card ul {
  width: min(480px, 100%) !important;
  margin: 0 auto 28px !important;
  padding-left: 22px !important;
}

.services-page .pd-section.dark .pd-logo-card li {
  font-size: 1rem !important;
  line-height: 1.55 !important;
  margin: 8px 0 !important;
  color: #d8e4f2 !important;
}

.services-page .pd-section.dark .pd-logo-card .pd-actions {
  width: min(480px, 100%) !important;
  margin: 0 auto !important;
}

/* Hero de Servicios: evita que el texto principal se corte en pantallas medianas */
.services-page .pd-services-hero h1 {
  font-size: clamp(3.6rem, 7.1vw, 7.1rem) !important;
  max-width: 780px !important;
}

/* Responsive */
@media (max-width: 980px) {
  .services-page .pd-section.dark .pd-feature {
    grid-template-columns: 1fr !important;
  }

  .services-page .pd-section.dark .pd-section-title {
    max-width: 760px !important;
  }

  .services-page .pd-section.dark .pd-section-title p {
    max-width: 680px !important;
  }

  .services-page .pd-section.dark .pd-logo-card {
    justify-self: stretch !important;
    max-width: none !important;
  }
}

@media (max-width: 640px) {
  .services-page .pd-header--internal .pd-brand,
  .services-page .pd-header--internal .pd-brand--mark {
    width: 58px !important;
    height: 58px !important;
  }

  .services-page .pd-header--internal .pd-brand img,
  .services-page .pd-header--internal .pd-brand--mark img {
    width: 58px !important;
    height: 58px !important;
  }

  .services-page .pd-section.dark {
    padding: 54px 0 !important;
  }

  .services-page .pd-section.dark .pd-logo-card img {
    width: min(280px, 86%) !important;
  }
}

/* === END PATCH SERVICIOS V16 === */


/* === PATCH SERVICIOS V17: página más compacta, sin imágenes rotas y logo local === */

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

/* Header interno: estrella directa sobre fondo azul, sin burbuja */
.services-page .pd-header--internal .pd-brand,
.services-page .pd-header--internal .pd-brand--mark {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  width: 76px !important;
  height: 76px !important;
  padding: 0 !important;
}

.services-page .pd-header--internal .pd-brand img,
.services-page .pd-header--internal .pd-brand--mark img {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  width: 72px !important;
  height: 72px !important;
  object-fit: contain !important;
  display: block !important;
  filter: drop-shadow(0 0 14px rgba(240,122,31,.24)) !important;
}

/* Secciones más compactas */
.services-page .pd-section {
  padding: clamp(54px, 6vw, 82px) 0 !important;
}

.services-page .pd-section-title {
  margin-bottom: 34px !important;
}

.services-page .pd-section-title.center {
  max-width: 820px !important;
}

.services-page .pd-section-title h2 {
  font-size: clamp(2.4rem, 4.5vw, 5rem) !important;
  line-height: .96 !important;
  letter-spacing: -.055em !important;
}

.services-page .pd-section-title p {
  font-size: 1rem !important;
  line-height: 1.6 !important;
}

/* Tarjetas de áreas más proporcionadas */
.services-page .pd-grid.cols-3 {
  gap: 18px !important;
}

.services-page .pd-grid.cols-3 .pd-card {
  min-height: 0 !important;
  padding: clamp(22px, 2.3vw, 30px) !important;
  border-radius: 24px !important;
}

.services-page .pd-grid.cols-3 .pd-card h3 {
  font-size: clamp(1.25rem, 1.7vw, 1.65rem) !important;
  margin-bottom: 14px !important;
}

.services-page .pd-grid.cols-3 .pd-card p,
.services-page .pd-grid.cols-3 .pd-card li {
  font-size: .98rem !important;
  line-height: 1.5 !important;
}

/* Oracle Stack más compacto y legible */
.services-page .pd-section.dark {
  padding: clamp(58px, 6.5vw, 88px) 0 !important;
}

.services-page .pd-section.dark .pd-feature {
  grid-template-columns: minmax(280px, .8fr) minmax(420px, 1.2fr) !important;
  gap: clamp(24px, 4vw, 48px) !important;
}

.services-page .pd-section.dark .pd-section-title h2 {
  font-size: clamp(2.5rem, 4vw, 4.6rem) !important;
}

.services-page .pd-section.dark .pd-logo-card {
  padding: clamp(22px, 2.8vw, 36px) !important;
  border-radius: 28px !important;
  max-width: 620px !important;
}

.services-page .pd-section.dark .pd-logo-card img {
  width: min(320px, 76%) !important;
  margin-bottom: 20px !important;
  padding: 18px 28px !important;
}

/* Bases de datos Oracle: no depende de imágenes externas rotas */
.services-page .pd-media-card {
  overflow: hidden !important;
  padding: 0 !important;
  border-radius: 24px !important;
  display: grid !important;
  grid-template-rows: auto 1fr !important;
}

.services-page .pd-media-visual {
  min-height: 150px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background:
    radial-gradient(circle at 30% 25%, rgba(240,122,31,.28), transparent 24%),
    linear-gradient(135deg, #06111f 0%, #0b2f55 100%) !important;
  border-bottom: 1px solid rgba(7,26,45,.08) !important;
}

.services-page .pd-media-visual span {
  width: 76px !important;
  height: 76px !important;
  border-radius: 24px !important;
  display: grid !important;
  place-items: center !important;
  color: #ffffff !important;
  background: rgba(255,255,255,.10) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  font-weight: 950 !important;
  letter-spacing: .06em !important;
  box-shadow: 0 24px 60px rgba(2,7,13,.18) !important;
}

.services-page .pd-visual-ha {
  background:
    radial-gradient(circle at 70% 25%, rgba(240,122,31,.25), transparent 24%),
    linear-gradient(135deg, #071a2d 0%, #123b63 100%) !important;
}

.services-page .pd-visual-tuning {
  background:
    radial-gradient(circle at 22% 70%, rgba(240,122,31,.24), transparent 24%),
    linear-gradient(135deg, #06111f 0%, #1b344f 100%) !important;
}

.services-page .pd-visual-migration {
  background:
    radial-gradient(circle at 76% 76%, rgba(240,122,31,.28), transparent 24%),
    linear-gradient(135deg, #08213d 0%, #06111f 100%) !important;
}

.services-page .pd-media-card .pd-card-body {
  padding: clamp(22px, 2.2vw, 30px) !important;
}

.services-page .pd-media-card h3 {
  font-size: clamp(1.25rem, 1.8vw, 1.65rem) !important;
  margin-bottom: 12px !important;
}

.services-page .pd-media-card p,
.services-page .pd-media-card li {
  font-size: .98rem !important;
  line-height: 1.5 !important;
}

/* Contacto más bajo */
.services-page .pd-contact-final {
  padding: 48px 0 52px !important;
}

.services-page .pd-contact-final .pd-contact-info-card,
.services-page .pd-contact-final .pd-chat-info-card {
  padding: clamp(24px, 2.6vw, 36px) !important;
  border-radius: 26px !important;
}

.services-page .pd-contact-final .pd-contact-info-card h2 {
  font-size: clamp(2.35rem, 3.9vw, 4.6rem) !important;
}

.services-page .pd-contact-final .pd-chat-info-card h2 {
  font-size: clamp(2.15rem, 3.4vw, 4rem) !important;
}

@media (max-width: 980px) {
  .services-page .pd-section.dark .pd-feature,
  .services-page .pd-contact-final .pd-contact-final-grid {
    grid-template-columns: 1fr !important;
  }

  .services-page .pd-section.dark .pd-logo-card {
    max-width: 100% !important;
  }
}

/* === END PATCH SERVICIOS V17 === */


/* =========================================================
   PATCH V20 DEFINITIVO
   Header + dropdown seleccionable + footer compacto común
   Inicio y Servicios
   ========================================================= */

/* Header siempre encima de todo */
.pd-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 999999 !important;
  overflow: visible !important;
}

/* Evita que el menú se recorte */
.pd-nav,
.pd-nav-links,
.pd-nav-dropdown {
  overflow: visible !important;
}

/* =======================
   HEADER INICIO
   ======================= */
.home-page .pd-header {
  background: rgba(255, 255, 255, .96) !important;
  border-bottom: 1px solid rgba(7, 26, 45, .10) !important;
  box-shadow: 0 10px 35px rgba(6, 17, 31, .08) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

.home-page .pd-nav {
  min-height: 78px !important;
}

.home-page .pd-brand img {
  width: 188px !important;
  max-height: 70px !important;
  height: auto !important;
  object-fit: contain !important;
}

/* =======================
   HEADER SERVICIOS / INTERNAS
   ======================= */
.services-page .pd-header--internal,
.pd-internal-page .pd-header--internal {
  background: rgba(6, 17, 31, .94) !important;
  border-bottom: 1px solid rgba(255, 255, 255, .08) !important;
  box-shadow: 0 16px 44px rgba(0, 0, 0, .18) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

.services-page .pd-header--internal .pd-nav,
.pd-internal-page .pd-header--internal .pd-nav {
  min-height: 78px !important;
}

/* Estrella sola, sin burbuja ni fondo */
.services-page .pd-header--internal .pd-brand,
.services-page .pd-header--internal .pd-brand--mark,
.pd-internal-page .pd-header--internal .pd-brand,
.pd-internal-page .pd-header--internal .pd-brand--mark {
  width: 78px !important;
  height: 78px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  font-size: 0 !important;
  color: transparent !important;
}

.services-page .pd-header--internal .pd-brand img,
.services-page .pd-header--internal .pd-brand--mark img,
.pd-internal-page .pd-header--internal .pd-brand img,
.pd-internal-page .pd-header--internal .pd-brand--mark img {
  width: 72px !important;
  height: 72px !important;
  max-width: 72px !important;
  max-height: 72px !important;
  object-fit: contain !important;
  object-position: center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  filter: drop-shadow(0 0 14px rgba(240, 122, 31, .28)) !important;
}

.services-page .pd-header--internal .pd-brand::before,
.services-page .pd-header--internal .pd-brand::after,
.services-page .pd-header--internal .pd-brand--mark::before,
.services-page .pd-header--internal .pd-brand--mark::after,
.pd-internal-page .pd-header--internal .pd-brand::before,
.pd-internal-page .pd-header--internal .pd-brand::after,
.pd-internal-page .pd-header--internal .pd-brand--mark::before,
.pd-internal-page .pd-header--internal .pd-brand--mark::after {
  content: none !important;
  display: none !important;
}

/* =======================
   DROPDOWN SERVICIOS
   ======================= */
.pd-nav-dropdown {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
}

/* Puente invisible para que no se cierre al mover el mouse */
.pd-nav-dropdown::after {
  content: "" !important;
  position: absolute !important;
  left: -18px !important;
  right: -18px !important;
  top: 100% !important;
  height: 16px !important;
  background: transparent !important;
  pointer-events: auto !important;
}

.pd-dropdown-menu {
  position: absolute !important;
  top: calc(100% + 8px) !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(6px) !important;
  min-width: 250px !important;
  padding: 14px !important;
  border-radius: 0 0 18px 18px !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  z-index: 1000000 !important;
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease !important;
}

.pd-nav-dropdown:hover .pd-dropdown-menu,
.pd-nav-dropdown:focus-within .pd-dropdown-menu,
.pd-nav-dropdown.open .pd-dropdown-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateX(-50%) translateY(0) !important;
}

/* Dropdown blanco en inicio */
.home-page .pd-dropdown-menu {
  background: rgba(255, 255, 255, .98) !important;
  border: 1px solid rgba(7, 26, 45, .10) !important;
  border-top: 3px solid var(--pd-orange) !important;
  box-shadow: 0 24px 60px rgba(6, 17, 31, .18) !important;
}

.home-page .pd-dropdown-menu a {
  color: #09233d !important;
}

/* Dropdown navy en servicios e internas */
.services-page .pd-header--internal .pd-dropdown-menu,
.pd-internal-page .pd-header--internal .pd-dropdown-menu {
  background: rgba(6, 17, 31, .98) !important;
  border: 1px solid rgba(255, 255, 255, .12) !important;
  border-top: 3px solid var(--pd-orange) !important;
  box-shadow: 0 26px 70px rgba(0, 0, 0, .32) !important;
}

.services-page .pd-header--internal .pd-dropdown-menu a,
.pd-internal-page .pd-header--internal .pd-dropdown-menu a {
  color: #dbe6f5 !important;
}

.pd-dropdown-menu a {
  display: block !important;
  padding: 13px 16px !important;
  border-radius: 12px !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}

.pd-dropdown-menu a:hover {
  color: var(--pd-orange) !important;
  background: rgba(240, 122, 31, .12) !important;
}

/* =======================
   FOOTER COMÚN COMPACTO
   Igual al footer del inicio
   ======================= */
.pd-footer {
  background: #05070a !important;
  padding: 34px 0 24px !important;
  border-top: 1px solid rgba(255, 255, 255, .10) !important;
}

.pd-footer-grid {
  display: grid !important;
  grid-template-columns: 1.35fr repeat(4, 1fr) !important;
  gap: 28px !important;
  align-items: start !important;
}

.pd-footer-logo {
  width: 150px !important;
  max-width: 150px !important;
  height: auto !important;
  margin: 0 0 16px !important;
  display: block !important;
}

.pd-footer h4 {
  margin: 0 0 12px !important;
  color: #ffffff !important;
  font-size: 1rem !important;
  line-height: 1.2 !important;
}

.pd-footer p,
.pd-footer a {
  display: block !important;
  color: rgba(255, 255, 255, .66) !important;
  margin: 0 0 9px !important;
  line-height: 1.52 !important;
  text-decoration: none !important;
}

.pd-footer a:hover {
  color: var(--pd-orange) !important;
}

/* Chat flotante igual: círculo naranja con burbuja negra */
.pd-chat-float {
  width: 74px !important;
  height: 74px !important;
  border-radius: 999px !important;
  background: #ff8a1f !important;
  box-shadow: 0 22px 50px rgba(240, 122, 31, .28) !important;
  z-index: 999998 !important;
}

.pd-chat-float::before {
  background: #06111f !important;
}

/* Responsive */
@media (max-width: 980px) {
  .pd-dropdown-menu {
    position: static !important;
    transform: none !important;
    min-width: 100% !important;
    margin-top: 8px !important;
  }

  .pd-nav-dropdown::after {
    display: none !important;
  }

  .pd-footer-grid {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 620px) {
  .pd-footer-grid {
    grid-template-columns: 1fr !important;
  }

  .home-page .pd-brand img {
    width: 150px !important;
  }

  .services-page .pd-header--internal .pd-brand,
  .services-page .pd-header--internal .pd-brand--mark {
    width: 62px !important;
    height: 62px !important;
  }

  .services-page .pd-header--internal .pd-brand img,
  .services-page .pd-header--internal .pd-brand--mark img {
    width: 58px !important;
    height: 58px !important;
  }
}


/* =========================================================
   PATCH V21 - Tarjetas Oracle más elegantes y compactas
   Mejora la sección Bases de Datos Oracle
   ========================================================= */

/* Evita que la sección se pegue al borde de la pantalla */
.services-page .pd-section:not(.dark) > .pd-container,
.services-page .pd-section > .pd-container {
  width: min(1180px, calc(100% - 48px)) !important;
  margin-inline: auto !important;
}

/* Título de la sección con mejor respiración */
.services-page .pd-section-title {
  max-width: 900px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}

.services-page .pd-section-title h2 {
  font-size: clamp(2.2rem, 4vw, 4.4rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -.045em !important;
}

.services-page .pd-section-title p {
  max-width: 760px !important;
  margin-inline: auto !important;
}

/* Grid de las tarjetas con más margen y menos tamaño exagerado */
.services-page .pd-grid.cols-2 {
  width: min(1120px, 100%) !important;
  margin-inline: auto !important;
  gap: 24px !important;
}

/* Tarjeta tipo media: más sofisticada, menos alta y con borde suave */
.services-page .pd-media-card {
  border-radius: 28px !important;
  overflow: hidden !important;
  background: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(7,26,45,.10) !important;
  box-shadow: 0 22px 70px rgba(6,17,31,.08) !important;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}

.services-page .pd-media-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 28px 90px rgba(6,17,31,.12) !important;
  border-color: rgba(240,122,31,.25) !important;
}

/* Recurso visual superior: más bajo y con patrón elegante */
.services-page .pd-media-visual {
  position: relative !important;
  min-height: 112px !important;
  max-height: 112px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  padding-left: 30px !important;
  background:
    radial-gradient(circle at 86% 28%, rgba(240,122,31,.24), transparent 24%),
    linear-gradient(135deg, #06111f 0%, #0b2a4a 58%, #103a63 100%) !important;
  border-bottom: 1px solid rgba(7,26,45,.08) !important;
}

/* Líneas decorativas tipo infraestructura */
.services-page .pd-media-visual::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px) !important;
  background-size: 34px 34px !important;
  mask-image: linear-gradient(90deg, rgba(0,0,0,.9), rgba(0,0,0,.25)) !important;
  pointer-events: none !important;
}

/* Círculo decorativo pequeño */
.services-page .pd-media-visual::after {
  content: "" !important;
  position: absolute !important;
  right: 28px !important;
  top: 22px !important;
  width: 70px !important;
  height: 70px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  background: radial-gradient(circle, rgba(240,122,31,.18), transparent 62%) !important;
  pointer-events: none !important;
}

/* Badge DB/HA/SQL/OCI: ya no gigante al centro */
.services-page .pd-media-visual span {
  position: relative !important;
  z-index: 1 !important;
  width: auto !important;
  min-width: 58px !important;
  height: 42px !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  background: rgba(255,255,255,.10) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: 0 14px 36px rgba(2,7,13,.20) !important;
  font-size: .86rem !important;
  font-weight: 950 !important;
  letter-spacing: .16em !important;
}

/* Contenido más compacto y con mejor margen */
.services-page .pd-media-card .pd-card-body {
  padding: 26px 30px 30px !important;
}

.services-page .pd-media-card h3 {
  font-size: clamp(1.28rem, 1.55vw, 1.62rem) !important;
  line-height: 1.15 !important;
  margin: 0 0 14px !important;
  letter-spacing: -.02em !important;
}

.services-page .pd-media-card p {
  font-size: .96rem !important;
  line-height: 1.58 !important;
  margin-bottom: 18px !important;
}

.services-page .pd-media-card ul {
  margin: 0 !important;
  padding-left: 0 !important;
  list-style: none !important;
}

.services-page .pd-media-card li {
  position: relative !important;
  padding-left: 20px !important;
  margin-bottom: 8px !important;
  font-size: .94rem !important;
  line-height: 1.42 !important;
}

.services-page .pd-media-card li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: .62em !important;
  width: 6px !important;
  height: 6px !important;
  border-radius: 999px !important;
  background: var(--pd-orange) !important;
  box-shadow: 0 0 0 4px rgba(240,122,31,.10) !important;
}

/* Variación sutil por tipo de tarjeta */
.services-page .pd-visual-ha {
  background:
    radial-gradient(circle at 80% 25%, rgba(240,122,31,.22), transparent 24%),
    linear-gradient(135deg, #06111f 0%, #102b45 55%, #0e3a5f 100%) !important;
}

.services-page .pd-visual-tuning {
  background:
    radial-gradient(circle at 84% 70%, rgba(240,122,31,.20), transparent 24%),
    linear-gradient(135deg, #06111f 0%, #14273d 58%, #193d5c 100%) !important;
}

.services-page .pd-visual-migration {
  background:
    radial-gradient(circle at 84% 22%, rgba(240,122,31,.22), transparent 24%),
    linear-gradient(135deg, #06111f 0%, #0c2b4a 58%, #10345a 100%) !important;
}

/* Responsive */
@media (max-width: 980px) {
  .services-page .pd-grid.cols-2 {
    grid-template-columns: 1fr !important;
  }

  .services-page .pd-media-visual {
    min-height: 100px !important;
    max-height: 100px !important;
  }
}

@media (max-width: 620px) {
  .services-page .pd-section:not(.dark) > .pd-container,
  .services-page .pd-section > .pd-container {
    width: min(100% - 28px, 1180px) !important;
  }

  .services-page .pd-media-card .pd-card-body {
    padding: 22px !important;
  }
}

/* ===================== END PATCH V21 ===================== */


/* =========================================================
   PATCH V22 - Sección Áreas de servicio más creativa
   Sin reducir información: reemplaza tarjetas simples por mapa de servicios
   ========================================================= */

.services-page .pd-service-map {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 16% 24%, rgba(240,122,31,.08), transparent 26%),
    radial-gradient(circle at 86% 18%, rgba(8,35,61,.06), transparent 28%),
    #f7f8fa !important;
}

.services-page .pd-service-map::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(6,17,31,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(6,17,31,.035) 1px, transparent 1px) !important;
  background-size: 42px 42px !important;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.55), transparent 75%) !important;
  pointer-events: none !important;
}

.services-page .pd-service-map .pd-wrap {
  position: relative !important;
  z-index: 1 !important;
}

.services-page .pd-kicker.light {
  color: var(--pd-orange) !important;
  background: rgba(240,122,31,.09) !important;
  border: 1px solid rgba(240,122,31,.13) !important;
  border-radius: 999px !important;
  padding: 8px 16px !important;
  display: inline-flex !important;
  width: fit-content !important;
  margin: 0 auto 18px !important;
}

.services-page .pd-service-map-layout {
  width: min(1160px, 100%) !important;
  margin: 44px auto 0 !important;
  display: grid !important;
  grid-template-columns: minmax(290px, .82fr) minmax(520px, 1.18fr) !important;
  gap: 26px !important;
  align-items: stretch !important;
}

/* Panel lateral: recurso visual, no tarjeta plana */
.services-page .pd-service-map-panel {
  position: relative !important;
  min-height: 430px !important;
  border-radius: 34px !important;
  padding: 34px !important;
  overflow: hidden !important;
  color: #fff !important;
  background:
    linear-gradient(135deg, rgba(6,17,31,.98), rgba(9,38,65,.96)),
    radial-gradient(circle at 80% 20%, rgba(240,122,31,.22), transparent 30%) !important;
  box-shadow: 0 28px 90px rgba(6,17,31,.18) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
}

.services-page .pd-service-map-panel::before {
  content: "" !important;
  position: absolute !important;
  inset: -1px !important;
  background-image:
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px) !important;
  background-size: 34px 34px !important;
  mask-image: radial-gradient(circle at 50% 42%, rgba(0,0,0,.9), transparent 72%) !important;
  pointer-events: none !important;
}

.services-page .pd-service-map-panel::after {
  content: "" !important;
  position: absolute !important;
  right: -70px !important;
  bottom: -70px !important;
  width: 220px !important;
  height: 220px !important;
  border-radius: 999px !important;
  background: radial-gradient(circle, rgba(240,122,31,.32), transparent 66%) !important;
  pointer-events: none !important;
}

.services-page .pd-map-orbit {
  position: relative !important;
  width: 150px !important;
  height: 150px !important;
  margin-bottom: 34px !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: 999px !important;
}

.services-page .pd-map-orbit::before,
.services-page .pd-map-orbit::after {
  content: "" !important;
  position: absolute !important;
  inset: 24px !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 999px !important;
}

.services-page .pd-map-orbit::after {
  inset: 54px !important;
  background: #ff8a1f !important;
  border: 0 !important;
  box-shadow: 0 0 0 14px rgba(240,122,31,.12) !important;
}

.services-page .pd-map-orbit span {
  position: absolute !important;
  width: 15px !important;
  height: 15px !important;
  border-radius: 999px !important;
  background: #ff8a1f !important;
  box-shadow: 0 0 0 9px rgba(240,122,31,.12) !important;
}

.services-page .pd-map-orbit span:nth-child(1) { top: 8px !important; left: 66px !important; }
.services-page .pd-map-orbit span:nth-child(2) { right: 13px !important; top: 92px !important; background: #ffffff !important; }
.services-page .pd-map-orbit span:nth-child(3) { left: 16px !important; bottom: 28px !important; }

.services-page .pd-map-label {
  position: relative !important;
  z-index: 1 !important;
  margin: 0 0 12px !important;
  color: #ff8a1f !important;
  text-transform: uppercase !important;
  letter-spacing: .24em !important;
  font-size: .76rem !important;
  font-weight: 900 !important;
}

.services-page .pd-service-map-panel h3 {
  position: relative !important;
  z-index: 1 !important;
  margin: 0 0 16px !important;
  font-size: clamp(1.75rem, 2.5vw, 2.55rem) !important;
  line-height: 1.06 !important;
  letter-spacing: -.04em !important;
}

.services-page .pd-service-map-panel > p:last-child {
  position: relative !important;
  z-index: 1 !important;
  margin: 0 !important;
  color: rgba(219,230,245,.78) !important;
  line-height: 1.65 !important;
}

/* Línea de servicios: más dinámica que cuadros iguales */
.services-page .pd-service-flow {
  position: relative !important;
  display: grid !important;
  gap: 18px !important;
  padding-left: 30px !important;
}

.services-page .pd-service-flow::before {
  content: "" !important;
  position: absolute !important;
  left: 10px !important;
  top: 24px !important;
  bottom: 24px !important;
  width: 2px !important;
  background: linear-gradient(to bottom, #ff8a1f, rgba(9,35,61,.18)) !important;
}

.services-page .pd-service-node {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 72px 1fr !important;
  gap: 18px !important;
  align-items: start !important;
  padding: 24px 26px !important;
  border-radius: 28px !important;
  background: rgba(255,255,255,.86) !important;
  border: 1px solid rgba(7,26,45,.10) !important;
  box-shadow: 0 20px 70px rgba(6,17,31,.075) !important;
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease !important;
}

.services-page .pd-service-node:nth-child(2) {
  margin-left: 34px !important;
}

.services-page .pd-service-node:nth-child(3) {
  margin-left: 68px !important;
}

.services-page .pd-service-node:hover {
  transform: translateX(6px) !important;
  border-color: rgba(240,122,31,.26) !important;
  box-shadow: 0 24px 86px rgba(6,17,31,.11) !important;
}

.services-page .pd-service-node::before {
  content: "" !important;
  position: absolute !important;
  left: -26px !important;
  top: 36px !important;
  width: 15px !important;
  height: 15px !important;
  border-radius: 999px !important;
  background: #ff8a1f !important;
  box-shadow: 0 0 0 8px rgba(240,122,31,.12) !important;
}

.services-page .pd-service-node.featured {
  background:
    linear-gradient(135deg, rgba(255,255,255,.94), rgba(255,255,255,.86)),
    radial-gradient(circle at 92% 18%, rgba(240,122,31,.13), transparent 30%) !important;
}

.services-page .pd-node-number {
  width: 62px !important;
  height: 62px !important;
  border-radius: 20px !important;
  display: grid !important;
  place-items: center !important;
  color: #ff8a1f !important;
  background: #06111f !important;
  font-weight: 950 !important;
  letter-spacing: .10em !important;
  box-shadow: 0 16px 42px rgba(6,17,31,.18) !important;
}

.services-page .pd-service-node h3 {
  margin: 0 0 8px !important;
  font-size: clamp(1.25rem, 1.7vw, 1.7rem) !important;
  line-height: 1.15 !important;
  letter-spacing: -.025em !important;
}

.services-page .pd-service-node p {
  margin: 0 0 14px !important;
  color: #526173 !important;
  line-height: 1.55 !important;
}

.services-page .pd-service-node ul {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.services-page .pd-service-node li {
  margin: 0 !important;
  padding: 8px 11px !important;
  border-radius: 999px !important;
  background: rgba(7,26,45,.055) !important;
  color: #243346 !important;
  font-size: .86rem !important;
  line-height: 1.1 !important;
  font-weight: 750 !important;
}

.services-page .pd-service-node li::before {
  display: none !important;
  content: none !important;
}

.services-page .pd-service-node.featured li {
  background: rgba(240,122,31,.10) !important;
  color: #8b3d0c !important;
}

/* Entrada suave al hacer scroll */
.services-page .pd-service-map-panel,
.services-page .pd-service-node {
  animation: pdServiceRise .7s ease both !important;
}

.services-page .pd-service-node:nth-child(1) { animation-delay: .05s !important; }
.services-page .pd-service-node:nth-child(2) { animation-delay: .12s !important; }
.services-page .pd-service-node:nth-child(3) { animation-delay: .19s !important; }

@keyframes pdServiceRise {
  from {
    opacity: 0;
    transform: translateY(22px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 980px) {
  .services-page .pd-service-map-layout {
    grid-template-columns: 1fr !important;
  }

  .services-page .pd-service-map-panel {
    min-height: 320px !important;
  }

  .services-page .pd-service-flow {
    padding-left: 22px !important;
  }

  .services-page .pd-service-node,
  .services-page .pd-service-node:nth-child(2),
  .services-page .pd-service-node:nth-child(3) {
    margin-left: 0 !important;
  }
}

@media (max-width: 620px) {
  .services-page .pd-service-node {
    grid-template-columns: 1fr !important;
  }

  .services-page .pd-node-number {
    width: 54px !important;
    height: 54px !important;
  }
}

/* ===================== END PATCH V22 ===================== */


/* =========================================================
   PATCH V23 ORACLE
   Página Oracle modernizada con el mismo header/footer del sitio
   ========================================================= */

.oracle-page {
  background: #f5f7fa !important;
  color: #071a2d !important;
}

.oracle-page .pd-header--internal {
  background: rgba(6, 17, 31, .94) !important;
}

/* Hero Oracle */
.oracle-page .pd-hero {
  min-height: calc(100vh - 78px) !important;
  background:
    radial-gradient(circle at 84% 30%, rgba(240,122,31,.20), transparent 30%),
    radial-gradient(circle at 12% 18%, rgba(0,52,133,.30), transparent 35%),
    linear-gradient(135deg, #06111f 0%, #08213a 48%, #172334 100%) !important;
  position: relative !important;
  overflow: hidden !important;
}

.oracle-page .pd-hero::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px) !important;
  background-size: 44px 44px !important;
  opacity: .52 !important;
}

.oracle-page .pd-hero-inner {
  position: relative !important;
  z-index: 1 !important;
  width: min(1320px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
  padding: clamp(70px, 8vw, 110px) 0 70px !important;
}

.oracle-page .pd-hero-top {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(420px, .95fr) !important;
  gap: clamp(34px, 6vw, 76px) !important;
  align-items: center !important;
}

.oracle-page .pd-kicker {
  color: #ff8a1f !important;
  font-weight: 950 !important;
  letter-spacing: .26em !important;
  text-transform: uppercase !important;
  font-size: .82rem !important;
  margin-bottom: 22px !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}

.oracle-page .pd-kicker::before {
  content: "" !important;
  width: 52px !important;
  height: 2px !important;
  background: #ff8a1f !important;
}

.oracle-page .pd-hero h1 {
  color: #fff !important;
  margin: 0 !important;
  font-size: clamp(3.4rem, 6.5vw, 6.4rem) !important;
  line-height: .93 !important;
  letter-spacing: -.07em !important;
  font-weight: 950 !important;
}

.oracle-page .pd-hero h1 .accent {
  color: #ffc08c !important;
}

.oracle-page .pd-hero p {
  max-width: 760px !important;
  margin: 30px 0 26px !important;
  color: #d7e0ec !important;
  line-height: 1.72 !important;
  font-size: clamp(1rem, 1.25vw, 1.22rem) !important;
}

.oracle-page .pd-pill-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 11px !important;
}

.oracle-page .pd-pill {
  border: 1px solid rgba(255,255,255,.16) !important;
  background: rgba(255,255,255,.075) !important;
  padding: 10px 15px !important;
  border-radius: 999px !important;
  color: #e5edf8 !important;
  font-weight: 800 !important;
  font-size: .87rem !important;
  backdrop-filter: blur(8px) !important;
}

.oracle-page .pd-pill::before {
  content: "" !important;
  display: inline-block !important;
  width: 7px !important;
  height: 7px !important;
  border-radius: 50% !important;
  background: #ff8a1f !important;
  margin-right: 9px !important;
}

/* Visual del hero */
.oracle-page .pd-hero-visual {
  position: relative !important;
  min-height: 420px !important;
  display: grid !important;
  place-items: center !important;
}

.oracle-page .pd-orbit {
  position: absolute !important;
  width: min(390px, 82vw) !important;
  height: min(390px, 82vw) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 50% !important;
  animation: oracleSpin 24s linear infinite !important;
}

.oracle-page .pd-orbit::before,
.oracle-page .pd-orbit::after {
  content: "" !important;
  position: absolute !important;
  width: 13px !important;
  height: 13px !important;
  border-radius: 50% !important;
  background: #ff8a1f !important;
  box-shadow: 0 0 0 8px rgba(240,122,31,.12) !important;
}

.oracle-page .pd-orbit::before { top: 35px !important; left: 64px !important; }
.oracle-page .pd-orbit::after {
  right: 30px !important;
  bottom: 74px !important;
  background: #3ad29f !important;
  box-shadow: 0 0 0 8px rgba(58,210,159,.12) !important;
}

@keyframes oracleSpin {
  from { transform: rotate(0); }
  to { transform: rotate(360deg); }
}

.oracle-page .pd-dashboard {
  position: relative !important;
  width: min(520px, 100%) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.055)) !important;
  box-shadow: 0 32px 95px rgba(0,0,0,.34) !important;
  border-radius: 30px !important;
  overflow: hidden !important;
  backdrop-filter: blur(14px) !important;
}

.oracle-page .pd-window-top {
  height: 56px !important;
  border-bottom: 1px solid rgba(255,255,255,.13) !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 0 24px !important;
  background: rgba(255,255,255,.08) !important;
}

.oracle-page .pd-dot {
  width: 14px !important;
  height: 14px !important;
  border-radius: 50% !important;
  background: #ff8a1f !important;
}
.oracle-page .pd-dot:nth-child(2) { background: #ffd166 !important; }
.oracle-page .pd-dot:nth-child(3) { background: #3ad29f !important; }

.oracle-page .pd-dashboard-body { padding: 30px !important; }

.oracle-page .pd-line {
  height: 15px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.20) !important;
  margin: 16px 0 !important;
  overflow: hidden !important;
}

.oracle-page .pd-line span {
  display: block !important;
  height: 100% !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, #ff8a1f, #ffc08c) !important;
}

.oracle-page .pd-line:nth-child(1) span { width: 88% !important; }
.oracle-page .pd-line:nth-child(2) span { width: 62% !important; }
.oracle-page .pd-line:nth-child(3) span { width: 78% !important; }
.oracle-page .pd-line:nth-child(4) span { width: 45% !important; }

.oracle-page .pd-dashboard-card {
  margin-top: 28px !important;
  padding: 26px !important;
  border-radius: 24px !important;
  background: #06111f !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.28) !important;
}

.oracle-page .pd-dashboard-card small {
  display: block !important;
  color: #ff8a1f !important;
  letter-spacing: .24em !important;
  text-transform: uppercase !important;
  font-weight: 950 !important;
  margin-bottom: 14px !important;
}

.oracle-page .pd-dashboard-card strong {
  display: block !important;
  color: #fff !important;
  font-size: clamp(1.5rem, 2.2vw, 1.85rem) !important;
  line-height: 1.2 !important;
  margin-bottom: 10px !important;
}

.oracle-page .pd-dashboard-card span {
  color: #bdc8d8 !important;
  line-height: 1.6 !important;
}

/* Métricas */
.oracle-page .pd-metrics {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 14px !important;
  margin-top: 34px !important;
}

.oracle-page .pd-metric {
  border: 1px solid rgba(255,255,255,.14) !important;
  background: rgba(255,255,255,.06) !important;
  border-radius: 20px !important;
  padding: 22px !important;
  min-height: 116px !important;
  backdrop-filter: blur(8px) !important;
}

.oracle-page .pd-metric strong {
  display: block !important;
  color: #fff !important;
  font-size: clamp(2rem, 3vw, 2.75rem) !important;
  letter-spacing: -.05em !important;
  line-height: 1 !important;
  margin-bottom: 10px !important;
}

.oracle-page .pd-metric span {
  display: block !important;
  color: #d5deea !important;
  line-height: 1.45 !important;
  font-weight: 700 !important;
}

.oracle-page .pd-metric.is-hot {
  background: linear-gradient(135deg, #d84a3b, #ff8a1f) !important;
  border-color: rgba(255,255,255,.2) !important;
}

.oracle-page .pd-local {
  margin-top: 20px !important;
  display: flex !important;
  gap: 16px !important;
  align-items: center !important;
  width: min(640px, 100%) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  background: rgba(255,255,255,.065) !important;
  padding: 16px 20px !important;
  border-radius: 16px !important;
  color: #e0e8f4 !important;
  font-weight: 700 !important;
}

.oracle-page .pd-local i {
  width: 42px !important;
  height: 42px !important;
  border-radius: 10px !important;
  background: #ff8a1f !important;
  display: inline-grid !important;
  place-items: center !important;
  color: #071a2d !important;
  font-style: normal !important;
  font-size: 20px !important;
  flex: 0 0 auto !important;
}

/* Secciones Oracle */
.oracle-page .pd-section {
  padding: clamp(62px, 7vw, 92px) 0 !important;
}

.oracle-page .pd-wrap {
  width: min(1320px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
}

.oracle-page .pd-section-label {
  color: #d84a3b !important;
  text-transform: uppercase !important;
  letter-spacing: .25em !important;
  font-weight: 900 !important;
  font-size: .78rem !important;
  margin-bottom: 20px !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}

.oracle-page .pd-section-label::before {
  content: "" !important;
  width: 48px !important;
  height: 1px !important;
  background: #d84a3b !important;
}

.oracle-page .pd-section h2 {
  font-size: clamp(2.55rem, 5vw, 4.6rem) !important;
  line-height: 1 !important;
  letter-spacing: -.06em !important;
  margin: 0 0 24px !important;
  color: #071a2d !important;
  font-weight: 950 !important;
}

.oracle-page .pd-lead {
  font-size: clamp(1rem, 1.45vw, 1.22rem) !important;
  line-height: 1.75 !important;
  color: #647084 !important;
  max-width: 850px !important;
  margin: 0 0 40px !important;
}

/* Servicios: tarjetas más sobrias */
.oracle-page .pd-services-intro {
  background: #fff !important;
}

.oracle-page .pd-service-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 22px !important;
  margin-top: 36px !important;
}

.oracle-page .pd-service-card {
  position: relative !important;
  overflow: hidden !important;
  background: #fff !important;
  border: 1px solid rgba(7,26,45,.10) !important;
  border-radius: 24px !important;
  padding: 30px !important;
  box-shadow: 0 18px 55px rgba(7,26,45,.06) !important;
  transition: transform .25s ease, box-shadow .25s ease !important;
}

.oracle-page .pd-service-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 auto 0 0 !important;
  width: 4px !important;
  background: linear-gradient(to bottom, #2d73c8, #ff8a1f) !important;
}

.oracle-page .pd-service-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 28px 75px rgba(7,26,45,.11) !important;
}

.oracle-page .pd-icon {
  width: 56px !important;
  height: 56px !important;
  border-radius: 16px !important;
  background: rgba(240,122,31,.10) !important;
  color: #d84a3b !important;
  display: grid !important;
  place-items: center !important;
  font-size: 24px !important;
  margin-bottom: 24px !important;
}

.oracle-page .pd-service-card h3 {
  font-size: 1.45rem !important;
  margin: 0 0 14px !important;
  color: #071a2d !important;
}

.oracle-page .pd-service-card p {
  color: #5d6878 !important;
  line-height: 1.65 !important;
  margin: 0 0 18px !important;
}

.oracle-page .pd-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.oracle-page .pd-tag {
  font-size: .78rem !important;
  background: #f3f1ec !important;
  border: 1px solid rgba(7,26,45,.10) !important;
  padding: 8px 11px !important;
  border-radius: 999px !important;
  color: #111 !important;
  font-weight: 750 !important;
}

/* Oracle stack */
.oracle-page .pd-oracle-stack {
  background: linear-gradient(135deg, #eef4fb, #ffffff) !important;
}

.oracle-page .pd-stack-card {
  background: #fff !important;
  border: 1px solid rgba(7,26,45,.10) !important;
  box-shadow: 0 24px 80px rgba(7,26,45,.08) !important;
  border-radius: 32px !important;
  padding: clamp(28px, 4vw, 54px) !important;
  display: grid !important;
  grid-template-columns: .9fr 1.1fr !important;
  gap: clamp(28px, 5vw, 56px) !important;
  align-items: center !important;
  position: relative !important;
  overflow: hidden !important;
}

.oracle-page .pd-oracle-logo-box {
  background:
    radial-gradient(circle at 75% 20%, rgba(240,122,31,.13), transparent 30%),
    #f4f6f8 !important;
  border-radius: 24px !important;
  min-height: 230px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 30px !important;
}

.oracle-page .pd-oracle-logo-box img {
  max-width: 360px !important;
  width: 100% !important;
  height: auto !important;
}

.oracle-page .pd-stack-list h3 {
  font-size: clamp(1.8rem, 3vw, 2.4rem) !important;
  margin: 0 0 20px !important;
  color: #071a2d !important;
}

.oracle-page .pd-stack-list p,
.oracle-page .pd-stack-list li {
  color: #526276 !important;
  line-height: 1.75 !important;
}

/* DB section */
.oracle-page .pd-db-section {
  background: #06111f !important;
  color: #fff !important;
  position: relative !important;
  overflow: hidden !important;
}

.oracle-page .pd-db-section::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px) !important;
  background-size: 44px 44px !important;
}

.oracle-page .pd-db-section .pd-wrap {
  position: relative !important;
  z-index: 1 !important;
}

.oracle-page .pd-db-section h2 {
  color: #fff !important;
}

.oracle-page .pd-db-section .pd-lead {
  color: #c6d3e4 !important;
}

.oracle-page .pd-db-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 22px !important;
  margin-top: 40px !important;
}

.oracle-page .pd-db-card {
  background: rgba(255,255,255,.96) !important;
  color: #071a2d !important;
  border-radius: 26px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.18) !important;
  overflow: hidden !important;
}

.oracle-page .pd-db-card .content {
  padding: 30px !important;
}

.oracle-page .pd-db-card h3 {
  font-size: 1.55rem !important;
  margin: 0 0 18px !important;
}

.oracle-page .pd-db-card li {
  color: #526276 !important;
  line-height: 1.75 !important;
  margin-bottom: 6px !important;
}

.oracle-page .pd-db-card li::marker,
.oracle-page .pd-stack-list li::marker {
  color: #ff8a1f !important;
}

/* Proceso */
.oracle-page .pd-process {
  background: #efeee9 !important;
}

.oracle-page .pd-process-grid {
  display: grid !important;
  grid-template-columns: .72fr 1.28fr !important;
  gap: clamp(32px, 6vw, 70px) !important;
  align-items: start !important;
}

.oracle-page .pd-step {
  display: grid !important;
  grid-template-columns: 50px 1fr !important;
  gap: 24px !important;
  padding: 26px 0 !important;
  border-bottom: 1px solid rgba(7,26,45,.10) !important;
}

.oracle-page .pd-step b {
  color: #d84834 !important;
}

.oracle-page .pd-step h3 {
  margin: 0 0 8px !important;
  font-size: 1.35rem !important;
  color: #071a2d !important;
}

.oracle-page .pd-step p {
  margin: 0 !important;
  color: #596473 !important;
  line-height: 1.65 !important;
}

/* Contacto */
.oracle-page .pd-contact {
  background: #f4f3ee !important;
}

.oracle-page .pd-contact-grid {
  display: grid !important;
  grid-template-columns: .85fr 1fr !important;
  gap: clamp(32px, 6vw, 70px) !important;
  align-items: center !important;
}

.oracle-page .pd-contact-copy p {
  font-size: 1.05rem !important;
  color: #596473 !important;
  line-height: 1.75 !important;
}

.oracle-page .pd-contact-list {
  display: grid !important;
  gap: 14px !important;
  margin-top: 30px !important;
}

.oracle-page .pd-contact-list a,
.oracle-page .pd-contact-list span {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  color: #071a2d !important;
  font-weight: 750 !important;
}

.oracle-page .pd-contact-list i {
  width: 40px !important;
  height: 40px !important;
  border-radius: 10px !important;
  background: #fff !important;
  border: 1px solid rgba(7,26,45,.08) !important;
  color: #d84a3b !important;
  display: grid !important;
  place-items: center !important;
  font-style: normal !important;
}

.oracle-page .pd-chat-card {
  background: #050607 !important;
  color: #fff !important;
  border-radius: 30px !important;
  padding: clamp(30px, 4vw, 48px) !important;
  box-shadow: 0 28px 80px rgba(0,0,0,.18) !important;
}

.oracle-page .pd-chat-icon {
  width: 64px !important;
  height: 64px !important;
  border-radius: 16px !important;
  background: #d84a3b !important;
  display: grid !important;
  place-items: center !important;
  font-size: 28px !important;
  margin-bottom: 28px !important;
}

.oracle-page .pd-chat-card h3 {
  font-size: clamp(2rem, 3vw, 2.4rem) !important;
  margin: 0 0 22px !important;
  line-height: 1.15 !important;
}

.oracle-page .pd-chat-card p {
  color: #c7cbd3 !important;
  line-height: 1.7 !important;
}

.oracle-page .pd-chat-card ol {
  list-style: none !important;
  padding: 0 !important;
  margin: 28px 0 0 !important;
  display: grid !important;
  gap: 16px !important;
}

.oracle-page .pd-chat-card li {
  display: grid !important;
  grid-template-columns: 34px 1fr !important;
  gap: 14px !important;
  align-items: start !important;
  color: #e8e8e8 !important;
  font-weight: 750 !important;
}

.oracle-page .pd-chat-card li b {
  background: #d84a3b !important;
  color: #fff !important;
  border-radius: 50% !important;
  width: 30px !important;
  height: 30px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 13px !important;
}

.oracle-page .pd-available {
  margin-top: 26px !important;
  color: #b9bbc3 !important;
}

.oracle-page .pd-available::before {
  content: "" !important;
  display: inline-block !important;
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
  background: #3ad29f !important;
  margin-right: 10px !important;
}

/* Cookie */
.oracle-page .pollux-cookie-reopen,
.oracle-page #pollux-cookie-reopen {
  position: fixed !important;
  left: 18px !important;
  bottom: 18px !important;
  background: #101226 !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 10px !important;
  padding: 10px 16px !important;
  z-index: 999998 !important;
}

/* Responsive Oracle */
@media (max-width: 1100px) {
  .oracle-page .pd-hero-top,
  .oracle-page .pd-stack-card,
  .oracle-page .pd-process-grid,
  .oracle-page .pd-contact-grid {
    grid-template-columns: 1fr !important;
  }

  .oracle-page .pd-metrics,
  .oracle-page .pd-service-grid,
  .oracle-page .pd-db-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 720px) {
  .oracle-page .pd-hero-inner,
  .oracle-page .pd-wrap {
    width: min(100% - 28px, 1320px) !important;
  }

  .oracle-page .pd-hero h1 {
    font-size: 3.1rem !important;
  }

  .oracle-page .pd-metrics,
  .oracle-page .pd-service-grid,
  .oracle-page .pd-db-grid {
    grid-template-columns: 1fr !important;
  }

  .oracle-page .pd-hero-visual {
    min-height: 340px !important;
  }
}

/* ===================== END PATCH V23 ORACLE ===================== */


/* =========================================================
   PATCH V24 ORACLE
   Ajuste visual: hero más oscuro, compacto y con identidad Oracle
   ========================================================= */

.oracle-page .pd-hero {
  min-height: auto !important;
  background:
    radial-gradient(circle at 83% 30%, rgba(240,122,31,.13), transparent 28%),
    radial-gradient(circle at 8% 20%, rgba(0,30,68,.42), transparent 34%),
    linear-gradient(135deg, #04101d 0%, #061525 44%, #111a27 100%) !important;
}

.oracle-page .pd-hero::before {
  opacity: .34 !important;
  background-size: 48px 48px !important;
}

.oracle-page .pd-hero::after {
  content: "" !important;
  position: absolute !important;
  right: -220px !important;
  top: 80px !important;
  width: 620px !important;
  height: 620px !important;
  background: radial-gradient(circle, rgba(240,122,31,.16), rgba(0,52,133,.10) 42%, transparent 70%) !important;
  pointer-events: none !important;
  filter: blur(2px) !important;
}

.oracle-page .pd-hero-inner {
  padding: clamp(52px, 6vw, 78px) 0 54px !important;
}

.oracle-page .pd-hero-top {
  grid-template-columns: minmax(0, .9fr) minmax(430px, 1fr) !important;
  gap: clamp(34px, 5vw, 66px) !important;
}

.oracle-page .pd-kicker {
  font-size: .78rem !important;
  letter-spacing: .24em !important;
  margin-bottom: 18px !important;
}

.oracle-page .pd-hero h1 {
  font-size: clamp(3.25rem, 5.25vw, 5.7rem) !important;
  line-height: .95 !important;
  letter-spacing: -.065em !important;
  max-width: 780px !important;
}

.oracle-page .pd-hero p {
  margin-top: 24px !important;
  margin-bottom: 22px !important;
  max-width: 700px !important;
  font-size: clamp(1rem, 1.12vw, 1.14rem) !important;
  line-height: 1.68 !important;
  color: #d2dce9 !important;
}

.oracle-page .pd-pill {
  font-size: .82rem !important;
  padding: 9px 13px !important;
}

/* Nuevo visual Oracle del hero */
.oracle-page .pd-oracle-hero-visual {
  min-height: 390px !important;
  display: grid !important;
  place-items: center !important;
  position: relative !important;
}

.oracle-page .pd-oracle-halo {
  position: absolute !important;
  width: min(430px, 82vw) !important;
  height: min(430px, 82vw) !important;
  border-radius: 50% !important;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.075), transparent 34%),
    conic-gradient(from 90deg, transparent, rgba(240,122,31,.24), transparent, rgba(0,52,133,.20), transparent) !important;
  opacity: .9 !important;
  filter: blur(.2px) !important;
}

.oracle-page .pd-oracle-halo::before,
.oracle-page .pd-oracle-halo::after {
  content: "" !important;
  position: absolute !important;
  inset: 34px !important;
  border-radius: 50% !important;
  border: 1px solid rgba(255,255,255,.13) !important;
}

.oracle-page .pd-oracle-halo::after {
  inset: 92px !important;
  border-color: rgba(240,122,31,.18) !important;
}

.oracle-page .pd-oracle-brand-card {
  position: relative !important;
  z-index: 2 !important;
  width: min(520px, 100%) !important;
  min-height: 250px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 34px !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  background:
    linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.045)),
    rgba(6,21,37,.68) !important;
  box-shadow: 0 34px 95px rgba(0,0,0,.35) !important;
  backdrop-filter: blur(14px) !important;
  overflow: hidden !important;
}

.oracle-page .pd-oracle-brand-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 24px !important;
  border-radius: 26px !important;
  background: rgba(255,255,255,.065) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
}

.oracle-page .pd-oracle-brand-card::after {
  content: "ORACLE CLOUD INFRASTRUCTURE" !important;
  position: absolute !important;
  left: 32px !important;
  bottom: 26px !important;
  color: rgba(255,255,255,.72) !important;
  font-size: .7rem !important;
  letter-spacing: .26em !important;
  font-weight: 950 !important;
}

.oracle-page .pd-oracle-brand-card img {
  position: relative !important;
  z-index: 2 !important;
  width: min(340px, 70%) !important;
  height: auto !important;
  object-fit: contain !important;
  filter: drop-shadow(0 20px 35px rgba(0,0,0,.25)) !important;
}

.oracle-page .pd-oracle-signal-card {
  position: absolute !important;
  z-index: 3 !important;
  width: 185px !important;
  border-radius: 22px !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  background: #06111f !important;
  padding: 18px 20px !important;
  box-shadow: 0 20px 50px rgba(0,0,0,.28) !important;
}

.oracle-page .pd-oracle-signal-card span {
  display: block !important;
  color: #ff8a1f !important;
  font-size: .72rem !important;
  font-weight: 950 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  margin-bottom: 7px !important;
}

.oracle-page .pd-oracle-signal-card strong {
  color: #fff !important;
  font-size: .98rem !important;
  line-height: 1.25 !important;
}

.oracle-page .pd-oracle-signal-card--one {
  left: 6% !important;
  bottom: 38px !important;
}

.oracle-page .pd-oracle-signal-card--two {
  right: 2% !important;
  top: 42px !important;
}

.oracle-page .pd-oracle-rail {
  position: absolute !important;
  z-index: 1 !important;
  width: min(460px, 90%) !important;
  display: grid !important;
  gap: 14px !important;
  transform: translateY(172px) !important;
  opacity: .55 !important;
}

.oracle-page .pd-oracle-rail span {
  height: 9px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.14) !important;
}

.oracle-page .pd-oracle-rail span:nth-child(1) { width: 86% !important; }
.oracle-page .pd-oracle-rail span:nth-child(2) { width: 68% !important; }
.oracle-page .pd-oracle-rail span:nth-child(3) { width: 78% !important; background: rgba(240,122,31,.45) !important; }
.oracle-page .pd-oracle-rail span:nth-child(4) { width: 54% !important; }

.oracle-page .pd-metrics {
  margin-top: 28px !important;
}

.oracle-page .pd-metric {
  min-height: 102px !important;
  padding: 18px 20px !important;
  border-radius: 18px !important;
}

.oracle-page .pd-metric strong {
  font-size: clamp(1.75rem, 2.65vw, 2.35rem) !important;
}

.oracle-page .pd-metric span {
  font-size: .92rem !important;
}

.oracle-page .pd-local {
  padding: 14px 18px !important;
  margin-top: 16px !important;
  font-size: .92rem !important;
}

/* Deja las secciones siguientes más cerca del hero */
.oracle-page .pd-section {
  padding-top: clamp(54px, 6vw, 78px) !important;
  padding-bottom: clamp(54px, 6vw, 78px) !important;
}

@media (max-width: 1100px) {
  .oracle-page .pd-hero-top {
    grid-template-columns: 1fr !important;
  }

  .oracle-page .pd-oracle-hero-visual {
    min-height: 360px !important;
  }

  .oracle-page .pd-oracle-signal-card--one {
    left: 4% !important;
  }

  .oracle-page .pd-oracle-signal-card--two {
    right: 4% !important;
  }
}

@media (max-width: 720px) {
  .oracle-page .pd-hero-inner {
    padding-top: 42px !important;
  }

  .oracle-page .pd-hero h1 {
    font-size: 3rem !important;
  }

  .oracle-page .pd-oracle-brand-card {
    min-height: 210px !important;
  }

  .oracle-page .pd-oracle-signal-card {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: 100% !important;
    margin-top: 12px !important;
  }

  .oracle-page .pd-oracle-hero-visual {
    display: flex !important;
    flex-direction: column !important;
    min-height: auto !important;
  }

  .oracle-page .pd-oracle-halo,
  .oracle-page .pd-oracle-rail {
    display: none !important;
  }
}

/* ===================== END PATCH V24 ORACLE ===================== */


/* =========================================================
   PATCH V28 HEADER ESTABLE
   Solo corrige header fijo y uniforme.
   No toca el diseño de Servicios, Oracle ni Azure.
   ========================================================= */

:root {
  --pd-header-height: 78px;
  --pd-header-dark: rgba(6, 17, 31, .94);
  --pd-header-light: rgba(255, 255, 255, .96);
}

/* El header siempre queda fijo y no cambia de altura */
.pd-header,
.pd-header.pd-header--internal,
header.pd-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  height: var(--pd-header-height) !important;
  min-height: var(--pd-header-height) !important;
  max-height: var(--pd-header-height) !important;
  z-index: 999999 !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: none !important;
  overflow: visible !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

/* Compensa la altura del header fijo */
html {
  scroll-padding-top: var(--pd-header-height) !important;
}

body {
  padding-top: var(--pd-header-height) !important;
}

/* Misma distribución interna del header en todas las páginas */
.pd-header .pd-nav,
.pd-header--internal .pd-nav {
  width: min(1180px, calc(100% - 40px)) !important;
  height: var(--pd-header-height) !important;
  min-height: var(--pd-header-height) !important;
  max-height: var(--pd-header-height) !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 24px !important;
  overflow: visible !important;
}

/* Header blanco únicamente en inicio */
.home-page .pd-header {
  background: var(--pd-header-light) !important;
  border-bottom: 1px solid rgba(7, 26, 45, .10) !important;
  box-shadow: 0 10px 35px rgba(6, 17, 31, .08) !important;
}

/* Header oscuro en páginas internas */
.pd-internal-page .pd-header,
.services-page .pd-header,
.oracle-page .pd-header,
.azure-page .pd-header,
.team-page .pd-header,
.polluxdocs-page .pd-header,
.blog-page .pd-header,
.contact-page .pd-header {
  background: var(--pd-header-dark) !important;
  border-bottom: 1px solid rgba(255, 255, 255, .08) !important;
  box-shadow: 0 16px 44px rgba(0, 0, 0, .18) !important;
}

/* En páginas internas: estrella sola, sin burbuja */
.pd-internal-page .pd-brand,
.services-page .pd-brand,
.oracle-page .pd-brand,
.azure-page .pd-brand,
.team-page .pd-brand,
.polluxdocs-page .pd-brand,
.blog-page .pd-brand,
.contact-page .pd-brand {
  width: 78px !important;
  height: 78px !important;
  min-width: 78px !important;
  max-width: 78px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
  line-height: 0 !important;
}

.pd-internal-page .pd-brand img,
.services-page .pd-brand img,
.oracle-page .pd-brand img,
.azure-page .pd-brand img,
.team-page .pd-brand img,
.polluxdocs-page .pd-brand img,
.blog-page .pd-brand img,
.contact-page .pd-brand img {
  width: 72px !important;
  height: 72px !important;
  max-width: 72px !important;
  max-height: 72px !important;
  object-fit: contain !important;
  display: block !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  filter: drop-shadow(0 0 14px rgba(240, 122, 31, .24)) !important;
}

/* En inicio se mantiene el logo completo */
.home-page .pd-brand {
  width: 150px !important;
  min-width: 150px !important;
  height: var(--pd-header-height) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.home-page .pd-brand img {
  width: auto !important;
  max-width: 150px !important;
  height: 58px !important;
  max-height: 58px !important;
  object-fit: contain !important;
  display: block !important;
}

/* Navegación centrada: evita saltos visuales entre páginas */
.pd-nav-links {
  height: var(--pd-header-height) !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

.pd-nav-links > a,
.pd-dropdown-toggle,
.pd-nav-cta {
  height: 46px !important;
  min-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
}

/* Dropdown no debe empujar ni cambiar altura del header */
.pd-nav-dropdown {
  position: relative !important;
  height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  z-index: 1000000 !important;
  overflow: visible !important;
}

.pd-nav-dropdown::after {
  content: "" !important;
  position: absolute !important;
  left: -18px !important;
  right: -18px !important;
  top: 100% !important;
  height: 14px !important;
  background: transparent !important;
  pointer-events: auto !important;
}

.pd-dropdown-menu {
  position: absolute !important;
  top: calc(100% + 8px) !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(6px) !important;
  min-width: 245px !important;
  z-index: 1000001 !important;
  margin: 0 !important;
}

.pd-nav-dropdown:hover .pd-dropdown-menu,
.pd-nav-dropdown:focus-within .pd-dropdown-menu,
.pd-nav-dropdown.open .pd-dropdown-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateX(-50%) translateY(0) !important;
}

/* ===================== END PATCH V28 HEADER ESTABLE ===================== */


/* =========================================================
   HEADER BASE DEFINITIVO V30
   Inicio y páginas internas usan la MISMA CAJA.
   Solo cambian color del header y logo.
   ========================================================= */

:root {
  --pd-header-height: 78px;
  --pd-header-width: min(1240px, calc(100% - 32px));
  --pd-brand-box: 188px;
  --pd-header-light: rgba(255, 255, 255, .96);
  --pd-header-dark: rgba(6, 17, 31, .94);
}

/* Compensa el header fijo */
html {
  scroll-padding-top: var(--pd-header-height) !important;
}

body {
  padding-top: var(--pd-header-height) !important;
}

/* Header único para todas las páginas */
.pd-header,
.pd-header.pd-header--internal,
header.pd-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  height: var(--pd-header-height) !important;
  min-height: var(--pd-header-height) !important;
  max-height: var(--pd-header-height) !important;
  margin: 0 !important;
  padding: 0 !important;
  z-index: 999999 !important;
  overflow: visible !important;
  transform: none !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

/* Inicio: blanco */
body.home-page .pd-header {
  background: var(--pd-header-light) !important;
  border-bottom: 1px solid rgba(7, 26, 45, .10) !important;
  box-shadow: 0 10px 35px rgba(6, 17, 31, .08) !important;
}

/* Internas: navy */
body.services-page .pd-header,
body.oracle-page .pd-header,
body.azure-page .pd-header,
body.team-page .pd-header,
body.polluxdocs-page .pd-header,
body.blog-page .pd-header,
body.contact-page .pd-header,
body.pd-internal-page .pd-header {
  background: var(--pd-header-dark) !important;
  border-bottom: 1px solid rgba(255, 255, 255, .08) !important;
  box-shadow: 0 16px 44px rgba(0, 0, 0, .18) !important;
}

/* Caja interna idéntica */
.pd-header .pd-nav,
.pd-header--internal .pd-nav,
body.home-page .pd-header .pd-nav,
body.services-page .pd-header .pd-nav,
body.oracle-page .pd-header .pd-nav,
body.azure-page .pd-header .pd-nav,
body.pd-internal-page .pd-header .pd-nav {
  width: var(--pd-header-width) !important;
  height: var(--pd-header-height) !important;
  min-height: var(--pd-header-height) !important;
  max-height: var(--pd-header-height) !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 24px !important;
  overflow: visible !important;
  box-sizing: border-box !important;
  background: transparent !important;
}

/* El bloque del logo ocupa SIEMPRE lo mismo.
   Esto evita que el menú se mueva horizontalmente entre páginas. */
.pd-header .pd-brand,
.pd-header .pd-brand--mark,
.pd-header--internal .pd-brand,
.pd-header--internal .pd-brand--mark,
body.home-page .pd-brand,
body.services-page .pd-brand,
body.oracle-page .pd-brand,
body.azure-page .pd-brand,
body.pd-internal-page .pd-brand {
  width: var(--pd-brand-box) !important;
  min-width: var(--pd-brand-box) !important;
  max-width: var(--pd-brand-box) !important;
  height: var(--pd-header-height) !important;
  min-height: var(--pd-header-height) !important;
  max-height: var(--pd-header-height) !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  line-height: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

/* Inicio: logo completo */
body.home-page .pd-brand img {
  width: 188px !important;
  max-width: 188px !important;
  height: auto !important;
  max-height: 60px !important;
  object-fit: contain !important;
  display: block !important;
  filter: drop-shadow(0 8px 18px rgba(7,26,45,.10)) !important;
}

/* Internas: estrella sola, dentro de la misma caja del logo */
body.services-page .pd-brand img,
body.oracle-page .pd-brand img,
body.azure-page .pd-brand img,
body.team-page .pd-brand img,
body.polluxdocs-page .pd-brand img,
body.blog-page .pd-brand img,
body.contact-page .pd-brand img,
body.pd-internal-page .pd-brand img {
  width: 72px !important;
  max-width: 72px !important;
  height: 72px !important;
  max-height: 72px !important;
  object-fit: contain !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  filter: drop-shadow(0 0 14px rgba(240, 122, 31, .24)) !important;
}

/* Links: misma caja vertical y misma posición */
.pd-header .pd-nav-links,
body.home-page .pd-nav-links,
body.services-page .pd-nav-links,
body.oracle-page .pd-nav-links,
body.azure-page .pd-nav-links,
body.pd-internal-page .pd-nav-links {
  height: var(--pd-header-height) !important;
  min-height: var(--pd-header-height) !important;
  max-height: var(--pd-header-height) !important;
  display: flex !important;
  align-items: center !important;
  gap: 26px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
  box-sizing: border-box !important;
}

/* Enlaces y botón de Servicios */
.pd-header .pd-nav-links > a,
.pd-header .pd-dropdown-toggle,
.pd-header .pd-nav-cta {
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  margin: 0 !important;
  white-space: nowrap !important;
  box-sizing: border-box !important;
  font-size: 14px !important;
  font-weight: 750 !important;
  letter-spacing: .02em !important;
}

/* En inicio los links son oscuros */
body.home-page .pd-nav a,
body.home-page .pd-dropdown-toggle {
  color: #09233d !important;
}

/* En internas los links son claros */
body.services-page .pd-nav a,
body.services-page .pd-dropdown-toggle,
body.oracle-page .pd-nav a,
body.oracle-page .pd-dropdown-toggle,
body.azure-page .pd-nav a,
body.azure-page .pd-dropdown-toggle,
body.team-page .pd-nav a,
body.team-page .pd-dropdown-toggle,
body.polluxdocs-page .pd-nav a,
body.polluxdocs-page .pd-dropdown-toggle,
body.blog-page .pd-nav a,
body.blog-page .pd-dropdown-toggle,
body.contact-page .pd-nav a,
body.contact-page .pd-dropdown-toggle,
body.pd-internal-page .pd-nav a,
body.pd-internal-page .pd-dropdown-toggle {
  color: #dbe6f5 !important;
}

/* Hover uniforme */
.pd-header .pd-nav a:hover,
.pd-header .pd-dropdown-toggle:hover {
  color: var(--pd-orange) !important;
  transform: none !important;
}

/* Activo en internas sin cambiar tamaño */
body.services-page .pd-dropdown-toggle.active,
body.oracle-page .pd-dropdown-toggle.active,
body.azure-page .pd-dropdown-toggle.active,
body.pd-internal-page .pd-dropdown-toggle.active {
  color: #ffffff !important;
  background: rgba(255, 255, 255, .09) !important;
  padding-left: 18px !important;
  padding-right: 18px !important;
  border-radius: 999px !important;
}

/* Contacto */
.pd-header .pd-nav-cta {
  padding-left: 16px !important;
  padding-right: 16px !important;
  border-radius: 999px !important;
}

body.home-page .pd-nav-cta {
  color: #09233d !important;
  border: 1px solid rgba(240,122,31,.55) !important;
  background: linear-gradient(135deg, rgba(240,122,31,.16), rgba(240,122,31,.05)) !important;
}

body.services-page .pd-nav-cta,
body.oracle-page .pd-nav-cta,
body.azure-page .pd-nav-cta,
body.pd-internal-page .pd-nav-cta {
  color: #ffffff !important;
  border: 1px solid rgba(240,122,31,.46) !important;
  background: rgba(240,122,31,.06) !important;
}

/* Dropdown: no cambia la altura ni empuja el header */
.pd-header .pd-nav-dropdown {
  position: relative !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  overflow: visible !important;
  z-index: 1000000 !important;
}

.pd-header .pd-nav-dropdown::after {
  content: "" !important;
  position: absolute !important;
  left: -18px !important;
  right: -18px !important;
  top: 100% !important;
  height: 14px !important;
  background: transparent !important;
  pointer-events: auto !important;
}

.pd-header .pd-dropdown-menu {
  position: absolute !important;
  top: calc(100% + 8px) !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(6px) !important;
  min-width: 250px !important;
  display: block !important;
  padding: 14px !important;
  border-radius: 0 0 18px 18px !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  z-index: 1000001 !important;
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease !important;
}

.pd-header .pd-nav-dropdown:hover .pd-dropdown-menu,
.pd-header .pd-nav-dropdown:focus-within .pd-dropdown-menu,
.pd-header .pd-nav-dropdown.open .pd-dropdown-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateX(-50%) translateY(0) !important;
}

/* Dropdown inicio */
body.home-page .pd-dropdown-menu {
  background: rgba(255,255,255,.98) !important;
  border: 1px solid rgba(7,26,45,.10) !important;
  border-top: 3px solid var(--pd-orange) !important;
  box-shadow: 0 24px 60px rgba(6,17,31,.18) !important;
}

body.home-page .pd-dropdown-menu a {
  color: #09233d !important;
}

/* Dropdown internas */
body.services-page .pd-dropdown-menu,
body.oracle-page .pd-dropdown-menu,
body.azure-page .pd-dropdown-menu,
body.pd-internal-page .pd-dropdown-menu {
  background: rgba(6,17,31,.98) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-top: 3px solid var(--pd-orange) !important;
  box-shadow: 0 26px 70px rgba(0,0,0,.32) !important;
}

body.services-page .pd-dropdown-menu a,
body.oracle-page .pd-dropdown-menu a,
body.azure-page .pd-dropdown-menu a,
body.pd-internal-page .pd-dropdown-menu a {
  color: #dbe6f5 !important;
}

/* Mantiene el hero debajo del header fijo */
body.home-page .pd-hero,
body.services-page .pd-services-hero,
body.oracle-page .pd-hero,
body.azure-page .azure-hero {
  margin-top: 0 !important;
}

/* Responsive del header */
@media (max-width: 760px) {
  :root {
    --pd-header-height: 74px;
    --pd-brand-box: 150px;
  }

  body.home-page .pd-brand img {
    width: 150px !important;
    max-width: 150px !important;
    max-height: 54px !important;
  }

  body.services-page .pd-brand img,
  body.oracle-page .pd-brand img,
  body.azure-page .pd-brand img,
  body.pd-internal-page .pd-brand img {
    width: 58px !important;
    height: 58px !important;
    max-width: 58px !important;
    max-height: 58px !important;
  }

  .pd-header .pd-nav {
    width: min(100% - 28px, 1160px) !important;
  }

  .pd-header .pd-nav-links {
    position: absolute !important;
    top: var(--pd-header-height) !important;
    left: 14px !important;
    right: 14px !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: calc(100vh - var(--pd-header-height) - 28px) !important;
    display: none !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
    padding: 18px !important;
    overflow: auto !important;
    border-radius: 0 0 22px 22px !important;
    background: rgba(6,17,31,.98) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    box-shadow: 0 26px 70px rgba(0,0,0,.32) !important;
  }

  .pd-header .pd-nav-links.open,
  .pd-header .pd-nav-links.is-open {
    display: flex !important;
  }

  .pd-header .pd-nav-links > a,
  .pd-header .pd-dropdown-toggle,
  .pd-header .pd-nav-cta {
    width: 100% !important;
    justify-content: flex-start !important;
    color: #ffffff !important;
    padding: 15px 12px !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
  }

  .pd-header .pd-nav-dropdown {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    display: block !important;
  }

  .pd-header .pd-dropdown-menu {
    position: static !important;
    transform: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    min-width: 0 !important;
    box-shadow: none !important;
    border: 0 !important;
    border-left: 3px solid var(--pd-orange) !important;
    border-radius: 0 !important;
    padding: 8px 0 8px 14px !important;
    background: transparent !important;
  }
}

/* ===================== FIN HEADER BASE DEFINITIVO V30 ===================== */


/* =========================================================
   AJUSTE SEGURO HEADER V31
   Solo mueve un poco la caja interna del header.
   No toca footer, secciones, cookies ni diseño general.
   ========================================================= */

:root {
  --pd-header-width: min(1240px, calc(100% - 32px)) !important;
}

.pd-header .pd-nav,
.pd-header--internal .pd-nav,
body.home-page .pd-header .pd-nav,
body.services-page .pd-header .pd-nav,
body.oracle-page .pd-header .pd-nav,
body.azure-page .pd-header .pd-nav,
body.team-page .pd-header .pd-nav,
body.polluxdocs-page .pd-header .pd-nav,
body.blog-page .pd-header .pd-nav,
body.contact-page .pd-header .pd-nav,
body.pd-internal-page .pd-header .pd-nav {
  width: var(--pd-header-width) !important;
}

/* ===================== FIN AJUSTE SEGURO HEADER V31 ===================== */


/* =========================================================
   FIX HEADER NAV SIN SALTO V32
   Evita que el header se mueva entre páginas.
   La "burbuja" activa ya no cambia ancho, alto ni posición.
   ========================================================= */

/* Caja única para cada item del menú */
.pd-header .pd-nav-links > a,
.pd-header .pd-dropdown-toggle {
  width: 126px !important;
  min-width: 126px !important;
  max-width: 126px !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  padding: 0 !important;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
  border: 1px solid transparent !important;
  transform: none !important;
}

/* Contacto tiene su propia caja un poco más ancha */
.pd-header .pd-nav-cta {
  width: 132px !important;
  min-width: 132px !important;
  max-width: 132px !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 999px !important;
}

/* La burbuja activa solo cambia fondo/color, no tamaño */
.pd-header .pd-dropdown-toggle.active,
.pd-header .pd-nav-links > a.active {
  width: 126px !important;
  min-width: 126px !important;
  max-width: 126px !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 999px !important;
  transform: none !important;
}

/* Evita que Servicios se vea con borde de foco negro al hacer click */
.pd-header .pd-dropdown-toggle:focus,
.pd-header .pd-dropdown-toggle:focus-visible,
.pd-header .pd-nav a:focus,
.pd-header .pd-nav a:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

/* Alineación del grupo completo */
.pd-header .pd-nav-links {
  gap: 10px !important;
  align-items: center !important;
}

/* El dropdown queda debajo sin empujar el header */
.pd-header .pd-nav-dropdown {
  width: 126px !important;
  min-width: 126px !important;
  max-width: 126px !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.pd-header .pd-dropdown-menu {
  left: 50% !important;
  top: calc(100% + 8px) !important;
  transform: translateX(-50%) translateY(6px) !important;
}

.pd-header .pd-nav-dropdown:hover .pd-dropdown-menu,
.pd-header .pd-nav-dropdown:focus-within .pd-dropdown-menu,
.pd-header .pd-nav-dropdown.open .pd-dropdown-menu {
  transform: translateX(-50%) translateY(0) !important;
}

/* En pantallas pequeñas se anula el ancho fijo para que el menú móvil respire */
@media (max-width: 760px) {
  .pd-header .pd-nav-links > a,
  .pd-header .pd-dropdown-toggle,
  .pd-header .pd-nav-cta,
  .pd-header .pd-nav-dropdown,
  .pd-header .pd-dropdown-toggle.active,
  .pd-header .pd-nav-links > a.active {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    justify-content: flex-start !important;
  }
}

/* ===================== FIN FIX HEADER NAV SIN SALTO V32 ===================== */


/* =========================================================
   FIX ORACLE HERO TOP V33
   El header ya está alineado; aquí se sube el contenido hero
   de Oracle para que no empiece tan abajo.
   ========================================================= */

body.oracle-page .pd-hero {
  min-height: calc(100vh - var(--pd-header-height, 78px)) !important;
  padding-top: 66px !important;
  padding-bottom: 72px !important;
  display: flex !important;
  align-items: center !important;
}

body.oracle-page .pd-hero-inner {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

body.oracle-page .pd-hero-top {
  align-items: center !important;
}

body.oracle-page .pd-kicker {
  margin-top: 0 !important;
}

/* En pantallas pequeñas dejamos más aire para que no se corte */
@media (max-width: 760px) {
  body.oracle-page .pd-hero {
    padding-top: 46px !important;
    padding-bottom: 58px !important;
    align-items: flex-start !important;
  }
}

/* ===================== FIN FIX ORACLE HERO TOP V33 ===================== */

