/* =============================================================================
 * Home 2026 — estilos específicos por sección.
 * Carga solo en páginas con plantilla template-home-2026.php.
 * ============================================================================ */

/* Hotfix: ocultar el header Elementor de Gerow en nuestras plantillas custom.
 * Evita la duplicación visual con nuestro propio header.php + parts/header.php.
 * El selector se aplica solo en plantillas donde NOSOTROS renderizamos chrome. */
body.page-template-template-home-2026 .elementor-location-header,
body.page-template-template-contacto .elementor-location-header,
body.page-template-template-local-page .elementor-location-header,
body.post-type-archive-da_caso .elementor-location-header,
body.single-da_caso .elementor-location-header {
	display: none !important;
}

/* TOP BAR ================================================================ */

.da-topbar {
	background: var(--da-navy);
	color: var(--da-text-on-navy);
	font-size: var(--fs-xs);
	font-family: var(--da-font-body);
	font-weight: var(--fw-medium);
}

.da-topbar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-4);
	min-height: 36px;
	padding-block: var(--sp-2);
}

.da-topbar__info,
.da-topbar__social {
	display: flex;
	align-items: center;
	gap: var(--sp-4);
	flex-wrap: wrap;
}

.da-topbar a {
	color: var(--da-text-on-navy);
	display: inline-flex;
	align-items: center;
	gap: var(--sp-1);
}

.da-topbar a:hover { color: var(--da-blue-light); }

.da-topbar__social a {
	width: 28px; height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--r-sm);
	transition: background var(--dur-fast) var(--ease-out);
}

.da-topbar__social a:hover { background: rgba(255,255,255,0.1); }
.da-topbar__social svg { width: 16px; height: 16px; }

@media (max-width: 540px) {
	.da-topbar { display: none; }
}

/* HEADER ================================================================ */

.da-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: #fff;
	border-bottom: 1px solid var(--da-border-soft);
	transition: box-shadow var(--dur-normal) var(--ease-out);
}

.da-header.is-scrolled { box-shadow: var(--shadow-md); }

.da-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-6);
	min-height: 80px;
	padding-block: var(--sp-3);
}

.da-header__logo img {
	height: 48px;
	width: auto;
	display: block;
}

.da-header__nav {
	display: flex;
	align-items: center;
	gap: var(--sp-6);
}

.da-header__nav ul {
	display: flex;
	gap: var(--sp-6);
	list-style: none;
	margin: 0; padding: 0;
}

.da-header__nav a {
	color: var(--da-navy);
	font-weight: var(--fw-medium);
	font-size: var(--fs-sm);
	font-family: var(--da-font-heading);
}

.da-header__cta {
	display: flex;
	align-items: center;
	gap: var(--sp-3);
}

.da-header__icon {
	width: 44px; height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--r-md);
	background: var(--da-blue-bg);
	color: var(--da-navy);
	transition: background var(--dur-fast) var(--ease-out);
}

.da-header__icon:hover { background: var(--da-blue); color: #fff; }
.da-header__icon svg { width: 20px; height: 20px; }

@media (max-width: 960px) {
	.da-header__nav ul { display: none; }
	.da-header__cta .da-btn { display: none; }
}

/* HERO ================================================================== */

.da-hero {
	padding-block: clamp(var(--sp-12), 8vw, var(--sp-24));
	background:
		radial-gradient(ellipse at top right, rgba(122,174,255,0.18), transparent 50%),
		linear-gradient(180deg, #fff 0%, var(--da-blue-bg) 100%);
	position: relative;
	overflow: hidden;
}

.da-hero__grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: clamp(var(--sp-8), 4vw, var(--sp-16));
	align-items: center;
}

@media (max-width: 880px) {
	.da-hero__grid { grid-template-columns: 1fr; }
}

.da-hero__title {
	font-size: var(--fs-4xl);
	margin-block: var(--sp-4) var(--sp-5);
	color: var(--da-navy);
}

.da-hero__title em {
	color: var(--da-blue);
	font-style: normal;
	background: linear-gradient(120deg, transparent 60%, rgba(0,85,255,0.12) 60%);
	padding: 0 0.1em;
}

/* Hero: layout secundario para CTAs y pilares */
.da-hero__secondary {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-2);
	margin-top: var(--sp-3);
}

.da-hero__icon-link {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	padding: var(--sp-2) var(--sp-4);
	background: #fff;
	border: 1.5px solid var(--da-border);
	border-radius: var(--r-pill);
	color: var(--da-text);
	font-size: var(--fs-sm);
	font-weight: var(--fw-medium);
	font-family: var(--da-font-heading);
	transition: border-color var(--dur-fast) var(--ease-out),
	            background var(--dur-fast) var(--ease-out),
	            color var(--dur-fast) var(--ease-out);
}

.da-hero__icon-link:hover {
	border-color: var(--da-blue);
	color: var(--da-navy);
	background: var(--da-blue-bg);
}

.da-hero__icon-link svg {
	width: 18px; height: 18px;
}

.da-hero__pillars {
	list-style: none;
	margin: var(--sp-6) 0 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
}

.da-hero__pillars li {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	font-size: var(--fs-sm);
	color: var(--da-text);
}

.da-hero__pillars li svg {
	width: 20px; height: 20px;
	color: var(--da-success);
	flex-shrink: 0;
	background: #ECFDF5;
	border-radius: 50%;
	padding: 3px;
}

.da-hero__pillars strong { color: var(--da-navy); font-weight: var(--fw-semibold); }

/* Hero media badge mejorado */
.da-hero__media-badge {
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
	min-width: 200px;
}

.da-hero__media-badge::before { display: none; }

.da-hero__media-badge strong {
	font-family: var(--da-font-heading);
	font-size: var(--fs-xl);
	color: var(--da-blue);
	font-weight: var(--fw-bold);
	line-height: 1;
}

.da-hero__media-badge span {
	font-size: var(--fs-xs);
	color: var(--da-text-soft);
	font-weight: var(--fw-medium);
}

.da-hero__subtitle {
	font-size: var(--fs-md);
	color: var(--da-text-soft);
	max-width: 56ch;
	margin-bottom: var(--sp-8);
}

.da-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-3);
	margin-bottom: var(--sp-8);
}

.da-hero__proof {
	display: flex;
	flex-direction: column;
	gap: var(--sp-4);
	font-size: var(--fs-sm);
	color: var(--da-text-soft);
}

.da-hero__rating {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	font-weight: var(--fw-medium);
}

.da-hero__rating-stars {
	color: #F59E0B;
	letter-spacing: 1px;
}

.da-hero__rating strong { color: var(--da-navy); font-size: var(--fs-base); }

.da-hero__media {
	position: relative;
	aspect-ratio: 4 / 5;
	border-radius: var(--r-2xl);
	overflow: hidden;
	box-shadow: var(--shadow-xl);
	background: linear-gradient(135deg, var(--da-navy), var(--da-blue));
}

.da-hero__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	filter: grayscale(100%) contrast(1.05);
}

.da-hero__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(0,25,76,0.35) 100%);
	pointer-events: none;
}

.da-hero__media-badge {
	position: absolute;
	left: var(--sp-5);
	bottom: var(--sp-5);
	background: rgba(255,255,255,0.95);
	backdrop-filter: blur(8px);
	color: var(--da-navy);
	padding: var(--sp-3) var(--sp-4);
	border-radius: var(--r-lg);
	font-family: var(--da-font-heading);
	font-weight: var(--fw-bold);
	font-size: var(--fs-sm);
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	box-shadow: var(--shadow-md);
}

.da-hero__media-badge::before {
	content: "";
	width: 10px; height: 10px;
	border-radius: 50%;
	background: var(--da-success);
	box-shadow: 0 0 0 4px rgba(5,150,105,0.2);
}

/* STATS ================================================================= */

.da-stats {
	background: var(--da-navy);
	color: #fff;
}

.da-stats__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--sp-6);
}

@media (max-width: 880px) {
	.da-stats__grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-8) var(--sp-4); }
}

.da-stat {
	text-align: center;
	padding-block: var(--sp-4);
}

.da-stat__value {
	font-family: var(--da-font-heading);
	font-size: var(--fs-3xl);
	font-weight: var(--fw-black);
	line-height: 1;
	color: #fff;
	letter-spacing: -0.03em;
	display: block;
}

.da-stat__value sup {
	font-size: 0.55em;
	font-weight: var(--fw-semibold);
	color: var(--da-blue-light);
	margin-left: 2px;
	vertical-align: top;
	top: 0.4em;
	position: relative;
}

.da-stat__label {
	display: block;
	font-size: var(--fs-sm);
	color: var(--da-text-on-navy-soft);
	margin-top: var(--sp-2);
	font-family: var(--da-font-body);
}

/* CTA FINAL ============================================================ */

.da-cta-final {
	position: relative;
	background: linear-gradient(135deg, var(--da-navy) 0%, var(--da-navy-deep) 100%);
	color: #fff;
	padding-block: clamp(var(--sp-16), 9vw, var(--sp-24));
	overflow: hidden;
}

.da-cta-final::before,
.da-cta-final::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
}

.da-cta-final::before {
	top: -200px; right: -120px;
	width: 480px; height: 480px;
	background: radial-gradient(circle, rgba(0,85,255,0.35), transparent 65%);
}

.da-cta-final::after {
	bottom: -180px; left: -100px;
	width: 380px; height: 380px;
	background: radial-gradient(circle, rgba(122,174,255,0.20), transparent 65%);
}

.da-cta-final__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: var(--sp-12);
	align-items: center;
}

@media (max-width: 880px) {
	.da-cta-final__inner { grid-template-columns: 1fr; }
}

.da-cta-final h2 {
	font-size: var(--fs-3xl);
	color: #fff;
	margin-bottom: var(--sp-4);
}

.da-cta-final p { color: var(--da-text-on-navy-soft); font-size: var(--fs-md); }

.da-cta-form {
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: var(--r-2xl);
	padding: var(--sp-8);
	backdrop-filter: blur(8px);
}

.da-cta-form__row {
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
	margin-bottom: var(--sp-4);
}

.da-cta-form label {
	font-size: var(--fs-sm);
	color: var(--da-text-on-navy);
	font-weight: var(--fw-medium);
}

.da-cta-form input[type="text"],
.da-cta-form input[type="tel"],
.da-cta-form input[type="email"],
.da-cta-form input[type="number"] {
	width: 100%;
	min-height: 52px;
	padding: var(--sp-3) var(--sp-4);
	background: rgba(255,255,255,0.92);
	color: var(--da-navy);
	font-family: var(--da-font-body);
	font-size: var(--fs-base);
	border: 2px solid transparent;
	border-radius: var(--r-md);
	transition: border-color var(--dur-fast) var(--ease-out),
	            background var(--dur-fast) var(--ease-out);
}

.da-cta-form input:focus {
	background: #fff;
	border-color: var(--da-blue);
}

.da-cta-form .da-rgpd {
	display: flex;
	gap: var(--sp-2);
	font-size: var(--fs-xs);
	color: var(--da-text-on-navy-soft);
	margin-bottom: var(--sp-4);
	line-height: 1.5;
}

.da-cta-form .da-rgpd a { color: var(--da-blue-light); text-decoration: underline; }

.da-cta-form .da-btn { width: 100%; }

.da-cta-form__note {
	font-size: var(--fs-xs);
	color: var(--da-text-on-navy-soft);
	text-align: center;
	margin-top: var(--sp-3);
	margin-bottom: 0;
}

/* Honeypot — invisible accesible. */
.da-honeypot {
	position: absolute;
	left: -9999px;
	width: 1px; height: 1px;
}

/* FOOTER RICO ========================================================= */

.da-footer {
	background: var(--da-navy-deep);
	color: var(--da-text-on-navy-soft);
	padding-top: var(--sp-16);
}

.da-footer__grid {
	display: grid;
	grid-template-columns: 1.4fr repeat(3, 1fr);
	gap: var(--sp-12) var(--sp-8);
}

@media (max-width: 880px) {
	.da-footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 540px) {
	.da-footer__grid { grid-template-columns: 1fr; }
}

.da-footer h3 {
	font-size: var(--fs-base);
	color: #fff;
	margin-bottom: var(--sp-4);
	font-weight: var(--fw-semibold);
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.da-footer ul {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
}

.da-footer a {
	color: var(--da-text-on-navy-soft);
	font-size: var(--fs-sm);
}

.da-footer a:hover { color: #fff; }

.da-footer__brand img {
	height: 48px;
	margin-bottom: var(--sp-4);
	filter: brightness(0) invert(1);
}

.da-footer__brand p {
	font-size: var(--fs-sm);
	color: var(--da-text-on-navy-soft);
	max-width: 32ch;
	margin-bottom: var(--sp-4);
}

.da-footer__contact { display: flex; flex-direction: column; gap: var(--sp-2); font-size: var(--fs-sm); }
.da-footer__contact strong { color: #fff; font-weight: var(--fw-semibold); }

.da-footer__bottom {
	border-top: 1px solid rgba(255,255,255,0.08);
	margin-top: var(--sp-12);
	padding-block: var(--sp-6);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: var(--sp-4);
	font-size: var(--fs-xs);
	color: var(--da-text-on-navy-soft);
}

.da-footer__legal {
	display: flex; flex-wrap: wrap; gap: var(--sp-4);
}

.da-footer__legal a { font-size: var(--fs-xs); }
