.ogblock-builder-row-inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
	align-items: center;
	width: min(100% - 2rem, 1400px);
	margin-inline: auto;
}

.ogblock-builder-row {
	display: flex;
	align-items: center;
}

.ogblock-builder-row-inner {
	flex: 1;
}

.ogblock-builder-zone {
	display: flex;
	align-items: center;
	gap: 1rem;
}

/* Cada zona/columna se subdivide en 4 bloques horizontales (divisiones verticales).
   HEADER: los bloques reservan espacio (1fr) → la posición define la ubicación
   (bloque 1 = extremo; bloque 4 = más cerca del centro).
   FOOTER: los bloques se ajustan al contenido (auto) para no desperdiciar ancho. */
.ogblock-builder-zone {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	align-items: center;
	gap: 0;
}
.ogblock-builder-slot {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	min-width: 0;
}
.ogblock-builder-zone-left .ogblock-builder-slot { align-items: flex-start; }
.ogblock-builder-zone-right .ogblock-builder-slot { align-items: flex-end; }

/* FOOTER: columnas con bloques al contenido, alineados al inicio. */
#colophon .ogblock-builder-zone {
	grid-template-columns: repeat(4, auto);
	justify-content: start;
	align-items: start;
}
#colophon .ogblock-builder-slot { align-items: flex-start; }

/* RESPONSIVE (<=1024px, header móvil y footer en tablet): las zonas fluyen.
   Esto evita que el título se parta letra por letra cuando el bloque es angosto. */
@media (max-width: 1024px) {
	.ogblock-builder-zone,
	#colophon .ogblock-builder-zone {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: 0.5rem 0.75rem;
	}
	.ogblock-builder-slot {
		flex: 0 1 auto;
		align-items: center;
	}
	.ogblock-builder-slot-empty {
		display: none;
	}
}

.ogblock-builder-zone-center {
	justify-content: center;
}

.ogblock-builder-zone-right {
	justify-content: flex-end;
}

.site-identity {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.site-description {
	margin: 0;
}

.site-navigation ul {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.site-navigation li {
	position: relative;
}

.site-navigation .sub-menu {
	position: absolute;
	z-index: 20;
	top: 100%;
	left: 0;
	display: none;
	min-width: 210px;
	padding: 0.5rem;
}

.site-navigation-footer ul {
	display: flex;
	flex-wrap: wrap;
}

/* Ocultar título de la página (toggle del Personalizador → Utilidades).
   Cubre títulos clásicos del theme y los de bloques de Gutenberg. */
.ogblock-hide-title .entry-title,
.ogblock-hide-title .page-title,
.ogblock-hide-title .wp-block-post-title {
	display: none !important;
}

.ogblock-classic-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 2rem;
	width: min(100% - (var(--ogb-container-padding) * 2), var(--ogb-content-width));
	margin-inline: auto;
	padding-block: 2rem;
}

.ogblock-has-sidebar-right,
.ogblock-has-sidebar-left {
	grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
}

.ogblock-has-sidebar-left .site-main {
	order: 2;
}

.ogblock-entry {
	margin-bottom: 2rem;
}

.ogblock-breadcrumbs {
	width: min(100% - (var(--ogb-container-padding) * 2), var(--ogb-content-width));
	margin: 1rem auto;
	font-size: 0.875rem;
}

.ogblock-scroll-top {
	position: fixed;
	z-index: 9990;
	right: 1rem;
	bottom: 1rem;
	width: 42px;
	height: 42px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: var(--ogb-color-accent);
	color: var(--ogb-color-contrast);
	cursor: pointer;
}

.site-navigation li:hover > .sub-menu,
.site-navigation li:focus-within > .sub-menu {
	display: block;
}

.ogblock-header-button {
	display: inline-flex;
	align-items: center;
	padding: 0.65em 1em;
	border: 1px solid transparent;
	text-decoration: none;
}

.ogblock-search-toggle,
.ogblock-search-close,
.ogblock-mobile-trigger,
.ogblock-mobile-drawer-close {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	border: 0;
	background: transparent;
	cursor: pointer;
}

.ogblock-search-toggle svg {
	display: block;
	fill: currentColor;
}

.ogblock-mobile-trigger svg {
	display: block;
	fill: currentColor;
}

.ogblock-social-links {
	display: flex;
	align-items: center;
}

/* ===== Caja de iconos ===== */
.ogblock-icon-box {
	display: flex;
	gap: 0.75rem;
	min-width: 0;
}
.ogblock-icon-box-vertical {
	flex-direction: column;
}
.ogblock-icon-box-horizontal {
	flex-direction: row;
	align-items: center;
}
.ogblock-icon-box-align-center {
	align-items: center;
	text-align: center;
}
.ogblock-icon-box-align-left {
	align-items: flex-start;
	text-align: left;
}
.ogblock-icon-box-align-right {
	align-items: flex-end;
	text-align: right;
}
.ogblock-icon-box-link {
	display: flex;
	flex-direction: inherit;
	align-items: inherit;
	gap: 0.75rem;
	text-decoration: none;
	color: inherit;
}
.ogblock-icon-box-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	line-height: 0;
}
.ogblock-icon-box-icon svg {
	display: block;
}
.ogblock-icon-box-shape-circle {
	border-radius: 50%;
}
.ogblock-icon-box-shape-rounded {
	border-radius: 12px;
}
.ogblock-icon-box-shape-square {
	border-radius: 0;
}
.ogblock-icon-box-body {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	min-width: 0;
}
.ogblock-icon-box-title {
	font-weight: 600;
	font-size: 1.05rem;
}
.ogblock-icon-box-text {
	font-size: 0.9rem;
	line-height: 1.5;
}

.ogblock-social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.8em;
	min-height: 1.8em;
	text-decoration: none;
}

.ogblock-social-link svg {
	fill: currentColor;
}

.ogblock-mobile-drawer {
	position: fixed;
	z-index: 99998;
	top: 0;
	right: 0;
	bottom: 0;
	width: min(86vw, 360px);
	padding: 3rem 1.5rem 1.5rem;
	background: #fff;
	box-shadow: -4px 0 18px rgba(0, 0, 0, 0.18);
}

.ogblock-mobile-drawer-close {
	position: absolute;
	top: 0.5rem;
	right: 0.75rem;
	font-size: 2rem;
}

.ogblock-mobile-drawer .site-navigation ul {
	flex-direction: column;
}

.ogblock-mobile-drawer .site-navigation .sub-menu {
	position: static;
	display: block;
	min-width: 0;
	padding-left: 1rem;
}

.ogblock-search-modal {
	position: fixed;
	z-index: 99999;
	inset: 0;
	padding: 2rem;
	background: rgba(0, 0, 0, 0.58);
}

.ogblock-search-modal-inner {
	position: relative;
	width: min(100%, 720px);
	margin: 14vh auto 0;
	padding: 2rem;
	background: #fff;
}

.ogblock-search-close {
	position: absolute;
	top: 0.35rem;
	right: 0.5rem;
	font-size: 2rem;
}

.ogblock-search-modal .search-form {
	display: flex;
	gap: 0.5rem;
}

.ogblock-search-modal .search-field {
	flex: 1;
}

/* ===== Edición contextual (lápiz en preview del Customizer) ===== */
.ogblock-ctx-editable {
	position: relative;
}
.ogblock-ctx-editable:hover {
	outline: 1px dashed rgba(34, 113, 177, 0.7);
	outline-offset: 2px;
}
.ogblock-ctx-pencil {
	position: absolute;
	top: 2px;
	inset-inline-end: 2px;
	z-index: 50;
	display: none;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	padding: 0;
	border: 0;
	border-radius: 4px;
	background: #2271b1;
	color: #fff;
	font-size: 13px;
	line-height: 1;
	cursor: pointer;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}
.ogblock-ctx-editable:hover > .ogblock-ctx-pencil {
	display: inline-flex;
}

/* ===== Layout robusto (Fase 3): nada se sale, sin texto vertical ===== */
.ogblock-builder-row-inner,
.ogblock-builder-zone,
.ogblock-builder-component {
	min-width: 0;
}
.ogblock-builder-component {
	max-width: 100%;
	/* break-word NO colapsa el min-content (evita el corte letra por letra que sí
	   provocaba overflow-wrap:anywhere). */
	overflow-wrap: break-word;
	word-break: normal;
}
/* Identidad: logo + texto sin pisarse, el título puede encogerse sin partirse vertical. */
.site-identity {
	min-width: 0;
	flex-wrap: nowrap;
}
.site-identity-text {
	min-width: 0;
}
.site-title {
	overflow-wrap: break-word;
	word-break: normal;
}

/* ===== Swap desktop / móvil (Fase 1) ===== */
/* Mobile header oculto en escritorio (>1024px). */
.ogblock-header-mobile {
	display: none;
}

/* Tablet + móvil (<=1024px): se muestra el header móvil, se oculta el desktop.
   El header móvil conserva sus zonas (logo izquierda / trigger derecha). */
@media (max-width: 1024px) {
	.ogblock-header-desktop {
		display: none;
	}

	.ogblock-header-mobile {
		display: block;
	}
}

/* Apilado de columnas del FOOTER y layout clásico en pantallas chicas (<=782px).
   El header móvil NO se apila: mantiene logo/trigger en sus extremos. */
@media (max-width: 782px) {
	#colophon .ogblock-builder-row-inner {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	#colophon .ogblock-builder-zone,
	#colophon .ogblock-builder-zone-center,
	#colophon .ogblock-builder-zone-right {
		justify-content: center;
	}

	.ogblock-has-sidebar-right,
	.ogblock-has-sidebar-left {
		grid-template-columns: 1fr;
	}

	.ogblock-has-sidebar-left .site-main {
		order: initial;
	}
}

/* ===== Smart slots: 3/4/5 divisions without vertical text collapse ===== */
.ogblock-builder-row {
	--ogb-row-slots: 5;
}

.ogblock-builder-row-mode-equal .ogblock-builder-zone {
	display: grid;
	grid-template-columns: repeat(var(--ogb-row-slots), minmax(0, 1fr));
	gap: 0;
}

.ogblock-builder-row-mode-content .ogblock-builder-zone {
	display: grid;
	grid-template-columns: repeat(var(--ogb-row-slots), max-content);
	gap: 0.75rem;
}

.ogblock-builder-row-mode-auto .ogblock-builder-zone {
	display: flex;
	flex-wrap: nowrap;
	gap: 0.75rem;
}

.ogblock-builder-row-mode-auto .ogblock-builder-slot-empty,
.ogblock-builder-row-mode-content .ogblock-builder-slot-empty,
.ogblock-builder-slot-extra.ogblock-builder-slot-empty {
	display: none;
}

#masthead .ogblock-builder-row-mode-auto .ogblock-builder-slot,
#masthead .ogblock-builder-row-mode-content .ogblock-builder-slot {
	flex-direction: row;
	width: max-content;
	max-width: 100%;
}

#masthead .ogblock-builder-component,
#masthead .site-title,
#masthead .site-description,
#masthead .ogblock-woo-link,
#masthead .ogblock-woo-placeholder {
	overflow-wrap: normal;
	word-break: normal;
	white-space: normal;
}

#masthead .site-title,
#masthead .ogblock-woo-link,
#masthead .ogblock-woo-placeholder {
	white-space: nowrap;
}

#masthead .ogblock-builder-zone-left {
	justify-content: flex-start;
}

#masthead .ogblock-builder-zone-center {
	justify-content: center;
}

#masthead .ogblock-builder-zone-right {
	justify-content: flex-end;
}

#colophon .ogblock-builder-row-mode-auto .ogblock-builder-slot,
#colophon .ogblock-builder-row-mode-content .ogblock-builder-slot {
	flex-direction: column;
}
