/* Shared Pro.AI landing shell: navbar + footer */
body > header:not(.topbar):not(.dash-header) {
  align-items: center !important;
  display: flex !important;
  gap: 24px !important;
  justify-content: space-between !important;
  z-index: 1000 !important;
  transition: width 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              max-width 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              background 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              border-color 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              padding 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

body > header:not(.topbar):not(.dash-header)::after {
  display: none !important;
}

/* Estilo de cápsula flotante premium para Desktop (min-width: 1025px) como en index.html */
@media (min-width: 1025px) {
  body > header:not(.topbar):not(.dash-header) {
    position: fixed !important;
    top: 20px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 95% !important;
    max-width: 1400px !important;
    background: rgba(255, 255, 255, 0.02) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 20px !important;
    padding: 12px 24px !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3) !important;
  }
  
  body > header:not(.topbar):not(.dash-header).scrolled {
    width: 92% !important;
    max-width: 1300px !important;
    background: rgba(0, 0, 0, 0.85) !important;
    border-color: rgba(255, 255, 255, 0.12) !important;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6) !important;
    padding: 10px 24px !important;
  }
}

body > header:not(.topbar):not(.dash-header) .logo {
  align-items: center !important;
  color: oklch(0.98 0.004 160) !important;
  display: inline-flex !important;
  font-family: var(--font-heading, "Outfit", system-ui, sans-serif) !important;
  font-size: 1.35rem !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

body > header:not(.topbar):not(.dash-header) .logo span,
footer .footer-logo span {
  color: var(--indigo, oklch(0.7 0.15 160)) !important;
}

body > header:not(.topbar):not(.dash-header) .nav-links {
  align-items: center !important;
  display: flex !important;
  gap: clamp(14px, 2vw, 28px) !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
}

body > header:not(.topbar):not(.dash-header) .nav-links a {
  color: oklch(0.62 0.006 160) !important;
  display: inline-flex !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  transition: color 0.18s ease !important;
  white-space: nowrap !important;
}

body > header:not(.topbar):not(.dash-header) .nav-links a:hover,
body > header:not(.topbar):not(.dash-header) .nav-links a.active {
  color: var(--indigo, oklch(0.7 0.15 160)) !important;
}

body > header:not(.topbar):not(.dash-header) > div:last-child {
  align-items: center !important;
  display: flex !important;
  gap: 10px !important;
}

body > header:not(.topbar):not(.dash-header) .nav-login-btn,
body > header:not(.topbar):not(.dash-header) .nav-cta {
  align-items: center !important;
  border-radius: 8px !important;
  display: inline-flex;
  font-family: var(--font-heading, "Outfit", system-ui, sans-serif) !important;
  font-size: 0.9rem !important;
  font-weight: 800 !important;
  gap: 8px !important;
  min-height: 38px !important;
  padding: 8px 16px !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

body > header:not(.topbar):not(.dash-header) .nav-login-btn {
  background: oklch(1 0 0 / 0.035) !important;
  border: 1px solid oklch(1 0 0 / 0.11) !important;
  color: oklch(0.95 0.004 160) !important;
}

body > header:not(.topbar):not(.dash-header) .nav-cta {
  background: var(--indigo, oklch(0.7 0.15 160)) !important;
  border: 1px solid var(--indigo, oklch(0.7 0.15 160)) !important;
  color: oklch(0.06 0.012 160) !important;
}

body > header:not(.topbar):not(.dash-header) .nav-cta-badge {
  background: oklch(0.06 0.012 160 / 0.15) !important;
  border-radius: 999px !important;
  color: oklch(0.06 0.012 160) !important;
  font-size: 0.68rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  margin-left: 2px !important;
  padding: 4px 8px !important;
}

footer:not(.proai-footer) {
  align-items: center !important;
  background: oklch(0.045 0.006 160) !important;
  border-top: 1px solid oklch(1 0 0 / 0.08) !important;
  color: oklch(0.62 0.006 160) !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  justify-content: space-between !important;
  padding: 40px 5% !important;
}

footer:not(.proai-footer) .footer-logo {
  color: oklch(0.98 0.004 160) !important;
  font-family: var(--font-heading, "Outfit", system-ui, sans-serif) !important;
  font-size: 1.15rem !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-decoration: none !important;
}

footer:not(.proai-footer) .footer-links {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 18px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

footer:not(.proai-footer) .footer-links a,
footer:not(.proai-footer) .footer-copy {
  color: oklch(0.62 0.006 160) !important;
  font-size: 0.85rem !important;
  text-decoration: none !important;
}

footer:not(.proai-footer) .footer-links a:hover {
  color: oklch(0.98 0.004 160) !important;
}

footer:not(.proai-footer) .footer-social {
  align-items: center !important;
  border: 1px solid oklch(1 0 0 / 0.1) !important;
  border-radius: 999px !important;
  color: oklch(0.62 0.006 160) !important;
  display: inline-flex !important;
  gap: 8px !important;
  min-height: 34px !important;
  padding: 7px 13px !important;
  text-decoration: none !important;
}

footer:not(.proai-footer) .footer-social:hover {
  background: oklch(0.7 0.15 160 / 0.08) !important;
  border-color: oklch(0.7 0.15 160 / 0.3) !important;
  color: oklch(0.98 0.004 160) !important;
}

/* Para pantallas de laptop comunes y medianas (1025px a 1480px) */
@media (max-width: 1480px) and (min-width: 1025px) {
  .nav-cta-price,
  .nav-cta-badge {
    display: none !important;
  }
  body > header:not(.topbar):not(.dash-header) {
    gap: clamp(10px, 1.2vw, 20px) !important;
    padding: 10px 24px !important;
  }
  .logo {
    font-size: 1.15rem !important;
  }
  .nav-links {
    gap: clamp(10px, 1.2vw, 20px) !important;
  }
  .nav-links a {
    font-size: 0.82rem !important;
  }
  .nav-login-btn, .nav-cta {
    font-size: 0.82rem !important;
    padding: 5px 12px !important;
    min-height: 32px !important;
  }
}

/* El menú móvil hamburguesa se activa a partir de los 1024px hacia abajo */
@media (max-width: 1024px) {
  body > header:not(.topbar):not(.dash-header) {
    border-radius: 0 !important;
    margin: 0 !important;
    min-height: 58px !important;
    padding: 12px 24px !important;
    width: 100% !important;
    max-width: 100vw !important;
    position: sticky !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    background: oklch(0.055 0.006 160 / 0.92) !important;
    border: none !important;
    border-bottom: 1px solid oklch(1 0 0 / 0.08) !important;
    box-shadow: none !important;
  }

  body > header:not(.topbar):not(.dash-header).scrolled {
    background: oklch(0.045 0.006 160 / 0.97) !important;
    border-bottom-color: oklch(0.78 0.14 160 / 0.28) !important;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.5) !important;
    padding: 10px 24px !important;
  }

  body > header:not(.topbar):not(.dash-header) .nav-links {
    align-items: flex-start !important;
    background: oklch(0.055 0.006 160 / 0.98) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    border: none !important;
    border-bottom: 1px solid oklch(1 0 0 / 0.08) !important;
    border-radius: 0 !important;
    box-shadow: 0 10px 30px oklch(0 0 0 / 0.3) !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    left: 0 !important;
    opacity: 0 !important;
    padding: 14px 24px !important;
    pointer-events: none !important;
    position: fixed !important;
    right: 0 !important;
    top: 58px !important;
    transform: translateY(-12px) !important;
    width: 100% !important;
    z-index: 199 !important;
  }

  body > header:not(.topbar):not(.dash-header) .nav-links.open {
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
  }

  body > header:not(.topbar):not(.dash-header) .nav-links li {
    border-bottom: 1px solid oklch(1 0 0 / 0.08) !important;
    width: 100% !important;
  }

  body > header:not(.topbar):not(.dash-header) .nav-links li:last-child {
    border-bottom: 0 !important;
  }

  body > header:not(.topbar):not(.dash-header) .nav-links a {
    display: block !important;
    font-size: 1rem !important;
    padding: 14px 0 !important;
    width: 100% !important;
  }

  body > header:not(.topbar):not(.dash-header) .nav-hamburger {
    display: inline-flex !important;
  }
}

@media (max-width: 720px) {
  body > header:not(.topbar):not(.dash-header) #nav-login-btn {
    display: none !important;
  }
}

@media (max-width: 560px) {
  body > header:not(.topbar):not(.dash-header) .nav-cta {
    max-width: 128px !important;
    overflow: hidden !important;
    padding-inline: 12px !important;
    text-overflow: ellipsis !important;
  }

  body > header:not(.topbar):not(.dash-header) .nav-cta-badge,
  body > header:not(.topbar):not(.dash-header) .nav-cta-price {
    display: none !important;
  }
}

/* ── Selector de Idiomas Premium (Google Translate Custom styling) ── */
.lang-selector {
  position: relative;
  display: inline-block;
}

.lang-selector-btn {
  background: rgba(255, 255, 255, 0.035) !important;
  border: 1px solid rgba(255, 255, 255, 0.11) !important;
  border-radius: 8px !important;
  color: oklch(0.95 0.004 160) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  min-height: 38px !important;
  padding: 8px 12px !important;
  cursor: pointer;
  font-family: var(--font-heading, "Outfit", system-ui, sans-serif) !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  transition: all 0.2s ease !important;
  user-select: none;
}

.lang-selector-btn:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.2) !important;
}

.lang-selector-btn .globe-icon {
  opacity: 0.8;
  color: var(--indigo, #10b981) !important;
}

.lang-selector-btn .chevron-icon {
  opacity: 0.6;
  transition: transform 0.2s ease;
}

.lang-selector.open .chevron-icon {
  transform: rotate(180deg);
}

.lang-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  background: oklch(0.055 0.006 160 / 0.98) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 12px !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5) !important;
  min-width: 120px;
  padding: 6px !important;
  display: flex;
  flex-direction: column;
  gap: 4px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity 0.2s ease, transform 0.2s ease !important;
  z-index: 1100 !important;
}

.lang-selector.open .lang-dropdown {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.lang-option {
  background: transparent !important;
  border: none !important;
  border-radius: 6px !important;
  color: oklch(0.7 0.004 160) !important;
  padding: 8px 12px !important;
  text-align: left !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  cursor: pointer;
  width: 100% !important;
  transition: all 0.15s ease !important;
  display: block !important;
}

.lang-option:hover {
  background: rgba(255, 255, 255, 0.05) !important;
  color: #ffffff !important;
}

.lang-option.active {
  background: rgba(16, 185, 129, 0.1) !important;
  color: var(--indigo, #10b981) !important;
}

/* Ocultar barra superior y branding de Google Translate */
.skiptranslate, iframe.goog-te-banner-frame {
  display: none !important;
}
body {
  top: 0 !important;
}
.goog-te-gadget {
  font-family: inherit !important;
}
.goog-te-combo {
  display: none !important;
}

/* Refuerzo visual del selector de idioma en el shell compartido */
body > header:not(.topbar):not(.dash-header) .lang-selector {
  flex-shrink: 0;
  line-height: 1;
  z-index: 230;
}

body > header:not(.topbar):not(.dash-header) .lang-selector-btn {
  background: oklch(1 0 0 / 0.045) !important;
  border: 1px solid oklch(1 0 0 / 0.12) !important;
  border-radius: 10px !important;
  box-shadow: inset 0 1px 0 oklch(1 0 0 / 0.055) !important;
  color: oklch(0.96 0.004 160) !important;
  display: grid !important;
  grid-template-columns: 24px minmax(26px, 1fr) 10px !important;
  min-height: 38px !important;
  min-width: 108px !important;
  padding: 6px 10px !important;
  position: relative !important;
}

body > header:not(.topbar):not(.dash-header) .lang-selector-btn::before {
  color: oklch(0.68 0.006 160) !important;
  content: "Idioma";
  font-family: var(--font-heading, "Outfit", system-ui, sans-serif) !important;
  font-size: 0.58rem !important;
  font-weight: 800 !important;
  left: 42px;
  letter-spacing: 0 !important;
  line-height: 1;
  position: absolute;
  top: 7px;
}

body > header:not(.topbar):not(.dash-header) .lang-selector-btn:hover,
body > header:not(.topbar):not(.dash-header) .lang-selector.open .lang-selector-btn {
  background: oklch(0.7 0.15 160 / 0.105) !important;
  border-color: oklch(0.7 0.15 160 / 0.34) !important;
}

body > header:not(.topbar):not(.dash-header) .lang-selector-btn .globe-icon {
  align-self: center !important;
  background: oklch(0.7 0.15 160 / 0.14) !important;
  border: 1px solid oklch(0.7 0.15 160 / 0.22) !important;
  border-radius: 7px !important;
  color: var(--indigo, oklch(0.7 0.15 160)) !important;
  height: 24px !important;
  justify-self: start !important;
  opacity: 1 !important;
  padding: 4px !important;
  width: 24px !important;
}

body > header:not(.topbar):not(.dash-header) .lang-selector-btn .lang-current {
  align-self: end !important;
  color: oklch(0.98 0.004 160) !important;
  font-size: 0.78rem !important;
  font-weight: 900 !important;
  grid-column: 2 !important;
  justify-self: start !important;
  line-height: 1;
  margin-top: 12px;
}

body > header:not(.topbar):not(.dash-header) .lang-selector-btn .chevron-icon {
  align-self: center !important;
  grid-column: 3 !important;
  justify-self: end !important;
  opacity: 0.72 !important;
}

body > header:not(.topbar):not(.dash-header) .lang-dropdown {
  border-radius: 10px !important;
  box-shadow: 0 18px 44px oklch(0 0 0 / 0.45) !important;
  min-width: 176px !important;
  padding: 8px !important;
}

body > header:not(.topbar):not(.dash-header) .lang-option {
  align-items: center !important;
  border: 1px solid transparent !important;
  display: flex !important;
  justify-content: space-between !important;
  min-height: 36px !important;
}

body > header:not(.topbar):not(.dash-header) .lang-option::after {
  color: oklch(0.58 0.006 160) !important;
  font-size: 0.68rem !important;
  font-weight: 900 !important;
}

body > header:not(.topbar):not(.dash-header) .lang-option[data-lang="es"]::after {
  content: "ES";
}

body > header:not(.topbar):not(.dash-header) .lang-option[data-lang="en"]::after {
  content: "EN";
}

body > header:not(.topbar):not(.dash-header) .lang-option[data-lang="fr"]::after {
  content: "FR";
}

body > header:not(.topbar):not(.dash-header) .lang-option.active {
  border-color: oklch(0.7 0.15 160 / 0.2) !important;
}

body > header:not(.topbar):not(.dash-header) .lang-option.active::after {
  color: var(--indigo, oklch(0.7 0.15 160)) !important;
}

@media (max-width: 1180px) {
  body > header:not(.topbar):not(.dash-header) .lang-selector-btn {
    min-width: 78px !important;
  }

  body > header:not(.topbar):not(.dash-header) .lang-selector-btn::before {
    display: none !important;
  }

  body > header:not(.topbar):not(.dash-header) .lang-selector-btn .lang-current {
    align-self: center !important;
    margin-top: 0;
  }
}

.proai-shell-header {
  align-items: center !important;
  display: flex !important;
  gap: 24px !important;
  justify-content: space-between !important;
  z-index: 1000 !important;
  transition: width 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              max-width 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              background 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              border-color 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              padding 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.proai-shell-header::after {
  display: none !important;
}

@media (min-width: 1025px) {
  .proai-shell-header {
    background: rgba(255, 255, 255, 0.02) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 20px !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3) !important;
    left: 50% !important;
    max-width: 1400px !important;
    padding: 12px 24px !important;
    position: fixed !important;
    top: 20px !important;
    transform: translateX(-50%) !important;
    width: 95% !important;
  }

  .proai-shell-header.scrolled {
    background: rgba(0, 0, 0, 0.85) !important;
    border-color: rgba(255, 255, 255, 0.12) !important;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6) !important;
    max-width: 1300px !important;
    padding: 10px 24px !important;
    width: 92% !important;
  }
}

.proai-shell-header .logo {
  align-items: center !important;
  color: oklch(0.98 0.004 160) !important;
  display: inline-flex !important;
  font-family: var(--font-heading, "Outfit", system-ui, sans-serif) !important;
  font-size: 1.35rem !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.proai-shell-header .logo span {
  color: var(--indigo, oklch(0.7 0.15 160)) !important;
}

.proai-shell-header .nav-links {
  align-items: center !important;
  display: flex !important;
  gap: clamp(14px, 2vw, 28px) !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
}

.proai-shell-header .nav-links a {
  color: oklch(0.62 0.006 160) !important;
  display: inline-flex !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  transition: color 0.18s ease !important;
  white-space: nowrap !important;
}

.proai-shell-header .nav-links a:hover,
.proai-shell-header .nav-links a.active {
  color: var(--indigo, oklch(0.7 0.15 160)) !important;
}

.proai-shell-header > .nav-actions {
  align-items: center !important;
  display: flex !important;
  gap: 10px !important;
}

.proai-shell-header .nav-login-btn,
.proai-shell-header .nav-cta {
  align-items: center !important;
  border-radius: 8px !important;
  display: inline-flex !important;
  font-family: var(--font-heading, "Outfit", system-ui, sans-serif) !important;
  font-size: 0.9rem !important;
  font-weight: 800 !important;
  gap: 8px !important;
  min-height: 38px !important;
  padding: 8px 16px !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.proai-shell-header .nav-login-btn {
  background: oklch(1 0 0 / 0.035) !important;
  border: 1px solid oklch(1 0 0 / 0.11) !important;
  color: oklch(0.95 0.004 160) !important;
}

.proai-shell-header .lang-selector {
  flex: 0 0 auto !important;
}

.proai-shell-header .lang-selector-btn {
  background: oklch(1 0 0 / 0.035) !important;
  border: 1px solid oklch(1 0 0 / 0.11) !important;
  border-radius: 8px !important;
  color: oklch(0.95 0.004 160) !important;
  font-family: var(--font-heading, "Outfit", system-ui, sans-serif) !important;
  font-size: 0.82rem !important;
  font-weight: 800 !important;
  min-height: 38px !important;
  padding: 8px 12px !important;
}

.proai-shell-header .lang-selector-btn:hover,
.proai-shell-header .lang-selector.open .lang-selector-btn {
  background: oklch(1 0 0 / 0.07) !important;
  border-color: oklch(1 0 0 / 0.18) !important;
  color: oklch(0.98 0.004 160) !important;
}

.proai-shell-header .lang-dropdown {
  background: oklch(0.08 0.01 160 / 0.98) !important;
  border-color: oklch(1 0 0 / 0.12) !important;
}

.proai-shell-header .lang-option {
  color: oklch(0.82 0.006 160) !important;
}

.proai-shell-header .lang-option.active {
  background: oklch(0.7 0.15 160 / 0.12) !important;
  color: oklch(0.98 0.004 160) !important;
}

@media (max-width: 1480px) and (min-width: 1025px) {
  .proai-shell-header {
    gap: clamp(10px, 1.2vw, 20px) !important;
    padding: 10px 24px !important;
  }

  .proai-shell-header .logo {
    font-size: 1.15rem !important;
  }

  .proai-shell-header .nav-links {
    gap: clamp(10px, 1.2vw, 20px) !important;
  }

  .proai-shell-header .nav-links a,
  .proai-shell-header .nav-login-btn {
    font-size: 0.82rem !important;
  }

  .proai-shell-header .nav-login-btn {
    min-height: 32px !important;
    padding: 5px 12px !important;
  }
}

@media (max-width: 1024px) {
  .proai-shell-header {
    background: rgba(8, 10, 18, 0.96) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    left: 0 !important;
    padding: 14px 5% !important;
    position: fixed !important;
    top: 0 !important;
    transform: none !important;
    width: 100% !important;
  }

  .proai-shell-header .nav-links {
    background: rgba(8, 10, 18, 0.98) !important;
  }

  .proai-shell-header .nav-hamburger {
    display: flex !important;
  }
}
