/*
 * ============================================================================
 * URBIFY · layout.css
 * ============================================================================
 * Estilos del layout global del sitio:
 *   §1. Header sticky (urb-header)
 *   §2. Hero search del shortcode [urbify_hero_search]
 *   §3. Featured grid del shortcode [urbify_featured_properties]
 *   §4. Value props (3 cols con iconos)
 *   §5. CTA final
 *   §6. Footer (4 cols + alerts subscribe + legal links)
 *
 * Pensado para colocarse DENTRO de Divi (Theme Builder + Divi Builder en Home)
 * vía módulos Code y módulos nativos con clases CSS personalizadas en Avanzado.
 *
 * @package Divi_Child_Urbify
 * @since   1.0.0
 */

/* ============================================================================
   §1. HEADER STICKY (urb-header)
   ============================================================================ */

/* §1 — Reglas viejas del header (.urb-header*) eliminadas.
 * El header se estiliza ahora en header.css.
 */

/* ============================================================================
   §1b. PÁGINA DE CONTACTO (page-contacto.php)
   ============================================================================ */

.urb-contact-page {
	padding-block: clamp(3rem, 8vw, 5rem);
	background: var(--urb-white);
}

.urb-contact-page__hero {
	max-width: 720px;
	margin: 0 auto var(--space-12);
	text-align: center;
}

.urb-contact-page__eyebrow {
	margin: 0 0 var(--space-2);
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--urb-mint-500);
}

.urb-contact-page__title {
	margin: 0 0 var(--space-3);
	font-family: var(--font-display);
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: var(--fw-bold);
	color: var(--urb-navy-900);
	line-height: var(--leading-tight);
	letter-spacing: var(--tracking-tight);
}

.urb-contact-page__subtitle {
	margin: 0;
	font-size: var(--text-lg);
	color: var(--urb-gray-600);
	line-height: var(--leading-relaxed);
}

.urb-contact-page__grid {
	display: grid;
	gap: var(--space-10);
	grid-template-columns: 1fr;
}

@media (min-width: 992px) {
	.urb-contact-page__grid {
		grid-template-columns: 1fr 1.4fr;
		gap: var(--space-12);
		align-items: start;
	}
}

/* ── Columna info ── */

.urb-contact-page__info {
	padding: var(--space-8);
	background: var(--urb-cream);
	border-radius: var(--radius-lg);
}

.urb-contact-page__info-title,
.urb-contact-page__form-title {
	margin: 0 0 var(--space-6);
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: var(--fw-semibold);
	color: var(--urb-navy-900);
}

.urb-contact-page__list {
	list-style: none;
	margin: 0 0 var(--space-6);
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
}

.urb-contact-page__item {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
}

.urb-contact-page__item-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background: var(--urb-white);
	color: var(--urb-mint-500);
	border-radius: var(--radius-full);
	flex-shrink: 0;
}

.urb-contact-page__item-body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.urb-contact-page__item-label {
	font-size: var(--text-xs);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color: var(--urb-gray-600);
}

.urb-contact-page__item-value {
	font-family: var(--font-display);
	font-size: var(--text-lg);
	color: var(--urb-navy-900);
	text-decoration: none;
	transition: color var(--transition-fast);
	word-break: break-word;
}

.urb-contact-page__item-value:hover {
	color: var(--urb-mint-500);
}

.urb-contact-page__whatsapp {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	width: 100%;
	padding: 14px 24px;
	background: #25D366;
	color: var(--urb-white);
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: var(--text-base);
	font-weight: var(--fw-semibold);
	text-decoration: none;
	transition: background var(--transition-fast), transform var(--transition-fast);
}

.urb-contact-page__whatsapp:hover {
	background: #1ebe5d;
	color: var(--urb-white);
	transform: translateY(-1px);
}

/* ── Columna formulario ── */

.urb-contact-page__form-wrap {
	padding: var(--space-8);
	background: var(--urb-white);
	border: 1px solid var(--urb-gray-200);
	border-radius: var(--radius-lg);
}

.urb-contact-page__form input[type="text"],
.urb-contact-page__form input[type="email"],
.urb-contact-page__form input[type="tel"],
.urb-contact-page__form textarea,
.urb-contact-page__form select {
	width: 100%;
	padding: 12px 14px;
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--urb-gray-900);
	background: var(--urb-gray-50);
	border: 1px solid var(--urb-gray-200);
	border-radius: var(--radius-md);
	transition: border-color var(--transition-fast), background var(--transition-fast);
}

.urb-contact-page__form input:focus,
.urb-contact-page__form textarea:focus,
.urb-contact-page__form select:focus {
	outline: 0;
	background: var(--urb-white);
	border-color: var(--urb-mint-500);
}

.urb-contact-page__form .wpcf7-submit {
	background: var(--urb-mint-500);
	color: var(--urb-white);
	border: 0;
	padding: 12px 28px;
	font-weight: var(--fw-semibold);
	cursor: pointer;
	transition: background var(--transition-fast);
}

.urb-contact-page__form .wpcf7-submit:hover {
	background: var(--urb-mint-400);
}

.urb-contact-page__form-placeholder {
	text-align: center;
	padding: var(--space-6) 0;
}

.urb-contact-page__form-placeholder p {
	margin: 0 0 var(--space-4);
	color: var(--urb-gray-600);
}

.urb-contact-page__admin-tip {
	margin-top: var(--space-6);
	padding: var(--space-3);
	background: rgba(46, 204, 113, 0.08);
	border-left: 3px solid var(--urb-mint-500);
	border-radius: var(--radius-sm);
	font-size: var(--text-sm);
	color: var(--urb-gray-600);
	text-align: left;
	font-style: italic;
}

/* ============================================================================
   §2. HERO SEARCH (shortcode [urbify_hero_search])
   ============================================================================ */

.urb-hero-search {
	max-width: 920px;
	margin: 0 auto;
	padding: var(--space-5) var(--space-6);
	background: var(--urb-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-xl);
}

.urb-hero-search__row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

.urb-hero-search__row--ops {
	margin-bottom: var(--space-4);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid var(--urb-gray-200);
}

.urb-hero-search__op {
	display: inline-flex;
	align-items: center;
	padding: 6px 16px;
	font-size: var(--text-sm);
	font-weight: var(--fw-medium);
	color: var(--urb-gray-600);
	background: var(--urb-white);
	border: 1.5px solid var(--urb-gray-200);
	border-radius: var(--radius-full);
	cursor: pointer;
	transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.urb-hero-search__op input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.urb-hero-search__op:hover {
	border-color: var(--urb-navy-900);
	color: var(--urb-navy-900);
}

.urb-hero-search__op:has(input:checked) {
	background: var(--urb-navy-900);
	color: var(--urb-white);
	border-color: var(--urb-navy-900);
}

.urb-hero-search__row--inputs {
	align-items: stretch;
}

.urb-hero-search__field {
	position: relative;
	display: flex;
	align-items: center;
	flex: 1 1 200px;
	min-width: 0;
}

.urb-hero-search__field input,
.urb-hero-search__field select {
	width: 100%;
	padding: 12px 14px;
	font-family: var(--font-body);
	font-size: var(--text-sm);
	color: var(--urb-gray-900);
	background: var(--urb-gray-50);
	border: 1px solid var(--urb-gray-200);
	border-radius: var(--radius-md);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.urb-hero-search__field--text input {
	padding-left: 40px;
}

.urb-hero-search__field-icon {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--urb-gray-400);
	pointer-events: none;
}

.urb-hero-search__field input:focus,
.urb-hero-search__field select:focus {
	outline: 0;
	border-color: var(--urb-mint-500);
	box-shadow: 0 0 0 3px rgba( 46, 204, 113, 0.18 );
	background: var(--urb-white);
}

.urb-hero-search__btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 12px 24px;
	background: var(--urb-mint-500);
	color: var(--urb-white);
	border: 0;
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	cursor: pointer;
	transition: background var(--transition-fast), transform var(--transition-fast);
	white-space: nowrap;
}

.urb-hero-search__btn:hover,
.urb-hero-search__btn:focus-visible {
	background: var(--urb-mint-400);
	transform: translateY(-1px);
}

@media (max-width: 720px) {
	.urb-hero-search__btn {
		flex: 1 1 100%;
		justify-content: center;
	}
}

/* ============================================================================
   §3. FEATURED GRID (shortcode [urbify_featured_properties])
   ============================================================================ */

.urb-featured-grid {
	display: grid;
	gap: var(--space-6);
	grid-template-columns: 1fr;
}

@media (min-width: 600px) {
	.urb-featured-grid--cols-2,
	.urb-featured-grid--cols-3,
	.urb-featured-grid--cols-4 {
		grid-template-columns: repeat( 2, 1fr );
	}
}

@media (min-width: 1024px) {
	.urb-featured-grid--cols-3 {
		grid-template-columns: repeat( 3, 1fr );
	}
	.urb-featured-grid--cols-4 {
		grid-template-columns: repeat( 4, 1fr );
	}
}

/* ============================================================================
   §4. VALUE PROPS (3 cols con iconos)
   ============================================================================ */

.urb-value-props {
	display: grid;
	gap: var(--space-8);
	grid-template-columns: 1fr;
}

@media (min-width: 720px) {
	.urb-value-props {
		grid-template-columns: repeat( 3, 1fr );
	}
}

.urb-value-prop {
	text-align: center;
	padding: var(--space-6);
}

.urb-value-prop__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	margin-bottom: var(--space-4);
	background: var(--urb-mint-100);
	color: var(--urb-mint-500);
	border-radius: var(--radius-full);
}

.urb-value-prop__icon svg {
	width: 28px;
	height: 28px;
}

.urb-value-prop__title {
	margin: 0 0 var(--space-2);
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: var(--fw-semibold);
	color: var(--urb-navy-900);
}

.urb-value-prop__desc {
	margin: 0;
	font-size: var(--text-base);
	color: var(--urb-gray-600);
	line-height: var(--leading-relaxed);
}

/* ============================================================================
   §5. CTA FINAL
   ============================================================================ */

.urb-cta-final {
	padding: var(--space-16) var(--gutter);
	text-align: center;
	background: var(--urb-navy-900);
	color: var(--urb-white);
	border-radius: var(--radius-xl);
}

.urb-cta-final__title {
	margin: 0 0 var(--space-3);
	font-family: var(--font-display);
	font-size: var(--text-3xl);
	color: var(--urb-white);
}

.urb-cta-final__text {
	max-width: 560px;
	margin: 0 auto var(--space-6);
	font-size: var(--text-lg);
	color: rgba( 255, 255, 255, 0.85 );
	line-height: var(--leading-relaxed);
}

.urb-cta-final__btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 14px 32px;
	background: var(--urb-mint-500);
	color: var(--urb-white);
	border: 0;
	border-radius: var(--radius-full);
	font-size: var(--text-base);
	font-weight: var(--fw-semibold);
	text-decoration: none;
	transition: background var(--transition-fast), transform var(--transition-fast);
}

.urb-cta-final__btn:hover,
.urb-cta-final__btn:focus-visible {
	background: var(--urb-mint-400);
	color: var(--urb-white);
	transform: translateY(-2px);
}

/* ============================================================================
   §6. FOOTER — Reglas globales obsoletas eliminadas.
   El footer se estiliza ahora en footer.css con clases específicas
   (.urb-pre-footer, .urb-footer__main, .urb-footer__col, etc.) para evitar
   colisiones con shortcodes que también usan .urb-footer-* (ver layout-shortcodes).
   ============================================================================ */

/* ── Alerts subscribe (shortcode [urbify_alerts_subscribe], NO el pre-footer) ── */

.urb-footer-alerts {
	max-width: 320px;
}

.urb-footer-alerts__title {
	color: var(--urb-white);
	font-family: var(--font-display);
	font-size: var(--text-base);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	margin: 0 0 var(--space-2);
}

.urb-footer-alerts__subtitle {
	margin: 0 0 var(--space-3);
	font-size: var(--text-sm);
	color: rgba( 255, 255, 255, 0.7 );
	line-height: var(--leading-snug);
}

.urb-footer-alerts__form {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.urb-footer-alerts__field input {
	width: 100%;
	padding: 10px 14px;
	font-family: var(--font-body);
	font-size: var(--text-sm);
	color: var(--urb-white);
	background: rgba( 255, 255, 255, 0.08 );
	border: 1px solid rgba( 255, 255, 255, 0.18 );
	border-radius: var(--radius-md);
	transition: background var(--transition-fast), border-color var(--transition-fast);
}

.urb-footer-alerts__field input::placeholder {
	color: rgba( 255, 255, 255, 0.4 );
}

.urb-footer-alerts__field input:focus {
	outline: 0;
	background: rgba( 255, 255, 255, 0.14 );
	border-color: var(--urb-mint-500);
}

.urb-footer-alerts__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: 10px 16px;
	background: var(--urb-mint-500);
	color: var(--urb-white);
	border: 0;
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	cursor: pointer;
	transition: background var(--transition-fast);
}

.urb-footer-alerts__btn:hover,
.urb-footer-alerts__btn:focus-visible {
	background: var(--urb-mint-400);
}

.urb-footer-alerts__rgpd {
	display: flex;
	align-items: flex-start;
	gap: var(--space-2);
	margin-top: var(--space-2);
	font-size: 11px;
	color: rgba( 255, 255, 255, 0.6 );
	line-height: 1.4;
}

.urb-footer-alerts__rgpd input {
	margin-top: 2px;
	flex-shrink: 0;
}

.urb-footer-alerts__rgpd a {
	color: var(--urb-mint-400);
	text-decoration: underline;
}

.urb-footer-alerts__feedback {
	margin: 4px 0 0;
	min-height: 1.4em;
	font-size: var(--text-xs);
}

.urb-footer-alerts__feedback--success { color: var(--urb-mint-400); }
.urb-footer-alerts__feedback--error   { color: #ff7b7b; }

/* ── Legal links (footer) ── */

.urb-footer-legal__list {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.urb-footer-legal__cookies-btn {
	background: none;
	border: 0;
	padding: 0;
	color: rgba( 255, 255, 255, 0.85 );
	font-family: inherit;
	font-size: inherit;
	cursor: pointer;
	text-align: left;
}

.urb-footer-legal__cookies-btn:hover {
	color: var(--urb-mint-400);
	text-decoration: underline;
}

/* ── Redes sociales (footer) ── */

.urb-footer-social {
	display: flex;
	gap: var(--space-2);
	margin-top: var(--space-3);
}

.urb-footer-social__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background: rgba( 255, 255, 255, 0.08 );
	color: var(--urb-white);
	border-radius: var(--radius-full);
	transition: background var(--transition-fast), color var(--transition-fast);
}

.urb-footer-social__link:hover,
.urb-footer-social__link:focus-visible {
	background: var(--urb-mint-500);
	color: var(--urb-white);
}

/* ============================================================================
   §7. HEADER LAYOUT INTERNO + RESPONSIVE
   ============================================================================ */

/* Skip link accesibilidad */
.urb-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 10000;
	padding: 12px 20px;
	background: var(--urb-mint-500);
	color: var(--urb-white);
	text-decoration: none;
}
.urb-skip-link:focus {
	left: var(--space-4);
	top: var(--space-4);
}

.urb-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-6);
}

/* Logo styles are now in header.css */

.urb-header__wordmark {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: var(--fw-bold);
	color: var(--urb-white);
	letter-spacing: var(--tracking-tight);
}

.urb-header__nav {
	flex: 1;
	display: flex;
	justify-content: center;
}

.urb-header__actions {
	display: flex;
	align-items: center;
	gap: var(--space-3);
}

.urb-header__toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 4px;
	width: 40px;
	height: 40px;
	padding: 0;
	background: transparent;
	border: 0;
	cursor: pointer;
}

.urb-header__toggle span {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--urb-white);
	transition: transform var(--transition-fast), opacity var(--transition-fast);
}

.urb-header__toggle[aria-expanded="true"] span:nth-child(1) {
	transform: translateY(6px) rotate(45deg);
}
.urb-header__toggle[aria-expanded="true"] span:nth-child(2) {
	opacity: 0;
}
.urb-header__toggle[aria-expanded="true"] span:nth-child(3) {
	transform: translateY(-6px) rotate(-45deg);
}

/* Responsive: en móvil, ocultamos solo nav detrás del toggle, actions siempre visibles */
@media (max-width: 1023px) {
	.urb-header__toggle { display: inline-flex; }
	.urb-header__nav {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--urb-navy-900);
		padding: var(--space-6) var(--gutter);
		flex-direction: column;
		align-items: stretch;
		display: none;
	}
	.urb-header.is-mobile-open .urb-header__nav {
		display: flex;
	}
	.urb-header__nav .menu,
	.urb-header__nav-list {
		flex-direction: column;
		gap: var(--space-3);
	}
	.urb-header__cta {
		text-align: center;
	}
}

/* ============================================================================
   §8. HOME PAGE — HERO + SECCIONES
   ============================================================================ */

/* ── Hero ── */

.urb-home-hero {
	position: relative;
	padding-block: clamp(120px, 18vw, 220px) clamp(60px, 10vw, 120px);
	background: linear-gradient(135deg, var(--urb-navy-900) 0%, var(--urb-navy-700) 100%);
	background-size: cover;
	background-position: center;
	color: var(--urb-white);
	margin-top: -88px; /* compensa header sticky transparente */
}

.urb-home-hero__content {
	max-width: 720px;
	margin: 0 auto var(--space-10);
	text-align: center;
	color: var(--urb-white);
}

.urb-home-hero__eyebrow {
	margin: 0 0 var(--space-3);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--urb-mint-400);
}

.urb-home-hero__title {
	margin: 0 0 var(--space-4);
	font-family: var(--font-display);
	font-size: var(--text-4xl);
	font-weight: var(--fw-bold);
	line-height: var(--leading-tight);
	color: var(--urb-white);
	letter-spacing: var(--tracking-tight);
}

.urb-home-hero__subtitle {
	margin: 0;
	font-size: var(--text-lg);
	line-height: var(--leading-relaxed);
	color: rgba(255, 255, 255, 0.85);
}

.urb-home-hero__search {
	max-width: 920px;
	margin: 0 auto;
}

/* ── Secciones home (uniforme) ── */

.urb-home-section {
	padding-block: var(--space-20);
}

.urb-home-section--featured {
	background: var(--urb-white);
}

.urb-home-section--values {
	background: var(--urb-cream);
}

.urb-home-section--cta {
	padding-block: var(--space-12) var(--space-20);
	background: var(--urb-white);
}

.urb-home-section__header {
	max-width: 720px;
	margin: 0 auto var(--space-10);
	text-align: center;
}

.urb-home-section__eyebrow {
	margin: 0 0 var(--space-2);
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--tracking-wider);
	text-transform: uppercase;
	color: var(--urb-mint-500);
}

.urb-home-section__title {
	margin: 0 0 var(--space-3);
	font-family: var(--font-display);
	font-size: var(--text-3xl);
	font-weight: var(--fw-bold);
	color: var(--urb-navy-900);
	letter-spacing: var(--tracking-tight);
}

.urb-home-section__subtitle {
	margin: 0;
	font-size: var(--text-lg);
	color: var(--urb-gray-600);
	line-height: var(--leading-relaxed);
}

.urb-home-section__cta {
	margin-top: var(--space-10);
	text-align: center;
}

/* ============================================================================
   §9. FOOTER LAYOUT INTERNO
   ============================================================================ */

.urb-footer__cols {
	display: grid;
	gap: var(--space-8);
	grid-template-columns: 1fr;
}

@media (min-width: 600px) {
	.urb-footer__cols {
		grid-template-columns: 1fr 1fr;
	}
}

@media (min-width: 1024px) {
	.urb-footer__cols {
		grid-template-columns: 1.4fr 1fr 1fr 1.4fr;
	}
}

.urb-footer__col {
	min-width: 0;
}

.urb-footer__logo {
	display: inline-block;
	margin-bottom: var(--space-3);
	text-decoration: none;
}

.urb-footer__logo-img {
	max-height: 36px;
	width: auto;
}

.urb-footer__desc {
	margin: 0 0 var(--space-3);
	font-size: var(--text-sm);
	color: rgba(255, 255, 255, 0.7);
	line-height: var(--leading-relaxed);
}

.urb-footer__legal-id {
	margin: 0;
	font-size: var(--text-xs);
	color: rgba(255, 255, 255, 0.5);
}

.urb-footer__menu,
.urb-footer__col ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

/* ============================================================================
   §10. UTILIDADES BOTONES (extensión de main.css)
   ============================================================================ */

.urb-btn--secondary {
	background: transparent;
	color: var(--urb-navy-900);
	border: 1.5px solid var(--urb-navy-900);
}

.urb-btn--secondary:hover,
.urb-btn--secondary:focus-visible {
	background: var(--urb-navy-900);
	color: var(--urb-white);
}
