/*
 * La Galga Gris · header.css
 * Header sticky, mega-menu, mini-cart icon, lang switcher, mobile drawer.
 */

.lgg-header {
	position: fixed;
	inset: 0 0 auto 0;
	z-index: var(--z-header);
	color: var(--color-ink-primary);
	transition: background var(--dur-base) var(--ease-standard),
				color var(--dur-base) var(--ease-standard),
				box-shadow var(--dur-base) var(--ease-standard),
				transform var(--dur-base) var(--ease-emphasized);
	will-change: transform;
}

.lgg-header[data-state="top"]    { background: transparent; }
.lgg-header[data-state="scrolled"] { background: color-mix(in srgb, var(--color-bg-base) 96%, transparent); box-shadow: 0 1px 0 var(--color-border-subtle); }
.lgg-header[data-state="hidden"] { transform: translateY(-100%); }

/* Cuando el hero es oscuro o cuando un usuario está sobre dark hero, opcional via data-over-dark */
.lgg-header[data-over-dark="true"][data-state="top"] { color: var(--color-ink-inverse); }
.lgg-header[data-over-dark="true"][data-state="top"] .lgg-header__brand-word--accent { color: var(--color-accent); }

body { padding-top: 76px; }
@media (min-width: 1024px) { body { padding-top: 84px; } }

.lgg-header__bar { padding-block: var(--sp-3); }
.lgg-header__container {
	max-width: var(--container-wide);
	margin-inline: auto;
	padding-inline: var(--container-pad-x);
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--sp-5);
}

/* ── Brand ──────────────────────────────────────────────────────── */
.lgg-header__brand {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-3);
	color: inherit;
	text-decoration: none;
	padding: var(--sp-1) 0;
}
.lgg-header__brand-mark {
	width: 36px; height: 36px;
	color: var(--color-ink-primary);
	display: inline-flex; align-items: center; justify-content: center;
	background: var(--color-bg-card);
	border-radius: 50%;
	box-shadow: var(--shadow-sm);
	transition: transform var(--dur-base) var(--ease-emphasized);
}
.lgg-header[data-over-dark="true"][data-state="top"] .lgg-header__brand-mark { background: var(--color-ink-inverse); color: var(--color-ink-primary); }
.lgg-header__brand:hover .lgg-header__brand-mark { transform: rotate(-6deg); }

.lgg-header__brand-text {
	display: inline-flex;
	gap: 0.25em;
	font-family: var(--font-display);
	font-weight: var(--fw-medium);
	font-size: 1.1rem;
	letter-spacing: -0.01em;
	line-height: 1;
}
.lgg-header__brand-word--accent { color: var(--color-accent); font-style: italic; }

/* ── Nav ────────────────────────────────────────────────────────── */
.lgg-header__nav { display: none; justify-self: center; }
@media (min-width: 1024px) { .lgg-header__nav { display: block; } }

.lgg-header__nav-list {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	gap: var(--sp-5);
	align-items: center;
}

.lgg-header__nav-item { position: relative; }

.lgg-header__nav-link {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	padding: var(--sp-3) 0;
	font-family: var(--font-body);
	font-size: 0.95rem;
	font-weight: var(--fw-medium);
	color: inherit;
	text-decoration: none;
	background: none;
	border: 0;
	cursor: pointer;
	position: relative;
}
.lgg-header__nav-link::after {
	content: "";
	position: absolute;
	left: 0; right: 0; bottom: var(--sp-2);
	height: 1.5px;
	background: currentColor;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform var(--dur-base) var(--ease-emphasized);
}
.lgg-header__nav-link:hover::after,
.lgg-header__nav-link[aria-expanded="true"]::after,
.lgg-header__nav-link.is-active::after { transform: scaleX(1); }

.lgg-header__nav-caret { width: 12px; height: 12px; transition: transform var(--dur-fast) var(--ease-standard); }
.lgg-header__nav-link[aria-expanded="true"] .lgg-header__nav-caret { transform: rotate(180deg); }

/* ── Mega-menu ──────────────────────────────────────────────────── */
.lgg-megamenu {
	position: absolute;
	top: calc(100% + 8px);
	left: 50%;
	transform: translateX(-50%) translateY(-6px);
	min-width: 720px;
	max-width: 92vw;
	background: var(--color-bg-card);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	padding: var(--sp-6);
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--dur-base) var(--ease-standard),
				transform var(--dur-base) var(--ease-emphasized);
	color: var(--color-ink-primary);
}
.lgg-megamenu[data-open="true"] {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
	pointer-events: auto;
}
.lgg-megamenu__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--sp-6);
}
.lgg-megamenu__col--links { display: flex; flex-direction: column; gap: var(--sp-3); }
.lgg-megamenu__eyebrow {
	margin: 0;
	font-size: var(--fz-micro);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--ls-eyebrow);
	text-transform: uppercase;
	color: var(--color-ink-muted);
}
.lgg-megamenu__eyebrow--spaced { margin-top: var(--sp-3); }
.lgg-megamenu__links {
	list-style: none;
	margin: 0; padding: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sp-2) var(--sp-5);
}
.lgg-megamenu__links a {
	color: var(--color-ink-primary);
	text-decoration: none;
	font-size: 0.95rem;
	padding-block: var(--sp-1);
	transition: color var(--dur-fast) var(--ease-standard), padding-left var(--dur-fast) var(--ease-standard);
}
.lgg-megamenu__links a:hover { color: var(--color-accent); padding-left: 3px; }

.lgg-megamenu__see-all {
	margin-top: var(--sp-2);
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	font-weight: var(--fw-semibold);
	color: var(--color-ink-primary);
	text-decoration: none;
	border-bottom: 1px solid var(--color-ink-primary);
	padding-bottom: 3px;
	width: fit-content;
}
.lgg-megamenu__see-all:hover { color: var(--color-accent); border-color: var(--color-accent); }
.lgg-megamenu__see-all svg { width: 14px; height: 14px; }

.lgg-megamenu__feature {
	display: block;
	text-decoration: none;
	color: inherit;
	background: var(--color-bg-subtle);
	border-radius: var(--radius-md);
	padding: var(--sp-3);
	transition: transform var(--dur-base) var(--ease-emphasized);
}
.lgg-megamenu__feature:hover { transform: translateY(-3px); }
.lgg-megamenu__feature-img { margin-bottom: var(--sp-3); }
.lgg-megamenu__feature-meta { display: flex; flex-direction: column; gap: var(--sp-2); padding: 0 var(--sp-2) var(--sp-2); }
.lgg-megamenu__feature-title {
	margin: 0;
	font-family: var(--font-display);
	font-size: 1.1rem;
	font-weight: var(--fw-medium);
	line-height: 1.25;
	color: var(--color-ink-primary);
}

/* ── Actions (right) ────────────────────────────────────────────── */
.lgg-header__actions {
	display: flex;
	align-items: center;
	gap: var(--sp-1);
}
.lgg-header__action {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--sp-1);
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: transparent;
	color: inherit;
	text-decoration: none;
	border: 0;
	cursor: pointer;
	transition: background var(--dur-fast) var(--ease-standard), color var(--dur-fast) var(--ease-standard);
}
.lgg-header__action:hover { background: color-mix(in srgb, currentColor 8%, transparent); }
.lgg-header__action svg { width: 20px; height: 20px; }

.lgg-header__action--lang {
	width: auto;
	padding: 0 var(--sp-3);
	border-radius: var(--radius-pill);
	font-family: var(--font-body);
	font-weight: var(--fw-semibold);
	font-size: 0.8rem;
	letter-spacing: 0.08em;
}
.lgg-header__action--lang .lgg-header__nav-caret { width: 10px; height: 10px; }

.lgg-header__lang { position: relative; }
.lgg-header__lang-list {
	list-style: none;
	margin: 8px 0 0;
	padding: var(--sp-2);
	position: absolute;
	right: 0; top: 100%;
	min-width: 180px;
	background: var(--color-bg-card);
	color: var(--color-ink-primary);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-md);
	display: none;
}
.lgg-header__lang-list[data-open="true"] { display: block; }
.lgg-header__lang-list a {
	display: block;
	padding: var(--sp-2) var(--sp-3);
	border-radius: var(--radius-sm);
	color: inherit;
	text-decoration: none;
	font-size: 0.9rem;
}
.lgg-header__lang-list a:hover { background: var(--color-bg-subtle); color: var(--color-accent); }

/* ── Mini-cart count ────────────────────────────────────────────── */
.lgg-header__action--cart .lgg-header__cart-count {
	position: absolute;
	top: 4px; right: 2px;
	min-width: 18px; height: 18px;
	padding: 0 4px;
	border-radius: 999px;
	background: var(--color-accent);
	color: var(--color-ink-inverse);
	font-size: 10px;
	font-weight: var(--fw-bold);
	display: inline-flex; align-items: center; justify-content: center;
	line-height: 1;
	transition: transform var(--dur-fast) var(--ease-emphasized), opacity var(--dur-fast);
	opacity: 0;
	transform: scale(0.7);
	pointer-events: none;
}
.lgg-header__action--cart[data-has-items="true"] .lgg-header__cart-count {
	opacity: 1;
	transform: scale(1);
}
.lgg-header__action--cart.is-shaking { animation: lgg-cart-shake var(--dur-slow) var(--ease-emphasized); }
@keyframes lgg-cart-shake {
	0%, 100% { transform: rotate(0); }
	15% { transform: rotate(-12deg); }
	30% { transform: rotate(10deg); }
	45% { transform: rotate(-7deg); }
	60% { transform: rotate(5deg); }
	75% { transform: rotate(-2deg); }
}
@media (prefers-reduced-motion: reduce) {
	.lgg-header__action--cart.is-shaking { animation: none; }
}

/* ── Burger / mobile ────────────────────────────────────────────── */
.lgg-header__action--burger { display: inline-flex; }
@media (min-width: 1024px) { .lgg-header__action--burger { display: none; } }

.lgg-header__burger {
	width: 20px; height: 14px;
	display: inline-flex;
	flex-direction: column;
	justify-content: space-between;
}
.lgg-header__burger span {
	display: block;
	height: 1.6px;
	background: currentColor;
	border-radius: 2px;
	transition: transform var(--dur-base) var(--ease-emphasized), opacity var(--dur-fast);
	transform-origin: center;
}
.lgg-header__action--burger[aria-expanded="true"] .lgg-header__burger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.lgg-header__action--burger[aria-expanded="true"] .lgg-header__burger span:nth-child(2) { opacity: 0; }
.lgg-header__action--burger[aria-expanded="true"] .lgg-header__burger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.lgg-header__mobile {
	position: fixed;
	inset: 76px 0 0 0;
	background: var(--color-bg-base);
	color: var(--color-ink-primary);
	transform: translateY(-100%);
	transition: transform var(--dur-slow) var(--ease-emphasized);
	overflow: hidden;
	z-index: calc(var(--z-header) - 1);
}
.lgg-header__mobile[data-open="true"] {
	transform: translateY(0);
	aria-hidden: false;
}
.lgg-header__mobile-scroll {
	height: 100%;
	overflow-y: auto;
	padding: var(--sp-5) var(--container-pad-x) var(--sp-8);
}
.lgg-header__mobile-list {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}
.lgg-header__mobile-list > li {
	border-top: 1px solid var(--color-border-subtle);
}
.lgg-header__mobile-list > li:last-child { border-bottom: 1px solid var(--color-border-subtle); }
.lgg-header__mobile-list a,
.lgg-header__mobile-list summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sp-4) 0;
	font-family: var(--font-display);
	font-size: 1.4rem;
	font-weight: var(--fw-medium);
	color: var(--color-ink-primary);
	text-decoration: none;
	cursor: pointer;
	list-style: none;
}
.lgg-header__mobile-list summary::-webkit-details-marker { display: none; }
.lgg-header__mobile-list details ul {
	list-style: none;
	margin: 0; padding: 0 0 var(--sp-4) var(--sp-4);
}
.lgg-header__mobile-list details ul a {
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: var(--fw-regular);
	color: var(--color-ink-secondary);
	padding: var(--sp-2) 0;
}
.lgg-header__mobile-cta { color: var(--color-accent) !important; }
.lgg-header__mobile-divider { height: var(--sp-5); border: 0 !important; }

@media (min-width: 1024px) { .lgg-header__mobile { display: none; } }

/* prevent body scroll when mobile menu open */
html.lgg-no-scroll, html.lgg-no-scroll body { overflow: hidden !important; }
