/* ============= Fachers Sorteo — paleta web fachers.com ============= */

/* === Ocultar AGRESIVAMENTE título y header de la página WP (Astra) en /sorteo y bases === */
body.fachers-sorteo-page .entry-title,
body.fachers-sorteo-page .ast-title-bar,
body.fachers-sorteo-page .ast-archive-description,
body.fachers-sorteo-page .ast-page-header,
body.fachers-sorteo-page .ast-page-header-wrap,
body.fachers-sorteo-page .ast-page-header-section,
body.fachers-sorteo-page .entry-header,
body.fachers-sorteo-page header.entry-header,
body.fachers-sorteo-page .ast-breadcrumbs,
body.fachers-sorteo-page nav.woocommerce-breadcrumb,
body.fachers-sorteo-page .breadcrumbs,
body.fachers-sorteo-page .ast-single-post-banner,
body.fachers-sorteo-page .single-page-title,
body.fachers-sorteo-page .ast-archive-title,
body.fachers-sorteo-page .page-title,
body.fachers-sorteo-page .ast-section-1 { display: none !important; }

body.fachers-sorteo-page #primary,
body.fachers-sorteo-page .ast-container.site-content,
body.fachers-sorteo-page main#primary,
body.fachers-sorteo-page main.site-main,
body.fachers-sorteo-page article.post,
body.fachers-sorteo-page article.page,
body.fachers-sorteo-page .entry-content,
body.fachers-sorteo-page .site-content > .ast-container {
	padding-top: 0 !important;
	margin-top: 0 !important;
}
body.fachers-sorteo-page .entry-content > .fs-sorteo:first-child {
	margin-top: -1px;
}
body.fachers-sorteo-page .site-content {
	padding-top: 0 !important;
}

.fs-sorteo {
	--fs-bg: #ffffff;
	--fs-bg-soft: #fafafa;
	--fs-form-bg: #0f1626;
	--fs-form-bg-2: #1a2238;
	--fs-text: #1a1a1a;
	--fs-text-soft: #555;
	--fs-muted: #888;
	--fs-border: #e8e8e8;
	--fs-red: #c8102e;
	--fs-red-dark: #9b0c25;
	--fs-gold: #ffc400;
	--fs-twitch: #9146ff;
	--fs-youtube: #ff0033;
	--fs-patreon: #ff7a59;
	--fs-radius: 8px;

	background: var(--fs-bg);
	color: var(--fs-text);
	font-family: inherit;
	margin: 0 calc(50% - 50vw);
	padding: 0 0 80px 0;
}
.fs-sorteo *, .fs-sorteo *::before, .fs-sorteo *::after { box-sizing: border-box; }
.fs-sorteo a { color: var(--fs-red); text-decoration: none; }
.fs-sorteo a:hover { color: var(--fs-red-dark); }
.fs-sorteo h1, .fs-sorteo h2, .fs-sorteo h3 { margin: 0; line-height: 1.2; color: var(--fs-text); }

.fs-section-title {
	text-align: center;
	font-size: clamp(26px, 3.5vw, 40px);
	font-weight: 900;
	margin: 0 auto 14px;
	letter-spacing: -0.02em;
	color: var(--fs-text);
	text-transform: uppercase;
}

/* ====== STATUS WIDGET (mis entradas) ====== */
.fs-status {
	max-width: 880px;
	margin: 32px auto 0;
	padding: 24px 28px;
	background: linear-gradient(135deg, #0f1626 0%, #1a2238 100%);
	color: #fff;
	border-radius: 14px;
	box-shadow: 0 16px 40px rgba(15,22,38,0.18);
	display: flex;
	flex-direction: column;
	gap: 16px;
	position: relative;
}
.fs-status[hidden] { display: none; }
.fs-status::before {
	content: "";
	position: absolute;
	top: 0; left: 24px; right: 24px;
	height: 3px;
	background: linear-gradient(90deg, var(--fs-red) 0%, var(--fs-gold) 100%);
	border-radius: 0 0 4px 4px;
}
.fs-status__head {
	display: flex; justify-content: space-between; align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}
.fs-status__greet {
	font-size: 17px;
	color: rgba(255,255,255,0.85);
}
.fs-status__greet strong {
	color: var(--fs-gold);
	font-weight: 700;
}
.fs-status__logout {
	background: transparent;
	border: 1px solid rgba(255,255,255,0.2);
	color: rgba(255,255,255,0.6);
	font-size: 12px;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 999px;
	cursor: pointer;
	font-family: inherit;
	transition: border-color 0.15s, color 0.15s;
}
.fs-status__logout:hover { border-color: rgba(255,255,255,0.4); color: #fff; }

.fs-status__body {
	display: flex;
	gap: 28px;
	align-items: center;
	flex-wrap: wrap;
}
.fs-status__big {
	display: flex;
	align-items: baseline;
	gap: 12px;
}
.fs-status__count {
	font-size: clamp(48px, 7vw, 72px);
	font-weight: 900;
	color: var(--fs-gold);
	line-height: 1;
	letter-spacing: -0.03em;
	font-variant-numeric: tabular-nums;
}
.fs-status__count-label {
	font-size: 14px;
	color: rgba(255,255,255,0.7);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
}
.fs-status__breakdown {
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 13px;
	color: rgba(255,255,255,0.7);
	border-left: 1px solid rgba(255,255,255,0.15);
	padding-left: 24px;
}
.fs-status__breakdown strong {
	color: #fff;
	font-weight: 800;
	font-size: 18px;
	margin-right: 6px;
}
@media (max-width: 600px) {
	.fs-status__breakdown { border-left: 0; padding-left: 0; border-top: 1px solid rgba(255,255,255,0.15); padding-top: 12px; }
}

.fs-status__plats {
	display: flex; gap: 6px; flex-wrap: wrap;
}
.fs-status__hint {
	font-size: 13px;
	color: rgba(255,255,255,0.6);
	margin: 0;
	padding-top: 12px;
	border-top: 1px solid rgba(255,255,255,0.1);
	line-height: 1.5;
}
.fs-status__hint strong { color: var(--fs-gold); }

/* ====== Recover access (mini login) ====== */
.fs-hero__login {
	position: absolute;
	top: 20px; right: 20px;
	z-index: 3;
	background: #fff;
	border: 1px solid var(--fs-border);
	color: var(--fs-text);
	padding: 8px 14px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: inherit;
	transition: border-color 0.15s, color 0.15s, transform 0.15s;
	box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.fs-hero__login:hover {
	border-color: var(--fs-red);
	color: var(--fs-red);
	transform: translateY(-1px);
}
.fs-hero__login-icon { font-size: 14px; }

.fs-recover {
	position: absolute;
	top: 60px; right: 20px;
	z-index: 4;
	width: min(360px, calc(100% - 40px));
	background: #fff;
	border: 1px solid var(--fs-border);
	border-radius: 12px;
	box-shadow: 0 20px 50px rgba(0,0,0,0.12);
	animation: fs-recover-in 0.2s ease-out;
}
.fs-recover[hidden] { display: none; }
@keyframes fs-recover-in {
	from { opacity: 0; transform: translateY(-8px); }
	to   { opacity: 1; transform: translateY(0); }
}
.fs-recover__inner { padding: 22px 22px 20px; position: relative; }
.fs-recover__close {
	position: absolute;
	top: 8px; right: 12px;
	background: transparent;
	border: 0;
	font-size: 22px;
	color: var(--fs-muted);
	cursor: pointer;
	font-family: inherit;
	width: 28px; height: 28px;
	border-radius: 50%;
	transition: background 0.15s, color 0.15s;
}
.fs-recover__close:hover { background: #f4f4f4; color: var(--fs-text); }
.fs-recover__title {
	font-size: 16px;
	font-weight: 800;
	color: var(--fs-text);
	margin: 0 0 8px;
}
.fs-recover__lead {
	font-size: 13px;
	color: var(--fs-text-soft);
	line-height: 1.45;
	margin: 0 0 14px;
}
.fs-recover__form {
	display: flex;
	gap: 6px;
}
.fs-recover__form input[type="email"] {
	flex: 1;
	min-width: 0;
	padding: 10px 12px;
	border: 1px solid var(--fs-border);
	border-radius: 8px;
	font-size: 14px;
	font-family: inherit;
}
.fs-recover__form input[type="email"]:focus {
	outline: none;
	border-color: var(--fs-red);
}
.fs-recover__form button {
	background: var(--fs-text);
	color: #fff;
	border: 0;
	padding: 0 16px;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
	white-space: nowrap;
	transition: background 0.15s;
}
.fs-recover__form button:hover { background: var(--fs-red); }
.fs-recover__form button:disabled { opacity: 0.6; cursor: wait; }
.fs-recover__feedback {
	margin-top: 12px;
	font-size: 13px;
	line-height: 1.4;
	color: var(--fs-text-soft);
	min-height: 1em;
}
.fs-recover__feedback.is-success { color: #065f46; }
.fs-recover__feedback.is-error { color: var(--fs-red-dark); }

/* ====== HERO (editorial / D2C) ====== */
.fs-hero {
	position: relative;
	padding: 110px 20px 100px;
	background:
		radial-gradient(ellipse at 50% -20%, rgba(255,196,0,0.06) 0%, transparent 60%),
		linear-gradient(180deg, #fafaf6 0%, #ffffff 100%);
	border-bottom: 1px solid var(--fs-border);
	overflow: hidden;
	text-align: center;
}
.fs-hero__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
}
.fs-hero__glow {
	position: absolute;
	border-radius: 50%;
	filter: blur(140px);
	will-change: transform;
}
.fs-hero__glow--1 {
	width: 520px; height: 520px;
	background: var(--fs-red);
	opacity: 0.07;
	top: -180px; left: -120px;
	animation: fs-glow-drift-1 28s ease-in-out infinite alternate;
}
.fs-hero__glow--2 {
	width: 560px; height: 560px;
	background: var(--fs-gold);
	opacity: 0.10;
	bottom: -220px; right: -140px;
	animation: fs-glow-drift-2 32s ease-in-out infinite alternate;
}
@keyframes fs-glow-drift-1 {
	from { transform: translate3d(0, 0, 0) scale(1); }
	to   { transform: translate3d(80px, 40px, 0) scale(1.1); }
}
@keyframes fs-glow-drift-2 {
	from { transform: translate3d(0, 0, 0) scale(1); }
	to   { transform: translate3d(-60px, -50px, 0) scale(1.05); }
}

.fs-hero__inner {
	max-width: 880px;
	margin: 0 auto;
	position: relative;
	z-index: 1;
	animation: fs-hero-fade 0.9s ease-out both;
}
@keyframes fs-hero-fade {
	from { opacity: 0; transform: translateY(16px); }
	to   { opacity: 1; transform: translateY(0); }
}

.fs-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 7px 16px;
	background: #fff;
	color: var(--fs-text);
	font-weight: 600;
	font-size: 13px;
	letter-spacing: 0.02em;
	border: 1px solid var(--fs-border);
	border-radius: 999px;
	margin-bottom: 32px;
	text-transform: none;
	box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.fs-hero__badge-dot {
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--fs-red);
	box-shadow: 0 0 0 4px rgba(200,16,46,0.15);
	animation: fs-pulse 2.4s ease-in-out infinite;
}
@keyframes fs-pulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(200,16,46,0.15); }
	50%      { box-shadow: 0 0 0 8px rgba(200,16,46,0.05); }
}

.fs-hero__title {
	font-size: clamp(44px, 8vw, 96px);
	font-weight: 800;
	letter-spacing: -0.035em;
	color: var(--fs-text);
	margin-bottom: 28px;
	line-height: 0.95;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
}
.fs-hero__title-line-1 {
	display: block;
	color: var(--fs-text);
}
.fs-hero__title-line-2 {
	display: block;
	color: var(--fs-text-soft);
	font-weight: 500;
	font-size: 0.55em;
	letter-spacing: -0.02em;
}
.fs-hero__title strong {
	color: var(--fs-red);
	font-weight: 800;
}
.fs-hero__subtitle {
	font-size: clamp(15px, 1.6vw, 18px);
	color: var(--fs-text-soft);
	max-width: 700px;
	margin: 0 auto 32px;
	line-height: 1.55;
}
.fs-hero__subtitle strong { color: var(--fs-text); }
.fs-hero__deadline {
	margin-top: 18px;
	font-size: 14px;
	color: var(--fs-muted);
}
.fs-hero__deadline strong { color: var(--fs-red); }
.fs-hero__deadline--closed {
	color: var(--fs-red);
	font-weight: 800;
	font-size: 17px;
}
.fs-cta {
	display: inline-block;
	margin-top: 28px;
	padding: 16px 38px;
	background: var(--fs-red);
	color: #fff !important;
	font-weight: 800;
	font-size: 17px;
	border-radius: 4px;
	text-decoration: none !important;
	transition: transform 0.15s, box-shadow 0.15s, background 0.15s;
	box-shadow: 0 6px 20px rgba(200,16,46,0.3);
	letter-spacing: 0.02em;
}
.fs-cta:hover { background: var(--fs-red-dark); transform: translateY(-2px); box-shadow: 0 10px 28px rgba(200,16,46,0.4); color: #fff !important; }

/* ====== COUNTDOWN ====== */
.fs-countdown {
	display: flex; gap: 10px; justify-content: center;
	margin: 28px 0 12px;
	flex-wrap: wrap;
}
.fs-countdown__cell {
	background: #fff;
	border: 2px solid var(--fs-text);
	border-radius: 6px;
	padding: 14px 18px;
	min-width: 80px;
	text-align: center;
	box-shadow: 0 4px 0 var(--fs-text);
}
.fs-countdown__num {
	display: block;
	font-size: clamp(26px, 4.5vw, 42px);
	font-weight: 900;
	color: var(--fs-red);
	font-variant-numeric: tabular-nums;
	line-height: 1;
}
.fs-countdown__label {
	display: block;
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--fs-muted);
	margin-top: 6px;
	font-weight: 700;
}

/* ====== PILLS ====== */
.fs-pill {
	display: inline-flex;
	align-items: center;
	padding: 4px 11px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 700;
	color: #fff;
	margin: 0 2px;
	letter-spacing: 0.02em;
}
.fs-pill--twitch  { background: var(--fs-twitch); }
.fs-pill--youtube { background: var(--fs-youtube); }
.fs-pill--patreon { background: var(--fs-patreon); }

/* ====== SECTIONS spacing ====== */
.fs-products,
.fs-form-section,
.fs-extras { padding: 90px 20px 0; max-width: 1200px; margin: 0 auto; }
.fs-form-section { max-width: 760px; }

.fs-section-intro {
	text-align: center;
	color: var(--fs-text-soft);
	max-width: 720px;
	margin: 0 auto 36px;
	line-height: 1.55;
	font-size: 15px;
}

/* ====== PACKS por plataforma (3 cards grandes) ====== */
.fs-packs {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 24px;
	margin-bottom: 28px;
}
.fs-pack {
	position: relative;
	background: #fff;
	border: 1px solid var(--fs-border);
	border-top: 6px solid var(--fs-muted);
	border-radius: var(--fs-radius);
	padding: 22px 22px 18px;
	display: flex;
	flex-direction: column;
	transition: transform 0.15s, box-shadow 0.15s;
}
.fs-pack:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 28px rgba(0,0,0,0.08);
}
.fs-pack--twitch  { border-top-color: var(--fs-twitch); }
.fs-pack--youtube { border-top-color: var(--fs-youtube); }
.fs-pack--patreon { border-top-color: var(--fs-patreon); }

.fs-pack__head {
	display: flex; justify-content: space-between; align-items: baseline;
	margin-bottom: 14px;
}
.fs-pack__platform {
	font-size: 18px;
	font-weight: 900;
	letter-spacing: 0.05em;
	color: var(--fs-text);
}
.fs-pack--twitch  .fs-pack__platform { color: var(--fs-twitch); }
.fs-pack--youtube .fs-pack__platform { color: var(--fs-youtube); }
.fs-pack--patreon .fs-pack__platform { color: var(--fs-patreon); }
.fs-pack__units {
	background: #f4f4f4;
	color: var(--fs-text);
	font-size: 11px;
	font-weight: 800;
	padding: 4px 10px;
	border-radius: 999px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.fs-pack__value {
	background: linear-gradient(135deg, #fff7e0 0%, #fff 100%);
	border: 1px dashed var(--fs-gold);
	border-radius: 8px;
	padding: 14px;
	margin-bottom: 16px;
	text-align: center;
}
.fs-pack__value-num {
	display: block;
	font-size: clamp(28px, 4vw, 38px);
	font-weight: 900;
	color: var(--fs-red);
	line-height: 1;
	letter-spacing: -0.02em;
}
.fs-pack__value-label {
	display: block;
	font-size: 11px;
	font-weight: 700;
	color: var(--fs-muted);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-top: 6px;
}

.fs-pack__items {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.fs-pack-item {
	display: flex;
	gap: 12px;
	align-items: center;
}
.fs-pack-item__img {
	width: 52px; height: 52px;
	border-radius: 6px;
	background: #f7f7f5;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	flex-shrink: 0;
	border: 1px solid var(--fs-border);
}
.fs-pack-item__info {
	flex: 1;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 8px;
}
.fs-pack-item__title {
	font-size: 13px;
	color: var(--fs-text);
	font-weight: 600;
	line-height: 1.3;
}
.fs-pack-item__qty {
	background: var(--fs-text);
	color: #fff;
	font-size: 12px;
	font-weight: 800;
	padding: 3px 8px;
	border-radius: 4px;
	white-space: nowrap;
}

.fs-products__total {
	text-align: center;
	color: var(--fs-text-soft);
	font-size: 14px;
	margin-top: 28px;
}
.fs-products__total strong {
	color: var(--fs-red);
	font-size: 18px;
	font-weight: 900;
}

/* ====== Sale badge en cards extras ====== */
.fs-extra { position: relative; }
.fs-extra__sale {
	position: absolute;
	top: 10px;
	left: 10px;
	background: var(--fs-red);
	color: #fff;
	font-size: 11px;
	font-weight: 800;
	padding: 4px 10px;
	border-radius: 4px;
	z-index: 1;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* ====== PRODUCTS GRID (estilo card WC) ====== */
.fs-products__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
}
.fs-product {
	position: relative;
	background: #fff;
	border: 1px solid var(--fs-border);
	border-radius: var(--fs-radius);
	padding: 16px;
	display: flex;
	flex-direction: column;
	color: var(--fs-text) !important;
	text-decoration: none !important;
	transition: transform 0.15s, border-color 0.15s, box-shadow 0.15s;
}
.fs-product:hover {
	transform: translateY(-3px);
	border-color: var(--fs-red);
	box-shadow: 0 10px 24px rgba(0,0,0,0.08);
	color: var(--fs-text) !important;
}
.fs-product__img {
	height: 180px;
	background-color: #f7f7f5;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	border-radius: 6px;
	margin-bottom: 14px;
}
.fs-product__title {
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 8px;
	min-height: 36px;
	line-height: 1.35;
	color: var(--fs-text);
}
.fs-product__price {
	font-size: 17px;
	font-weight: 700;
	color: var(--fs-red);
	margin-bottom: 8px;
}
.fs-product__price del {
	color: var(--fs-muted);
	font-weight: 500;
	font-size: 14px;
	margin-right: 6px;
}
.fs-product__qty {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	font-weight: 700;
	color: var(--fs-text-soft);
	margin-bottom: 8px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.fs-product__qty-num {
	background: var(--fs-red);
	color: #fff;
	padding: 2px 8px;
	border-radius: 999px;
	font-weight: 800;
}
.fs-product__split {
	display: flex; gap: 4px; flex-wrap: wrap;
	margin-top: auto;
	padding-top: 8px;
	border-top: 1px solid var(--fs-border);
}

/* ====== FORM (mantengo color oscuro original) ====== */
.fs-form-section {
	padding-top: 90px;
}
.fs-form-section__lead {
	text-align: center;
	color: var(--fs-text-soft);
	margin-bottom: 32px;
	line-height: 1.55;
	font-size: 15px;
}
.fs-form-section__lead strong { color: var(--fs-text); }

.fs-form {
	background: linear-gradient(180deg, var(--fs-form-bg) 0%, var(--fs-form-bg-2) 100%);
	border-radius: 14px;
	padding: 40px;
	color: #f4f4f5;
	box-shadow: 0 20px 60px rgba(15,22,38,0.25);
}
.fs-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
	margin-bottom: 22px;
}
@media (max-width: 600px) { .fs-form__row { grid-template-columns: 1fr; } .fs-form { padding: 28px 22px; } }
.fs-field { display: flex; flex-direction: column; gap: 6px; }
.fs-field__label {
	font-size: 12px;
	color: rgba(255,255,255,0.7);
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}
.fs-field input {
	background: rgba(0,0,0,0.3);
	border: 1px solid rgba(255,255,255,0.12);
	color: #fff;
	padding: 14px 16px;
	border-radius: 8px;
	font-size: 16px;
	font-family: inherit;
	transition: border-color 0.15s;
}
.fs-field input:focus {
	outline: none;
	border-color: var(--fs-gold);
}
.fs-field input::placeholder { color: rgba(255,255,255,0.35); }

.fs-platforms {
	border: none; padding: 0; margin: 0 0 22px 0;
}
.fs-platforms legend {
	font-size: 12px;
	color: rgba(255,255,255,0.7);
	font-weight: 700;
	margin-bottom: 12px;
	padding: 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	width: 100%;
}
.fs-platforms__hint {
	display: block;
	margin-top: 10px;
	font-size: 12px;
	color: rgba(255,255,255,0.55);
	line-height: 1.5;
}
.fs-platform {
	display: flex; align-items: center; gap: 12px;
	padding: 12px 14px;
	background: rgba(0,0,0,0.25);
	border: 2px solid rgba(255,255,255,0.08);
	border-radius: 8px;
	margin-bottom: 8px;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s;
}
.fs-platform:hover { border-color: rgba(255,255,255,0.18); }
.fs-platform input { display: none; }
.fs-platform__check {
	width: 22px; height: 22px;
	border: 2px solid rgba(255,255,255,0.4);
	border-radius: 5px;
	flex-shrink: 0;
	background: transparent;
	position: relative;
	transition: all 0.15s;
}
.fs-platform input:checked + .fs-platform__check {
	background: var(--fs-gold);
	border-color: var(--fs-gold);
}
.fs-platform input:checked + .fs-platform__check::after {
	content: "✓";
	position: absolute;
	color: #1a1a1a;
	font-weight: 900;
	font-size: 15px;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%);
}
.fs-platform:has(input:checked) { border-color: var(--fs-gold); background: rgba(255,196,0,0.08); }
.fs-platform__main { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.fs-platform__name { font-weight: 700; font-size: 16px; color: #fff; }
.fs-platform__sub  { font-size: 11px; color: rgba(255,255,255,0.55); font-weight: 500; }
.fs-platform__link {
	font-size: 11px;
	color: rgba(255,255,255,0.5) !important;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	white-space: nowrap;
}
.fs-platform__link:hover { color: var(--fs-gold) !important; }

.fs-checkboxes { margin: 22px 0; }
.fs-check {
	display: flex; align-items: flex-start; gap: 10px;
	padding: 6px 0;
	font-size: 14px;
	cursor: pointer;
}
.fs-check input { margin-top: 4px; flex-shrink: 0; accent-color: var(--fs-gold); }
.fs-check span { line-height: 1.5; color: rgba(255,255,255,0.75); }
.fs-check span a { color: var(--fs-gold); }
.fs-check span strong { color: #fff; }

.fs-honey { position: absolute; left: -9999px; height: 0; overflow: hidden; }

.fs-submit {
	width: 100%;
	background: var(--fs-red);
	color: #fff;
	border: none;
	padding: 18px;
	border-radius: 8px;
	font-size: 17px;
	font-weight: 800;
	cursor: pointer;
	transition: transform 0.15s, background 0.15s, box-shadow 0.15s;
	font-family: inherit;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.fs-submit:hover:not(:disabled) {
	background: var(--fs-red-dark);
	transform: translateY(-2px);
	box-shadow: 0 10px 28px rgba(200,16,46,0.4);
}
.fs-submit:disabled { opacity: 0.5; cursor: wait; }

.fs-form__feedback {
	margin-top: 18px;
	padding: 0;
	font-size: 14px;
	text-align: center;
	min-height: 1em;
}
.fs-form__feedback.is-success {
	background: rgba(34,197,94,0.18);
	border: 1px solid rgba(34,197,94,0.5);
	color: #86efac;
	padding: 14px;
	border-radius: 8px;
}
.fs-form__feedback.is-error {
	background: rgba(239,68,68,0.18);
	border: 1px solid rgba(239,68,68,0.5);
	color: #fca5a5;
	padding: 14px;
	border-radius: 8px;
}

/* ====== EXTRAS (productos comprables) ====== */
.fs-extras__lead {
	text-align: center;
	color: var(--fs-text-soft);
	margin-bottom: 32px;
	max-width: 700px;
	margin-left: auto; margin-right: auto;
	line-height: 1.55;
	font-size: 15px;
}
.fs-extras__lead strong { color: var(--fs-red); }
.fs-extras__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
}
.fs-extra {
	background: #fff;
	border: 1px solid var(--fs-border);
	border-radius: var(--fs-radius);
	overflow: hidden;
	display: block;
	color: var(--fs-text) !important;
	text-decoration: none !important;
	transition: transform 0.15s, border-color 0.15s, box-shadow 0.15s;
}
.fs-extra:hover {
	transform: translateY(-3px);
	border-color: var(--fs-red);
	box-shadow: 0 10px 24px rgba(0,0,0,0.08);
	color: var(--fs-text) !important;
}
.fs-extra__img {
	height: 200px;
	background: #f7f7f5;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}
.fs-extra__body { padding: 16px; }
.fs-extra__title { font-size: 14px; font-weight: 600; margin-bottom: 8px; line-height: 1.35; min-height: 36px; }
.fs-extra__price { font-size: 17px; font-weight: 700; color: var(--fs-red); margin-bottom: 12px; }
.fs-extra__price del { color: var(--fs-muted); font-weight: 500; font-size: 14px; margin-right: 6px; }
.fs-extra__cta {
	display: inline-block;
	background: var(--fs-text);
	color: #fff;
	padding: 8px 14px;
	border-radius: 4px;
	font-weight: 700;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.fs-extra:hover .fs-extra__cta { background: var(--fs-red); }

/* ====== FOOTER ====== */
.fs-footer {
	max-width: 800px;
	margin: 80px auto 0;
	padding: 28px 20px 0;
	text-align: center;
	color: var(--fs-muted);
	font-size: 13px;
	border-top: 1px solid var(--fs-border);
}
.fs-footer a { color: var(--fs-red); }

/* ====== Bases legales ====== */
.fs-bases {
	max-width: 820px;
	margin: 30px auto;
	padding: 36px 32px;
	background: #fff;
	color: var(--fs-text);
	border: 1px solid var(--fs-border);
	border-radius: var(--fs-radius);
	line-height: 1.7;
}
.fs-bases h1 { font-size: clamp(26px, 4vw, 36px); margin-bottom: 20px; color: var(--fs-text); }
.fs-bases h2 { font-size: 20px; margin-top: 30px; margin-bottom: 10px; color: var(--fs-red); }
.fs-bases ul { padding-left: 22px; }
.fs-bases li { margin-bottom: 5px; }
.fs-bases p { color: var(--fs-text-soft); }
.fs-bases p strong, .fs-bases li strong { color: var(--fs-text); }
.fs-bases table { background: #fff; }
.fs-bases table th { background: #fff8e6 !important; color: var(--fs-text); font-weight: 700; }

/* ====== Confirm result page ====== */
.fs-result {
	min-height: 70vh;
	display: flex; align-items: center; justify-content: center;
	padding: 40px 20px;
	text-align: center;
	background: var(--fs-bg-soft);
}
.fs-result__inner { max-width: 560px; }
.fs-result__icon { font-size: 72px; margin-bottom: 20px; }
.fs-result__title { font-size: 30px; margin-bottom: 14px; font-weight: 900; color: var(--fs-text); }
.fs-result__msg { color: var(--fs-text-soft); font-size: 16px; line-height: 1.6; }
.fs-result__back {
	display: inline-block;
	margin-top: 28px;
	padding: 13px 26px;
	background: var(--fs-red);
	color: #fff !important;
	border-radius: 4px;
	font-weight: 800;
	text-decoration: none !important;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	font-size: 14px;
}
.fs-result__back:hover { background: var(--fs-red-dark); }
