/* ==========================================================================
   Detallista ES – Frontend CSS
   Variables extra, utilidades y estilos que theme.json no puede expresar.
   ========================================================================== */

/* --------------------------------------------------------------------------
   Variables adicionales
   -------------------------------------------------------------------------- */
:root {
	--dt-bg:          var(--wp--preset--color--background, #f8f4ed);
	--dt-paper:       var(--wp--preset--color--paper, #faf8f4);
	--dt-cream:       var(--wp--preset--color--cream, #ede5d6);
	--dt-ink:         var(--wp--preset--color--ink, #2c2118);
	--dt-muted:       var(--wp--preset--color--muted, #6b5f52);
	--dt-border:      var(--wp--preset--color--border, #ddd0bc);
	--dt-terracotta:  var(--wp--preset--color--terracotta, #c4632d);
	--dt-olive:       var(--wp--preset--color--olive, #5e6e3f);
	--dt-amber:       var(--wp--preset--color--amber, #d18d3a);

	--dt-shadow-paper: 0 1px 2px rgba(44,33,24,0.06), 0 12px 32px -12px rgba(44,33,24,0.18);
	--dt-shadow-soft:  0 8px 24px -10px rgba(44,33,24,0.15);
	--dt-shadow-deep:  0 30px 60px -30px rgba(44,33,24,0.35);

	--dt-radius-sm: 8px;
	--dt-radius-md: 16px;
	--dt-radius-lg: 22px;
	--dt-radius-xl: 30px;

	--dt-font-display: 'Fraunces', Georgia, serif;
	--dt-font-body:    'Inter', system-ui, sans-serif;
	--dt-font-script:  'Caveat', cursive;
}

/* --------------------------------------------------------------------------
   Base
   -------------------------------------------------------------------------- */
.wp-site-blocks {
	min-height: 100vh;
}

body {
	background-color: var(--dt-bg);
	color: var(--dt-ink);
	font-feature-settings: "ss01", "cv11";
	-webkit-font-smoothing: antialiased;
}

.wp-block-image img {
	height: auto;
}

.wp-block-separator {
	opacity: 1;
}

/* --------------------------------------------------------------------------
   Tipografía — fuentes por clase
   -------------------------------------------------------------------------- */
.detallista-display,
.wp-block-heading {
	font-family: var(--dt-font-display);
	font-weight: 400;
}

.detallista-script {
	font-family: var(--dt-font-script);
	font-style: normal;
}

/* --------------------------------------------------------------------------
   Eyebrow — etiqueta sobre títulos de sección
   Uso: <p class="detallista-eyebrow">Texto</p>
   -------------------------------------------------------------------------- */
.detallista-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	font-family: var(--dt-font-body);
	font-size: 0.8125rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--dt-terracotta);
	margin-bottom: 1.25rem;
}

.detallista-eyebrow::before {
	content: '';
	display: inline-block;
	width: 2.5rem;
	height: 1px;
	background: currentColor;
	flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   Textura grain — superposición decorativa
   -------------------------------------------------------------------------- */
.detallista-grain {
	position: relative;
}

.detallista-grain::after {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
	opacity: 0.4;
	mix-blend-mode: multiply;
}

/* --------------------------------------------------------------------------
   Cabecera sticky
   -------------------------------------------------------------------------- */
.detallista-site-header {
	position: sticky;
	top: 0;
	z-index: 80;
	background: rgba(248, 244, 237, 0.88);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--dt-border);
	transition: box-shadow 0.25s ease;
}

.detallista-site-header.is-scrolled {
	box-shadow: var(--dt-shadow-soft);
}

/* --------------------------------------------------------------------------
   Cards de servicios / productos
   -------------------------------------------------------------------------- */
.detallista-card {
	background: var(--dt-paper);
	border-radius: var(--dt-radius-xl);
	box-shadow: var(--dt-shadow-paper);
	overflow: hidden;
	transition: transform 0.3s ease;
}

.detallista-card:hover {
	transform: translateY(-4px);
}

.detallista-card .wp-block-image img {
	aspect-ratio: 4 / 3;
	object-fit: cover;
	width: 100%;
	transition: transform 0.7s ease;
}

.detallista-card:hover .wp-block-image img {
	transform: scale(1.04);
}

.detallista-card__body {
	padding: 2rem;
}

/* --------------------------------------------------------------------------
   Cards de producto (ficha estilo maqueta)
   -------------------------------------------------------------------------- */
.detallista-product-card {
	overflow: hidden;
}

.detallista-product-card .wp-block-image img {
	aspect-ratio: 4 / 5;
	object-fit: cover;
	width: 100%;
	border-radius: var(--dt-radius-xl);
}

/* --------------------------------------------------------------------------
   Imagen hero
   -------------------------------------------------------------------------- */
.detallista-hero-image img {
	border-radius: var(--dt-radius-xl);
	box-shadow: var(--dt-shadow-deep);
	width: 100%;
	object-fit: cover;
}

/* --------------------------------------------------------------------------
   Card flotante de testimonial (sobre imagen hero)
   -------------------------------------------------------------------------- */
.detallista-floating-card {
	background: var(--dt-paper);
	border-radius: var(--dt-radius-lg);
	box-shadow: var(--dt-shadow-paper);
	padding: 1.25rem 1.5rem;
	max-width: 280px;
	margin-top: 1rem;
}

@media (min-width: 782px) {
	.detallista-floating-card {
		position: absolute;
		bottom: -1rem;
		left: -1rem;
		margin-top: 0;
	}
}

.detallista-floating-card__quote {
	font-family: var(--dt-font-script);
	font-size: 1.1rem;
	color: var(--dt-ink);
	margin: 0 0 0.4rem;
	line-height: 1.4;
}

.detallista-floating-card__attr {
	font-family: var(--dt-font-body);
	font-size: 0.8125rem;
	color: var(--dt-muted);
	margin: 0;
}

/* --------------------------------------------------------------------------
   Testimonial centrada
   -------------------------------------------------------------------------- */
.detallista-testimonial-section {
	border-top: 1px solid var(--dt-border);
	border-bottom: 1px solid var(--dt-border);
}

.detallista-testimonial-quote {
	font-family: var(--dt-font-script);
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	color: var(--dt-terracotta);
	line-height: 1.3;
	text-align: center;
	margin: 0 0 1.25rem;
}

.detallista-testimonial-attr {
	font-family: var(--dt-font-body);
	font-size: 0.9375rem;
	color: var(--dt-muted);
	text-align: center;
	margin: 0;
}

/* --------------------------------------------------------------------------
   Tabla de catálogo
   -------------------------------------------------------------------------- */
.detallista-catalog {
	width: 100%;
	border-collapse: collapse;
}

.detallista-catalog-row {
	display: grid;
	grid-template-columns: 1fr 1fr auto;
	gap: 1rem;
	align-items: center;
	padding: 1.25rem 0;
	border-bottom: 1px solid var(--dt-border);
}

.detallista-catalog-row:first-child {
	border-top: 1px solid var(--dt-border);
}

.detallista-catalog-name {
	font-family: var(--dt-font-display);
	font-size: 1.125rem;
	margin: 0;
}

.detallista-catalog-detail {
	color: var(--dt-muted);
	font-size: 0.9375rem;
	margin: 0;
}

.detallista-catalog-price {
	font-family: var(--dt-font-body);
	font-size: 0.9375rem;
	color: var(--dt-muted);
	white-space: nowrap;
	text-align: right;
}

/* --------------------------------------------------------------------------
   Steps / Pasos numerados
   -------------------------------------------------------------------------- */
.detallista-step-card {
	background: var(--dt-cream);
	border-radius: var(--dt-radius-lg);
	padding: 2rem;
}

.detallista-step-number {
	font-family: var(--dt-font-display);
	font-size: 2.5rem;
	color: var(--dt-terracotta);
	opacity: 0.6;
	line-height: 1;
	margin: 0 0 1rem;
}

/* --------------------------------------------------------------------------
   Cards de personalización
   -------------------------------------------------------------------------- */
.detallista-custom-card {
	background: var(--dt-cream);
	border-radius: var(--dt-radius-lg);
	padding: 2rem;
	text-align: center;
}

.detallista-custom-card__icon {
	font-size: 2rem;
	color: var(--dt-terracotta);
	margin-bottom: 1rem;
}

/* --------------------------------------------------------------------------
   Botones
   -------------------------------------------------------------------------- */
.wp-block-button__link {
	transition: filter 0.2s ease, transform 0.2s ease;
	font-family: var(--dt-font-body);
}

.wp-block-button__link:hover,
.wp-block-button__link:focus-visible {
	filter: brightness(0.92);
}

.wp-block-button.is-style-outline .wp-block-button__link {
	border: 1.5px solid var(--dt-border);
	color: var(--dt-ink);
	background: transparent;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--dt-cream);
	filter: none;
}

/* --------------------------------------------------------------------------
   Sección imagen + UVPs (dos columnas)
   -------------------------------------------------------------------------- */
.detallista-uvp-item {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--dt-border);
}

.detallista-uvp-item:last-child {
	border-bottom: 0;
}

.detallista-uvp-item::before {
	content: '';
	display: inline-block;
	width: 2rem;
	height: 1px;
	background: var(--dt-terracotta);
	margin-top: 0.6rem;
	flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   WooCommerce overrides — adaptar al sistema visual del tema
   -------------------------------------------------------------------------- */
.woocommerce,
.woocommerce-page {
	font-family: var(--dt-font-body);
	color: var(--dt-ink);
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	background: var(--dt-paper);
	border-radius: var(--dt-radius-xl);
	box-shadow: var(--dt-shadow-paper);
	overflow: hidden;
	transition: transform 0.3s ease;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
	transform: translateY(-4px);
}

.woocommerce ul.products li.product img,
.woocommerce-page ul.products li.product img {
	border-radius: 0;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--dt-font-display);
	font-weight: 400;
	color: var(--dt-ink);
}

.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
	color: var(--dt-muted);
	font-size: 0.9375rem;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce-page a.button,
.woocommerce-page button.button,
.woocommerce-page input.button {
	background: var(--dt-terracotta);
	color: var(--dt-paper);
	border-radius: 999px;
	font-family: var(--dt-font-body);
	font-weight: 500;
	border: none;
	padding: 0.85rem 1.75rem;
	transition: filter 0.2s ease;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce-page a.button:hover,
.woocommerce-page button.button:hover {
	background: var(--dt-terracotta);
	color: var(--dt-paper);
	filter: brightness(0.9);
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce-page a.button.alt,
.woocommerce-page button.button.alt {
	background: var(--dt-ink);
	color: var(--dt-paper);
}

/* Formulario de checkout y carrito */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	border: 1px solid var(--dt-border);
	border-radius: var(--dt-radius-md);
	background: var(--dt-paper);
	color: var(--dt-ink);
	padding: 0.75rem 1rem;
	font-family: var(--dt-font-body);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
	border-color: var(--dt-terracotta);
	outline: none;
	box-shadow: 0 0 0 3px rgba(196, 99, 45, 0.15);
}

/* Tabla de carrito */
.woocommerce table.cart,
.woocommerce-page table.cart {
	border-collapse: collapse;
}

.woocommerce table.cart td,
.woocommerce-page table.cart td,
.woocommerce table.cart th,
.woocommerce-page table.cart th {
	border: 1px solid var(--dt-border);
	padding: 1rem;
}

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 782px) {
	.detallista-catalog-row {
		grid-template-columns: 1fr;
	}

	.detallista-catalog-price {
		text-align: left;
	}
}
