/* ==========================================================================
   Presolicitud de Franquicia Rabbit Smokers
   Estilo: lineal tipo Excel / hoja de cálculo
   ========================================================================== */

/* Grises neutros (mismo R=G=B) para evitar tinte rosado/salmón en pantalla */
:root {
	--fp-bg: #f2f2f2;
	--fp-surface: #ffffff;
	--fp-border: #d0d0d0;
	--fp-border-light: #e5e5e5;
	--fp-header-bg: #e8e8e8;
	--fp-text: #222222;
	--fp-text-soft: #555555;
	--fp-accent: #333333;
	--fp-focus: #0066cc;
	--fp-success-bg: #e0ebe0;
	--fp-success-border: #a0b0a0;
	--fp-error-bg: #e5e5e5;
	--fp-error-border: #b0b0b0;
	--fp-dummy-bg: #e8e8e8;
	--fp-dummy-border: #c0c0c0;
}

/* Contenedor */
.franquicia-presolicitud-wrap {
	max-width: 800px;
	margin: 0 auto 2rem;
	padding: 1rem;
	font-family: "Segoe UI", system-ui, sans-serif;
	font-size: 0.875rem;
	line-height: 1.4;
	color: var(--fp-text);
	background: var(--fp-bg);
}

/* Título principal */
.franquicia-presolicitud-wrap .franquicia-presolicitud-title {
	font-family: "Open Sans", sans-serif;
	font-size: 1.125rem;
	font-weight: 700;
	text-align: center;
	margin: 0 0 1rem;
	color: var(--fp-text);
	border: 1px solid var(--fp-border);
	background: var(--fp-surface);
	padding: 0.6rem 1rem;
}

/* Aviso confidencial - celda tipo Excel */
.franquicia-aviso-confidencial {
	background: var(--fp-surface);
	border: 1px solid var(--fp-border);
	border-left: 3px solid var(--fp-accent);
	padding: 0.75rem 1rem;
	margin-bottom: 1rem;
	font-size: 0.8125rem;
	color: var(--fp-text-soft);
}

.franquicia-aviso-confidencial p { margin: 0 0 0.4rem; }
.franquicia-aviso-confidencial p:last-child { margin-bottom: 0; }

/* Mensajes */
.franquicia-message {
	padding: 0.6rem 1rem;
	margin-bottom: 1rem;
	font-size: 0.8125rem;
	border: 1px solid;
}
.franquicia-message--success {
	background: var(--fp-success-bg);
	color: #1b5e20;
	border-color: var(--fp-success-border);
}
.franquicia-message--error {
	background: var(--fp-error-bg);
	color: #b71c1c;
	border-color: var(--fp-error-border);
}
.franquicia-message--dummy {
	background: var(--fp-dummy-bg);
	color: #6b5a00;
	border-color: var(--fp-dummy-border);
}

/* Formulario = tabla/hoja */
.franquicia-presolicitud-form {
	background: var(--fp-surface);
	border: 1px solid var(--fp-border);
}

/* Sección = bloque con borde */
.franquicia-section {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid var(--fp-border);
}
.franquicia-section:last-of-type { border-bottom: none; }

.franquicia-section--conditional {
	display: none;
	background: var(--fp-bg);
}
.franquicia-section--conditional.is-visible { display: block; }

/* Título de sección = fila de encabezado tipo Excel */
.franquicia-presolicitud-wrap .franquicia-section-title {
	font-family: "Open Sans", sans-serif;
	font-size: 0.9375rem;
	font-weight: 700;
	margin: 0;
	padding: 0.5rem 0.75rem;
	background: var(--fp-header-bg);
	border-bottom: 1px solid var(--fp-border);
	color: var(--fp-text);
}

/* Formalización: cada campo en su propia fila para evitar solapamientos */
.franquicia-section--formalizacion .franquicia-field {
	display: block;
	padding: 0.5rem 0.75rem;
	border-bottom: 1px solid var(--fp-border-light);
}
.franquicia-section--formalizacion .franquicia-field label,
.franquicia-section--formalizacion .franquicia-field .franquicia-checkbox-label {
	display: block;
	margin-bottom: 0.35rem;
}
.franquicia-section--formalizacion .franquicia-field input[type="text"],
.franquicia-section--formalizacion .franquicia-field input[type="date"] {
	display: block;
	width: 100%;
	max-width: 280px;
}
.franquicia-section--formalizacion .franquicia-checkbox-wrap {
	padding: 0;
}

/* Texto formalización */
.franquicia-formalizacion-text {
	background: var(--fp-bg);
	border-bottom: 1px solid var(--fp-border-light);
	padding: 0.5rem 0.75rem;
	margin: 0;
	font-size: 0.8125rem;
	color: var(--fp-text-soft);
}
.franquicia-formalizacion-text p { margin: 0 0 0.35rem; }
.franquicia-formalizacion-text p:last-child { margin-bottom: 0; }

/* Campos = filas tipo Excel (etiqueta | valor) */
.franquicia-fields {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.franquicia-field {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.25rem;
	align-items: start;
	padding: 0.4rem 0.75rem;
	border-bottom: 1px solid var(--fp-border-light);
	min-height: 2rem;
	box-sizing: border-box;
}
.franquicia-field:last-child { border-bottom: none; }

@media (min-width: 640px) {
	.franquicia-field {
		grid-template-columns: 220px 1fr;
		align-items: center;
		gap: 0.75rem;
	}
	.franquicia-field--inline .franquicia-radio-group { grid-column: 2; }
	.franquicia-field--inline label { grid-column: 1; }
	.franquicia-field--checkbox .franquicia-checkbox-wrap { grid-column: 1 / -1; }
	.franquicia-field--file { align-items: start; }
}

.franquicia-field label {
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--fp-text);
	margin: 0;
}
.franquicia-field .required { color: #c00; font-weight: 600; }

/* Inputs - estilo celda */
.franquicia-field input[type="text"],
.franquicia-field input[type="email"],
.franquicia-field input[type="tel"],
.franquicia-field input[type="number"],
.franquicia-field input[type="date"],
.franquicia-field select,
.franquicia-field textarea {
	width: 100%;
	max-width: 100%;
	padding: 0.4rem 0.5rem;
	border: 1px solid var(--fp-border);
	font-size: 0.875rem;
	font-family: inherit;
	color: var(--fp-text);
	background: var(--fp-surface);
	box-sizing: border-box;
}
.franquicia-field input:focus,
.franquicia-field select:focus,
.franquicia-field textarea:focus {
	border-color: var(--fp-focus);
	outline: 1px solid var(--fp-focus);
	outline-offset: 0;
}
.franquicia-field textarea {
	min-height: 60px;
	resize: vertical;
}

/* Anexos - lista lineal */
.franquicia-anexos-list {
	list-style: decimal;
	padding-left: 1.5rem;
	margin: 0;
	border-top: 1px solid var(--fp-border-light);
}
.franquicia-anexos-list > li {
	padding: 0.5rem 0.75rem;
	border-bottom: 1px solid var(--fp-border-light);
	font-size: 0.8125rem;
}
.franquicia-anexos-list > li:last-child { border-bottom: none; }
.franquicia-anexos .franquicia-anexos-title {
	font-family: "Open Sans", sans-serif;
	font-size: 0.9375rem;
	font-weight: 700;
	margin: 0;
	padding: 0.5rem 0.75rem;
	background: var(--fp-header-bg);
	border-bottom: 1px solid var(--fp-border);
	color: var(--fp-text-soft);
}
.franquicia-anexos {
	margin: 0;
	padding: 0;
	border-top: 1px solid var(--fp-border);
}
.franquicia-anexos .franquicia-field--file {
	padding: 0.35rem 0;
}
.franquicia-anexos .franquicia-field--file input[type="file"] {
	border: 1px solid var(--fp-border);
	padding: 0.35rem 0.5rem;
	font-size: 0.8125rem;
}
.franquicia-anexos .franquicia-field--file label { font-size: 0.8125rem; }

/* Radio - fila lineal */
.franquicia-radio-group,
.franquicia-field--inline .franquicia-radio-group {
	display: flex;
	flex-wrap: wrap;
	gap: 0 1.25rem;
}
.franquicia-radio-label {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-weight: 400;
	font-size: 0.875rem;
	color: var(--fp-text);
	cursor: pointer;
}
.franquicia-radio-label input { width: auto; margin: 0; accent-color: var(--fp-accent); }

/* Checkbox autorización - fila */
.franquicia-checkbox-wrap {
	padding: 0.4rem 0;
}
.franquicia-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	cursor: pointer;
	font-weight: 500;
	font-size: 0.8125rem;
	color: var(--fp-text);
	line-height: 1.35;
}
.franquicia-checkbox-label input {
	width: 1.1rem;
	height: 1.1rem;
	margin: 0.15rem 0 0;
	flex-shrink: 0;
	accent-color: var(--fp-accent);
}

/* Aviso privacidad */
.franquicia-aviso-privacidad {
	margin: 0;
	padding: 0.5rem 0.75rem;
	font-size: 0.8125rem;
	color: var(--fp-text-soft);
	line-height: 1.45;
	border-top: 1px solid var(--fp-border);
}
.franquicia-aviso-privacidad .franquicia-aviso-privacidad-title {
	font-family: "Open Sans", sans-serif;
	font-size: 0.9375rem;
	font-weight: 700;
	margin: 0 0 0.35rem;
	color: var(--fp-text);
}

/* Botón */
.franquicia-submit-wrap {
	margin: 0;
	padding: 0.75rem 1rem;
	border-top: 1px solid var(--fp-border);
	background: var(--fp-surface);
	text-align: center;
}
.franquicia-submit {
	display: inline-block;
	background: var(--fp-accent);
	color: #fff;
	border: 1px solid var(--fp-accent);
	padding: 0.5rem 1.5rem;
	font-size: 0.9375rem;
	font-weight: 600;
	font-family: inherit;
	cursor: pointer;
}
.franquicia-submit:hover { background: #555; border-color: #555; }
.franquicia-submit:focus { outline: 2px solid var(--fp-focus); outline-offset: 2px; }
