/**
 * Divine Bridge — widgets Elementor (layout + patrón «Jewel» del design system).
 */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap");

/*
 * Stack hero + barra (contenedor interno Elementor con id db-landing-hero-stack).
 * Debe ir por ENCIMA de los widgets hermanos (features, how-it-works…) en el mismo
 * .e-con exterior: si no, al hacer scroll esos bloques se pintan después en el DOM
 * y tapan la barra fixed. NO usar z-index:0 + isolation aquí: capa todo el subárbol.
 */
#db-landing-hero-stack {
	position: relative;
	z-index: 999980;
}

/*
 * Barra superior: el <nav> es position:absolute y no ocupa flujo; Elementor suele
 * aplicar margin-bottom al widget → hueco bajo la “fila” vacía. Pie: mismo criterio
 * para no duplicar separación con el margen del widget.
 */
.elementor-widget-divine_bridge_landing_nav,
.elementor-widget-divine_bridge_landing_footer {
	margin: 0 !important;
}

.elementor-widget-divine_bridge_landing_nav .elementor-widget-container,
.elementor-widget-divine_bridge_landing_footer .elementor-widget-container {
	margin: 0 !important;
	padding: 0 !important;
	min-height: 0;
	overflow: visible;
}

/*
 * Barra: z-index ALTÍSIMO en el wrapper del widget (no solo en el <nav> interno).
 * Si el wrapper queda en 1, todo el subárbol (fixed + panel móvil) compite en esa
 * capa y el hero / secciones Elementor (sticky, motion, z-index 10–999) pasan por encima.
 */
.elementor-widget-divine_bridge_landing_nav {
	position: relative;
	z-index: 999990;
}

/* Hero en la misma pila que la nav: siempre debajo de la barra */
#db-landing-hero-stack > .elementor-widget-divine_bridge_landing_hero {
	position: relative;
	z-index: 0;
}

/*
 * Pie compacto: capa por encima del flujo normal (evita quedar tapado por secciones
 * con transform/sticky y z-index medio) pero siempre por debajo de la barra (999990).
 */
.elementor-widget-divine_bridge_landing_footer {
	position: relative;
	z-index: 10050;
}

/* —— Landing index-plano (widgets BEM; no requieren Tailwind) —— */
.db-landing {
	--db-ld-dark: #0a1128;
	--db-ld-gold: #c5a059;
	--db-ld-gold-bright: #f3d082;
	--db-ld-gray-50: #f9fafb;
	--db-ld-gray-200: #e5e7eb;
	--db-ld-gray-500: #6b7280;
	--db-ld-gray-600: #4b5563;
	--db-ld-max: 80rem;
	box-sizing: border-box;
	font-family: Inter, system-ui, sans-serif;
}

.db-landing *,
.db-landing *::before,
.db-landing *::after {
	box-sizing: border-box;
}

/* Barra superior: colocar la sección/columna padre en position:relative */
.db-landing-nav {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 50;
	color: #fff;
	pointer-events: none;
}

/* Fija al viewport (opción del widget) */
.db-landing-nav--fixed {
	position: fixed;
	right: 0;
	z-index: 1100;
	isolation: isolate;
}

.admin-bar .db-landing-nav--fixed {
	top: 32px;
}

@media screen and (max-width: 782px) {
	.admin-bar .db-landing-nav--fixed {
		top: 46px;
	}
}

/*
 * Anclas del menú (#hero, #features…): con barra position:fixed el título quedaba
 * bajo la navegación. scroll-padding en el viewport raíz alinea el destino.
 * En HTML pegado (Tailwind): añade data-db-fixed-nav al contenedor raíz si el nav es fixed.
 */
html:has(.db-landing-nav--fixed),
html:has([data-db-fixed-nav]) {
	scroll-padding-top: 6rem;
}

html:has(body.admin-bar .db-landing-nav--fixed),
html:has(body.admin-bar [data-db-fixed-nav]) {
	scroll-padding-top: calc(32px + 6rem);
}

@media screen and (max-width: 782px) {
	html:has(body.admin-bar .db-landing-nav--fixed),
	html:has(body.admin-bar [data-db-fixed-nav]) {
		scroll-padding-top: calc(46px + 6rem);
	}
}

/*
 * Cristal al scroll: el blur va en .db-landing-nav__glass (hijo), NO en <nav>.
 * backdrop-filter en el ancestro del panel fixed rompe el viewport como containing block
 * y el menú móvil queda recortado / por debajo del contenido al desplazar.
 */
.db-landing-nav--scroll-glass {
	transition:
		border-color 0.35s ease,
		box-shadow 0.35s ease;
}

.db-landing-nav--scroll-glass:not(.db-landing-nav--is-scrolled) {
	border-bottom: 1px solid transparent;
	box-shadow: none;
}

.db-landing-nav--scroll-glass.db-landing-nav--is-scrolled {
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	box-shadow: 0 4px 28px rgba(0, 0, 0, 0.18);
}

.db-landing-nav__glass {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	transition:
		background-color 0.35s ease,
		backdrop-filter 0.35s ease,
		-webkit-backdrop-filter 0.35s ease;
	background-color: transparent;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
}

.db-landing-nav--scroll-glass.db-landing-nav--is-scrolled .db-landing-nav__glass {
	background-color: rgba(10, 17, 40, 0.55);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
}

@media (prefers-reduced-motion: reduce) {
	.db-landing-nav--scroll-glass,
	.db-landing-nav__glass {
		transition-duration: 0.12s;
	}
}

.db-landing-nav__inner {
	pointer-events: auto;
	position: relative;
	z-index: 1;
	max-width: var(--db-ld-max);
	margin-left: auto;
	margin-right: auto;
	padding: 1rem 1.5rem;
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.db-landing-nav__logo {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	flex-shrink: 0;
	position: relative;
	z-index: 2;
}

.db-landing-nav__logo-img {
	display: block;
	width: auto;
	height: auto;
	max-width: 160px;
}

.db-landing-nav__monogram {
	display: flex;
	align-items: center;
	gap: 0.25rem;
}

.db-landing-nav__letter {
	color: var(--db-ld-gold);
	font-size: 1.5rem;
	font-family: ui-serif, Georgia, serif;
	line-height: 1;
}

.db-landing-nav__divider {
	width: 2rem;
	height: 2px;
	background: var(--db-ld-gold);
}

.db-landing-nav__tagline {
	font-size: 0.75rem;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	margin-top: 0.25rem;
}

/* Escritorio: enlaces + email */
.db-landing-nav__desktop {
	display: none;
	align-items: center;
	justify-content: flex-end;
	gap: clamp(1rem, 3vw, 2rem);
	flex: 1;
	min-width: 0;
}

.db-landing-nav__menu--desktop {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	align-content: center;
	justify-content: flex-end;
	gap: clamp(0.75rem, 2vw, 2rem);
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.25;
}

/* Misma caja visual que los enlaces (subrayado + padding) para alinear en fila */
.db-landing-nav__menu--desktop .db-landing-nav__link {
	display: inline-flex;
	align-items: center;
	box-sizing: border-box;
}

.db-landing-nav__email--desktop {
	display: none;
	align-items: center;
	gap: 0.5rem;
	flex-shrink: 0;
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.25;
	/* Reserva el hueco del borde inferior de los enlaces (2px + padding) */
	padding-bottom: 0.25rem;
	border-bottom: 2px solid transparent;
	box-sizing: border-box;
}

@media (min-width: 768px) {
	.db-landing-nav__desktop {
		display: flex;
	}
}

@media (min-width: 1024px) {
	.db-landing-nav__email--desktop {
		display: flex;
	}
}

/* Móvil: menú hamburguesa */
.db-landing-nav__drawer {
	display: block;
	flex-shrink: 0;
	position: relative;
	z-index: 2;
}

@media (min-width: 768px) {
	.db-landing-nav__drawer {
		display: none !important;
	}
}

.db-landing-nav__burger {
	list-style: none;
	cursor: pointer;
	width: 2.75rem;
	height: 2.75rem;
	border-radius: 0.375rem;
	border: 1px solid rgba(255, 255, 255, 0.25);
	background: rgba(10, 17, 40, 0.35);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 5px;
	padding: 0;
	margin: 0;
	transition:
		background 0.2s ease,
		border-color 0.2s ease;
}

.db-landing-nav__burger::-webkit-details-marker {
	display: none;
}

.db-landing-nav__burger:hover,
.db-landing-nav__burger:focus-visible {
	background: rgba(197, 160, 89, 0.15);
	border-color: var(--db-ld-gold);
	outline: none;
}

.db-landing-nav__burger-line {
	display: block;
	width: 1.25rem;
	height: 2px;
	background: #fff;
	border-radius: 1px;
	transition: transform 0.2s ease;
}

.db-landing-nav__drawer[open] .db-landing-nav__burger-line:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.db-landing-nav__drawer[open] .db-landing-nav__burger-line:nth-child(2) {
	opacity: 0;
}

.db-landing-nav__drawer[open] .db-landing-nav__burger-line:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/*
 * Panel móvil: z-index muy alto respecto a secciones Elementor (sticky, etc.).
 * Debe quedar por encima del contenido al hacer scroll.
 */
.db-landing-nav__drawer-panel {
	position: fixed;
	left: 0;
	right: 0;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	margin: 0;
	transform: none;
	top: clamp(4.75rem, 22vw, 6.5rem);
	bottom: 0;
	overflow-x: hidden;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	padding: 1.25rem max(1.25rem, env(safe-area-inset-left, 0px)) 1.5rem
		max(1.25rem, env(safe-area-inset-right, 0px));
	background: linear-gradient(180deg, #1a3d6e 0%, #143056 35%, #0d2244 70%, #0a1128 100%);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-top: 1px solid rgba(197, 160, 89, 0.25);
	box-shadow: 0 16px 48px rgba(0, 0, 0, 0.45);
	z-index: 100000;
}

.db-landing-nav__drawer[open] {
	z-index: 3;
}

.db-landing-nav__email--mobile,
.db-landing-nav__menu--mobile .db-landing-nav__link {
	overflow-wrap: anywhere;
	word-break: break-word;
}

.db-landing-nav__menu--mobile {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0.25rem;
	font-size: 1rem;
	font-weight: 500;
}

.db-landing-nav__menu--mobile .db-landing-nav__link {
	display: block;
	padding: 0.65rem 0.5rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 0;
}

.db-landing-nav__menu--mobile .db-landing-nav__link--current {
	border-bottom-color: var(--db-ld-gold);
}

.db-landing-nav__email--mobile {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid rgba(197, 160, 89, 0.2);
	font-size: 0.875rem;
}

.db-landing-nav__link {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
	border-bottom: 2px solid transparent;
	padding-bottom: 0.25rem;
}

.db-landing-nav__link:hover,
.db-landing-nav__link:focus-visible {
	color: var(--db-ld-gold);
}

.db-landing-nav__link--current {
	color: var(--db-ld-gold);
	border-bottom-color: var(--db-ld-gold);
}

.db-landing-nav__email-icon {
	width: 1rem;
	height: 1rem;
	flex-shrink: 0;
}

/* Hero */
.db-landing-hero {
	position: relative;
	display: flex;
	align-items: center;
	overflow: hidden;
	min-height: 700px;
	padding-top: 5rem;
}

.db-landing-hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.db-landing-hero__picture {
	display: block;
	width: 100%;
	height: 100%;
}

.db-landing-hero__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.db-landing-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		90deg,
		rgba(10, 17, 40, 0.9) 0%,
		rgba(10, 17, 40, 0.4) 50%,
		rgba(10, 17, 40, 0.1) 100%
	);
}

/* Parallax leve (transform aplicado por landing-motion.js) */
.db-landing-hero--parallax .db-landing-hero__picture,
.db-landing-hero--parallax .db-landing-hero__img {
	transform-origin: center center;
	will-change: transform;
	backface-visibility: hidden;
}

.db-landing-hero__inner {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: var(--db-ld-max);
	margin: 0 auto;
	padding: 0 1.5rem;
}

.db-landing-hero__copy {
	max-width: 42rem;
}

.db-landing-hero__title {
	margin: 0 0 1.5rem;
	color: #fff;
	font-size: clamp(2.25rem, 5vw, 3.75rem);
	font-weight: 700;
	line-height: 1.15;
	font-family: ui-serif, Georgia, serif;
}

.db-landing-hero__desc {
	margin: 0 0 2.5rem;
	color: #e5e7eb;
	font-size: clamp(1.05rem, 2vw, 1.25rem);
	max-width: 32rem;
}

/*
 * CTA dorado metálico (hero + shop partner): degradado champagne→oro→bronce,
 * bisel superior, borde #FFF2A8, halo dorado y brillo (ref. diseño).
 */
.db-landing-hero__cta {
	position: relative;
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	padding: 0.35rem;
	overflow: visible;
	border: 1px solid #fff2a8;
	border-radius: 0.875rem;
	background: linear-gradient(
		180deg,
		#f7d17d 0%,
		#f2cb6a 14%,
		#e5b751 42%,
		#c99732 76%,
		#b88a2e 100%
	);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.88),
		inset 0 20px 28px -14px rgba(255, 255, 255, 0.22),
		inset 0 -4px 12px rgba(45, 30, 6, 0.32),
		0 0 0 1px rgba(255, 235, 160, 0.5),
		0 6px 20px rgba(229, 183, 81, 0.4),
		0 14px 34px rgba(184, 138, 46, 0.28),
		0 0 44px rgba(247, 209, 125, 0.26);
	transition:
		transform 0.22s cubic-bezier(0.33, 1, 0.68, 1),
		box-shadow 0.22s ease,
		filter 0.2s ease;
}

.db-landing-hero__cta::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	pointer-events: none;
	z-index: 1;
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.5) 0%,
		rgba(255, 255, 255, 0.12) 32%,
		transparent 58%
	);
}

.db-landing-hero__cta > *:not(.db-gold-btn-beam) {
	position: relative;
	z-index: 3;
}

/*
 * Border beam — sin transform: rotate (evita “marco” girando fuera del botón).
 * Se anima el ángulo del conic-gradient vía @property; la máscara deja solo el anillo del borde.
 */
@property --db-gold-beam-angle {
	syntax: "<angle>";
	initial-value: 0deg;
	inherits: false;
}

.db-landing-hero__cta .db-gold-btn-beam,
.db-landing-partner__btn--shop .db-gold-btn-beam {
	--db-gold-beam-angle: 0deg;
	position: absolute;
	inset: 0;
	border-radius: inherit;
	z-index: 2;
	pointer-events: none;
	box-sizing: border-box;
	background: conic-gradient(
		from var(--db-gold-beam-angle),
		transparent 0deg,
		transparent 58deg,
		rgba(255, 255, 255, 0.35) 78deg,
		rgba(255, 252, 235, 1) 92deg,
		rgba(255, 245, 200, 0.95) 100deg,
		rgba(243, 208, 130, 0.75) 112deg,
		rgba(255, 255, 255, 0.3) 128deg,
		transparent 148deg,
		transparent 360deg
	);
	padding: 1.5px;
	-webkit-mask:
		linear-gradient(#fff 0 0) content-box,
		linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask:
		linear-gradient(#fff 0 0) content-box,
		linear-gradient(#fff 0 0);
	mask-composite: exclude;
	animation: db-gold-border-beam-angle 2.8s linear infinite;
	opacity: 0.92;
}

@keyframes db-gold-border-beam-angle {
	to {
		--db-gold-beam-angle: 360deg;
	}
}

.db-landing-hero__cta:hover {
	transform: translateY(-2px);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.95),
		inset 0 22px 32px -14px rgba(255, 255, 255, 0.28),
		inset 0 -4px 12px rgba(45, 30, 6, 0.22),
		0 0 0 1px rgba(255, 245, 200, 0.62),
		0 9px 28px rgba(247, 209, 125, 0.48),
		0 18px 42px rgba(229, 183, 81, 0.36),
		0 0 54px rgba(255, 236, 160, 0.32);
	filter: brightness(1.04);
}

.db-landing-hero__cta:focus-visible {
	outline: 2px solid #fff8d4;
	outline-offset: 4px;
}

.db-landing-hero__cta:focus-visible:not(:hover) {
	transform: translateY(-1px);
}

.db-landing-hero__cta:active {
	transform: translateY(0) scale(0.985);
	filter: brightness(0.97);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.5) inset,
		0 -2px 8px rgba(40, 28, 6, 0.35) inset,
		0 2px 10px rgba(184, 138, 46, 0.28);
	transition-duration: 0.08s;
}

.db-landing-hero__cta-iconwrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(180deg, #ffffff 0%, #f3f3f3 100%);
	padding: 0.75rem;
	border-radius: 0.5rem;
	margin-right: 0.75rem;
	border: 1px solid rgba(255, 255, 255, 0.85);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.9) inset,
		0 2px 6px rgba(10, 17, 40, 0.12);
	transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.db-landing-hero__cta:hover .db-landing-hero__cta-iconwrap {
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 1) inset,
		0 3px 10px rgba(10, 17, 40, 0.14);
}

.db-landing-hero__cta-logo {
	display: block;
	width: 1.5rem;
	height: 1.5rem;
	object-fit: contain;
}

.db-landing-hero__cta-text {
	padding-right: 1.5rem;
	text-align: left;
	display: flex;
	flex-direction: column;
	gap: 0.125rem;
}

.db-landing-hero__cta-line1 {
	font-size: 0.875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: -0.02em;
	color: #0a0a0a;
	text-shadow: 0 1px 0 rgba(255, 255, 255, 0.35);
}

.db-landing-hero__cta-line2 {
	font-size: 0.625rem;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.95);
	text-shadow: 0 1px 2px rgba(10, 17, 40, 0.35);
}

/* Features */
.db-landing-features {
	background: var(--db-ld-gray-50);
	padding: 4rem 0;
}

.db-landing-features__inner {
	max-width: var(--db-ld-max);
	margin: 0 auto;
	padding: 0 1.5rem;
}

.db-landing-features__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	text-align: center;
}

@media (min-width: 768px) {
	.db-landing-features__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.db-landing-features__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 1.25rem 1rem;
	border-radius: 0.75rem;
	border: 1px solid transparent;
	transition:
		transform 0.35s cubic-bezier(0.33, 1, 0.68, 1),
		box-shadow 0.35s ease,
		border-color 0.35s ease,
		background-color 0.35s ease;
}

.db-landing-features__item:hover {
	transform: translateY(-6px);
	border-color: rgba(197, 160, 89, 0.22);
	background-color: rgba(255, 255, 255, 0.65);
	box-shadow:
		0 12px 32px rgba(10, 17, 40, 0.08),
		0 4px 12px rgba(197, 160, 89, 0.12);
}

.db-landing-features__item:hover .db-landing-features__icon {
	transform: scale(1.08);
	color: var(--db-ld-gold-bright);
}

.db-landing-features__icon {
	margin-bottom: 1rem;
	color: var(--db-ld-gold);
	display: flex;
	align-items: center;
	justify-content: center;
	transition:
		transform 0.35s cubic-bezier(0.33, 1, 0.68, 1),
		color 0.3s ease;
}

.db-landing-icon--feature {
	width: 3rem;
	height: 3rem;
}

.db-landing-features__title {
	margin: 0 0 0.5rem;
	font-size: 1.25rem;
	font-weight: 700;
	color: #111827;
}

.db-landing-features__text {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.625;
	color: var(--db-ld-gray-600);
	max-width: 20rem;
}

/* How it works */
.db-landing-how {
	background: #fff;
	padding: 5rem 0;
}

.db-landing-how__inner {
	max-width: var(--db-ld-max);
	margin: 0 auto;
	padding: 0 1.5rem;
}

.db-landing-how__heading {
	margin: 0 0 4rem;
	text-align: center;
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	font-weight: 700;
	font-family: ui-serif, Georgia, serif;
	color: #111827;
}

.db-landing-how__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}

@media (min-width: 768px) {
	.db-landing-how__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.db-landing-how__card {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	padding: 0.5rem;
	margin: -0.5rem;
	border-radius: 0.75rem;
	border: 1px solid transparent;
	transition:
		transform 0.4s cubic-bezier(0.33, 1, 0.68, 1),
		box-shadow 0.4s ease,
		border-color 0.4s ease;
}

.db-landing-how__card:hover {
	transform: translateY(-5px);
	border-color: rgba(197, 160, 89, 0.2);
	box-shadow:
		0 16px 40px rgba(10, 17, 40, 0.09),
		0 6px 16px rgba(197, 160, 89, 0.1);
}

.db-landing-how__figure {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: 0.5rem;
	border: 1px solid var(--db-ld-gray-200);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
	transition:
		box-shadow 0.4s ease,
		border-color 0.4s ease;
}

.db-landing-how__card:hover .db-landing-how__figure {
	border-color: rgba(197, 160, 89, 0.35);
	box-shadow: 0 8px 24px rgba(10, 17, 40, 0.12);
}

.db-landing-how__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.55s cubic-bezier(0.33, 1, 0.68, 1);
}

.db-landing-how__card:hover .db-landing-how__img {
	transform: scale(1.04);
}

.db-landing-how__row {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
}

.db-landing-how__badge {
	flex-shrink: 0;
	width: 2rem;
	height: 2rem;
	margin-top: 0.25rem;
	padding: 0.5rem;
	border-radius: 9999px;
	background: var(--db-ld-gold);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
}

.db-landing-icon--process {
	width: 1rem;
	height: 1rem;
}

.db-landing-how__title {
	margin: 0 0 0.25rem;
	font-size: 1.125rem;
	font-weight: 700;
	color: #111827;
}

.db-landing-how__text {
	margin: 0;
	font-size: 0.875rem;
	color: var(--db-ld-gray-500);
	line-height: 1.5;
}

/* Contact (Contact Form 7) */
.db-landing-contact {
	position: relative;
	background: linear-gradient(165deg, #fcfcfd 0%, var(--db-ld-gray-50) 45%, #f3f4f6 100%);
	padding-block: clamp(2.25rem, 6vw, 4.5rem);
	padding-inline: 0;
}

.db-landing-contact__inner {
	max-width: var(--db-ld-max);
	margin: 0 auto;
	width: 100%;
	box-sizing: border-box;
	padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
	padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
}

@media (min-width: 480px) {
	.db-landing-contact__inner {
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
	}
}

@media (min-width: 768px) {
	.db-landing-contact__inner {
		padding-left: max(1.25rem, env(safe-area-inset-left, 0px));
		padding-right: max(1.25rem, env(safe-area-inset-right, 0px));
	}
}

@media (min-width: 1024px) {
	.db-landing-contact__inner {
		padding-left: max(1.5rem, env(safe-area-inset-left, 0px));
		padding-right: max(1.5rem, env(safe-area-inset-right, 0px));
	}
}

.db-landing-contact__header {
	text-align: center;
	max-width: 36rem;
	margin: 0 auto clamp(1.5rem, 4vw, 2.5rem);
	padding-inline: 0;
}

.db-landing-contact__heading {
	margin: 0 0 0.875rem;
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	font-weight: 700;
	font-family: ui-serif, Georgia, serif;
	color: #111827;
	letter-spacing: -0.02em;
	line-height: 1.2;
}

.db-landing-contact__heading::after {
	content: '';
	display: block;
	width: 2.75rem;
	height: 3px;
	margin: 1rem auto 0;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--db-ld-gold-bright), var(--db-ld-gold));
	opacity: 0.95;
}

.db-landing-contact__lead {
	margin: 0;
	font-size: 1rem;
	line-height: 1.65;
	color: var(--db-ld-gray-600);
	max-width: 34rem;
	margin-inline: auto;
}

.db-landing-contact__form {
	max-width: min(48rem, 100%);
	width: 100%;
	margin: 0 auto;
	box-sizing: border-box;
	padding-block: clamp(0.875rem, 2vw, 1.25rem);
	padding-inline: clamp(0.625rem, 2vw, 0.875rem);
	background: #fff;
	border: 1px solid rgba(10, 17, 40, 0.07);
	border-radius: clamp(0.625rem, 1.5vw, 0.875rem);
	box-shadow:
		0 1px 2px rgba(10, 17, 40, 0.04),
		0 14px 40px -12px rgba(10, 17, 40, 0.1);
}

@media (min-width: 480px) {
	.db-landing-contact__form {
		padding-block: 1rem;
		padding-inline: 0.875rem;
	}
}

@media (min-width: 640px) {
	.db-landing-contact__form {
		padding-block: 1.125rem;
		padding-inline: 1rem;
	}
}

@media (min-width: 768px) {
	.db-landing-contact__form {
		padding-block: 1.25rem;
		padding-inline: 1.125rem;
	}
}

.db-landing-contact__notice {
	margin: 0;
	padding: 0.875rem clamp(0.75rem, 3vw, 1.25rem);
	border-radius: 0.625rem;
	background: rgba(197, 160, 89, 0.1);
	border: 1px solid rgba(197, 160, 89, 0.28);
	color: var(--db-ld-gray-600);
	font-size: 0.875rem;
	line-height: 1.5;
}

/* Pantalla de agradecimiento (tras envío CF7) */
.db-landing-contact__success[hidden] {
	display: none !important;
}

.db-landing-contact__success {
	text-align: center;
	padding: 0.5rem 0 0.25rem;
}

.db-landing-contact__success-icon {
	display: flex;
	justify-content: center;
	margin: 0 0 1.125rem;
	color: var(--db-ld-gold);
}

.db-landing-contact__success-icon svg {
	display: block;
}

.db-landing-contact__success-icon-bg {
	fill: rgba(197, 160, 89, 0.14);
	stroke: rgba(197, 160, 89, 0.35);
	stroke-width: 1;
}

.db-landing-contact__success-title {
	margin: 0 0 0.5rem;
	font-size: 1.375rem;
	font-weight: 700;
	font-family: ui-serif, Georgia, serif;
	color: #111827;
	letter-spacing: -0.02em;
	line-height: 1.25;
}

.db-landing-contact__success-text {
	margin: 0 0 1.35rem;
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--db-ld-gray-600);
}

.db-landing-contact__success-reset {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0.5rem 1rem;
	font-family: inherit;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--db-ld-gray-600);
	background: transparent;
	border: 1px solid rgba(10, 17, 40, 0.12);
	border-radius: 0.5rem;
	cursor: pointer;
	transition:
		color 0.2s ease,
		border-color 0.2s ease,
		background-color 0.2s ease;
}

.db-landing-contact__success-reset:hover {
	color: #111827;
	border-color: rgba(197, 160, 89, 0.45);
	background: rgba(197, 160, 89, 0.06);
}

.db-landing-contact__success-reset:focus-visible {
	outline: 2px solid var(--db-ld-gold);
	outline-offset: 2px;
}

.db-landing-contact__success--animate {
	animation: db-landing-contact-success-in 0.4s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes db-landing-contact-success-in {
	from {
		opacity: 0;
		transform: translateY(0.5rem);
	}

	to {
		opacity: 1;
		transform: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.db-landing-contact__success--animate {
		animation: none;
	}
}

/* CF7 dentro del bloque de contacto */
.db-landing-contact .wpcf7 {
	margin: 0;
}

/*
 * CF7: dos columnas con grid (minmax(0,1fr)) para que nombre y email compartan fila
 * aunque el contenedor sea estrecho. Flex + min-width rompía la 2.ª columna (email abajo).
 * !important gana a display:block de Elementor. Campo oculto CF7 = fieldset display:none (no ocupa celda).
 */
.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form,
.db-landing.db-landing-contact .wpcf7 .wpcf7-form,
.db-landing-contact .wpcf7-form.wpcf7-form {
	display: grid !important;
	grid-template-columns: 1fr;
	gap: 0.625rem 0.75rem;
	width: 100%;
	min-width: 0;
	box-sizing: border-box;
	align-items: start;
}

@media (min-width: 480px) {
	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form,
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form,
	.db-landing-contact .wpcf7-form.wpcf7-form {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 0.75rem 1rem;
	}

	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > *,
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form > *,
	.db-landing-contact .wpcf7-form.wpcf7-form > * {
		min-width: 0;
		box-sizing: border-box;
	}

	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > fieldset.hidden-fields-container,
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form > fieldset.hidden-fields-container,
	.db-landing-contact .wpcf7-form.wpcf7-form > fieldset.hidden-fields-container {
		display: none !important;
	}

	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > p:has(textarea),
	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > p:has(input[type='file']),
	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > p:has(input[type='submit']),
	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > p:has(button[type='submit']),
	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > p:has(.wpcf7-acceptance),
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form > p:has(textarea),
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form > p:has(input[type='file']),
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form > p:has(input[type='submit']),
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form > p:has(button[type='submit']),
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form > p:has(.wpcf7-acceptance),
	.db-landing-contact .wpcf7-form.wpcf7-form > p:has(textarea),
	.db-landing-contact .wpcf7-form.wpcf7-form > p:has(input[type='file']),
	.db-landing-contact .wpcf7-form.wpcf7-form > p:has(input[type='submit']),
	.db-landing-contact .wpcf7-form.wpcf7-form > p:has(button[type='submit']),
	.db-landing-contact .wpcf7-form.wpcf7-form > p:has(.wpcf7-acceptance) {
		grid-column: 1 / -1;
	}

	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > .wpcf7-response-output,
	.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > fieldset:not(.hidden-fields-container),
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form > .wpcf7-response-output,
	.db-landing.db-landing-contact .wpcf7 .wpcf7-form > fieldset:not(.hidden-fields-container),
	.db-landing-contact .wpcf7-form.wpcf7-form > .wpcf7-response-output,
	.db-landing-contact .wpcf7-form.wpcf7-form > fieldset:not(.hidden-fields-container) {
		grid-column: 1 / -1;
	}
}

/* Navegadores sin :has(): del 3.er <p> en adelante a ancho completo (nombre y email = 1.º y 2.º <p>). */
@supports not selector(:has(*)) {
	@media (min-width: 480px) {
		.elementor-widget-divine_bridge_landing_contact .db-landing-contact .wpcf7-form.wpcf7-form > p:nth-of-type(n + 3),
		.db-landing.db-landing-contact .wpcf7 .wpcf7-form > p:nth-of-type(n + 3),
		.db-landing-contact .wpcf7-form.wpcf7-form > p:nth-of-type(n + 3) {
			grid-column: 1 / -1;
		}
	}
}

.db-landing-contact .wpcf7-form > p {
	margin: 0;
	min-width: 0;
}

.db-landing-contact .wpcf7 label,
.db-landing-contact .wpcf7 .wpcf7-form-control-wrap {
	display: block;
	width: 100%;
	min-width: 0;
}

.db-landing-contact .wpcf7 label {
	font-size: 0.8125rem;
	font-weight: 600;
	color: #374151;
	margin-bottom: 0.3rem;
	letter-spacing: 0.01em;
}

.db-landing-contact .wpcf7 .wpcf7-form-control-wrap {
	margin-top: 0;
}

.db-landing-contact .wpcf7 input[type='text'],
.db-landing-contact .wpcf7 input[type='email'],
.db-landing-contact .wpcf7 input[type='tel'],
.db-landing-contact .wpcf7 input[type='url'],
.db-landing-contact .wpcf7 select,
.db-landing-contact .wpcf7 textarea {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	padding: 0.5625rem 0.6875rem;
	font-family: inherit;
	font-size: max(16px, 0.9375rem);
	line-height: 1.45;
	color: #111827;
	background: #fafbfc;
	border: 1px solid rgba(10, 17, 40, 0.1);
	border-radius: 0.625rem;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		background-color 0.2s ease;
}

@media (min-width: 480px) {
	.db-landing-contact .wpcf7 input[type='text'],
	.db-landing-contact .wpcf7 input[type='email'],
	.db-landing-contact .wpcf7 input[type='tel'],
	.db-landing-contact .wpcf7 input[type='url'],
	.db-landing-contact .wpcf7 select,
	.db-landing-contact .wpcf7 textarea {
		padding: 0.625rem 0.8125rem;
		font-size: max(16px, 0.9375rem);
	}
}

.db-landing-contact .wpcf7 textarea {
	min-height: clamp(3.75rem, 14vw, 4.75rem);
	resize: vertical;
}

.db-landing-contact .wpcf7 input:focus,
.db-landing-contact .wpcf7 select:focus,
.db-landing-contact .wpcf7 textarea:focus {
	outline: none;
	background: #fff;
	border-color: rgba(197, 160, 89, 0.65);
	box-shadow:
		0 0 0 3px rgba(197, 160, 89, 0.18),
		inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.db-landing-contact .wpcf7 input[type='submit'],
.db-landing-contact .wpcf7 button[type='submit'] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	margin-top: 0.0625rem;
	padding: 0.625rem 0.875rem;
	font-family: inherit;
	font-size: 0.9375rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	text-transform: none;
	color: #0a1128;
	background: linear-gradient(135deg, var(--db-ld-gold-bright) 0%, var(--db-ld-gold) 100%);
	border: none;
	border-radius: 0.625rem;
	cursor: pointer;
	box-shadow:
		0 4px 14px rgba(197, 160, 89, 0.32),
		0 1px 3px rgba(10, 17, 40, 0.1);
	transition:
		transform 0.2s ease,
		box-shadow 0.2s ease,
		filter 0.2s ease;
}

@media (min-width: 480px) {
	.db-landing-contact .wpcf7 input[type='submit'],
	.db-landing-contact .wpcf7 button[type='submit'] {
		padding: 0.6875rem 1.125rem;
	}
}

@media (min-width: 640px) {
	.db-landing-contact .wpcf7 input[type='submit'],
	.db-landing-contact .wpcf7 button[type='submit'] {
		padding: 0.75rem 1.25rem;
	}
}

.db-landing-contact .wpcf7 input[type='submit']:hover,
.db-landing-contact .wpcf7 button[type='submit']:hover {
	filter: brightness(1.04);
	box-shadow:
		0 6px 22px rgba(197, 160, 89, 0.38),
		0 2px 6px rgba(10, 17, 40, 0.12);
}

.db-landing-contact .wpcf7 input[type='submit']:active,
.db-landing-contact .wpcf7 button[type='submit']:active {
	transform: translateY(1px);
}

.db-landing-contact .wpcf7 input[type='submit']:focus-visible,
.db-landing-contact .wpcf7 button[type='submit']:focus-visible {
	outline: 2px solid var(--db-ld-gold);
	outline-offset: 3px;
}

.db-landing-contact .wpcf7-not-valid-tip {
	font-size: 0.75rem;
	color: #b45309;
	margin-top: 0.35rem;
}

.db-landing-contact .wpcf7-response-output {
	margin: 0.625rem 0 0;
	padding: 0.5rem 0.75rem;
	border-radius: 0.5rem;
	font-size: 0.875rem;
	border-width: 1px;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

.db-landing-contact .wpcf7-mail-sent-ok {
	background: rgba(34, 197, 94, 0.1);
	border-color: rgba(34, 197, 94, 0.45);
	color: #166534;
}

.db-landing-contact .wpcf7-validation-errors,
.db-landing-contact .wpcf7-acceptance-missing,
.db-landing-contact .wpcf7-spam-blocked,
.db-landing-contact .wpcf7-mail-sent-ng {
	background: rgba(254, 226, 226, 0.6);
	border-color: rgba(220, 38, 38, 0.35);
	color: #991b1b;
}

/* Partner CTA */
.db-landing-partner {
	position: relative;
	overflow: hidden;
	background: var(--db-ld-dark);
	color: #fff;
	padding: 5rem 0;
}

.db-landing-partner__glow {
	position: absolute;
	pointer-events: none;
	filter: blur(100px);
	z-index: 0;
}

.db-landing-partner__glow--tr {
	top: 0;
	right: 0;
	width: 50%;
	height: 100%;
	background: rgba(30, 58, 138, 0.1);
}

.db-landing-partner__glow--bl {
	bottom: 0;
	left: 0;
	width: 33%;
	height: 50%;
	background: rgba(197, 160, 89, 0.05);
	filter: blur(80px);
}

.db-landing-partner__inner {
	position: relative;
	z-index: 1;
	max-width: var(--db-ld-max);
	margin: 0 auto;
	padding: 0 1.5rem;
}

.db-landing-partner__grid {
	display: grid;
	gap: 2.5rem;
	align-items: center;
}

@media (min-width: 1024px) {
	.db-landing-partner__grid {
		grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
		gap: 3rem 3.5rem;
		align-items: center;
	}
}

.db-landing-partner__visual {
	width: 100%;
	max-width: 22rem;
	margin-left: auto;
	margin-right: auto;
}

@media (min-width: 1024px) {
	.db-landing-partner__visual {
		max-width: none;
		margin: 0;
		justify-self: stretch;
	}
}

/* Sin imagen: no ocupa espacio en móvil; en escritorio se reserva la columna derecha */
@media (max-width: 1023px) {
	.db-landing-partner__visual--empty {
		display: none;
	}
}

.db-landing-partner__figure {
	margin: 0;
	position: relative;
	border-radius: 1rem;
	overflow: hidden;
	aspect-ratio: 4 / 5;
	border: 1px solid rgba(255, 255, 255, 0.08);
	box-shadow:
		0 4px 24px rgba(0, 0, 0, 0.35),
		0 0 0 1px rgba(197, 160, 89, 0.12);
	background: rgba(10, 17, 40, 0.6);
}

.db-landing-partner__side-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
}

.db-landing-partner__figure--placeholder {
	border: 2px dashed rgba(255, 255, 255, 0.18);
	box-shadow: none;
	background:
		linear-gradient(145deg, rgba(197, 160, 89, 0.06) 0%, transparent 55%),
		rgba(10, 17, 40, 0.45);
}

.elementor-editor-active .db-landing-partner__figure--placeholder {
	border-color: rgba(197, 160, 89, 0.4);
	background:
		linear-gradient(145deg, rgba(197, 160, 89, 0.12) 0%, transparent 50%),
		rgba(10, 17, 40, 0.5);
}

.db-landing-partner__main {
	text-align: center;
}

@media (min-width: 1024px) {
	.db-landing-partner__main {
		text-align: left;
	}
}

.db-landing-partner__logo {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-bottom: 2rem;
}

@media (min-width: 1024px) {
	.db-landing-partner__logo {
		align-items: flex-start;
	}
}

.db-landing-partner__logo-img {
	display: block;
	width: auto;
	height: auto;
	max-width: 200px;
}

.db-landing-partner__monogram {
	display: flex;
	align-items: center;
	gap: 0.25rem;
}

.db-landing-partner__letter {
	color: var(--db-ld-gold);
	font-size: 1.875rem;
	font-family: ui-serif, Georgia, serif;
}

.db-landing-partner__divider {
	width: 2.5rem;
	height: 2px;
	background: var(--db-ld-gold);
}

.db-landing-partner__brand {
	margin-top: 0.5rem;
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.4em;
	text-transform: uppercase;
}

.db-landing-partner__subbrand {
	margin-top: 0.25rem;
	font-size: 0.625rem;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	opacity: 0.6;
}

.db-landing-partner__heading {
	margin: 0 0 1rem;
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 700;
	line-height: 1.2;
	font-family: ui-serif, Georgia, serif;
}

.db-landing-partner__desc {
	margin: 0 0 2rem;
	color: #9ca3af;
	font-size: 1.125rem;
	max-width: 36rem;
}

.db-landing-partner__actions {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	align-items: stretch;
	justify-content: center;
	overflow: visible;
}

@media (min-width: 640px) {
	.db-landing-partner__actions {
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
		justify-content: center;
	}
}

@media (min-width: 1024px) {
	.db-landing-partner__actions {
		justify-content: flex-start;
	}
}

.db-landing-partner__btn {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	border-radius: 0.625rem;
	transition:
		transform 0.22s cubic-bezier(0.33, 1, 0.68, 1),
		box-shadow 0.22s ease,
		filter 0.2s ease,
		background 0.22s ease,
		border-color 0.22s ease;
}

.db-landing-partner__btn--shop {
	position: relative;
	padding: 0.35rem;
	overflow: visible;
	border: 1px solid #fff2a8;
	border-radius: 0.875rem;
	background: linear-gradient(
		180deg,
		#f7d17d 0%,
		#f2cb6a 14%,
		#e5b751 42%,
		#c99732 76%,
		#b88a2e 100%
	);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.88),
		inset 0 20px 28px -14px rgba(255, 255, 255, 0.22),
		inset 0 -4px 12px rgba(45, 30, 6, 0.32),
		0 0 0 1px rgba(255, 235, 160, 0.5),
		0 6px 20px rgba(229, 183, 81, 0.4),
		0 14px 34px rgba(184, 138, 46, 0.28),
		0 0 44px rgba(247, 209, 125, 0.26);
}

.db-landing-partner__btn--shop::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	pointer-events: none;
	z-index: 1;
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.5) 0%,
		rgba(255, 255, 255, 0.12) 32%,
		transparent 58%
	);
}

.db-landing-partner__btn--shop > *:not(.db-gold-btn-beam) {
	position: relative;
	z-index: 3;
}

.db-landing-partner__btn--shop:hover {
	transform: translateY(-2px);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.95),
		inset 0 22px 32px -14px rgba(255, 255, 255, 0.28),
		inset 0 -4px 12px rgba(45, 30, 6, 0.22),
		0 0 0 1px rgba(255, 245, 200, 0.62),
		0 9px 28px rgba(247, 209, 125, 0.48),
		0 18px 42px rgba(229, 183, 81, 0.36),
		0 0 54px rgba(255, 236, 160, 0.32);
	filter: brightness(1.04);
}

.db-landing-partner__btn--shop:focus-visible {
	outline: 2px solid #fff8d4;
	outline-offset: 4px;
}

.db-landing-partner__btn--shop:focus-visible:not(:hover) {
	transform: translateY(-1px);
}

.db-landing-partner__btn--shop:active {
	transform: translateY(0) scale(0.985);
	filter: brightness(0.97);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.5) inset,
		0 -2px 8px rgba(40, 28, 6, 0.35) inset,
		0 2px 10px rgba(184, 138, 46, 0.28);
	transition-duration: 0.08s;
}

.db-landing-partner__btn-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(180deg, #ffffff 0%, #f3f3f3 100%);
	padding: 0.5rem;
	border-radius: 0.5rem;
	margin-right: 0.75rem;
	border: 1px solid rgba(255, 255, 255, 0.85);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.9) inset,
		0 2px 6px rgba(10, 17, 40, 0.12);
	transition: box-shadow 0.22s ease;
}

.db-landing-partner__btn--shop:hover .db-landing-partner__btn-icon {
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 1) inset,
		0 3px 10px rgba(10, 17, 40, 0.14);
}

.db-landing-partner__btn-icon img {
	width: 1.25rem;
	height: 1.25rem;
	object-fit: contain;
	display: block;
}

.db-landing-partner__btn-text {
	display: flex;
	flex-direction: column;
	gap: 0.125rem;
	text-align: left;
	padding-right: 1.5rem;
}

.db-landing-partner__btn-line1 {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	color: #0a0a0a;
	text-shadow: 0 1px 0 rgba(255, 255, 255, 0.35);
}

.db-landing-partner__btn-line2 {
	font-size: 0.625rem;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.95);
	text-shadow: 0 1px 2px rgba(10, 17, 40, 0.35);
}

.db-landing-partner__btn--outline {
	padding: 0.35rem 0.3rem;
	border: 2px solid rgba(197, 160, 89, 0.55);
	background: rgba(10, 17, 40, 0.55);
	backdrop-filter: blur(6px);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.06) inset,
		0 2px 12px rgba(0, 0, 0, 0.25);
}

.db-landing-partner__btn--outline:hover {
	transform: translateY(-2px);
	border-color: rgba(243, 208, 130, 0.65);
	background: rgba(197, 160, 89, 0.14);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.1) inset,
		0 4px 20px rgba(197, 160, 89, 0.12),
		0 12px 32px rgba(0, 0, 0, 0.35);
}

.db-landing-partner__btn--outline:focus-visible {
	outline: 2px solid var(--db-ld-gold-bright);
	outline-offset: 3px;
}

.db-landing-partner__btn--outline:active {
	transform: translateY(0) scale(0.99);
	transition-duration: 0.08s;
}

.db-landing-partner__btn-outline-icon {
	padding: 0.5rem;
	margin-right: 0.5rem;
	display: inline-flex;
	color: var(--db-ld-gold);
}

.db-landing-partner__svg-user {
	width: 1.5rem;
	height: 1.5rem;
}

.db-landing-partner__btn-gold {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	color: var(--db-ld-gold);
}

.db-landing-partner__btn-muted {
	font-size: 0.625rem;
	font-weight: 500;
	color: #9ca3af;
}

/* Footer (solo color sólido por defecto; la imagen la añade Elementor en el widget) */
.db-landing-foot {
	background-color: var(--db-ld-dark);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	border-top: 1px solid rgba(255, 255, 255, 0.05);
	padding: 2rem 0;
	color: rgba(255, 255, 255, 0.6);
	font-size: 0.75rem;
}

.db-landing-foot__brand {
	width: 100%;
	text-align: center;
}

.db-landing-foot__logo {
	display: block;
	width: auto;
	height: auto;
	max-width: 140px;
	margin-inline: auto;
	opacity: 0.9;
}

.db-landing-foot__inner {
	max-width: var(--db-ld-max);
	margin: 0 auto;
	padding: 0 1.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	justify-content: flex-end;
}

/* Con logo en escritorio: grid 1fr | logo | 1fr (clase en <footer> desde el widget) */
@media (min-width: 768px) {
	.db-landing-foot--has-logo .db-landing-foot__inner {
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
		align-items: end;
		gap: 1rem 1.25rem;
		width: 100%;
	}

	.db-landing-foot--has-logo .db-landing-foot__brand {
		grid-column: 2;
		grid-row: 1;
		justify-self: center;
		width: auto;
		text-align: center;
	}

	.db-landing-foot--has-logo .db-landing-foot__store {
		grid-column: 1;
		grid-row: 1;
		justify-self: start;
		justify-content: flex-start;
		text-align: left;
	}

	.db-landing-foot--has-logo .db-landing-foot__social {
		grid-column: 3;
		grid-row: 1;
		justify-self: end;
	}

	.db-landing-foot:not(.db-landing-foot--has-logo) .db-landing-foot__inner {
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: flex-end;
	}
}

.db-landing-foot__store {
	display: flex;
	align-items: flex-end;
	gap: 0.5rem;
	flex-wrap: wrap;
	justify-content: center;
}

.db-landing-foot__store-label {
	color: var(--db-ld-gold);
	font-weight: 600;
}

.db-landing-foot__store-link {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
}

.db-landing-foot__store-link:hover,
.db-landing-foot__store-link:focus-visible {
	color: var(--db-ld-gold);
}

.db-landing-foot__store-text {
	color: inherit;
}

.db-landing-foot__social {
	display: flex;
	gap: 1.5rem;
	align-items: flex-end;
}

.db-landing-foot__icon {
	color: inherit;
	transition: color 0.2s ease;
	display: flex;
}

.db-landing-foot__icon:hover,
.db-landing-foot__icon:focus-visible {
	color: var(--db-ld-gold);
}

.db-landing-foot__svg {
	width: 1.25rem;
	height: 1.25rem;
	fill: currentColor;
}

.db-feature-card {
	display: flex;
	flex-direction: column;
	width: 100%;
	box-sizing: border-box;
}

.db-feature-card__overline {
	margin: 0;
}

.db-feature-card__title {
	margin: 0;
}

.db-feature-card__text {
	margin: 0;
}

/* Botón Jewel (tarjetas): degradado, sombra y foco alineados al resto del landing */
.db-feature-card__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	box-sizing: border-box;
	background-color: transparent;
	background-image: linear-gradient(
		145deg,
		var(--db-jewel-a, #775a19) 0%,
		var(--db-jewel-b, #4d3a11) 100%
	);
	color: var(--db-jewel-fg, #1c1408);
	border: none;
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.2) inset,
		0 1px 2px rgba(28, 20, 8, 0.15),
		0 4px 14px rgba(77, 58, 17, 0.22);
	transition:
		filter 0.22s ease,
		transform 0.22s cubic-bezier(0.33, 1, 0.68, 1),
		box-shadow 0.22s ease,
		color 0.2s ease;
}

.db-feature-card__btn:hover {
	filter: brightness(1.09);
	transform: translateY(-2px);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.28) inset,
		0 2px 4px rgba(28, 20, 8, 0.12),
		0 8px 22px rgba(77, 58, 17, 0.3);
}

.db-feature-card__btn:focus-visible {
	outline: 2px solid var(--db-jewel-a, #775a19);
	outline-offset: 3px;
	filter: brightness(1.06);
}

.db-feature-card__btn:active {
	transform: translateY(0) scale(0.985);
	filter: brightness(0.97);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.12) inset,
		0 2px 6px rgba(28, 20, 8, 0.2);
	transition-duration: 0.08s;
}

.db-feature-card__btn--static {
	cursor: default;
	pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
	.db-landing-hero__cta,
	.db-landing-partner__btn,
	.db-feature-card__btn {
		transition-duration: 0.15s;
		transition-property: opacity, box-shadow, filter;
	}

	.db-landing-hero__cta:hover,
	.db-landing-hero__cta:focus-visible,
	.db-landing-hero__cta:active,
	.db-landing-partner__btn--shop:hover,
	.db-landing-partner__btn--shop:focus-visible,
	.db-landing-partner__btn--shop:active,
	.db-landing-partner__btn--outline:hover,
	.db-landing-partner__btn--outline:active,
	.db-feature-card__btn:hover,
	.db-feature-card__btn:active {
		transform: none;
	}

	.db-landing-hero__cta .db-gold-btn-beam,
	.db-landing-partner__btn--shop .db-gold-btn-beam {
		animation: none;
		opacity: 0.35;
	}

	.db-landing-features__item,
	.db-landing-features__item:hover,
	.db-landing-features__icon,
	.db-landing-how__card,
	.db-landing-how__card:hover,
	.db-landing-how__img {
		transition: none !important;
		transform: none !important;
	}

	.db-landing-reveal .db-landing-features__item,
	.db-landing-reveal .db-landing-how__heading,
	.db-landing-reveal .db-landing-how__card,
	.db-landing-reveal .db-landing-contact__inner,
	.db-landing-reveal .db-landing-partner__grid,
	.db-landing-reveal .db-landing-foot__inner {
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
	}
}

.db-feature-card--align-left {
	align-items: flex-start;
	text-align: left;
}

.db-feature-card--align-center {
	align-items: center;
	text-align: center;
}

.db-feature-card--align-right {
	align-items: flex-end;
	text-align: right;
}

/* —— Revelado al scroll (landing-motion.js) —— */
.db-landing-reveal .db-landing-features__item {
	opacity: 0;
	transform: translateY(1.5rem);
	transition:
		opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.7s cubic-bezier(0.22, 1, 0.36, 1),
		box-shadow 0.35s ease,
		border-color 0.35s ease,
		background-color 0.35s ease;
}

.db-landing-reveal .db-landing-how__heading,
.db-landing-reveal .db-landing-how__card,
.db-landing-reveal .db-landing-contact__inner,
.db-landing-reveal .db-landing-partner__grid,
.db-landing-reveal .db-landing-foot__inner {
	opacity: 0;
	transform: translateY(1.5rem);
	transition:
		opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.db-landing-reveal .db-landing-how__card {
	transition:
		opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.7s cubic-bezier(0.22, 1, 0.36, 1),
		box-shadow 0.4s ease,
		border-color 0.4s ease;
}

.db-landing-reveal.db-landing-reveal--visible .db-landing-features__item,
.db-landing-reveal.db-landing-reveal--visible .db-landing-how__heading,
.db-landing-reveal.db-landing-reveal--visible .db-landing-how__card,
.db-landing-reveal.db-landing-reveal--visible .db-landing-contact__inner,
.db-landing-reveal.db-landing-reveal--visible .db-landing-partner__grid,
.db-landing-reveal.db-landing-reveal--visible .db-landing-foot__inner {
	opacity: 1;
	transform: none;
}

.db-landing-reveal.db-landing-reveal--visible .db-landing-features__item:nth-child(1) {
	transition-delay: 0.05s;
}

.db-landing-reveal.db-landing-reveal--visible .db-landing-features__item:nth-child(2) {
	transition-delay: 0.12s;
}

.db-landing-reveal.db-landing-reveal--visible .db-landing-features__item:nth-child(3) {
	transition-delay: 0.19s;
}

.db-landing-reveal.db-landing-reveal--visible .db-landing-how__card:nth-child(1) {
	transition-delay: 0.06s;
}

.db-landing-reveal.db-landing-reveal--visible .db-landing-how__card:nth-child(2) {
	transition-delay: 0.14s;
}

.db-landing-reveal.db-landing-reveal--visible .db-landing-how__card:nth-child(3) {
	transition-delay: 0.22s;
}

/* Editor Elementor: ver contenido sin esperar al scroll */
.elementor-editor-active .db-landing-reveal .db-landing-features__item,
.elementor-editor-active .db-landing-reveal .db-landing-how__heading,
.elementor-editor-active .db-landing-reveal .db-landing-how__card,
.elementor-editor-active .db-landing-reveal .db-landing-contact__inner,
.elementor-editor-active .db-landing-reveal .db-landing-partner__grid,
.elementor-editor-active .db-landing-reveal .db-landing-foot__inner {
	opacity: 1 !important;
	transform: none !important;
	transition: none !important;
}
