@charset "utf-8";

/* ============================
   MAGICAL HORIZONTAL MAIN MENU
   ============================ */

.magic-menu {
  margin: 1.8rem auto 2.2rem;
  max-width: 1100px;
  z-index: 10;
  position: relative;
}

/* Mobile toggle button (hidden on desktop) */
.menu-toggle {
  display: none;
  border: 1px solid rgba(214,187,255,0.6);
  border-radius: 999px;
  padding: 10px 14px;
  background: rgba(25, 10, 45, 0.65);
  color: #fdf3ff;
  font-family: 'Cinzel', serif;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
}

/* Glowing purple bar */
.magic-menu > ul {
  list-style: none;
  margin: 0;
  padding: 0.55rem 1.4rem;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.4rem;
  flex-wrap: wrap;

  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,0.18), transparent 60%),
    linear-gradient(135deg, #3b0b63, #5b1591, #391e77);
  border-radius: 999px;
  box-shadow:
    0 0 0 1px rgba(212, 187, 255, 0.6),
    0 16px 30px rgba(0,0,0,0.8),
    0 0 18px rgba(176,126,255,0.9);
}

.magic-menu > ul > li {
  position: relative;
  display: flex;
  align-items: center;
}

/* Top-level links */
.magic-menu > ul > li > a {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;

  padding: 0.45rem 0.95rem;
  border-radius: 999px;

  color: #fbe8ff;
  text-decoration: none;
  font-family: 'Cinzel', serif;
  font-size: 0.9rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;

  border: 1px solid transparent;
  background: radial-gradient(circle at 50% 0%, rgba(255,255,255,0.15), transparent 60%);
  transition:
    background 160ms ease,
    color 120ms ease,
    box-shadow 160ms ease,
    transform 120ms ease,
    border-color 160ms ease;
}

.magic-menu > ul > li > a span:first-child {
  font-size: 1.05rem;
}

.magic-menu > ul > li > a:hover,
.magic-menu > ul > li > a:focus-visible {
  color: #fff7ff;
  transform: translateY(-1px);
  border-color: rgba(221, 191, 255, 0.9);
  box-shadow:
    0 0 10px rgba(223,188,255,0.95),
    0 8px 18px rgba(0,0,0,0.9);
}

.magic-menu > ul > li > a.active {
  color: #fff9e6;
  border-color: rgba(248, 214, 140, 0.95);
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,0.22), transparent 60%),
    linear-gradient(135deg, #c7903f, #eaca77);
  box-shadow:
    0 0 14px rgba(255,228,145,0.95),
    0 10px 22px rgba(0,0,0,1);
}

/* ============================
   DROPDOWNS (desktop default)
   ============================ */

.magic-menu .has-dropdown {
  position: relative;
}

/* Invisible hover bridge so the menu doesn't collapse while moving into it */
.magic-menu .has-dropdown::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 14px;
}

/* Dropdown panel */
.magic-menu .dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  margin-top: 0; /* remove gap */
  transform: translateX(-50%) translateY(6px) scale(0.98);
  transform-origin: top center;

  list-style: none;
  padding: 0.4rem 0.55rem;
  min-width: 180px;

  background:
    radial-gradient(circle at 0% 0%, rgba(255,255,255,0.14), transparent 70%),
    linear-gradient(135deg, #1f0b32, #31174c);
  border-radius: 14px;
  border: 1px solid rgba(214, 187, 255, 0.7);
  box-shadow:
    0 14px 30px rgba(0,0,0,0.9),
    0 0 16px rgba(179,140,255,0.95);

  opacity: 0;
  visibility: hidden;
  pointer-events: none;

  transition:
    opacity 120ms ease,
    transform 120ms ease,
    visibility 0s linear 120ms;
  z-index: 25;
}

/* Show dropdown on hover/focus (desktop) */
.magic-menu .has-dropdown:hover > .dropdown,
.magic-menu .has-dropdown:focus-within > .dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0) scale(1);
  transition:
    opacity 120ms ease,
    transform 120ms ease,
    visibility 0s;
}

/* Optional: slightly delay closing to prevent flicker */
.magic-menu .has-dropdown:not(:hover):not(:focus-within) > .dropdown {
  transition-delay: 180ms;
}

.magic-menu .dropdown li {
  margin: 0.15rem 0;
}

.magic-menu .dropdown a {
  display: flex;
  align-items: center;
  gap: 0.45rem;

  padding: 0.25rem 0.6rem;
  border-radius: 999px;

  color: #f2e7ff;
  text-decoration: none;
  font-size: 0.86rem;
  font-family: 'Crimson Pro', serif;
  letter-spacing: 0.04em;
  white-space: nowrap;

  transition: background 130ms ease, color 130ms ease, transform 110ms ease;
}

.magic-menu .dropdown a:hover,
.magic-menu .dropdown a:focus-visible {
  background: rgba(242, 208, 255, 0.16);
  color: #ffffff;
  transform: translateX(1px);
}

/* ============================
   RESPONSIVE TWEAKS
   ============================ */

@media (max-width: 900px) {
  .magic-menu > ul {
    gap: 0.8rem;
    padding-inline: 0.9rem;
  }

  .magic-menu > ul > li > a {
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    padding: 0.4rem 0.8rem;
  }
}

/* ============================
   MOBILE MODE (hamburger + tap dropdown)
   ============================ */

@media (max-width: 720px) {
  .magic-menu {
    padding: 0 12px;
  }

  .menu-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 10px 0;
  }

  /* hide list until opened */
  .magic-menu > ul {
    display: none;
    padding: 10px 12px;
    border-radius: 18px; /* less pill-like when vertical */
  }

  .magic-menu.is-open > ul {
    display: block;
  }

  /* vertical stack */
  .magic-menu > ul > li {
    display: block;
  }

  .magic-menu > ul > li > a {
    display: flex;
    justify-content: space-between;
    width: 100%;
  }

  /* dropdown becomes in-flow */
  .magic-menu .dropdown {
    position: static;
    left: auto;
    margin-top: 8px;
    transform: none;

    min-width: 0;
    width: 100%;

    display: none;          /* mobile closed */
    opacity: 1;             /* no fade tricks needed in flow */
    visibility: visible;
    pointer-events: auto;
  }

  /* Tap open via JS adding .open */
  .magic-menu .has-dropdown.open > .dropdown {
    display: block;
  }

  /* Don’t use the invisible hover bridge in mobile mode */
  .magic-menu .has-dropdown::after {
    display: none;
  }
}
@media (max-width: 720px) {
  .magic-menu {
    margin: 0.6rem auto 1.2rem; /* was 1.8rem auto 2.2rem */
  }
}
/* Keep dropdowns inside the viewport on narrower screens */
@media (max-width: 980px) {
  .magic-menu .dropdown {
    left: 0;                 /* anchor to the parent li */
    right: auto;
    transform: translateY(6px) scale(0.98); /* remove -50% centering */
    max-width: calc(100vw - 24px);
  }

  .magic-menu .has-dropdown:hover > .dropdown,
  .magic-menu .has-dropdown:focus-within > .dropdown {
    transform: translateY(0) scale(1);
  }
}
@media (max-width: 980px) {
  .magic-menu .dropdown {
    left: 0;
    transform: translateY(6px) scale(0.98);
    max-width: calc(100vw - 24px);
  }

  /* If the item is the last one(s), align the dropdown to the right */
  .magic-menu > ul > li:last-child .dropdown,
  .magic-menu > ul > li:nth-last-child(2) .dropdown {
    left: auto;
    right: 0;
  }
}
@media (max-width: 720px) {
  .site-header { margin: 1rem auto 0.6rem; }
  .magic-menu  { margin: 0.4rem auto 1.2rem; }
}
@media (max-width: 720px) {
  .magic-menu .dropdown .mobile-parent-link a {
    font-family: 'Cinzel', serif;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    border: 1px solid rgba(248, 214, 140, 0.55);
    background: rgba(248, 214, 140, 0.10);
  }
}
@media (max-width: 720px) {
  .magic-menu {
    /* force open by default */
  }

  .magic-menu > ul {
    display: block;
  }
}