/* ===========================================================
   Minath — Libro de Reclamaciones
   Diseño responsive con paleta Minath (azul marino + amarillo).
   Variables inyectadas dinámicamente desde el panel.
   Reglas defensivas para que el tema (XStore) no rompa los campos.
   =========================================================== */

.mlr-libro {
	/* Defaults; el panel los sobrescribe */
	--mlr-bg:             #f6f7fb;
	--mlr-card-bg:        #ffffff;
	--mlr-brand:          #1c2e4a;
	--mlr-brand-rgb:      28, 46, 74;
	--mlr-brand-dark:     #0f1f37;
	--mlr-accent:         #fbcb00;
	--mlr-accent-rgb:     251, 203, 0;
	--mlr-field-bg:       #f1f4f9;
	--mlr-field-bg-focus: #e9eef6;
	--mlr-field-text:     #1a2238;
	--mlr-btn-bg:         #1c2e4a;
	--mlr-btn-bg-hover:   #0f1f37;
	--mlr-btn-text:       #ffffff;

	--mlr-line:    #e5e7eb;
	--mlr-muted:   #6b7280;
	--mlr-error:   #b42318;
	--mlr-success: #067647;
	--mlr-radius:  10px;
	--mlr-radius-sm: 8px;
	--mlr-gap:     18px;

	background: var(--mlr-bg);
	color: var(--mlr-field-text);
	font-family: inherit;
	padding: clamp(32px, 6vw, 72px) clamp(16px, 4vw, 32px);
	box-sizing: border-box;
}
.mlr-libro *,
.mlr-libro *::before,
.mlr-libro *::after { box-sizing: border-box; }

.mlr-libro__inner { max-width: 880px; margin: 0 auto; }

/* ---------- Encabezado ---------- */
.mlr-libro__head {
	text-align: center;
	margin-bottom: clamp(28px, 5vw, 44px);
}
.mlr-libro__logo {
	margin-bottom: 22px;
}
.mlr-libro__logo img {
	max-width: 180px;
	height: auto;
	display: inline-block;
}
.mlr-libro__eyebrow {
	display: inline-block;
	font-size: 11px;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--mlr-brand);
	margin-bottom: 14px;
	padding: 6px 14px;
	background: rgba(var(--mlr-accent-rgb), .18);
	border-radius: 99px;
	font-weight: 600;
}
.mlr-libro__title {
	font-family: inherit;
	font-weight: 700;
	font-size: clamp(28px, 5vw, 42px);
	line-height: 1.15;
	color: var(--mlr-brand);
	margin: 0 0 14px;
}
.mlr-libro__title::after {
	content: "";
	display: block;
	width: 56px;
	height: 3px;
	background: var(--mlr-accent);
	margin: 14px auto 0;
	border-radius: 3px;
}
.mlr-libro__lead {
	max-width: 60ch; margin: 0 auto;
	color: var(--mlr-muted); font-size: 15px; line-height: 1.65;
}
.mlr-libro__empresa {
	margin-top: 20px;
	padding: 14px 18px;
	background: rgba(var(--mlr-brand-rgb), .04);
	border: 1px solid var(--mlr-line);
	border-radius: var(--mlr-radius-sm);
	display: inline-flex;
	flex-wrap: wrap;
	gap: 6px 22px;
	font-size: 13px;
	color: var(--mlr-field-text);
	text-align: left;
}
.mlr-libro__empresa span { display: inline-block; }
.mlr-libro__empresa strong { color: var(--mlr-brand); font-weight: 600; }

/* ---------- Aviso obligatorio (INDECOPI) ---------- */
.mlr-libro .mlr-aviso {
	max-width: 880px;
	margin: 0 auto 26px;
	background: #fffbea;
	border: 1px solid rgba(var(--mlr-accent-rgb), .6);
	border-left: 5px solid var(--mlr-accent);
	border-radius: var(--mlr-radius-sm);
	padding: 16px 20px;
	display: flex;
	gap: 14px;
	align-items: flex-start;
	color: #4b3d00;
	font-size: 14px;
	line-height: 1.55;
}
.mlr-libro .mlr-aviso__icon {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	background: var(--mlr-accent);
	color: var(--mlr-brand);
	border-radius: 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 19px;
	font-weight: 700;
}
.mlr-libro .mlr-aviso__text { flex: 1; }
.mlr-libro .mlr-aviso__text strong {
	display: block;
	color: var(--mlr-brand);
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: .06em;
	margin-bottom: 2px;
}
.mlr-libro .mlr-aviso__text p { margin: 0; }

/* ---------- Tarjeta del formulario ---------- */
.mlr-libro .mlr-form {
	background: var(--mlr-card-bg);
	border: 1px solid var(--mlr-line);
	border-radius: var(--mlr-radius);
	padding: clamp(20px, 4vw, 36px);
	box-shadow: 0 20px 60px -30px rgba(var(--mlr-brand-rgb), .35);
}

/* ---------- Secciones ---------- */
.mlr-libro .mlr-section {
	border: none;
	padding: 0;
	margin: 0 0 28px;
	min-width: 0; /* fix para grid en Firefox */
}
.mlr-libro .mlr-section:last-of-type { margin-bottom: 12px; }
.mlr-section__title {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 16px;
	font-weight: 700;
	color: var(--mlr-brand);
	margin: 0 0 18px;
	padding: 0 0 12px;
	border-bottom: 2px solid var(--mlr-line);
	width: 100%;
	float: none;
}
.mlr-section__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	background: var(--mlr-accent);
	color: var(--mlr-brand);
	border-radius: 50%;
	font-size: 14px;
	font-weight: 800;
	flex: 0 0 auto;
}

/* ---------- Grid ---------- */
.mlr-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--mlr-gap); }

/* ---------- Campos ---------- */
.mlr-libro .mlr-field { display: flex; flex-direction: column; margin: 0; min-width: 0; }
.mlr-field--full { grid-column: 1 / -1; }

.mlr-libro .mlr-label {
	font-size: 13px;
	color: var(--mlr-brand);
	font-weight: 600;
	margin: 0 0 7px;
	line-height: 1.4;
}
.mlr-req { color: var(--mlr-error); margin-left: 2px; }

/* --- RESET DEFENSIVO de controles (vence al tema) --- */
.mlr-libro .mlr-input,
.mlr-libro .mlr-select select,
.mlr-libro .mlr-submit {
	box-sizing: border-box !important;
	width: 100% !important;
	max-width: 100% !important;
	height: auto !important;
	min-height: 0 !important;
	margin: 0 !important;
	line-height: 1.5 !important;
	font-family: inherit !important;
	font-size: 15px !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	float: none !important;
	overflow: visible !important;
	box-shadow: none;
}

.mlr-libro .mlr-input {
	color: var(--mlr-field-text);
	background: var(--mlr-field-bg) !important;
	border: 1.5px solid transparent !important;
	border-radius: var(--mlr-radius-sm) !important;
	padding: 12px 14px !important;
	transition: background .2s ease, border-color .2s ease, box-shadow .2s ease;
	-webkit-appearance: none; appearance: none;
}
.mlr-libro .mlr-input::placeholder { color: var(--mlr-muted); opacity: .8; }
.mlr-libro .mlr-input:hover { background: var(--mlr-field-bg-focus) !important; }
.mlr-libro .mlr-input:focus {
	outline: none;
	background: #fff !important;
	border-color: var(--mlr-brand) !important;
	box-shadow: 0 0 0 4px rgba(var(--mlr-brand-rgb), .12) !important;
}
.mlr-libro .mlr-textarea {
	resize: vertical;
	min-height: 110px !important;
	height: auto !important;
	line-height: 1.55 !important;
}

/* Select con flecha propia */
.mlr-libro .mlr-select { position: relative; }
.mlr-libro .mlr-select::after {
	content: ""; position: absolute; right: 16px; top: 50%;
	width: 8px; height: 8px;
	border-right: 2px solid var(--mlr-brand);
	border-bottom: 2px solid var(--mlr-brand);
	transform: translateY(-65%) rotate(45deg);
	pointer-events: none;
}
.mlr-libro .mlr-select select {
	color: var(--mlr-field-text) !important;
	background: var(--mlr-field-bg) !important;
	border: 1.5px solid transparent !important;
	border-radius: var(--mlr-radius-sm) !important;
	padding: 12px 38px 12px 14px !important;
	cursor: pointer;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	appearance: none !important;
	background-image: none !important;
	transition: background .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.mlr-libro .mlr-select select:hover { background: var(--mlr-field-bg-focus) !important; }
.mlr-libro .mlr-select select:focus {
	outline: none;
	background: #fff !important;
	border-color: var(--mlr-brand) !important;
	box-shadow: 0 0 0 4px rgba(var(--mlr-brand-rgb), .12) !important;
}

/* Date input - mejor look */
.mlr-libro input[type="date"]::-webkit-calendar-picker-indicator {
	cursor: pointer;
	opacity: .7;
	filter: invert(15%) sepia(15%) saturate(2000%) hue-rotate(190deg);
}

/* Errores */
.mlr-field--invalid .mlr-input,
.mlr-field--invalid .mlr-select select {
	border-color: var(--mlr-error) !important;
	background: #fef3f2 !important;
}
.mlr-error { display: none; color: var(--mlr-error); font-size: 13px; margin-top: 6px; font-weight: 500; }
.mlr-field--invalid .mlr-error { display: block; }

/* ---------- Radio buttons (Producto/Servicio) ---------- */
.mlr-radio-group { display: flex; gap: 12px; flex-wrap: wrap; }
.mlr-radio {
	flex: 1 1 calc(50% - 6px);
	min-width: 140px;
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 16px;
	background: var(--mlr-field-bg);
	border: 1.5px solid transparent;
	border-radius: var(--mlr-radius-sm);
	cursor: pointer;
	font-size: 14px;
	font-weight: 500;
	color: var(--mlr-field-text);
	transition: background .15s ease, border-color .15s ease;
}
.mlr-radio:hover { background: var(--mlr-field-bg-focus); }
.mlr-radio input { position: absolute; opacity: 0; pointer-events: none; }
.mlr-radio__box {
	width: 18px; height: 18px;
	border: 2px solid var(--mlr-muted);
	border-radius: 50%;
	background: #fff;
	position: relative;
	flex: 0 0 auto;
	transition: border-color .15s ease;
}
.mlr-radio__box::after {
	content: "";
	position: absolute;
	inset: 3px;
	border-radius: 50%;
	background: var(--mlr-brand);
	transform: scale(0);
	transition: transform .15s ease;
}
.mlr-radio input:checked ~ .mlr-radio__box { border-color: var(--mlr-brand); }
.mlr-radio input:checked ~ .mlr-radio__box::after { transform: scale(1); }
.mlr-radio:has(input:checked) {
	border-color: var(--mlr-brand);
	background: rgba(var(--mlr-brand-rgb), .04);
}

/* ---------- Tipos (Reclamo/Queja) - tarjetas grandes ---------- */
.mlr-tipos {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}
.mlr-tipo {
	position: relative;
	cursor: pointer;
	display: block;
}
.mlr-tipo input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}
.mlr-tipo__card {
	display: block;
	padding: 16px 18px;
	background: var(--mlr-field-bg);
	border: 2px solid transparent;
	border-radius: var(--mlr-radius-sm);
	transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.mlr-tipo:hover .mlr-tipo__card {
	background: var(--mlr-field-bg-focus);
	border-color: rgba(var(--mlr-brand-rgb), .2);
}
.mlr-tipo input:checked ~ .mlr-tipo__card {
	border-color: var(--mlr-brand);
	background: #fff;
	box-shadow: 0 0 0 4px rgba(var(--mlr-brand-rgb), .08);
}
.mlr-tipo input:focus-visible ~ .mlr-tipo__card {
	box-shadow: 0 0 0 3px var(--mlr-accent);
}
.mlr-tipo__heading {
	display: block;
	font-size: 16px;
	font-weight: 700;
	color: var(--mlr-brand);
	margin-bottom: 6px;
	position: relative;
	padding-left: 28px;
}
.mlr-tipo__heading::before {
	content: "";
	position: absolute;
	left: 0; top: 50%;
	width: 18px; height: 18px;
	border: 2px solid var(--mlr-muted);
	border-radius: 50%;
	transform: translateY(-50%);
	background: #fff;
}
.mlr-tipo__heading::after {
	content: "";
	position: absolute;
	left: 5px; top: 50%;
	width: 8px; height: 8px;
	background: var(--mlr-brand);
	border-radius: 50%;
	transform: translateY(-50%) scale(0);
	transition: transform .15s ease;
}
.mlr-tipo input:checked ~ .mlr-tipo__card .mlr-tipo__heading::before { border-color: var(--mlr-brand); }
.mlr-tipo input:checked ~ .mlr-tipo__card .mlr-tipo__heading::after  { transform: translateY(-50%) scale(1); }
.mlr-tipo__desc {
	display: block;
	font-size: 13px;
	color: var(--mlr-muted);
	line-height: 1.5;
}

/* ---------- Checkbox personalizado ---------- */
.mlr-libro .mlr-check {
	display: flex; align-items: flex-start; gap: 12px;
	cursor: pointer; font-size: 14px; color: var(--mlr-field-text);
	line-height: 1.5; margin: 0;
}
.mlr-libro .mlr-check input {
	position: absolute !important; opacity: 0 !important;
	width: 0 !important; height: 0 !important; margin: 0 !important;
}
.mlr-check__box {
	flex: 0 0 auto; width: 22px; height: 22px;
	border: 1.5px solid var(--mlr-muted); border-radius: 5px;
	background: #fff; position: relative; margin-top: 1px;
	transition: background .2s ease, border-color .2s ease;
}
.mlr-check input:checked + .mlr-check__box {
	background: var(--mlr-brand); border-color: var(--mlr-brand);
}
.mlr-check__box::after {
	content: ""; position: absolute; left: 7px; top: 3px;
	width: 6px; height: 11px;
	border-right: 2.5px solid #fff; border-bottom: 2.5px solid #fff;
	transform: rotate(45deg) scale(0); transition: transform .15s ease;
}
.mlr-check input:checked + .mlr-check__box::after { transform: rotate(45deg) scale(1); }
.mlr-check input:focus-visible + .mlr-check__box {
	box-shadow: 0 0 0 4px rgba(var(--mlr-brand-rgb), .2);
}
.mlr-check__text { color: var(--mlr-muted); font-size: 13px; }
.mlr-field--invalid .mlr-check__box { border-color: var(--mlr-error); }

/* ---------- Declaración del consumidor ---------- */
.mlr-libro .mlr-declaracion {
	background: rgba(var(--mlr-brand-rgb), .03);
	border: 1px dashed rgba(var(--mlr-brand-rgb), .25);
	border-radius: var(--mlr-radius-sm);
	padding: 18px 20px;
}
.mlr-libro .mlr-declaracion__title {
	margin: 0 0 6px;
	font-size: 13px;
	color: var(--mlr-brand);
	text-transform: uppercase;
	letter-spacing: .06em;
	font-weight: 700;
}
.mlr-libro .mlr-declaracion__note {
	margin: 0 0 12px;
	font-size: 12.5px;
	color: var(--mlr-muted);
	line-height: 1.55;
}
.mlr-libro .mlr-declaracion .mlr-check__text { font-size: 13px; color: var(--mlr-field-text); line-height: 1.55; }

/* ---------- Honeypot ---------- */
.mlr-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }

/* ---------- Acciones / Botón ---------- */
.mlr-actions {
	display: flex;
	align-items: center;
	gap: 22px;
	margin-top: 28px;
	flex-wrap: wrap;
}
.mlr-actions__note {
	margin: 0;
	font-size: 13px;
	color: var(--mlr-muted);
	flex: 1 1 200px;
}
.mlr-actions__note strong { color: var(--mlr-brand); }

.mlr-libro .mlr-submit {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: auto !important;
	color: var(--mlr-btn-text) !important;
	background: var(--mlr-btn-bg) !important;
	border: none !important;
	border-radius: var(--mlr-radius-sm) !important;
	padding: 15px 36px !important;
	font-weight: 700 !important;
	letter-spacing: .02em !important;
	text-transform: none !important;
	line-height: 1.2 !important;
	height: auto !important;
	min-width: 220px;
	cursor: pointer;
	transition: background .2s ease, transform .1s ease, box-shadow .2s ease;
	box-shadow: 0 6px 20px -10px rgba(var(--mlr-brand-rgb), .6);
}
.mlr-libro .mlr-submit:hover {
	background: var(--mlr-btn-bg-hover) !important;
	color: var(--mlr-btn-text) !important;
	box-shadow: 0 10px 28px -10px rgba(var(--mlr-brand-rgb), .7);
	transform: translateY(-1px);
}
.mlr-libro .mlr-submit:active { transform: translateY(0); }
.mlr-libro .mlr-submit:focus-visible { outline: 3px solid var(--mlr-accent); outline-offset: 3px; }
.mlr-libro .mlr-submit[disabled] { opacity: .75; cursor: progress; }

.mlr-submit__label { display: inline-block; }
.mlr-submit__spinner {
	display: none; width: 16px; height: 16px; margin-left: 10px;
	border: 2px solid rgba(255, 255, 255, .35); border-top-color: #fff; border-radius: 50%;
	animation: mlr-spin .7s linear infinite;
}
.mlr-submit.is-loading .mlr-submit__spinner { display: inline-block; }
@keyframes mlr-spin { to { transform: rotate(360deg); } }

/* ---------- Mensaje de respuesta ---------- */
.mlr-feedback {
	margin-top: 24px;
	padding: 18px 22px;
	border-radius: var(--mlr-radius-sm);
	font-size: 15px;
	line-height: 1.55;
}
.mlr-feedback.is-success {
	background: #ecfdf3;
	color: #024b32;
	border-left: 4px solid var(--mlr-success);
}
.mlr-feedback.is-error {
	background: #fef3f2;
	color: #7a1d11;
	border-left: 4px solid var(--mlr-error);
}
.mlr-feedback__hoja {
	display: inline-block;
	margin-top: 10px;
	padding: 6px 14px;
	background: var(--mlr-brand);
	color: var(--mlr-accent);
	border-radius: 6px;
	font-family: Menlo, Consolas, monospace;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: .04em;
}
.mlr-feedback__hojalink {
	margin-top: 14px;
}
.mlr-feedback__hojalink a {
	display: inline-block;
	background: var(--mlr-brand);
	color: #fff !important;
	text-decoration: none !important;
	padding: 10px 20px;
	border-radius: 6px;
	font-weight: 600;
	font-size: 14px;
	border-top: 3px solid var(--mlr-accent);
	transition: transform .15s ease, box-shadow .15s ease;
}
.mlr-feedback__hojalink a:hover {
	transform: translateY(-1px);
	box-shadow: 0 8px 20px -10px rgba(var(--mlr-brand-rgb), .5);
	color: #fff !important;
}

/* ---------- Responsive ---------- */
@media (max-width: 720px) {
	.mlr-grid { grid-template-columns: 1fr; gap: 14px; }
	.mlr-tipos { grid-template-columns: 1fr; }
	.mlr-libro .mlr-submit { width: 100% !important; min-width: 0; }
	.mlr-actions { gap: 16px; }
	.mlr-actions__note { text-align: center; flex-basis: 100%; }
	.mlr-libro__empresa { flex-direction: column; gap: 6px; }
}

@media (max-width: 480px) {
	.mlr-libro .mlr-form { padding: 20px 16px; }
	.mlr-section__title { font-size: 15px; gap: 10px; }
	.mlr-section__num { width: 26px; height: 26px; font-size: 13px; }
	.mlr-radio { flex-basis: 100%; }
}

/* ---------- Movimiento reducido ---------- */
@media (prefers-reduced-motion: reduce) {
	.mlr-libro .mlr-input,
	.mlr-libro .mlr-select select,
	.mlr-check__box,
	.mlr-radio__box,
	.mlr-libro .mlr-submit,
	.mlr-submit__spinner,
	.mlr-tipo__card { transition: none !important; animation: none !important; }
}
