@import "../../Styles/root.css";
@import "../../Styles/fonts.css";
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
html {
  padding-bottom: env(safe-area-inset-bottom);
  cursor: var(--cursor);
}

html
  :is(
    a,
    button,
    summary,
    ul li,
    label[for],
    input[type="button"],
    input[type="submit"],
    input[type="reset"],
    input[type="checkbox"],
    input[type="radio"],
    [role="button"],
    [role="link"],
    [onclick],
    [tabindex]
  ) {
  cursor: var(--cursor-pointer) !important;
}

html.selection-active {
  cursor: var(--cursor-select) !important;
}

body {
  margin: 0;
  padding: 0;
  width: 100%;
  overflow-x: hidden;
  background-color: var(--color-bg);
}

/* AJUSTES PARA EL MENÚ */
.menu {
  position: fixed;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: transparent;
  top: 5px;
  padding: 0 30px;
  box-sizing: border-box;
  z-index: 10;
  pointer-events: auto !important;

  /* ÚNICO añadido para animar */
  transition: transform 0.3s ease;
}

/* Oculto al hacer scroll hacia abajo */
.menu.is-hidden {
  transform: translateY(calc(-100% - 10px));
}

.toggle-box {
  display: none;
  position: relative;
  align-items: center;
  justify-content: center;
  background-color: var(--color-bg);
  border: 1px solid var(--color-text);
  height: 50px;
  width: 50px;
  overflow: hidden;
}

.menu-toggle {
  position: relative;
  height: 22px;
  width: 22px;
}

/* Logo */
.menu .logo {
  z-index: 2;
  position: relative;
  top: 5px;
}

.LogoOzz {
  width: 100%;
  height: 100%;
}

.LogoOzz path {
  fill: var(--color-text);
}

/* Navegación */
.nav {
  display: flex;
  list-style: none;
}

.nav-space {
  display: flex;
  gap: 15px;
}

/* Cada elemento de la lista */
.nav-item {
  display: flex;
  justify-content: center;
  align-items: center;
  border: 1px solid var(--color-text);
  position: relative; /* Necesario para el posicionamiento absoluto del pseudo-elemento */
  overflow: hidden; /* Oculta el pseudo-elemento que se desborda */
  background-color: rgba(var(--color-bg-rgb), 0.7);
  z-index: 1; /* Establece un contexto de apilamiento */
}

.nav-item:nth-child(2) {
  border-left: none;
  border-right: none;
}

.nav-item:nth-child(3) {
  border-right: none;
}

.nav-item.active::before {
  height: 100%;
}

/* Igual que .nav-item:hover .nav-link */
.nav-item.active .nav-link {
  color: var(--color-bg);
}

/* Enlaces del menú */
.nav-link {
  display: block;
  padding: 0.75rem 1.5rem;
  text-decoration: none;
  text-align: center;
  font-size: 1rem;
  color: var(--color-text);
  font-family: var(--font-paragraph);
  font-weight: 100;
  position: relative; /* Necesario para el z-index */
  z-index: 2; /* Asegura que el texto esté por encima del efecto */
  transition: color 0.4s; /* Transición solo para el color del texto */
}

.nav-idiom {
  position: relative; /* Necesario para el z-index */
  z-index: 2;
}

/* Pseudo-elemento para el efecto de cortina */
.nav-item::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  background-color: var(--color-text);
  transition: height 0.4s ease;
  z-index: 1;
}

/* Efecto hover */
.nav-item:hover::before {
  height: 100%;
}

.nav-item:hover .nav-link {
  color: var(--color-bg);
}

.nav-item.language {
  display: flex;
  justify-content: center;
  align-items: center;
  border: 1px solid var(--color-bg);
  border-right: none;
  position: relative;
  overflow: hidden;
  background-color: var(--color-text); /* Usa un fallback */
  z-index: 1;
  cursor: pointer;
}

.Language path {
  fill: var(--color-bg); /* Usa variable con fallback */
  transition: fill 0.3s ease; /* Agrega transición si lo deseas */
}

.nav-item.language::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  background-color: var(--color-bg);
  transition: height 0.4s ease;
  z-index: 1;
}

.nav-item.language:hover::before {
  height: 100%;
}

.Language {
  height: 23px;
  margin: 0 15px;
  display: block; /* Asegura que el SVG se muestre correctamente */
  z-index: 2;
}

.nav-item.nav-item.language:hover .Language path {
  fill: var(--color-text);
}

.nav-item.theme {
  display: flex;
  justify-content: center;
  align-items: center;
  border: 1px solid var(--color-bg);
  position: relative;
  overflow: hidden;
  background-color: var(--color-text); /* Usa un fallback */
  z-index: 1;
  cursor: pointer;
}

.nav-item.theme::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  background-color: var(--color-bg);
  transition: height 0.4s ease;
  z-index: 1;
}

.nav-item.theme:hover::before {
  height: 100%;
}

.logo svg {
  height: 70px;
}

#LogoMobile {
  display: none;
}

.FireOzz {
  width: 100%;
  height: 100%;
}

.FireOzz path {
  fill: var(--color-text);
}

.Theme {
  height: 25px;
  margin: 0 15px;
  display: block; /* Asegura que el SVG se muestre correctamente */
  z-index: 2;
}

.Theme.hover-icon {
  display: none;
}

.Theme path {
  fill: var(--color-bg); /* Usa variable con fallback */
  transition: fill 0.3s ease; /* Agrega transición si lo deseas */
}

.nav-item.theme:hover .Theme.default-icon {
  display: none;
}

.nav-item.theme:hover .Theme.hover-icon {
  display: block;
}

.nav-item.theme:hover .Theme.hover-icon path,
.nav-item.theme:hover .Theme.default-icon path {
  fill: var(--color-text);
}
/* --- Responsive: pantallas ≤ 768px --- */
@media (max-width: 768px) {
  .menu {
    padding: 10px 15px;
  }

  .menu .logo {
    z-index: 11;
    position: relative;
    top: 0px;
  }

  .logo svg {
    height: 30px;
    width: 30px;
  }

  .toggle-box {
    display: flex;
    z-index: 11;
    position: relative;
    cursor: pointer;
  }

  #LogoPc {
    display: none;
  }

  #LogoMobile {
    display: block;
    z-index: 11;
    position: relative;
  }

  .nav-space {
    display: flex;
    position: fixed;
    gap: 0;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
    max-height: 100dvh;

    background-color: var(--color-placeholder);
    z-index: 10;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 0;
    padding: 0 15px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s ease, visibility 0.4s ease;
    box-sizing: border-box;
  }

  .nav-space.active {
    opacity: 1;
    visibility: visible;
  }

  .nav-space .nav {
    flex-direction: column;
    align-items: center;
    transform: translateY(20px);
    opacity: 0;
    transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275),
      opacity 0.4s ease;
  }

  .nav-space.active .nav {
    transform: translateY(0);
    opacity: 1;
  }

  .nav-link {
    font-size: 60px;
    padding: 0rem 0;
    transition: color 0.3s ease;
  }

  .nav-item {
    border: none;
    transform: translateY(30px);
    opacity: 0;
    transition: transform 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275),
      opacity 0.4s ease;
    margin: 0;
    padding: 0;
    background-color: transparent;
  }

  .nav-space.active .nav-item {
    transform: translateY(0);
    opacity: 1;
  }

  /* Efecto de resorte para elementos principales */
  .nav-space.active .nav-item:nth-child(1) {
    transition-duration: 0.5s;
  }
  .nav-space.active .nav-item:nth-child(2) {
    transition-duration: 0.55s;
  }
  .nav-space.active .nav-item:nth-child(3) {
    transition-duration: 0.6s;
  }
  .nav-space.active .nav-item:nth-child(4) {
    transition-duration: 0.65s;
  }

  #nav-tools {
    width: 100%;
    display: flex;
    flex-direction: initial;
    position: absolute;
    padding: 5px 15px;
    bottom: 10px;
    left: -5px;
    margin-bottom: 0;
    opacity: 0;
    transition: opacity 0.4s ease, visibility 0.4s ease;
  }

  .nav-space.active #nav-tools {
    opacity: 1;
  }

  .nav-item.language {
    border: 1px solid var(--color-placeholder);
    background-color: var(--color-placeholder);
  }

  .nav-item.language svg path {
    fill: var(--color-text);
  }

  .nav-item.language:hover::before {
    height: 0;
  }

  .Language {
    margin: 0 10px;
  }

  .nav-item.theme {
    border: 1px solid var(--color-placeholder);
    background-color: var(--color-placeholder);
  }

  .Theme {
    margin: 0 10px;
  }

  .nav-item.theme svg path {
    fill: var(--color-text);
  }

  .nav-item.theme:hover::before {
    height: 0;
  }
}
