/**
 * Serficon Calculadora – estilos frontend.
 *
 * Paleta por defecto: Serficon. Sobrescribible por calculadora vía
 * config "tema" (el JS pinta las variables en el contenedor) o por CSS
 * del tema hijo apuntando a .sfc-calc { --sfc-acento: ... }.
 *
 * Regla de oro del layout: el resumen vive en el flujo del documento.
 * En escritorio va en columna lateral con position:sticky DENTRO de su
 * columna; en móvil pasa debajo del formulario en position:static.
 * Nunca position:fixed sobre el viewport.
 */

.sfc-calc {
	--sfc-tinta: #0E1F18;
	--sfc-acento: #00BF64;
	--sfc-acento2: #006633;
	--sfc-papel: #FFFFFF;
	--sfc-fondo: #FAF7F2;
	--sfc-borde: #E7E2D8;
	--sfc-suave: #7C8A83;
	--sfc-radio: 14px;

	color: var(--sfc-tinta);
	font-size: 16px;
	line-height: 1.45;
}

.sfc-calc, .sfc-calc * { box-sizing: border-box; }

.sfc-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(290px, 360px);
	gap: 28px;
	align-items: start;
}

/* ------------------------------------------------------------------ */
/* Campos                                                              */
/* ------------------------------------------------------------------ */

/* La columna de campos es una tarjeta gemela del resumen: mismo fondo,
   borde y radio, para que los enunciados se lean sobre fondo propio
   y no sobre el fondo de la página. */
.sfc-campos {
	display: grid;
	gap: 26px;
	min-width: 0;
	background: var(--sfc-fondo);
	border: 1.5px solid var(--sfc-borde);
	border-radius: calc(var(--sfc-radio) + 4px);
	padding: 22px;
}

.sfc-campo { margin: 0; padding: 0; border: 0; min-width: 0; }

.sfc-label {
	display: block;
	font-weight: 700;
	font-size: 17px;
	margin: 0 0 10px;
	padding: 0;
	color: var(--sfc-tinta);
}

.sfc-descripcion { margin: -6px 0 10px; font-size: 14px; color: var(--sfc-suave); }
.sfc-pista { margin: 8px 0 0; font-size: 13px; color: var(--sfc-suave); }

/* Opciones (radio / checkbox) en tarjetas */

.sfc-opciones { display: grid; gap: 10px; }

.sfc-opcion {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 13px 16px;
	background: var(--sfc-papel);
	border: 1.5px solid var(--sfc-borde);
	border-radius: var(--sfc-radio);
	cursor: pointer;
	transition: border-color .15s ease, background-color .15s ease, box-shadow .15s ease;
}

.sfc-opcion:hover { border-color: var(--sfc-acento); }

.sfc-opcion.is-checked {
	border-color: var(--sfc-acento);
	background: color-mix(in srgb, var(--sfc-acento) 7%, var(--sfc-papel));
	box-shadow: 0 1px 0 rgba(14, 31, 24, 0.04);
}

.sfc-opcion-input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.sfc-opcion-marca {
	flex: 0 0 auto;
	width: 20px;
	height: 20px;
	border: 2px solid var(--sfc-borde);
	border-radius: 50%;
	position: relative;
	transition: border-color .15s ease, background-color .15s ease;
}

.sfc-opcion input[type="checkbox"] ~ .sfc-opcion-marca { border-radius: 6px; }

.sfc-opcion.is-checked .sfc-opcion-marca {
	border-color: var(--sfc-acento2);
	background: linear-gradient(135deg, var(--sfc-acento2), var(--sfc-acento));
}

.sfc-opcion.is-checked .sfc-opcion-marca::after {
	content: "";
	position: absolute;
	inset: 0;
	background: center / 12px no-repeat url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6.5 4.8 9 10 3.5' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* Foco visible accesible (el input está oculto, marcamos la tarjeta) */
.sfc-opcion:has(.sfc-opcion-input:focus-visible),
.sfc-opcion.is-focus {
	outline: 2px solid var(--sfc-acento2);
	outline-offset: 2px;
}

.sfc-opcion-cuerpo { display: grid; gap: 2px; min-width: 0; }
.sfc-opcion-label { font-weight: 600; }
.sfc-opcion-detalle { font-size: 13px; color: var(--sfc-suave); }

.sfc-opcion-precio {
	margin-left: auto;
	font-weight: 700;
	font-size: 14px;
	color: var(--sfc-acento2);
	white-space: nowrap;
}

/* Select */

.sfc-select {
	width: 100%;
	padding: 12px 14px;
	border: 1.5px solid var(--sfc-borde);
	border-radius: var(--sfc-radio);
	background: var(--sfc-papel);
	color: var(--sfc-tinta);
	font-size: 16px;
}

/* Cantidad (stepper) */

.sfc-stepper {
	display: inline-flex;
	align-items: stretch;
	border: 1.5px solid var(--sfc-borde);
	border-radius: var(--sfc-radio);
	background: var(--sfc-papel);
	overflow: hidden;
}

.sfc-stepper-btn {
	width: 46px;
	border: 0;
	background: transparent;
	color: var(--sfc-acento2);
	font-size: 22px;
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
	padding: 10px 0;
	transition: background-color .15s ease;
}

.sfc-stepper-btn:hover { background: color-mix(in srgb, var(--sfc-acento) 10%, transparent); }

.sfc-stepper-input {
	width: 72px;
	border: 0;
	border-left: 1.5px solid var(--sfc-borde);
	border-right: 1.5px solid var(--sfc-borde);
	text-align: center;
	font-size: 17px;
	font-weight: 600;
	color: var(--sfc-tinta);
	background: transparent;
	-moz-appearance: textfield;
	appearance: textfield;
}

.sfc-stepper-input::-webkit-outer-spin-button,
.sfc-stepper-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* Rango */

.sfc-rango-cabecera {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
}

.sfc-rango-valor { font-weight: 700; color: var(--sfc-acento2); font-variant-numeric: tabular-nums; }

.sfc-rango {
	--sfc-rango-pct: 0%;
	width: 100%;
	height: 6px;
	margin: 10px 0 6px;
	border-radius: 999px;
	appearance: none;
	-webkit-appearance: none;
	background: linear-gradient(to right, var(--sfc-acento) var(--sfc-rango-pct), var(--sfc-borde) var(--sfc-rango-pct));
	outline-offset: 4px;
}

.sfc-rango::-webkit-slider-thumb {
	-webkit-appearance: none;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--sfc-papel);
	border: 3px solid var(--sfc-acento2);
	cursor: pointer;
	box-shadow: 0 1px 3px rgba(14, 31, 24, 0.2);
}

.sfc-rango::-moz-range-thumb {
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: var(--sfc-papel);
	border: 3px solid var(--sfc-acento2);
	cursor: pointer;
}

.sfc-rango-escala {
	display: flex;
	justify-content: space-between;
	font-size: 12px;
	color: var(--sfc-suave);
}

/* Nota */

.sfc-nota { font-size: 14px; color: var(--sfc-suave); }
.sfc-nota p { margin: 0 0 8px; }

/* ------------------------------------------------------------------ */
/* Resumen                                                             */
/* ------------------------------------------------------------------ */

.sfc-resumen {
	position: sticky;          /* sticky dentro de su columna, no fixed */
	top: 24px;
	background: var(--sfc-fondo);
	border: 1.5px solid var(--sfc-borde);
	border-radius: calc(var(--sfc-radio) + 4px);
	padding: 22px;
}

.sfc-resumen-titulo {
	margin: 0 0 14px;
	padding: 0;
	font-size: 18px;
	font-weight: 800;
	color: var(--sfc-tinta);
}

.sfc-resumen-vacio { margin: 0 0 6px; font-size: 14px; color: var(--sfc-suave); }

.sfc-resumen-lista {
	list-style: none;
	margin: 0 0 14px;
	padding: 0;
	display: grid;
	gap: 10px;
}

.sfc-resumen-item {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 14px;
	font-size: 14.5px;
}

.sfc-item-texto { display: grid; gap: 1px; min-width: 0; }
.sfc-item-label { font-weight: 600; }
.sfc-item-detalle { font-size: 12.5px; color: var(--sfc-suave); }
.sfc-item-importe { font-weight: 700; white-space: nowrap; font-variant-numeric: tabular-nums; }

.sfc-total {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 14px;
	padding-top: 14px;
	border-top: 2px solid var(--sfc-borde);
}

.sfc-total-label { font-weight: 700; }

.sfc-total-importe {
	font-size: 28px;
	font-weight: 800;
	letter-spacing: -0.01em;
	font-variant-numeric: tabular-nums;
	background: linear-gradient(135deg, var(--sfc-acento2), var(--sfc-acento));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: var(--sfc-acento2); /* fallback */
}

.sfc-iva { margin: 4px 0 0; font-size: 12.5px; color: var(--sfc-suave); text-align: right; }

.sfc-boton {
	display: block;
	width: 100%;
	margin-top: 16px;
	padding: 13px 18px;
	border: 0;
	border-radius: 999px;
	text-align: center;
	font-size: 16px;
	font-weight: 700;
	font-family: inherit;
	text-decoration: none;
	cursor: pointer;
	color: #FFFFFF !important;
	background: linear-gradient(135deg, var(--sfc-acento2), var(--sfc-acento));
	transition: filter .15s ease, transform .15s ease;
}

.sfc-boton:hover { filter: brightness(1.06); }
.sfc-boton:active { transform: translateY(1px); }

/* Mini-formulario de envío por WhatsApp */

.sfc-wa-form { display: none; }

.sfc-wa-form.is-abierto {
	display: grid;
	gap: 10px;
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1.5px dashed var(--sfc-borde);
}

.sfc-wa-intro { margin: 0; font-size: 13.5px; color: var(--sfc-suave); }

.sfc-wa-campo { display: grid; gap: 4px; }

.sfc-wa-label { font-size: 13px; font-weight: 600; color: var(--sfc-tinta); }

.sfc-input {
	width: 100%;
	padding: 12px 14px;
	border: 1.5px solid var(--sfc-borde);
	border-radius: var(--sfc-radio);
	background: var(--sfc-papel);
	color: var(--sfc-tinta);
	font-size: 16px;
	font-family: inherit;
}

.sfc-input:focus { outline: 2px solid var(--sfc-acento2); outline-offset: 1px; border-color: var(--sfc-acento); }

.sfc-wa-enviar { margin-top: 4px; }

/* ------------------------------------------------------------------ */
/* Móvil: el resumen pasa DEBAJO del formulario, en el flujo normal.   */
/* Nunca barra fija sobre el viewport.                                 */
/* ------------------------------------------------------------------ */

@media (max-width: 820px) {
	.sfc-grid { grid-template-columns: minmax(0, 1fr); gap: 24px; }
	.sfc-resumen { position: static; }
}

@media (prefers-reduced-motion: reduce) {
	.sfc-calc * { transition: none !important; }
}
