/* ==========================================================================
   Saturno Heritage — Sistema de diseño
   Archivo único, mobile-first.
   Secciones:
   0. @font-face (tipografías de marca self-hosted)
   1. Tokens (variables)
   2. Reset / base
   3. Tipografía
   4. Layout / utilidades
   5. Botones / enlaces
   6. Header / Nav / WhatsApp / Lang switcher
   7. Hero & secciones home
   8. Tarjeta de producto
   9. Páginas (historia, mayoreo, contacto, 404)
   10. Footer
   11. Formularios
   12. Animaciones (AOS-lite)
   13. Accesibilidad / utilidades de pantalla
   14. Responsive (>= 768, >= 1024)
   ========================================================================== */

/* 0. @FONT-FACE ----------------------------------------------------------- */
/* Clash Display — display (display, headings, logo). 6 pesos.
   Los archivos viven en assets/fonts/. font-display: swap evita FOIT. */
@font-face {
	font-family: "Clash Display";
	font-style: normal;
	font-weight: 200;
	font-display: swap;
	src: url("../fonts/ClashDisplay-Extralight.otf") format("opentype");
}
@font-face {
	font-family: "Clash Display";
	font-style: normal;
	font-weight: 300;
	font-display: swap;
	src: url("../fonts/ClashDisplay-Light.otf") format("opentype");
}
@font-face {
	font-family: "Clash Display";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("../fonts/ClashDisplay-Regular.otf") format("opentype");
}
@font-face {
	font-family: "Clash Display";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("../fonts/ClashDisplay-Medium.otf") format("opentype");
}
@font-face {
	font-family: "Clash Display";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("../fonts/ClashDisplay-Semibold.otf") format("opentype");
}
@font-face {
	font-family: "Clash Display";
	font-style: normal;
	font-weight: 700;
	font-display: swap;
	src: url("../fonts/ClashDisplay-Bold.otf") format("opentype");
}

/* Minion Pro — serif heritage para acentos editoriales (eyebrows, quotes). */
@font-face {
	font-family: "Minion Pro";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("../fonts/MinionPro-Regular.otf") format("opentype");
}

/* 1. TOKENS ---------------------------------------------------------------- */
:root {
	--c-bg:        #F5F0EB;
	--c-bg-alt:    #EFE7DD;
	--c-dark:      #2C1A0E;
	--c-dark-2:    #4A2F1E;
	--c-accent:    #B8895A;
	--c-accent-2:  #9C7045;
	--c-black:     #111111;
	--c-white:     #FFFFFF;
	--c-muted:     #7A6B5E;
	--c-line:      #E2D6C7;

	/* Display: Clash Display (sans display) — para títulos y logo */
	--ff-display: "Clash Display", "Helvetica Neue", Helvetica, Arial, sans-serif;
	/* Serif heritage: Minion Pro — solo para acentos editoriales */
	--ff-serif:   "Minion Pro", Georgia, "Times New Roman", serif;
	/* Sans body: Inter — para body, UI, formularios */
	--ff-sans:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;

	--fs-base: 16px;
	--lh-base: 1.65;

	--space-1: 4px;
	--space-2: 8px;
	--space-3: 16px;
	--space-4: 24px;
	--space-5: 32px;
	--space-6: 48px;
	--space-7: 64px;
	--space-8: 96px;
	--space-9: 128px;

	--radius-sm: 2px;
	--radius:    4px;
	--radius-lg: 8px;

	--ease: cubic-bezier(0.22, 1, 0.36, 1);
	--dur:  .35s;

	--container: 1280px;
	--container-narrow: 880px;
	--header-h: 76px;
}

/* 2. RESET / BASE --------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font: 400 var(--fs-base)/var(--lh-base) var(--ff-sans);
	color: var(--c-dark);
	background: var(--c-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, svg, video, picture { max-width: 100%; height: auto; display: block; }
a { color: var(--c-dark); text-decoration: none; transition: color var(--dur) var(--ease); }
a:hover { color: var(--c-accent); }
button { font: inherit; cursor: pointer; }
hr { border: 0; border-top: 1px solid var(--c-line); margin: var(--space-6) 0; }
::selection { background: var(--c-accent); color: var(--c-white); }

/* 3. TIPOGRAFÍA ----------------------------------------------------------- */
/* Headings con Clash Display: pesos según jerarquía.
   h1 (más impacto) = Semibold; h2 = Medium; h3 = Medium; h4 = Inter Bold (UI). */
h1, h2, h3 {
	font-family: var(--ff-display);
	color: var(--c-dark);
	margin: 0 0 var(--space-3);
	line-height: 1.08;
	letter-spacing: -.015em;
}
h1 { font-size: clamp(2.25rem, 5.5vw, 4.25rem); font-weight: 600; }
h2 { font-size: clamp(1.75rem, 4vw, 3rem);     font-weight: 500; }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.6rem); font-weight: 500; line-height: 1.2; }
h4 {
	font-family: var(--ff-sans);
	font-size: 1.05rem; font-weight: 600;
	letter-spacing: .04em; text-transform: uppercase;
	margin: 0 0 var(--space-3); color: var(--c-dark); line-height: 1.3;
}

p  { margin: 0 0 var(--space-3); }
.saturno-rich-text p, .saturno-rich-text li { font-size: 1.0625rem; }
.saturno-rich-text h2 { margin-top: var(--space-6); }

/* 4. LAYOUT --------------------------------------------------------------- */
.saturno-container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--space-3); }
@media (min-width: 768px) { .saturno-container { padding-inline: var(--space-5); } }

.saturno-section { padding: var(--space-7) 0; }
@media (min-width: 768px) { .saturno-section { padding: var(--space-8) 0; } }

.saturno-section__header { text-align: center; max-width: 720px; margin: 0 auto var(--space-6); }
/* Eyebrow editorial: Minion Pro en cursiva (acento heritage), no caps. */
.saturno-section__eyebrow {
	display: inline-block;
	font-family: var(--ff-serif);
	font-size: 1rem;
	letter-spacing: .02em;
	text-transform: none;
	color: var(--c-accent);
	font-weight: 400;
	font-style: italic;
	margin: 0 0 var(--space-2);
}
.saturno-section__eyebrow--light { color: var(--c-bg-alt); }
.saturno-section__title { margin-bottom: var(--space-3); }
.saturno-section__subtitle { color: var(--c-muted); }
.saturno-section__cta { text-align: center; margin-top: var(--space-6); }

/* 5. BOTONES -------------------------------------------------------------- */
.saturno-btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: var(--space-2);
	padding: 14px 28px;
	font-family: var(--ff-sans);
	font-weight: 600;
	font-size: .95rem;
	letter-spacing: .04em;
	border: 1px solid transparent;
	border-radius: var(--radius);
	cursor: pointer;
	transition: all var(--dur) var(--ease);
	text-transform: uppercase;
	white-space: nowrap;
}
.saturno-btn--primary {
	background: var(--c-dark);
	color: var(--c-white);
	border-color: var(--c-dark);
}
.saturno-btn--primary:hover { background: var(--c-accent); border-color: var(--c-accent); color: var(--c-white); }

.saturno-btn--secondary {
	background: transparent;
	color: var(--c-dark);
	border-color: var(--c-dark);
}
.saturno-btn--secondary:hover { background: var(--c-dark); color: var(--c-white); }

.saturno-btn--ghost {
	background: transparent;
	color: var(--c-white);
	border-color: rgba(255,255,255,0.7);
}
.saturno-btn--ghost:hover { background: var(--c-white); color: var(--c-dark); border-color: var(--c-white); }

.saturno-link-arrow {
	display: inline-flex; align-items: center; gap: var(--space-2);
	font-weight: 600; font-size: .95rem;
	letter-spacing: .04em; text-transform: uppercase;
	border-bottom: 1px solid currentColor; padding-bottom: 2px;
}
.saturno-link-arrow:hover { color: var(--c-accent); }
.saturno-link-arrow span { transition: transform var(--dur) var(--ease); }
.saturno-link-arrow:hover span { transform: translateX(4px); }

/* 6. HEADER --------------------------------------------------------------- */
.saturno-header {
	position: sticky; top: 0; z-index: 50;
	background: rgba(245, 240, 235, 0.96);
	backdrop-filter: saturate(180%) blur(8px);
	border-bottom: 1px solid var(--c-line);
}
.saturno-header[data-scrolled="true"] { box-shadow: 0 2px 12px rgba(44,26,14,0.05); }
.saturno-header__inner {
	display: flex; align-items: center; gap: var(--space-4);
	min-height: var(--header-h);
}
.saturno-logo { display: inline-flex; align-items: center; }
.saturno-logo-text {
	font-family: var(--ff-display);
	font-size: 1.5rem;
	font-weight: 600;
	letter-spacing: -.005em;
	color: var(--c-dark);
}

.saturno-nav {
	position: fixed; inset: var(--header-h) 0 0 0;
	background: var(--c-bg);
	padding: var(--space-5);
	transform: translateX(-100%);
	transition: transform var(--dur) var(--ease);
	overflow-y: auto;
	z-index: 49;
}
.saturno-nav.is-open { transform: translateX(0); }
.saturno-nav__list, .saturno-nav__list ul { list-style: none; padding: 0; margin: 0; }
.saturno-nav__list li { border-bottom: 1px solid var(--c-line); }
.saturno-nav__list a {
	display: block; padding: var(--space-3) 0;
	font-family: var(--ff-display); font-size: 1.75rem; font-weight: 500;
}

.saturno-menu-toggle {
	border: 0; background: transparent; padding: var(--space-2);
	display: flex; flex-direction: column; gap: 5px;
	width: 36px; height: 36px;
}

/* Botón X para cerrar el menú móvil — anula estilos de Astra (.wp-block-button)
   con triple selector + !important. La clase con BEM doble guion bajo evita
   colisiones con cualquier .saturno-nav-close global del padre. */
.saturno-nav .saturno-nav__close-btn,
button.saturno-nav__close-btn,
.saturno-nav button.saturno-nav__close-btn {
	position: absolute !important;
	top: 16px !important;
	right: 16px !important;
	background: transparent !important;
	background-color: transparent !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 8px !important;
	margin: 0 !important;
	width: auto !important;
	height: auto !important;
	color: var(--c-dark, #2C1A0E) !important;
	cursor: pointer !important;
	box-shadow: none !important;
	display: none;
	line-height: 1 !important;
	font-size: 0 !important;
	z-index: 102 !important;
}

.saturno-nav .saturno-nav__close-btn svg {
	width: 28px !important;
	height: 28px !important;
	stroke: currentColor !important;
	fill: none !important;
}

@media (max-width: 768px) {
	.saturno-nav .saturno-nav__close-btn {
		display: block !important;
	}
}

.saturno-nav .saturno-nav__close-btn:hover,
.saturno-nav .saturno-nav__close-btn:focus {
	background: transparent !important;
	color: var(--c-accent, #B8895A) !important;
	outline: none !important;
}
.saturno-menu-toggle span { display: block; width: 22px; height: 2px; background: var(--c-dark); transition: transform var(--dur) var(--ease); }
.saturno-menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.saturno-menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.saturno-menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.saturno-header__actions { margin-left: auto; display: flex; align-items: center; gap: var(--space-3); }

.saturno-lang-switcher {
	display: flex; gap: var(--space-2); list-style: none; padding: 0; margin: 0;
	font-size: .85rem; font-weight: 600; letter-spacing: .08em;
}
.saturno-lang-switcher a { padding: 4px 6px; color: var(--c-muted); }
.saturno-lang-switcher .is-current a { color: var(--c-dark); border-bottom: 1.5px solid var(--c-accent); }

.saturno-cart-link { position: relative; display: inline-flex; align-items: center; }
.saturno-cart-count {
	position: absolute; top: -6px; right: -10px;
	min-width: 18px; height: 18px; padding: 0 5px;
	background: var(--c-accent); color: var(--c-white);
	border-radius: 50%; font-size: 11px; font-weight: 700;
	display: inline-flex; align-items: center; justify-content: center;
}

/* WhatsApp flotante — anclado abajo derecha, con doble selector contra Astra.
   La cadena html body ... aumenta especificidad por encima de cualquier
   regla de Astra que use body o body.foo. */
.saturno-whatsapp-btn,
a.saturno-whatsapp-btn {
	position: fixed !important;
	bottom: 24px !important;
	right: 24px !important;
	z-index: 9999 !important;
	width: 56px !important;
	height: 56px !important;
	background: #25D366 !important;
	border-radius: 50% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	color: #fff !important;
	box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
	transition: transform 0.2s ease;
}

.saturno-whatsapp-btn:hover {
	transform: scale(1.05);
}

.saturno-whatsapp-btn svg {
	width: 28px !important;
	height: 28px !important;
}

/* Scroll-to-top de Astra — empujar arriba para no encimar con WhatsApp.
   Usa html body ... para ganar la guerra de especificidad con Astra. */
body #ast-scroll-top,
body .ast-scroll-top,
html body #ast-scroll-top,
html body .ast-scroll-top {
	bottom: 100px !important;
	right: 24px !important;
	z-index: 9998 !important;
}

@media (max-width: 768px) {
	.saturno-whatsapp-btn,
	a.saturno-whatsapp-btn {
		bottom: 16px !important;
		right: 16px !important;
		width: 50px !important;
		height: 50px !important;
	}
	body #ast-scroll-top,
	body .ast-scroll-top {
		bottom: 80px !important;
		right: 16px !important;
	}
}

/* 7. HERO Y SECCIONES HOME ----------------------------------------------- */
.saturno-hero {
	min-height: 92vh;
	display: flex; align-items: center;
	background-size: cover; background-position: center;
	color: var(--c-white);
	position: relative;
}
.saturno-hero__inner { max-width: 760px; padding-block: var(--space-7); }
.saturno-hero__eyebrow {
	font-family: var(--ff-serif); font-style: italic; font-weight: 400;
	color: var(--c-bg-alt);
	font-size: 1.1rem; letter-spacing: .01em; text-transform: none;
	margin: 0 0 var(--space-3);
}
.saturno-hero__title {
	color: var(--c-white);
	font-size: clamp(2.5rem, 7vw, 5rem);
	margin-bottom: var(--space-3);
}
.saturno-hero__subtitle {
	color: rgba(255,255,255,0.9);
	max-width: 580px; font-size: 1.0625rem; margin-bottom: var(--space-5);
}
.saturno-hero__ctas { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.saturno-hero__scroll {
	position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%);
	width: 1px; height: 40px; background: rgba(255,255,255,0.4);
	overflow: hidden;
}
.saturno-hero__scroll span {
	display: block; width: 100%; height: 50%;
	background: var(--c-white);
	animation: scroll-line 2s var(--ease) infinite;
}
@keyframes scroll-line { 0% { transform: translateY(-100%); } 100% { transform: translateY(200%); } }

/* Featured products grid */
.saturno-featured__grid {
	display: grid; gap: var(--space-4);
	grid-template-columns: repeat(2, 1fr);
}

/* Craftsmanship */
.saturno-craft__grid {
	display: grid; gap: var(--space-6);
}
.saturno-craft__media img { border-radius: var(--radius-lg); object-fit: cover; aspect-ratio: 4 / 5; }
.saturno-craft__pillars {
	list-style: none; padding: 0; margin: var(--space-4) 0;
	display: grid; gap: var(--space-3);
}
.saturno-craft__pillars li {
	padding: var(--space-3) 0; border-top: 1px solid var(--c-line);
}
.saturno-craft__pillars strong { display: block; margin-bottom: 4px; font-size: 1rem; }

/* B2B teaser */
.saturno-b2b-teaser {
	background-size: cover; background-position: center;
	color: var(--c-white);
	text-align: center;
}
.saturno-b2b-teaser__inner { max-width: 720px; margin: 0 auto; padding-block: var(--space-7); }
.saturno-b2b-teaser h2 { color: var(--c-white); margin-bottom: var(--space-3); }
.saturno-b2b-teaser p { color: rgba(255,255,255,0.88); margin-bottom: var(--space-5); font-size: 1.0625rem; }

/* Newsletter */
.saturno-newsletter-card {
	background: var(--c-dark); color: var(--c-white);
	border-radius: var(--radius-lg);
	padding: var(--space-7) var(--space-4); text-align: center;
}
.saturno-newsletter-card h2 { color: var(--c-white); }
.saturno-newsletter-card p { color: rgba(255,255,255,0.85); margin-bottom: var(--space-4); }

.saturno-newsletter-form {
	display: flex; flex-wrap: wrap; gap: var(--space-2);
	max-width: 480px; margin: 0 auto;
	position: relative;
}
.saturno-newsletter-form input {
	flex: 1 1 200px; min-width: 0;
	padding: 14px 16px; border-radius: var(--radius);
	border: 1px solid var(--c-line); background: var(--c-white); color: var(--c-dark);
	font-size: 1rem;
}
.saturno-newsletter-form button {
	padding: 14px 22px; background: var(--c-accent); color: var(--c-white);
	border: 0; border-radius: var(--radius);
	font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
	transition: background var(--dur) var(--ease);
}
.saturno-newsletter-form button:hover { background: var(--c-accent-2); }

/* Instagram */
.saturno-instagram__grid {
	display: grid; gap: var(--space-2);
	grid-template-columns: repeat(2, 1fr);
}
.saturno-instagram__item img {
	width: 100%; aspect-ratio: 1; object-fit: cover;
	transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.saturno-instagram__item:hover img { transform: scale(1.04); opacity: .85; }

/* 8. TARJETA PRODUCTO ---------------------------------------------------- */
.saturno-product-card {
	display: block;
	background: transparent;
	transition: transform var(--dur) var(--ease);
}
.saturno-product-card__image {
	overflow: hidden;
	background: var(--c-bg-alt);
	margin-bottom: var(--space-3);
	border-radius: var(--radius);
	aspect-ratio: 4 / 5;
}
.saturno-product-card__image img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .8s var(--ease);
}
.saturno-product-card:hover .saturno-product-card__image img { transform: scale(1.06); }
.saturno-product-card__title {
	font-family: var(--ff-display); font-size: 1.2rem; font-weight: 500; letter-spacing: -.005em;
	margin: 0 0 4px;
}
.saturno-product-card__short { color: var(--c-muted); font-size: .9rem; margin-bottom: 4px; }
.saturno-product-card__price { font-weight: 600; color: var(--c-dark); margin: 0; }

.saturno-sale-badge {
	display: inline-block; background: var(--c-accent); color: var(--c-white);
	padding: 4px 10px; font-size: .7rem; letter-spacing: .12em; text-transform: uppercase;
	border-radius: 999px; margin-bottom: var(--space-2);
}

/* 9. PÁGINAS -------------------------------------------------------------- */
.saturno-page-hero {
	padding: var(--space-7) 0 var(--space-4); text-align: center;
}
.saturno-page-hero h1 { margin: 0; }

.saturno-historia-hero, .saturno-mayoreo-hero {
	min-height: 60vh;
	display: flex; align-items: center;
	background-size: cover; background-position: center;
	color: var(--c-white);
}
.saturno-historia-hero h1, .saturno-mayoreo-hero h1 { color: var(--c-white); margin-top: var(--space-2); }

.saturno-historia-intro { max-width: var(--container-narrow); margin: 0 auto; font-size: 1.125rem; }

.saturno-process__grid {
	display: grid; gap: var(--space-5);
	grid-template-columns: 1fr;
}
.saturno-process__step { position: relative; }
.saturno-process__media { aspect-ratio: 4 / 5; overflow: hidden; border-radius: var(--radius); margin-bottom: var(--space-3); }
.saturno-process__media img { width: 100%; height: 100%; object-fit: cover; }
.saturno-process__number {
	display: inline-block; font-family: var(--ff-display); color: var(--c-accent);
	font-size: 1.5rem; font-weight: 200; letter-spacing: -.01em; margin-bottom: 4px;
}

.saturno-values__grid {
	display: grid; gap: var(--space-5);
	grid-template-columns: 1fr;
}
.saturno-value h3 { margin-bottom: var(--space-2); }

/* Mayoreo grid */
.saturno-mayoreo-grid {
	display: grid; gap: var(--space-5);
	grid-template-columns: 1fr;
}
.saturno-mayoreo-grid__item {
	padding: var(--space-5); background: var(--c-white);
	border-radius: var(--radius); border: 1px solid var(--c-line);
}
.saturno-mayoreo-grid__item h3 { margin-bottom: var(--space-2); }

/* Contacto */
.saturno-contact-grid { display: grid; gap: var(--space-6); }
.saturno-contact-info__list { list-style: none; padding: 0; margin: var(--space-3) 0; }
.saturno-contact-info__list li { padding: var(--space-2) 0; border-bottom: 1px solid var(--c-line); }
.saturno-map iframe { width: 100%; border-radius: var(--radius); }

/* 404 */
.saturno-404 { padding: var(--space-9) 0; text-align: center; }
.saturno-404__inner { max-width: 600px; margin: 0 auto; }
.saturno-404__ctas { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-3); margin: var(--space-4) 0; }
.saturno-404__search { margin-top: var(--space-5); }

/* Single post */
.saturno-single__header { padding: var(--space-7) 0 var(--space-4); text-align: center; }
.saturno-single__meta { color: var(--c-muted); font-size: .85rem; letter-spacing: .08em; text-transform: uppercase; margin-bottom: var(--space-3); }
.saturno-single__title { max-width: 800px; margin: 0 auto; }
.saturno-single__hero { margin-top: var(--space-5); aspect-ratio: 16 / 9; overflow: hidden; }
.saturno-single__hero img { width: 100%; height: 100%; object-fit: cover; }
.saturno-single__content { max-width: var(--container-narrow); margin: var(--space-7) auto; }
.saturno-single__content > * { margin-bottom: var(--space-3); }
.saturno-single__content img { border-radius: var(--radius); margin: var(--space-4) 0; }

/* Blog grid */
.saturno-blog-grid {
	display: grid; gap: var(--space-5);
	grid-template-columns: 1fr;
}
.saturno-blog-card__image { aspect-ratio: 16 / 10; overflow: hidden; border-radius: var(--radius); margin-bottom: var(--space-3); }
.saturno-blog-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.saturno-blog-card:hover .saturno-blog-card__image img { transform: scale(1.05); }
.saturno-blog-card__meta { color: var(--c-muted); font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; margin-bottom: var(--space-2); }
.saturno-blog-card__title { margin-bottom: var(--space-2); font-size: 1.5rem; }
.saturno-blog-card__excerpt { color: var(--c-muted); font-size: .95rem; }

.saturno-pagination { margin-top: var(--space-7); text-align: center; }
.saturno-pagination .page-numbers {
	display: inline-block; padding: 8px 14px; margin: 0 2px;
	border: 1px solid var(--c-line); border-radius: var(--radius);
}
.saturno-pagination .page-numbers.current { background: var(--c-dark); color: var(--c-white); border-color: var(--c-dark); }

/* 10. FOOTER -------------------------------------------------------------- */
.saturno-footer {
	background: var(--c-dark);
	color: var(--c-bg-alt);
	padding-top: var(--space-7);
}
.saturno-footer .saturno-logo-text { color: var(--c-white); }

/* Logo footer — dos variantes según extensión, evita conflicto entre invert y color.
   Variante PNG: invierte colores asumiendo logo monocromo oscuro sobre fondo oscuro.
   Variante SVG (respaldo): drop-shadow sutil para destacar sin alterar el color. */
.saturno-footer__brand {
	margin-bottom: var(--space-4);
}

.saturno-footer__brand .saturno-logo {
	display: inline-block;
}

/* Default + PNG (logos monocromos en raster) */
.saturno-footer__brand .saturno-logo img {
	max-width: 180px !important;
	height: auto !important;
	filter: invert(1) brightness(1.5) !important;
	opacity: 0.9 !important;
	mix-blend-mode: normal !important;
}

/* SVG con colores: drop-shadow en vez de invertir para preservar el arte. */
.saturno-footer__brand .saturno-logo img[src$=".svg"],
.saturno-footer__brand .saturno-logo img[src*=".svg?"] {
	filter: drop-shadow(0 0 1px rgba(245,240,235,0.5)) !important;
	opacity: 1 !important;
}
.saturno-footer h4 { color: var(--c-white); margin-bottom: var(--space-3); }
.saturno-footer a { color: var(--c-bg-alt); }
.saturno-footer a:hover { color: var(--c-accent); }

.saturno-footer__grid {
	display: grid; gap: var(--space-6);
	grid-template-columns: 1fr;
	padding-bottom: var(--space-6);
}
.saturno-footer__tagline { font-size: .9rem; color: rgba(255,255,255,0.7); margin-top: var(--space-2); }
.saturno-footer__menu { list-style: none; padding: 0; margin: 0; }
.saturno-footer__menu li { padding: 4px 0; }
.saturno-footer__contact { list-style: none; padding: 0; margin: 0 0 var(--space-3); font-size: .92rem; }
.saturno-footer__contact li { padding: 4px 0; }

.saturno-social { display: flex; gap: var(--space-2); }
.saturno-social a {
	width: 36px; height: 36px;
	border: 1px solid rgba(255,255,255,0.3);
	border-radius: 50%;
	display: inline-flex; align-items: center; justify-content: center;
	font-size: .75rem; font-weight: 600; letter-spacing: .04em;
}
.saturno-social a:hover { border-color: var(--c-accent); background: var(--c-accent); color: var(--c-white); }

.saturno-footer__bottom {
	border-top: 1px solid rgba(255,255,255,0.12);
	padding: var(--space-4) 0;
	font-size: .82rem;
	color: rgba(255,255,255,0.6);
}
.saturno-footer__bottom .saturno-container {
	display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: space-between;
}
.saturno-footer__bottom p { margin: 0; }

/* 11. FORMULARIOS --------------------------------------------------------- */
.saturno-form { max-width: 760px; margin: 0 auto; }
.saturno-form__row { display: grid; grid-template-columns: 1fr; gap: var(--space-3); margin-bottom: var(--space-3); }
.saturno-form__field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--space-3); }
.saturno-form__field label { font-size: .85rem; font-weight: 600; letter-spacing: .04em; color: var(--c-dark-2); }
.saturno-form__field input,
.saturno-form__field select,
.saturno-form__field textarea {
	width: 100%;
	padding: 12px 14px;
	background: var(--c-white);
	border: 1px solid var(--c-line);
	border-radius: var(--radius);
	font-family: inherit; font-size: 1rem; color: var(--c-dark);
	transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.saturno-form__field input:focus,
.saturno-form__field select:focus,
.saturno-form__field textarea:focus {
	outline: none;
	border-color: var(--c-accent);
	box-shadow: 0 0 0 3px rgba(184,137,90,0.18);
}
.saturno-form__field input:invalid:not(:placeholder-shown),
.saturno-form__field [aria-invalid="true"] { border-color: #C84A3A; }

.saturno-form__submit { margin-top: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); }
.saturno-form__legal { font-size: .8rem; color: var(--c-muted); margin: 0; }

.saturno-form-status {
	padding: var(--space-3); border-radius: var(--radius);
	margin-bottom: var(--space-4); font-weight: 500;
}
.saturno-form-status--success { background: #E5F0E0; color: #2D5B1F; border: 1px solid #B6D4A8; }
.saturno-form-status--error   { background: #F8E1DC; color: #7A2B1F; border: 1px solid #E8B7AC; }

/* Search form */
.saturno-search-form { display: flex; gap: var(--space-2); max-width: 480px; margin: 0 auto; }
.saturno-search-form input { flex: 1; padding: 12px 16px; border: 1px solid var(--c-line); border-radius: var(--radius); }
.saturno-search-form button { padding: 0 16px; background: var(--c-dark); color: var(--c-white); border: 0; border-radius: var(--radius); }

/* 12. ANIMACIONES (AOS-lite) --------------------------------------------- */
[data-aos] {
	opacity: 0;
	transition: opacity .6s var(--ease), transform .6s var(--ease);
	will-change: opacity, transform;
}
[data-aos="fade-up"]    { transform: translateY(24px); }
[data-aos="fade-right"] { transform: translateX(-24px); }
[data-aos="fade-left"]  { transform: translateX(24px); }
[data-aos="zoom-in"]    { transform: scale(0.96); }
[data-aos].is-visible {
	opacity: 1;
	transform: none;
}
@media (prefers-reduced-motion: reduce) {
	[data-aos], [data-aos].is-visible { transition: none; transform: none; opacity: 1; }
	html { scroll-behavior: auto; }
}

/* 13. ACCESIBILIDAD ------------------------------------------------------- */
.screen-reader-text, .saturno-skip-link {
	position: absolute !important;
	width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px);
	white-space: nowrap;
}
.saturno-skip-link:focus {
	position: fixed !important; top: 8px; left: 8px;
	width: auto; height: auto; clip: auto;
	padding: 8px 16px; background: var(--c-dark); color: var(--c-white);
	z-index: 100;
}
:focus-visible { outline: 2px solid var(--c-accent); outline-offset: 3px; }

/* 14. RESPONSIVE ---------------------------------------------------------- */
@media (min-width: 768px) {
	.saturno-menu-toggle { display: none; }
	.saturno-nav {
		position: static; inset: auto;
		transform: none;
		background: transparent;
		padding: 0;
	}
	.saturno-nav__list {
		display: flex; align-items: center; gap: var(--space-5);
	}
	.saturno-nav__list li { border: 0; }
	.saturno-nav__list a {
		padding: var(--space-2) 0; font-family: var(--ff-sans); font-size: .92rem;
		font-weight: 500; letter-spacing: .04em; text-transform: uppercase;
	}
	.saturno-nav__list a:hover { color: var(--c-accent); }

	.saturno-featured__grid { grid-template-columns: repeat(5, 1fr); }
	.saturno-craft__grid { grid-template-columns: 1fr 1.1fr; align-items: center; }
	.saturno-instagram__grid { grid-template-columns: repeat(6, 1fr); }
	.saturno-process__grid { grid-template-columns: repeat(3, 1fr); }
	.saturno-values__grid { grid-template-columns: repeat(2, 1fr); }
	.saturno-mayoreo-grid { grid-template-columns: repeat(2, 1fr); }
	.saturno-contact-grid { grid-template-columns: 1fr 1.4fr; }
	.saturno-blog-grid { grid-template-columns: repeat(2, 1fr); }
	.saturno-footer__grid { grid-template-columns: 1.4fr 1fr 1fr 1.4fr; }
	.saturno-form__row { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
	.saturno-values__grid { grid-template-columns: repeat(4, 1fr); }
	.saturno-blog-grid { grid-template-columns: repeat(3, 1fr); }
	.saturno-newsletter-card { padding: var(--space-8); }
}

/* ==========================================================================
   15. AJUSTES MÓVILES (v1.1) — navbar limpio + grids generosos en mobile
   ========================================================================== */
@media (max-width: 768px) {
	/* Navbar móvil más limpio */
	.saturno-header__inner {
		padding: 12px 16px;
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
	}

	/* Regla del logo navbar movida a su propia sección (17) — single source of truth. */

	/* Menú hamburguesa visible en móvil */
	.saturno-menu-toggle {
		display: flex;
		flex-direction: column;
		justify-content: space-around;
		width: 28px;
		height: 22px;
		background: transparent;
		border: 0;
		cursor: pointer;
		padding: 0;
	}
	.saturno-menu-toggle span {
		display: block;
		width: 100%;
		height: 2px;
		background: var(--c-dark);
		transition: all 0.3s ease;
	}

	/* Navegación móvil — full-screen overlay */
	.saturno-nav {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100vh;
		background: var(--c-bg);
		transform: translateX(-100%);
		transition: transform 0.3s ease;
		z-index: 100;
		padding: 80px 24px 24px;
	}
	.saturno-nav.is-open {
		transform: translateX(0);
	}
	.saturno-nav__list {
		display: flex;
		flex-direction: column;
		gap: 20px;
		list-style: none;
		padding: 0;
		margin: 0;
	}
	.saturno-nav__list a {
		font-family: var(--ff-display);
		font-size: 1.5rem;
		color: var(--c-dark);
		text-decoration: none;
	}
}

@media (min-width: 769px) {
	.saturno-menu-toggle {
		display: none;
	}
}

/* Modelos destacados — más espacio en móvil */
@media (max-width: 768px) {
	.saturno-featured__grid,
	.woocommerce ul.products {
		grid-template-columns: 1fr !important;
		gap: 32px !important;
		padding: 0 16px;
	}

	.saturno-product-card {
		padding-bottom: 16px;
	}

	.saturno-product-card__image {
		margin-bottom: 12px;
	}

	.saturno-section {
		padding: 48px 0;
	}

	.saturno-section__header {
		padding: 0 16px;
		margin-bottom: 32px;
	}

	.saturno-hero__title {
		font-size: 2.25rem !important;
		line-height: 1.1;
	}

	.saturno-hero__subtitle {
		font-size: 1rem;
		padding: 0 16px;
	}

	.saturno-hero__ctas {
		flex-direction: column;
		gap: 12px;
		padding: 0 16px;
	}

	.saturno-hero__ctas .saturno-btn {
		width: 100%;
		text-align: center;
	}
}

/* ==========================================================================
   16. AJUSTES TABLET / DESKTOP CHICO (v1.2) — 769–1024px
   El navbar se comprime para no romper en pantallas intermedias.
   ========================================================================== */
@media (min-width: 769px) and (max-width: 1024px) {
	.saturno-header__inner {
		padding: 12px 16px;
		gap: 16px;
	}

	.saturno-nav__list {
		gap: 16px;
	}

	.saturno-nav__list a {
		font-size: 0.9rem;
	}

	/* Regla del logo navbar consolidada en sección 17 (no pisar aquí). */
}

/* ==========================================================================
   17. LOGO NAVBAR (v1.3) — single source of truth
   Consolidación: las reglas previas en secciones 15 y 16 fueron eliminadas
   para evitar contradicciones acumuladas entre versiones.
   ========================================================================== */
.saturno-header__logo img,
.saturno-header__logo .saturno-logo img {
	max-height: 56px;
	width: auto;
	max-width: 220px;
	object-fit: contain;
}

@media (max-width: 768px) {
	.saturno-header__logo img,
	.saturno-header__logo .saturno-logo img {
		max-height: 44px !important;
		max-width: 160px !important;
	}
}

/* ==========================================================================
   18. SCROLL-TOP DE ASTRA — colores de marca (v1.4)
   El componente nativo de Astra usa azul #046bd2 que desentona. Lo pintamos
   con la paleta Saturno: fondo marrón oscuro, hover en tan, ícono cream.
   ========================================================================== */
body #ast-scroll-top,
html body #ast-scroll-top,
body .ast-scroll-top-icon {
	background-color: #2C1A0E !important;
	color: #F5F0EB !important;
	border-radius: 50% !important;
	width: 48px !important;
	height: 48px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

body #ast-scroll-top:hover {
	background-color: #B8895A !important;
}

body #ast-scroll-top svg,
body #ast-scroll-top .ast-icon-arrow {
	fill: currentColor !important;
	width: 18px !important;
	height: 18px !important;
}

/* ==========================================================================
   19. FEATURED PRODUCTS — grid 2x2 (v1.5)
   El shortcode de WC genera 4 items; forzamos 2 columnas tanto si vienen del
   loop de WC como si vienen del fallback estático del template.
   ========================================================================== */
.saturno-featured .woocommerce ul.products,
.saturno-featured .saturno-featured__grid {
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 32px !important;
}

.saturno-featured .saturno-product-card__image,
.saturno-featured .woocommerce ul.products li.product img {
	aspect-ratio: 4/5;
	object-fit: cover;
	width: 100%;
}

.saturno-featured .saturno-product-card__title,
.saturno-featured .woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 1.25rem !important;
	margin-top: 16px;
}

.saturno-featured .saturno-product-card__price,
.saturno-featured .woocommerce ul.products li.product .price {
	font-size: 1.1rem !important;
	font-weight: 600;
	margin-top: 8px;
}

@media (max-width: 768px) {
	.saturno-featured .woocommerce ul.products,
	.saturno-featured .saturno-featured__grid {
		grid-template-columns: 1fr !important;
	}
}
