/* ============================================================
   Joybunch — Header + mobile drawer + bottom nav
   v0.0.8 — LittleTalkies-inspired 3-zone header (logo / nav / actions)
   References tokens.
   ============================================================ */

/* ---------- Header floated card (CREAM bg, soft square, sticky on scroll) ----------
   Pill is sticky directly in body — no surrounding band wrapper. On scroll, only
   the cream pill follows; content scrolls under it (no white strip).
*/
.joy-header {
	position: sticky;
	top: var(--joy-space-sm);              /* 8px float gap when sticky */
	z-index: var(--z-sticky-header);
	background: var(--joy-cream-bg);
	border-radius: var(--joy-radius-xl);    /* 24px — soft square, NOT full pill */
	box-shadow: var(--joy-shadow-md);
	border: 1px solid rgba(44, 37, 32, 0.04);
	max-width: var(--joy-container-xl);
	width: calc(100% - var(--joy-space-md)); /* 8px gap each side */
	margin: var(--joy-space-sm) auto;
	min-height: var(--height-header-mobile);
}
@media (min-width: 768px) {
	.joy-header {
		top: var(--joy-space-md);            /* 16px float gap on desktop */
		width: calc(100% - var(--joy-space-xl)); /* 16px gap each side */
		margin: var(--joy-space-md) auto;
		min-height: var(--height-header-desktop);
	}
}

.joy-header-inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--joy-space-md);
	width: 100%;
	padding: 8px var(--joy-space-md);
	min-height: var(--height-header-mobile);
}
@media (min-width: 768px) { .joy-header-inner { padding: 8px var(--joy-space-lg); min-height: var(--height-header-desktop); } }
@media (max-width: 991px) {
	.joy-header-inner {
		grid-template-columns: auto 1fr auto; /* hamburger | logo | actions */
		justify-items: start;
	}
	.joy-header-inner .joy-logo { justify-self: center; }
	.joy-header-inner .joy-header-actions { justify-self: end; }
}

/* ---------- Logo (smile under joy) ---------- */
.joy-logo {
	display: inline-flex;
	flex-direction: column;
	align-items: flex-start;
	text-decoration: none;
	color: var(--joy-graphite);
	flex-shrink: 0;
	line-height: 1;
}
.joy-logo:hover { color: var(--joy-graphite); }
.joy-logo-wordmark {
	font: 700 30px/1 var(--joy-font-display);
	letter-spacing: -1px;
	color: var(--joy-graphite);
}
@media (min-width: 768px) { .joy-logo-wordmark { font-size: 38px; letter-spacing: -1.5px; } }
.joy-logo-smile {
	display: block;
	margin: -2px 0 0 4px;
	width: 56px;
	height: 14px;
	color: var(--joy-coral);
}
@media (min-width: 768px) {
	.joy-logo-smile { width: 70px; height: 18px; margin-left: 6px; }
}

/* ---------- Primary nav (desktop only) ---------- */
.joy-nav {
	display: none;
	gap: var(--joy-space-xl);
	align-items: center;
	justify-content: center;
	list-style: none;
	padding: 0;
	margin: 0;
}
@media (min-width: 992px) { .joy-nav { display: flex; } }
.joy-nav,
.joy-nav ul,
.joy-nav li { list-style: none; padding: 0; margin: 0; }
.joy-nav li { display: inline-flex; }
.joy-nav a {
	color: var(--joy-graphite);
	font: 500 var(--joy-text-md)/1.2 var(--joy-font-body);
	text-decoration: none;
	padding: 8px 0;
	position: relative;
	transition: color var(--dur-fast) var(--ease);
	white-space: nowrap;
}
.joy-nav a::before { content: none !important; } /* explicit no-bullet rule */
.joy-nav a:hover { color: var(--joy-coral-dark); }
.joy-nav a.is-active,
.joy-nav .current-menu-item > a {
	color: var(--joy-coral-dark);
	font-weight: 600;
}
.joy-nav a.is-active::after,
.joy-nav .current-menu-item > a::after {
	content: '';
	position: absolute;
	left: 0; right: 0; bottom: 2px;
	height: 2px;
	background: var(--joy-coral);
	border-radius: 2px;
}

/* ---------- Mobile hamburger (2-line) ---------- */
.joy-hamburger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px; height: 40px;
	border-radius: 50%;
	background: transparent;
	color: var(--joy-graphite);
	border: none;
	cursor: pointer;
	padding: 0;
	transition: background var(--dur-fast) var(--ease);
}
.joy-hamburger:hover { background: var(--joy-white); }
.joy-hamburger:focus-visible { outline: 2px solid var(--color-focus-ring); outline-offset: 2px; }
@media (min-width: 992px) { .joy-hamburger { display: none; } }

/* ---------- Header actions group ---------- */
.joy-header-actions {
	display: flex;
	align-items: center;
	gap: 4px;
}
@media (min-width: 768px) { .joy-header-actions { gap: var(--joy-space-sm); } }

/* ---------- Icon-only link (cart, wishlist) ---------- */
.joy-icon-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px; height: 40px;
	border-radius: 50%;
	color: var(--joy-graphite);
	background: transparent;
	text-decoration: none;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
	flex-shrink: 0;
}
.joy-icon-link:hover { background: var(--joy-white); color: var(--joy-graphite); }
.joy-icon-link:focus-visible { outline: 2px solid var(--color-focus-ring); outline-offset: 2px; }

.joy-cart-badge {
	position: absolute;
	top: 2px; right: 0;
	min-width: 18px; height: 18px;
	padding: 0 5px;
	background: var(--joy-coral);
	color: var(--joy-white);
	border-radius: var(--joy-radius-pill);
	font: 700 10px/18px var(--joy-font-body);
	text-align: center;
	box-shadow: 0 0 0 2px var(--joy-cream-bg);
}

/* ---------- Login pill (outline graphite, "Login | Register") ---------- */
.joy-login-btn {
	display: none;
	align-items: center;
	gap: 8px;
	padding: 8px 18px;
	min-height: 40px;
	border: 1.5px solid var(--joy-graphite);
	border-radius: var(--joy-radius-pill);
	font: 600 var(--joy-text-base)/1 var(--joy-font-body);
	color: var(--joy-graphite);
	background: transparent;
	text-decoration: none;
	white-space: nowrap;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
	margin-left: 4px;
}
@media (min-width: 992px) { .joy-login-btn { display: inline-flex; } }
.joy-login-btn:hover {
	background: var(--joy-graphite);
	color: var(--joy-white);
}
.joy-login-btn .divider {
	color: var(--joy-graphite-soft);
	font-weight: 400;
	margin: 0 -2px;
}
.joy-login-btn:hover .divider {
	color: rgba(255, 255, 255, 0.5);
}
.joy-login-btn:focus-visible {
	outline: 2px solid var(--color-focus-ring);
	outline-offset: 2px;
}

/* ---------- Mobile drawer (modern: rounded right edge, blur backdrop, larger nav) ---------- */
.joy-drawer-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(44, 37, 32, 0.45);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--dur-base) var(--ease);
	z-index: var(--z-drawer-backdrop);
}
.joy-drawer-backdrop.is-open { opacity: 1; pointer-events: auto; }

.joy-drawer {
	position: fixed;
	top: 0; left: 0; bottom: 0;
	width: min(340px, 88vw);
	background: var(--joy-white);
	box-shadow: var(--joy-shadow-xl);
	z-index: var(--z-drawer);
	transform: translateX(-100%);
	transition: transform var(--dur-base) var(--ease-bounce);
	display: flex;
	flex-direction: column;
	overflow-y: auto;
	overscroll-behavior: contain;
	will-change: transform;
	border-radius: 0 var(--joy-radius-2xl) var(--joy-radius-2xl) 0;
}
.joy-drawer.is-open { transform: translateX(0); }
@media (prefers-reduced-motion: reduce) {
	.joy-drawer { transition: none; }
	.joy-drawer-backdrop { transition: none; }
}

.joy-drawer-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--joy-space-md) var(--joy-space-lg);
	min-height: var(--height-header-mobile);
}
.joy-drawer-close {
	width: 40px; height: 40px;
	border-radius: 50%;
	background: transparent;
	color: var(--joy-graphite);
	border: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background var(--dur-fast) var(--ease);
}
.joy-drawer-close:hover { background: var(--joy-cream-bg); }
.joy-drawer-close:focus-visible { outline: 2px solid var(--color-focus-ring); outline-offset: 2px; }

.joy-drawer-nav {
	padding: var(--joy-space-sm) var(--joy-space-md);
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.joy-drawer-nav,
.joy-drawer-nav ul,
.joy-drawer-nav li { list-style: none; padding: 0; margin: 0; }
.joy-drawer-nav li { display: block; }
.joy-drawer-nav a {
	display: flex;
	align-items: center;
	padding: 14px var(--joy-space-md);
	color: var(--joy-graphite);
	font: 600 var(--joy-text-xl)/1.3 var(--joy-font-display);
	text-decoration: none;
	border-radius: var(--joy-radius-md);
	transition: background var(--dur-fast) var(--ease),
	            color var(--dur-fast) var(--ease),
	            transform var(--dur-fast) var(--ease);
}
.joy-drawer-nav a::before { content: none !important; }
.joy-drawer-nav a:hover,
.joy-drawer-nav a:focus-visible {
	background: var(--joy-cream-bg);
	color: var(--joy-coral-dark);
}
.joy-drawer-nav a:active { transform: scale(0.98); }
.joy-drawer-nav a.is-active,
.joy-drawer-nav .current-menu-item > a {
	background: var(--joy-coral-bg);
	color: var(--joy-coral-dark);
}

.joy-drawer-footer {
	padding: var(--joy-space-lg);
	background: var(--joy-cream-bg);
	border-radius: var(--joy-radius-xl);
	margin: var(--joy-space-md);
}

/* ---------- Mobile bottom tab bar (kit signature dark pill) ---------- */
.joy-bottomnav {
	position: fixed;
	bottom: var(--joy-space-md);
	left: 50%;
	transform: translateX(-50%);
	background: var(--joy-graphite);
	border-radius: var(--joy-radius-pill);
	padding: 6px;
	display: flex;
	align-items: center;
	gap: 4px;
	box-shadow: var(--joy-shadow-xl);
	z-index: var(--z-bottomnav);
	max-width: calc(100vw - 32px);
}
@media (min-width: 992px) { .joy-bottomnav { display: none; } }

.joy-bottomnav a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 0;
	border-radius: var(--joy-radius-pill);
	color: var(--joy-graphite);
	background: var(--joy-white);
	width: 44px; height: 44px;
	justify-content: center;
	font: 600 var(--joy-text-sm)/1.2 var(--joy-font-body);
	text-decoration: none;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
	position: relative;
}
.joy-bottomnav a span { display: none; }
.joy-bottomnav a.is-active {
	background: var(--joy-coral);
	color: var(--joy-white);
	width: auto;
	padding: 0 18px;
}
.joy-bottomnav a.is-active span { display: inline; }
.joy-bottomnav svg { flex-shrink: 0; }
.joy-bottomnav .badge {
	position: absolute;
	top: -2px; right: -2px;
	min-width: 18px; height: 18px;
	padding: 0 5px;
	background: var(--joy-coral);
	color: var(--joy-white);
	border-radius: var(--joy-radius-pill);
	font: 700 10px/18px var(--joy-font-body);
	text-align: center;
	border: 2px solid var(--joy-graphite);
	box-sizing: content-box;
}

/* When drawer is open, prevent body scroll */
body.joy-no-scroll { overflow: hidden; }
