/* Base frontend y componentes compartidos. */

.fpdual-ui,
.fpdual-ui * {
	box-sizing: border-box;
}

.fpdual-ui {
	color: var(--fpdual-color-text);
	font-family: var(--fpdual-font-body);
	font-size: 14px;
	font-weight: 400;
	line-height: 1.45;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

.fpdual-ui :where(p, h1, h2, h3, h4, h5, h6, ul, ol, li, fieldset, legend) {
	font-family: inherit;
	letter-spacing: 0;
}

.fpdual-ui :where(p, li) {
	font-size: 14px;
	line-height: 1.45;
}

.fpdual-ui :where(a) {
	color: var(--fpdual-color-primary);
	font-weight: 800;
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
}

.fpdual-ui :where(a:hover, a:focus) {
	color: var(--fpdual-color-primary-strong);
}

.fpdual-section {
	width: min(var(--fpdual-max-width), calc(100% - 32px));
	margin-inline: auto;
	padding-block: var(--fpdual-space-page);
}

.fpdual-panel {
	position: relative;
	/*background: var(--fpdual-color-surface);*/
	box-shadow: var(--fpdual-shadow-panel);
}

.fpdual-panel::before,
.fpdual-panel::after {
	content: "";
	position: absolute;
	display: block;
	background: var(--fpdual-color-primary);
	pointer-events: none;
}

.fpdual-panel::before {
	top: -18px;
	right: clamp(18px, 8vw, 88px);
	width: 34px;
	height: 34px;
}

.fpdual-panel::after {
	right: -14px;
	bottom: 72px;
	width: 18px;
	height: 18px;
	opacity: 0.75;
}

.fpdual-kicker {
	display: inline-flex;
	border: 2px solid var(--fpdual-color-primary);
    background: var(--fpdual-color-surface-transparent);
    color: var(--fpdual-color-primary);
    font-family: var(--fpdual-font-display);
	align-items: center;
	min-height: 28px;
	margin: 0 0 12px;
	padding: 5px 10px;
	font-size: 13px;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
}

.fpdual-title {
	margin: 0;
	color: var(--fpdual-color-primary);
	font-family: var(--fpdual-font-display);
	font-size: clamp(34px, 4.2vw, 58px);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: 0;
}

.fpdual-lead {
	max-width: 760px;
	margin: 16px 0 0;
	color: var(--fpdual-color-ink);
	font-size: clamp(15px, 1.2vw, 17px);
	font-weight: 600;
	line-height: 1.45;
	gap:20px;
}

.fpdual-deco-squares {
	position: absolute;
	top: clamp(26px, 4vw, 48px);
	right: clamp(18px, 3vw, 34px);
	width: 58px;
	height: 72px;
	pointer-events: none;
	z-index: 0;
}

.fpdual-deco-squares::before,
.fpdual-deco-squares::after {
	content: "";
	position: absolute;
	background: var(--fpdual-color-primary);
}

.fpdual-deco-squares::before {
	top: 0;
	right: 0;
	width: 24px;
	height: 24px;
	box-shadow:
		-32px 34px 0 var(--fpdual-color-primary-soft),
		-12px 48px 0 var(--fpdual-color-ink);
}

.fpdual-deco-squares::after {
	right: 20px;
	bottom: 6px;
	width: 32px;
	height: 32px;
	opacity: 0.92;
}

.fpdual-button {
	appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 12px 18px;
	border: 2px solid var(--fpdual-color-primary);
	border-radius: var(--fpdual-radius-control);
	background: var(--fpdual-color-primary);
	color: var(--fpdual-color-on-primary);
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
	text-decoration: none;
	text-transform: uppercase;
	cursor: pointer;
	transition:
		background-color var(--fpdual-transition),
		border-color var(--fpdual-transition),
		color var(--fpdual-transition),
		transform var(--fpdual-transition);
}

.fpdual-button:hover,
.fpdual-button:focus {
	background: var(--fpdual-color-primary-hover, var(--fpdual-color-primary-soft));
	border-color: var(--fpdual-color-primary-hover, var(--fpdual-color-primary-soft));
	color: var(--fpdual-color-on-primary);
	transform: none;
}

.fpdual-button:focus-visible {
	outline: 3px solid var(--fpdual-color-primary-focus);
	outline-offset: 3px;
}

.fpdual-button--secondary {
	background: var(--fpdual-color-ink);
	border-color: var(--fpdual-color-ink);
}
