/* ════════════════════════════════════════════════════════════════════════
   Header + Mobile Drawer
   ════════════════════════════════════════════════════════════════════════ */

.an-header {
	position: sticky;
	top: 0;
	z-index: 999;
	background: var(--an-header-bg);
	color: var(--an-header-text);
	border-bottom: 1px solid var(--an-header-border);
	transition: box-shadow 0.2s ease;
}
.an-header.is-scrolled {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.an-header__inner {
	max-width: var(--an-container-max);
	margin: 0 auto;
	padding: 0 var(--an-container-pad);
	height: var(--an-header-height);
	display: flex;
	align-items: center;
	gap: 32px;
}
@media (max-width: 1024px) {
	.an-header__inner {
		padding: 0 var(--an-container-pad-md);
		height: var(--an-header-height-mobile);
		gap: 16px;
	}
}
@media (max-width: 640px) {
	.an-header__inner {
		padding: 0 var(--an-container-pad-sm);
	}
}

/* ─── Logo ─── */
.an-header__brand {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}
.an-logo {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
	color: #FFFFFF;
	text-decoration: none;
	font-family: 'Playfair Display', Georgia, serif;
	line-height: 1;
}
.an-logo:hover { color: #FFFFFF; }
.an-logo__main {
	font-size: 22px;
	font-weight: 600;
	letter-spacing: -0.01em;
}
.an-logo__sub {
	font-size: 22px;
	font-weight: 400;
	font-style: italic;
	opacity: 0.9;
}
@media (max-width: 640px) {
	.an-logo__main, .an-logo__sub { font-size: 18px; }
}

/* ─── Desktop nav ─── */
.an-header__nav {
	flex: 1;
	display: flex;
	justify-content: center;
}
.an-nav {
	display: flex;
	align-items: center;
	gap: 4px;
	list-style: none;
	margin: 0;
	padding: 0;
}
.an-menu-item { position: relative; }
.an-menu-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 8px 14px;
	color: var(--an-header-text);
	font-size: 14px;
	font-weight: 500;
	border-radius: var(--an-radius-sm);
	text-decoration: none;
	transition: color var(--an-trans-base), background-color var(--an-trans-base);
}
.an-menu-link:hover,
.an-menu-link:focus-visible {
	color: #FF3D4F;                    /* brand red, slightly bright for dark bg */
	background: transparent;           /* no background fill — clean Rodin feel */
}
.an-menu-link:hover .an-chevron,
.an-menu-link:focus-visible .an-chevron {
	opacity: 0.9;
}
.an-menu-item.current-menu-item > .an-menu-link,
.an-menu-item.current-menu-parent > .an-menu-link {
	color: #FF3D4F;              /* active = red text */
	position: relative;
}
.an-menu-item.current-menu-item > .an-menu-link::after,
.an-menu-item.current-menu-parent > .an-menu-link::after {
	content: '';
	position: absolute;
	left: 14px; right: 14px;
	bottom: 4px;
	height: 2px;
	background: var(--starter-accent);
	border-radius: 2px;
}

/* Chevron ▾ */
.an-chevron {
	display: inline-block;
	width: 8px; height: 8px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(45deg) translateY(-2px);
	margin-left: 4px;
	opacity: 0.7;
	transition: transform 0.2s ease;
}
.an-has-children:hover > .an-menu-link .an-chevron {
	transform: rotate(-135deg) translateY(-2px);
}

/* ─── Submenu (desktop dropdown) ─── */
.an-submenu {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	min-width: 220px;
	padding: 8px;
	margin: 0;
	list-style: none;
	background: var(--an-header-bg-elevated);
	border: 1px solid var(--an-header-border);
	border-radius: var(--an-radius-md);
	box-shadow: var(--an-shadow-dropdown);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-6px);
	transition: opacity var(--an-trans-base), visibility var(--an-trans-base), transform var(--an-trans-base);
	z-index: 100;
}
.an-has-children:hover > .an-submenu,
.an-has-children:focus-within > .an-submenu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}
.an-submenu .an-menu-link {
	display: block;
	padding: 10px 14px;
	border-radius: var(--an-radius-sm);
	color: var(--an-header-text);
	font-size: 14px;
	white-space: nowrap;
}
.an-submenu .an-menu-link:hover,
.an-submenu .an-menu-link:focus-visible {
	color: #FF3D4F;
	background: rgba(255, 255, 255, 0.04);
}

/* ─── Desktop right actions ─── */
.an-header__actions {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-shrink: 0;
}

/* ─── Theme toggle ──────────────────────────────────────────
   Rounded-square button matching the theme's button radius
   (same as the Login / List Your Practice buttons beside it).
   Animated sun ⇄ moon swap — only ONE icon shows at a time. */
.an-theme-toggle {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--an-radius-sm);
	color: #FFFFFF;
	cursor: pointer;
	overflow: hidden;
	transition:
		background-color var(--an-trans-base),
		border-color var(--an-trans-base),
		transform var(--an-trans-fast),
		box-shadow var(--an-trans-base);
}
.an-theme-toggle:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.38);
	box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.04);
}
.an-theme-toggle:active { transform: scale(0.94); }
.an-theme-toggle:focus-visible {
	outline: none;
	box-shadow: 0 0 0 3px rgba(225, 29, 46, 0.45);
}

.an-theme-toggle svg { width: 18px; height: 18px; display: block; }

/* Both icons stack in the same position — one is always hidden. */
.an-theme-toggle__sun,
.an-theme-toggle__moon {
	position: absolute;
	inset: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition:
		opacity 280ms ease,
		transform 380ms cubic-bezier(0.4, 0.0, 0.2, 1);
}

/* Default state = LIGHT theme (show moon, hide sun). Clicking will
   switch to dark → show sun. */
.an-theme-toggle__sun  { opacity: 0; transform: rotate(-45deg) scale(0.6); }
.an-theme-toggle__moon { opacity: 1; transform: rotate(0deg)   scale(1);   }

[data-theme="dark"] .an-theme-toggle__sun  { opacity: 1; transform: rotate(0deg)    scale(1);   color: #FFC65A; }
[data-theme="dark"] .an-theme-toggle__moon { opacity: 0; transform: rotate(45deg)   scale(0.6); }

/* Drawer variant — rectangular row, both icons visible as a label */
.an-theme-toggle--drawer {
	border-radius: var(--an-radius-sm);
	width: auto;
	height: auto;
	justify-content: flex-start;
	overflow: visible;
}
.an-theme-toggle--drawer .an-theme-toggle__sun,
.an-theme-toggle--drawer .an-theme-toggle__moon {
	position: static;
	inset: auto;
	opacity: 1;
	transform: none;
}

/* ─── User menu (logged-in avatar dropdown) ─── */
.an-user-menu { position: relative; }
.an-user-menu__toggle {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 8px 4px 4px;
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: var(--an-radius-sm);
	cursor: pointer;
	color: #FFFFFF;
	transition: border-color var(--an-trans-base), background-color var(--an-trans-base);
}
.an-user-menu__toggle:hover,
.an-user-menu__toggle[aria-expanded="true"] {
	border-color: rgba(255, 255, 255, 0.35);
	background: rgba(255, 255, 255, 0.04);
}

.an-user-menu__avatar {
	position: relative;
	display: inline-block;
	width: 36px; height: 36px;
}
.an-avatar {
	width: 100% !important; height: 100% !important;
	border-radius: 50%;
	object-fit: cover;
	display: block;
}
.an-avatar--lg {
	width: 44px !important; height: 44px !important;
}
.an-avatar__badge {
	position: absolute;
	right: -2px; bottom: -2px;
	width: 14px; height: 14px;
	background: var(--starter-success, #1F8F4E);
	color: #FFFFFF;
	border: 2px solid var(--an-header-bg);
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.an-avatar__badge svg { width: 8px; height: 8px; }

.an-user-menu__panel {
	position: absolute;
	top: calc(100% + 10px);
	right: 0;
	min-width: 260px;
	background: var(--an-header-bg-elevated);
	border: 1px solid var(--an-header-border);
	border-radius: var(--an-radius-md);
	box-shadow: var(--an-shadow-dropdown);
	padding: 8px 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-6px);
	transition: opacity var(--an-trans-base), visibility var(--an-trans-base), transform var(--an-trans-base);
	z-index: 1000;
}
.an-user-menu.is-open .an-user-menu__panel {
	opacity: 1; visibility: visible; transform: translateY(0);
}
.an-user-menu__header {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	border-bottom: 1px solid var(--an-header-border);
}
.an-user-menu__name {
	font-size: 14px;
	font-weight: 600;
	color: #FFFFFF;
}
.an-user-menu__role {
	font-size: 12px;
	color: var(--an-header-text-muted);
	margin-top: 2px;
}
.an-verified-tag {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	color: var(--starter-success, #1F8F4E);
	font-weight: 500;
	margin-left: 4px;
}
.an-verified-tag svg { width: 10px; height: 10px; }

.an-user-menu__list {
	list-style: none;
	margin: 0;
	padding: 4px 0;
}
.an-user-menu__list a {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 16px;
	color: #FFFFFF;
	font-size: 14px;
	text-decoration: none;
	transition: background-color 0.15s ease;
}
.an-user-menu__list a:hover {
	background: var(--an-header-hover-bg);
}
.an-icon-wrap {
	display: inline-flex;
	width: 16px; height: 16px;
	opacity: 0.72;
}
.an-icon-wrap svg { width: 100%; height: 100%; }
.an-user-menu__badge {
	margin-left: auto;
	padding: 2px 8px;
	background: var(--starter-accent);
	color: #FFFFFF;
	font-size: 11px;
	font-weight: 600;
	border-radius: var(--an-radius-pill);
}
.an-user-menu__badge--count {
	min-width: 22px;
	height: 22px;
	padding: 0 6px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	line-height: 1;
}
.an-user-menu__divider {
	height: 1px;
	background: var(--an-header-border);
	margin: 4px 0;
}

/* ─── Mobile: Hamburger & mobile actions ─── */
.an-header__mobile-actions {
	margin-left: auto;
	display: flex;
	align-items: center;
	gap: 8px;
}

.an-hamburger {
	display: inline-flex;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 40px; height: 40px;
	padding: 10px 8px;
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: var(--an-radius-sm);
	cursor: pointer;
	transition: background-color var(--an-trans-base);
}
.an-hamburger:hover { background: var(--an-header-hover-bg); }
.an-hamburger__line {
	display: block;
	height: 2px;
	background: #FFFFFF;
	border-radius: 2px;
	transition: transform 0.25s ease, opacity 0.2s ease;
}
.an-hamburger[aria-expanded="true"] .an-hamburger__line:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.an-hamburger[aria-expanded="true"] .an-hamburger__line:nth-child(2) {
	opacity: 0;
}
.an-hamburger[aria-expanded="true"] .an-hamburger__line:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* ─── Mobile drawer — premium layout ─── */
.an-drawer {
	position: fixed;
	inset: 0;
	z-index: 1001;
	pointer-events: none;
	visibility: hidden;
}
.an-drawer.is-open {
	visibility: visible;
	pointer-events: auto;
}
.an-drawer__backdrop {
	position: absolute; inset: 0;
	background: rgba(0, 0, 0, 0.55);
	-webkit-backdrop-filter: blur(2px);
	backdrop-filter: blur(2px);
	opacity: 0;
	transition: opacity var(--an-trans-slow);
}
.an-drawer.is-open .an-drawer__backdrop { opacity: 1; }

.an-drawer__panel {
	position: absolute;
	top: 0; right: 0; bottom: 0;
	width: min(380px, 88vw);
	background: var(--an-header-bg);
	background-image:
		radial-gradient(1200px 400px at 120% -10%, rgba(225, 29, 46, 0.12) 0%, transparent 60%),
		radial-gradient(800px 300px at -20% 100%, rgba(225, 29, 46, 0.05) 0%, transparent 60%);
	color: var(--an-header-text);
	padding: 20px 20px 24px;
	overflow-y: auto;
	transform: translateX(100%);
	transition: transform var(--an-trans-slow);
	display: flex;
	flex-direction: column;
	gap: 20px;
	box-shadow: -24px 0 48px rgba(0, 0, 0, 0.4);
}
.an-drawer.is-open .an-drawer__panel {
	transform: translateX(0);
}

/* ─── Top row: logo left, toggle + close right ─── */
.an-drawer__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding-bottom: 16px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.an-drawer__top-actions {
	display: flex;
	align-items: center;
	gap: 8px;
}
/* Mobile theme toggle (top-right in drawer) — inherit the circular style */
.an-theme-toggle--mobile {
	width: 40px;
	height: 40px;
}

.an-drawer__close {
	width: 40px; height: 40px;
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: var(--an-radius-sm);
	color: #FFFFFF;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background var(--an-trans-base), border-color var(--an-trans-base);
}
.an-drawer__close svg { width: 15px; height: 15px; }
.an-drawer__close:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.35);
}

/* ─── User block (logged in) ─── */
.an-drawer__user {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 16px;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--an-radius-md);
}
.an-drawer__user-info { min-width: 0; }
.an-drawer__user-name {
	font-size: 15px;
	font-weight: 600;
	color: #FFFFFF;
	line-height: 1.3;
}
.an-drawer__user-role {
	font-size: 12px;
	color: rgba(255, 255, 255, 0.66);
	margin-top: 2px;
	display: flex;
	align-items: center;
	gap: 6px;
}

/* ─── Nav list ─── */
.an-drawer__nav { display: block; }
.an-drawer-nav {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.an-drawer-nav .an-menu-item {
	position: relative;
}
.an-drawer-nav .an-menu-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 14px;
	border: none;
	border-radius: var(--an-radius-md);
	color: #FFFFFF;
	font-size: 15px;
	font-weight: 500;
	background: transparent;
	transition: background var(--an-trans-base), color var(--an-trans-base), transform var(--an-trans-fast);
}
.an-drawer-nav .an-menu-link:hover,
.an-drawer-nav .an-menu-link:focus {
	background: rgba(255, 255, 255, 0.06);
	color: #FFFFFF;
}
.an-drawer-nav .an-menu-link:active {
	transform: scale(0.98);
}
/* Disable the red underline on active items inside drawer — looks bad on dark bg */
.an-drawer-nav .an-menu-item.current-menu-item > .an-menu-link,
.an-drawer-nav .an-menu-item.current-menu-parent > .an-menu-link {
	color: #FFFFFF;
}
.an-drawer-nav .an-menu-item.current-menu-item > .an-menu-link::after,
.an-drawer-nav .an-menu-item.current-menu-parent > .an-menu-link::after {
	display: none;
}
/* Use a small red dot on the left for active in drawer */
.an-drawer-nav .an-menu-item.current-menu-item > .an-menu-link {
	background: rgba(225, 29, 46, 0.1);
}
.an-drawer-nav .an-menu-item.current-menu-item > .an-menu-link::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
	height: 20px;
	background: var(--starter-accent);
	border-radius: 0 2px 2px 0;
}

/* Chevron in drawer — small, drawer-nav tap handles expand */
.an-drawer-nav .an-menu-link .an-chevron {
	width: 7px; height: 7px;
	margin-left: 8px;
	opacity: 0.5;
	transition: transform var(--an-trans-base), opacity var(--an-trans-base);
	flex-shrink: 0;
}

/* Submenu flattened inside drawer */
.an-drawer-nav .an-submenu {
	position: static;
	display: none;
	opacity: 1;
	visibility: visible;
	transform: none;
	box-shadow: none;
	background: transparent;
	border: none;
	padding: 4px 0 4px 20px;
	margin: 2px 0;
	list-style: none;
}
.an-drawer-nav .an-has-children.is-open > .an-submenu {
	display: block;
}
.an-drawer-nav .an-has-children.is-open > .an-menu-link .an-chevron {
	transform: rotate(-135deg) translateY(-2px);
	opacity: 0.9;
}
.an-drawer-nav .an-submenu .an-menu-link {
	padding: 10px 14px;
	font-size: 14px;
	color: rgba(255, 255, 255, 0.75);
	font-weight: 400;
}
.an-drawer-nav .an-submenu .an-menu-link:hover {
	color: #FFFFFF;
	background: rgba(255, 255, 255, 0.04);
}

/* ─── Section with small label (e.g. "More") ─── */
.an-drawer__section {
	padding-top: 16px;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.an-drawer__section-label {
	display: block;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.4);
	padding: 0 14px;
	margin-bottom: 8px;
}
.an-drawer-nav--extras {
	margin: 0;
}

/* ─── Actions footer (bottom of drawer) ─── */
.an-drawer__actions {
	margin-top: auto;
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding-top: 20px;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.an-drawer__actions .an-btn {
	padding: 13px 20px;
	font-size: 14.5px;
}
.an-drawer__actions .an-btn--outline {
	border-color: rgba(255, 255, 255, 0.35);
}
.an-drawer__actions .an-btn--outline:hover {
	background: rgba(255, 255, 255, 0.06);
	border-color: #FFFFFF;
}

/* Dedicated logout link (not a big button — subtle) */
.an-drawer__logout {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px;
	color: rgba(255, 255, 255, 0.6);
	font-size: 13px;
	font-weight: 500;
	text-decoration: none;
	border-radius: var(--an-radius-sm);
	transition: color var(--an-trans-base), background var(--an-trans-base);
}
.an-drawer__logout:hover {
	color: #FFFFFF;
	background: rgba(255, 255, 255, 0.04);
}
.an-drawer__logout svg {
	width: 14px; height: 14px;
	opacity: 0.7;
}
