/* Custom Font Faces */
@font-face {
  font-family: 'Helvetica Neue';
  src: url('https://storage.miragemusic.ch/fonts/helvetica-neue/HelveticaNeueRoman.woff2') format('woff2'),
       url('https://storage.miragemusic.ch/fonts/helvetica-neue/HelveticaNeueRoman.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Helvetica Neue';
  src: url('https://storage.miragemusic.ch/fonts/helvetica-neue/HelveticaNeueBold.woff2') format('woff2'),
       url('https://storage.miragemusic.ch/fonts/helvetica-neue/HelveticaNeueBold.woff') format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Helvetica Neue';
  src: url('https://storage.miragemusic.ch/fonts/helvetica-neue/HelveticaNeueBlack.woff2') format('woff2'),
       url('https://storage.miragemusic.ch/fonts/helvetica-neue/HelveticaNeueBlack.woff') format('woff');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg-color: #ffffff;
  --text-color: #000000;
  --hover-transition: 0.4s cubic-bezier(0.25, 1, 0.5, 1);
}

body {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  background-color: var(--bg-color);
  color: var(--text-color);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin: 0;
  padding: 0;
}

/* Classe custom per tanto margine verticale (Bootstrap si ferma a 5) */
.my-7 {
  margin-top: 6rem !important;
  margin-bottom: 6rem !important;
}

/* Typographic Settings */
.logo-text {
  font-weight: 900;
  /* Forza la variante "Black" del font */
  font-size: clamp(3.5rem, 8vw, 8rem);
  letter-spacing: -0.04em;
  line-height: 0.9;
}

.nav-link-item {
  font-weight: 700;
  text-decoration: none;
  color: var(--text-color);
  text-transform: uppercase;
  line-height: 1;
  position: relative;
  padding: 0.1em 0;
  white-space: nowrap;
  /* Hit area remains fixed in space, preventing flicker */
  display: block;
}

.nav-link-text {
  display: inline-block;
  transition: opacity var(--hover-transition), transform var(--hover-transition), letter-spacing var(--hover-transition);
}

.nav-container .nav-link-item:hover .nav-link-text {
  opacity: 1;
  transform: translateX(-20px);
  letter-spacing: 0.02em;
}

/* Animated Underline */
.nav-link-text::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0%;
  height: 3px;
  background-color: var(--text-color);
  transition: width var(--hover-transition);
}

.nav-link-item:hover .nav-link-text::after {
  width: 100%;
}

/* Desktop Navigation Alignments */
@media (min-width: 992px) {
  .nav-link-text::after {
    left: auto;
    right: 0;
    /* Draw underline da destra a sinistra */
  }

  .nav-container .nav-link-item:hover .nav-link-text {
    transform: translateX(-20px);
    /* Move back towards the center */
  }
}

/* Disabled / Coming Soon states */
.nav-link-disabled {
  color: #c0c0c0 !important;
  pointer-events: none;
  cursor: default;
}

.nav-link-disabled::after {
  display: none !important;
  /* Forza la rimozione dell'underline animato */
}

.nav-link-disabled-wrapper {
  gap: 0;
}

.coming-soon-badge {
  font-size: 0.5em;
  opacity: 0.6;
  margin-top: -0.2em;
}

.footer-email {
  text-decoration: none;
  color: var(--text-color);
  font-weight: 500;
  transition: opacity var(--hover-transition);
}

.footer-email:hover {
  opacity: 0.5;
}

.event-footer-icon {
  width: 20px;
  height: 20px;
  transition: transform var(--hover-transition);
  display: inline-block;
}

.event-footer-icon:hover {
  transform: scale(1.1);
}

.event-footer-logo {
  transition: opacity 0.3s ease;
  cursor: pointer;
}

.event-footer-logo:hover {
  opacity: 1 !important;
}

.footer-brand {
  font-weight: 900;
  letter-spacing: -0.02em;
}