/* Make user button appear active when login dialog is open */
body[data-dialog-open="user-dropdown"] .user-icon-link {
  --_btn-color: var(--btn-hover-color);
  --_btn-color-bg: var(--btn-hover-color-bg);
}

/* Hide default dialog backdrop */
body[data-dialog-mode="modal"][data-dialog-open="user-dropdown"] dialog::backdrop {
  background: transparent;
}

/* Custom backdrop */
body[data-dialog-mode="modal"][data-dialog-open="user-dropdown"]:after{
  content: '';
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  z-index: 10;
  opacity: 1;
  transition: opacity 300ms;
}
@starting-style {
  body[data-dialog-mode="modal"][data-dialog-open="user-dropdown"]:after { opacity: 0; }
}

/* Arrow under user button */
body[data-dialog-open="user-dropdown"] header .user-icon-link {
  position: relative;
  z-index: 20;
}
body[data-dialog-open="user-dropdown"] header .user-icon-link:after {
  content: '';
  width: 0px;
  height: 0px;
  border-style: solid;
  border-width: 8px 6px 0 6px;
  border-color: #ffffff transparent transparent transparent;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 85%);
}


dialog#user-dropdown {
  --dialog-radius: 1.25em;
  --link-color: var(--primaryColor);
  --btn-hover-color: var(--color-fg);
  --btn-hover-color-bg: var(--color-bg);
}


/* Position the dialog under the user button */
@supports (anchor-name: --profile-button) {
  #header-group-inner .user-icon-link { anchor-name: --profile-button; }
  dialog#user-dropdown {
    position: absolute;
    z-index: 100;
    margin: 0;
    border: 0;
    width: max-content;
    justify-self: center;
    position-anchor: --profile-button;
    inset-block-start: anchor(bottom);
    margin-top: 6px;
    left: auto;
    right: anchor(right);
    top: anchor(bottom);
    bottom: auto;

    --dialog-padding: var(--space, 1rem);
  }
}

/* Basic dialog styles */
dialog#user-dropdown form li, dialog#user-dropdown .user-button-links li { list-style: none; }

/* Responsive adjustments */
@media (max-width: 600px) {
  body.not-logged-in dialog#user-dropdown { width: 100%; left: 0; right: 0; }
  body.not-logged-in dialog#user-dropdown .messages { max-width: 100%; }
}
@media (max-width: 400px) { body.logged-in dialog#user-dropdown { width: 100%; left: 0; right: 0; } }

  /* Login form styles */
dialog#user-dropdown #user-login-form {
  text-align: left;
}
dialog#user-dropdown #user-login-form input {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin: 0;
}
dialog#user-dropdown #user-login-form .form-item {
  margin-top: 0;
  margin-bottom: var(--space);
}
dialog#user-dropdown #user-login-form .form-item label {
  font-weight: 600;
}
dialog#user-dropdown #user-login-form .item-list ul {
  margin: 0;
  display: flex;
  gap: var(--space);
  margin-top: var(--space);
  justify-content: space-between;
  flex-wrap: wrap;
  border-top: 1px solid #ccc;
  padding-top: var(--space);
}
dialog#user-dropdown .content-messages-inner {
  margin-bottom: var(--space, 1rem);
}
dialog#user-dropdown .content-messages-inner .messages {
  margin: 0;
}
dialog#user-dropdown .messages {
  max-width: 26ch;
}

/* Logged in user links */
dialog#user-dropdown .user-button-links ul {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1em;
}
dialog#user-dropdown .user-button-links li > a {
  display: flex;
  align-items: center;
  gap: .5em;
}




