/* nav.css — CLEAN REPLACE (Header + Overlay Nav + Radial Fan + Social Stack) */

/* =========================
   HEADER — LEFT RAIL
========================= */

.site-header{
  position:fixed;
  inset:0 auto 0 0;
  width:88px;
  z-index:200; /* rail stays high, but radial will be higher */
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:stretch;
  padding:20px 0 24px;
  background:radial-gradient(circle at top, rgba(9,53,61,0.96), rgba(4,25,29,0.97));
  border-right:1px solid rgba(232,247,245,0.06);
  backdrop-filter: blur(18px);
}

.header-inner{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  align-items:center;
  gap:32px;
}

.header-top{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
}

.brand{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  text-align:center;
}

.brand-logo{
  font-weight:700;
  letter-spacing:0.18em;
  font-size:11px;
  text-transform:uppercase;
  position:relative;
  cursor:pointer;
  padding:4px 8px;
  border-radius:999px;
}

.brand-logo::before{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius:inherit;
  background:radial-gradient(circle, rgba(105,232,217,0.5), rgba(105,232,217,0) 70%);
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
  z-index:-1;
}
.brand-logo::after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:inherit;
  border:1px solid rgba(105,232,217,0.45);
  box-shadow:0 0 10px rgba(105,232,217,0.6);
  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
}

/* idle breathing when menu closed */
body:not(.menu-open) .brand-logo::before,
body:not(.menu-open) .brand-logo::after{
  opacity:1;
  animation: menuGlow 2.2s ease-in-out infinite;
}

/* softer static when menu open */
body.menu-open .brand-logo::before,
body.menu-open .brand-logo::after{
  opacity:.6;
  animation:none;
}

.brand-tagline{
  font-size:10px;
  color:var(--text-muted);
}

/* burger */
.menu-toggle{
  width:32px;
  height:32px;
  border-radius:999px;
  border:1px solid rgba(232,247,245,0.14);
  background:rgba(4,25,29,0.9);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  padding:0;
  box-shadow:0 0 10px rgba(105,232,217,0.4);
  transition:border-color var(--transition-fast),
             box-shadow var(--transition-fast),
             transform var(--transition-fast),
             background var(--transition-fast);
  animation: menuGlow 2.2s ease-in-out infinite;
}

.menu-toggle-icon{
  font-size:16px;
  line-height:1;
  color:var(--text-muted);
  transition:transform var(--transition-fast),
             color var(--transition-fast),
             opacity var(--transition-fast);
}

.menu-toggle:hover{
  border-color:var(--accent-strong);
  box-shadow:0 0 12px rgba(105,232,217,0.7);
  background:radial-gradient(circle at top, rgba(13,82,88,0.95), rgba(4,25,29,0.98));
}

body.menu-open .menu-toggle{
  transform: rotate(90deg);
  animation:none;
  box-shadow:0 0 12px rgba(105,232,217,0.7);
}
body.menu-open .menu-toggle-icon{
  transform: rotate(90deg);
  color:var(--accent-strong);
}

/* center burger on desktop */
@media (min-width:960px){
  .menu-toggle{
    position:absolute;
    top:50%;
    left:50%;
    margin-top:-16px;
    margin-left:-16px;
  }
}
@media (max-width:959.98px){
  .menu-toggle{ position:static; margin:0; }
}

/* =========================
   SOCIAL HUB (BOTTOM-LEFT)
   Same style as radial
========================= */

.header-bottom{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

/* social container */
.social-toggle{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

/* expandable stack */
.social-stack{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  max-height:0;
  opacity:0;
  transform: translateY(10px);
  pointer-events:none;
  overflow:hidden;
  transition:max-height 260ms ease, opacity 220ms ease, transform 260ms ease;
}

body.social-open .social-stack{
  max-height:420px;
  opacity:1;
  transform: translateY(0);
  pointer-events:auto;
}

/* hub button = radial circle */
.social-hub-btn{
  width:54px;
  height:54px;
  border-radius:999px;
  border:1px solid rgba(137,243,230,0.75);
  background: radial-gradient(circle at 30% 20%, rgba(16,72,75,0.96), rgba(4,25,29,0.98));
  box-shadow:0 0 18px rgba(137,243,230,0.65);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  animation: radialHubGlow 2.4s ease-in-out infinite;
}

/* neutral 3-dot icon (NOT discord) */
.social-hub-btn::after{
  content:"";
  width:18px;
  height:6px;
  border-radius:999px;
  background:
    radial-gradient(circle, rgba(137,243,230,0.95) 60%, transparent 62%) 0 50% / 6px 6px no-repeat,
    radial-gradient(circle, rgba(137,243,230,0.95) 60%, transparent 62%) 50% 50% / 6px 6px no-repeat,
    radial-gradient(circle, rgba(137,243,230,0.95) 60%, transparent 62%) 100% 50% / 6px 6px no-repeat;
}

body.social-open .social-hub-btn{
  animation:none;
  box-shadow:0 0 28px rgba(137,243,230,0.9);
}

/* each social button matches radial circle */
.social-icon{
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(137,243,230,0.75);
  background: radial-gradient(circle at 30% 20%, rgba(16,72,75,0.96), rgba(4,25,29,0.98));
  box-shadow:0 0 14px rgba(137,243,230,0.55);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  position:relative;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
}

.social-icon::before{
  content:"";
  width:18px;
  height:18px;
  background: rgba(137,243,230,0.95);
  mask-size:contain;
  mask-position:center;
  mask-repeat:no-repeat;
  -webkit-mask-size:contain;
  -webkit-mask-position:center;
  -webkit-mask-repeat:no-repeat;
}

/* icons */
.social-spotify::before{
  mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/spotify.svg");
  -webkit-mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/spotify.svg");
}
.social-soundcloud::before{
  mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/soundcloud.svg");
  -webkit-mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/soundcloud.svg");
}
.social-youtube::before{
  mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/youtube.svg");
  -webkit-mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/youtube.svg");
}
.social-instagram::before{
  mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/instagram.svg");
  -webkit-mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/instagram.svg");
}
.social-tiktok::before{
  mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/tiktok.svg");
  -webkit-mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/tiktok.svg");
}
.social-discord::before{
  mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/discord.svg");
  -webkit-mask-image:url("https://cdn.jsdelivr.net/gh/simple-icons/simple-icons/icons/discord.svg");
}

.social-icon:hover{
  transform: translateY(-1px);
  box-shadow:0 0 22px rgba(137,243,230,0.95);
}

/* =========================
   OVERLAY NAV (SIDE PANEL)
========================= */

.nav{
  position:fixed;
  top:0;
  bottom:0;
  left:88px;
  width:min(280px, 72vw);
  padding:80px 28px 32px;
  display:flex;
  flex-direction:column;
  gap:12px;
  background: radial-gradient(circle at top, rgba(4,25,29,0.99), rgba(2,14,16,0.99));
  border-right:1px solid rgba(232,247,245,0.08);
  transform: translateX(-100%);
  opacity:0;
  pointer-events:none;
  z-index:180;
  transition: transform var(--transition-fast), opacity var(--transition-fast);
}
body.menu-open .nav{
  transform: translateX(0);
  opacity:1;
  pointer-events:auto;
}

.nav-link{
  border-radius:999px;
  border:1px solid transparent;
  padding:8px 18px;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  background:transparent;
  color:var(--text-muted);
  cursor:pointer;
  text-align:left;
  width:100%;
  transition: background var(--transition-fast),
             color var(--transition-fast),
             border-color var(--transition-fast),
             box-shadow var(--transition-fast),
             transform var(--transition-fast);
}

.nav-link:hover{
  border-color:var(--accent-strong);
  color:var(--accent-strong);
  box-shadow:0 0 10px rgba(105,232,217,0.55);
  transform: translateX(4px);
  text-shadow:0 0 8px rgba(137,243,230,0.9);
  animation: navNeonPulse 1.4s ease-in-out infinite;
}

.nav-link.active{
  background: radial-gradient(circle at top, var(--accent-strong), var(--accent-gold));
  color:#04191D;
  box-shadow: var(--shadow-glow);
}

/* =========================
   FAN MENU (FINAL HARD)
   - Perfect circles (never oval)
   - Symmetric 7-item fan
   - Uses body.fan-open
========================= */

#radial-menu-root{
  position: fixed !important;
  left: 50px !important;              /* after rail */
  top: 50% !important;
  width: 260px !important;
  height: 260px !important;
  transform: translateY(-50%) !important;
  pointer-events: none !important;
  z-index: 9999 !important;
}
body.fan-open #radial-menu-root{ pointer-events: auto !important; }

/* hub button */
#radial-hub-btn.radial-hub-btn{
  position: fixed !important;
  top: 50% !important;
  left: 48px !important;
  transform: translateY(-50%) !important;
  width: 54px !important;
  height: 54px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(137,243,230,0.65) !important;
  background: radial-gradient(circle at 30% 20%, rgba(16,72,75,0.96), rgba(4,25,29,1)) !important;
  box-shadow: 0 0 14px rgba(105,232,217,0.7) !important;
  z-index: 10000 !important;
}

/* fan button = the circle (guaranteed 1:1) */
#radial-menu-root .fan-btn{
  -webkit-appearance: none !important;
  appearance: none !important;
  background: radial-gradient(circle at 30% 20%, rgba(16,72,75,0.96), rgba(4,25,29,0.98)) !important;
  border: 1px solid rgba(137,243,230,0.75) !important;
  box-shadow: 0 0 14px rgba(137,243,230,0.55) !important;

  width: 34px !important;
  height: 34px !important;
  aspect-ratio: 1 / 1 !important;
  border-radius: 999px !important;

  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;

  opacity: 0 !important;
  pointer-events: none !important;
  cursor: pointer !important;

  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* label sits to the right of the circle */
#radial-menu-root .fan-btn .fan-label{
  position: absolute !important;
  left: 46px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;

  font-size: 10px !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
  color: rgba(222,245,241,0.92) !important;
  text-shadow: 0 0 8px rgba(105,232,217,0.35) !important;
  white-space: nowrap !important;
}

/* =========================
   MOBILE: logo only (no socials, no nav)
========================= */

@media (max-width: 900px){
  /* turn left rail into a tiny top-left pill */
  .site-header{
    position: fixed;
    inset: 12px auto auto 12px;
    width: auto;
    height: auto;
    padding: 0;
    background: transparent;
    border: none;
    backdrop-filter: none;
  }

  .header-inner{
    height: auto;
    justify-content: flex-start;
    gap: 0;
  }

  .header-top{ gap: 0; }

  .brand{
    padding: 10px 14px;
    border-radius: 999px;
    background: radial-gradient(circle at top, rgba(9,53,61,0.96), rgba(4,25,29,0.97));
    border: 1px solid rgba(232,247,245,0.10);
    box-shadow: 0 0 18px rgba(105,232,217,0.45);
  }

  .brand-tagline{ display: none; }
  .header-bottom, #social-toggle{ display: none !important; }

  /* hide nav controls on mobile for now */
  #radial-hub-btn,
  #radial-menu-root,
  .radial-nav{
    display: none !important;
  }
}

/* symmetric angles for 7 items */
#radial-menu-root .fan-btn:nth-of-type(1){ --angle: -60deg !important; }
#radial-menu-root .fan-btn:nth-of-type(2){ --angle: -40deg !important; }
#radial-menu-root .fan-btn:nth-of-type(3){ --angle: -20deg !important; }
#radial-menu-root .fan-btn:nth-of-type(4){ --angle:   0deg !important; }
#radial-menu-root .fan-btn:nth-of-type(5){ --angle:  20deg !important; }
#radial-menu-root .fan-btn:nth-of-type(6){ --angle:  40deg !important; }
#radial-menu-root .fan-btn:nth-of-type(7){ --angle:  60deg !important; }

/* open spread */
body.fan-open #radial-menu-root .fan-btn{
  opacity: 1 !important;
  pointer-events: auto !important;
  transform:
    translate(-50%, -50%)
    rotate(var(--angle))
    translateX(170px)
    rotate(calc(-1 * var(--angle))) !important;
}


/* FAN: move whole fan closer to hub */
#radial-menu-root{
  left: 10px !important;   /* was 88 */
}

/* also nudge labels slightly back */
#radial-menu-root .fan-btn .fan-label{
  left: 50px !important;
}
