/* Celeste Harbor Common Navigation */

.site-header{
  position:relative;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  margin-bottom:44px;
  color:var(--muted);
  font-size:13px;
  flex-wrap:wrap;
}

.brand{
  color:var(--text);
  letter-spacing:.04em;
  text-decoration:none;
}

.nav{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  align-items:center;
  position:relative;
}

.nav-parent{
  appearance:none;
  border:0;
  background:transparent;
  color:var(--muted);
  font:inherit;
  padding:0;
  cursor:pointer;
}

.nav-parent:hover,
.nav-parent.is-active{
  color:var(--text);
}

.nav-parent.is-active{
  text-decoration:underline;
  text-underline-offset:.25em;
}

.subnav{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  z-index:200;
  width:max-content;
  max-width:min(520px, calc(100vw - 40px));
}

.subnav-panel{
  display:none;
  position:relative;
  flex-direction:column;
  gap:2px;
  min-width:180px;
  padding:12px;
  border:1px solid rgba(169,183,255,.28);
  border-radius:16px;
  background:
    radial-gradient(circle at top left, rgba(169,183,255,.12), transparent 42%),
    rgba(10,14,28,.98);
  box-shadow:0 18px 48px rgba(0,0,0,.46);
  backdrop-filter:blur(8px);
}

.subnav-panel::before{
  content:"";
  position:absolute;
  top:-7px;
  left:22px;
  width:12px;
  height:12px;
  transform:rotate(45deg);
  border-left:1px solid rgba(169,183,255,.28);
  border-top:1px solid rgba(169,183,255,.28);
  background:rgba(10,14,28,.98);
}

.subnav-panel a{
  color:var(--muted);
  text-decoration:none;
  font-size:13px;
  line-height:1.7;
  padding:7px 10px;
  border-radius:10px;
  white-space:nowrap;
}

.subnav-panel a:hover{
  color:var(--text);
  background:rgba(255,255,255,.045);
}

.logout-link{
  color:var(--muted);
  text-decoration:none;
  cursor:pointer;
}

.logout-link:hover{
  color:var(--text);
}

.nav-letter-link{
  position:relative;
}

body.has-unread-letter .nav-letter-link{
  color:var(--text);
}

body.has-unread-letter .nav-letter-link::after{
  content:"";
  position:absolute;
  top:2px;
  right:2px;
  width:8px;
  height:8px;
  border-radius:999px;
  background:#ffe3a3;
  box-shadow:
    0 0 8px rgba(255,227,163,.85),
    0 0 18px rgba(255,227,163,.45);
}

@media(max-width:640px){
  .site-header{
    align-items:flex-start;
    flex-direction:column;
    margin-bottom:34px;
  }

  .nav{
    width:100%;
    gap:12px;
    font-size:12px;
  }

  .subnav{
    top:calc(100% + 10px);
    left:0;
    right:auto;
    max-width:calc(100vw - 32px);
  }

  .subnav-panel{
    min-width:190px;
    max-width:calc(100vw - 32px);
  }

  .subnav-panel a{
    font-size:13px;
    white-space:normal;
  }
}
