@layer components {

/* Notification Inbox Styles */

.notification-inbox {
  position: relative;
}

  /* Mobile notification inbox in header */
  .notification-inbox--mobile {
    display: flex;
    align-items: center;
  }

    .notification-inbox--mobile .notification-bell {
      inline-size: 36px;
      block-size: 36px;
    }

    .notification-inbox--mobile .notification-bell .heroicon,
    .notification-inbox--mobile .notification-bell .notification-bell-icon {
      inline-size: 22px;
      block-size: 22px;
    }

    .notification-inbox--mobile .notification-badge {
      inset-block-start: 2px;
      right: 2px;
      min-inline-size: 16px;
      block-size: 16px;
      padding: 0 4px;
      font-size: 10px;
      line-height: 16px;
    }

    /* Mobile dropdown from header - fixed positioning */
    .notification-inbox--mobile .notification-dropdown {
      position: fixed;
      inset-block-start: 60px;
      right: 16px;
      left: 16px;
      inline-size: auto;
      max-inline-size: none;
    }

/* Bell Button */
/* stylelint-disable-next-line no-descending-specificity */
.notification-bell {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 40px;
  block-size: 40px;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease;
}

  .notification-bell:hover {
    background: var(--color-bg-secondary);
    color: var(--color-text-primary);
    text-decoration: none;
  }

  .notification-bell:focus-visible {
    outline: 2px solid var(--color-focus-ring);
    outline-offset: 2px;
  }

  /* stylelint-disable no-descending-specificity -- icon sizing for notification bell */
  .notification-bell .heroicon,
  .notification-bell .notification-bell-icon {
    inline-size: 24px;
    block-size: 24px;
  }
  /* stylelint-enable no-descending-specificity */

/* Badge */
/* stylelint-disable-next-line no-descending-specificity */
.notification-badge {
  position: absolute;
  inset-block-start: 4px;
  right: 4px;
  min-inline-size: 18px;
  block-size: 18px;
  padding: 0 5px;
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  line-height: 18px;
  text-align: center;
  color: white;
  background: var(--color-error-500);
  border-radius: 9px;
}

/* Dropdown Panel */
/* stylelint-disable-next-line no-descending-specificity */
.notification-dropdown {
  position: absolute;
  inset-block-start: calc(100% + 8px);
  right: 0;
  inline-size: 360px;
  max-inline-size: calc(100vw - 32px);
  max-block-size: calc(100vh - 100px);
  max-block-size: calc(100dvh - 100px);
  background: var(--color-bg-primary);
  border: 1px solid var(--color-border-primary);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

  .notification-dropdown.hidden {
    display: none;
  }

  /* Dropdown Header */
  .notification-dropdown__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3) var(--space-4);
    border-block-end: 1px solid var(--color-border-primary);
  }

  .notification-dropdown__title {
    margin: 0;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
  }

  .notification-dropdown__mark-all {
    padding: var(--space-1) var(--space-2);
    font-size: var(--text-xs);
    font-weight: var(--font-medium);
    color: var(--color-text-accent-bright);
    background: transparent;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background-color 0.15s ease;
  }

    .notification-dropdown__mark-all:hover {
      background: var(--color-bg-selected);
    }

  /* Dropdown List */
  .notification-dropdown__list {
    flex: 1;
    overflow-y: auto;
    max-block-size: 400px;
  }

  /* Empty State */
  .notification-dropdown__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-8) var(--space-4);
    color: var(--color-text-tertiary);
  }

    /* stylelint-disable-next-line no-descending-specificity */
    .notification-dropdown__empty .heroicon,
    .notification-dropdown__empty .notification-empty-icon {
      inline-size: 48px;
      block-size: 48px;
      opacity: 0.5;
    }

    .notification-dropdown__empty p {
      margin: 0;
      font-size: var(--text-sm);
    }

  /* Dropdown Footer */
  .notification-dropdown__footer {
    padding: var(--space-2) var(--space-4);
    border-block-start: 1px solid var(--color-border-primary);
  }

  .notification-dropdown__settings-link {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2);
    font-size: var(--text-xs);
    color: var(--color-text-secondary);
    text-decoration: none;
    border-radius: var(--radius-sm);
    transition: color 0.15s ease, background-color 0.15s ease;
  }

    .notification-dropdown__settings-link:hover {
      color: var(--color-text-primary);
      background: var(--color-bg-secondary);
    }

    /* stylelint-disable-next-line no-descending-specificity */
    .notification-dropdown__settings-link .heroicon,
    .notification-dropdown__settings-link .notification-settings-icon {
      inline-size: 16px;
      block-size: 16px;
    }

  /* Sidebar dropdown uses fixed positioning to escape sidebar overflow:hidden */
  .notification-dropdown--sidebar {
    position: fixed;
    inset-block-start: auto;
    left: auto;
    right: auto;
    margin-inline-start: 0;
    /* Position will be set by JavaScript */
  }

  /* Mobile Responsive - Original dropdown */
  @media (width <= 480px) {
.notification-dropdown {
    position: fixed;
    inset-block-start: 60px;
    right: 16px;
    left: 16px;
    inline-size: auto;
    max-inline-size: none
}
  }

/* Notification Item */
.notification-item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  text-decoration: none;
  color: var(--color-text-primary);
  border-block-end: 1px solid var(--color-border-secondary);
  transition: background-color 0.15s ease;
}

  .notification-item:hover {
    background: var(--color-bg-secondary);
  }

  .notification-item:last-child {
    border-block-end: none;
  }

  .notification-item--read {
    opacity: 0.6;
  }

  .notification-item__icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: 32px;
    block-size: 32px;
    background: var(--color-bg-tertiary);
    border-radius: var(--radius-full);
    color: var(--color-text-secondary);
  }

    .notification-item__icon svg {
      inline-size: 18px;
      block-size: 18px;
    }

  .notification-item__content {
    flex: 1;
    min-inline-size: 0;
  }

  .notification-item__description {
    margin: 0 0 var(--space-1) 0;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    line-height: 1.4;
    color: var(--color-text-primary);
  }

  .notification-item__time {
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
  }

/* ===========================================
   Sidebar Inbox Styles
   =========================================== */

.sidebar-inbox-wrapper {
  position: relative;
  inline-size: 100%;
}

  /* Mobile: Hide sidebar inbox, show bell icon in header */
  @media (width <= 768px) {
.sidebar-inbox-wrapper {
    display: none
}
  }

.sidebar-inbox-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  inline-size: 100%;
  padding: var(--space-2-5) var(--space-3);
  font-size: var(--text-sm);
  text-align: start;
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease;
}

  .sidebar-inbox-item:hover {
    background: var(--color-bg-secondary);
    color: var(--color-text-primary);
  }

  /* stylelint-disable-next-line no-descending-specificity */
  .sidebar-inbox-item .heroicon,
  .sidebar-inbox-item .sidebar-nav-icon {
    inline-size: 20px;
    block-size: 20px;
    flex-shrink: 0;
  }

  .sidebar-inbox-item .sidebar-nav-label {
    flex: 1;
  }

/* Sidebar inbox badge - right justified */
.sidebar-inbox-badge {
  min-inline-size: 20px;
  block-size: 20px;
  padding: 0 6px;
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  line-height: 20px;
  text-align: center;
  color: white;
  background: var(--color-error-500);
  border-radius: 10px;
  margin-inline-start: auto;
}

/* Desktop: Hide header notification (use sidebar instead) */
.header-notification-mobile {
  display: none;
}

  /* Mobile: Hide sidebar inbox, show bell icon in header */
  @media (width <= 768px) {
.header-notification-mobile {
    display: block
}
  }

} /* @layer components */
