/**
 * Responsive / Media Queries
 *
 * @package CreadiNegocio
 */

/* -----------------------------------------------
   Tablet (max-width: 1024px)
----------------------------------------------- */
@media screen and (max-width: 1024px) {
	:root {
		--text-h1: 4rem;    /* 40px */
		--text-h2: 3.2rem;  /* 32px */
		--text-h3: 2.6rem;  /* 26px */
	}

	.posts-grid {
		grid-template-columns: repeat(auto-fill, minmax(28rem, 1fr));
		gap: var(--space-6);
	}

	.footer-widgets-inner {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* -----------------------------------------------
   Mobile Navigation (max-width: 768px)
----------------------------------------------- */
@media screen and (max-width: 768px) {
	:root {
		--text-h1: 3.4rem;  /* 34px */
		--text-h2: 2.8rem;  /* 28px */
		--text-h3: 2.4rem;  /* 24px */
		--text-h4: 2rem;    /* 20px */
		--text-h5: 1.8rem;  /* 18px */
		--text-h6: 1.6rem;  /* 16px */
	}

	body.menu-open {
		overflow: hidden;
	}

	/* Barra superior pegada al viewport (corrige hueco / contenido bajo el notch) */
	.site-header {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		z-index: 1100;
	}

	body.admin-bar .site-header {
		top: 46px;
	}

	/* El margin del admin bar ya baja el body; solo compensamos la altura del header (incl. notch en la barra). */
	#page.site {
		padding-top: calc(var(--site-header-height, 7.2rem) + env(safe-area-inset-top, 0px));
	}

	.menu-toggle {
		display: flex;
		position: relative;
		z-index: 1102;
	}

	.primary-menu {
		position: fixed;
		top: calc(var(--site-header-height, 7.2rem) + env(safe-area-inset-top, 0px));
		left: 0;
		right: 0;
		bottom: 0;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		padding: var(--space-6);
		background-color: var(--color-bg);
		border-top: 1px solid var(--color-border);
		overflow-y: auto;
		transform: translateX(100%);
		transition: transform var(--transition-base);
		z-index: 1101;
		pointer-events: none;
		-webkit-overflow-scrolling: touch;
	}

	.primary-menu.is-toggled {
		transform: translateX(0);
		pointer-events: auto;
	}

	.admin-bar .primary-menu {
		top: calc(46px + var(--site-header-height, 7.2rem) + env(safe-area-inset-top, 0px));
	}

	.primary-menu > li > a {
		padding: var(--space-4);
		font-size: var(--text-base);
		border-bottom: 1px solid var(--color-border);
		border-radius: 0;
	}

	/* Ítems con hijos: fila enlace + botón flecha; submenú colapsado hasta abrir */
	.primary-menu > li.menu-item-has-children {
		display: flex;
		flex-wrap: wrap;
		align-items: stretch;
	}

	.primary-menu > li.menu-item-has-children > a {
		flex: 1 1 auto;
		min-width: 0;
		border-bottom: 1px solid var(--color-border);
	}

	/* Botón flecha: solo el chevron, mismo color que el texto del enlace, sin fondo */
	.primary-menu .submenu-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		flex: 0 0 auto;
		width: 4.6rem;
		height: 4.6rem;
		min-height: 0;
		align-self: center;
		margin: var(--space-2, 0.8rem) var(--space-2, 0.8rem) var(--space-2, 0.8rem) var(--space-3, 1.2rem);
		padding: 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		color: var(--color-text);
		cursor: pointer;
		box-shadow: none;
		transition: color var(--transition-fast, 0.15s ease), transform var(--transition-fast, 0.15s ease);
	}

	.primary-menu .submenu-toggle:hover,
	.primary-menu .submenu-toggle:focus-visible {
		background: transparent;
		color: var(--color-primary, #871f78);
		outline: none;
	}

	.primary-menu .submenu-toggle::after {
		content: "";
		display: block;
		width: 0.55em;
		height: 0.55em;
		margin-top: -0.2em;
		border-right: 2px solid currentColor;
		border-bottom: 2px solid currentColor;
		transform: rotate(45deg);
		transition: transform 0.2s ease;
	}

	.primary-menu li.is-submenu-open > .submenu-toggle::after {
		transform: rotate(-135deg);
		margin-top: 0.15em;
	}

	.primary-menu li.menu-item-has-children > .sub-menu {
		position: static;
		flex: 1 0 100%;
		width: 100%;
		max-height: 0;
		overflow: hidden;
		opacity: 0;
		visibility: hidden;
		transform: none;
		box-shadow: none;
		border: none;
		padding: 0 0 0 var(--space-6);
		margin: 0;
		margin-top: 0;
		background-color: var(--color-bg-alt, #f9f5f8);
		border-radius: var(--radius-md, 0.8rem);
		transition:
			max-height 0.35s ease,
			opacity 0.25s ease,
			visibility 0.25s ease,
			margin-top 0.25s ease,
			padding-top 0.25s ease,
			padding-bottom 0.25s ease;
	}

	.primary-menu li.menu-item-has-children.is-submenu-open > .sub-menu {
		max-height: min(70vh, 80rem);
		opacity: 1;
		visibility: visible;
		margin-top: var(--space-3, 1.2rem);
		padding-top: var(--space-4, 1.6rem);
		padding-bottom: var(--space-4, 1.6rem);
	}

	.primary-menu .sub-menu a {
		padding: var(--space-3) var(--space-4);
		border-bottom: 1px solid var(--color-border);
		border-radius: 0;
	}

	.primary-menu .sub-menu .sub-menu {
		padding-left: var(--space-4, 1.6rem);
	}

	.primary-menu .sub-menu li.menu-item-has-children {
		display: flex;
		flex-wrap: wrap;
		align-items: stretch;
	}

	.site-main > .container:has(#secondary),
	.site-archive-bounds__grid:has(#secondary) {
		grid-template-columns: 1fr;
	}

	.sidebar {
		position: static;
		top: auto;
		max-height: none;
		overflow-y: visible;
		padding-top: var(--space-8);
		border-top: 2px solid var(--color-border);
	}

	.entry-content {
		font-size: var(--text-base);
	}

	.footer-widgets-inner {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}

	.footer-bottom-inner {
		flex-direction: column;
		text-align: center;
	}

	.footer-navigation .footer-menu {
		flex-wrap: wrap;
		justify-content: center;
	}

	.post-navigation .nav-links {
		grid-template-columns: 1fr;
	}

	.back-to-top {
		bottom: var(--space-4);
		right: var(--space-4);
		width: 40px;
		height: 40px;
	}

	body.has-wa-widget .back-to-top {
		right: auto;
		left: var(--space-4);
	}
}

/* -----------------------------------------------
   Small Mobile (max-width: 480px)
----------------------------------------------- */
@media screen and (max-width: 480px) {
	:root {
		--site-header-height: 6rem;
		--text-h1: 2.8rem;  /* 28px */
		--text-h2: 2.4rem;  /* 24px */
		--text-h3: 2rem;    /* 20px */
		--text-h4: 1.8rem;  /* 18px */
		--text-h5: 1.6rem;  /* 16px */
		--text-h6: 1.4rem;  /* 14px */
	}

	.site-main {
		padding-block: var(--space-8);
	}

	.posts-grid {
		grid-template-columns: 1fr;
	}

	.entry-meta {
		flex-direction: column;
		gap: var(--space-2);
	}

	.site-logo img {
		height: 36px;
	}

	.site-title {
		font-size: var(--text-lg);
	}

	.site-description {
		display: none;
	}

	.error-404 {
		padding-block: var(--space-8);
	}
}

/* -----------------------------------------------
   Prefers Reduced Motion
----------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* -----------------------------------------------
   Print
----------------------------------------------- */
@media print {
	.site-header,
	.site-footer,
	.sidebar,
	.menu-toggle,
	.back-to-top,
	.post-navigation,
	.comments-area,
	.pagination {
		display: none !important;
	}

	body {
		font-size: 12pt;
		color: #000;
		background: #fff;
	}

	.site-main > .container,
	.site-archive-bounds__grid {
		grid-template-columns: 1fr !important;
	}

	a {
		color: #000;
		text-decoration: underline;
	}

	a[href]::after {
		content: " (" attr(href) ")";
		font-size: 0.8em;
	}
}
