/* Nav constants in /css/Theme.css */

.transparent-video {
  width: 100%;
  height: auto;
  object-fit: cover;
  mix-blend-mode: screen;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: -1;
}
/* --- 1. SHARED BASE --- */
.bottom-nav-container {
  position: fixed;
  bottom: 10px;
  right: 10px;
  z-index: 10000;
  pointer-events: none;
}

.arc-nav { 
  list-style: none; 
  margin: 0; 
  padding: 0; 
}

/* --- BACKDROP (Glass Effect) --- */
.nav-backdrop {
  position: absolute;
  /* Shifted -40px to the right and down to "cradle" the buttons */
  bottom: -40px;
  right: -40px;

  /* Increased size to ensure Home and About aren't cut off */
  width: calc(var(--nav-radius) *0.7);
  height: calc(var(--nav-radius)*2.2);

  /* Smoother fade: Black in corner -> Transparent at edges */
  background: radial-gradient(
    circle at calc(100% - 40px) calc(100% - 40px),
    rgba(0, 0, 0, 0.75) 0%,
    rgba(0, 0, 0, 0.4) 50%,
    transparent 75%
  );
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  border-radius: 8px 0 0 0;
  /* Subtle border only on the curved edge */
  border-top: 1px solid var(--accentTransparent);
  border-left: 1px solid var(--accentTransparent);

  pointer-events: none;
  z-index: 9000;
  transform-origin: calc(100% - 40px) calc(100% - 40px);
  transition: all 0.5s ease;
}
/* --- THE CURVE LINE --- */
.nav-curve-line {
  position: absolute;
  bottom: 0px;
  right: -10px;
  width: calc((var(--nav-size)*0.9));
  height: calc(var(--nav-radius)*1.75);
  border-left: 1px solid var(--accentTransparent);
  border-top: 1px solid var(--accentTransparent);
  border-radius: 8px 0 0 8px;
  pointer-events: none;
  z-index: 9500;
  opacity: 1; /* Visible on Desktop by default */
  transition: opacity 0.4s ease;
}


/* --- NAV SQUARES --- */
.nav-square {
  position: absolute;
  bottom: 0;
  right: 0;
  width: var(--nav-size);
  height: var(--nav-size);
  background: var(--bg-dark);
  border: 1px solid var(--glow);
  border-radius: 8px ;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10005;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.8),
              inset 0 0 0 1px rgba(255, 255, 255, 0.05);
  text-shadow: 0 2px 4px rgba(0,0,0,1);
  transform: skew(5px 0px);
  pointer-events: auto;
}

.nav-square.active { 
  background: var(--accentColor); 
  box-shadow: 0 0 10px var(--accentTransparent), 0 0 50px rgba(98, 195, 229, 0.2); 
  border: none; 
}
.nav-square.active img { filter: brightness(0); }
.nav-square img {
  width: 24pt;
  height: 24pt;
}
/* Lift square on hover to ensure tooltip is on top */
.nav-square:hover { z-index: 15000; }

/* --- TOOLTIPS --- */
.nav-square::after {
  content: attr(data-tooltip);
  position: absolute;
  right: 115%;
  background: #000;
  color: var(--accentColor);
  border: 1px solid var(--accentTransparent);
  padding: 5px 12px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: bold;
  white-space: nowrap;
  opacity: 0;
  transform: translateX(10px);
  transition: 0.3s ease;
  pointer-events: none;
  z-index: 20000 !important;
  box-shadow: 0 4px 15px rgba(0,0,0,0.5);
}

.nav-square:hover::after {
  opacity: 1;
  transform: translateX(0);
}

/* --- DESKTOP LOGIC --- */
@media (min-width: 992px) {
  /*
  .nav-main-trigger { display: none !important; }
  */

  .nav-square:nth-of-type(1) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -1.6)); }
  .nav-square:nth-of-type(2) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -1.26)); }
  .nav-square:nth-of-type(3) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -0.92)); }
  .nav-square:nth-of-type(4) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -0.58)); }
  .nav-square:nth-of-type(5) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -0.24)); }

  /* Commander nav item (authenticated only) — positioned above the regular nav with a gap */
  .nav-square-commander:nth-of-type(6) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -2.10)); }
}

.nav-main-trigger {
  width: calc(var(--nav-size)*1.8);
  height: calc(var(--nav-size)*0.8);
  background: var(--bg-dark);
  border: 1px solid var(--accentTransparent);
  border-bottom: 0px;
  border-right: 0px;
  border-radius: 8px 0px 8px 0px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 11000;
  position: relative;
  right: -10px;
  bottom: -20px;
  pointer-events: auto;
}

/* --- MOBILE LOGIC --- */
@media (max-width: 991px) {
  /* Nav mobile overrides in Theme.css handled by separate media query */
  
  /* Hide elements until toggle */
  .nav-backdrop { opacity: 0; transform: scale(0.8); }
  .nav-curve-line {
    opacity: 0;   width: calc((var(--nav-size)*0.97));
  }
  .nav-square { opacity: 0; scale: 0.2; pointer-events: none; }

  .nav-main-trigger {
    width: calc(var(--nav-size)*2);
  }

}
  .nav-square { opacity: 0; pointer-events: none; }
  .nav-curve-line {
    opacity: 0; ;
  }
  .nav-backdrop { opacity: 0;}



  /* Hamburger Icon */

  .nav-main-trigger span, .nav-main-trigger span::before, .nav-main-trigger span::after {
    content: ""; display: block; background: var(--textColor); height: 2px; width: 22px; transition: 0.3s; position: absolute;
  }

  .nav-main-trigger span::before { top: -7px; }
  .nav-main-trigger span::after { bottom: -7px; }

  /* OPEN STATES */
  #nav-toggle:checked ~ .nav-backdrop { opacity: 1; transform: scale(1); pointer-events: all; }
  #nav-toggle:checked ~ .nav-curve-line { opacity: 1; }
  #nav-toggle:checked ~ .arc-nav .nav-square { opacity: 1; scale: 1; pointer-events: auto; }
  /* Pre Calc sin and cos for x and y */
  /*
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(1) { transform: translate(0, calc(var(--nav-radius) * -1)); }
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(2) { transform: translate(calc(var(--nav-radius) * 0.38), calc(var(--nav-radius) * -0.92)); }
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(3) { transform: translate(calc(var(--nav-radius) * 0.70), calc(var(--nav-radius) * -0.70)); }
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(4) { transform: translate(calc(var(--nav-radius) * 0.92), calc(var(--nav-radius) * -0.38)); }
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(5) { transform: translate(var(--nav-radius), 0); }
  */
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(1) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -1.6)); }
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(2) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -1.26)); }
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(3) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -0.92)); }
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(4) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -0.58)); }
  #nav-toggle:checked ~ .arc-nav .nav-square:nth-of-type(5) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -0.24)); }
  /* Commander item on mobile toggle */
  #nav-toggle:checked ~ .arc-nav .nav-square-commander:nth-of-type(6) { transform: translate(calc(var(--nav-size)/-5), calc(var(--nav-radius) * -2.10)); }

  /* X Animation */
  #nav-toggle:checked ~ .nav-main-trigger span { background: transparent; }
  #nav-toggle:checked ~ .nav-main-trigger span::before { transform: rotate(45deg); top: 0; }
  #nav-toggle:checked ~ .nav-main-trigger span::after { transform: rotate(-45deg); bottom: 0; }
  @media (prefers-color-scheme: light) {
    .nav-square img{
      filter: invert(100%);
    }
    .navbar-brand span {
      color: var(--textColor);
    }
  }

@media (prefers-color-scheme: light) {
  .transparent-video {
    filter: invert(1) hue-rotate(180deg);
    mix-blend-mode: multiply;
  }

  .nav-backdrop {
    background: radial-gradient(
      circle at calc(100% - 40px) calc(100% - 40px),
      rgba(180, 175, 168, 0.75) 0%,
      rgba(180, 175, 168, 0.35) 50%,
      transparent 75%
    );
  }

  .nav-square {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    text-shadow: none;
  }

  .nav-square.active {
    box-shadow: 0 0 10px var(--accentTransparent);
  }

  .nav-square::after {
    background: #fff;
    color: var(--textColor);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.12);
  }
}

/* ─── Commander Nav Items (Gold Accent) ─────────────────── */

/* Commander logo: tint to accent color */
.commander-logo {
    filter: sepia(1) saturate(3) hue-rotate(10deg) brightness(1.2) !important;
}

@media (prefers-color-scheme: light) {
    .commander-logo {
        content: url("/assets/Logo/LogoLightTheme.png");
        filter: sepia(1) saturate(3) hue-rotate(10deg) brightness(0.7) !important;
    }
}

.nav-square-commander {
    border-color: rgba(243, 196, 28, 0.4) !important;
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.8),
                inset 0 0 0 1px rgba(243, 196, 28, 0.1) !important;
}

.nav-square-commander::after {
    color: rgb(243, 196, 28) !important;
    border-color: rgba(243, 196, 28, 0.3) !important;
}

.nav-square-commander:hover {
    border-color: rgba(243, 196, 28, 0.7) !important;
    box-shadow: 0 0 20px rgba(243, 196, 28, 0.2),
                inset 0 0 0 1px rgba(243, 196, 28, 0.15) !important;
}

/* Commander items in home index nav */
.nav-square-commander-index {
    border-color: rgba(243, 196, 28, 0.4);
}
.nav-square-commander-index a {
    color: rgb(243, 196, 28) !important;
}
.nav-square-commander-index:hover {
    border-color: rgba(243, 196, 28, 0.7);
}

/* ─── Static User Bar (top-right, all pages) ────────────── */
.cms-user-bar {
    position: fixed;
    top: 12px;
    right: 16px;
    z-index: 10500;
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: 'JetBrainsMono', monospace;
    font-size: 0.7rem;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(243, 196, 28, 0.15);
    border-radius: 4px;
    padding: 6px 14px;
}

.cms-user-bar-name {
    color: var(--textColor);
    opacity: 0.6;
}

.cms-user-bar-role {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 0.6rem;
    color: rgb(243, 196, 28);
    border: 1px solid rgba(243, 196, 28, 0.3);
    border-radius: 3px;
    padding: 1px 6px;
}

.cms-user-bar-logout {
    color: var(--textColor);
    opacity: 0.35;
    text-decoration: none;
    transition: opacity 0.3s;
}

.cms-user-bar-logout:hover {
    opacity: 1;
    color: rgb(243, 196, 28);
}

@media (prefers-color-scheme: light) {
    .cms-user-bar {
        background: rgba(255, 255, 255, 0.6);
        border-color: rgba(180, 140, 10, 0.2);
    }
    .cms-user-bar-role {
        color: rgb(180, 140, 10);
        border-color: rgba(180, 140, 10, 0.3);
    }
}