/* ============================================================
   LTS Child — CSS de paritat amb el disseny actual (markup de blocs).
   Valors del header presos dels estils computats reals del live (post-30).
   ============================================================ */

:root {
	--lts-principal: var(--wp--preset--color--principal);
	--lts-secundario: var(--wp--preset--color--secundario);
	--lts-texto: var(--wp--preset--color--texto);
	--lts-acento: var(--wp--preset--color--acento);
	--lts-fondo-claro: var(--wp--preset--color--fondo-claro);
	--lts-fondo-oscuro: var(--wp--preset--color--fondo-oscuro);
	--lts-header-h: 90px;
}

/* ───────────────────────── FOCUS GLOBAL ─────────────────────────
   Sense quadre de focus amb ratolí (clic) a cap enllaç/botó/camp;
   per teclat sí, vora accent neta (accessibilitat). Cobreix tot el front
   (logo, menú, enllaços de contingut, navegació de compte WooCommerce, etc.). */
a:focus:not(:focus-visible),
button:focus:not(:focus-visible),
input:focus:not(:focus-visible),
select:focus:not(:focus-visible),
textarea:focus:not(:focus-visible),
[tabindex]:focus:not(:focus-visible),
.wp-block-button__link:focus:not(:focus-visible),
.wp-element-button:focus:not(:focus-visible) {
	outline: none;
	box-shadow: none;
}
a:focus-visible,
button:focus-visible,
.wp-block-button__link:focus-visible,
.wp-element-button:focus-visible {
	outline: 2px solid var(--lts-acento);
	outline-offset: 2px;
}

/* Letter-spacing normal a cos i encapçalats (com el live). Override del -0.01em
   de lts-global.css (mu-plugin), que al child no el tapa Elementor. Les classes
   específiques amb tracking propi (eyebrow, botons uppercase) hi guanyen per especificitat. */
body, h1, h2, h3, h4, h5, h6, p, li,
.wp-block-heading, .wp-block-button__link, .wp-element-button {
	letter-spacing: normal;
}

/* ───────────────────────── HEADER (glass, lligat a l'scroll) ───────────────────────── */

/* L'embolcall del template-part <header.wp-block-template-part> només fa l'alçada
   del header, cosa que limitava el position:sticky a eixos ~90px (a les pàgines sense
   hero el header marxava en fer scroll). Amb display:contents l'embolcall surt de la
   caixa i .lts-header s'enganxa dins de .wp-site-blocks (tota la pàgina). Només el header. */
header.wp-block-template-part { display: contents; }

.lts-header {
	position: sticky;
	top: 0;
	z-index: 100;
	width: 100%;
	color: var(--lts-fondo-claro);
	background: rgba(12, 24, 33, 0.6); /* vidre (preferència de Carles); blur fa llegible el text blanc */
	-webkit-backdrop-filter: saturate(140%) blur(12px);
	backdrop-filter: saturate(140%) blur(12px);
	padding-block: 20px;
	transition: padding 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
}
.lts-header.is-stuck {
	padding-block: 12px;
}
/* Layout del header explícit (no depèn del CSS de blocs de WP, que LiteSpeed/Elementor
   poden no carregar en pàgines amb contingut Elementor → el menú es trencaria). */
.lts-header__inner {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	max-width: none;
	padding-inline: 4%; /* full-width amb marge lateral 4%, com el live (no contenidor 1200px) */
}
.lts-header a {
	text-decoration: none;
}

/* En previsualització com a admin, la barra de WP (fixed) taparia el header.
   El públic no la té; només desplacem quan hi és. */
body.admin-bar .lts-header {
	top: 32px;
}
@media screen and (max-width: 782px) {
	body.admin-bar .lts-header { top: 46px; }
}

/* Pàgines amb hero (home, proyecto...): header transparent damunt del hero.
   En creuar els 50px (is-stuck), transició al estat compacte (bg rgba(12,24,33,0.4),
   padding 12px). El logo puja suaument per la transició de padding (no escala). */
body:has(.lts-hero) .lts-header {
	position: fixed;
	left: 0;
	right: 0;
	background: transparent;
	-webkit-backdrop-filter: none;
	backdrop-filter: none;
	padding-block: 20px;
}
body:has(.lts-hero) .lts-header.is-stuck {
	background: rgba(12, 24, 33, 0.6); /* mateix vidre que les pàgines sense hero: consistent */
	-webkit-backdrop-filter: saturate(140%) blur(12px);
	backdrop-filter: saturate(140%) blur(12px);
	padding-block: 12px;
}
/* CRÍTIC: amb el menú mòbil obert, el header NO pot tenir backdrop-filter ni
   transform. Tots dos creen un bloc contenidor (containing block) que faria que
   l'overlay del menú (position:fixed, descendent del header) es posicionés relatiu
   al header en lloc del viewport → el menú quedava "dins del header" en fer scroll
   (el header guanya el blur a is-stuck). Amb això l'overlay sempre ocupa la pantalla. */
.lts-header:has(.wp-block-navigation__responsive-container.is-menu-open) {
	-webkit-backdrop-filter: none !important;
	backdrop-filter: none !important;
	transform: none !important;
}
body:has(.lts-hero) .wp-site-blocks > main:first-of-type {
	margin-top: calc(-1 * var(--lts-header-h));
}
/* En mòbil/tauleta el header és fix i el hero és més baix: el pull-up de dalt feia
   que el contingut centrat quedara darrere del header. El neutralitzem ací (la
   imatge segueix darrere del header transparent; el contingut baixa i el neteja). */
@media (max-width: 1023.98px) {
	body:has(.lts-hero) .wp-site-blocks > main:first-of-type { margin-top: 0; }
}

/* Logo — 50px d'alt, blanc com el live. Selector sense .lts-header perquè el color
   apliqui també dins l'iframe sandbox del bloc wp:html a l'editor (allà no hi ha
   l'ancestre .lts-header). */
.lts-logo {
	display: inline-flex;
	align-items: center;
	color: var(--lts-fondo-claro);
	transition: color 0.3s ease;
}
.lts-logo svg {
	height: 50px;
	width: auto;
	display: block;
	fill: currentColor;
}
.lts-logo:hover {
	color: var(--lts-acento);
}
/* Sense quadre de focus de ratolí al logo ni als botons d'icona; per teclat sí */
.lts-logo:focus,
.lts-iconbtn:focus {
	outline: none;
	box-shadow: none;
}
.lts-logo:focus-visible,
.lts-iconbtn:focus-visible {
	outline: 2px solid var(--lts-acento);
	outline-offset: 3px;
	border-radius: 3px;
}

/* Accions de la dreta */
.lts-header__actions {
	display: flex;
	flex-wrap: nowrap;
	gap: 12px;
	align-items: center;
}
/* Llista de la navegació: flex explícit (independent del CSS de blocs de WP) */
.lts-nav .wp-block-navigation__container {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
}

/* Navegació: pills — text taronja, vora blanca 2px, radi 4px (valors live) */
.lts-nav {
	gap: 12px;
}
.lts-header .lts-nav .wp-block-navigation-item__content {
	display: inline-flex;
	align-items: center;
	box-sizing: border-box;
	height: 43px; /* com el live; igual que els botons d'icona */
	color: var(--lts-fondo-claro); /* text blanc (preferència de Carles; el live és taronja) */
	border: 2px solid var(--lts-fondo-claro);
	border-radius: 4px;
	padding: 12px 24px; /* com el live */
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 15px;
	font-weight: 400;
	letter-spacing: normal;
	line-height: 1;
	text-decoration: none;
	transition: color 0.25s ease, border-color 0.25s ease, background-color 0.25s ease;
}
.lts-header .lts-nav .wp-block-navigation-item__content:hover,
.lts-header .lts-nav .wp-block-navigation-item__content:focus,
.lts-header .lts-nav .current-menu-item > .wp-block-navigation-item__content {
	color: var(--lts-fondo-claro);
	background-color: rgba(253, 253, 253, 0.16);
	text-decoration: none;
}
/* Sense quadre de focus de ratolí (la vora + el tint de fons ja indiquen l'estat);
   per teclat sí, vora accent neta (accessibilitat). */
.lts-nav .wp-block-navigation-item__content:focus {
	outline: none;
	box-shadow: none;
}
.lts-nav .wp-block-navigation-item__content:focus-visible {
	outline: 2px solid var(--lts-acento);
	outline-offset: 2px;
}

/* "Acceder" → academia: vora accent però text blanc (es llig sobre qualsevol fons) */
.lts-header .lts-nav .lts-acceder .wp-block-navigation-item__content {
	background-color: transparent;
	border-color: var(--lts-acento);
	color: var(--lts-fondo-claro);
}
.lts-nav .lts-acceder .wp-block-navigation-item__content:hover,
.lts-nav .lts-acceder .wp-block-navigation-item__content:focus {
	background-color: var(--lts-acento);
	border-color: var(--lts-acento);
	color: var(--lts-fondo-claro);
}

/* Botons d'icona (cerca, carret): mateix llenguatge que els pills */
.lts-header a.lts-iconbtn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 43px;
	height: 43px;
	color: var(--lts-fondo-claro);
	border: 0; /* icones sense vora (preferència de Carles) */
	border-radius: 4px;
	transition: color 0.25s ease, background-color 0.25s ease;
}
.lts-header a.lts-iconbtn:hover {
	color: var(--lts-fondo-claro);
	background-color: rgba(253, 253, 253, 0.16);
}
.lts-iconbtn svg {
	width: 20px;
	height: 20px;
}

/* Icones del header injectades per WooCommerce (compte + mini-cart): mateix
   llenguatge que .lts-iconbtn (43px, sense vora, hover amb fons com "buscar"). */
.lts-header .wp-block-woocommerce-customer-account { display: inline-flex; margin: 0; font-size: inherit; }
.lts-header .wc-block-customer-account__link,
.lts-header .wc-block-mini-cart__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 43px;
	height: 43px;
	padding: 0;
	border: 0;
	border-radius: 4px;
	background: transparent;
	cursor: pointer;
	transition: background-color 0.25s ease, color 0.25s ease;
}
.lts-header .wc-block-customer-account__link:hover,
.lts-header .wc-block-mini-cart__button:hover {
	background-color: rgba(253, 253, 253, 0.16); /* mateix hover que la cerca */
}
/* Persona = accés a l'aula (academia): taronja, CTA destacat. */
.lts-header .lts-account-link { color: var(--lts-acento); }
.lts-header .wc-block-customer-account__account-icon { width: 22px; height: 22px; }
/* Carret (mini-cart): icona blanca, coherent amb la resta. */
.lts-header .wc-block-mini-cart__button { color: var(--lts-fondo-claro); }
.lts-header .wc-block-mini-cart__icon { width: 22px; height: 22px; }

/* Menú mòbil — hamburguesa amb caixa (com les icones).
   NO posar `display` aquí: el bloc Navigation ja l'amaga en desktop i la mostra
   en mòbil. Forçar display la faria sortir també en desktop. */
.lts-nav .wp-block-navigation__responsive-container-open {
	align-items: center;
	justify-content: center;
	width: 47px;
	height: 47px;
	color: var(--lts-fondo-claro);
	border: 0; /* hamburguesa sense vora, coherent amb les altres icones */
	border-radius: 4px;
}
.lts-nav .wp-block-navigation__responsive-container-open svg {
	width: 22px;
	height: 22px;
	fill: currentColor;
}

/* Overlay del menú mòbil: fons fosc, ítems en text blanc gran sense pills */
.lts-nav .wp-block-navigation__responsive-container.is-menu-open {
	background-color: var(--lts-fondo-oscuro) !important;
}
/* Menú mòbil obert: editorial, centrat vertical i horitzontalment, links grans
   en Playfair (com el to del lloc), amb accent taronja en hover. */
.lts-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	display: flex !important;
	flex-direction: column;
	justify-content: center !important;
	align-items: center !important; /* centra el menú horitzontalment (core el posa a flex-end) */
	min-height: 80vh;
	padding-top: 0;
}
/* El fill directe del content (el bloc nav) s'estirava a tota l'alçada; el deixem a
   l'alçada del seu contingut i el centrem verticalment dins del content. */
.lts-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content > .wp-block-navigation {
	flex: 0 0 auto;
	margin: auto 0;
}
.lts-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
	flex-direction: column;
	flex-wrap: nowrap;
	align-items: center;
	gap: 6px;
}
.lts-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
	display: inline-flex;
	height: auto; /* reset de l'altura fixa de 47px del header */
	border: 0 !important;
	border-radius: 0;
	padding: 12px 0;
	font-family: var(--wp--preset--font-family--playfair);
	font-size: clamp(1.9rem, 8vw, 2.6rem);
	line-height: 1.1;
	color: var(--lts-fondo-claro) !important;
	background: transparent !important;
	outline: none !important; /* treure el quadre de focus estrany del primer ítem */
}
.lts-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:hover,
.lts-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:focus {
	color: var(--lts-acento) !important;
	background: transparent !important;
}
/* "Acceder" al menú mòbil: també en accent (coherent amb desktop) */
.lts-nav .wp-block-navigation__responsive-container.is-menu-open .lts-acceder .wp-block-navigation-item__content {
	color: var(--lts-acento) !important;
}
.lts-nav .wp-block-navigation__responsive-container-close {
	color: var(--lts-fondo-claro);
}
.lts-nav .wp-block-navigation__responsive-container-close svg {
	width: 28px;
	height: 28px;
	fill: currentColor;
}

/* Llindar de col·lapse: el bloc Navigation de core només passa a hamburguesa per
   sota de 600px, però el menú complet (logo + 5 ítems + Acceder + icones) no hi
   cap en tauletes. Forcem el mode hamburguesa fins a 1024px sobreescrivint el
   `@media (min-width:600px)` de core (mostrar botó open, amagar menú inline). */
@media (max-width: 1023.98px) {
	.lts-nav .wp-block-navigation__responsive-container-open:not(.always-shown) { display: flex !important; }
	.lts-nav .wp-block-navigation__responsive-container:not(.is-menu-open) { display: none !important; }
}

@media (max-width: 781px) {
	.lts-logo svg { height: 40px; }
	.lts-header { padding-block: 12px; }
	.lts-header__actions { gap: 8px; }
}

/* Cerca nativa (desplegable des del header, sense popup d'Elementor) */
.lts-search-overlay {
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	background: transparent;
	padding: 22px 4%;
	opacity: 0;
	transform: translateY(-12px);
	transition: opacity 0.25s ease, transform 0.25s ease;
}
.lts-search-overlay.is-open {
	opacity: 1;
	transform: none;
}
.lts-search-inner {
	max-width: 680px;
	margin: 0 auto;
}
.lts-search-bar {
	display: flex;
	align-items: stretch;
	gap: 12px;
}
/* Caixa de cerca: mateix component que el hero de la botiga (contorn fi, fons
   fosc translúcid, botó taronja). Coherent amb els xips i botons de la web. */
.lts-search-form {
	flex: 1;
	display: flex;
	align-items: stretch;
	border: 1px solid rgba(253, 253, 253, 0.5);
	border-radius: 8px;
	background: rgba(12, 24, 33, 0.72);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
	padding: 5px;
}
.lts-search-input {
	flex: 1 1 auto;
	min-width: 0;
	background: transparent;
	border: 0;
	color: var(--lts-fondo-claro);
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 17px;
	padding: 10px 14px;
	outline: none;
}
.lts-search-input::placeholder {
	color: rgba(253, 253, 253, 0.55);
}
/* Amaga el botó natiu de neteja del type=search (× blava del navegador, off-brand) */
.lts-search-input::-webkit-search-cancel-button,
.lts-search-input::-webkit-search-decoration {
	-webkit-appearance: none;
	appearance: none;
}
.lts-search-submit {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--lts-acento);
	color: var(--lts-fondo-claro);
	border: 0;
	border-radius: 5px;
	padding: 0 18px;
	cursor: pointer;
	transition: background-color 0.2s ease;
}
.lts-search-submit:hover {
	background: var(--lts-secundario);
}
.lts-search-close {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	background: rgba(12, 24, 33, 0.72);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(253, 253, 253, 0.3);
	border-radius: 8px;
	color: rgba(253, 253, 253, 0.7);
	cursor: pointer;
	transition: color 0.2s ease, border-color 0.2s ease;
}
.lts-search-close:hover {
	color: var(--lts-fondo-claro);
	border-color: rgba(253, 253, 253, 0.5);
}
/* Resultats en viu: targeta de vidre fosc perquè es lligin sobre el hero */
.lts-search-results {
	margin: 12px 0 0;
	max-height: min(58vh, 460px);
	overflow-y: auto;
	background: rgba(12, 24, 33, 0.92);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(253, 253, 253, 0.12);
	border-radius: 8px;
	box-shadow: 0 12px 34px rgba(0, 0, 0, 0.4);
	padding: 8px;
}
.lts-search-result {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 18px;
	padding: 13px 14px;
	text-decoration: none;
	border-left: 2px solid transparent;
	border-radius: 6px;
	transition: background 0.18s ease, border-color 0.18s ease;
}
.lts-search-result + .lts-search-result {
	border-top: 1px solid rgba(253, 253, 253, 0.07);
}
.lts-search-result:hover,
.lts-search-result.is-active {
	background: rgba(253, 152, 64, 0.16);
	border-left-color: var(--lts-acento);
	border-top-color: transparent;
}
.lts-search-result__title {
	flex: 1;
	min-width: 0;
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 1.02rem;
	line-height: 1.35;
	color: var(--lts-fondo-claro);
}
.lts-search-result:hover .lts-search-result__title,
.lts-search-result.is-active .lts-search-result__title {
	color: var(--lts-acento);
}
.lts-search-result__type {
	flex-shrink: 0;
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 0.68rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(253, 253, 253, 0.45);
}
.lts-search-empty {
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 0.95rem;
	color: rgba(253, 253, 253, 0.6);
	margin: 0;
	padding: 16px 6px;
}
.lts-search-loading {
	width: 26px;
	height: 26px;
	margin: 22px auto;
	border: 2px solid rgba(253, 253, 253, 0.2);
	border-top-color: var(--lts-acento);
	border-radius: 50%;
	animation: lts-spin 0.7s linear infinite;
}
@keyframes lts-spin {
	to { transform: rotate(360deg); }
}

/* ── Modal natiu (lead magnet "Guía de Respiración"), substitueix el popup
   d'Elementor Pro. S'obre des de #open-guia / .lts-open-guia. ── */
.lts-modal {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
}
.lts-modal[hidden] { display: none; }
.lts-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(12, 24, 33, 0.6);
	opacity: 0;
	transition: opacity 0.25s ease;
}
.lts-modal.is-open .lts-modal__backdrop { opacity: 1; }
.lts-modal__panel {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 560px;
	background: var(--lts-fondo-claro);
	border-radius: 6px;
	padding: 48px 44px;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
	transform: translateY(14px);
	opacity: 0;
	transition: transform 0.25s ease, opacity 0.25s ease;
}
.lts-modal.is-open .lts-modal__panel { transform: none; opacity: 1; }
.lts-modal__close {
	position: absolute;
	top: 14px;
	right: 14px;
	background: transparent;
	border: 0;
	color: var(--lts-secundario);
	cursor: pointer;
	display: flex;
	padding: 6px;
	border-radius: 4px;
	transition: color 0.2s ease;
}
.lts-modal__close:hover { color: var(--lts-acento); }
.lts-modal__title {
	font-family: var(--wp--preset--font-family--playfair);
	text-align: center;
	margin: 0 0 10px;
}
.lts-modal__subtitle {
	text-align: center;
	color: var(--lts-secundario);
	margin: 0 0 28px;
}
body.lts-modal-open { overflow: hidden; }
.lts-guia-form__row { display: flex; gap: 12px; margin-bottom: 14px; }
.lts-guia-form input {
	flex: 1;
	min-width: 0;
	padding: 12px 0;
	border: 0;
	border-bottom: 1px solid #d8d8d8;
	background: transparent;
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 16px;
	color: var(--lts-principal);
	transition: border-color 0.2s ease;
}
.lts-guia-form input:focus { outline: none; border-color: var(--lts-acento); }
.lts-guia-form__submit {
	width: 100%;
	padding: 15px 28px;
	background: var(--lts-acento);
	color: var(--lts-fondo-claro);
	border: 0;
	border-radius: 4px;
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 14px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.2s ease;
}
.lts-guia-form__submit:hover { background: #e58838; }
.lts-guia-form__submit:disabled { opacity: 0.55; cursor: not-allowed; }
.lts-guia-form__msg {
	text-align: center;
	margin-top: 16px;
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 15px;
}
.lts-guia-form__msg.is-success { color: #2e7d32; }
.lts-guia-form__msg.is-error { color: #c62828; }
@media (max-width: 520px) {
	.lts-modal__panel { padding: 36px 24px; }
	.lts-guia-form__row { flex-direction: column; gap: 0; }
	.lts-guia-form input { margin-bottom: 14px; }
}

/* Conté el desplaçament lateral dels reveals perquè no provoque scroll horitzontal
   en mòbil. `clip` (no `hidden`) no crea contenidor de scroll ni afecta sticky/fixed,
   i deixa l'eix vertical visible (el hero es pot pujar amb margin negatiu). */
.lts-main { overflow-x: clip; }

/* ───────────────────────── HERO (cover) ───────────────────────── */

.lts-hero {
	color: var(--lts-fondo-claro);
	/* No tapar tota la pantalla: deixar que la secció següent "trega el cap"
	   (senyal clar que hi ha contingut a sota). Override del min-height:100vh inline. */
	min-height: 85vh !important;
}
@media (max-width: 767px) {
	.lts-hero { min-height: 78vh !important; }
}
/* Home: el hero és la landing -> imatge gairebé a tota la pantalla (quasi 100vh).
   La resta de heros deixen la llesca de sota com a senyal de scroll. */
@media (min-width: 768px) {
	body.home .lts-hero--feature { min-height: 100vh !important; }
}
/* Pàgina de resultats de cerca: hero amb imatge (coherent amb blog/tienda) però
   més baix, perquè la llista de resultats sigui el focus i no quedi sota el plec. */
.lts-hero.lts-hero--results { min-height: 58vh !important; }
@media (max-width: 767px) {
	.lts-hero.lts-hero--results { min-height: 66vh !important; }
}
.lts-rule {
	width: 60px;
	height: 3px;
	border: 0;
	margin: 24px auto;
	opacity: 1;
}
.lts-hero__subtitle {
	max-width: 40ch;
	margin-inline: auto;
	opacity: 0.92;
}

/* ───────────────────────── SECCIONS DE CONTINGUT ───────────────────────── */

.lts-section {
	padding-block: 84px;
	padding-inline: 24px;
}
.lts-section--alt {
	background: #f3f1ec; /* gris càlid suau, com les seccions clares del live */
}
.lts-cols {
	gap: 56px;
}
.lts-img img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 6px;
}
.lts-rule--left {
	margin-left: 0;
	margin-right: auto;
}
.lts-section__lead {
	max-width: 62ch;
	margin-inline: auto;
}

/* Passos apilats (¿Cómo trabajo contigo?) — files a tot l'ample, com el live */
.lts-steps {
	margin-top: 32px;
}
.lts-step {
	padding-block: 40px;
	border-top: 1px solid rgba(26, 26, 26, 0.12);
}
.lts-step:first-child {
	border-top: 0;
}
.lts-step h3 {
	margin-top: 0;
}
.lts-step .wp-block-buttons {
	margin-top: 20px;
}

/* Heros: imatge de fons FIXA mentre es fa scroll (parallax), com vol el disseny.
   Apliquem background-attachment: fixed de forma explícita (el CSS de core ho
   amaga darrere de prefers-reduced-motion). En mòbil (iOS) degrada a scroll. */
.lts-hero .wp-block-cover__image-background,
.lts-cta .wp-block-cover__image-background {
	object-fit: cover;
	background-attachment: fixed;
	background-size: cover;
	background-position: center;
}

.lts-hero {
	position: relative;
}

/* ── Hero "feature" (scroll dinàmic): títol gran protagonista, vora recta i
   imatge que fa ZOOM en fer scroll (JS, lleuger). Tots els heros del tema són
   "feature"; el divisor diagonal "tilt" antic es va retirar. ── */
.lts-hero--feature .wp-block-cover__image-background {
	background-attachment: scroll; /* per poder escalar-la amb transform */
	transform-origin: center center;
	will-change: transform;
	transition: transform 0.1s linear;
}
.lts-hero--feature .lts-hero__content { will-change: transform, opacity; }
.lts-hero--feature h1 {
	font-size: clamp(3.2rem, 9vw, 6rem); /* títol protagonista */
	line-height: 1.02;
}
@media (max-width: 767px) {
	.lts-hero--feature h1 { font-size: clamp(2.6rem, 14vw, 4rem); }
}
/* El títol de la pàgina de resultats és una FRASE llarga ("Resultados de búsqueda
   para: X"), no una paraula com "Blog.": mida continguda perquè no es desbordi cap
   al header i càpiga dins el hero. */
.lts-hero.lts-hero--results h1 {
	font-size: clamp(1.6rem, 4.2vw, 2.6rem) !important;
	line-height: 1.18;
	overflow-wrap: anywhere;
}
/* El cover és flex-row (centrat vertical via align-items) i el hero està estirat
   ~90px amunt sota el header transparent. Amb contingut centrat, un títol llarg es
   desborda cap amunt sota el header. L'alineem a DALT i li donem marge superior que
   supera l'estirada + el header (~90+90), així mai el trepitja per llarg que sigui
   (el hero creix avall si cal). */
.lts-hero.lts-hero--results {
	align-items: flex-start !important;
}
.lts-hero.lts-hero--results .lts-hero__content {
	padding-top: 196px;
	padding-bottom: 56px;
}

/* Cercador dins del hero: vidre FOSC (mateix to que la capçalera, #0C1821) amb
   blur i ombra, perquè el camp i el placeholder es lligen sobre el fons ocupat. */
.lts-hero__search { max-width: 540px; margin: 30px auto 0; }
.lts-hero__search .wp-block-search__inside-wrapper {
	display: flex;
	align-items: stretch;
	border: 1px solid rgba(253, 253, 253, 0.5);
	border-radius: 8px;
	background: rgba(12, 24, 33, 0.55);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.28);
	padding: 5px;
}
/* El camp ocupa tot l'ample disponible i el botó queda fix a la dreta. Definit
   aquí (no depèn del full del bloc wp:search, que només es carrega si hi ha un
   bloc de cerca real a la pàgina: a Tienda fem servir un <form> propi). */
.lts-hero__search .wp-block-search__input {
	flex: 1 1 auto;
	min-width: 0;
	border: 0;
	background: transparent;
	color: var(--lts-fondo-claro);
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 16px;
	padding: 10px 14px;
}
.lts-hero__search .wp-block-search__button { flex: 0 0 auto; white-space: nowrap; }
.lts-hero__search .wp-block-search__input::placeholder { color: rgba(253, 253, 253, 0.78); }
.lts-hero__search .wp-block-search__input:focus { outline: none; }
.lts-hero__search .wp-block-search__button {
	background: var(--lts-acento);
	color: var(--lts-fondo-claro);
	border: 0;
	border-radius: 5px;
	font-family: var(--wp--preset--font-family--tenor);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-size: 13px;
	padding: 0 22px;
	margin: 0;
	transition: background-color 0.2s ease;
}
.lts-hero__search .wp-block-search__button:hover { background: var(--lts-secundario); }

/* Xips de categoria al hero: mateix llenguatge visual que els botons del lloc
   (radi 5px, vora 2px, majúscules, letter-spacing 0.1em, 13px). Inactiu = contorn
   clar sobre el hero fosc; actiu = omplit d'accent (com el pas outline -> filled). */
.lts-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-top: 22px; }
.lts-chip {
	display: inline-block;
	padding: 10px 22px;
	border-radius: 5px;
	border: 2px solid rgba(253, 253, 253, 0.4);
	background: transparent;
	color: var(--lts-fondo-claro);
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 13px;
	line-height: 1;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.lts-chip:hover { border-color: var(--lts-fondo-claro); }
.lts-chip.is-active {
	background: var(--lts-acento);
	border-color: var(--lts-acento);
	color: var(--lts-fondo-claro);
}
.lts-filter-empty { grid-column: 1 / -1; text-align: center; list-style: none; }

/* Graella del blog */
.lts-bloggrid {
	margin-top: 44px;
}
.lts-bloggrid .wp-block-post-title {
	margin-top: 14px;
}

/* Botons plens: text blanc sobre accent (evita text taronja sobre taronja) */
.wp-block-button:not(.is-style-outline) > .wp-block-button__link {
	color: var(--lts-fondo-claro);
	background-color: var(--lts-acento);
	border: 2px solid var(--lts-acento);
}
.wp-block-button:not(.is-style-outline) > .wp-block-button__link:hover {
	background-color: var(--lts-secundario);
	border-color: var(--lts-secundario);
	color: var(--lts-fondo-claro);
}

/* Botons outline: vora fosca + text accent (com el live), fons transparent */
.wp-block-button.is-style-outline .wp-block-button__link {
	color: var(--lts-acento);
	border: 2px solid var(--lts-principal);
	background: transparent;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--lts-acento);
	border-color: var(--lts-acento);
	color: var(--lts-fondo-claro);
}

@media (max-width: 781px) {
	.lts-section { padding-block: 56px; }
	.lts-cols { gap: 32px; }
}

/* Columnes-imatge (cover, alçada fixa, radi) */
.lts-img-col img {
	width: 100%;
	height: 420px;
	object-fit: cover;
	border-radius: 4px;
	display: block;
}
.lts-img-col--blog img {
	height: 320px;
}
@media (max-width: 781px) {
	.lts-img-col img { height: 280px; }
}

/* Reveal lligat a l'scroll: el JS escriu opacity/transform cada frame segons la
   posició a la finestra (scrubbed), per això no hi ha transition. S'arma via JS;
   sense JS o amb moviment reduït, el contingut queda visible. */
.lts-reveal.lts-armed,
.lts-reveal-children > .lts-armed {
	opacity: 0;
	will-change: opacity, transform;
}
@media (prefers-reduced-motion: reduce) {
	.lts-reveal,
	.lts-reveal-children > * { opacity: 1 !important; transform: none !important; }
}

/* Testimonis: graella 3 col amb facade de YouTube */
.lts-testi-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 44px;
}
@media (max-width: 767px) {
	.lts-testi-grid { grid-template-columns: 1fr; }
}
.lts-vembed {
	position: relative;
	padding-bottom: 56.25%;
	border-radius: 4px;
	overflow: hidden;
	background: var(--lts-fondo-oscuro);
}
.lts-vembed iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}
.lts-vn {
	text-align: center;
	margin-top: 10px;
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 0.9rem;
	color: var(--lts-secundario);
}

/* ───────────────────────── FOOTER (com el live: barra blanca + franja Kit Digital) ───────────────────────── */

/* Barra blanca: logo fosc + enllaços legals + copyright */
.lts-footer__bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 18px 28px;
	background: var(--lts-fondo-claro);
	padding: 26px 4%;
	max-width: none;
}
/* Logo del footer: SVG monocrom via CSS mask → recolorable (fosc, hover accent com el live) */
.lts-footer__logo {
	display: inline-block;
	width: 162px;
	height: 44px;
	background-color: var(--lts-principal);
	-webkit-mask: url(../img/lts-logo-full.svg) no-repeat center / contain;
	mask: url(../img/lts-logo-full.svg) no-repeat center / contain;
	transition: background-color 0.3s ease;
}
.lts-footer__logo:hover {
	background-color: var(--lts-acento);
}
.lts-footer__legal {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 24px;
	justify-content: center;
	margin: 0; /* el bloc navegació porta un margin-top per defecte que el descentrava al footer */
}
.lts-footer__legal a {
	color: var(--lts-principal);
	text-decoration: none;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0.02em;
	transition: color 0.2s ease;
}
.lts-footer__legal a:hover {
	color: var(--lts-acento);
}
.lts-footer__copy {
	color: var(--lts-secundario);
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0.02em;
	margin: 0;
}

/* Franja Kit Digital: fons negre (#111 com el live) amb el banner sencer */
.lts-footer__kd {
	background: #111;
	padding: 16px 4%;
	text-align: center;
}
/* Banner Kit Digital sencer (com el live), sense retallar. Ara és un bloc
   core/image (editable des de l'editor): els estils visuals van a la <img>. */
.lts-footer__kd-banner {
	max-width: 900px;
	margin: 0 auto;
}
.lts-footer__kd-banner img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 4px;
}
/* Nota: el widget de privacitat dels EUA d'Iubenda (.iub__us-widget) es va
   desactivar al config d'Iubenda (enableUspr/usprApplies = false, 2026-05-25),
   per innecessari per a públic UE. La icona verda RGPD (preferències de cookies)
   es manté. Per això ja no cal CSS per a aquell bloc. */
/* Amb 4 enllaços legals, logo i copyright no caben en una fila neta per sota de
   ~1100px (el copyright quedava orfe en una segona línia). Apilem abans. */
@media (max-width: 1100px) {
	.lts-footer__bar { flex-direction: column; text-align: center; gap: 16px; }
}

/* ───────────────────────── CONTACTO ───────────────────────── */

/* Secció fosca (testimonis) */
.lts-section--dark h2 { color: var(--lts-fondo-claro); }

/* Chevron de scroll del hero (fix, cantonada inferior esquerra, com el live) */
.lts-scroll-chevron {
	position: fixed;
	bottom: 16px;
	left: 8%;
	z-index: 90; /* per sota del header (100) i del menú mòbil, perquè no els tape */
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: 0;
	cursor: pointer;
	opacity: 0;
	animation: lts-chev-in 0.5s 1.2s ease-out forwards;
	transition: opacity 0.4s;
}
.lts-scroll-chevron.is-hidden { opacity: 0 !important; pointer-events: none; }
/* Amaga la fletxa quan el menú mòbil està obert (no ha de flotar sobre el menú). */
body:has(.wp-block-navigation__responsive-container.is-menu-open) .lts-scroll-chevron {
	display: none !important;
}
@keyframes lts-chev-in { to { opacity: 1; } }
.lts-scroll-chevron::before,
.lts-scroll-chevron::after {
	content: "";
	position: absolute;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1.5px solid rgba(253, 152, 64, 0.3);
	animation: lts-chev-pulse 2.4s 2s ease-out infinite;
}
.lts-scroll-chevron::after { border-color: rgba(253, 152, 64, 0.15); animation-delay: 2.6s; }
@keyframes lts-chev-pulse { 0% { transform: scale(1); opacity: 1; } 100% { transform: scale(1.8); opacity: 0; } }
.lts-scroll-chevron svg {
	position: relative;
	z-index: 2;
	animation: lts-chev-bounce 2.2s 2s ease-in-out infinite;
	filter: drop-shadow(0 1px 4px rgba(253, 152, 64, 0.3));
}
@keyframes lts-chev-bounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(5px); } }
.lts-scroll-chevron:hover svg,
.lts-scroll-chevron:hover::before,
.lts-scroll-chevron:hover::after { animation-play-state: paused; }
@media (max-width: 767px) {
	.lts-scroll-chevron { left: 5%; bottom: 8px; width: 36px; height: 36px; }
	.lts-scroll-chevron::before, .lts-scroll-chevron::after { width: 36px; height: 36px; }
}

/* Carrusel de testimonis (natiu, fade via grid-stack) */
.ltc-wrap { width: 100%; max-width: 900px; margin: 0 auto; padding: 8px 0 0; box-sizing: border-box; }
.ltc-track { display: grid; }
.ltc-slide {
	grid-area: 1 / 1;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.45s ease;
}
.ltc-slide.is-active { opacity: 1; pointer-events: auto; }
.ltc-card {
	display: grid;
	grid-template-columns: 42% 1fr;
	gap: 24px;
	padding: 32px;
	box-sizing: border-box;
	background: #0c1821;
	border: 1px solid rgba(255, 255, 255, 0.09);
	border-radius: 4px;
	position: relative;
	overflow: hidden;
}
@media (max-width: 767px) {
	.ltc-card { grid-template-columns: 1fr; gap: 16px; padding: 24px; }
}
.ltc-vid-wrap {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	border-radius: 4px;
	cursor: pointer;
	background: #000;
}
.ltc-vid-wrap img,
.ltc-vid-frame { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }
.ltc-vid-wrap img { object-fit: cover; transition: opacity 0.3s; }
.ltc-vid-wrap:hover img { opacity: 0.82; }
.ltc-vid-play {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 54px;
	height: 38px;
	background: rgba(0, 0, 0, 0.7);
	border-radius: 8px;
	transition: background 0.3s;
}
.ltc-vid-wrap:hover .ltc-vid-play { background: rgba(255, 0, 0, 0.9); }
.ltc-vid-play::after {
	content: "";
	display: block;
	margin: 9px 0 0 19px;
	border-style: solid;
	border-width: 10px 0 10px 16px;
	border-color: transparent transparent transparent #fff;
}
.ltc-vid-name {
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 0.8rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--lts-acento);
	margin-top: 10px;
	text-align: center;
}
.ltc-text-col { display: flex; flex-direction: column; justify-content: center; }
.ltc-quote {
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 0.95rem;
	line-height: 1.8;
	color: var(--lts-fondo-claro);
	opacity: 0.86;
	margin: 0 0 18px;
}
.ltc-quote::before {
	content: "\201C";
	color: var(--lts-acento);
	font-size: 1.4em;
	line-height: 0.7;
	vertical-align: middle;
	margin-right: 4px;
	font-family: var(--wp--preset--font-family--playfair);
}
.ltc-ig {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 0.62rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(253, 152, 64, 0.5);
	text-decoration: none;
	transition: color 0.3s;
}
.ltc-ig:hover { color: var(--lts-acento); }
.ltc-prog { position: absolute; bottom: 0; left: 0; height: 2px; width: 0; background: var(--lts-acento); opacity: 0.7; }
.ltc-prog.ltc-running { animation: ltc-prog 8000ms linear forwards; }
@keyframes ltc-prog { from { width: 0; } to { width: 100%; } }
.ltc-nav { display: flex; justify-content: center; align-items: center; gap: 12px; margin-top: 22px; }
.ltc-nav-btn {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 1px solid rgba(253, 152, 64, 0.25);
	background: none;
	color: rgba(253, 152, 64, 0.5);
	font-size: 14px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: border-color 0.25s, color 0.25s, background-color 0.25s;
}
.ltc-nav-btn:hover { border-color: var(--lts-acento); color: #0c1821; background-color: var(--lts-acento); }

/* Nota de privacitat sota el formulari */
.lts-form-note { color: var(--lts-secundario); opacity: 0.8; margin-top: 18px; }

/* ───────────────────────── BLOG (graella de posts) ───────────────────────── */

/* Cercador del blog: input amb subratllat + botó accent (com el live) */
.lts-blog-search { max-width: 520px; margin: 28px auto 0; }
.lts-blog-search .wp-block-search__inside-wrapper {
	border: 0;
	border-bottom: 1px solid #d8d8d8;
	border-radius: 0;
}
.lts-blog-search .wp-block-search__input {
	border: 0;
	background: transparent;
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 16px;
	padding: 8px 0;
}
.lts-blog-search .wp-block-search__input:focus { outline: none; }
.lts-blog-search .wp-block-search__button {
	background: var(--lts-acento);
	color: var(--lts-fondo-claro);
	border: 0;
	border-radius: 4px;
	font-family: var(--wp--preset--font-family--tenor);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-size: 13px;
	padding: 0 22px;
	margin: 4px;
	transition: background-color 0.2s ease;
}
.lts-blog-search .wp-block-search__button:hover { background: var(--lts-secundario); }

/* Pàgina de resultats de cerca: llista neta (títol + extracte), robusta per a
   qualsevol tipus (articles, pàgines, productes) sense dependre d'imatge destacada */
.lts-search-results-section { padding-top: 8px; }
.lts-search-hits .wp-block-post-template {
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 0;
}
.lts-search-hit {
	padding: 22px 0;
	border-bottom: 1px solid rgba(12, 24, 33, 0.1);
}
.lts-search-hit__title { margin: 0 0 6px; }
.lts-search-hit__title a {
	font-family: var(--wp--preset--font-family--playfair);
	color: var(--lts-fondo-oscuro);
	text-decoration: none;
	font-size: clamp(1.18rem, 2.2vw, 1.5rem);
	line-height: 1.25;
	transition: color 0.18s ease;
}
.lts-search-hit__title a:hover { color: var(--lts-acento); }
.lts-search-hit__excerpt {
	font-family: var(--wp--preset--font-family--tenor);
	color: rgba(12, 24, 33, 0.7);
	margin: 0;
	line-height: 1.55;
}

/* Graella de posts: 3 columnes, targetes amb imatge + títol sobre degradat */
.lts-section--grid { padding-top: 24px; }
.lts-post-grid .wp-block-post-template {
	gap: 28px;
	margin: 0;
}
@media (max-width: 900px) {
	.lts-post-grid .wp-block-post-template.is-layout-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.lts-post-grid .wp-block-post-template.is-layout-grid { grid-template-columns: 1fr; }
}
.lts-post-card {
	position: relative;
	border-radius: 4px;
	overflow: hidden;
	background: #0c1821;
}
.lts-post-card .wp-block-post-featured-image {
	margin: 0;
	border-radius: 0;
}
.lts-post-card .wp-block-post-featured-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.5s ease, opacity 0.3s ease;
}
.lts-post-card:hover .wp-block-post-featured-image img { transform: scale(1.05); }
.lts-post-card__overlay {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 48px 22px 20px;
	background: linear-gradient(to top, rgba(12, 24, 33, 0.92) 0%, rgba(12, 24, 33, 0.55) 55%, transparent 100%);
	pointer-events: none;
}
.lts-post-card__overlay .wp-block-post-title {
	margin: 0;
	font-size: 1.12rem;
	line-height: 1.3;
}
.lts-post-card__overlay .wp-block-post-title a {
	color: var(--lts-fondo-claro);
	text-decoration: none;
	pointer-events: auto;
	transition: color 0.2s ease;
}
.lts-post-card__overlay .wp-block-post-title a:hover { color: var(--lts-acento); }

/* Paginació */
.lts-pagination { margin-top: 48px; gap: 14px; align-items: center; }
.lts-pagination .wp-block-query-pagination-numbers,
.lts-pagination .page-numbers { font-family: var(--wp--preset--font-family--tenor); }
.lts-pagination a, .lts-pagination .page-numbers {
	color: var(--lts-texto);
	text-decoration: none;
	transition: color 0.2s ease;
}
.lts-pagination a:hover { color: var(--lts-acento); }
.lts-pagination .page-numbers.current { color: var(--lts-acento); font-weight: 700; }

/* ───────────────────────── TIENDA (graella de productes) ───────────────────────── */
.lts-shop-grid .wp-block-woocommerce-product-template,
.lts-shop-grid .products-block-post-template { gap: 28px; margin: 0; list-style: none; padding: 0; }
@media (max-width: 900px) {
	.lts-shop-grid .wp-block-woocommerce-product-template.is-layout-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.lts-shop-grid .wp-block-woocommerce-product-template.is-layout-grid { grid-template-columns: 1fr; }
}
.lts-product-card {
	background: var(--lts-fondo-claro);
	border: 1px solid rgba(26, 26, 26, 0.08);
	border-radius: 4px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.3s ease;
}
.lts-product-card:hover { box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1); }
.lts-product-card__img { margin: 0; }
.lts-product-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.lts-product-card__body { padding: 18px 18px 22px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.lts-product-card__title { margin: 0; line-height: 1.3; }
.lts-product-card__title a { color: var(--lts-principal); text-decoration: none; transition: color 0.2s ease; }
.lts-product-card__title a:hover { color: var(--lts-acento); }
.lts-product-card__price { color: var(--lts-secundario); font-family: var(--wp--preset--font-family--tenor); margin: 0; }
.lts-product-card__price .amount,
.lts-product-card__price ins { color: var(--lts-principal); }
.lts-product-card__btn { margin-top: auto; }
.lts-product-card__btn a,
.lts-product-card__btn .wp-block-button__link,
.lts-product-card__btn .wc-block-components-product-button__button {
	display: block;
	width: 100%;
	text-align: center;
	background: var(--lts-acento);
	color: var(--lts-fondo-claro);
	border: 0;
	border-radius: 4px;
	padding: 12px 18px;
	font-family: var(--wp--preset--font-family--tenor);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 13px;
	text-decoration: none;
	transition: background-color 0.2s ease;
}
.lts-product-card__btn a:hover,
.lts-product-card__btn .wp-block-button__link:hover,
.lts-product-card__btn .wc-block-components-product-button__button:hover { background: var(--lts-secundario); }

/* ───────────────────────── SINGLE DE PRODUCTE (afiliació) ─────────────────────────
   Buy box (imatge gran + títol/preu/descripció/CTA) + relacionats. Sense pestanyes
   ni ressenyes (productes d'afiliació). */
.lts-product__top { gap: 48px; align-items: flex-start; }
.lts-product__media .woocommerce-product-gallery,
.lts-product__media figure,
.lts-product__media .wp-block-woocommerce-product-image-gallery { margin: 0; }
.lts-product__media img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 8px;
	box-shadow: 0 16px 44px rgba(0, 0, 0, 0.14);
}
.lts-product__title { margin: 0 0 14px; line-height: 1.12; }
.lts-product__info .wp-block-woocommerce-product-price,
.lts-product__info .price {
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 1.4rem;
	color: var(--lts-principal);
}
.lts-product__desc {
	font-family: var(--wp--preset--font-family--tenor);
	color: var(--lts-texto);
	line-height: 1.7;
	margin: 22px 0 28px;
}
.lts-product__desc p { margin: 0 0 1em; }
.lts-product__desc :last-child { margin-bottom: 0; }
/* CTA "Comprar en Amazon" (producte extern) */
.lts-product__info .wp-block-woocommerce-add-to-cart-form a.button,
.lts-product__info .single_add_to_cart_button,
.lts-product__info a.button {
	display: inline-block;
	background: var(--lts-acento);
	color: var(--lts-fondo-claro);
	font-family: var(--wp--preset--font-family--tenor);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-size: 0.95rem;
	font-weight: 700;
	padding: 14px 34px;
	border-radius: 5px;
	border: 2px solid var(--lts-acento);
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.lts-product__info .wp-block-woocommerce-add-to-cart-form a.button:hover,
.lts-product__info .single_add_to_cart_button:hover,
.lts-product__info a.button:hover {
	background: var(--lts-fondo-oscuro);
	border-color: var(--lts-fondo-oscuro);
	color: var(--lts-fondo-claro);
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
}
/* Relacionats: "También te puede interesar" */
.lts-related__inner { max-width: 1140px; margin: 0 auto; padding-inline: 4%; }
.lts-related__title {
	font-family: var(--wp--preset--font-family--playfair);
	margin: 0 0 28px;
}
.lts-related-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
.lts-related-grid .lts-product-card__img { display: block; aspect-ratio: 4 / 3; overflow: hidden; }
@media (max-width: 900px) { .lts-related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .lts-related-grid { grid-template-columns: 1fr; } }
@media (max-width: 781px) {
	.lts-product__top { gap: 28px; }
	.lts-product__media { max-width: 360px; margin-inline: auto; }
}

/* ───────────────────────── CAPÇALERA COMPACTA DE PÀGINA ─────────────────────────
   Alternativa al hero 100vh per a pàgines de contingut: banda fosca curta. */
.lts-pagehead {
	padding-top: 76px;
	padding-bottom: 72px;
	padding-inline: 24px;
	text-align: center;
}
.lts-pagehead h1 { margin: 0; color: var(--lts-fondo-claro); }
.lts-pagehead__subtitle {
	max-width: 48ch;
	margin: 0 auto;
	opacity: 0.85;
	font-size: 1.125rem;
}

/* ───────────────────────── SINGLE POST ───────────────────────── */
/* Banner del single: cover amb la imatge destacada de fons + capa fosca. Hero més
   baix que les landings (50vh): és un article, no una portada.
   A diferència de les landings, NO es puja sota el header (el banner és més baix i
   el títol pot ser llarg de diverses línies), i deixa marge superior d'alçada de
   header perquè el títol no xoque mai amb el menú. */
body.single .wp-site-blocks > main:first-of-type { margin-top: 0; }
.lts-article__head {
	text-align: center;
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}
.lts-article__head.lts-hero {
	min-height: 50vh !important;
	padding-top: var(--lts-header-h);
	padding-bottom: 2rem;
}
/* La imatge destacada fa de fons del banner (post-featured-image absolut) + capa fosca */
.lts-article__head .lts-article__bg { position: absolute; inset: 0; margin: 0; z-index: 0; }
.lts-article__head .lts-article__bg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.lts-article__head::before {
	content: "";
	position: absolute;
	inset: 0;
	background: var(--lts-fondo-oscuro);
	opacity: 0.5;
	z-index: 1;
}
.lts-article__head .lts-hero__content { position: relative; z-index: 2; }
/* Títol del banner: gran però no tan gegant com el hero de les landings */
.lts-article__head .wp-block-post-title {
	color: var(--lts-fondo-claro);
	font-size: clamp(2.2rem, 4.5vw, 3.6rem);
	line-height: 1.12;
}
/* Meta sota el títol: CATEGORÍA · FECHA en una línia */
.lts-article__meta { gap: 0; align-items: center; margin-top: 12px; }
.lts-article__meta .lts-eyebrow { margin: 0; }
.lts-article__meta .lts-article__date {
	color: rgba(253, 253, 253, 0.72);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}
.lts-article__meta .lts-article__date::before {
	content: "·";
	margin: 0 12px;
	color: rgba(253, 253, 253, 0.5);
}
.lts-eyebrow {
	font-family: var(--wp--preset--font-family--tenor);
	font-size: 0.72rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--lts-acento);
	margin-bottom: 14px;
}
/* L'eyebrow de categoria NO és un enllaç (no s'usen les pàgines de categoria) */
.lts-eyebrow a { color: var(--lts-acento); text-decoration: none; pointer-events: none; cursor: default; }
.lts-article__head .wp-block-post-title { margin: 0 0 10px; }
.lts-article__date { color: rgba(253, 253, 253, 0.7); margin: 0; }
/* Cos de l'article: lectura còmoda (Tenor Sans, interlineat ample), alineat a
   l'esquerra (prosa), com el live. */
.lts-article__body { padding-top: 40px; text-align: left; }
.lts-article__body p,
.lts-article__body li { line-height: 1.85; }
/* H2 amb barra d'accent a l'esquerra (com el live) */
.lts-article__body h2 {
	margin-top: 1.8em;
	border-left: 4px solid var(--lts-acento);
	padding-left: 18px;
}
.lts-article__body h3 { margin-top: 1.4em; }
/* "Volver" a dalt del contingut: és un <p> (es constreny a la columna del cos,
   alineat amb el text); l'enllaç va dins. */
/* Sigue leyendo: navegació article anterior / següent */
.lts-postnav__row { gap: 30px; }
.lts-postnav .wp-block-post-navigation-link { font-family: var(--wp--preset--font-family--tenor); font-size: 1.05rem; }
.lts-postnav .lts-postnav__next { text-align: right; }
.lts-postnav a { text-decoration: none; color: var(--lts-texto); transition: color 0.2s ease; }
.lts-postnav a:hover { color: var(--lts-acento); }
.lts-postnav .post-navigation-link__label {
	display: block;
	color: var(--lts-secundario);
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin-bottom: 6px;
}

/* Bloc d'articles relacionats (lts/related-posts): graella de targetes com el blog */
.lts-related__grid {
	list-style: none;
	margin: 1.5rem 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25rem;
}
@media (max-width: 900px) { .lts-related__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .lts-related__grid { grid-template-columns: 1fr; } }
.lts-article__body img { border-radius: 4px; }
.lts-article__body blockquote {
	border-left: 3px solid var(--lts-acento);
	padding-left: 24px;
	margin-left: 0;
	font-style: italic;
	color: var(--lts-secundario);
}
.lts-article__comments { padding-top: 32px; }

/* Formulari Contacto: Nombre + Apellidos en la mateixa línia (com el live).
   Scoped a #formulario per no afectar altres forms de lts-forms. */
@media (min-width: 600px) {
	#formulario .lts-form-el { display: flex; flex-wrap: wrap; column-gap: 24px; }
	#formulario .lts-form-el > * { flex: 1 1 100%; }
	#formulario .lts-form-el > .lts-field:has(input[name="nombre"]),
	#formulario .lts-form-el > .lts-field:has(input[name="apellidos"]) { flex: 1 1 calc(50% - 12px); }
}
