/*
 * La Galga Gris · components.css
 * Componentes base reutilizables (botones, formularios, tablas, accordion genérico, marquee).
 * Componentes específicos (mega-menu, configurador, product card, etc.) viven en sus propios items.
 */

/* ── Buttons ────────────────────────────────────────────────────── */
.lgg-btn {
	--btn-bg: var(--color-accent);
	--btn-bg-hover: var(--color-accent-hover);
	--btn-fg: var(--color-ink-inverse);
	--btn-border: transparent;
	--btn-py: 0.875rem;
	--btn-px: 1.5rem;

	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--sp-2);
	padding: var(--btn-py) var(--btn-px);
	background: var(--btn-bg);
	color: var(--btn-fg);
	border: 1px solid var(--btn-border);
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: var(--fz-body);
	font-weight: var(--fw-semibold);
	letter-spacing: 0.01em;
	line-height: 1.2;
	text-decoration: none;
	cursor: pointer;
	transition: background var(--dur-fast) var(--ease-standard),
				color var(--dur-fast) var(--ease-standard),
				border-color var(--dur-fast) var(--ease-standard),
				transform var(--dur-fast) var(--ease-standard);
}
.lgg-btn:hover { background: var(--btn-bg-hover); color: var(--btn-fg); }
.lgg-btn:active { transform: translateY(1px); }
.lgg-btn:disabled, .lgg-btn[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; }

.lgg-btn--primary { /* default, accent */ }

.lgg-btn--ink {
	--btn-bg: var(--color-ink-primary);
	--btn-bg-hover: #000;
	--btn-fg: var(--color-ink-inverse);
}

.lgg-btn--ghost {
	--btn-bg: transparent;
	--btn-bg-hover: var(--color-bg-subtle);
	--btn-fg: var(--color-ink-primary);
	--btn-border: var(--color-border-default);
}
.lgg-btn--ghost:hover { color: var(--color-ink-primary); }

.lgg-btn--inverse {
	--btn-bg: var(--color-ink-inverse);
	--btn-bg-hover: #FFF;
	--btn-fg: var(--color-ink-primary);
}

.lgg-btn--sm { --btn-py: 0.5rem; --btn-px: 1rem; font-size: var(--fz-small); }
.lgg-btn--lg { --btn-py: 1.1rem; --btn-px: 2rem; font-size: var(--fz-body-l); }

.lgg-btn--icon { width: 2.5rem; height: 2.5rem; padding: 0; border-radius: 50%; }

/* CTA con underline animado (alternativa al botón) */
.lgg-link-cta {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	font-family: var(--font-body);
	font-weight: var(--fw-semibold);
	color: var(--color-ink-primary);
	text-decoration: none;
	padding-bottom: 0.25rem;
	border-bottom: 1px solid var(--color-ink-primary);
	transition: gap var(--dur-fast) var(--ease-standard),
				color var(--dur-fast) var(--ease-standard);
}
.lgg-link-cta:hover { color: var(--color-accent); border-color: var(--color-accent); gap: var(--sp-3); }

/* ── Form basics ────────────────────────────────────────────────── */
.lgg-field { display: flex; flex-direction: column; gap: var(--sp-2); }
.lgg-field__label {
	font-size: var(--fz-small);
	font-weight: var(--fw-medium);
	color: var(--color-ink-secondary);
	letter-spacing: 0.01em;
}
.lgg-field__hint { font-size: var(--fz-micro); color: var(--color-ink-muted); }
.lgg-field__error { font-size: var(--fz-small); color: var(--color-danger); }

.lgg-input, .lgg-textarea, .lgg-select {
	width: 100%;
	padding: 0.75rem 1rem;
	background: var(--color-bg-card);
	border: 1px solid var(--color-border-default);
	border-radius: var(--radius-md);
	color: var(--color-ink-primary);
	font-size: var(--fz-body);
	line-height: 1.4;
	transition: border-color var(--dur-fast) var(--ease-standard),
				box-shadow var(--dur-fast) var(--ease-standard);
}
.lgg-input:focus, .lgg-textarea:focus, .lgg-select:focus {
	border-color: var(--color-accent);
	box-shadow: var(--shadow-glow-accent);
	outline: none;
}
.lgg-textarea { min-height: 9rem; resize: vertical; }

/* ── Accordion base ─────────────────────────────────────────────── */
.lgg-accordion { display: flex; flex-direction: column; }
.lgg-accordion__item {
	border-top: 1px solid var(--color-border-subtle);
}
.lgg-accordion__item:last-child { border-bottom: 1px solid var(--color-border-subtle); }
.lgg-accordion__trigger {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-4);
	padding: var(--sp-5) 0;
	font-family: var(--font-display);
	font-size: var(--fz-h3);
	font-weight: var(--fw-medium);
	color: var(--color-ink-primary);
	text-align: left;
	cursor: pointer;
	line-height: 1.2;
}
.lgg-accordion__trigger:hover { color: var(--color-accent); }
.lgg-accordion__icon {
	width: 1.5rem; height: 1.5rem;
	flex: 0 0 auto;
	transition: transform var(--dur-base) var(--ease-emphasized);
}
.lgg-accordion__item[aria-expanded="true"] .lgg-accordion__icon,
.lgg-accordion__trigger[aria-expanded="true"] .lgg-accordion__icon { transform: rotate(45deg); }
.lgg-accordion__panel {
	overflow: hidden;
	max-height: 0;
	transition: max-height var(--dur-base) var(--ease-emphasized);
}
.lgg-accordion__panel[data-open="true"] { max-height: 40rem; }
.lgg-accordion__inner { padding-bottom: var(--sp-5); color: var(--color-ink-secondary); max-width: 64ch; }

/* ── Marquee strip ──────────────────────────────────────────────── */
.lgg-marquee {
	display: flex;
	overflow: hidden;
	gap: 0;
	border-block: 1px solid var(--color-border-subtle);
	padding-block: var(--sp-3);
	background: var(--color-bg-subtle);
	mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
	-webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}
.lgg-marquee__track {
	display: flex;
	gap: var(--sp-6);
	white-space: nowrap;
	animation: lgg-marquee 40s linear infinite;
	will-change: transform;
}
.lgg-marquee:hover .lgg-marquee__track { animation-play-state: paused; }
.lgg-marquee__item {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-6);
	font-family: var(--font-display);
	font-size: clamp(1.125rem, 1.8vw, 1.5rem);
	letter-spacing: var(--ls-heading);
	color: var(--color-ink-primary);
}
.lgg-marquee__bullet {
	width: 0.5rem; height: 0.5rem;
	border-radius: 50%;
	background: var(--color-accent);
	flex: 0 0 auto;
}
@keyframes lgg-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.lgg-marquee__track { animation: none; }
}

/* ── Tables (Woo + tallas) ──────────────────────────────────────── */
.lgg-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--fz-body);
}
.lgg-table th, .lgg-table td {
	padding: var(--sp-4) var(--sp-3);
	text-align: left;
	border-bottom: 1px solid var(--color-border-subtle);
}
.lgg-table th {
	font-family: var(--font-body);
	font-weight: var(--fw-semibold);
	color: var(--color-ink-primary);
	background: var(--color-bg-subtle);
}
.lgg-table tr:hover td { background: color-mix(in srgb, var(--color-accent) 6%, transparent); }

/* ── Toast / notice ─────────────────────────────────────────────── */
.lgg-notice {
	padding: var(--sp-4) var(--sp-5);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border-subtle);
	background: var(--color-bg-card);
	font-size: var(--fz-small);
	color: var(--color-ink-secondary);
}
.lgg-notice--success { border-color: color-mix(in srgb, var(--color-success) 50%, transparent); }
.lgg-notice--warning { border-color: color-mix(in srgb, var(--color-warning) 50%, transparent); }
.lgg-notice--danger  { border-color: color-mix(in srgb, var(--color-danger)  50%, transparent); }
