/*!
Theme Name: Blocksy Child — Micelio
Theme URI: https://miceliocreate.com
Author: Estudio Micelio
Author URI: https://miceliocreate.com
Description: Child theme de Blocksy para Micelio Create. Aísla customizaciones de marca (tipografía, paleta, componentes editoriales) del theme parent para sobrevivir auto-updates.
Version: 1.5.0
Template: blocksy
Requires PHP: 7.4
Text Domain: blocksy-child
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/

/* ============================================================
   MICELIO CREATE — Editorial Design System v1.5
   Aplicado sobre Blocksy parent vía CSS overrides en child.
   FASE 3+ — Identidad visual aplicada + perf round 2 (self-hosted Fraunces).
   ============================================================ */

/* ---------- 0. Fraunces self-hosted (perf round 2) ---------- */
@font-face {
	font-family: 'Fraunces';
	font-style: normal;
	font-weight: 300 700;
	font-display: swap;
	src: url('assets/fonts/fraunces-normal.woff2') format('woff2-variations');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: 'Fraunces';
	font-style: italic;
	font-weight: 300 700;
	font-display: swap;
	src: url('assets/fonts/fraunces-italic.woff2') format('woff2-variations');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ---------- 1. Variables (paleta + tipografía) ---------- */
:root {
	/* Paleta Micelio */
	--mc-ink: #000000;
	--mc-ink-soft: #0F0F0F;
	--mc-bone: #F4F1EA;
	--mc-bone-warm: #EBE5D8;
	--mc-paper: #FFFFFF;
	--mc-mist: #8A8A85;
	--mc-mist-light: #C9C6BE;
	--mc-ochre: #A8804E;
	--mc-ochre-bright: #C99560;
	--mc-line: rgba(0, 0, 0, 0.1);
	--mc-line-strong: rgba(0, 0, 0, 0.2);
	--mc-line-on-dark: rgba(244, 241, 234, 0.15);

	/* Familias tipográficas */
	--mc-display: 'Fraunces', Georgia, 'Times New Roman', serif;
	--mc-body: 'Inter Tight', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--mc-mono: 'JetBrains Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;
}

/* Override de la paleta interna de Blocksy para que sus internals la usen */
:root {
	--theme-palette-color-1: var(--mc-ochre);
	--theme-palette-color-2: var(--mc-ochre-bright);
	--theme-palette-color-3: var(--mc-mist);
	--theme-palette-color-4: var(--mc-ink);
	--theme-palette-color-5: var(--mc-bone-warm);
	--theme-palette-color-6: var(--mc-bone-warm);
	--theme-palette-color-7: var(--mc-bone);
	--theme-palette-color-8: var(--mc-paper);

	--theme-font-stack-default: var(--mc-body);
	--theme-text-color: var(--mc-ink-soft);
	--theme-link-initial-color: var(--mc-ink);
	--theme-link-hover-color: var(--mc-ochre);
	--theme-headings-color: var(--mc-ink);
	--theme-border-color: var(--mc-line);
	--theme-selection-text-color: var(--mc-bone);
	--theme-selection-background-color: var(--mc-ink);
}

/* ---------- 2. Base body + selección ---------- */
body {
	font-family: var(--mc-body);
	background: var(--mc-bone);
	color: var(--mc-ink-soft);
	font-weight: 400;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

::selection {
	background: var(--mc-ink);
	color: var(--mc-bone);
}

a {
	transition: color 0.25s;
}

/* ---------- 3. Tipografía (Fraunces para display, Inter para UI) ---------- */
h1, h2, h3, h4, h5,
.entry-title,
.woocommerce-loop-product__title,
.product_title,
.widget-title {
	font-family: var(--mc-display);
	color: var(--mc-ink);
	font-weight: 300;
	line-height: 1.05;
	letter-spacing: -0.02em;
	font-variation-settings: 'opsz' 144, 'SOFT' 30;
}

h1, .entry-title { font-size: clamp(2.25rem, 5vw, 3.5rem); font-weight: 300; letter-spacing: -0.025em; }
h2 { font-size: clamp(1.85rem, 4vw, 3rem); font-weight: 300; }
h3 { font-size: clamp(1.5rem, 2.75vw, 2rem); font-weight: 400; }
h4 { font-size: clamp(1.25rem, 2vw, 1.5rem); font-weight: 400; }
h5 { font-size: 1.15rem; font-weight: 500; line-height: 1.2; }

h6,
.widget-title {
	font-family: var(--mc-body);
	font-size: 0.85rem;
	font-weight: 500;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--mc-ink);
	line-height: 1.3;
}

/* Itálica editorial — sólo cuando hay <em> dentro de headings/display */
h1 em, h2 em, h3 em, h4 em,
.entry-title em, .product_title em,
.ct-section-title em, .woocommerce-loop-product__title em {
	font-style: italic;
	color: var(--mc-ochre);
	font-variation-settings: 'opsz' 144, 'SOFT' 80, 'WONK' 1;
}

p, li, dd {
	font-family: var(--mc-body);
}

/* ---------- 4. Topbar (top-row) ---------- */
[data-id="top-row"],
.ct-header [data-row*="top"] {
	background: var(--mc-ink) !important;
	color: var(--mc-bone);
}
[data-id="top-row"] *,
.ct-header [data-row*="top"] * {
	color: var(--mc-bone);
}
[data-id="top-row"] p,
.ct-header [data-row*="top"] p {
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	margin: 0;
	color: var(--mc-bone-warm) !important;
}
[data-id="top-row"] a {
	color: var(--mc-bone-warm) !important;
	text-decoration: none;
}
[data-id="top-row"] a:hover {
	color: var(--mc-ochre-bright) !important;
}

/* ---------- 5. Header / Nav (middle-row) ---------- */
.ct-header [data-row*="middle"] {
	background: var(--mc-bone) !important;
}

.ct-menu-link {
	font-family: var(--mc-body) !important;
	font-size: 0.85rem !important;
	font-weight: 500;
	letter-spacing: 0.04em;
	color: var(--mc-ink) !important;
	text-transform: none;
}
.ct-menu-link:hover,
[data-id="menu"] li:hover > .ct-menu-link {
	color: var(--mc-ochre) !important;
}

.ct-menu-link::after { display: none; }

/* Subrayado ochre en hover de menu (efecto editorial) — sólo nivel superior */
[data-id="menu"] > ul > li > .ct-menu-link {
	position: relative;
	padding-bottom: 2px;
	border-bottom: 1px solid transparent;
	transition: border-color 0.25s, color 0.25s;
}
[data-id="menu"] > ul > li > .ct-menu-link:hover {
	border-bottom-color: var(--mc-ochre);
}

/* ---------- 5.b Sub-menús (dropdown) ---------- */
/* Fondo dark de Blocksy: forzar texto bone para que sea legible. */
.sub-menu,
[data-id="menu"] .sub-menu,
.ct-mega-menu {
	background: var(--mc-ink) !important;
	border: none !important;
	border-radius: 0 !important;
	padding: 0.75rem 0 !important;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15) !important;
}

.sub-menu .ct-menu-link,
[data-id="menu"] .sub-menu .ct-menu-link,
.ct-mega-menu .ct-menu-link,
ul.sub-menu li > a {
	color: var(--mc-bone) !important;
	font-family: var(--mc-body) !important;
	font-size: 0.8rem !important;
	font-weight: 400 !important;
	letter-spacing: 0.04em !important;
	text-transform: none !important;
	padding: 0.55rem 1.5rem !important;
	border-bottom: none !important;
	display: block !important;
}

.sub-menu .ct-menu-link:hover,
[data-id="menu"] .sub-menu .ct-menu-link:hover,
.ct-mega-menu .ct-menu-link:hover,
ul.sub-menu li > a:hover {
	color: var(--mc-ochre-bright) !important;
	background: transparent !important;
	border-bottom: none !important;
}

/* Quitar separadores dashed que Blocksy a veces inyecta en dropdowns */
.sub-menu li,
[data-id="menu"] .sub-menu li {
	border: none !important;
}

/* Logo container */
[data-id="logo"] .site-logo-container img {
	max-height: 45px;
	width: auto;
}

/* ---------- 6. Buttons (universal override) ---------- */
.wp-block-button__link,
.button,
button.button,
button[type="submit"],
input[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce-page button.button,
.woocommerce-page input.button,
.woocommerce .single_add_to_cart_button,
.added_to_cart,
.checkout-button,
.ct-button {
	font-family: var(--mc-body) !important;
	font-size: 0.78rem !important;
	font-weight: 500 !important;
	letter-spacing: 0.12em !important;
	text-transform: uppercase !important;
	padding: 1rem 1.75rem !important;
	border: 1px solid var(--mc-ink) !important;
	background: var(--mc-ink) !important;
	color: var(--mc-bone) !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	transition: background 0.25s, border-color 0.25s, color 0.25s !important;
	min-height: 45px !important;
	line-height: 1.2 !important;
	text-decoration: none !important;
}

.wp-block-button__link:hover,
.button:hover,
button.button:hover,
button[type="submit"]:hover,
input[type="submit"]:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .single_add_to_cart_button:hover,
.added_to_cart:hover,
.checkout-button:hover {
	background: var(--mc-ochre) !important;
	border-color: var(--mc-ochre) !important;
	color: var(--mc-bone) !important;
}

/* Ghost / secondary button — usa class .is-style-outline o .ct-button.ghost */
.wp-block-button.is-style-outline .wp-block-button__link,
.ct-button.ghost,
.button.alt,
.button.outline {
	background: transparent !important;
	color: var(--mc-ink) !important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover,
.ct-button.ghost:hover,
.button.alt:hover,
.button.outline:hover {
	background: var(--mc-ink) !important;
	color: var(--mc-bone) !important;
}

/* ---------- 7. Product cards (loop) ---------- */
.products .product,
[data-products] .product {
	background: var(--mc-paper);
	border: 1px solid var(--mc-line);
	transition: border-color 0.3s, transform 0.3s;
	padding: 0 !important;
}
.products .product:hover,
[data-products] .product:hover {
	border-color: var(--mc-ink);
	transform: translateY(-2px);
}

.products .product .woocommerce-loop-product__title,
[data-products] .product .woocommerce-loop-product__title {
	font-family: var(--mc-display) !important;
	font-weight: 400 !important;
	font-size: 1.0625rem !important;
	letter-spacing: -0.01em !important;
	line-height: 1.2 !important;
	color: var(--mc-ink) !important;
	padding: 0 1rem;
}

.products .product .price,
[data-products] .product .price {
	font-family: var(--mc-mono) !important;
	font-size: 0.95rem !important;
	font-weight: 500 !important;
	color: var(--mc-ink) !important;
	letter-spacing: 0 !important;
	padding: 0 1rem 1rem;
}

.products .product .price del { color: var(--mc-mist) !important; }
.products .product .price ins { background: transparent !important; }

/* Sale badge */
.onsale,
[class*="ct-woo-badge-"] {
	background: var(--mc-ochre) !important;
	color: var(--mc-bone) !important;
	font-family: var(--mc-mono) !important;
	font-size: 0.65rem !important;
	letter-spacing: 0.12em !important;
	text-transform: uppercase !important;
	border-radius: 0 !important;
	padding: 0.3rem 0.55rem !important;
	font-weight: 500 !important;
}

/* Product image hover */
.products .product .woocommerce-LoopProduct-link {
	display: block;
	overflow: hidden;
	background: var(--mc-bone-warm);
}

/* "Add to cart" en loop */
.products .product .add_to_cart_button,
.products .product .button.add_to_cart_button {
	margin: 0 1rem 1rem !important;
	width: calc(100% - 2rem) !important;
	display: block !important;
	text-align: center !important;
}

/* ---------- 8. Single product (ficha) ---------- */
.single-product div.product .entry-title,
.single-product div.product .product_title {
	font-family: var(--mc-display) !important;
	font-size: clamp(1.75rem, 3.5vw, 2.5rem) !important;
	font-weight: 300 !important;
	letter-spacing: -0.02em !important;
	color: var(--mc-ink) !important;
	margin-bottom: 1rem !important;
}

.single-product div.product .price {
	font-family: var(--mc-mono) !important;
	font-size: 1.3rem !important;
	font-weight: 500 !important;
	color: var(--mc-ink) !important;
	margin-bottom: 1.5rem !important;
}

.single-product div.product .woocommerce-product-details__short-description {
	font-family: var(--mc-body);
	color: var(--mc-ink-soft);
	font-size: 1.0625rem;
	line-height: 1.6;
}

/* Trust signals debajo del CTA — los inserto vía CSS pseudo-element */
.single-product div.product form.cart::after {
	content: "Producción 3–5 días · Hecho en CDMX · Devoluciones por defecto de impresión";
	display: block;
	margin-top: 1.25rem;
	padding-top: 1.25rem;
	border-top: 1px solid var(--mc-line);
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mc-mist);
	text-align: left;
}

/* Tabs de descripción */
.woocommerce-tabs .tabs li a,
.woocommerce-tabs[data-type] .tabs li a {
	font-family: var(--mc-body) !important;
	font-size: 0.75rem !important;
	letter-spacing: 0.12em !important;
	text-transform: uppercase !important;
	font-weight: 600 !important;
	color: var(--mc-mist) !important;
}
.woocommerce-tabs .tabs li.active a,
.woocommerce-tabs[data-type] .tabs li.active a {
	color: var(--mc-ink) !important;
}

/* ---------- 9. Footer ---------- */
.ct-footer {
	background: var(--mc-ink) !important;
	color: var(--mc-bone);
}
.ct-footer * { color: inherit; }

.ct-footer .widget-title {
	font-family: var(--mc-mono) !important;
	font-size: 0.72rem !important;
	letter-spacing: 0.18em !important;
	text-transform: uppercase !important;
	color: var(--mc-ochre-bright) !important;
	font-weight: 500 !important;
	margin-bottom: 1.25rem !important;
}

.ct-footer .menu li a,
.ct-footer a {
	font-family: var(--mc-body);
	font-size: 0.85rem;
	color: var(--mc-bone) !important;
	letter-spacing: 0;
	text-transform: none;
	font-weight: 400;
	border-bottom: none !important;
	padding: 0.35rem 0;
	display: inline-block;
}
.ct-footer .menu li a:hover,
.ct-footer a:hover {
	color: var(--mc-ochre-bright) !important;
}

.ct-footer [data-id="copyright"] {
	background: var(--mc-ink) !important;
	color: var(--mc-mist-light) !important;
}
.ct-footer [data-id="copyright"] * {
	color: var(--mc-mist-light) !important;
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* ---------- 10. Joinchat (WhatsApp flotante) ---------- */
.joinchat--right .joinchat__button {
	background: var(--mc-ink) !important;
	color: var(--mc-bone) !important;
	border-radius: 999px !important;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18) !important;
	transition: background 0.3s, transform 0.3s !important;
}
.joinchat--right .joinchat__button:hover {
	background: var(--mc-ochre) !important;
	transform: translateY(-2px) !important;
}
.joinchat .joinchat__tooltip {
	background: var(--mc-ink) !important;
	color: var(--mc-bone) !important;
	font-family: var(--mc-body) !important;
	font-size: 0.8rem !important;
	font-weight: 500 !important;
}
.joinchat .joinchat__message {
	background: var(--mc-paper) !important;
	color: var(--mc-ink) !important;
	border-radius: 0 !important;
	font-family: var(--mc-body) !important;
}

/* ---------- 11. ACOWFA form (Personalización por demanda) ---------- */
.wcpa-front-form-section .wcpa-front-form-section-header,
.wcpa-form-outer h2,
.wcpa-form-outer h3 {
	font-family: var(--mc-display) !important;
	color: var(--mc-ink) !important;
	letter-spacing: -0.015em !important;
	font-weight: 400 !important;
}

.wcpa-form-outer label {
	font-family: var(--mc-body) !important;
	font-weight: 500 !important;
	color: var(--mc-ink) !important;
}

.wcpa-form-outer input[type="text"],
.wcpa-form-outer textarea,
.wcpa-form-outer select {
	border: 1px solid var(--mc-line-strong) !important;
	border-radius: 0 !important;
	background: var(--mc-paper) !important;
	font-family: var(--mc-body) !important;
}

.wcpa-form-outer a {
	color: var(--mc-ochre) !important;
	font-weight: 500;
	border-bottom: 1px solid var(--mc-ochre);
}
.wcpa-form-outer a:hover {
	color: var(--mc-ink) !important;
	border-bottom-color: var(--mc-ink);
}

/* ---------- 12. Formularios genéricos ---------- */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="password"],
input[type="number"],
textarea,
select {
	font-family: var(--mc-body);
	border: 1px solid var(--mc-line-strong);
	border-radius: 0;
	background: var(--mc-paper);
	padding: 0.7rem 0.9rem;
	color: var(--mc-ink);
	font-size: 0.95rem;
	transition: border-color 0.25s;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
textarea:focus,
select:focus {
	border-color: var(--mc-ink);
	outline: none;
}

/* ---------- 13. WooCommerce cart + checkout ---------- */
.woocommerce-cart table.shop_table,
.woocommerce-checkout table.shop_table {
	border: 1px solid var(--mc-line-strong);
	border-radius: 0;
	background: var(--mc-paper);
}
.woocommerce-cart table.shop_table th,
.woocommerce-checkout table.shop_table th {
	font-family: var(--mc-body);
	font-size: 0.75rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--mc-ink);
}

/* ---------- 14. Breadcrumbs ---------- */
.ct-breadcrumbs {
	font-family: var(--mc-body) !important;
	font-size: 0.75rem !important;
	letter-spacing: 0.05em !important;
	color: var(--mc-mist) !important;
}
.ct-breadcrumbs a {
	color: var(--mc-mist) !important;
}
.ct-breadcrumbs a:hover {
	color: var(--mc-ink) !important;
}

/* ---------- 15. Hero / page titles ---------- */
.entry-header .page-title,
[data-prefix*="page"] .entry-header .page-title,
[data-prefix*="product"] .entry-header .page-title {
	font-family: var(--mc-display) !important;
	font-weight: 300 !important;
	letter-spacing: -0.025em !important;
	color: var(--mc-ink) !important;
}

/* ---------- 16. Page backgrounds ---------- */
.tienda,
.woocommerce-shop,
[data-prefix="woo_categories"] {
	background: var(--mc-bone);
}

/* ---------- 17. Quitar bordes/radius ruidosos ---------- */
.ct-cart-icon-wrapper .ct-dynamic-count-shop {
	border-radius: 0 !important;
	background: var(--mc-ink) !important;
	color: var(--mc-bone) !important;
	font-family: var(--mc-mono);
	font-size: 0.65rem;
	font-weight: 500;
}

/* ---------- 18. Misc cleanups ---------- */
.ct-meta-element-author,
.ct-meta-element-categories a {
	color: var(--mc-mist) !important;
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* ============================================================
   FASE 4 — Páginas editoriales
   Clases reutilizables para Sobre Micelio, Cómo funciona, Para marcas.
   Scope: page-level layouts. No afecta el resto del sitio.
   ============================================================ */

.mc-page {
	font-family: var(--mc-body);
	color: var(--mc-ink-soft);
	max-width: 1280px;
	margin: 0 auto;
}

/* Hero narrativo */
.mc-hero {
	padding: clamp(2.5rem, 6vw, 5rem) clamp(1.25rem, 4vw, 3rem);
	border-bottom: 1px solid var(--mc-line);
}
.mc-hero-eyebrow {
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--mc-ochre);
	margin-bottom: 2rem;
	display: flex;
	align-items: center;
	gap: 1rem;
}
.mc-hero-eyebrow::before {
	content: "";
	flex: 0 0 48px;
	height: 1px;
	background: var(--mc-ochre);
}
.mc-hero-title {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(2.5rem, 8vw, 6.5rem);
	line-height: 0.92;
	letter-spacing: -0.035em;
	color: var(--mc-ink);
	max-width: 18ch;
	margin: 0 0 clamp(1.5rem, 3vw, 2.5rem);
	font-variation-settings: 'opsz' 144, 'SOFT' 25;
}
.mc-hero-title em {
	font-style: italic;
	color: var(--mc-ochre);
	font-variation-settings: 'opsz' 144, 'SOFT' 80, 'WONK' 1;
	font-weight: 300;
}
.mc-hero-bottom {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	padding-top: 2rem;
	border-top: 1px solid var(--mc-line);
}
@media (min-width: 800px) {
	.mc-hero-bottom { grid-template-columns: 1fr 1fr; gap: 3rem; align-items: end; }
}
.mc-hero-lede {
	font-size: clamp(1rem, 1.4vw, 1.2rem);
	line-height: 1.55;
	color: var(--mc-ink-soft);
	max-width: 32rem;
}
.mc-hero-lede strong {
	font-weight: 500;
	font-family: var(--mc-display);
	font-style: italic;
	color: var(--mc-ink);
}
.mc-hero-stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem;
}
.mc-hero-stat {
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mc-mist);
}
.mc-hero-stat strong {
	display: block;
	font-family: var(--mc-display);
	font-weight: 300;
	font-style: italic;
	font-size: clamp(2rem, 3.5vw, 2.75rem);
	color: var(--mc-ink);
	line-height: 1;
	margin-bottom: 0.35rem;
	font-variation-settings: 'opsz' 144, 'SOFT' 80, 'WONK' 1;
	letter-spacing: -0.02em;
}
.mc-hero-stat strong .acc {
	color: var(--mc-ochre);
}

/* Prose blocks (origen, nombre, estudio, proceso) */
.mc-prose {
	max-width: 720px;
	margin: 0 auto;
	padding: clamp(3rem, 5vw, 4.5rem) clamp(1.25rem, 4vw, 3rem);
}
.mc-prose-eyebrow {
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--mc-mist);
	margin-bottom: 1.5rem;
	display: flex;
	align-items: center;
	gap: 1rem;
}
.mc-prose-eyebrow strong { color: var(--mc-ink); font-weight: 500; }
.mc-prose-eyebrow::before {
	content: "";
	flex: 0 0 32px;
	height: 1px;
	background: currentColor;
	opacity: 0.4;
}
.mc-prose h2 {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.85rem, 4vw, 3rem);
	line-height: 1;
	letter-spacing: -0.025em;
	margin-bottom: 1.5rem;
	max-width: 22ch;
	color: var(--mc-ink);
}
.mc-prose h2 em {
	font-style: italic;
	color: var(--mc-ochre);
	font-variation-settings: 'opsz' 144, 'SOFT' 80, 'WONK' 1;
}
.mc-prose .lead {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.3rem, 2.2vw, 1.7rem);
	line-height: 1.35;
	color: var(--mc-ink);
	margin-bottom: 1.75rem;
	letter-spacing: -0.015em;
}
.mc-prose .lead em {
	font-style: italic;
	color: var(--mc-ochre);
}
.mc-prose p {
	font-size: 1.0625rem;
	line-height: 1.65;
	margin: 0 0 1.25rem;
	color: var(--mc-ink-soft);
}
.mc-prose p strong { color: var(--mc-ink); font-weight: 500; }
.mc-prose p em {
	font-family: var(--mc-display);
	font-style: italic;
	color: var(--mc-ink);
}
.mc-prose hr {
	border: 0;
	height: 1px;
	background: var(--mc-line);
	width: 4rem;
	margin: 2.5rem 0;
}

/* Full quote band (dark) */
.mc-full-quote {
	background: var(--mc-ink);
	color: var(--mc-bone);
	padding: clamp(4rem, 8vw, 7rem) clamp(1.25rem, 4vw, 3rem);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.mc-full-quote::before {
	content: "°";
	position: absolute;
	top: -2rem;
	left: 50%;
	transform: translateX(-50%);
	font-family: var(--mc-display);
	font-style: italic;
	font-size: 20rem;
	color: var(--mc-ochre);
	opacity: 0.07;
	line-height: 1;
	pointer-events: none;
	font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.mc-full-quote-text {
	position: relative;
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.8rem, 4.5vw, 3.5rem);
	line-height: 1.1;
	letter-spacing: -0.025em;
	max-width: 24ch;
	margin: 0 auto;
	font-variation-settings: 'opsz' 144, 'SOFT' 30;
	color: var(--mc-bone);
}
.mc-full-quote-text em {
	font-style: italic;
	color: var(--mc-ochre-bright);
	font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.mc-full-quote-sig {
	position: relative;
	margin-top: 2.5rem;
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--mc-mist-light);
}
.mc-full-quote-sig::before { content: "— "; color: var(--mc-ochre-bright); }

/* Band wrappers */
.mc-band {
	padding: clamp(3rem, 5vw, 4.5rem) clamp(1.25rem, 4vw, 3rem);
}
.mc-band.warm { background: var(--mc-bone-warm); }
.mc-band.dark { background: var(--mc-ink); color: var(--mc-bone); }
.mc-band.dark .mc-prose-eyebrow strong { color: var(--mc-bone); }
.mc-band-inner { max-width: 1280px; margin: 0 auto; }
.mc-band-inner.prose { max-width: 720px; }

/* Principles grid (5 principios) */
.mc-principles {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	border-top: 1px solid var(--mc-line-strong);
	margin-top: 2.5rem;
}
@media (min-width: 800px) { .mc-principles { grid-template-columns: 1fr 1fr; } }
.mc-principle {
	padding: 2.25rem 1.5rem 2.25rem 0;
	border-bottom: 1px solid var(--mc-line-strong);
}
@media (min-width: 800px) {
	.mc-principle:nth-child(odd) { border-right: 1px solid var(--mc-line-strong); padding-right: 2rem; }
	.mc-principle:nth-child(even) { padding-left: 2rem; padding-right: 0; }
}
.mc-principle-num {
	font-family: var(--mc-display);
	font-style: italic;
	font-weight: 300;
	font-size: 1.15rem;
	color: var(--mc-ochre);
	margin-bottom: 0.85rem;
	font-variation-settings: 'opsz' 72, 'SOFT' 100, 'WONK' 1;
}
.mc-principle-num::before { content: "— "; }
.mc-principle h3 {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.4rem, 2.4vw, 1.85rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	margin: 0 0 0.75rem;
	color: var(--mc-ink);
}
.mc-principle h3 em {
	font-style: italic;
	color: var(--mc-ochre);
	font-variation-settings: 'opsz' 144, 'SOFT' 80, 'WONK' 1;
}
.mc-principle p {
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--mc-ink-soft);
	margin: 0;
}

/* No-list (lo que rechazamos — sobre fondo dark) */
.mc-no-list {
	display: flex;
	flex-direction: column;
	gap: 0;
	border-top: 1px solid var(--mc-line-on-dark);
	margin-top: 2rem;
}
.mc-no-item {
	padding: 1.5rem 0;
	border-bottom: 1px solid var(--mc-line-on-dark);
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.5rem;
}
@media (min-width: 700px) {
	.mc-no-item { grid-template-columns: 1fr 2fr; gap: 2rem; align-items: baseline; }
}
.mc-no-tag {
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--mc-ochre-bright);
}
.mc-no-tag::before { content: "✕ "; color: var(--mc-ochre-bright); margin-right: 0.25rem; }
.mc-no-text {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.05rem, 1.7vw, 1.3rem);
	line-height: 1.35;
	letter-spacing: -0.01em;
	color: var(--mc-bone);
	margin: 0;
}
.mc-no-text em {
	font-style: italic;
	color: var(--mc-ochre-bright);
	font-variation-settings: 'opsz' 72, 'SOFT' 80, 'WONK' 1;
}

/* Audience numbered (4 perfiles) */
.mc-audience {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	margin-top: 2.5rem;
}
.mc-aud-row {
	display: grid;
	grid-template-columns: 60px 1fr;
	gap: 1.5rem;
	padding: 1.5rem 0;
	border-top: 1px solid var(--mc-line);
	align-items: start;
}
.mc-aud-row:last-child { border-bottom: 1px solid var(--mc-line); }
.mc-aud-num {
	font-family: var(--mc-display);
	font-style: italic;
	font-weight: 300;
	font-size: 1.4rem;
	color: var(--mc-ochre);
	font-variation-settings: 'opsz' 72, 'SOFT' 100, 'WONK' 1;
	line-height: 1;
}
.mc-aud-title {
	font-family: var(--mc-display);
	font-weight: 400;
	font-size: 1.2rem;
	margin: 0 0 0.4rem;
	letter-spacing: -0.01em;
	color: var(--mc-ink);
}
.mc-aud-body {
	font-size: 0.92rem;
	color: var(--mc-ink-soft);
	line-height: 1.55;
	margin: 0;
}

/* 4-step grid (Cómo funciona) */
.mc-steps {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	border-top: 1px solid var(--mc-line);
	margin-top: 2rem;
}
@media (min-width: 720px) { .mc-steps { grid-template-columns: repeat(4, 1fr); } }
.mc-step {
	padding: 2rem 1.25rem;
	border-bottom: 1px solid var(--mc-line);
}
@media (min-width: 720px) {
	.mc-step { border-right: 1px solid var(--mc-line); border-bottom: 0; }
	.mc-step:last-child { border-right: 0; }
}
.mc-step-num {
	font-family: var(--mc-display);
	font-weight: 300;
	font-style: italic;
	font-size: 2.75rem;
	line-height: 1;
	color: var(--mc-ochre);
	font-variation-settings: 'opsz' 144, 'SOFT' 80, 'WONK' 1;
	margin-bottom: 0.85rem;
}
.mc-step h4 {
	font-family: var(--mc-display);
	font-weight: 400;
	font-size: 1.15rem;
	letter-spacing: -0.01em;
	margin: 0 0 0.4rem;
	color: var(--mc-ink);
}
.mc-step p {
	font-size: 0.9rem;
	line-height: 1.5;
	color: var(--mc-ink-soft);
	margin: 0;
}

/* Closing CTA (dark) */
.mc-closing {
	background: var(--mc-ink);
	color: var(--mc-bone);
	padding: clamp(3.5rem, 7vw, 6rem) clamp(1.25rem, 4vw, 3rem);
	text-align: center;
}
.mc-closing-eyebrow {
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--mc-ochre-bright);
	margin-bottom: 1.25rem;
}
.mc-closing-text {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.8rem, 4.5vw, 3.5rem);
	line-height: 1;
	letter-spacing: -0.03em;
	max-width: 22ch;
	margin: 0 auto 2rem;
	color: var(--mc-bone);
	font-variation-settings: 'opsz' 144, 'SOFT' 30;
}
.mc-closing-text em {
	font-style: italic;
	color: var(--mc-ochre-bright);
	font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.mc-closing-cta {
	display: flex;
	gap: 0.75rem;
	justify-content: center;
	flex-wrap: wrap;
}
.mc-closing-cta .button,
.mc-closing-cta a.button {
	background: var(--mc-bone) !important;
	color: var(--mc-ink) !important;
	border-color: var(--mc-bone) !important;
}
.mc-closing-cta .button.outline,
.mc-closing-cta .button.alt {
	background: transparent !important;
	color: var(--mc-bone) !important;
	border-color: var(--mc-bone) !important;
}
.mc-closing-cta .button:hover {
	background: var(--mc-ochre) !important;
	border-color: var(--mc-ochre) !important;
	color: var(--mc-bone) !important;
}

/* B2B form layout (Para marcas) */
.mc-b2b-form {
	max-width: 720px;
	margin: 0 auto;
	padding: clamp(2.5rem, 5vw, 4rem) clamp(1.25rem, 4vw, 3rem);
}
.mc-b2b-form .wpforms-field-label {
	font-family: var(--mc-mono) !important;
	font-size: 0.7rem !important;
	letter-spacing: 0.15em !important;
	text-transform: uppercase !important;
	color: var(--mc-mist) !important;
	font-weight: 500 !important;
}

/* Esconder Blocksy hero/title default en estas páginas (usamos el hero propio) */
.page-template-default .mc-page ~ .ct-breadcrumbs,
.mc-page-no-hero .entry-header {
	display: none;
}

/* ============================================================
   Perf — mitigación CLS Stackable images
   Reserva espacio para img dentro de bloques Stackable sin dimensiones
   ============================================================ */
.wp-block-stackable-image,
.stk-block-image {
	contain-intrinsic-size: 1px 400px;
}
.wp-block-stackable-image img,
.stk-block-image img {
	max-width: 100%;
	height: auto;
}
.wp-block-stackable-image:has(img:not([width])),
.stk-block-image:has(img:not([width])) {
	min-height: 240px;
}

/* ============================================================
   FASE 6 — Home editorial
   Componentes específicos del home: hero split, marquee, paths,
   triptych categorías, B2B band, CDMX band.
   ============================================================ */

.mc-home {
	max-width: 1280px;
	margin: 0 auto;
}

/* Hero split (mockup pattern) */
.mc-home-hero {
	display: grid;
	grid-template-columns: 1fr;
	border-bottom: 1px solid var(--mc-ink);
	background: var(--mc-bone);
}
@media (min-width: 900px) {
	.mc-home-hero { grid-template-columns: 1.1fr 0.9fr; }
}
.mc-home-hero-left {
	padding: clamp(2.5rem, 5vw, 5rem) clamp(1.25rem, 4vw, 3rem);
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-right: 1px solid var(--mc-ink);
}
@media (max-width: 899px) { .mc-home-hero-left { border-right: 0; border-bottom: 1px solid var(--mc-ink); } }
.mc-home-hero-meta {
	display: flex;
	gap: 1.5rem;
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--mc-mist);
	margin-bottom: 2.5rem;
	flex-wrap: wrap;
}
.mc-home-hero-meta strong { color: var(--mc-ink); font-weight: 500; }
.mc-home-hero-title {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(2.5rem, 7vw, 5.5rem);
	line-height: 0.92;
	letter-spacing: -0.03em;
	margin: 0 0 clamp(1.25rem, 3vw, 2rem);
	color: var(--mc-ink);
	max-width: 18ch;
}
.mc-home-hero-title em {
	font-style: italic;
	color: var(--mc-ochre);
	font-weight: 300;
}
.mc-home-hero-title .glyph {
	color: var(--mc-ochre);
	font-style: italic;
}
.mc-home-hero-lede {
	font-size: clamp(1rem, 1.35vw, 1.125rem);
	line-height: 1.55;
	color: var(--mc-ink-soft);
	max-width: 30rem;
	margin: 0 0 1.75rem;
}
.mc-home-hero-lede strong {
	font-weight: 500;
	font-family: var(--mc-display);
	font-style: italic;
	color: var(--mc-ink);
}
.mc-home-hero-cta {
	display: flex;
	gap: 0.65rem;
	flex-wrap: wrap;
	margin-bottom: 2rem;
}
.mc-home-hero-trust {
	display: flex;
	gap: 1.75rem;
	flex-wrap: wrap;
	padding-top: 1.5rem;
	border-top: 1px solid var(--mc-line);
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--mc-mist);
}
.mc-home-hero-trust span { display: inline-flex; align-items: center; gap: 0.5rem; }
.mc-home-hero-trust span::before {
	content: "°";
	color: var(--mc-ochre);
	font-family: var(--mc-display);
	font-style: italic;
	font-size: 1.15rem;
}
.mc-home-hero-right {
	background: var(--mc-ink);
	color: var(--mc-bone);
	min-height: 360px;
	display: flex;
	align-items: flex-end;
	position: relative;
	overflow: hidden;
	aspect-ratio: 4 / 5;
}
@media (min-width: 900px) {
	.mc-home-hero-right {
		aspect-ratio: auto;
		max-height: 600px;
	}
}
@media (min-width: 1280px) {
	.mc-home-hero-right {
		max-height: 700px;
	}
}
.mc-home-hero-right img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mc-home-hero-right-overlay {
	position: relative;
	z-index: 2;
	padding: 1.25rem 1.5rem;
	width: 100%;
	background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 100%);
	display: flex;
	justify-content: space-between;
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mc-mist-light);
	flex-wrap: wrap;
	gap: 0.5rem;
}
.mc-home-hero-right-overlay strong { color: var(--mc-bone); font-weight: 500; display: block; }
.mc-home-hero-tag {
	position: absolute;
	top: 1.5rem; left: 1.5rem;
	z-index: 2;
	font-family: var(--mc-mono);
	font-size: 0.65rem;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	background: var(--mc-ochre);
	color: var(--mc-ink);
	padding: 0.4rem 0.7rem;
	font-weight: 500;
}

/* Marquee (brand words) */
.mc-marquee {
	overflow: hidden;
	border-bottom: 1px solid var(--mc-ink);
	background: var(--mc-bone);
	padding: 0.95rem 0;
}
.mc-marquee-track {
	display: flex;
	gap: 3rem;
	animation: mc-marquee 32s linear infinite;
	white-space: nowrap;
	align-items: center;
	width: max-content;
}
.mc-marquee-item {
	font-family: var(--mc-display);
	font-style: italic;
	font-weight: 300;
	font-size: clamp(1.3rem, 3vw, 2.25rem);
	letter-spacing: -0.02em;
	flex-shrink: 0;
	color: var(--mc-ink);
}
.mc-marquee-item .glyph {
	color: var(--mc-ochre);
	margin: 0 1.5rem;
	font-size: 0.7em;
}
@keyframes mc-marquee {
	from { transform: translateX(0); }
	to { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.mc-marquee-track { animation: none; }
}

/* Section headers reutilizables (eyebrow + title + lede) */
.mc-section {
	padding: clamp(3rem, 6vw, 5rem) clamp(1.25rem, 4vw, 3rem);
}
.mc-section.dark { background: var(--mc-ink); color: var(--mc-bone); }
.mc-section.warm { background: var(--mc-bone-warm); }
.mc-section-inner { max-width: 1280px; margin: 0 auto; }
.mc-section-header {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
	align-items: end;
	margin-bottom: clamp(2rem, 4vw, 3rem);
}
@media (min-width: 800px) {
	.mc-section-header { grid-template-columns: 1.4fr 0.6fr; gap: 3rem; }
}
.mc-section-eyebrow {
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--mc-mist);
	margin-bottom: 1rem;
	display: flex;
	align-items: center;
	gap: 1rem;
}
.mc-section-eyebrow strong { color: var(--mc-ink); font-weight: 500; }
.mc-section.dark .mc-section-eyebrow { color: var(--mc-mist-light); }
.mc-section.dark .mc-section-eyebrow strong { color: var(--mc-bone); }
.mc-section-eyebrow::before {
	content: "";
	flex: 0 0 32px;
	height: 1px;
	background: currentColor;
	opacity: 0.4;
}
.mc-section-title {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.85rem, 4vw, 3.25rem);
	line-height: 0.98;
	letter-spacing: -0.025em;
	margin: 0 0 1rem;
	max-width: 40rem;
	color: var(--mc-ink);
}
.mc-section.dark .mc-section-title { color: var(--mc-bone); }
.mc-section-title em {
	font-style: italic;
	color: var(--mc-ochre);
}
.mc-section.dark .mc-section-title em { color: var(--mc-ochre-bright); }
.mc-section-lede {
	font-size: 1rem;
	line-height: 1.55;
	color: var(--mc-ink-soft);
	max-width: 36rem;
	margin: 0;
}
.mc-section.dark .mc-section-lede { color: var(--mc-mist-light); }
.mc-section-cta {
	display: flex;
	align-items: flex-end;
	justify-content: flex-end;
}

/* Three paths (personalización) */
.mc-paths {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	border-top: 1px solid var(--mc-ink);
	border-bottom: 1px solid var(--mc-ink);
}
@media (min-width: 900px) { .mc-paths { grid-template-columns: repeat(3, 1fr); } }
.mc-path {
	padding: clamp(1.75rem, 3vw, 2.5rem) clamp(1.5rem, 2.5vw, 2rem);
	border-right: 1px solid var(--mc-ink);
	background: var(--mc-bone);
	display: flex;
	flex-direction: column;
	min-height: 360px;
	text-decoration: none;
	color: var(--mc-ink);
	transition: background 0.4s, color 0.4s;
}
@media (max-width: 899px) {
	.mc-path { border-right: 0; border-bottom: 1px solid var(--mc-ink); min-height: auto; }
	.mc-path:last-child { border-bottom: 0; }
}
.mc-path:last-child { border-right: 0; }
.mc-path:hover { background: var(--mc-ink); color: var(--mc-bone); }
.mc-path:hover .mc-path-num,
.mc-path:hover .mc-path-arrow { color: var(--mc-ochre-bright); }
.mc-path:hover .mc-path-rule { background: var(--mc-bone); }
.mc-path-top {
	display: flex;
	justify-content: space-between;
	margin-bottom: 1.25rem;
	align-items: flex-start;
}
.mc-path-num {
	font-family: var(--mc-mono);
	font-size: 0.8rem;
	color: var(--mc-mist);
	transition: color 0.4s;
}
.mc-path-tag {
	font-family: var(--mc-mono);
	font-size: 0.65rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	background: var(--mc-ochre);
	color: var(--mc-ink);
	padding: 0.25rem 0.55rem;
	font-weight: 500;
}
.mc-path-title {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.5rem, 2.75vw, 2rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	margin: 0 0 0.85rem;
}
.mc-path-title em {
	font-style: italic;
	color: inherit;
}
.mc-path:not(:hover) .mc-path-title em { color: var(--mc-ochre); }
.mc-path-body {
	font-size: 0.92rem;
	line-height: 1.55;
	margin: 0 0 1.5rem;
	flex: 1;
	color: inherit;
}
.mc-path-rule {
	width: 32px;
	height: 1px;
	background: currentColor;
	margin-bottom: 1rem;
	transition: background 0.4s;
}
.mc-path-cta {
	font-family: var(--mc-mono);
	font-size: 0.75rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	display: flex;
	justify-content: space-between;
	margin-top: auto;
	font-weight: 500;
	align-items: center;
}
.mc-path-arrow {
	font-size: 1.5rem;
	font-family: var(--mc-display);
	font-style: italic;
	transition: transform 0.4s, color 0.4s;
}
.mc-path:hover .mc-path-arrow { transform: translateX(4px); }

/* Categories triptych (Vestible / Portable / Habitable) */
.mc-cat-triptych {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	margin-top: 1rem;
}
@media (min-width: 800px) {
	.mc-cat-triptych { grid-template-columns: repeat(3, 1fr); }
}
.mc-cat-tile {
	position: relative;
	aspect-ratio: 4/5;
	background: var(--mc-ink);
	color: var(--mc-bone);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 1.5rem;
	text-decoration: none;
	overflow: hidden;
	transition: transform 0.4s;
}
.mc-cat-tile:hover { transform: scale(1.01); }
.mc-cat-tile-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	opacity: 0.5;
	transition: opacity 0.4s, transform 0.4s;
}
.mc-cat-tile:hover .mc-cat-tile-bg { opacity: 0.65; transform: scale(1.05); }
.mc-cat-tile.vestible .mc-cat-tile-bg {
	background: radial-gradient(ellipse at 30% 20%, rgba(168,128,78,0.45) 0%, transparent 55%),
		linear-gradient(180deg, #1a1a1a 0%, #000 100%);
}
.mc-cat-tile.portable .mc-cat-tile-bg {
	background: radial-gradient(ellipse at 70% 80%, rgba(168,128,78,0.4) 0%, transparent 55%),
		linear-gradient(135deg, #0f0f0f 0%, #1f1f1f 100%);
}
.mc-cat-tile.habitable .mc-cat-tile-bg {
	background: radial-gradient(ellipse at 50% 50%, rgba(168,128,78,0.35) 0%, transparent 60%),
		linear-gradient(180deg, #181818 0%, #050505 100%);
}
.mc-cat-tile > * { position: relative; z-index: 1; }
.mc-cat-top {
	display: flex;
	justify-content: space-between;
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mc-mist-light);
}
.mc-cat-top strong { color: var(--mc-ochre-bright); }
.mc-cat-title {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.85rem, 3.5vw, 2.75rem);
	line-height: 0.95;
	letter-spacing: -0.02em;
	margin: 0;
	color: var(--mc-bone);
}
.mc-cat-title em {
	font-style: italic;
	color: var(--mc-ochre-bright);
}
.mc-cat-bottom {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	color: var(--mc-mist-light);
}
.mc-cat-sub {
	font-size: 0.85rem;
	line-height: 1.4;
	max-width: 14rem;
}
.mc-cat-arrow {
	font-family: var(--mc-display);
	font-style: italic;
	font-size: 2rem;
	color: var(--mc-ochre-bright);
	transition: transform 0.3s;
}
.mc-cat-tile:hover .mc-cat-arrow { transform: translateX(6px); }

/* B2B band */
.mc-b2b-band {
	background: var(--mc-bone-warm);
	padding: clamp(2.5rem, 5vw, 4rem) clamp(1.25rem, 4vw, 3rem);
	border-top: 1px solid var(--mc-ink);
	border-bottom: 1px solid var(--mc-ink);
}
.mc-b2b-inner {
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: center;
}
@media (min-width: 900px) { .mc-b2b-inner { grid-template-columns: 1fr auto; } }
.mc-b2b-title {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.45rem, 2.8vw, 2.25rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	max-width: 32rem;
	margin: 0;
	color: var(--mc-ink);
}
.mc-b2b-title em {
	font-style: italic;
	color: var(--mc-ochre);
}
.mc-b2b-meta {
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mc-mist);
	margin-top: 0.65rem;
}

/* CDMX band (dark, centered) */
.mc-cdmx-band {
	background: var(--mc-ink);
	color: var(--mc-bone);
	padding: clamp(3.5rem, 6vw, 5rem) clamp(1.25rem, 4vw, 3rem);
	text-align: center;
}
.mc-cdmx-tag {
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--mc-ochre-bright);
	margin-bottom: 1rem;
}
.mc-cdmx-text {
	font-family: var(--mc-display);
	font-weight: 300;
	font-size: clamp(1.85rem, 5vw, 4rem);
	line-height: 0.98;
	letter-spacing: -0.03em;
	max-width: 40rem;
	margin: 0 auto;
	color: var(--mc-bone);
}
.mc-cdmx-text em {
	font-style: italic;
	color: var(--mc-ochre-bright);
}
.mc-cdmx-coords {
	margin-top: 1.75rem;
	display: flex;
	justify-content: center;
	gap: 2rem;
	font-family: var(--mc-mono);
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--mc-mist-light);
	flex-wrap: wrap;
}
.mc-cdmx-coords strong {
	color: var(--mc-bone);
	font-weight: 500;
	display: block;
	margin-bottom: 0.2rem;
}

/* Productos shortcode wrapper (cuando el [products] del WC se inserta) */
.mc-home .woocommerce {
	max-width: 1280px;
	margin: 0 auto;
}

/* End of Micelio Editorial Design System v1.4 */
