/** * Header Component - Admin Interface * * Top header bar with page title, search, notifications, and user menu. * Sticky positioning with backdrop blur for modern look. */ @layer admin-components { /** * Header Container */ .admin-header { display: flex; align-items: center; gap: var(--admin-spacing-md); background-color: var(--admin-header-bg); border-bottom: 1px solid var(--admin-header-border); padding: var(--admin-spacing-md) var(--admin-spacing-content-padding); min-height: var(--admin-header-height-mobile); /* Sticky with blur effect */ position: sticky; top: 0; z-index: var(--admin-z-header); backdrop-filter: blur(8px); background-color: var(--admin-header-bg); @media (min-width: 768px) { min-height: var(--admin-header-height-tablet); } @media (min-width: 1440px) { min-height: var(--admin-header-height-wide); } } /** * Page Title */ .admin-header__title { font-size: var(--admin-font-size-xl); font-weight: 600; color: var(--admin-header-text); margin: 0; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; @media (max-width: 767px) { /* Hide on mobile, show breadcrumbs instead */ display: none; } } /** * Search Bar */ .admin-header__search { flex: 0 1 400px; max-width: 400px; @media (max-width: 767px) { /* Full width on mobile */ flex: 1; max-width: none; } } .admin-search { position: relative; width: 100%; } .admin-search__input { width: 100%; padding: var(--admin-spacing-sm) var(--admin-spacing-md); padding-left: calc(var(--admin-spacing-md) + 20px + var(--admin-spacing-sm)); border: 1px solid var(--admin-border-light); border-radius: var(--admin-radius-md); font-size: var(--admin-font-size-sm); background-color: var(--admin-bg-secondary); color: var(--admin-content-text); transition: all var(--admin-transition-base); &::placeholder { color: var(--admin-content-text); opacity: 0.5; } &:focus { outline: none; border-color: var(--admin-focus-ring); box-shadow: 0 0 0 3px var(--admin-focus-ring-alpha); background-color: var(--admin-content-bg); } } .admin-search__icon { position: absolute; left: var(--admin-spacing-md); top: 50%; transform: translateY(-50%); width: 20px; height: 20px; color: var(--admin-content-text); opacity: 0.5; pointer-events: none; } /** * Header Actions (Right Side) */ .admin-header__actions { display: flex; align-items: center; gap: var(--admin-spacing-sm); margin-left: auto; } /** * Action Button (Icon Button) */ .admin-action-btn { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: var(--admin-radius-md); background-color: transparent; border: 1px solid transparent; color: var(--admin-header-text); cursor: pointer; transition: all var(--admin-transition-base); position: relative; &:hover { background-color: var(--admin-hover-overlay); border-color: var(--admin-border-light); } &:focus-visible { outline: 2px solid var(--admin-focus-ring); outline-offset: 2px; } } .admin-action-btn__icon { width: 20px; height: 20px; } /** * Notification Badge */ .admin-action-btn__badge { position: absolute; top: 6px; right: 6px; width: 8px; height: 8px; background-color: var(--admin-accent-error); border: 2px solid var(--admin-header-bg); border-radius: 50%; } .admin-action-btn__badge--count { width: auto; height: auto; min-width: 18px; padding: 2px 5px; font-size: 10px; font-weight: 600; color: white; line-height: 1; border-radius: 9px; } /** * Theme Toggle Button */ .admin-theme-toggle { display: flex; align-items: center; gap: var(--admin-spacing-xs); padding: var(--admin-spacing-xs) var(--admin-spacing-sm); background-color: var(--admin-bg-secondary); border: 1px solid var(--admin-border-light); border-radius: var(--admin-radius-md); cursor: pointer; transition: all var(--admin-transition-base); &:hover { background-color: var(--admin-bg-tertiary); } @media (max-width: 767px) { /* Icon only on mobile */ padding: var(--admin-spacing-xs); .admin-theme-toggle__label { display: none; } } } .admin-theme-toggle__icon { width: 18px; height: 18px; color: var(--admin-header-text); } .admin-theme-toggle__label { font-size: var(--admin-font-size-sm); color: var(--admin-header-text); } /** * User Menu Dropdown */ .admin-user-menu { position: relative; } .admin-user-menu__trigger { display: flex; align-items: center; gap: var(--admin-spacing-sm); padding: var(--admin-spacing-xs); background-color: transparent; border: 1px solid transparent; border-radius: var(--admin-radius-md); cursor: pointer; transition: all var(--admin-transition-base); &:hover { background-color: var(--admin-hover-overlay); border-color: var(--admin-border-light); } &:focus-visible { outline: 2px solid var(--admin-focus-ring); outline-offset: 2px; } } .admin-user-menu__avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; border: 2px solid var(--admin-border-light); } .admin-user-menu__name { font-size: var(--admin-font-size-sm); font-weight: 500; color: var(--admin-header-text); @media (max-width: 767px) { display: none; } } .admin-user-menu__chevron { width: 16px; height: 16px; color: var(--admin-header-text); transition: transform var(--admin-transition-base); .admin-user-menu[data-open="true"] & { transform: rotate(180deg); } @media (max-width: 767px) { display: none; } } /** * Dropdown Menu */ .admin-user-menu__dropdown { position: absolute; top: calc(100% + var(--admin-spacing-xs)); right: 0; min-width: 200px; background-color: var(--admin-content-bg); border: 1px solid var(--admin-border-light); border-radius: var(--admin-radius-md); box-shadow: var(--admin-shadow-lg); padding: var(--admin-spacing-sm) 0; display: none; z-index: var(--admin-z-dropdown); .admin-user-menu[data-open="true"] & { display: block; } } .admin-user-menu__item { list-style: none; margin: 0; } .admin-user-menu__link { display: flex; align-items: center; gap: var(--admin-spacing-sm); padding: var(--admin-spacing-sm) var(--admin-spacing-md); color: var(--admin-content-text); text-decoration: none; font-size: var(--admin-font-size-sm); transition: background-color var(--admin-transition-base); &:hover { background-color: var(--admin-bg-secondary); } } .admin-user-menu__icon { width: 18px; height: 18px; opacity: 0.7; } .admin-user-menu__divider { height: 1px; background-color: var(--admin-border-light); margin: var(--admin-spacing-sm) 0; } }