/* =========================================================================
   Highland — main.css
   Paleta Ikurriña refinada · Cormorant Garamond + Inter
   ========================================================================= */

/* ----------------------------------------------------------------- Tokens */
:root {
	--c-white:       #FFFFFF;
	--c-off-white:   #FAF7F1;
	--c-stone:       #ECE6D7;
	--c-stone-mute:  #D4C5A9;
	--c-ink:         #1A1A1A;
	--c-ink-soft:    #3A3A3A;
	--c-ink-mute:    #6A6A6A;
	--c-line:        #E6E2D8;
	--c-line-strong: #0A0A0A;
	--c-black:       #0A0A0A;

	--c-green:       #1B5E3F;
	--c-green-deep:  #0F3D27;
	--c-red:         #B81E1E;
	--c-red-deep:    #7A0F0F;
	--c-brass:       #B8860B;

	--ff-display: 'Cormorant Garamond', 'Times New Roman', Georgia, serif;
	--ff-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Arial, sans-serif;

	--fs-xs:  0.75rem;     /* 12 */
	--fs-sm:  0.875rem;    /* 14 */
	--fs-md:  1rem;        /* 16 */
	--fs-lg:  1.125rem;    /* 18 */
	--fs-xl:  clamp(1.25rem, 1rem + 1vw, 1.75rem);
	--fs-2xl: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	--fs-3xl: clamp(2rem, 1.25rem + 3vw, 3.75rem);
	--fs-4xl: clamp(2.5rem, 1.25rem + 5vw, 5rem);

	--ls-tight:  -0.01em;
	--ls-normal:  0;
	--ls-wide:    0.08em;
	--ls-wider:   0.15em;
	--ls-widest:  0.2em;

	--space-0:  0;
	--space-1:  0.25rem;
	--space-2:  0.5rem;
	--space-3:  0.75rem;
	--space-4:  1rem;
	--space-5:  1.5rem;
	--space-6:  2rem;
	--space-8:  3rem;
	--space-10: 4rem;
	--space-12: 5rem;
	--space-16: 7rem;
	--space-20: 9rem;

	--radius-0: 0;
	--radius-sm: 2px;
	--radius-md: 4px;

	--ease: cubic-bezier(.22, .61, .36, 1);
	--dur:  280ms;

	--container: 1240px;
	--container-narrow: 920px;
	--container-wide: 1440px;
	--gutter: clamp(1rem, 4vw, 2.5rem);

	--header-h: 88px;
	--topbar-h: 36px;
}

/* ----------------------------------------------------------------- Reset */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }

body {
	margin: 0;
	background: var(--c-white);
	color: var(--c-ink);
	font-family: var(--ff-body);
	font-size: var(--fs-md);
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings: "kern", "liga", "calt";
}

img, svg, video { max-width: 100%; height: auto; display: block; }

button { font: inherit; cursor: pointer; background: none; border: 0; padding: 0; color: inherit; }
input, select, textarea { font: inherit; color: inherit; }

a { color: var(--c-black); text-decoration: none; transition: color var(--dur) var(--ease); }
a:hover { color: var(--c-red); }

::selection { background: var(--c-red); color: #fff; }

/* <mark> en HTML5 (lo usa WC en "Tu pedido #X se realizó el ..." y similares).
 * Lo neutralizamos: sin fondo, sin resaltado, texto normal. */
mark {
	background: transparent;
	color: inherit;
	font-weight: inherit;
	padding: 0;
}

:focus-visible {
	outline: 2px solid var(--c-red);
	outline-offset: 3px;
}

/* ----------------------------------------------------------------- Tipografía */
.is-serif, .display { font-family: var(--ff-display); }

h1, h2, h3, h4 {
	font-family: var(--ff-display);
	font-weight: 400;
	color: var(--c-black);
	margin: 0 0 var(--space-4);
	line-height: 1.15;
}
h1 { font-size: var(--fs-4xl); font-weight: 300; letter-spacing: var(--ls-tight); line-height: 1.04; }
h2 { font-size: var(--fs-3xl); }
h3 { font-size: var(--fs-2xl); }
h4 { font-size: var(--fs-xl); font-weight: 500; }

p { margin: 0 0 1em; }

.eyebrow {
	display: inline-block;
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-red);
}
.eyebrow--green { color: var(--c-green); }
.eyebrow--white { color: #fff; }
.eyebrow--ink   { color: var(--c-ink); }

.lead {
	font-size: var(--fs-lg);
	color: var(--c-ink-soft);
	max-width: 56ch;
}

/* ----------------------------------------------------------------- Layout */
.wrap {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: var(--gutter);
}
.wrap--narrow { max-width: var(--container-narrow); }
.wrap--wide   { max-width: var(--container-wide); }
.wrap--full   { max-width: 100%; padding-inline: 0; }

.section       { padding-block: clamp(3.5rem, 6vw, 7rem); }
.section--cream { background: var(--c-off-white); }
.section--green { background: var(--c-green); color: #fff; }
.section--green :is(h1,h2,h3,h4,a) { color: #fff; }
.section--red   { background: var(--c-red); color: #fff; }
.section--red :is(h1,h2,h3,h4,a) { color: #fff; }
.section--black { background: var(--c-black); color: #fff; }
.section--black :is(h1,h2,h3,h4,a) { color: #fff; }

.section__head { text-align: center; margin-bottom: var(--space-10); }
.section__head .eyebrow { margin-bottom: var(--space-3); }
.section__head h2 { margin-bottom: var(--space-3); }
.section__head .lead { margin-inline: auto; }

.hr-thin { display: inline-block; width: 36px; height: 1px; background: var(--c-line-strong); margin: var(--space-4) 0; }
.hr-thin.hr-red   { background: var(--c-red); }
.hr-thin.hr-green { background: var(--c-green); }
.hr-thin.hr-white { background: #fff; }
.hr-thin.is-block { display: block; }

/* ----------------------------------------------------------------- Botones */
.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 0.95rem 1.75rem;
	font-family: var(--ff-body);
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	border: 1px solid transparent;
	border-radius: 0;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
	cursor: pointer;
}
.btn--red    { background: var(--c-red);   color: #fff; }
.btn--red:hover { background: var(--c-red-deep); color: #fff; }
.btn--green  { background: var(--c-green); color: #fff; }
.btn--green:hover { background: var(--c-green-deep); color: #fff; }
.btn--black  { background: var(--c-black); color: #fff; }
.btn--black:hover { background: #222; color: #fff; }
.btn--ghost  { background: transparent; color: var(--c-black); border-color: var(--c-black); }
.btn--ghost:hover { background: var(--c-black); color: #fff; }
.btn--ghost-light { background: transparent; color: #fff; border-color: #fff; }
.btn--ghost-light:hover { background: #fff; color: var(--c-black); }

.link-arrow {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	border-bottom: 1px solid currentColor;
	padding-bottom: 2px;
	font-weight: 500;
	color: var(--c-black);
}
.link-arrow:hover { color: var(--c-red); }
.link-arrow .arrow { transition: transform var(--dur) var(--ease); color: var(--c-red); }
.link-arrow:hover .arrow { transform: translateX(4px); }

/* ----------------------------------------------------------------- Marca Ikurriña */
.ikurrina-mark {
	position: relative;
	display: inline-block;
	background: #fff;
	border: 1px solid #fff;
	box-sizing: border-box;
	flex: 0 0 auto;
}
.ikurrina-mark__bg    { position: absolute; inset: 0; background: var(--c-red); }
.ikurrina-mark__cross,
.ikurrina-mark__diag  { position: absolute; inset: 0; }
.ikurrina-mark__cross::before,
.ikurrina-mark__cross::after {
	content: ""; position: absolute; background: #fff;
}
.ikurrina-mark__cross::before { top: 50%; left: 0; right: 0; height: 18%; transform: translateY(-50%); }
.ikurrina-mark__cross::after  { left: 50%; top: 0; bottom: 0; width: 18%; transform: translateX(-50%); }
.ikurrina-mark__diag::before,
.ikurrina-mark__diag::after {
	content: ""; position: absolute; left: -10%; right: -10%; height: 14%; background: var(--c-green);
}
.ikurrina-mark__diag::before { top: 50%; transform: translateY(-50%) rotate(45deg); }
.ikurrina-mark__diag::after  { top: 50%; transform: translateY(-50%) rotate(-45deg); }

/* ----------------------------------------------------------------- Top bar */
.topbar {
	background: var(--c-black);
	color: #fff;
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	height: var(--topbar-h);
	display: flex;
	align-items: center;
}
.topbar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
}
.topbar__left { display: flex; align-items: center; gap: var(--space-3); }
.topbar__right { display: flex; align-items: center; gap: var(--space-5); }
.topbar__msg  { color: rgba(255,255,255,.85); }
.topbar__nav  { display: flex; gap: var(--space-5); list-style: none; padding: 0; margin: 0; }
.topbar__nav a { color: rgba(255,255,255,.7); }
.topbar__nav a:hover { color: #fff; }

/* Language switcher */
.lang-switch {
	display: flex;
	align-items: center;
	gap: 0;
	list-style: none;
	padding: 0;
	margin: 0;
}
.lang-switch li { line-height: 1; }
.lang-switch li + li { padding-left: 0.6rem; margin-left: 0.6rem; border-left: 1px solid rgba(255,255,255,.18); }
.lang-switch a {
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: rgba(255,255,255,.65);
}
.lang-switch a:hover,
.lang-switch .current-lang a,
.lang-switch .current_lang a { color: #fff; }
.lang-switch .current-lang,
.lang-switch .current_lang { pointer-events: none; }
.lang-switch img.flag,
.lang-switch .flag { display: none; }

/* ----------------------------------------------------------------- Header */
.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: #fff;
	border-bottom: 1px solid var(--c-line);
}
.header__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--space-6);
	min-height: var(--header-h);
}
.header__menu-toggle { grid-column: 1; }
.brand            { grid-column: 1; justify-self: start; text-align: left; }
.nav              { grid-column: 2; justify-self: end; min-width: 0; }
.header__actions  { grid-column: 3; justify-self: end; }
.nav__list {
	list-style: none;
	padding: 0; margin: 0;
	display: flex;
	flex-wrap: nowrap;
	gap: clamp(1rem, 2vw, 2rem);
	white-space: nowrap;
}
.nav__item { white-space: nowrap; }
.nav__link {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	padding: 6px 0;
	border-bottom: 1px solid transparent;
	white-space: nowrap;
}
.nav__link:hover,
.current-menu-item > .nav__link { color: var(--c-red); border-bottom-color: var(--c-red); }

.brand {
	color: var(--c-black);
	line-height: 1;
}
.brand__link {
	display: inline-flex;
	align-items: center;
	gap: clamp(0.6rem, 1vw, 0.9rem);
	color: inherit;
	text-decoration: none;
}
.brand__logo {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	flex: 0 0 auto;
}
.brand__logo svg {
	height: clamp(36px, 3vw, 48px);
	width: auto;
	display: block;
	color: var(--c-black);
	transition: color var(--dur) var(--ease);
	overflow: visible;
}
.brand__link:hover .brand__logo svg { color: var(--c-red); }
.brand__text {
	display: inline-flex;
	flex-direction: column;
	gap: 4px;
	line-height: 1;
}
.brand__name {
	display: inline-flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 0 0.35rem;
	font-family: var(--ff-display);
	font-size: clamp(1.05rem, 0.85rem + 0.55vw, 1.4rem);
	font-weight: 500;
	letter-spacing: var(--ls-tight);
	color: var(--c-black);
	line-height: 1;
}
.brand__name-line {
	display: inline-block;
	white-space: nowrap;
	line-height: 1.05;
}
.brand__sub {
	font-family: var(--ff-body);
	font-size: 0.62rem;
	font-weight: 500;
	letter-spacing: var(--ls-widest);
	color: var(--c-ink-mute);
	text-transform: uppercase;
	white-space: nowrap;
}
/* WP custom logo (cuando se sube desde el Customizer) */
.custom-logo-link { display: inline-block; line-height: 0; }
.custom-logo {
	height: clamp(36px, 3vw, 48px) !important;
	width: auto !important;
	max-height: 48px;
}

.header__actions {
	justify-self: end;
	display: flex;
	align-items: center;
	gap: var(--space-5);
}
.header__icon-btn,
.header__cart {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	color: var(--c-black);
}
.header__cart-count {
	display: inline-grid;
	place-items: center;
	min-width: 22px; height: 22px;
	padding: 0 6px;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0;
	background: var(--c-red);
	color: #fff;
	border-radius: 999px;
}
.header__menu-toggle { display: none; }

/* Overlay y botón close del drawer móvil — ocultos en desktop */
.nav-overlay,
.nav__close { display: none; }

/* ----------------------------------------------------------------- Hero */
.hero {
	position: relative;
	overflow: hidden;
	min-height: clamp(520px, 78vh, 820px);
	display: grid;
	align-items: end;
	color: #fff;
	background: var(--c-green-deep);
	isolation: isolate;
}
.hero__bg {
	position: absolute;
	inset: 0;
	z-index: -1;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.hero__bg::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 100%);
}
.hero__inner {
	position: relative;
	padding-block: clamp(4rem, 10vh, 8rem);
}
.hero__eyebrow { color: rgba(255,255,255,.85); margin-bottom: var(--space-4); display: inline-flex; align-items: center; gap: 0.6rem; }
.hero__eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--c-red); display: inline-block; }

.hero__title {
	position: relative;
	max-width: 18ch;
	color: #fff;
	font-size: var(--fs-4xl);
	font-weight: 300;
	line-height: 1.04;
	letter-spacing: -0.01em;
	padding-left: 1.25rem;
	margin: 0 0 var(--space-5);
}
.hero__title::before {
	content: "";
	position: absolute;
	left: 0; top: 0.4em; bottom: 0.4em;
	width: 3px;
	background: var(--c-red);
}
.hero__subtitle {
	max-width: 48ch;
	color: rgba(255,255,255,.9);
	font-size: var(--fs-lg);
	margin-bottom: var(--space-6);
}
.hero__ctas { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* ----------------------------------------------------------------- Trust band */
.trust {
	border-block: 1px solid var(--c-line);
	background: #fff;
}
.trust__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--gutter);
}
.trust__item {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	padding-block: var(--space-6);
}
.trust__item + .trust__item { border-left: 1px solid var(--c-line); padding-left: var(--space-6); }
.trust__icon {
	width: 38px; height: 38px;
	display: grid; place-items: center;
	color: var(--c-black);
}
.trust__icon svg .accent { stroke: var(--c-red); }
.trust__title { font-family: var(--ff-display); font-size: 1.25rem; line-height: 1.2; margin: 0; color: var(--c-black); }
.trust__desc  { font-size: 0.875rem; color: var(--c-ink-mute); margin: 4px 0 0; letter-spacing: 0.02em; }

/* ----------------------------------------------------------------- Story split */
.story {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 540px;
}
.story__media {
	background-size: cover;
	background-position: center;
	position: relative;
	min-height: 380px;
}
.story__panel {
	background: var(--c-green);
	color: #fff;
	padding: clamp(2.5rem, 5vw, 5rem);
	display: grid;
	align-content: center;
}
.story__panel h2 { color: #fff; max-width: 18ch; }
.story__panel p  { color: rgba(255,255,255,.88); max-width: 52ch; }
.story__panel .link-arrow { color: #fff; border-color: rgba(255,255,255,.4); }
.story__panel .link-arrow:hover { color: #fff; border-color: #fff; }
.story__panel .link-arrow .arrow { color: var(--c-red); }

/* ----------------------------------------------------------------- Product cards */
.product-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-6);
}
.product-card {
	background: var(--c-off-white);
	border: 1px solid var(--c-line-strong);
	display: flex;
	flex-direction: column;
	padding: 0;
	position: relative;
	transition: transform var(--dur) var(--ease);
}
.product-card:hover { transform: translateY(-3px); }
.product-card__media {
	position: relative;
	aspect-ratio: 4 / 5;
	overflow: hidden;
	background: var(--c-stone);
}
.product-card__media img,
.product-card .woocommerce-loop-product__link img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform 600ms var(--ease);
}
.product-card:hover .product-card__media img,
.product-card:hover .woocommerce-loop-product__link img {
	transform: scale(1.04);
}
.product-card__body {
	padding: var(--space-5) var(--space-5) var(--space-6);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	flex: 1 1 auto;
	min-height: 0;
}
.product-card__cat {
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-red);
	font-weight: 600;
}
.product-card__title {
	font-family: var(--ff-display);
	font-size: 1.5rem;
	line-height: 1.2;
	color: var(--c-black);
	margin: 0;
}
.product-card__desc { color: var(--c-ink-mute); font-size: 0.9rem; margin: 0; }
.product-card__foot {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--space-3);
	margin-top: auto;
	padding-top: var(--space-3);
	border-top: 1px solid var(--c-line);
	min-width: 0;
}
.product-card__foot > * { min-width: 0; }
.product-card__foot .product-card__price { width: 100%; }
.product-card__foot .product-card__cta { align-self: stretch; justify-content: center; }
.product-card__price {
	font-family: var(--ff-display);
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--c-black);
	display: flex;
	align-items: baseline;
	gap: 0.6rem;
	flex-wrap: wrap;
}
.product-card__price del {
	font-size: 0.95rem;
	color: var(--c-ink-mute);
	font-weight: 400;
	text-decoration: line-through;
	opacity: 0.75;
}
.product-card__price del .woocommerce-Price-amount { font: inherit; color: inherit; }
.product-card__price ins {
	text-decoration: none;
	color: var(--c-red);
	background: transparent;
}
.product-card__price ins .woocommerce-Price-amount { font: inherit; color: inherit; }
.product-card__cta {
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-red);
	display: inline-flex; align-items: center; gap: 0.35rem;
}
.product-card__cta:hover { color: var(--c-red-deep); }

/* ----------------------------------------------------------------- Pull quote */
.pull-quote {
	position: relative;
	min-height: 480px;
	color: #fff;
	display: grid;
	place-items: center;
	text-align: center;
	background: #2a2a2a;
}
.pull-quote__bg {
	position: absolute; inset: 0; z-index: 0;
	background-size: cover; background-position: center;
}
.pull-quote__bg::after {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 100%);
}
.pull-quote__inner { position: relative; z-index: 1; max-width: 38ch; padding-inline: var(--gutter); }
.pull-quote__rule {
	display: block; width: 40px; height: 2px; background: var(--c-red);
	margin: 0 auto var(--space-5);
}
.pull-quote__text {
	font-family: var(--ff-display);
	font-style: italic;
	font-weight: 300;
	font-size: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	line-height: 1.25;
	color: #fff;
}
.pull-quote__cite {
	display: block;
	margin-top: var(--space-5);
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: rgba(255,255,255,.7);
	font-style: normal;
}

/* ----------------------------------------------------------------- Values triptych */
.values {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
}
.values__item {
	padding: var(--space-8) var(--space-5);
	text-align: center;
}
.values__item + .values__item { border-left: 1px solid var(--c-line-strong); }
.values__icon {
	width: 48px; height: 48px;
	margin: 0 auto var(--space-4);
	display: grid; place-items: center;
	color: var(--c-black);
}
.values__icon svg .accent { stroke: var(--c-red); }
.values__title { font-family: var(--ff-display); font-size: 1.5rem; margin: 0 0 var(--space-2); color: var(--c-black); }
.values__text  { font-size: 0.95rem; color: var(--c-ink-soft); max-width: 32ch; margin-inline: auto; }

/* ----------------------------------------------------------------- Blog teasers */
.posts-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-6);
}
.post-card {
	background: var(--c-off-white);
	display: grid;
	grid-template-rows: auto 1fr;
	overflow: hidden;
}
.post-card__media {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--c-stone);
}
.post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms var(--ease); }
.post-card:hover .post-card__media img { transform: scale(1.04); }
.post-card__body { padding: var(--space-5) var(--space-5) var(--space-6); display: grid; gap: var(--space-3); align-content: start; }
.post-card__cat  { font-size: var(--fs-xs); letter-spacing: var(--ls-wider); text-transform: uppercase; color: var(--c-red); font-weight: 600; }
.post-card__title { font-family: var(--ff-display); font-size: 1.5rem; line-height: 1.25; margin: 0; color: var(--c-black); }
.post-card__title a { color: inherit; }
.post-card__title a:hover { color: var(--c-red); }
.post-card__date { font-size: var(--fs-xs); color: var(--c-ink-mute); letter-spacing: var(--ls-wide); text-transform: uppercase; }

/* ----------------------------------------------------------------- Newsletter */
.newsletter {
	background: var(--c-red);
	color: #fff;
	padding-block: clamp(3rem, 6vw, 5.5rem);
	text-align: center;
}
.newsletter h2 { color: #fff; font-style: italic; font-weight: 400; margin-bottom: var(--space-3); }
.newsletter__lead { color: rgba(255,255,255,.85); max-width: 56ch; margin: 0 auto var(--space-6); }
.newsletter__form {
	display: flex;
	align-items: stretch;
	max-width: 560px;
	margin-inline: auto;
	background: #fff;
	border: 1px solid #fff;
	position: relative;
}
/* Hidden + honeypot fuera del flujo: no ocupan espacio dentro del flex */
.newsletter__form input[type="hidden"] { display: none !important; }
.newsletter__form > div[aria-hidden="true"] {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important; height: 1px !important;
	overflow: hidden;
}
.newsletter__form input[type="email"] {
	flex: 1 1 auto;
	min-width: 0;
	border: 0;
	padding: 1rem 1.25rem;
	color: var(--c-black);
	background: transparent;
	font-family: var(--ff-body);
	font-size: var(--fs-md);
}
.newsletter__form input[type="email"]:focus { outline: 0; }
.newsletter__form button {
	flex: 0 0 auto;
	padding: 1rem 1.5rem;
	background: var(--c-black);
	color: #fff;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	border: 0;
	cursor: pointer;
}
.newsletter__form button:hover { background: #222; }

/* Variante footer (fondo crema, no rojo) */
.newsletter__form--footer {
	border-color: var(--c-line-strong);
	margin: 0;
	max-width: 100%;
}
.newsletter__form--footer input[type="email"] {
	font-size: 0.9rem;
	padding: 0.7rem 0.85rem;
}
.newsletter__form--footer button {
	background: var(--c-red);
	padding: 0.7rem 1rem;
	font-size: 0.7rem;
}
.newsletter__form--footer button:hover { background: var(--c-red-deep); }

/* ----------------------------------------------------------------- Footer */
.site-footer {
	background: var(--c-off-white);
	color: var(--c-ink);
	border-top: 1px solid var(--c-line-strong);
}
.footer__top {
	background: var(--c-green);
	color: #fff;
	padding-block: var(--space-4);
}
.footer__top-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; }
.footer__top a { color: #fff; }
.footer__social { display: flex; gap: var(--space-4); }
.footer__social a { display: inline-grid; place-items: center; width: 36px; height: 36px; border: 1px solid rgba(255,255,255,.4); border-radius: 999px; transition: all var(--dur) var(--ease); }
.footer__social a:hover { background: #fff; color: var(--c-green); border-color: #fff; }

.footer__main { padding-block: clamp(2.5rem, 5vw, 4.5rem); }
.footer__cols {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
	gap: var(--space-8);
}
.footer__brand { font-family: var(--ff-display); font-size: 1.5rem; line-height: 1.2; color: var(--c-black); margin-bottom: var(--space-3); }
.footer__brand-desc { font-size: 0.9rem; color: var(--c-ink-soft); max-width: 32ch; }
.footer__col h4 {
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	margin: 0 0 var(--space-4);
}
.footer__list { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.65rem; }
.footer__list a { color: var(--c-ink-soft); font-size: 0.95rem; }
.footer__list a:hover { color: var(--c-red); }

.footer__copyright {
	background: var(--c-black);
	color: rgba(255,255,255,.7);
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wide);
	padding-block: var(--space-4);
}
.footer__copyright-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; }
.footer__copyright a { color: rgba(255,255,255,.85); }
.footer__copyright a:hover { color: #fff; }

/* ----------------------------------------------------------------- Shop archive (Tienda) */
.shop-hero {
	padding-block: clamp(3.5rem, 6vw, 6rem);
	background: var(--c-off-white);
	border-bottom: 1px solid var(--c-line);
	text-align: center;
}
.shop-hero h1 { margin: var(--space-3) 0 var(--space-3); }
.shop-hero .lead { margin-inline: auto; }

.shop-main { padding-block: clamp(2.5rem, 4vw, 4rem); }
.shop-main .shop-layout {
	display: grid !important;
	grid-template-columns: 240px minmax(0, 1fr) !important;
	gap: clamp(1.5rem, 4vw, 3.5rem);
	align-items: start;
}

.shop-sidebar {
	position: sticky;
	top: calc(var(--header-h) + var(--topbar-h) + 1rem);
	display: grid;
	gap: var(--space-6);
	padding-right: var(--space-2);
}
.shop-sidebar__block {
	padding-bottom: var(--space-6);
	border-bottom: 1px solid var(--c-line);
}
.shop-sidebar__block:last-child { border-bottom: 0; }
/* Cabecera del bloque (es un <button> en accordion). En desktop se comporta
 * como un título estático sin botón visual. */
.shop-sidebar h3.shop-sidebar__title,
.shop-sidebar button.shop-sidebar__title {
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	line-height: 1;
	margin: 0 0 var(--space-4);
	background: transparent;
	border: 0;
	padding: 0;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	text-align: left;
}
.shop-sidebar__chevron {
	display: none; /* solo visible en móvil */
	font-size: 1.25rem;
	line-height: 1;
	color: var(--c-ink-mute);
	transition: transform 0.3s var(--ease);
}
.shop-sidebar__panel {
	/* En desktop el panel es siempre visible — no hace falta animación */
}
.shop-sidebar__list,
.shop-sidebar__notes {
	list-style: none;
	padding: 0; margin: 0;
	display: grid;
	gap: 0.55rem;
}
.shop-sidebar__list a {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.5rem;
	padding: 4px 0;
	color: var(--c-ink-soft);
	font-size: 0.95rem;
	border-bottom: 1px solid transparent;
}
.shop-sidebar__list a:hover { color: var(--c-red); }
.shop-sidebar__list .is-active a { color: var(--c-black); border-bottom-color: var(--c-red); font-weight: 500; }
.shop-sidebar__count {
	font-size: 0.75rem;
	color: var(--c-ink-mute);
	letter-spacing: 0.04em;
}
.shop-sidebar__notes li {
	font-size: 0.875rem;
	color: var(--c-ink-soft);
	padding-left: 1rem;
	position: relative;
	line-height: 1.5;
}
.shop-sidebar__notes li::before {
	content: "";
	position: absolute;
	left: 0; top: 0.65em;
	width: 6px; height: 1px;
	background: var(--c-red);
}

.shop-results { min-width: 0; }

/* Toolbar */
.shop-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
	padding-bottom: var(--space-5);
	margin-bottom: var(--space-6);
	border-bottom: 1px solid var(--c-line);
	flex-wrap: wrap;
}
.woocommerce-result-count {
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin: 0;
}
.woocommerce-ordering {
	margin: 0;
}
.woocommerce-ordering select {
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	background: transparent;
	border: 0;
	border-bottom: 1px solid var(--c-line-strong);
	padding: 0.5rem 1.5rem 0.5rem 0;
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%230a0a0a' stroke-width='1.6'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0 center;
	background-size: 12px;
	cursor: pointer;
}
.woocommerce-ordering select:focus { outline: 0; border-bottom-color: var(--c-red); }

/* Shop grid: 4 columnas por defecto en escritorio */
.shop-grid {
	list-style: none;
	margin: 0 !important;
	padding: 0 !important;
	display: grid !important;
	gap: var(--space-5);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}
/* Neutraliza el CSS legacy de WooCommerce que rompe el grid */
.shop-grid > li,
.shop-grid > li.first,
.shop-grid > li.last,
.shop-grid > li.product {
	clear: none !important;
	float: none !important;
	width: auto !important;
	margin: 0 !important;
	padding: 0 !important;
}
/* WooCommerce inserta un ::before y ::after de clearfix en ul.products
 * que en CSS Grid se convierten en celdas vacías y ocupan dos slots.
 * Los anulamos. */
.shop-grid::before,
.shop-grid::after {
	display: none !important;
	content: none !important;
}
.shop-grid.columns-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.shop-grid.columns-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.shop-grid.columns-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

/* Card de producto en el archive */
.shop-grid .product-card {
	float: none !important;
	margin: 0 !important;
	width: auto !important;
}
.product-card__media {
	position: relative;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: var(--c-stone);
	display: block;
}
.product-card__flag {
	position: absolute;
	top: var(--space-3);
	left: var(--space-3);
	background: var(--c-red);
	color: #fff;
	font-size: 0.6rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	padding: 5px 10px;
	z-index: 1;
}
.product-card__flag--featured {
	background: var(--c-black);
	left: auto; right: var(--space-3);
}
.product-card__cta {
	background: transparent !important;
	color: var(--c-red) !important;
	border: 0 !important;
	padding: 0 !important;
	font-size: var(--fs-xs) !important;
	font-weight: 600 !important;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	display: inline-flex !important;
	align-items: center;
	gap: 0.4rem;
	margin: 0 !important;
}
.product-card__cta:hover { color: var(--c-red-deep) !important; background: transparent !important; }
.product-card__cta-arrow { transition: transform var(--dur) var(--ease); }
.product-card__cta:hover .product-card__cta-arrow { transform: translateX(3px); }

/* Estado "added" del botón ajax */
.product-card__cta.added { color: var(--c-green) !important; }
.product-card__cta.added::before { content: "✓ "; }

/* Oculta el link "Ver carrito" que WooCommerce inyecta tras añadir;
 * abrimos el modal automáticamente, no necesitamos ese enlace. */
.product-card .added_to_cart,
.product-card__foot .added_to_cart,
.product-card a.added_to_cart.wc-forward {
	display: none !important;
}

/* Paginación */
.shop-pagination { margin-top: var(--space-10); text-align: center; }
.woocommerce-pagination ul.page-numbers {
	display: inline-flex !important;
	gap: 0.25rem;
	border: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none;
}
.woocommerce-pagination ul.page-numbers li { border: 0 !important; }
.woocommerce-pagination ul.page-numbers li .page-numbers,
.woocommerce-pagination ul.page-numbers li span.page-numbers {
	display: inline-grid;
	place-items: center;
	min-width: 40px; height: 40px;
	border: 1px solid var(--c-line) !important;
	background: #fff !important;
	color: var(--c-black) !important;
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wide);
}
.woocommerce-pagination ul.page-numbers li .page-numbers:hover,
.woocommerce-pagination ul.page-numbers li .page-numbers.current {
	background: var(--c-black) !important;
	color: #fff !important;
	border-color: var(--c-black) !important;
}

/* Quantity input compartido */
.qty-input {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--c-line-strong);
	background: #fff;
	height: 44px;
}
.qty-input__btn {
	width: 38px; height: 100%;
	display: grid; place-items: center;
	font-size: 1.1rem;
	color: var(--c-black);
	background: transparent;
}
.qty-input__btn:hover { background: var(--c-off-white); }
.qty-input__num {
	width: 56px;
	text-align: center;
	border: 0;
	border-left: 1px solid var(--c-line);
	border-right: 1px solid var(--c-line);
	height: 100%;
	font-family: var(--ff-display);
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--c-black);
	-moz-appearance: textfield;
}
.qty-input__num::-webkit-outer-spin-button,
.qty-input__num::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.qty-input__num:focus { outline: 0; }

/* Responsive shop: SIEMPRE 2 columnas en pantallas medianas y móvil */
@media (max-width: 1200px) {
	.shop-grid,
	.shop-grid.columns-2,
	.shop-grid.columns-3,
	.shop-grid.columns-4 {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}
@media (max-width: 980px) {
	.shop-grid,
	.shop-grid.columns-2,
	.shop-grid.columns-3,
	.shop-grid.columns-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media (max-width: 860px) {
	.shop-main .shop-layout { grid-template-columns: 1fr !important; }
	.shop-sidebar {
		position: static;
		padding-right: 0;
		gap: 0;
		border: 1px solid var(--c-line);
		background: #fff;
	}
	.shop-sidebar__block {
		padding: 0;
		border-bottom: 1px solid var(--c-line);
	}
	.shop-sidebar__block:last-child { border-bottom: 0; }

	/* Cabecera clickable del accordion */
	.shop-sidebar button.shop-sidebar__title {
		padding: 1rem 1.1rem;
		margin: 0;
		font-size: 0.78rem;
		letter-spacing: 0.16em;
		transition: background var(--dur) var(--ease);
	}
	.shop-sidebar button.shop-sidebar__title:hover { background: var(--c-off-white); }
	.shop-sidebar button.shop-sidebar__title[aria-expanded="true"] {
		background: var(--c-off-white);
	}

	/* Mostrar el chevron y rotarlo cuando está abierto */
	.shop-sidebar__chevron {
		display: inline-block;
	}
	.shop-sidebar button.shop-sidebar__title[aria-expanded="true"] .shop-sidebar__chevron {
		transform: rotate(180deg);
		color: var(--c-red);
	}

	/* Panel: oculto por defecto, visible cuando el bloque tiene .is-open */
	.shop-sidebar__panel {
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.35s cubic-bezier(.22,.61,.36,1);
	}
	.shop-sidebar__block.is-open .shop-sidebar__panel {
		max-height: 600px;
	}
	.shop-sidebar__panel > .shop-sidebar__list,
	.shop-sidebar__panel > .shop-sidebar__notes {
		padding: 0 1.1rem 1rem;
		margin: 0;
	}
}
@media (max-width: 560px) {
	/* En móvil mantenemos 2 columnas (NO 1) */
	.shop-grid,
	.shop-grid.columns-2,
	.shop-grid.columns-3,
	.shop-grid.columns-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--space-3);
	}
	.shop-toolbar { gap: var(--space-3); }
	.product-card__body { padding: var(--space-3) var(--space-3) var(--space-4); }
	.product-card__title { font-size: 1.05rem; }
	.product-card__price { font-size: 1.05rem; }
	.product-card__desc { display: none; } /* en móvil, sin descripción para que no quede agobiante */
}

/* ----------------------------------------------------------------- Single product (Highland) */
.single-product-main { padding-block: clamp(1.5rem, 3vw, 3rem) clamp(3rem, 6vw, 6rem); }

.wc-breadcrumb {
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin: 0 0 clamp(1.5rem, 3vw, 3rem);
}
.wc-breadcrumb a { color: var(--c-ink-mute); }
.wc-breadcrumb a:hover { color: var(--c-red); }
.wc-breadcrumb .sep { margin: 0 0.5rem; color: var(--c-stone-mute); }

.single-product__article { display: block; }
.single-product__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
	gap: clamp(2rem, 5vw, 5rem);
	align-items: start;
	margin-bottom: clamp(3rem, 6vw, 6rem);
}

/* ----- Galería con Swiper ----- */
.product-gallery { position: relative; width: 100%; min-width: 0; }
.product-gallery__main {
	background: var(--c-off-white);
	border: 1px solid var(--c-line-strong);
	overflow: hidden;
	width: 100%;
}
/* Cada slide ocupa exactamente el ancho del swiper. Sin esto, Swiper deja
 * width:auto y la imagen interna calcula tamaños astronómicos. */
.product-gallery__main .swiper-slide {
	width: 100% !important;
	flex-shrink: 0 !important;
}
.product-gallery__slide {
	position: relative;
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: var(--c-off-white);
}
.product-gallery__zoom {
	position: absolute;
	inset: 0;
	display: block;
	cursor: zoom-in;
	overflow: hidden;
}
.product-gallery__img,
.product-gallery__slide img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms var(--ease);
}
.product-gallery__zoom:hover .product-gallery__img { transform: scale(1.04); }

/* Flechas */
.product-gallery__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
	width: 44px; height: 44px;
	display: grid;
	place-items: center;
	background: rgba(255,255,255,.92);
	color: var(--c-black);
	border: 1px solid var(--c-line-strong);
	cursor: pointer;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.product-gallery__nav:hover { background: var(--c-black); color: #fff; border-color: var(--c-black); }
.product-gallery__nav--prev { left: 1rem; }
.product-gallery__nav--next { right: 1rem; }
.product-gallery__nav.swiper-button-disabled { opacity: 0.4; cursor: not-allowed; }
.product-gallery__nav.swiper-button-disabled:hover { background: rgba(255,255,255,.92); color: var(--c-black); border-color: var(--c-line-strong); }

/* Indicador de paginación: puntos discretos */
.product-gallery__pagination {
	display: flex;
	justify-content: center;
	gap: 0.4rem;
	margin-top: var(--space-4);
}
.product-gallery__bullet {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 999px;
	background: var(--c-stone-mute);
	border: 0;
	cursor: pointer;
	transition: background var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.product-gallery__bullet:hover { background: var(--c-ink-mute); }
.product-gallery__bullet--active {
	background: var(--c-red);
	transform: scaleX(2.4);
	border-radius: 4px;
}

/* Lightbox */
.product-lightbox {
	position: fixed;
	inset: 0;
	z-index: 999;
	background: rgba(10,10,10,.94);
	display: grid;
	place-items: center;
	padding: clamp(1rem, 4vw, 4rem);
	cursor: zoom-out;
	animation: hl-fade-in 200ms var(--ease);
}
.product-lightbox img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	border: 1px solid rgba(255,255,255,.1);
}
.product-lightbox__close {
	position: absolute;
	top: 1rem; right: 1rem;
	width: 44px; height: 44px;
	background: transparent;
	border: 1px solid rgba(255,255,255,.5);
	color: #fff;
	font-size: 1.5rem;
	cursor: pointer;
	display: grid; place-items: center;
}
.product-lightbox__close:hover { background: rgba(255,255,255,.1); }
@keyframes hl-fade-in { from { opacity: 0; } to { opacity: 1; } }

/* ----- Summary ----- */
.single-product__summary {
	padding-top: var(--space-2);
}
.single-product__summary .eyebrow { margin-bottom: var(--space-3); }
.single-product__summary .product_title.entry-title {
	font-family: var(--ff-display);
	font-size: clamp(1.75rem, 1.25rem + 1.5vw, 2.75rem);
	font-weight: 300;
	line-height: 1.1;
	letter-spacing: -0.01em;
	color: var(--c-black);
	margin: 0 0 var(--space-3);
}
.single-product__summary p.price,
.single-product__summary span.price {
	font-family: var(--ff-display);
	font-size: clamp(1.5rem, 1rem + 1.5vw, 2.25rem);
	font-weight: 600;
	color: var(--c-black);
	margin: 0 0 var(--space-5);
	display: block;
}
.single-product__summary p.price del { color: var(--c-ink-mute); font-weight: 400; opacity: 0.7; margin-right: 0.5rem; }
.single-product__summary p.price ins { text-decoration: none; color: var(--c-red); }

/* Aviso de reserva (Disponible para reservar - Envíos DD/MM/AAAA) */
.product-preorder {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	padding: 0.55rem 0.85rem;
	margin: 0 0 var(--space-5);
	background: rgba(184, 30, 30, 0.06);
	color: var(--c-red-deep);
	font-size: 0.875rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.3;
	border-left: 3px solid var(--c-red);
}
.product-preorder__dot {
	width: 8px; height: 8px;
	border-radius: 999px;
	background: var(--c-red);
	box-shadow: 0 0 0 4px rgba(184,30,30,.15);
	animation: hl-pulse 1.6s ease-in-out infinite;
	flex-shrink: 0;
}
.product-preorder__label { font-weight: 600; color: var(--c-black); }
.product-preorder__sep   { color: var(--c-stone-mute); }
.product-preorder__date  { color: var(--c-ink-soft); }
@keyframes hl-pulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(184,30,30,.15); }
	50%      { box-shadow: 0 0 0 8px rgba(184,30,30,.05); }
}

/* Badge "En reserva" en la card del listado */
.product-card__flag--preorder {
	background: var(--c-red) !important;
	color: #fff !important;
}

.single-product__summary .woocommerce-product-details__short-description {
	font-size: 1.05rem;
	line-height: 1.7;
	color: var(--c-ink-soft);
	margin-bottom: var(--space-6);
	max-width: 52ch;
}

/* Estado loading en el botón de añadir al carrito (single product) */
.single_add_to_cart_button.is-loading {
	position: relative;
	color: transparent !important;
	pointer-events: none;
}
.single_add_to_cart_button.is-loading::after {
	content: "";
	position: absolute;
	left: 50%; top: 50%;
	width: 18px; height: 18px;
	margin: -9px 0 0 -9px;
	border: 2px solid rgba(255,255,255,.4);
	border-top-color: #fff;
	border-radius: 999px;
	animation: hl-spin 700ms linear infinite;
}
@keyframes hl-spin { to { transform: rotate(360deg); } }

/* Form add to cart */
.single-product__summary form.cart {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-3);
	margin: 0 0 var(--space-6);
	padding: var(--space-5) 0;
	border-top: 1px solid var(--c-line);
	border-bottom: 1px solid var(--c-line);
}
.single-product__summary form.cart .single_add_to_cart_button {
	flex: 1 1 auto;
	min-width: 200px;
	background: var(--c-red) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 1rem 1.75rem !important;
	font-family: var(--ff-body) !important;
	font-size: 0.8125rem !important;
	font-weight: 600 !important;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	transition: background var(--dur) var(--ease);
}
.single-product__summary form.cart .single_add_to_cart_button:hover {
	background: var(--c-red-deep) !important;
}

/* Meta (sku, categorías) */
.single-product__summary .product_meta {
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wide);
	color: var(--c-ink-mute);
	display: grid;
	gap: 0.5rem;
	margin: 0 0 var(--space-5);
}
.single-product__summary .product_meta > span {
	display: flex;
	gap: 0.5rem;
	text-transform: uppercase;
}
.single-product__summary .product_meta a {
	color: var(--c-black);
	text-transform: none;
	letter-spacing: 0;
	font-size: 0.875rem;
}
.single-product__summary .product_meta a:hover { color: var(--c-red); }

/* Bloque de confianza */
.product-trust {
	margin-top: var(--space-5);
	padding-top: var(--space-5);
	border-top: 1px solid var(--c-line);
}
.product-trust__list {
	list-style: none;
	margin: 0; padding: 0;
	display: grid;
	gap: var(--space-3);
}
.product-trust__list li {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	font-size: 0.95rem;
	color: var(--c-ink-soft);
	line-height: 1.5;
}
.product-trust__list svg {
	flex: 0 0 auto;
	color: var(--c-black);
}
.product-trust__list svg .accent { stroke: var(--c-red); }

/* ----- Tabs ----- */
.single-product__details { margin-top: clamp(2rem, 4vw, 4rem); }
.woocommerce-tabs.wc-tabs-wrapper { display: block; }
.woocommerce-tabs ul.wc-tabs,
.woocommerce-tabs ul.tabs {
	display: flex;
	gap: var(--space-6);
	list-style: none;
	margin: 0 0 var(--space-6) !important;
	padding: 0 0 var(--space-3) !important;
	border-bottom: 1px solid var(--c-line) !important;
	background: transparent !important;
}
.woocommerce-tabs ul.wc-tabs::before,
.woocommerce-tabs ul.wc-tabs::after,
.woocommerce-tabs ul.tabs::before,
.woocommerce-tabs ul.tabs::after { display: none !important; }
.woocommerce-tabs ul.wc-tabs li,
.woocommerce-tabs ul.tabs li {
	background: transparent !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
}
.woocommerce-tabs ul.wc-tabs li::before,
.woocommerce-tabs ul.wc-tabs li::after,
.woocommerce-tabs ul.tabs li::before,
.woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce-tabs ul.wc-tabs li a,
.woocommerce-tabs ul.tabs li a {
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-ink-mute) !important;
	padding: 0.5rem 0 !important;
	display: inline-block;
	border-bottom: 2px solid transparent !important;
	margin-bottom: -1px;
	background: transparent !important;
}
.woocommerce-tabs ul.wc-tabs li.active a,
.woocommerce-tabs ul.tabs li.active a {
	color: var(--c-black) !important;
	border-bottom-color: var(--c-red) !important;
}
.woocommerce-tabs .panel,
.woocommerce-Tabs-panel {
	font-size: 1rem;
	line-height: 1.7;
	color: var(--c-ink-soft);
	max-width: 80ch;
}
.woocommerce-Tabs-panel h2:first-child { margin-top: 0; }

/* Productos relacionados / upsells */
.related.products,
.upsells.products {
	margin-top: clamp(3rem, 6vw, 5rem);
	padding-top: clamp(2rem, 4vw, 3rem);
	border-top: 1px solid var(--c-line);
}
.related.products > h2,
.upsells.products > h2 {
	font-family: var(--ff-display);
	font-size: var(--fs-2xl);
	font-weight: 400;
	margin: 0 0 var(--space-6);
	text-align: center;
}

/* Notice de añadido al carrito */
.woocommerce-message,
.wc-block-components-notice-banner {
	background: var(--c-green) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 1rem 1.5rem !important;
	margin: 0 0 var(--space-5) !important;
}
.woocommerce-message a,
.woocommerce-message a.button {
	background: #fff !important;
	color: var(--c-black) !important;
	padding: 0.5rem 1rem !important;
	border-radius: 0 !important;
	font-size: var(--fs-xs) !important;
	font-weight: 600 !important;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	border: 0 !important;
}

@media (max-width: 860px) {
	.single-product__grid { grid-template-columns: 1fr; gap: var(--space-6); }
	.product-gallery__nav { width: 38px; height: 38px; }
	.product-gallery__nav--prev { left: 0.5rem; }
	.product-gallery__nav--next { right: 0.5rem; }
}

/* ----------------------------------------------------------------- Notices Highland (success/error/info) */
.woocommerce-notices-wrapper { margin: 0 0 var(--space-4); }

.hl-notice {
	display: flex;
	align-items: flex-start;
	gap: 0.85rem;
	padding: 0.95rem 1.1rem;
	margin: 0 0 var(--space-3);
	background: #fff;
	border: 1px solid var(--c-line-strong);
	border-left-width: 3px;
	color: var(--c-black);
	font-size: 0.95rem;
	line-height: 1.5;
	transition: opacity 280ms var(--ease), transform 280ms var(--ease);
	box-shadow: 0 1px 0 rgba(0,0,0,.02);
}
.hl-notice--success {
	border-left-color: var(--c-green);
	background: rgba(27, 94, 63, 0.05);
}
.hl-notice--error {
	border-left-color: var(--c-red);
	background: rgba(184, 30, 30, 0.05);
}
.hl-notice--info {
	border-left-color: var(--c-black);
	background: var(--c-off-white);
}
.hl-notice__icon {
	flex: 0 0 auto;
	display: grid;
	place-items: center;
	width: 22px; height: 22px;
	border-radius: 999px;
	color: #fff;
	margin-top: 1px;
}
.hl-notice--success .hl-notice__icon { background: var(--c-green); }
.hl-notice--error   .hl-notice__icon { background: var(--c-red); }
.hl-notice--info    .hl-notice__icon { background: var(--c-black); }
.hl-notice__body { flex: 1; min-width: 0; }
.hl-notice__body p { margin: 0; }
.hl-notice__body a {
	color: inherit;
	border-bottom: 1px solid currentColor;
	font-weight: 500;
	margin-left: 0.4rem;
}
.hl-notice__body a.button,
.hl-notice__body a.wc-forward,
.hl-notice__body a.restore-item {
	display: inline-block;
	margin-left: 0.6rem;
	padding: 0.4rem 0.85rem;
	background: var(--c-black);
	color: #fff;
	border: 0;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
}
.hl-notice__body a.button:hover { background: #222; color: #fff; border: 0; }
.hl-notice__close {
	flex: 0 0 auto;
	width: 28px; height: 28px;
	display: grid; place-items: center;
	color: var(--c-ink-mute);
	background: transparent;
	border: 0;
	cursor: pointer;
	border-radius: 999px;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.hl-notice__close:hover { background: rgba(0,0,0,.05); color: var(--c-black); }

/* ----------------------------------------------------------------- Toasts (notificaciones flotantes) */
.hl-toasts {
	position: fixed;
	top: calc(var(--header-h) + var(--topbar-h) + 1rem);
	right: 1.25rem;
	z-index: 1000;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	pointer-events: none;
	max-width: min(360px, calc(100vw - 2rem));
	width: 100%;
}
.hl-toast {
	pointer-events: auto;
	display: grid;
	grid-template-columns: auto 1fr auto;
	grid-template-areas:
		"icon body close"
		"icon cta  cta";
	align-items: start;
	gap: 0.65rem 0.7rem;
	padding: 0.85rem 0.95rem;
	background: #fff;
	border: 1px solid var(--c-line-strong);
	border-left-width: 3px;
	color: var(--c-black);
	font-size: 0.9rem;
	line-height: 1.4;
	box-shadow: 0 14px 40px -12px rgba(10,10,10,.18);
	opacity: 0;
	transform: translateX(20px) translateY(-4px);
	transition: opacity 320ms var(--ease), transform 320ms var(--ease);
}
.hl-toast.is-visible { opacity: 1; transform: translateX(0) translateY(0); }
.hl-toast--success { border-left-color: var(--c-green); }
.hl-toast--error   { border-left-color: var(--c-red); }
.hl-toast--info    { border-left-color: var(--c-black); }
.hl-toast__icon {
	grid-area: icon;
	display: grid; place-items: center;
	width: 28px; height: 28px;
	border-radius: 999px;
	color: #fff;
	margin-top: 1px;
}
.hl-toast--success .hl-toast__icon { background: var(--c-green); }
.hl-toast--error   .hl-toast__icon { background: var(--c-red); }
.hl-toast--info    .hl-toast__icon { background: var(--c-black); }
.hl-toast__body { grid-area: body; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.hl-toast__title {
	font-family: var(--ff-display);
	font-size: 1.05rem;
	font-weight: 500;
	color: var(--c-black);
	line-height: 1.2;
	letter-spacing: -0.01em;
}
.hl-toast__msg { color: var(--c-ink-soft); font-size: 0.85rem; }
.hl-toast__cta {
	grid-area: cta;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-red);
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	margin-top: 4px;
	padding: 6px 0;
	border-bottom: 1px solid var(--c-red);
	align-self: start;
	justify-self: start;
}
.hl-toast__cta:hover { color: var(--c-red-deep); border-bottom-color: var(--c-red-deep); }
.hl-toast__close {
	grid-area: close;
	width: 22px; height: 22px;
	display: grid; place-items: center;
	background: transparent;
	border: 0;
	color: var(--c-ink-mute);
	cursor: pointer;
	border-radius: 999px;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.hl-toast__close:hover { background: rgba(0,0,0,.05); color: var(--c-black); }

@media (max-width: 720px) {
	.hl-toasts {
		top: auto;
		bottom: 1rem;
		right: 0.75rem;
		left: 0.75rem;
		max-width: none;
	}
	.hl-toast { font-size: 0.85rem; padding: 0.75rem 0.85rem; }
	.hl-toast__title { font-size: 0.95rem; }
	.hl-notice { font-size: 0.875rem; padding: 0.75rem 0.85rem; }
	.hl-notice__body a.button { display: block; margin: 6px 0 0; text-align: center; }
}

/* ----------------------------------------------------------------- Página /carrito/ (ticket grande centrado) */
.cart-page {
	padding-block: clamp(2rem, 4vw, 4rem);
	background: var(--c-white);
	min-height: 60vh;
}
.cart-page__head {
	text-align: center;
	margin-bottom: clamp(2rem, 4vw, 3rem);
}
.cart-page__head h1 {
	margin: var(--space-3) 0;
}
.cart-page__head .lead {
	margin-inline: auto;
	max-width: 56ch;
}

/* El ticket en página tiene sombra de papel sobre la mesa */
.ticket--page {
	max-width: 720px;
	margin: 0 auto;
	box-shadow:
		0 24px 60px -28px rgba(0,0,0,.30),
		0 1px 0 rgba(0,0,0,.05);
}
/* Quitamos el min-height: 100% del ticket cuando va en página */
.cart-page .ticket--page {
	min-height: auto;
	flex: 0 0 auto;
}
/* En la página el ticket se hace cómodo: items un poco más grandes */
.ticket--page .ticket__brand { font-size: clamp(1.65rem, 1rem + 1.2vw, 2.1rem); }
.ticket--page .ticket__items { gap: 0; }
.ticket--page .ticket__item { padding: 0.95rem 0; }
.ticket--page .ticket__item-thumb { width: 64px; height: 64px; }
.ticket--page .ticket__item-name { font-size: 1.15rem; }
.ticket--page .ticket__row--total dd { font-size: 1.65rem; }

@media (max-width: 720px) {
	.cart-page { padding-block: clamp(1.5rem, 4vw, 2.5rem); }
	.ticket--page {
		max-width: 100%;
		box-shadow: none;
	}
	.ticket--page .ticket__item-thumb { width: 56px; height: 56px; }
	.ticket--page .ticket__item-name  { font-size: 1.05rem; }
}

/* ----------------------------------------------------------------- Página /mi-cuenta/ */
.myaccount-page {
	padding-block: clamp(2rem, 4vw, 4rem);
	background: var(--c-white);
	min-height: 60vh;
}
.myaccount-page__head {
	text-align: center;
	margin-bottom: clamp(2rem, 4vw, 3rem);
}
.myaccount-page__head h1 {
	margin: var(--space-3) 0;
}
.myaccount-page__head .lead {
	margin-inline: auto;
	max-width: 56ch;
}

/* Layout sidebar + content. min-width:0 en todas las columnas para que los
 * hijos puedan acomodarse sin desbordar el grid. */
.myaccount-grid {
	display: grid;
	grid-template-columns: 240px minmax(0, 1fr);
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
	max-width: 100%;
	min-width: 0;
}
.myaccount-grid__nav,
.myaccount-grid__content,
.woocommerce-MyAccount-content {
	min-width: 0;
	max-width: 100%;
}
.myaccount-grid__content > *,
.woocommerce-MyAccount-content > * {
	max-width: 100%;
}

/* Sidebar de navegación */
.myaccount-nav {
	position: sticky;
	top: calc(var(--header-h) + var(--topbar-h) + 1rem);
}
.myaccount-nav__title {
	display: block;
	margin: 0 0 var(--space-3);
}
.myaccount-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0;
}
.myaccount-nav__item {
	border-bottom: 1px solid var(--c-line);
}
.myaccount-nav__item:first-child { border-top: 1px solid var(--c-line); }
.myaccount-nav__link {
	display: block;
	padding: 0.85rem 0;
	font-family: var(--ff-body);
	font-size: 0.95rem;
	color: var(--c-ink-soft);
	transition: color var(--dur) var(--ease), padding-left var(--dur) var(--ease);
}
.myaccount-nav__link:hover {
	color: var(--c-red);
	padding-left: 0.4rem;
}
.myaccount-nav__item.is-active .myaccount-nav__link {
	color: var(--c-black);
	font-weight: 600;
	padding-left: 0.5rem;
	border-left: 2px solid var(--c-red);
	background: linear-gradient(90deg, rgba(184,30,30,0.05) 0, transparent 100%);
	margin-left: -2px;
}

/* Contenido principal */
.myaccount-grid__content { min-width: 0; }

.myaccount-section {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	padding: clamp(1.5rem, 3vw, 2rem);
	margin-bottom: var(--space-5);
}
.myaccount-section__head {
	margin-bottom: var(--space-5);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--c-line);
}
.myaccount-section__head .eyebrow { display: block; margin-bottom: var(--space-2); }
.myaccount-section__head h2 {
	font-size: var(--fs-2xl);
	font-weight: 400;
	margin: 0;
}
.myaccount-section__sub {
	font-size: 0.875rem;
	color: var(--c-ink-mute);
	margin: var(--space-2) 0 0;
	letter-spacing: 0.02em;
}
.myaccount-section__cta {
	display: flex;
	gap: var(--space-3);
	margin-top: var(--space-5);
	flex-wrap: wrap;
}
.myaccount-section__cta .btn {
	flex: 1 1 200px;
	min-width: 0;
	justify-content: center;
}

/* ---- Dashboard ---- */
.myaccount-dashboard {}
.myaccount-dashboard__intro {
	font-size: 1.05rem;
	color: var(--c-ink-soft);
	margin: 0 0 var(--space-5);
	line-height: 1.7;
}
.myaccount-dashboard__intro a {
	color: var(--c-red);
	border-bottom: 1px solid currentColor;
	font-weight: 500;
}

.myaccount-stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-3);
	margin: 0 0 var(--space-6);
}
.myaccount-stat {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	padding: var(--space-4);
}
.myaccount-stat__label {
	display: block;
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wider);
	font-weight: 600;
	color: var(--c-ink-mute);
	margin-bottom: 0.5rem;
}
.myaccount-stat__value {
	display: block;
	font-family: var(--ff-display);
	font-size: 1.85rem;
	font-weight: 500;
	color: var(--c-black);
	letter-spacing: var(--ls-tight);
	line-height: 1;
}
.myaccount-stat__value .woocommerce-Price-amount { font: inherit; color: inherit; }

/* ---- Estados de pedido (badges) ---- */
.myaccount-status {
	display: inline-block;
	padding: 0.2rem 0.55rem;
	font-family: var(--ff-body);
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	background: var(--c-stone);
	color: var(--c-black);
	border-radius: 0;
}
.myaccount-status--processing,
.myaccount-status--on-hold { background: var(--c-red); color: #fff; }
.myaccount-status--completed { background: var(--c-green); color: #fff; }
.myaccount-status--pending { background: var(--c-stone-mute); color: var(--c-black); }
.myaccount-status--cancelled,
.myaccount-status--failed,
.myaccount-status--refunded { background: var(--c-ink-mute); color: #fff; }

/* ---- Lista de pedidos ---- */
.myaccount-orders__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--space-3);
}
.myaccount-order {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	overflow: hidden;
}
.myaccount-order__head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: var(--space-3) var(--space-5);
	background: var(--c-black);
	color: #fff;
}
.myaccount-order__number {
	font-family: var(--ff-display);
	font-size: 1.25rem;
	font-weight: 500;
}
.myaccount-order__date {
	font-family: 'Courier New', ui-monospace, monospace;
	font-size: 0.8rem;
	letter-spacing: 0.02em;
	color: rgba(255,255,255,.7);
}
.myaccount-order__body {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: var(--space-5);
	align-items: center;
	padding: var(--space-5);
	min-width: 0;
}
.myaccount-order__stats {
	display: flex;
	gap: var(--space-6);
	flex-wrap: wrap;
}
.myaccount-order__stat {
	display: grid;
	gap: 4px;
}
.myaccount-order__label {
	font-family: var(--ff-body);
	font-size: 0.65rem;
	letter-spacing: var(--ls-wider);
	font-weight: 600;
	color: var(--c-ink-mute);
}
.myaccount-order__value {
	font-family: 'Courier New', ui-monospace, monospace;
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--c-black);
}
.myaccount-order__value--total {
	font-family: var(--ff-display);
	font-size: 1.25rem;
	font-weight: 600;
}
.myaccount-order__actions {
	display: flex;
	gap: var(--space-2);
	flex-shrink: 0;
}
.myaccount-order__action {
	font-size: 0.65rem !important;
	padding: 0.55rem 0.9rem !important;
}

.myaccount-orders__empty,
.myaccount-section--empty {
	text-align: center;
	padding: var(--space-8) var(--space-5);
	background: var(--c-off-white);
	border: 1px dashed var(--c-line-strong);
}
.myaccount-orders__empty p,
.myaccount-section--empty p {
	font-family: var(--ff-display);
	font-size: 1.4rem;
	font-style: italic;
	color: var(--c-ink-mute);
	margin: 0 0 var(--space-4);
}

/* ---- Mi cuenta · Direcciones ---- */
.myaccount-addresses__intro {
	font-size: 0.95rem;
	color: var(--c-ink-soft);
	margin: 0 0 var(--space-5);
}
.myaccount-addresses__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: var(--space-4);
}
.myaccount-addresses__grid--single {
	grid-template-columns: minmax(0, 520px);
}
.myaccount-address {
	display: flex;
	flex-direction: column;
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	overflow: hidden;
	transition: border-color var(--dur) var(--ease);
}
.myaccount-address:hover { border-color: var(--c-line-strong); }

.myaccount-address__head {
	padding: var(--space-4) var(--space-5);
	border-bottom: 1px solid var(--c-line);
	background: #fff;
}
.myaccount-address__head .eyebrow { display: block; margin-bottom: var(--space-2); }
.myaccount-address__title {
	font-family: var(--ff-display);
	font-size: 1.25rem;
	font-weight: 500;
	color: var(--c-black);
	margin: 0;
	line-height: 1.2;
}

.myaccount-address__body {
	flex: 1;
	padding: var(--space-5);
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

/* Dirección formateada (address tag) */
.myaccount-address__addr {
	font-style: normal;
	font-family: var(--ff-body);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--c-ink);
	display: block;
}
.myaccount-address__addr br { line-height: 1.6; }

/* Meta: teléfono/email separados con dashed line */
.myaccount-address__meta {
	margin: 0;
	padding-top: var(--space-3);
	border-top: 1px dashed var(--c-line-strong);
	display: grid;
	gap: var(--space-3);
}
.myaccount-address__meta-row {
	display: grid;
	gap: 4px;
}
.myaccount-address__meta-row dt {
	font-size: 0.6rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	color: var(--c-ink-mute);
	margin: 0;
}
.myaccount-address__meta-row dd {
	margin: 0;
	font-size: 0.95rem;
	color: var(--c-ink);
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
}
.myaccount-address__meta-row a {
	color: var(--c-black);
	border-bottom: 1px solid currentColor;
	font-family: inherit;
}
.myaccount-address__meta-row a:hover { color: var(--c-red); }

.myaccount-address__empty {
	font-style: italic;
	color: var(--c-ink-mute);
	margin: 0;
	padding: var(--space-4) 0;
	text-align: center;
}

.myaccount-address__foot {
	padding: var(--space-4) var(--space-5);
	border-top: 1px solid var(--c-line);
	background: #fff;
}
.myaccount-address__edit {
	width: 100%;
	justify-content: center;
}

/* Responsive */
@media (max-width: 720px) {
	.myaccount-addresses__grid { grid-template-columns: 1fr; }
}

/* ---- Forms (account-edit, edit-address, ver-pedido) ---- */
.woocommerce-MyAccount-content form,
.woocommerce-EditAccountForm,
.edit-account,
.woocommerce-EditAddressForm {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	padding: clamp(1.5rem, 3vw, 2rem);
	max-width: 100%;
	min-width: 0;
}

/* Cabecera del form (h3 "Dirección de facturación", "Detalles de la cuenta", etc.) */
.woocommerce-MyAccount-content form > h3,
.woocommerce-MyAccount-content form > h2,
.edit-account > h3,
.woocommerce-EditAddressForm > h3 {
	font-family: var(--ff-display);
	font-size: 1.5rem;
	font-weight: 400;
	color: var(--c-black);
	margin: 0 0 var(--space-5);
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--c-line);
}

/* Wrapper de campos de dirección: grid de 2 columnas (Nombre / Apellidos, etc.) */
.woocommerce-address-fields__field-wrapper {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: var(--space-2) var(--space-4);
	margin-bottom: var(--space-4);
}
.woocommerce-address-fields__field-wrapper .form-row {
	margin-bottom: var(--space-3);
	min-width: 0;
}
.woocommerce-address-fields__field-wrapper > .form-row.form-row-wide,
.woocommerce-address-fields__field-wrapper .form-row-wide {
	grid-column: 1 / -1 !important;
	width: 100% !important;
	float: none !important;
	clear: both;
}
.woocommerce-address-fields__field-wrapper .form-row-first,
.woocommerce-address-fields__field-wrapper .form-row-last {
	float: none !important;
	display: block;
	width: 100% !important;
	margin-right: 0;
	grid-column: auto;
}

/* En móvil, una sola columna */
@media (max-width: 720px) {
	.woocommerce-address-fields__field-wrapper {
		grid-template-columns: 1fr;
		gap: 0;
	}
}

/* Botón submit en cualquier form de Mi cuenta (Guardar dirección, Guardar
 * cambios de cuenta, etc.). Selectores anchos para coger el botón sin importar
 * el wrapper (puede estar dentro de <p>, <div.woocommerce-address-fields>, etc.) */
.woocommerce-MyAccount-content button[type="submit"],
.woocommerce-MyAccount-content button[name="save_address"],
.woocommerce-MyAccount-content button[name="save_account_details"],
.woocommerce-MyAccount-content input[type="submit"],
.woocommerce-EditAddressForm button[type="submit"],
.woocommerce-EditAccountForm button[type="submit"] {
	background: var(--c-red) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 1rem 1.75rem !important;
	font-family: var(--ff-body) !important;
	font-size: 0.8125rem !important;
	font-weight: 600 !important;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	cursor: pointer;
	transition: background var(--dur) var(--ease);
}
.woocommerce-MyAccount-content button[type="submit"]:hover,
.woocommerce-MyAccount-content input[type="submit"]:hover,
.woocommerce-EditAddressForm button[type="submit"]:hover,
.woocommerce-EditAccountForm button[type="submit"]:hover {
	background: var(--c-red-deep) !important;
}
/* Fieldset "Cambio de contraseña" en datos-cuenta */
.woocommerce-MyAccount-content fieldset {
	max-width: 100%;
	min-width: 0;
	border: 1px solid var(--c-line);
	padding: var(--space-4);
	margin: var(--space-5) 0 0;
	background: #fff;
}
.woocommerce-MyAccount-content fieldset legend {
	font-family: var(--ff-display);
	font-size: 1.1rem;
	font-weight: 500;
	color: var(--c-black);
	padding: 0 0.5rem;
}
.woocommerce-MyAccount-content form .form-row {
	margin-bottom: var(--space-4);
}
.woocommerce-MyAccount-content label {
	display: block;
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	margin-bottom: 6px;
}
.woocommerce-MyAccount-content input[type="text"],
.woocommerce-MyAccount-content input[type="email"],
.woocommerce-MyAccount-content input[type="password"],
.woocommerce-MyAccount-content input[type="tel"],
.woocommerce-MyAccount-content select,
.woocommerce-MyAccount-content textarea {
	width: 100%;
	height: auto;
	padding: 0.75rem 0.9rem;
	background: #fff;
	border: 1px solid var(--c-line-strong);
	border-radius: 0;
	font: inherit;
	color: var(--c-black);
	transition: border-color var(--dur) var(--ease);
}
.woocommerce-MyAccount-content input:focus,
.woocommerce-MyAccount-content select:focus,
.woocommerce-MyAccount-content textarea:focus {
	outline: 0;
	border-color: var(--c-red);
}

/* ---- Auth (login/registro) ---- */
.myaccount-auth { max-width: 920px; margin: 0 auto; }
.myaccount-auth__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: var(--space-5);
}
.myaccount-auth__card {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	padding: clamp(1.75rem, 3vw, 2.25rem);
}
.myaccount-auth__head {
	margin-bottom: var(--space-5);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--c-line);
}
.myaccount-auth__head h2 {
	font-size: var(--fs-xl);
	margin: var(--space-2) 0 0;
}
.myaccount-auth__card .form-row {
	margin-bottom: var(--space-4);
}
.myaccount-auth__card label {
	display: block;
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	margin-bottom: 6px;
}
.myaccount-auth__card input.input-text {
	width: 100%;
	padding: 0.75rem 0.9rem;
	border: 1px solid var(--c-line-strong);
	background: #fff;
	font: inherit;
	color: var(--c-black);
}
.myaccount-auth__card input:focus {
	outline: 0;
	border-color: var(--c-red);
}
.myaccount-auth__row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-3);
	justify-content: space-between;
}
.myaccount-auth__remember {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--c-ink-soft);
	cursor: pointer;
}
.myaccount-auth__lost {
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wide);
	color: var(--c-red);
	border-bottom: 1px solid currentColor;
}
.myaccount-auth__card button { width: 100%; justify-content: center; }

/* Responsive Mi cuenta */
@media (max-width: 980px) {
	.myaccount-grid {
		grid-template-columns: 1fr;
		gap: var(--space-4);
	}

	/* Navegación como pestañas deslizables horizontales */
	.myaccount-nav {
		position: sticky;
		top: calc(var(--header-h) + var(--topbar-h));
		z-index: 5;
		background: var(--c-white);
		margin: 0 calc(-1 * var(--gutter)) var(--space-4);
		padding: 0;
		border-bottom: 1px solid var(--c-line);
	}
	.myaccount-nav__title { display: none; }
	.myaccount-nav__list {
		display: flex;
		flex-wrap: nowrap;
		gap: 0;
		overflow-x: auto;
		overflow-y: hidden;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		scroll-snap-type: x proximity;
		/* Padding en los extremos del scroll: así el primer/último item
		 * respeta el gutter sin ser cortado al hacer scroll-left=0. */
		padding: 0;
		scroll-padding-inline: var(--gutter);
	}
	.myaccount-nav__list::-webkit-scrollbar { display: none; }

	.myaccount-nav__item {
		border: 0;
		flex-shrink: 0;
		scroll-snap-align: start;
	}
	.myaccount-nav__item:first-child {
		border-top: 0;
		padding-left: var(--gutter);
	}
	.myaccount-nav__item:last-child {
		padding-right: var(--gutter);
	}

	.myaccount-nav__link {
		display: inline-block;
		padding: 0.95rem 0.85rem !important;
		font-size: 0.7rem;
		font-weight: 600;
		letter-spacing: var(--ls-wider);
		text-transform: uppercase;
		color: var(--c-ink-mute);
		border-bottom: 2px solid transparent;
		white-space: nowrap;
		margin-bottom: -1px;
	}
	.myaccount-nav__link:hover {
		color: var(--c-black);
	}
	.myaccount-nav__item.is-active .myaccount-nav__link {
		background: transparent;
		color: var(--c-black);
		border: 0;
		border-bottom: 2px solid var(--c-red);
		margin: 0 0 -1px;
	}

	.myaccount-stats { grid-template-columns: 1fr 1fr; }
	.myaccount-auth__grid { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
	.myaccount-stats { grid-template-columns: 1fr 1fr; gap: 0.5rem; }
	.myaccount-stat { padding: var(--space-3); }
	.myaccount-stat__value { font-size: 1.4rem; }

	/* Pedidos: head con número y fecha */
	.myaccount-order__head {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.25rem;
		padding: var(--space-3) var(--space-4);
	}
	.myaccount-order__number { font-size: 1.1rem; }
	.myaccount-order__date { font-size: 0.7rem; }

	.myaccount-order__body {
		grid-template-columns: 1fr;
		gap: var(--space-3);
		padding: var(--space-4);
	}
	.myaccount-order__stats {
		gap: var(--space-4);
		justify-content: space-between;
	}
	.myaccount-order__stat { min-width: 0; }
	.myaccount-order__value--total { font-size: 1.1rem; }
	.myaccount-order__actions {
		flex-direction: column;
		width: 100%;
	}
	.myaccount-order__actions a { width: 100%; justify-content: center; }

	.myaccount-section__cta { flex-direction: column; }
	.myaccount-section__cta .btn { width: 100%; justify-content: center; }

	.myaccount-section { padding: var(--space-4); }
	.myaccount-section__head h2 { font-size: 1.4rem; }

	/* Direcciones: head + body + foot más compactos */
	.myaccount-address__head { padding: var(--space-3) var(--space-4); }
	.myaccount-address__body { padding: var(--space-4); }
	.myaccount-address__foot { padding: var(--space-3) var(--space-4); }
	.myaccount-address__title { font-size: 1.1rem; }

	/* Auth login/registro: card con menos padding */
	.myaccount-auth__card { padding: var(--space-4); }
	.myaccount-auth__row { flex-direction: column; align-items: flex-start; gap: 0.6rem; }
}

/* Móvil pequeño */
@media (max-width: 480px) {
	.myaccount-stats { grid-template-columns: 1fr; }
	.myaccount-order__stats { gap: var(--space-3); flex-wrap: wrap; }
	.myaccount-order__stat { flex: 1 0 calc(50% - var(--space-3)); }
}

/* ----------------------------------------------------------------- Página /pago/ (checkout) */
.checkout-page {
	padding-block: clamp(2rem, 4vw, 4rem);
	background: var(--c-white);
	min-height: 60vh;
}
.checkout-page__head {
	text-align: center;
	margin-bottom: clamp(2rem, 4vw, 3.5rem);
}
.checkout-page__head h1 {
	margin: var(--space-3) 0;
}
.checkout-page__head .lead {
	margin-inline: auto;
	max-width: 56ch;
}

/* Accordion checkout (estilo Prestashop) */
.checkout-acc-section {
	background: #fff;
	border: 1px solid var(--c-line-strong);
	margin-bottom: var(--space-3);
	overflow: hidden;
	transition: border-color var(--dur) var(--ease);
}
.checkout-acc-section.is-open {
	border-color: var(--c-black);
}

/* Cabecera (siempre visible, clickable) */
.checkout-acc-section__head {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	width: 100%;
	padding: var(--space-4);
	background: transparent;
	border: 0;
	cursor: pointer;
	text-align: left;
	font: inherit;
	color: var(--c-black);
	transition: background var(--dur) var(--ease);
}
.checkout-acc-section__head:hover {
	background: var(--c-off-white);
}
.checkout-acc-section.is-open .checkout-acc-section__head {
	background: var(--c-off-white);
	border-bottom: 1px solid var(--c-line);
}
.checkout-acc-section__num {
	display: grid;
	place-items: center;
	width: 32px; height: 32px;
	border-radius: 50%;
	background: var(--c-stone);
	color: var(--c-ink-mute);
	font-family: var(--ff-display);
	font-size: 1rem;
	font-weight: 600;
	flex: 0 0 auto;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.checkout-acc-section.is-open .checkout-acc-section__num {
	background: var(--c-red);
	color: #fff;
}
.checkout-acc-section.is-done .checkout-acc-section__num {
	background: var(--c-black);
	color: #fff;
}
.checkout-acc-section__heading {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}
.checkout-acc-section__title {
	font-family: var(--ff-display);
	font-size: 1.15rem;
	font-weight: 500;
	color: var(--c-black);
	line-height: 1.25;
}
.checkout-acc-section__chevron {
	font-size: 1.4rem;
	color: var(--c-ink-mute);
	transition: transform var(--dur) var(--ease);
	flex: 0 0 auto;
	line-height: 1;
}
.checkout-acc-section.is-open .checkout-acc-section__chevron {
	transform: rotate(180deg);
	color: var(--c-red);
}

/* Cuerpo: display none/block, fiable en todos los navegadores */
.checkout-acc-section__body {
	display: none;
}
.checkout-acc-section.is-open .checkout-acc-section__body {
	display: block;
	animation: hl-acc-in 0.25s var(--ease);
}
@keyframes hl-acc-in {
	from { opacity: 0; transform: translateY(-4px); }
	to   { opacity: 1; transform: translateY(0); }
}
.checkout-acc-section__inner {
	padding: var(--space-5);
}

/* Botones de navegación entre pasos */
.checkout-step__nav {
	display: flex;
	justify-content: flex-end;
	gap: var(--space-3);
	margin-top: var(--space-5);
	padding-top: var(--space-4);
	border-top: 1px solid var(--c-line);
}
.checkout-step__nav--back {
	justify-content: flex-start;
}
.checkout-step__nav .btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}
.checkout-step__nav .checkout-step__back {
	margin-right: auto;
}

/* Lista de transportistas dentro del paso 2 (la usa nuestro paso, no el resumen) */
.checkout-shipping-methods {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.5rem;
}

/* Resumen: fila de envío con nombre + precio */
.checkout-review__shipping-name {
	display: block;
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	color: var(--c-ink-mute);
	font-weight: 500;
	margin-bottom: 0.15rem;
	text-align: right;
}
.checkout-review__shipping-price {
	display: block;
	font-family: 'Courier New', ui-monospace, monospace;
	font-weight: 600;
	color: var(--c-black);
	text-align: right;
}

/* En móvil */
@media (max-width: 560px) {
	.checkout-acc-section__inner { padding: var(--space-4); }
	.checkout-acc-section__title { font-size: 1rem; }
	.checkout-step__nav { flex-direction: column-reverse; }
	.checkout-step__nav .btn { width: 100%; justify-content: center; margin-right: 0 !important; }
}

/* Layout principal: 2 columnas */
.checkout-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
	gap: clamp(2rem, 5vw, 4rem);
	align-items: start;
}
.checkout-grid__main { min-width: 0; }
.checkout-grid__aside { min-width: 0; }
.checkout-aside__inner {
	position: sticky;
	top: calc(var(--header-h) + var(--topbar-h) + 1rem);
}

/* Secciones */
.checkout-section {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	padding: clamp(1.5rem, 3vw, 2rem);
	margin-bottom: var(--space-5);
}
.checkout-section__head {
	margin-bottom: var(--space-5);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--c-line);
}
.checkout-section__head .eyebrow { display: block; margin-bottom: var(--space-2); }
.checkout-section__head h2,
.checkout-section__head h3 {
	font-size: var(--fs-xl);
	font-weight: 400;
	margin: 0;
	letter-spacing: var(--ls-tight);
}

/* Formulario WooCommerce */
.checkout-form .form-row {
	margin-bottom: var(--space-4);
}
.checkout-form .form-row label,
.checkout-form .form-row > .woocommerce-input-wrapper > label {
	display: block;
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	margin-bottom: 6px;
}
.checkout-form .form-row .required {
	color: var(--c-red);
	font-weight: 700;
	margin-left: 2px;
}
.checkout-form .form-row .optional {
	color: var(--c-ink-mute);
	font-size: 0.7rem;
	font-weight: 500;
	letter-spacing: 0.04em;
}

.checkout-form input[type="text"],
.checkout-form input[type="email"],
.checkout-form input[type="tel"],
.checkout-form input[type="number"],
.checkout-form input[type="password"],
.checkout-form select,
.checkout-form textarea,
.checkout-form .select2-container .select2-selection,
.checkout-form .select2-container--default .select2-selection--single {
	width: 100%;
	height: auto;
	padding: 0.75rem 0.9rem;
	background: #fff;
	border: 1px solid var(--c-line-strong);
	border-radius: 0;
	font-family: var(--ff-body);
	font-size: 1rem;
	color: var(--c-black);
	transition: border-color var(--dur) var(--ease);
}
.checkout-form input:focus,
.checkout-form select:focus,
.checkout-form textarea:focus,
.checkout-form .select2-container--open .select2-selection {
	outline: 0;
	border-color: var(--c-red);
}
.checkout-form .select2-container .select2-selection--single .select2-selection__rendered {
	line-height: 1.5;
	padding: 0;
}
.checkout-form .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 100%;
	right: 0.75rem;
}
.checkout-form textarea { min-height: 96px; resize: vertical; }

/* Filas en grid (calle/número, código postal/población, etc.) */
.checkout-form .form-row-first,
.checkout-form .form-row-last {
	display: inline-block;
	width: calc(50% - 0.5rem);
	box-sizing: border-box;
}
.checkout-form .form-row-first { margin-right: 1rem; }
.checkout-form .form-row-wide { width: 100%; display: block; }

/* Validación */
.checkout-form .woocommerce-invalid input.input-text,
.checkout-form .woocommerce-invalid select {
	border-color: var(--c-red) !important;
	background: rgba(184,30,30,0.03);
}
.checkout-form .woocommerce-validated input.input-text {
	border-color: var(--c-green);
}

/* Headings dentro del form (Billing details, Ship to different address) */
#customer_details h3 {
	font-family: var(--ff-display);
	font-size: var(--fs-xl);
	font-weight: 400;
	margin: var(--space-5) 0 var(--space-4);
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--c-line);
}
#customer_details h3:first-child { margin-top: 0; }
#customer_details h3 #ship-to-different-address-checkbox {
	margin-right: 0.5rem;
}
#customer_details h3 .woocommerce-form__label {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: var(--fs-md);
	font-weight: 500;
	letter-spacing: var(--ls-tight);
	text-transform: none;
	color: var(--c-black);
}

/* ---- Resumen del pedido ---- */
.checkout-review {
	font-family: var(--ff-body);
}
.checkout-review__items {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0;
}
.checkout-review__item {
	display: grid;
	grid-template-columns: 56px 1fr;
	gap: 0.75rem;
	padding: 0.75rem 0;
	border-bottom: 1px dashed var(--c-line);
	align-items: center;
}
.checkout-review__item:last-child { border-bottom: 0; }
.checkout-review__thumb {
	width: 56px; height: 56px;
	overflow: hidden;
	background: var(--c-stone);
	border: 1px solid rgba(10,10,10,.08);
}
.checkout-review__thumb img {
	width: 100%; height: 100%; object-fit: cover;
}
.checkout-review__body { min-width: 0; display: grid; gap: 4px; }
.checkout-review__name {
	font-family: var(--ff-display);
	font-size: 1rem;
	color: var(--c-black);
	font-weight: 500;
	line-height: 1.25;
}
.checkout-review__line {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.825rem;
	color: var(--c-ink-soft);
}
.checkout-review__qty { font-weight: 700; color: var(--c-black); }
.checkout-review__dots {
	flex: 1;
	height: 1px;
	background-image: radial-gradient(circle, var(--c-ink-mute) 1px, transparent 1.5px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
	background-position: 0 50%;
	opacity: 0.45;
	transform: translateY(-3px);
}
.checkout-review__price {
	font-weight: 700;
	color: var(--c-black);
	white-space: nowrap;
}

.checkout-review__rule {
	height: 0;
	border-top: 1px solid var(--c-black);
	margin: var(--space-4) 0 var(--space-3);
}

/* Tabla nativa de totales (estructura WC). En lugar de display:table, forzamos
 * todo a display:block para tener layout flexible 100% controlado.
 * La estructura semántica <table><tr><th><td> sigue intacta para que la AJAX
 * nativa de WC funcione, pero el render visual es CSS Grid / flex. */
.checkout-review__totals,
.checkout-review__totals tbody {
	display: block;
	width: 100%;
	max-width: 100%;
	margin: 0 0 var(--space-5);
	border: 0;
	border-collapse: collapse;
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.95rem;
}
.checkout-review__totals tr {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 0.5rem;
	padding: 0.4rem 0;
	width: 100%;
	color: var(--c-ink-soft);
}
.checkout-review__totals th,
.checkout-review__totals td {
	display: block;
	border: 0;
	padding: 0;
	background: transparent;
	font-weight: 400;
	text-align: left;
	min-width: 0;
}
.checkout-review__totals th {
	font-weight: 500;
}
.checkout-review__totals td {
	font-weight: 600;
	color: var(--c-black);
	text-align: right;
}

/* Sufijo "(sin impuestos)" en línea aparte y más discreto */
.checkout-review__totals td small,
.checkout-review__totals td .woocommerce-Price-taxLabel,
.checkout-review__totals td .tax_label {
	display: block;
	font-size: 0.72rem;
	color: var(--c-ink-mute);
	font-weight: 400;
	margin-top: 0.15rem;
}

/* Fila "Envío" → label arriba, lista de métodos debajo (full width). */
.checkout-review__totals tr.shipping,
.checkout-review__totals tr.woocommerce-shipping-totals {
	flex-direction: column;
	align-items: stretch;
	gap: 0.4rem;
}
.checkout-review__totals tr.shipping th,
.checkout-review__totals tr.woocommerce-shipping-totals th {
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	font-weight: 600;
}
.checkout-review__totals tr.shipping td,
.checkout-review__totals tr.woocommerce-shipping-totals td {
	text-align: left;
	width: 100%;
	max-width: 100%;
}

/* Total final */
.checkout-review__row--total {
	margin-top: 0.4rem;
	padding-top: 0.7rem !important;
	border-top: 1px dashed rgba(10,10,10,.3);
	color: var(--c-black) !important;
}
.checkout-review__row--total th {
	font-family: var(--ff-body);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
}
.checkout-review__row--total td {
	font-family: var(--ff-display);
	font-size: 1.5rem;
	font-weight: 600;
}

/* Métodos de pago */
/* Anula el fondo violeta default de WooCommerce sobre #payment */
#add_payment_method #payment,
.woocommerce-cart #payment,
.woocommerce-checkout #payment,
.woocommerce-checkout-payment#payment,
.checkout-payment {
	background: transparent !important;
	border-radius: 0 !important;
}
.checkout-payment {
	margin-top: var(--space-5);
}
.checkout-payment__head {
	margin-bottom: var(--space-4);
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--c-line);
}
.checkout-payment__head h3 {
	font-family: var(--ff-display);
	font-size: var(--fs-xl);
	font-weight: 400;
	margin: var(--space-2) 0 0;
}
.checkout-payment__methods {
	list-style: none;
	margin: 0 0 var(--space-5);
	padding: 0;
	display: grid;
	gap: 0.5rem;
}
.checkout-payment__methods li.wc_payment_method {
	background: #fff;
	border: 1px solid var(--c-line-strong);
	padding: 0.85rem 1rem;
	transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.checkout-payment__methods li.wc_payment_method:hover { border-color: var(--c-black); }
.checkout-payment__methods li.wc_payment_method label {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	cursor: pointer;
	font-family: var(--ff-body);
	font-size: 0.95rem;
	font-weight: 500;
	color: var(--c-black);
}
.checkout-payment__methods li.wc_payment_method input[type="radio"] {
	accent-color: var(--c-red);
	width: 18px; height: 18px;
	flex-shrink: 0;
}
/* Radio nativo en cualquier contexto del checkout: rojo */
.woocommerce input[type="radio"],
.checkout input[type="radio"],
.checkout-payment input[type="radio"] { accent-color: var(--c-red); }
/* Checkboxes nativos: negro */
.woocommerce input[type="checkbox"],
.checkout input[type="checkbox"] { accent-color: var(--c-black); }

/* Neutralizar el "button" violeta default de WC en cualquier sitio del frontend */
.woocommerce button.button:not(.btn):not(.checkout-place-order):not(.qty-input__btn),
.woocommerce a.button:not(.btn):not(.checkout-place-order),
.woocommerce-page button.button:not(.btn):not(.checkout-place-order):not(.qty-input__btn),
.woocommerce-page a.button:not(.btn):not(.checkout-place-order),
.woocommerce input.button:not(.btn):not(.checkout-place-order) {
	background: var(--c-black) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 0.65rem 1.1rem !important;
	font-family: var(--ff-body) !important;
	font-size: 0.75rem !important;
	font-weight: 600 !important;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	transition: background var(--dur) var(--ease);
	box-shadow: none !important;
}
.woocommerce button.button:not(.btn):not(.checkout-place-order):hover,
.woocommerce a.button:not(.btn):not(.checkout-place-order):hover,
.woocommerce-page button.button:not(.btn):not(.checkout-place-order):hover,
.woocommerce-page a.button:not(.btn):not(.checkout-place-order):hover {
	background: var(--c-red) !important;
}
/* Variante "alt" en botones de WC (la que sale violeta) */
.woocommerce button.alt,
.woocommerce-page button.alt,
.woocommerce input.alt {
	background: var(--c-red) !important;
	color: #fff !important;
}
.checkout-payment__methods li.wc_payment_method .payment_box {
	margin-top: 0.75rem;
	padding: 0.85rem 1rem;
	background: var(--c-off-white) !important;
	font-size: 0.9rem;
	color: var(--c-ink-soft);
	border-left: 2px solid var(--c-red);
	border-radius: 0 !important;
}
/* Anula el caret triangular violeta del payment_box default de WC */
.woocommerce-checkout #payment .payment_box::before,
.checkout-payment__methods .payment_box::before {
	display: none !important;
}
/* Anular bordes y padding heredados de WC en ul.payment_methods */
.woocommerce-checkout #payment ul.payment_methods,
.checkout-payment__methods {
	border-bottom: 0 !important;
	margin: 0 0 var(--space-5) !important;
	padding: 0 !important;
}
.woocommerce-checkout #payment .form-row.place-order,
.checkout-payment .form-row.place-order {
	background: transparent !important;
	border-radius: 0 !important;
	padding: 0 !important;
}

/* Botón final */
.checkout-place-order,
.checkout-payment .place-order .btn {
	width: 100%;
	display: block;
	padding: 1.1rem 1.25rem !important;
	font-size: 0.875rem !important;
	margin-top: var(--space-4);
}

/* Coupon toggle + form (estilo Highland) */
.woocommerce-form-coupon-toggle,
.woocommerce-form-login-toggle {
	margin: 0 0 var(--space-4);
}
.woocommerce-form-coupon-toggle .woocommerce-info,
.woocommerce-form-login-toggle .woocommerce-info {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	border-left: 3px solid var(--c-red);
	padding: 0.85rem 1rem;
	font-size: 0.9rem;
	color: var(--c-ink-soft);
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
}
.woocommerce-info a.showcoupon,
.woocommerce-info a.showlogin {
	color: var(--c-red);
	font-weight: 600;
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	font-size: var(--fs-xs);
	border-bottom: 1px solid var(--c-red);
	padding-bottom: 1px;
	margin-left: auto;
}
.woocommerce-info a.showcoupon:hover,
.woocommerce-info a.showlogin:hover { color: var(--c-red-deep); border-bottom-color: var(--c-red-deep); }

.checkout_coupon,
.woocommerce-form-coupon {
	display: block !important; /* nuestra plantilla no usa toggle */
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	padding: var(--space-4);
	margin: 0 0 var(--space-5);
}
.checkout-coupon__title {
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	margin: 0 0 var(--space-3);
}
.checkout_coupon p,
.woocommerce-form-coupon p { margin: 0; }
.checkout_coupon p:not(:last-child),
.woocommerce-form-coupon p:not(:last-child) { margin-bottom: var(--space-3); }
.checkout_coupon .form-row,
.woocommerce-form-coupon .form-row {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: var(--space-3);
	margin: 0;
}
.checkout_coupon input[type="text"],
.woocommerce-form-coupon input[type="text"] {
	width: 100%;
	height: auto;
	padding: 0.75rem 0.9rem;
	border: 1px solid var(--c-line-strong);
	background: #fff;
	font-family: var(--ff-body);
	font-size: 1rem;
}
.checkout_coupon input[type="text"]:focus,
.woocommerce-form-coupon input[type="text"]:focus { outline: 0; border-color: var(--c-red); }
.checkout_coupon button,
.woocommerce-form-coupon button {
	background: var(--c-black);
	color: #fff;
	border: 0;
	padding: 0.75rem 1.5rem;
	font-family: var(--ff-body);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	cursor: pointer;
	white-space: nowrap;
	align-self: flex-end;
	min-width: 140px;
	transition: background var(--dur) var(--ease);
}
.checkout_coupon button:hover,
.woocommerce-form-coupon button:hover { background: var(--c-red); }

/* Form login si lo muestra al inicio del checkout */
.woocommerce-form-login.login {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	padding: var(--space-4);
	margin: 0 0 var(--space-5);
}

/* ---- Página de gracias ---- */
.thankyou-page {
	padding-block: clamp(3rem, 6vw, 5rem);
	min-height: 60vh;
	background: var(--c-white);
}
.thankyou-page__head {
	text-align: center;
	margin-bottom: clamp(2rem, 4vw, 3rem);
}
.thankyou-page__head h1 {
	margin: var(--space-3) 0;
	max-width: 18ch;
	margin-inline: auto;
}
.thankyou-page__head .lead { margin-inline: auto; }
.thankyou-page__actions {
	margin-top: clamp(2rem, 4vw, 3rem);
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-3);
}

.thankyou-receipt {
	background: #FAF6EE;
	background-image:
		linear-gradient(to bottom, rgba(0,0,0,.012) 0%, rgba(0,0,0,0) 50%, rgba(0,0,0,.012) 100%),
		repeating-linear-gradient(0deg, rgba(0,0,0,0) 0, rgba(0,0,0,0) 28px, rgba(0,0,0,.018) 29px);
	padding: clamp(2rem, 4vw, 2.5rem);
	max-width: 540px;
	margin: 0 auto;
	box-shadow: 0 22px 48px -22px rgba(0,0,0,.25);
}
.thankyou-receipt__head {
	text-align: center;
	padding-bottom: var(--space-4);
	margin-bottom: var(--space-4);
	border-bottom: 1px dashed rgba(10,10,10,.25);
}
.thankyou-receipt__brand {
	font-family: var(--ff-display);
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0.04em;
}
.thankyou-receipt__sub {
	font-size: 0.7rem;
	letter-spacing: var(--ls-widest);
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin: 4px 0 0.65rem;
}
.thankyou-receipt__meta {
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.75rem;
	color: var(--c-ink-soft);
}
.thankyou-receipt__summary {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0;
}
.thankyou-receipt__summary li {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: 0.6rem 0;
	border-bottom: 1px dashed rgba(10,10,10,.18);
	gap: 0.5rem;
}
.thankyou-receipt__summary li:last-child { border-bottom: 0; }
.thankyou-receipt__label {
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.thankyou-receipt__summary strong {
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-weight: 700;
	color: var(--c-black);
}
.thankyou-receipt__summary li:nth-child(1) strong { font-family: var(--ff-display); font-size: 1.05rem; }
.thankyou-receipt__note {
	margin-top: var(--space-4);
	padding: var(--space-4);
	background: rgba(255,255,255,0.6);
	border-left: 2px solid var(--c-red);
}
.thankyou-receipt__note p {
	margin: 0.5rem 0 0;
	font-style: italic;
	color: var(--c-ink-soft);
	font-size: 0.95rem;
	line-height: 1.5;
}

/* ---- Página "Pedido recibido": secciones extra ---- */
.thankyou-section {
	max-width: 720px;
	margin: clamp(2rem, 4vw, 3rem) auto 0;
}
.thankyou-section__head {
	text-align: center;
	margin-bottom: var(--space-5);
}
.thankyou-section__head .eyebrow { display: block; margin-bottom: var(--space-2); }
.thankyou-section__head h2 {
	font-size: var(--fs-2xl);
	font-weight: 400;
	margin: 0;
}

/* Lista de items del pedido (estilo recibo) */
.order-details {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	padding: clamp(1.5rem, 3vw, 2rem);
	font-family: var(--ff-body);
	margin-bottom: var(--space-5);
}
.order-customer {
	margin-bottom: var(--space-5);
}

/* Margen entre bloques en Mi cuenta → Ver pedido (plantilla view-order de WC):
 * cada bloque (parrafo, order-details, order-customer, etc.) lleva separación
 * vertical para que no quede todo pegado. */
.woocommerce-MyAccount-content > p,
.woocommerce-MyAccount-content > section,
.woocommerce-MyAccount-content > address,
.woocommerce-MyAccount-content > h2,
.woocommerce-MyAccount-content > h3 {
	margin-bottom: var(--space-4);
}
.woocommerce-MyAccount-content > *:last-child { margin-bottom: 0; }
/* "El pedido #X se realizó..." con un poco de aire arriba si va tras un h2 */
.woocommerce-MyAccount-content > p:first-child { margin-top: 0; }
.order-details__items {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0;
}
.order-details__item {
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: 0.85rem;
	padding: 0.75rem 0;
	border-bottom: 1px dashed var(--c-line);
	align-items: center;
}
.order-details__item:last-child { border-bottom: 0; }
.order-details__thumb {
	width: 64px; height: 64px;
	overflow: hidden;
	background: var(--c-stone);
	border: 1px solid rgba(10,10,10,.08);
}
.order-details__thumb img { width: 100%; height: 100%; object-fit: cover; }
.order-details__body { min-width: 0; display: grid; gap: 4px; }
.order-details__name {
	font-family: var(--ff-display);
	font-size: 1.1rem;
	color: var(--c-black);
	font-weight: 500;
	line-height: 1.25;
}
.order-details__line {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.875rem;
	color: var(--c-ink-soft);
}
.order-details__qty { font-weight: 700; color: var(--c-black); }
.order-details__dots {
	flex: 1;
	height: 1px;
	background-image: radial-gradient(circle, var(--c-ink-mute) 1px, transparent 1.5px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
	background-position: 0 50%;
	opacity: 0.45;
	transform: translateY(-3px);
}
.order-details__price {
	font-weight: 700;
	color: var(--c-black);
	white-space: nowrap;
}
.order-details__rule {
	border-top: 1px solid var(--c-black);
	margin: var(--space-4) 0 var(--space-3);
	height: 0;
}
.order-details__totals {
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.95rem;
	margin: 0;
}
.order-details__row {
	display: flex; justify-content: space-between; align-items: baseline;
	padding: 0.4rem 0;
	color: var(--c-ink-soft);
	gap: 0.5rem;
}
.order-details__row dt { margin: 0; font-weight: 500; }
.order-details__row dd { margin: 0; font-weight: 600; color: var(--c-black); text-align: right; }
.order-details__row--total {
	margin-top: 0.4rem;
	padding-top: 0.6rem;
	border-top: 1px dashed rgba(10,10,10,.3);
}
.order-details__row--total dt {
	font-family: var(--ff-body);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
}
.order-details__row--total dd {
	font-family: var(--ff-display);
	font-size: 1.5rem;
	font-weight: 600;
}
.order-details__customer-note {
	margin-top: var(--space-4);
	padding: var(--space-4);
	background: #fff;
	border-left: 2px solid var(--c-red);
	font-size: 0.95rem;
}
.order-details__customer-note p { margin: 0.4rem 0 0; font-style: italic; color: var(--c-ink-soft); }

/* Direcciones */
.order-customer__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-5);
}
.order-customer__col {
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	padding: var(--space-5);
}
.order-customer__col h3 {
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
	margin: 0 0 var(--space-3);
}
.order-customer__col address {
	font-family: var(--ff-body);
	font-style: normal;
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--c-ink-soft);
}
.order-customer__line {
	display: flex;
	align-items: baseline;
	gap: 0.5rem;
	margin: 0.5rem 0 0;
	padding-top: 0.5rem;
	border-top: 1px dashed var(--c-line);
	font-size: 0.9rem;
}
.order-customer__label {
	font-size: 0.65rem;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-ink-mute);
	font-weight: 600;
	flex-shrink: 0;
	min-width: 4rem;
}
.order-customer__col a {
	color: var(--c-black);
	text-decoration: none;
	border-bottom: 1px solid currentColor;
}
.order-customer__col a:hover { color: var(--c-red); }

/* BACS instructions: WC imprime un <p> suelto (sin clase) con la frase
 * "Realiza el pago directamente en nuestra cuenta bancaria..." antes de
 * <section.woocommerce-bacs-bank-details>. Lo estilizamos como aviso
 * crema con borde rojo, en lugar de quedar como párrafo huérfano. */
.thankyou-page .wrap > p,
.thankyou-page__head + p {
	max-width: 720px;
	margin: var(--space-5) auto var(--space-3);
	padding: 0.95rem 1.1rem;
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	border-left: 3px solid var(--c-red);
	color: var(--c-ink-soft);
	font-size: 0.95rem;
	line-height: 1.6;
}

/* BACS / instrucciones de pago: WC inyecta automáticamente
 *   <section.woocommerce-bacs-bank-details>
 *      <h2.wc-bacs-bank-details-heading>Nuestros detalles bancarios</h2>
 *      <ul.wc-bacs-bank-details>
 *          <li.wc-bacs-bank-details-account>
 *             <h3.wc-bacs-bank-details-account-name>Carne de Highland:</h3>
 *             <ul>
 *                <li.bank_name>Banco: <strong>...</strong></li>
 *                <li.iban>IBAN: <strong>...</strong></li>
 *                ...
 */
.woocommerce-bacs-bank-details {
	max-width: 720px;
	margin: clamp(1.5rem, 3vw, 2.5rem) auto;
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	border-left: 3px solid var(--c-red);
	padding: clamp(1.25rem, 3vw, 1.75rem);
}
/* Heading de la sección: en mayúsculas pequeñas tipo eyebrow */
.wc-bacs-bank-details-heading,
.woocommerce-bacs-bank-details > h2 {
	font-family: var(--ff-body) !important;
	font-size: var(--fs-xs) !important;
	font-weight: 600 !important;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-red);
	margin: 0 0 var(--space-4) !important;
}
.wc-bacs-bank-details {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--space-4);
}
.wc-bacs-bank-details li.wc-bacs-bank-details-account {
	display: grid;
	gap: 0.5rem;
	background: transparent;
	padding: 0;
}
/* Nombre de la cuenta: serif elegante, sin h3 enorme y sin los dos puntos */
.wc-bacs-bank-details h3.wc-bacs-bank-details-account-name {
	font-family: var(--ff-display) !important;
	font-size: 1.35rem !important;
	font-weight: 500 !important;
	margin: 0 !important;
	color: var(--c-black);
	line-height: 1.2;
}
/* Lista de campos (Banco, IBAN, BIC...) */
.wc-bacs-bank-details ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0;
}
.wc-bacs-bank-details ul li {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.85rem;
	align-items: baseline;
	padding: 0.55rem 0;
	border-top: 1px dashed rgba(10,10,10,.18);
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.85rem;
	color: var(--c-ink-mute);
	letter-spacing: 0.02em;
}
.wc-bacs-bank-details ul li:first-child { border-top: 0; }
.wc-bacs-bank-details ul li strong {
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--c-black);
	letter-spacing: 0.02em;
}

/* Responsive checkout */
@media (max-width: 980px) {
	.checkout-grid {
		grid-template-columns: 1fr;
		gap: var(--space-5);
	}
	.checkout-aside__inner { position: static; }
	/* Accordion primero, resumen al final */
	.checkout-grid__main { order: 1; }
	.checkout-grid__aside { order: 2; }

	/* Cabecera del accordion compacta */
	.checkout-acc-section__head { padding: var(--space-3) var(--space-4); gap: var(--space-3); }
	.checkout-acc-section__num { width: 28px; height: 28px; font-size: 0.9rem; }
	.checkout-acc-section__title { font-size: 1.05rem; }

	.order-customer__grid { grid-template-columns: 1fr; }
}

/* Móvil pequeño: accordion ultra-compacto */
@media (max-width: 480px) {
	.checkout-page__head h1 { font-size: clamp(1.6rem, 8vw, 2.2rem); }
	.checkout-acc-section__head { padding: 0.85rem 0.9rem; gap: 0.6rem; }
	.checkout-acc-section__num { width: 26px; height: 26px; font-size: 0.85rem; }
	.checkout-acc-section__title { font-size: 0.95rem; line-height: 1.3; }
	.checkout-acc-section__inner { padding: var(--space-4) var(--space-3); }

	/* Métodos de envío en el paso 2: padding más justo */
	.checkout-acc-section ul#shipping_method li,
	.checkout-acc-section .woocommerce-shipping-methods li {
		padding: 0.6rem 0.7rem !important;
		gap: 0.5rem;
	}

	/* Resumen lateral: padding ajustado */
	.checkout-grid__aside .checkout-section { padding: var(--space-4) var(--space-3); }
}

/* Página "Pedido recibido": móvil */
@media (max-width: 720px) {
	.thankyou-page { padding-block: clamp(1.5rem, 4vw, 2.5rem); }
	.thankyou-receipt { padding: var(--space-5) var(--space-4); }
	.thankyou-receipt__brand { font-size: 1.25rem; letter-spacing: 0.03em; }
	.thankyou-receipt__summary li {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.25rem;
		padding: 0.55rem 0;
	}
	.thankyou-receipt__summary strong { font-size: 1rem; }

	/* Order details items en móvil */
	.order-details { padding: var(--space-4); }
	.order-details__item { grid-template-columns: 56px 1fr; gap: 0.65rem; padding: 0.6rem 0; }
	.order-details__thumb { width: 56px; height: 56px; }
	.order-details__name { font-size: 1rem; }
	.order-details__row--total dd { font-size: 1.25rem; }

	/* Customer (direcciones) cards apiladas */
	.order-customer__grid { gap: var(--space-3); }
	.order-customer__col { padding: var(--space-4); }
	.order-customer__line { gap: 0.4rem; }

	/* BACS bank details: lista vertical */
	.woocommerce-bacs-bank-details { padding: var(--space-4); margin-block: var(--space-4); }
	.wc-bacs-bank-details ul li {
		gap: 0.4rem 0.6rem;
		font-size: 0.8rem;
	}
	.wc-bacs-bank-details ul li strong { font-size: 0.85rem; word-break: break-all; }

	.thankyou-page__actions { flex-direction: column; }
	.thankyou-page__actions .btn { width: 100%; justify-content: center; }
}

@media (max-width: 720px) {
	.checkout-page { padding-block: clamp(1.5rem, 4vw, 2.5rem); }
	.checkout-section { padding: var(--space-4); }
	.checkout-form .form-row-first,
	.checkout-form .form-row-last {
		display: block;
		width: 100%;
		margin-right: 0;
	}
	.checkout-payment__methods li.wc_payment_method { padding: 0.7rem 0.85rem; }
	.thankyou-page__actions { flex-direction: column; align-items: stretch; }
	.thankyou-page__actions .btn { width: 100%; justify-content: center; }
}

/* ----------------------------------------------------------------- Modal "Ticket" del carrito */
.cart-modal {
	position: fixed;
	inset: 0;
	/* Usamos 100% (heredado del fixed) + dvh como refuerzo en navegadores móviles
	 * que tienen barras dinámicas. El height fixed cubre el viewport entero. */
	height: 100vh;
	height: 100dvh;
	z-index: 999;
	pointer-events: none;
	visibility: hidden;
}
.cart-modal[aria-hidden="false"] {
	pointer-events: auto;
	visibility: visible;
}
.cart-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(10,10,10,.55);
	opacity: 0;
	transition: opacity 280ms var(--ease);
}
.cart-modal[aria-hidden="false"] .cart-modal__overlay { opacity: 1; }

.cart-modal__panel {
	position: absolute;
	top: 0; right: 0;
	height: 100%;
	width: min(440px, 100vw);
	background: #FAF6EE; /* fondo SÓLIDO del ticket: si el modal scrollea, no se ve negro */
	transform: translateX(100%);
	transition: transform 360ms cubic-bezier(.2, .7, .25, 1);
	display: flex;
	flex-direction: column;
	align-items: stretch;
	padding: 0;
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior: contain;
}
.cart-modal[aria-hidden="false"] .cart-modal__panel { transform: translateX(0); }

.cart-modal__close {
	position: absolute;
	top: 1.1rem; right: 1.1rem;
	z-index: 2;
	width: 36px; height: 36px;
	display: grid; place-items: center;
	background: var(--c-black);
	color: #fff;
	border: 0;
	cursor: pointer;
	border-radius: 999px;
	box-shadow: 0 4px 14px rgba(0,0,0,.2);
	transition: background var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.cart-modal__close:hover { background: var(--c-red); transform: rotate(90deg); }

body.has-cart-modal { overflow: hidden; }

/* ----------------------------------------------------------------- Ticket (papel kraft) */
.ticket {
	flex: 1 0 auto; /* nunca se encoge: si hay mucho contenido se hace scroll en el panel */
	min-height: 100%;
	background: #FAF6EE;
	background-image:
		linear-gradient(to bottom, rgba(0,0,0,.012) 0%, rgba(0,0,0,0) 50%, rgba(0,0,0,.012) 100%),
		repeating-linear-gradient(
			0deg,
			rgba(0,0,0,0) 0,
			rgba(0,0,0,0) 28px,
			rgba(0,0,0,.018) 29px
		);
	color: var(--c-black);
	padding: clamp(2rem, 4vw, 2.5rem) clamp(1.25rem, 3vw, 2rem) calc(clamp(2rem, 4vw, 2.5rem) + env(safe-area-inset-bottom, 0px));
	padding-top: calc(clamp(2rem, 4vw, 2.5rem) + env(safe-area-inset-top, 0px));
	position: relative;
	font-family: var(--ff-body);
	display: flex;
	flex-direction: column;
}

/* Cabecera */
.ticket__head {
	text-align: center;
	margin-bottom: var(--space-5);
}
.ticket__brand {
	font-family: var(--ff-display);
	font-size: 1.85rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	color: var(--c-black);
	margin-bottom: 4px;
}
.ticket__sub {
	font-size: 0.7rem;
	letter-spacing: var(--ls-widest);
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 0.75rem;
}
.ticket__meta {
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.75rem;
	letter-spacing: 0.02em;
	color: var(--c-ink-soft);
	display: inline-flex;
	gap: 0.4rem;
	flex-wrap: wrap;
	justify-content: center;
}
.ticket__sep { opacity: 0.55; }

/* Reglas decorativas */
.ticket__rule {
	height: 0;
	border-top: 1px dashed var(--c-ink-mute);
	margin: var(--space-3) 0 var(--space-4);
	opacity: 0.65;
}
.ticket__rule--double {
	border-top: 1px solid var(--c-black);
	border-bottom: 1px solid var(--c-black);
	height: 3px;
	opacity: 1;
	margin: var(--space-4) 0 var(--space-3);
}

/* Estado vacío */
.ticket__empty {
	text-align: center;
	padding: var(--space-6) 0;
	display: grid;
	gap: var(--space-3);
}
.ticket__empty p {
	font-family: var(--ff-display);
	font-size: 1.4rem;
	font-style: italic;
	color: var(--c-ink-mute);
	margin: 0;
}

/* Lista de items */
.ticket__items {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-2);
	display: grid;
	gap: 0;
}
.ticket__item {
	display: grid;
	grid-template-columns: 56px 1fr auto;
	gap: 0.85rem;
	padding: 0.75rem 0;
	align-items: center;
	border-bottom: 1px dashed rgba(10,10,10,.18);
}
.ticket__item:last-child { border-bottom: 0; }
.ticket__item-thumb {
	width: 56px; height: 56px;
	overflow: hidden;
	background: var(--c-stone);
	display: block;
	border: 1px solid rgba(10,10,10,.08);
}
.ticket__item-img {
	width: 100%; height: 100%;
	object-fit: cover;
}
.ticket__item-body {
	min-width: 0;
	display: grid;
	gap: 4px;
}
.ticket__item-name {
	font-family: var(--ff-display);
	font-size: 1.05rem;
	color: var(--c-black);
	font-weight: 500;
	line-height: 1.2;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.ticket__item-name:hover { color: var(--c-red); }
.ticket__item-line {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.875rem;
	color: var(--c-ink-soft);
}
/* Cantidad en el ticket */
.ticket__item-qty {
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-weight: 700;
	color: var(--c-black);
	font-size: 0.95rem;
}
/* En la página /carrito/, el input es nativo de WC y editable */
.ticket__qty {
	display: inline-flex;
	align-items: center;
}
.ticket__qty-input {
	width: 56px;
	height: 32px;
	text-align: center;
	border: 1px solid rgba(10,10,10,.25);
	background: #fff;
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--c-black);
	padding: 0 6px;
	-moz-appearance: textfield;
}
.ticket__qty-input::-webkit-outer-spin-button,
.ticket__qty-input::-webkit-inner-spin-button { -webkit-appearance: auto; margin: 0; }
.ticket__qty-input:focus { outline: 0; border-color: var(--c-red); }

.ticket__item-dots {
	flex: 1;
	height: 1px;
	background-image: radial-gradient(circle, var(--c-ink-mute) 1px, transparent 1.5px);
	background-size: 4px 1px;
	background-repeat: repeat-x;
	background-position: 0 50%;
	opacity: 0.45;
	transform: translateY(-3px);
}
.ticket__item-price {
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-weight: 700;
	color: var(--c-black);
	font-size: 0.95rem;
}
.ticket__item-price .woocommerce-Price-amount { font-family: inherit; font-weight: inherit; color: inherit; }
.ticket__item-remove {
	grid-column: 3;
	grid-row: 1 / -1;
	align-self: start;
	width: 24px; height: 24px;
	display: grid; place-items: center;
	color: var(--c-ink-mute);
	background: transparent;
	border: 0;
	border-radius: 999px;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
	margin-left: 0.4rem;
}
.ticket__item-remove:hover { background: var(--c-red); color: #fff; }

/* Totales */
.ticket__totals {
	margin: 0 0 var(--space-5);
	font-family: 'Courier New', ui-monospace, Menlo, Consolas, monospace;
	font-size: 0.95rem;
}
.ticket__row {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 0.45rem 0;
	color: var(--c-ink-soft);
}
.ticket__row dt { margin: 0; font-weight: 500; }
.ticket__row dd { margin: 0; font-weight: 600; color: var(--c-black); }
.ticket__row-mute { color: var(--c-ink-mute) !important; font-weight: 400 !important; font-size: 0.85rem; }
.ticket__row--total {
	margin-top: 0.4rem;
	padding-top: 0.6rem;
	border-top: 1px dashed rgba(10,10,10,.3);
	font-size: 1.05rem;
}
.ticket__row--total dt { font-family: var(--ff-body); font-weight: 600; text-transform: uppercase; letter-spacing: var(--ls-wide); font-size: 0.78rem; }
.ticket__row--total dd { font-family: var(--ff-display); font-size: 1.5rem; font-weight: 600; }

/* Acciones */
.ticket__actions {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	margin: 0 0 var(--space-5);
	position: relative;
	z-index: 1;
}
.ticket__actions .btn {
	justify-content: center;
	width: 100%;
}
/* En el modal-ticket, los botones ghost necesitan fondo sólido del papel
 * para no transparentar las imágenes de los productos por encima. */
.cart-modal .ticket__actions .btn--ghost {
	background: var(--c-white) !important;
	color: var(--c-black);
	border-color: var(--c-black);
}
.cart-modal .ticket__actions .btn--ghost:hover {
	background: var(--c-black) !important;
	color: #fff;
}
.cart-modal .ticket__actions .btn--red {
	background: var(--c-red);
	color: #fff;
}

.ticket__keep-shopping {
	display: block;
	text-align: center;
	font-size: 0.8rem;
	letter-spacing: var(--ls-wide);
	color: var(--c-ink-mute);
	padding: 0.65rem 0.4rem;
	margin-top: 0.25rem;
	background: transparent;
}
.ticket__keep-shopping:hover { color: var(--c-red); }

/* Footer del ticket */
.ticket__footer {
	margin-top: auto;
	padding-top: var(--space-3);
	text-align: center;
}
.ticket__thanks {
	font-family: var(--ff-display);
	font-style: italic;
	font-size: 0.95rem;
	color: var(--c-ink-mute);
	margin: 0;
}

/* Sombra del panel solo en escritorio (en móvil ocupa toda la pantalla) */
@media (min-width: 861px) {
	.cart-modal__panel {
		box-shadow: -22px 0 48px -22px rgba(0,0,0,.35), -1px 0 0 rgba(0,0,0,.04);
	}
}

/* Responsive del modal-ticket */
@media (max-width: 860px) {
	.cart-modal__panel {
		width: 100%;
		max-width: 100%;
	}
	.ticket {
		padding: clamp(1.5rem, 5vw, 2.25rem) clamp(1rem, 4vw, 1.5rem) calc(clamp(1.5rem, 5vw, 2.25rem) + env(safe-area-inset-bottom, 0px));
		padding-top: calc(clamp(1.5rem, 5vw, 2.25rem) + env(safe-area-inset-top, 0px));
	}
}

@media (max-width: 720px) {
	.cart-modal__close {
		top: 0.65rem; right: 0.65rem;
		width: 38px; height: 38px;
	}
	.ticket__brand { font-size: 1.45rem; letter-spacing: 0.03em; }
	.ticket__sub   { font-size: 0.65rem; }
	.ticket__meta  { font-size: 0.7rem; }
	.ticket__item {
		grid-template-columns: 52px 1fr auto;
		gap: 0.65rem;
		padding: 0.65rem 0;
	}
	.ticket__item-thumb { width: 52px; height: 52px; }
	.ticket__item-name { font-size: 1rem; }
	.ticket__item-line { font-size: 0.8rem; gap: 0.4rem; }
	.ticket__item-price { font-size: 0.875rem; }
	.ticket__item-remove { width: 32px; height: 32px; } /* área de toque */
	.ticket__qty { height: 32px; } /* touch-friendly */
	.ticket__qty-btn { width: 30px; height: 30px; font-size: 1.05rem; }
	.ticket__qty-input { width: 38px; height: 30px; font-size: 0.9rem; }
	.ticket__row { padding: 0.4rem 0; font-size: 0.875rem; }
	.ticket__row--total dd { font-size: 1.35rem; }
	.ticket__actions { gap: 0.55rem; margin-bottom: var(--space-4); }
	.ticket__actions .btn {
		padding: 0.95rem 1rem;
		min-height: 48px; /* touch-friendly */
	}
	.ticket__keep-shopping { padding: 0.6rem; min-height: 40px; display: block; }
}

/* Móvil pequeño: aún más compacto pero legible */
@media (max-width: 380px) {
	.ticket { padding: 1.5rem 0.85rem; }
	.ticket__brand { font-size: 1.25rem; }
	.ticket__item { grid-template-columns: 44px 1fr auto; gap: 0.5rem; }
	.ticket__item-thumb { width: 44px; height: 44px; }
}

/* ----------------------------------------------------------------- WooCommerce overrides (sólo lo imprescindible — todo lo demás ya viene en plantillas custom) */
.wc-main { padding-block: clamp(2rem, 4vw, 4rem); }

/* Breadcrumb por defecto de WC (cuando lo emite alguna página) */
.woocommerce-breadcrumb {
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: var(--space-5);
}
.woocommerce-breadcrumb a { color: var(--c-ink-mute); }
.woocommerce-breadcrumb a:hover { color: var(--c-red); }

/* Cart & Checkout (estilo coherente con el resto del tema) */
.woocommerce-cart .wc-block-cart-item__product-name a,
.woocommerce-checkout .wc-block-components-product-name {
	font-family: var(--ff-display);
	color: var(--c-black);
}
.wc-block-components-button.contained,
.wc-block-cart__submit-button {
	background: var(--c-red);
	color: #fff;
	border-radius: 0;
}

/* ----------------------------------------------------------------- About page */
.about-hero {
	padding-block: clamp(4rem, 8vw, 7rem);
	background: var(--c-white);
	text-align: center;
	border-bottom: 1px solid var(--c-line);
}
.about-hero h1 {
	margin: var(--space-4) 0 var(--space-5);
	max-width: 18ch;
	margin-inline: auto;
}
.about-hero .lead { margin-inline: auto; }
.about-hero__rule {
	width: 48px; height: 2px;
	background: var(--c-red);
	margin: var(--space-6) auto 0;
}

/* Tres pilares: Nosotros / Misión / Valor */
.about-pillars__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
}
.about-pillars__grid .pillar {
	padding: var(--space-8) var(--space-6);
	display: grid;
	gap: var(--space-3);
	align-content: start;
	border-left: 1px solid var(--c-line);
}
.about-pillars__grid .pillar:first-child { border-left: 0; }
.about-pillars__grid .pillar h2 { font-size: var(--fs-xl); margin: 0; }
.about-pillars__grid .pillar p { color: var(--c-ink-soft); margin: 0; }

/* Fundador con imagen + cita */
.about-founder__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: center;
}
.about-founder__media {
	margin: 0;
	overflow: hidden;
	background: var(--c-stone);
	aspect-ratio: 1 / 1;
}
.about-founder__media img {
	width: 100%; height: 100%;
	object-fit: cover;
}
.about-founder__panel { display: grid; gap: var(--space-4); align-content: center; }
.about-founder__panel h2 { margin: 0; max-width: 18ch; }
.about-founder__panel p { color: var(--c-ink-soft); margin: 0; max-width: 52ch; }

.about-quote {
	margin: var(--space-5) 0 0;
	padding: var(--space-5) var(--space-6) var(--space-5);
	background: #fff;
	border-left: 3px solid var(--c-red);
	position: relative;
}
.about-quote__rule {
	display: block;
	width: 24px; height: 1px;
	background: var(--c-red);
	margin-bottom: var(--space-3);
}
.about-quote p {
	font-family: var(--ff-display);
	font-style: italic;
	font-weight: 400;
	font-size: clamp(1.15rem, 0.85rem + 1vw, 1.5rem);
	line-height: 1.4;
	color: var(--c-black);
	margin: 0 0 var(--space-3);
}
.about-quote cite {
	font-style: normal;
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	color: var(--c-ink-mute);
}

/* Animales */
.about-animals .section__head { max-width: 56ch; }
.about-animals__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-6);
	margin-top: var(--space-8);
}
.ani-card {
	background: var(--c-off-white);
	border: 1px solid var(--c-line-strong);
	padding: var(--space-6);
	display: grid;
	gap: var(--space-3);
	align-content: start;
}
.ani-card h3 { font-size: var(--fs-2xl); margin: 0; }
.ani-card p  { color: var(--c-ink-soft); margin: 0; }
.ani-card .ekolurra {
	margin-top: var(--space-3);
	max-height: 36px;
	width: auto;
	height: auto;
	object-fit: contain;
	align-self: start;
	filter: grayscale(100%);
	opacity: 0.85;
}

/* Impacto */
.about-impact__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: start;
}
.about-impact__intro h2 { color: #fff; margin: var(--space-3) 0; }
.about-impact__intro p  { color: rgba(255,255,255,.88); }
.impact-list {
	list-style: none;
	padding: 0; margin: 0;
	display: grid;
	gap: var(--space-4);
}
.impact-list li {
	padding: var(--space-4) 0;
	border-top: 1px solid rgba(255,255,255,.18);
	display: grid;
	gap: 4px;
	color: rgba(255,255,255,.85);
	font-size: 0.95rem;
}
.impact-list li:first-child { border-top-color: rgba(255,255,255,.4); }
.impact-list strong {
	display: block;
	font-family: var(--ff-display);
	font-size: 1.5rem;
	font-weight: 400;
	color: #fff;
	letter-spacing: var(--ls-tight);
}

.about-cta { padding-block: clamp(3rem, 6vw, 6rem); }
.about-cta h2 { max-width: 22ch; margin-inline: auto; }

/* Responsive de la about */
@media (max-width: 980px) {
	.about-pillars__grid { grid-template-columns: 1fr; }
	.about-pillars__grid .pillar { border-left: 0; border-top: 1px solid var(--c-line); }
	.about-pillars__grid .pillar:first-child { border-top: 0; }
	.about-founder__grid { grid-template-columns: 1fr; }
	.about-founder__media { aspect-ratio: 4 / 3; }
	.about-animals__grid { grid-template-columns: 1fr; }
	.about-impact__grid { grid-template-columns: 1fr; }
}

/* ----------------------------------------------------------------- Page hero (interior pages) */
.page-hero {
	padding-block: clamp(3rem, 6vw, 6rem);
	background: var(--c-off-white);
	text-align: center;
	border-bottom: 1px solid var(--c-line);
}
.page-hero h1 { margin-bottom: var(--space-3); }

/* ----------------------------------------------------------------- 404 */
.error-404 { padding-block: clamp(4rem, 10vw, 8rem); text-align: center; }
.error-404__num { font-family: var(--ff-display); font-size: clamp(5rem, 12vw, 10rem); font-weight: 300; color: var(--c-red); line-height: 1; margin: 0 0 var(--space-3); }

/* ----------------------------------------------------------------- Search form */
.search-form {
	display: flex;
	border-bottom: 1px solid var(--c-line-strong);
	max-width: 420px;
}
.search-form input[type="search"] {
	flex: 1;
	border: 0;
	background: transparent;
	padding: 0.75rem 0;
	font-size: var(--fs-md);
}
.search-form input[type="search"]:focus { outline: 0; }
.search-form button { padding: 0 0.5rem; }

/* ----------------------------------------------------------------- Responsive */
@media (max-width: 980px) {
	.story { grid-template-columns: 1fr; }
	.product-grid { grid-template-columns: repeat(2, 1fr); }
	.posts-grid   { grid-template-columns: repeat(2, 1fr); }
	.values { grid-template-columns: 1fr; }
	.values__item + .values__item { border-left: 0; border-top: 1px solid var(--c-line-strong); }
	.footer__cols { grid-template-columns: repeat(2, 1fr); }
	.woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 1080px) {
	.header__inner {
		grid-template-columns: auto 1fr auto;
		gap: var(--space-3);
	}
	.header__menu-toggle {
		display: inline-grid; place-items: center;
		width: 40px; height: 40px;
		grid-column: 1; justify-self: start;
		margin-left: -8px;
	}
	.brand {
		grid-column: 2;
		justify-self: center;
		text-align: center;
	}
	.brand__link { gap: 0.5rem; }
	.brand__sub { display: none; }
	/* Mostrar overlay y close en móvil */
	.nav-overlay { display: block; }
	.nav__close { display: grid; }

	/* Mobile nav drawer (deslizante desde la izquierda) */
	.nav {
		position: fixed;
		top: 0;
		left: 0;
		bottom: 0;
		width: min(86vw, 360px);
		max-width: 360px;
		z-index: 80;
		background: #fff;
		padding: calc(var(--header-h) + var(--topbar-h) + 1rem) var(--space-5) var(--space-6);
		overflow-y: auto;
		overflow-x: hidden;
		-webkit-overflow-scrolling: touch;
		transform: translateX(-100%);
		transition: transform 0.35s cubic-bezier(.22,.61,.36,1), box-shadow 0.35s var(--ease);
		box-shadow: none;
		visibility: hidden;
		display: block;
		border-top: 0;
	}
	.nav.is-open {
		transform: translateX(0);
		visibility: visible;
		box-shadow: 12px 0 32px rgba(0,0,0,0.15);
	}
	.nav__list {
		flex-direction: column;
		gap: 0;
		white-space: normal;
		padding: 0;
		margin: 0;
	}
	.nav__item {
		border-bottom: 1px solid var(--c-line);
	}
	.nav__item:last-child { border-bottom: 0; }
	.nav__link {
		display: block;
		font-family: var(--ff-display);
		font-size: 1.5rem;
		font-weight: 500;
		color: var(--c-black);
		padding: 1.1rem 0;
		text-decoration: none;
		letter-spacing: 0;
		text-transform: none;
		line-height: 1.2;
		transition: color var(--dur) var(--ease), padding-left var(--dur) var(--ease);
	}
	.nav__link:hover,
	.nav__link:focus-visible {
		color: var(--c-red);
		padding-left: 0.4rem;
	}
	.nav__item.current-menu-item .nav__link,
	.nav__item.current-menu-parent .nav__link {
		color: var(--c-red);
	}

	/* Botón cerrar (X) en el drawer */
	.nav__close {
		position: absolute;
		top: 1.1rem;
		right: 1rem;
		display: grid;
		place-items: center;
		width: 40px; height: 40px;
		background: transparent;
		border: 0;
		color: var(--c-black);
		cursor: pointer;
		transition: color var(--dur) var(--ease);
	}
	.nav__close:hover { color: var(--c-red); }

	/* Animación de entrada de items (cuando el drawer se abre) */
	.nav.is-open .nav__item {
		opacity: 0;
		transform: translateX(-12px);
		animation: hl-nav-slide 0.45s cubic-bezier(.22,.61,.36,1) forwards;
	}
	.nav.is-open .nav__item:nth-child(1) { animation-delay: 0.10s; }
	.nav.is-open .nav__item:nth-child(2) { animation-delay: 0.16s; }
	.nav.is-open .nav__item:nth-child(3) { animation-delay: 0.22s; }
	.nav.is-open .nav__item:nth-child(4) { animation-delay: 0.28s; }
	.nav.is-open .nav__item:nth-child(5) { animation-delay: 0.34s; }
	.nav.is-open .nav__item:nth-child(6) { animation-delay: 0.40s; }
	.nav.is-open .nav__item:nth-child(7) { animation-delay: 0.46s; }
	@keyframes hl-nav-slide {
		to { opacity: 1; transform: translateX(0); }
	}

	/* Overlay oscuro detrás del drawer */
	.nav-overlay {
		position: fixed;
		inset: 0;
		background: rgba(10,10,10,0.5);
		z-index: 70;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.3s var(--ease), visibility 0.3s var(--ease);
	}
	.nav-overlay.is-open {
		opacity: 1;
		visibility: visible;
	}

	/* Hamburguesa: animar a una "X" cuando el drawer está abierto */
	.header__menu-toggle[aria-expanded="true"] svg {
		transform: rotate(90deg);
		transition: transform 0.3s var(--ease);
	}

	.header__actions { gap: var(--space-3); grid-column: 3; }
}

@media (max-width: 720px) {
	:root {
		--header-h: 68px;
		--topbar-h: 32px;
		--gutter: 1rem;
	}
	.header__inner {
		grid-template-columns: auto 1fr auto;
		gap: var(--space-3);
	}
	.topbar { font-size: 0.65rem; letter-spacing: 0.04em; padding-block: 6px; }
	.topbar__inner { gap: 0.6rem; }
	.topbar__left { gap: 0.4rem; min-width: 0; flex: 1 1 auto; }
	.topbar__right { flex: 0 0 auto; gap: var(--space-3); }
	.topbar__msg {
		font-size: 0.62rem;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
		min-width: 0;
		flex: 1 1 auto;
	}
	.topbar__nav { display: none; }

	/* Logo + nombre alineados a la izquierda (al lado de la hamburguesa) */
	.brand {
		grid-column: 2;
		justify-self: start;
		text-align: left;
		min-width: 0;
	}
	.brand__link { gap: 0.45rem; min-width: 0; }
	.brand__logo svg { height: 34px; flex-shrink: 0; }
	.brand__text { min-width: 0; flex: 0 1 auto; }
	.brand__name {
		font-size: 0.92rem;
		font-weight: 500;
		flex-direction: column;
		gap: 1px 0;
	}
	.brand__name-line { display: block; line-height: 1.05; }
	.brand__sub { display: none; }

	/* Iconos a la derecha — quitamos la lupa, dejamos solo cuenta + carrito */
	.header__actions {
		grid-column: 3;
		gap: 0.5rem;
		flex-shrink: 0;
	}
	.header__actions > a:first-child { display: none; } /* búsqueda oculta en móvil */
	.header__icon-btn,
	.header__cart { padding: 6px; }
	.header__icon-btn svg,
	.header__cart svg { width: 20px; height: 20px; }
	.header__cart-count { min-width: 18px; height: 18px; font-size: 0.6rem; padding: 0 4px; }

	.trust__grid { grid-template-columns: 1fr; }
	.trust__item + .trust__item { border-left: 0; border-top: 1px solid var(--c-line); padding-left: 0; padding-top: var(--space-4); }

	.product-grid, .posts-grid { grid-template-columns: 1fr; }
	.footer__cols { grid-template-columns: 1fr; }
	.woocommerce ul.products { grid-template-columns: 1fr !important; }

	.topbar__nav { display: none; }
	.newsletter__form { flex-direction: column; }
	.newsletter__form button { width: 100%; }
}

/* =========================================================================
   RESPONSIVE GLOBAL — refinamientos móvil/tablet de TODAS las páginas.
   (Sumado a las media queries específicas de cada componente arriba.)
   ========================================================================= */

/* ---------- Tablet (≤ 980px) ---------- */
@media (max-width: 980px) {
	/* Hero front-page: el subtítulo y el botón ghost necesitan respirar */
	.hero { min-height: clamp(420px, 65vh, 640px); }
	.hero__title { padding-left: 0.85rem; }
	.hero__title::before { left: 0; width: 2px; }
	.hero__ctas { gap: var(--space-2); }

	/* Story panel sin altura mínima incómoda */
	.story__media { min-height: 280px; }

	/* Páginas estáticas: hero más compacto */
	.page-hero { padding-block: clamp(2.5rem, 5vw, 4rem); }

	/* About page (Nuestra historia) */
	.about-hero { padding-block: clamp(3rem, 5vw, 4.5rem); }
	.about-hero__rule { margin-top: var(--space-5); }

	/* Newsletter */
	.newsletter { padding-block: clamp(2.5rem, 5vw, 4rem); }
}

/* ---------- Móvil grande (≤ 720px) ---------- */
@media (max-width: 720px) {
	/* Tipografía: bajar la escala global para que titulares no desborden */
	h1 { font-size: clamp(1.85rem, 1.2rem + 4vw, 2.4rem); }
	h2 { font-size: clamp(1.55rem, 1.1rem + 2.8vw, 2rem); }
	h3 { font-size: clamp(1.25rem, 1rem + 1.5vw, 1.6rem); }
	.lead { font-size: 1rem; }

	/* Hero portada */
	.hero {
		min-height: clamp(420px, 70vh, 560px);
		text-align: left;
	}
	.hero__inner { padding-block: clamp(3rem, 8vh, 5rem); }
	.hero__subtitle { font-size: 1rem; }
	.hero__ctas { flex-direction: column; align-items: stretch; }
	.hero__ctas .btn { width: 100%; justify-content: center; }

	/* Botones: ancho cómodo en touch */
	.btn { padding: 0.95rem 1.25rem; font-size: 0.75rem; }

	/* Section spacing */
	.section { padding-block: clamp(2.5rem, 8vw, 4rem); }
	.section__head { margin-bottom: var(--space-6); }

	/* Story panel */
	.story__panel { padding: clamp(1.75rem, 6vw, 2.5rem); }

	/* Trust band: vertical alignment */
	.trust__item { padding-block: var(--space-4); }
	.trust__item + .trust__item { padding-top: var(--space-4); }
	.trust__icon { width: 32px; height: 32px; }
	.trust__icon svg { width: 28px; height: 28px; }
	.trust__title { font-size: 1.1rem; }
	.trust__desc { font-size: 0.85rem; }

	/* Pull quote */
	.pull-quote { min-height: 360px; }

	/* Values triptych */
	.values__item { padding: var(--space-6) var(--space-4); }

	/* Newsletter form: input y botón apilados */
	.newsletter__form input[type="email"] { padding: 0.85rem 1rem; font-size: 0.95rem; }
	.newsletter__form button { padding: 0.85rem 1rem; }

	/* About page (Nuestra historia) */
	.about-hero h1 { max-width: 100%; }
	.about-pillars__grid .pillar { padding: var(--space-6) var(--space-4); }
	.about-pillars__grid .pillar h2 { font-size: 1.35rem; }
	.about-founder__panel { padding: 0; }
	.about-quote { padding: var(--space-4); margin-top: var(--space-4); }
	.about-quote p { font-size: 1.05rem; }
	.ani-card { padding: var(--space-5); }
	.ani-card h3 { font-size: 1.4rem; }
	.about-impact { padding: var(--space-8) 0; }
	.impact-list strong { font-size: 1.25rem; }

	/* Shop hero (tienda) */
	.shop-hero { padding-block: clamp(2.5rem, 6vw, 4rem); }
	.shop-toolbar {
		flex-direction: column;
		align-items: stretch;
		gap: var(--space-3);
		text-align: left;
	}
	.woocommerce-ordering select { width: 100%; padding-right: 1.5rem; }

	/* Product cards en móvil */
	.product-card__title { font-size: 1.1rem; line-height: 1.25; }
	.product-card__cat { font-size: 0.65rem; }
	.product-card__price { font-size: 1.1rem; }
	.product-card__cta { font-size: 0.65rem; }

	/* Single product galería: flechas dentro del frame */
	.product-gallery__nav {
		width: 36px; height: 36px;
		background: rgba(255,255,255,.85);
	}
	.product-gallery__nav--prev { left: 0.5rem; }
	.product-gallery__nav--next { right: 0.5rem; }
	.product-gallery__slide { aspect-ratio: 4 / 5; }
	.product-gallery__pagination { margin-top: var(--space-3); }

	/* Single product summary */
	.single-product__summary form.cart {
		flex-direction: column;
		align-items: stretch;
		gap: var(--space-3);
		padding: var(--space-4) 0;
	}
	.single-product__summary form.cart .qty-input {
		width: 100%;
		justify-content: space-between;
	}
	.single-product__summary form.cart .qty-input__num { flex: 1; }
	.single-product__summary form.cart .single_add_to_cart_button {
		width: 100%;
		min-width: 0;
	}
	.product-trust { margin-top: var(--space-4); padding-top: var(--space-4); }
	.product-trust__list li { font-size: 0.875rem; }

	/* Aviso de reserva: que respire en móvil pequeño */
	.product-preorder {
		flex-wrap: wrap;
		font-size: 0.8rem;
		padding: 0.5rem 0.7rem;
	}
	.product-preorder__sep { display: none; }
	.product-preorder__date { width: 100%; padding-left: 1.4rem; margin-top: 2px; }

	/* WooCommerce tabs: scroll horizontal en lugar de wrap */
	.woocommerce-tabs ul.wc-tabs,
	.woocommerce-tabs ul.tabs {
		gap: var(--space-4) !important;
		overflow-x: auto;
		flex-wrap: nowrap;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}
	.woocommerce-tabs ul.wc-tabs::-webkit-scrollbar,
	.woocommerce-tabs ul.tabs::-webkit-scrollbar { display: none; }
	.woocommerce-tabs ul.wc-tabs li,
	.woocommerce-tabs ul.tabs li { flex-shrink: 0; }

	/* Productos relacionados: title más pequeño */
	.related.products > h2,
	.upsells.products > h2 { font-size: 1.5rem; }

	/* Carrito + checkout: tablas se vuelven cards */
	.woocommerce table.shop_table,
	.woocommerce-cart .cart_totals,
	.woocommerce-checkout .woocommerce-checkout-review-order { font-size: 0.95rem; }
	.woocommerce-cart-form__cart-item { display: block; }
	.woocommerce-cart-form__cart-item td {
		display: flex;
		justify-content: space-between;
		gap: var(--space-3);
		border: 0;
		padding: 0.5rem 0;
		text-align: right !important;
	}
	.woocommerce-cart-form__cart-item td.product-thumbnail { justify-content: flex-start; }
	.woocommerce-cart-form__cart-item td::before {
		content: attr(data-title);
		font-size: var(--fs-xs);
		letter-spacing: var(--ls-wide);
		text-transform: uppercase;
		color: var(--c-ink-mute);
	}

	/* Forms WC en móvil: inputs touch-friendly */
	.woocommerce form .form-row input,
	.woocommerce form .form-row select,
	.woocommerce form .form-row textarea {
		font-size: 16px; /* evita zoom en iOS */
		padding: 0.75rem 0.85rem;
	}

	/* Search form en móvil */
	.search-form { max-width: 100%; }

	/* Footer */
	.footer__main { padding-block: clamp(2.5rem, 6vw, 3.5rem); }
	.footer__brand { font-size: 1.25rem; }
	.footer__top-inner { gap: var(--space-3); justify-content: center; }
	.footer__copyright-inner { flex-direction: column; align-items: flex-start; gap: var(--space-3); text-align: left; }
	.footer__copyright .footer__list { flex-wrap: wrap; gap: 0.85rem 1.25rem !important; }

	/* Page hero (interior) */
	.page-hero { padding-block: clamp(2rem, 5vw, 3rem); }

	/* 404 */
	.error-404 { padding-block: clamp(3rem, 8vw, 5rem); }
	.error-404__num { font-size: clamp(4rem, 18vw, 7rem); }

	/* Lightbox: padding más pequeño en móvil */
	.product-lightbox { padding: 0.5rem; }
	.product-lightbox__close { top: 0.5rem; right: 0.5rem; }
}

/* ---------- Móvil pequeño (≤ 480px) ---------- */
@media (max-width: 480px) {
	:root { --gutter: 0.85rem; }

	/* Topbar más compacto */
	.topbar { font-size: 0.6rem; padding-block: 5px; }
	.topbar__msg { font-size: 0.58rem; letter-spacing: 0.03em; }
	.topbar__left .ikurrina-mark { display: none; } /* damos espacio al mensaje */
	.lang-switch a { font-size: 0.62rem; }

	/* Hero: subtítulo se acorta visualmente */
	.hero__subtitle { line-clamp: 3; }

	/* Cards en móvil pequeño: 2 cols pero ajustadas */
	.shop-grid { gap: 0.65rem !important; }
	.product-card__media { aspect-ratio: 1 / 1; }
	.product-card__body { padding: 0.7rem !important; gap: 0.4rem !important; }
	.product-card__title { font-size: 0.95rem; }
	.product-card__price { font-size: 0.95rem; }
	.product-card__cta { font-size: 0.6rem; }
	.product-card__flag { font-size: 0.55rem; padding: 3px 7px; }

	/* Form cart compacto */
	.single-product__summary form.cart .single_add_to_cart_button {
		padding: 0.85rem 1rem !important;
		font-size: 0.7rem !important;
	}

	/* Botones: que no rompan layout */
	.btn { padding: 0.85rem 1rem; font-size: 0.7rem; }
}

/* Asegura que ningún elemento desborde horizontalmente nunca */
*, *::before, *::after { box-sizing: border-box; }
html, body { overflow-x: hidden; max-width: 100%; }
img, video, iframe { max-width: 100%; height: auto; }

/* Tablas en WC: mejor scroll horizontal interno que romper layout */
.woocommerce table {
	max-width: 100%;
	width: 100%;
	border-collapse: collapse;
}
.woocommerce-MyAccount-content table.shop_table,
.woocommerce-MyAccount-content table.account-orders-table {
	display: block;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	white-space: nowrap;
}

/* Formularios: ningún input/select/textarea de WC excede el contenedor */
.woocommerce input,
.woocommerce select,
.woocommerce textarea,
.woocommerce-page input,
.woocommerce-page select,
.woocommerce-page textarea {
	max-width: 100%;
	box-sizing: border-box;
}

/* Polylang form coupon expandido: respeta el ancho */
.checkout_coupon .form-row,
.woocommerce-form-coupon .form-row {
	max-width: 100%;
	min-width: 0;
}
.checkout_coupon .form-row input,
.woocommerce-form-coupon .form-row input {
	min-width: 0;
}

/* Cualquier tabla que aparezca dentro de mi cuenta se vuelve scrolleable
 * en móvil sin romper layout. */
@media (max-width: 720px) {
	.woocommerce-MyAccount-content > * { max-width: 100%; }
	.woocommerce-MyAccount-content table { font-size: 0.875rem; }
	.woocommerce-MyAccount-content table th,
	.woocommerce-MyAccount-content table td { padding: 0.5rem 0.65rem; }

	/* Forms WC con grid form-row-first/last: stack en móvil */
	.woocommerce form .form-row-first,
	.woocommerce form .form-row-last,
	.woocommerce-page form .form-row-first,
	.woocommerce-page form .form-row-last,
	form.woocommerce-checkout .form-row-first,
	form.woocommerce-checkout .form-row-last {
		float: none;
		display: block;
		width: 100%;
		margin-right: 0;
	}

	/* select2 (selectores de país/provincia) ancho 100% */
	.select2-container { max-width: 100% !important; }
	.select2-container--default .select2-selection--single { height: 44px !important; }
	.select2-container--default .select2-selection--single .select2-selection__rendered { line-height: 44px !important; padding-left: 0.85rem !important; }

	/* Cantidad: que quepa con la imagen del producto */
	.qty-input { max-width: 100%; }

	/* Cualquier "wrap" que esté en móvil pequeño: padding lateral garantizado */
	.wrap { padding-inline: var(--gutter); }

	/* Bloques que tienen padding interno: también respetan box-sizing */
	.checkout-section,
	.myaccount-section,
	.checkout-payment,
	.order-details,
	.order-customer__col,
	.myaccount-address,
	.myaccount-stat,
	.myaccount-order { max-width: 100%; }

	/* Address: si la línea es muy larga, romper */
	.myaccount-address__addr,
	.order-customer__col address {
		word-wrap: break-word;
		overflow-wrap: break-word;
	}

	/* Email/teléfono en cards de direcciones */
	.myaccount-address__meta-row dd,
	.order-customer__line {
		word-break: break-all;
	}

	/* Single product summary: en móvil baja el title y precio */
	.single-product__summary form.cart {
		gap: 0.5rem;
	}
	.single-product__summary form.cart .qty-input,
	.single-product__summary form.cart .single_add_to_cart_button {
		width: 100%;
	}
}

/* Móvil pequeño (≤480px): aún más conservador */
@media (max-width: 480px) {
	:root { --gutter: 0.85rem; }
	.wrap { padding-inline: var(--gutter); }

	/* Tablas con WC en móvil pequeño: scroll más explícito */
	.woocommerce-MyAccount-content table.shop_table::after,
	.woocommerce-MyAccount-content table.account-orders-table::after {
		content: "→";
		display: block;
		text-align: right;
		color: var(--c-ink-mute);
		padding: 0.5rem;
	}
}

/* ----------------------------------------------------------------- Envío (checkout / cart)
 * Los métodos de envío viven dentro de la celda <td> de "Envío" en la tabla
 * de totales. Esa tabla tiene tipografía monoespaciada (estilo ticket), así
 * que sobreescribimos para que los métodos se vean con la fuente del cuerpo. */
ul#shipping_method,
.woocommerce-shipping-methods {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: grid;
	gap: 0.5rem;
	font-family: var(--ff-body) !important;
}
ul#shipping_method li,
.woocommerce-shipping-methods li {
	margin: 0 !important;
	background: transparent;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.7rem;
	border: 1px solid var(--c-line);
	background: #fff;
	padding: 0.7rem 0.9rem !important;
	cursor: pointer;
	transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
ul#shipping_method li:hover,
.woocommerce-shipping-methods li:hover {
	border-color: var(--c-red);
	background: #fffafa;
}
/* Variante seleccionada: usamos :has() (todos los navegadores modernos) */
ul#shipping_method li:has(input[type="radio"]:checked),
.woocommerce-shipping-methods li:has(input[type="radio"]:checked) {
	border-color: var(--c-red);
	background: #fff5f5;
	box-shadow: inset 0 0 0 1px var(--c-red);
}

ul#shipping_method li input[type="radio"],
.woocommerce-shipping-methods li input[type="radio"] {
	margin: 0;
	accent-color: var(--c-red);
	flex: 0 0 auto;
}

ul#shipping_method li label,
.woocommerce-shipping-methods li label {
	margin: 0;
	padding: 0;
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.25rem 0.5rem;
	font-family: var(--ff-body);
	font-size: 0.95rem;
	color: var(--c-black);
	cursor: pointer;
	line-height: 1.35;
}
/* Coste a la derecha del nombre. WC mete la cantidad como hijo del label,
 * así que la sacamos al final con margin-left auto. */
ul#shipping_method li label .woocommerce-Price-amount,
.woocommerce-shipping-methods li label .woocommerce-Price-amount {
	margin-left: auto;
	font-family: var(--ff-display);
	font-size: 1.1rem;
	color: var(--c-black);
	font-weight: 600;
	white-space: nowrap;
}

/* Detalle SOLO de Recogida en obrador. Va dentro del <li> tras el label,
 * en una fila nueva (flex-basis 100%), oculto por defecto y visible solo
 * cuando el radio del propio <li> está marcado. */
.hl-method-info {
	flex: 1 0 100%;
	display: none;
	margin: 0.6rem 0 0;
	padding: 0.85rem 1rem;
	background: #FAF6EE;
	border-left: 3px solid var(--c-red);
	font-family: var(--ff-body) !important;
	font-size: 0.9rem;
	line-height: 1.5;
	color: var(--c-ink);
}
ul#shipping_method li:has(input[type="radio"]:checked) .hl-method-info,
.woocommerce-shipping-methods li:has(input[type="radio"]:checked) .hl-method-info {
	display: block;
}
.hl-method-info__title {
	display: block;
	font-family: var(--ff-display);
	font-size: 1.05rem;
	color: var(--c-black);
	margin-bottom: 0.4rem;
	font-weight: 600;
}
.hl-method-info p { margin: 0 0 0.45rem; }
.hl-method-info p:last-child { margin-bottom: 0; }
.hl-method-info__label {
	font-weight: 600;
	font-size: 0.78rem;
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	color: var(--c-black);
	margin-right: 0.3rem;
}
.hl-method-info__row { color: var(--c-ink-mute); }
.hl-method-info__hint {
	color: var(--c-ink-mute);
	font-style: italic;
	font-size: 0.85rem;
}


/* ----------------------------------------------------------------- Contacto */
.contact-hero {
	background: var(--c-off-white);
	padding-block: clamp(3.5rem, 6vw, 6rem);
	border-bottom: 1px solid var(--c-line);
	text-align: center;
}
.contact-hero h1 {
	margin: var(--space-3) 0 var(--space-4);
}
.contact-hero .lead {
	max-width: 640px;
	margin-inline: auto;
}
.contact-hero__rule {
	width: 60px; height: 2px;
	background: var(--c-red);
	margin: var(--space-5) auto 0;
}

.contact-grid { padding-block: clamp(3rem, 5vw, 5rem); }
.contact-grid__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: start;
}

/* Sidebar info */
.contact-info { display: grid; gap: var(--space-6); }
.contact-info__block {
	padding-bottom: var(--space-5);
	border-bottom: 1px solid var(--c-line);
}
.contact-info__block:last-child { border-bottom: 0; padding-bottom: 0; }
.contact-info__block .eyebrow {
	display: block;
	margin-bottom: var(--space-3);
}
.contact-info__block h2 {
	font-family: var(--ff-display);
	font-size: 1.6rem;
	font-weight: 400;
	color: var(--c-black);
	margin: 0 0 var(--space-2);
}
.contact-info__block p { margin: 0; color: var(--c-ink-mute); }
.contact-info__big {
	display: inline-block;
	font-family: var(--ff-display);
	font-size: 1.4rem;
	color: var(--c-black);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.contact-info__big:hover { color: var(--c-red); border-bottom-color: var(--c-red); }
.contact-info__hint {
	font-size: var(--fs-xs);
	color: var(--c-ink-mute);
	margin-top: 0.35rem;
}
.contact-info__list {
	list-style: none;
	padding: 0; margin: 0;
	display: grid;
	gap: 0.5rem;
}
.contact-info__list li {
	position: relative;
	padding-left: 1.1rem;
	color: var(--c-ink);
	font-size: 0.95rem;
}
.contact-info__list li::before {
	content: "—";
	position: absolute;
	left: 0;
	color: var(--c-red);
}

/* Formulario */
.contact-form-wrap {
	background: #fff;
	border: 1px solid var(--c-line-strong);
	padding: clamp(1.75rem, 3vw, 2.5rem);
}
.contact-form-wrap__head {
	margin-bottom: var(--space-5);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--c-line);
}
.contact-form-wrap__head .eyebrow {
	display: block;
	margin-bottom: var(--space-2);
}
.contact-form-wrap__head h2 {
	font-family: var(--ff-display);
	font-size: clamp(1.6rem, 2.5vw, 2rem);
	font-weight: 400;
	margin: 0;
}

.contact-form { display: grid; gap: var(--space-4); }
.contact-form__row { display: grid; gap: var(--space-4); }
.contact-form__row--2 { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }

.contact-form__field { display: grid; gap: 0.4rem; min-width: 0; }
.contact-form__field > span {
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	color: var(--c-black);
}
.contact-form__field > span em {
	color: var(--c-red);
	font-style: normal;
	margin-left: 0.15rem;
}
.contact-form__field input,
.contact-form__field textarea {
	width: 100%;
	border: 1px solid var(--c-line-strong);
	background: #fff;
	color: var(--c-black);
	font: inherit;
	font-size: 1rem;
	padding: 0.75rem 0.9rem;
	border-radius: 0;
	transition: border-color var(--dur) var(--ease);
}
.contact-form__field textarea {
	resize: vertical;
	min-height: 140px;
	line-height: 1.5;
}
.contact-form__field input:focus,
.contact-form__field textarea:focus {
	outline: 0;
	border-color: var(--c-red);
}
.contact-form__field.has-error input,
.contact-form__field.has-error textarea {
	border-color: var(--c-red);
	background: #fff7f7;
}
.contact-form__hp {
	position: absolute !important;
	left: -9999px;
	width: 1px; height: 1px;
	overflow: hidden;
}

.contact-form__legal {
	font-size: var(--fs-xs);
	color: var(--c-ink-mute);
	margin: 0;
	line-height: 1.5;
}
.contact-form__actions {
	display: flex;
	justify-content: flex-end;
	margin-top: var(--space-2);
}
.contact-form__actions .btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

/* Alerts */
.contact-alert {
	padding: 1rem 1.1rem;
	margin-bottom: var(--space-5);
	border-left: 4px solid;
	background: #fff;
}
.contact-alert strong { display: block; margin-bottom: 0.25rem; }
.contact-alert p { margin: 0; color: var(--c-ink-mute); font-size: 0.95rem; }
.contact-alert--ok {
	border-color: var(--c-green);
	background: #f3f9f4;
}
.contact-alert--ok strong { color: var(--c-green); }
.contact-alert--err {
	border-color: var(--c-red);
	background: #fff5f5;
}
.contact-alert--err strong { color: var(--c-red); }

/* Mobile */
@media (max-width: 860px) {
	.contact-grid__inner { grid-template-columns: 1fr; gap: var(--space-7); }
	.contact-info { order: 2; }
	.contact-form-wrap { order: 1; }
}
@media (max-width: 560px) {
	.contact-form__row--2 { grid-template-columns: 1fr; }
	.contact-form__actions { justify-content: stretch; }
	.contact-form__actions .btn { width: 100%; justify-content: center; }
}

/* ----------------------------------------------------------------- Instagram */
.ig-section__head {
	text-align: center;
	margin-bottom: var(--space-7);
}
.ig-section__head h2 {
	font-family: var(--ff-display);
	font-size: clamp(1.8rem, 4vw, 2.6rem);
	font-weight: 500;
	margin: var(--space-3) 0 var(--space-3);
}
.ig-section__head .lead {
	max-width: 540px;
	margin-inline: auto;
	color: var(--c-ink-soft);
}
.ig-section__head .lead a {
	color: var(--c-red);
	text-decoration: none;
	border-bottom: 1px solid var(--c-red);
}

.ig-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-4);
	max-width: 1100px;
	margin: 0 auto;
	align-items: start; /* cada card toma su altura natural */
}
.ig-card {
	background: var(--c-stone);
	min-width: 0;
	min-height: 720px; /* reels son verticales 9:16, ~720-820px tras procesar */
	display: flex;
	flex-direction: column;
}
/* El <blockquote> que pone Instagram antes de procesar.
 * embed.js lo reemplaza por un <iframe>. */
.ig-card .instagram-media {
	border: 1px solid var(--c-line) !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	min-width: 0 !important;
	max-width: 100% !important;
	margin: 0 !important;
	width: 100% !important;
	flex: 1 1 auto;
	background: #fff;
}
/* El iframe inyectado por Instagram tras procesar el embed.
 * IG le pone height inline; lo respetamos. Solo ajustamos width + borde. */
.ig-card iframe {
	width: 100% !important;
	max-width: 100% !important;
	min-width: 0 !important;
	border: 1px solid var(--c-line) !important;
	display: block;
	background: #fff;
}

.ig-section__cta {
	text-align: center;
	margin-top: var(--space-7);
}
.ig-section__cta .btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

/* Mobile */
@media (max-width: 900px) {
	.ig-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-3); }
}
@media (max-width: 560px) {
	.ig-grid { grid-template-columns: 1fr; }
	.ig-card { max-width: 380px; margin: 0 auto; }
}

/* ----------------------------------------------------------------- FAQ */
.faq-hero {
	background: var(--c-off-white);
	padding-block: clamp(3rem, 6vw, 5rem);
	border-bottom: 1px solid var(--c-line);
	text-align: center;
}
.faq-hero h1 { margin: var(--space-3) 0 var(--space-3); }
.faq-hero .lead { max-width: 620px; margin-inline: auto; }
.faq-hero__rule {
	width: 60px; height: 2px;
	background: var(--c-red);
	margin: var(--space-5) auto 0;
}

.faq-list {
	list-style: none;
	margin: 0; padding: 0;
	display: grid;
	gap: var(--space-3);
}
.faq-item {
	background: #fff;
	border: 1px solid var(--c-line-strong);
	overflow: hidden;
	transition: border-color var(--dur) var(--ease);
}
.faq-item.is-open { border-color: var(--c-red); }

.faq-item__head {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	width: 100%;
	padding: var(--space-4) var(--space-5);
	background: transparent;
	border: 0;
	cursor: pointer;
	text-align: left;
	font: inherit;
	color: var(--c-black);
	transition: background var(--dur) var(--ease);
}
.faq-item__head:hover { background: var(--c-off-white); }
.faq-item.is-open .faq-item__head { background: var(--c-off-white); }

.faq-item__num {
	font-family: var(--ff-display);
	font-size: 1.4rem;
	font-weight: 500;
	color: var(--c-red);
	flex: 0 0 auto;
	min-width: 2.5rem;
}
.faq-item__q {
	flex: 1;
	font-family: var(--ff-display);
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 1.3;
	color: var(--c-black);
	min-width: 0;
}
.faq-item__plus {
	flex: 0 0 auto;
	color: var(--c-ink-mute);
	transition: color var(--dur) var(--ease);
}
.faq-item.is-open .faq-item__plus { color: var(--c-red); }
.faq-item__plus-v {
	transition: transform 0.3s var(--ease);
	transform-origin: center;
}
.faq-item.is-open .faq-item__plus-v {
	transform: scaleY(0);
}

.faq-item__body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.4s cubic-bezier(.22,.61,.36,1);
}
.faq-item.is-open .faq-item__body {
	max-height: 1200px;
}
.faq-item__answer {
	padding: 0 var(--space-5) var(--space-5);
	color: var(--c-ink);
	font-size: 0.98rem;
	line-height: 1.65;
}
.faq-item__answer p { margin: 0 0 var(--space-3); }
.faq-item__answer p:last-child { margin-bottom: 0; }
.faq-item__answer ul,
.faq-item__answer ol { margin: 0 0 var(--space-3); padding-left: 1.4rem; }
.faq-item__answer li { margin-bottom: 0.4rem; }
.faq-item__answer strong { color: var(--c-black); }

.faq-cta {
	margin-top: var(--space-10);
	padding: var(--space-7) var(--space-5);
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	text-align: center;
}
.faq-cta h2 {
	font-family: var(--ff-display);
	font-size: clamp(1.6rem, 3vw, 2rem);
	font-weight: 500;
	margin: var(--space-3) 0;
}
.faq-cta p {
	color: var(--c-ink-soft);
	margin: 0 auto var(--space-5);
	max-width: 480px;
}
.faq-cta .btn { display: inline-flex; align-items: center; gap: 0.5rem; }

/* Móvil */
@media (max-width: 600px) {
	.faq-item__head { padding: var(--space-3) var(--space-4); gap: var(--space-3); }
	.faq-item__num { font-size: 1.2rem; min-width: 2rem; }
	.faq-item__q { font-size: 1rem; }
	.faq-item__answer { padding: 0 var(--space-4) var(--space-4); font-size: 0.95rem; }
	.faq-cta { padding: var(--space-5) var(--space-4); }
}

/* ----------------------------------------------------------------- Header search */
.header-search {
	background: var(--c-off-white);
	border-bottom: 1px solid var(--c-line);
	border-top: 1px solid var(--c-line);
	padding-block: 0;
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transform: translateY(-6px);
	transition: max-height 0.3s var(--ease), opacity 0.25s var(--ease), transform 0.25s var(--ease), padding-block 0.3s var(--ease);
}
.header-search.is-open {
	max-height: 200px;
	opacity: 1;
	transform: translateY(0);
	padding-block: 0.85rem;
}
.header-search__form {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	background: #fff;
	border: 1px solid var(--c-line-strong);
	padding: 0.45rem 0.75rem;
	transition: border-color var(--dur) var(--ease);
}
.header-search__form:focus-within {
	border-color: var(--c-red);
}
.header-search__icon {
	color: var(--c-ink-mute);
	flex: 0 0 auto;
}
.header-search__form input[type="search"] {
	flex: 1 1 auto;
	border: 0;
	outline: 0;
	background: transparent;
	font-family: var(--ff-body);
	font-size: 1rem;
	padding: 0.4rem 0;
	color: var(--c-black);
	min-width: 0;
}
.header-search__form input[type="search"]::placeholder { color: var(--c-ink-mute); }
.header-search__form input[type="search"]::-webkit-search-cancel-button { display: none; }
.header-search__submit {
	background: var(--c-red);
	color: #fff;
	border: 0;
	padding: 0.55rem 1rem;
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	cursor: pointer;
	white-space: nowrap;
	transition: background var(--dur) var(--ease);
	flex: 0 0 auto;
}
.header-search__submit:hover { background: var(--c-red-deep); }
.header-search__close {
	background: transparent;
	border: 0;
	color: var(--c-ink-mute);
	cursor: pointer;
	padding: 0.4rem;
	display: grid;
	place-items: center;
	flex: 0 0 auto;
	transition: color var(--dur) var(--ease);
}
.header-search__close:hover { color: var(--c-black); }

/* Botón lupa cuando el panel está abierto */
.header__search-toggle.is-active {
	color: var(--c-red);
}

/* Móvil: el botón "Buscar" se oculta y el botón close se queda */
@media (max-width: 560px) {
	.header-search__form { padding: 0.4rem 0.5rem; gap: 0.4rem; }
	.header-search__form input[type="search"] { font-size: 16px; padding: 0.35rem 0; } /* 16px evita zoom en iOS */
	.header-search__submit { display: none; }
	.header-search.is-open { padding-block: 0.6rem; }
}

/* ----------------------------------------------------------------- Blog */

/* Barra de progreso de lectura */
.blog-progress {
	position: fixed;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: transparent;
	z-index: 200;
	pointer-events: none;
}
.blog-progress__bar {
	display: block;
	height: 100%;
	width: 0%;
	background: var(--c-red);
	transition: width 0.08s linear;
}

/* Hero del listado */
.blog-archive__hero {
	background: var(--c-off-white);
	padding-block: clamp(3rem, 6vw, 6rem);
	border-bottom: 1px solid var(--c-line);
	text-align: center;
}
.blog-archive__hero h1 {
	margin: var(--space-3) 0 var(--space-3);
}
.blog-archive__hero .lead {
	max-width: 620px;
	margin-inline: auto;
}
.blog-archive__rule {
	width: 60px; height: 2px;
	background: var(--c-red);
	margin: var(--space-5) auto 0;
}

/* Filtros de categoría */
.blog-filters {
	background: #fff;
	border-bottom: 1px solid var(--c-line);
	padding-block: var(--space-4);
}
.blog-filters__list {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: center;
}
.blog-filters__chip {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 0.95rem;
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	color: var(--c-ink);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-decoration: none;
	transition: all var(--dur) var(--ease);
}
.blog-filters__chip:hover {
	background: #fff;
	border-color: var(--c-red);
	color: var(--c-red);
}
.blog-filters__chip.is-active {
	background: var(--c-red);
	border-color: var(--c-red);
	color: #fff;
}
.blog-filters__count {
	display: inline-grid;
	place-items: center;
	min-width: 22px; height: 22px;
	border-radius: 50%;
	background: rgba(0,0,0,0.06);
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0;
	padding: 0 0.4rem;
}
.blog-filters__chip.is-active .blog-filters__count {
	background: rgba(255,255,255,0.18);
	color: #fff;
}

/* Featured post (post destacado en home del blog) */
.blog-archive__featured {
	padding-block: clamp(3rem, 5vw, 5rem) 0;
}
.blog-feature {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
	background: #fff;
	border: 1px solid var(--c-line);
}
.blog-feature__media {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--c-stone);
}
.blog-feature__media img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform 600ms var(--ease);
}
.blog-feature__media:hover img { transform: scale(1.03); }
.blog-feature__pill {
	position: absolute;
	top: var(--space-4);
	left: var(--space-4);
	background: var(--c-red);
	color: #fff;
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 6px 12px;
}
.blog-feature__body {
	padding: clamp(1.5rem, 3vw, 2.5rem);
}
.blog-feature__title {
	font-family: var(--ff-display);
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	font-weight: 500;
	line-height: 1.15;
	margin: var(--space-3) 0 var(--space-3);
	color: var(--c-black);
}
.blog-feature__title a {
	color: inherit;
	text-decoration: none;
	background-image: linear-gradient(var(--c-red), var(--c-red));
	background-size: 0 1px;
	background-position: 0 100%;
	background-repeat: no-repeat;
	transition: background-size 0.4s var(--ease);
}
.blog-feature__title a:hover { background-size: 100% 1px; }
.blog-feature__excerpt {
	color: var(--c-ink-soft);
	font-size: 1rem;
	line-height: 1.6;
	margin: 0 0 var(--space-4);
}
.blog-feature__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-top: var(--space-3);
	color: var(--c-red);
	font-weight: 600;
	font-size: var(--fs-xs);
	letter-spacing: var(--ls-wider);
	text-transform: uppercase;
	border-bottom: 1px solid var(--c-red);
	padding-bottom: 2px;
	text-decoration: none;
	transition: gap var(--dur) var(--ease);
}
.blog-feature__cta:hover { gap: 0.8rem; }

/* Grid de cards del listado */
.blog-archive__grid-wrap {
	padding-block: clamp(2.5rem, 5vw, 5rem);
}
.blog-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(2rem, 4vw, 3rem) clamp(1.5rem, 3vw, 2.5rem);
}
.blog-card {
	display: flex;
	flex-direction: column;
	background: transparent;
}
.blog-card__media {
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--c-stone);
	margin-bottom: var(--space-4);
}
.blog-card__media img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform 600ms var(--ease);
}
.blog-card__media:hover img { transform: scale(1.03); }

.blog-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.blog-card__cat {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--c-red);
	margin-bottom: var(--space-2);
}
.blog-card__title {
	font-family: var(--ff-display);
	font-size: clamp(1.15rem, 1.4vw, 1.4rem);
	font-weight: 500;
	line-height: 1.2;
	margin: 0;
	color: var(--c-black);
}
.blog-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--dur) var(--ease);
}
.blog-card__title a:hover { color: var(--c-red); }
.blog-card__excerpt {
	font-size: 0.92rem;
	line-height: 1.6;
	color: var(--c-ink-soft);
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
a.blog-card__cat {
	text-decoration: none;
	transition: color var(--dur) var(--ease);
}
a.blog-card__cat:hover { color: var(--c-red-deep); }
.blog-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	font-size: var(--fs-xs);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.blog-card__sep { color: var(--c-line-strong); }

/* Paginación */
.blog-pagination {
	margin-top: var(--space-10);
	display: flex;
	justify-content: center;
	gap: 0.4rem;
	flex-wrap: wrap;
}
.blog-pagination .page-numbers {
	display: inline-grid;
	place-items: center;
	min-width: 44px;
	height: 44px;
	padding: 0 0.85rem;
	border: 1px solid var(--c-line-strong);
	background: #fff;
	color: var(--c-black);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	text-decoration: none;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.blog-pagination .page-numbers:hover,
.blog-pagination .page-numbers.current {
	background: var(--c-black);
	color: #fff;
	border-color: var(--c-black);
}

/* CTA común reutilizable */
.blog-cta {
	text-align: center;
	padding-block: clamp(2.5rem, 4vw, 3.5rem);
}
.blog-cta h2 {
	font-family: var(--ff-display);
	font-size: clamp(1.6rem, 3.5vw, 2.4rem);
	font-weight: 500;
	margin: var(--space-3) 0 var(--space-3);
}
.blog-cta p {
	max-width: 540px;
	margin: 0 auto var(--space-5);
	color: var(--c-ink-soft);
	font-size: 1rem;
	line-height: 1.6;
}
.blog-cta .btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

/* ============== Single post ============== */

.blog-single { padding-bottom: 0; }

.blog-single__hero {
	padding-block: clamp(2.5rem, 5vw, 4.5rem) 0;
	text-align: center;
	background: var(--c-off-white);
}

/* Breadcrumbs */
.blog-single__crumbs {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.5rem;
	font-size: 0.78rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: var(--space-5);
}
.blog-single__crumbs a {
	color: var(--c-ink-mute);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: all var(--dur) var(--ease);
}
.blog-single__crumbs a:hover { color: var(--c-red); border-color: var(--c-red); }
.blog-single__crumbs span { color: var(--c-line-strong); }

.blog-single__cat {
	display: inline-block;
	margin-bottom: var(--space-3);
	text-decoration: none;
}
.blog-single__title {
	font-family: var(--ff-display);
	font-size: clamp(1.9rem, 4.5vw, 3.4rem);
	font-weight: 500;
	line-height: 1.1;
	color: var(--c-black);
	max-width: 22ch;
	margin: var(--space-3) auto var(--space-4);
}
.blog-single__lead {
	max-width: 56ch;
	margin: 0 auto var(--space-5);
	font-family: var(--ff-display);
	font-size: clamp(1.05rem, 1.8vw, 1.25rem);
	font-weight: 400;
	font-style: italic;
	color: var(--c-ink-soft);
	line-height: 1.45;
}
.blog-single__meta {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.6rem;
	font-size: var(--fs-xs);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.blog-single__meta strong { color: var(--c-black); font-weight: 600; }
.blog-single__avatar {
	display: grid;
	place-items: center;
	width: 28px; height: 28px;
	border-radius: 50%;
	background: var(--c-red);
	color: #fff;
	font-family: var(--ff-display);
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0;
}
.blog-single__rule {
	width: 80px; height: 2px;
	background: var(--c-red);
	margin: var(--space-6) auto 0;
}
.blog-single__cover {
	margin: clamp(2rem, 4vw, 3rem) 0 0;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: var(--gutter);
}
.blog-single__cover img {
	width: 100%;
	height: auto;
	max-height: 60vh;
	object-fit: cover;
	display: block;
}
.blog-single__cover figcaption {
	font-size: var(--fs-xs);
	color: var(--c-ink-mute);
	text-align: center;
	margin-top: var(--space-3);
	font-style: italic;
}

/* Cuerpo del artículo: layout 2 columnas (TOC sticky + main) */
.blog-single__article { padding-block: clamp(3rem, 6vw, 5rem); }
.blog-single__layout {
	display: grid;
	grid-template-columns: 240px minmax(0, 720px);
	gap: clamp(2.5rem, 6vw, 5rem);
	justify-content: center;
	align-items: start;
}
.blog-single__sidebar { min-width: 0; }
.blog-single__sidebar-inner {
	position: sticky;
	top: calc(var(--header-h) + var(--topbar-h) + 2rem);
	display: grid;
	gap: var(--space-6);
}
.blog-single__main { min-width: 0; max-width: 720px; }

/* TOC */
.blog-toc { display: grid; gap: var(--space-3); }
.blog-toc .eyebrow { display: block; }
.blog-toc__list {
	list-style: none;
	padding: 0; margin: 0;
	display: grid;
	gap: 0.45rem;
	border-left: 1px solid var(--c-line);
}
.blog-toc__item a {
	display: block;
	padding: 0.35rem 0.85rem;
	color: var(--c-ink-mute);
	font-size: 0.88rem;
	line-height: 1.4;
	text-decoration: none;
	border-left: 2px solid transparent;
	margin-left: -1px;
	transition: all var(--dur) var(--ease);
}
.blog-toc__item.is-sub a { padding-left: 1.7rem; font-size: 0.82rem; }
.blog-toc__item a:hover { color: var(--c-black); }
.blog-toc__item a.is-active {
	color: var(--c-red);
	border-color: var(--c-red);
	font-weight: 600;
}

/* Compartir lateral */
.blog-share-side { display: grid; gap: var(--space-3); }
.blog-share-side__links {
	display: flex;
	gap: 0.4rem;
}
.blog-share-side .share-btn { width: 34px; height: 34px; }
.blog-single__content {
	color: var(--c-ink);
	font-family: var(--ff-body);
	font-size: 1.05rem;
	line-height: 1.75;
}
.blog-single__content p { margin: 0 0 var(--space-4); }

/* Drop cap en el primer párrafo */
.blog-single__content > p:first-of-type::first-letter {
	float: left;
	font-family: var(--ff-display);
	font-size: 4.5rem;
	line-height: 0.85;
	font-weight: 500;
	color: var(--c-red);
	margin: 0.4rem 0.6rem 0 0;
}

.blog-single__content h2,
.blog-single__content h3,
.blog-single__content h4 {
	font-family: var(--ff-display);
	font-weight: 500;
	color: var(--c-black);
	line-height: 1.2;
}
.blog-single__content h2 {
	font-size: clamp(1.6rem, 3vw, 2rem);
	margin: var(--space-8) 0 var(--space-4);
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--c-line);
}
.blog-single__content h3 {
	font-size: clamp(1.3rem, 2.4vw, 1.6rem);
	margin: var(--space-6) 0 var(--space-3);
}
.blog-single__content h4 {
	font-size: 1.2rem;
	margin: var(--space-5) 0 var(--space-3);
}
.blog-single__content ul,
.blog-single__content ol {
	margin: 0 0 var(--space-4);
	padding-left: 1.5rem;
}
.blog-single__content ul li,
.blog-single__content ol li {
	margin-bottom: 0.4rem;
	line-height: 1.65;
}
.blog-single__content blockquote {
	border-left: 3px solid var(--c-red);
	padding: var(--space-3) 0 var(--space-3) var(--space-5);
	margin: var(--space-6) 0;
	font-family: var(--ff-display);
	font-size: 1.4rem;
	font-style: italic;
	line-height: 1.4;
	color: var(--c-black);
}
.blog-single__content a {
	color: var(--c-red);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	transition: color var(--dur) var(--ease);
}
.blog-single__content a:hover { color: var(--c-red-deep); }
.blog-single__content img {
	max-width: 100%;
	height: auto;
	margin: var(--space-5) 0;
}
.blog-single__content figure { margin: var(--space-6) 0; }
.blog-single__content figcaption {
	font-size: var(--fs-xs);
	color: var(--c-ink-mute);
	font-style: italic;
	text-align: center;
	margin-top: var(--space-2);
}
.blog-single__content strong { color: var(--c-black); font-weight: 600; }

/* Tags */
.blog-single__tags {
	margin-top: var(--space-8);
	padding-top: var(--space-5);
	border-top: 1px solid var(--c-line);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.blog-single__tags ul {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.blog-single__tags a {
	display: inline-block;
	padding: 0.3rem 0.7rem;
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
	color: var(--c-ink);
	font-size: var(--fs-xs);
	text-decoration: none;
	transition: background var(--dur) var(--ease);
}
.blog-single__tags a:hover { background: var(--c-stone); }

/* Botón share genérico (reusado en sidebar) */
.share-btn {
	display: grid;
	place-items: center;
	width: 38px; height: 38px;
	background: transparent;
	border: 1px solid var(--c-line-strong);
	color: var(--c-black);
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.share-btn:hover {
	background: var(--c-red);
	border-color: var(--c-red);
	color: #fff;
}

/* Bio del autor al final del artículo */
.blog-single__author-bio {
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: var(--space-4);
	align-items: start;
	margin-top: var(--space-7);
	padding: var(--space-5);
	background: var(--c-off-white);
	border: 1px solid var(--c-line);
}
.blog-single__author-bio-avatar {
	display: grid;
	place-items: center;
	width: 64px; height: 64px;
	border-radius: 50%;
	background: var(--c-red);
	color: #fff;
	font-family: var(--ff-display);
	font-size: 1.6rem;
	font-weight: 500;
}
.blog-single__author-bio .eyebrow { display: block; margin-bottom: 0.4rem; }
.blog-single__author-bio h3 {
	font-family: var(--ff-display);
	font-size: 1.4rem;
	font-weight: 500;
	margin: 0 0 var(--space-2);
	color: var(--c-black);
}
.blog-single__author-bio p {
	margin: 0;
	color: var(--c-ink-soft);
	font-size: 0.95rem;
	line-height: 1.6;
}

/* Navegación prev/next */
.blog-single__nav {
	margin-top: var(--space-7);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-4);
}
.blog-single__nav-item {
	display: grid;
	gap: 0.4rem;
	padding: var(--space-4) var(--space-5);
	background: #fff;
	border: 1px solid var(--c-line-strong);
	color: var(--c-black);
	text-decoration: none;
	transition: all var(--dur) var(--ease);
}
.blog-single__nav-item:hover {
	border-color: var(--c-red);
	background: #fffafa;
}
.blog-single__nav-item--next { text-align: right; }
.blog-single__nav-item .eyebrow {
	color: var(--c-red);
	font-size: 0.7rem;
}
.blog-single__nav-title {
	font-family: var(--ff-display);
	font-size: 1.05rem;
	font-weight: 500;
	line-height: 1.3;
	color: var(--c-black);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Posts relacionados */
.blog-single__related {
	margin-top: 0;
}
.blog-single__related-head {
	text-align: center;
	margin-bottom: var(--space-7);
}
.blog-single__related-head h2 {
	font-family: var(--ff-display);
	font-size: clamp(1.6rem, 3vw, 2rem);
	font-weight: 500;
	margin: var(--space-3) 0 0;
	color: var(--c-black);
}

/* ============== Responsive blog ============== */

/* Tablet horizontal: TOC sigue visible pero más estrecho */
@media (max-width: 1100px) {
	.blog-single__layout {
		grid-template-columns: 200px minmax(0, 720px);
		gap: var(--space-6);
	}
	.blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* Tablet: ocultamos sidebar TOC, todo en columna */
@media (max-width: 900px) {
	.blog-single__layout {
		grid-template-columns: 1fr;
		gap: 0;
	}
	.blog-single__sidebar {
		order: 2;
		margin-top: var(--space-6);
		padding-top: var(--space-5);
		border-top: 1px solid var(--c-line);
	}
	.blog-single__sidebar-inner {
		position: static;
		grid-template-columns: 1fr 1fr;
		gap: var(--space-5);
		display: grid;
	}
	.blog-single__main { order: 1; max-width: none; }

	/* Featured: imagen arriba, texto abajo */
	.blog-feature { grid-template-columns: 1fr; }
	.blog-feature__media { aspect-ratio: 16 / 9; }
}

@media (max-width: 700px) {
	.blog-single__sidebar-inner { grid-template-columns: 1fr; gap: var(--space-4); }
}

/* Móvil */
@media (max-width: 600px) {
	.blog-grid { grid-template-columns: 1fr; gap: var(--space-5); }

	.blog-archive__hero { padding-block: clamp(2.5rem, 7vw, 4rem); }

	.blog-filters { padding-block: var(--space-3); }
	.blog-filters__list { justify-content: flex-start; flex-wrap: nowrap; overflow-x: auto; padding: 0 var(--gutter); margin: 0 calc(-1 * var(--gutter)); -webkit-overflow-scrolling: touch; }
	.blog-filters__list::-webkit-scrollbar { display: none; }
	.blog-filters__chip { flex: 0 0 auto; padding: 0.4rem 0.75rem; font-size: 0.7rem; }
	.blog-filters__count { min-width: 18px; height: 18px; font-size: 0.65rem; }

	.blog-feature__body { padding: var(--space-5) var(--space-4); }
	.blog-feature__title { font-size: clamp(1.4rem, 5.5vw, 1.9rem); }
	.blog-feature__excerpt { font-size: 0.95rem; }

	.blog-card__media { aspect-ratio: 16 / 10; margin-bottom: var(--space-3); }
	.blog-card__title { font-size: 1.15rem; }

	.blog-single__crumbs { font-size: 0.7rem; gap: 0.35rem; }
	.blog-single__title { font-size: clamp(1.6rem, 7vw, 2.2rem); margin-block: var(--space-3) var(--space-3); }
	.blog-single__lead { font-size: 1rem; }
	.blog-single__meta { font-size: 0.7rem; gap: 0.4rem; }
	.blog-single__avatar { width: 24px; height: 24px; font-size: 0.75rem; }
	.blog-single__rule { margin-top: var(--space-5); }
	.blog-single__cover { padding-inline: 0; }
	.blog-single__cover img { max-height: 50vh; }

	.blog-single__article { padding-block: clamp(2rem, 5vw, 3rem); }
	.blog-single__content { font-size: 1rem; line-height: 1.7; }
	.blog-single__content > p:first-of-type::first-letter { font-size: 3.2rem; }
	.blog-single__content blockquote {
		font-size: 1.1rem;
		padding-left: var(--space-4);
		margin-block: var(--space-5);
	}
	.blog-single__content h2 { font-size: 1.4rem; margin-top: var(--space-6); }
	.blog-single__content h3 { font-size: 1.2rem; }

	.blog-single__author-bio {
		grid-template-columns: 1fr;
		text-align: center;
		gap: var(--space-3);
		padding: var(--space-4);
	}
	.blog-single__author-bio-avatar {
		margin: 0 auto;
		width: 56px; height: 56px;
		font-size: 1.4rem;
	}

	.blog-single__nav { grid-template-columns: 1fr; gap: var(--space-3); }
	.blog-single__nav-item { padding: var(--space-3) var(--space-4); }
	.blog-single__nav-item--next { text-align: left; }

	.blog-single__related-head { margin-bottom: var(--space-5); }

	.blog-pagination .page-numbers { min-width: 36px; height: 36px; padding: 0 0.6rem; font-size: 0.7rem; }
	.blog-pagination .prev,
	.blog-pagination .next { padding: 0 0.85rem; }
}

/* Móvil pequeño */
@media (max-width: 380px) {
	.blog-archive__hero h1 { font-size: clamp(1.7rem, 9vw, 2.2rem); }
	.blog-feature__cta { font-size: 0.7rem; }
	.blog-cta h2 { font-size: 1.5rem; }
	.blog-toc__item a { font-size: 0.85rem; }
}

