/* =========================================================================
   Consulta JCE API — hoja de estilos del portal
   Estética institucional: navy + dorado latón, encabezados serif.
   © 2026 Anthony J. Rojas Valdez — ARSL v1.0
   ========================================================================= */

:root {
	/* Paleta institucional (navy + latón) */
	--c-primary: #13294b;
	--c-primary-dark: #0d1d36;
	--c-primary-light: #25457a;
	--c-accent: #b6862c;
	--c-accent-dark: #946c20;
	--c-accent-soft: #e8d9b0;

	--c-bg: #eef1f5;
	--c-surface: #ffffff;
	--c-surface-alt: #f6f8fb;
	--c-text: #1d2733;
	--c-muted: #5d6b7a;
	--c-border: #d3dae2;
	--c-success: #1f7a4d;

	--font-serif: Georgia, 'Cambria', 'Times New Roman', serif;
	--font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

	--maxw: 1160px;
	--radius: 4px;
	--shadow: 0 1px 3px rgba(13, 29, 54, .08), 0 6px 18px rgba(13, 29, 54, .06);
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
	height: 100%;
	/* Asegura que el HTML conozca la altura completa */
}

body {
	margin: 0;
	font-family: var(--font-sans);
	color: var(--c-text);
	background: var(--c-bg);
	line-height: 1.6;
	font-size: 16px;

	/* === CAMBIOS PARA EMPUJAR EL FOOTER === */
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

h1,
h2,
h3,
h4 {
	font-family: var(--font-serif);
	font-weight: 700;
	line-height: 1.2;
	margin: 0;
}

a {
	color: var(--c-primary-light);
	text-decoration: none;
}

a:hover {
	color: var(--c-accent-dark);
}

.container {
	width: 100%;
	max-width: var(--maxw);
	margin: 0 auto;
	padding: 0 24px;
}

.brand__logo {
	height: 48px;
	/* Cambiado de 94px a 48px para coincidir con el HTML */
	width: auto;
	display: block;
}

/* ---------- Botones ---------- */
.btn {
	display: inline-flex;
	align-items: center;
	gap: .5em;
	padding: .65em 1.25em;
	border-radius: var(--radius);
	font-weight: 600;
	font-size: .95rem;
	line-height: 1;
	cursor: pointer;
	border: 1px solid transparent;
	transition: all .15s ease;
	white-space: nowrap;
}

.btn--lg {
	padding: .85em 1.6em;
	font-size: 1rem;
}

.btn--block {
	display: flex;
	width: 100%;
	justify-content: center;
}

.btn--accent {
	background: var(--c-accent);
	color: #fff;
	border-color: var(--c-accent);
}

.btn--accent:hover {
	background: var(--c-accent-dark);
	border-color: var(--c-accent-dark);
	color: #fff;
}

.btn--ghost {
	background: transparent;
	color: var(--c-primary);
	border-color: var(--c-border);
}

.btn--ghost:hover {
	background: var(--c-surface);
	border-color: var(--c-primary-light);
	color: var(--c-primary);
}

.btn--ghost-light {
	background: transparent;
	color: #fff;
	border-color: rgba(255, 255, 255, .4);
}

.btn--ghost-light:hover {
	background: rgba(255, 255, 255, .1);
	color: #fff;
}

/* ---------- Barra superior ---------- */
.topbar {
	background: var(--c-primary-dark);
	color: #c5d0de;
	font-size: .82rem;
}

.topbar__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 38px;
}

.topbar__link {
	color: #e6ecf3;
	font-weight: 600;
}

.topbar__link:hover {
	color: var(--c-accent-soft);
}

.topbar i {
	color: var(--c-accent);
}

/* ---------- Masthead ---------- */
.masthead {
	background: var(--c-surface);
	border-bottom: 3px solid var(--c-accent);
}

.masthead__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	/* Esto garantizará que el botón y el logo estén centrados verticalmente */
	padding: 16px 24px;
	/* Controla el espaciado superior/inferior del bloque blanco */
}

.brand {
	display: inline-flex;
	flex-direction: row;
	/* Cambiado de column a row */
	align-items: center;
	/* Alinea el logo y el texto horizontalmente */
	gap: 16px;
	/* Separación elegante entre el logo y el eslogan */
	color: var(--c-text);
}

.brand__mark {
	display: grid;
	place-items: center;
	width: 46px;
	height: 46px;
	flex: none;
	background: var(--c-primary);
	color: var(--c-accent);
	border-radius: 6px;
	font-size: 1.5rem;
}

.brand__text {
	display: flex;
	flex-direction: column;
}

.brand__name {
	font-family: var(--font-serif);
	font-size: 1.35rem;
	color: var(--c-primary);
	letter-spacing: .2px;
}

.brand__name strong {
	color: var(--c-accent-dark);
}

.brand__tagline {
	font-size: .85rem;
	color: var(--c-muted);
	border-left: 1px solid var(--c-border);
	/* Una pequeña línea divisoria */
	padding-left: 16px;
	display: inline-block;
}

/* ---------- Navegación principal ---------- */
.mainnav {
	background: var(--c-primary);
}

.mainnav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
}

.mainnav__list a {
	display: block;
	padding: 14px 20px;
	color: #d7e0ec;
	font-weight: 600;
	font-size: .92rem;
	border-bottom: 3px solid transparent;
}

.mainnav__list a:hover {
	background: var(--c-primary-light);
	color: #fff;
}

.mainnav__list a.is-active {
	color: #fff;
	border-bottom-color: var(--c-accent);
}

/* ---------- Hero ---------- */
.hero {
	background: linear-gradient(180deg, var(--c-surface) 0%, var(--c-surface-alt) 100%);
	border-bottom: 1px solid var(--c-border);
}

.hero__inner {
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 48px;
	align-items: center;
	padding: 56px 24px;
}

.hero__eyebrow {
	color: var(--c-accent-dark);
	font-weight: 700;
	font-size: .85rem;
	text-transform: uppercase;
	letter-spacing: .5px;
	margin: 0 0 12px;
}

.hero__title {
	font-size: 2.5rem;
	color: var(--c-primary);
	margin-bottom: 16px;
}

.hero__lead {
	font-size: 1.12rem;
	color: var(--c-muted);
	margin: 0 0 26px;
}

.hero__actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
	margin-bottom: 18px;
}

.hero__note {
	font-size: .85rem;
	color: var(--c-muted);
	margin: 0;
}

.hero__note i,
.hero__eyebrow i {
	color: var(--c-accent);
}

.hero__card {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 8px;
	box-shadow: var(--shadow);
	overflow: hidden;
}

.hero__card-head {
	background: var(--c-primary);
	color: #fff;
	padding: 14px 18px;
	font-weight: 600;
	font-size: .95rem;
}

.hero__card-head i {
	color: var(--c-accent);
	margin-right: 6px;
}

.hero__data {
	margin: 0;
	padding: 18px;
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 10px 16px;
}

.hero__data dt {
	color: var(--c-muted);
	font-size: .85rem;
	font-weight: 600;
}

.hero__data dd {
	margin: 0;
	font-weight: 600;
	color: var(--c-text);
}

.badge {
	display: inline-flex;
	align-items: center;
	gap: .35em;
	padding: .2em .6em;
	border-radius: 999px;
	font-size: .8rem;
	font-weight: 700;
}

.badge--ok {
	background: #e3f3ea;
	color: var(--c-success);
}

/* ---------- Secciones ---------- */
.section {
	padding: 64px 0;
}

.section--alt {
	background: var(--c-surface-alt);
	border-top: 1px solid var(--c-border);
	border-bottom: 1px solid var(--c-border);
}

.section--dark {
	background: var(--c-primary);
	color: #fff;
}

.section__head {
	text-align: center;
	max-width: 700px;
	margin: 0 auto 40px;
}

.section__kicker {
	display: inline-block;
	color: var(--c-accent-dark);
	font-weight: 700;
	font-size: .82rem;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 10px;
}

.section__kicker--light {
	color: var(--c-accent-soft);
}

.section__title {
	font-size: 1.9rem;
	color: var(--c-primary);
}

.section__title--light {
	color: #fff;
}

/* ---------- Tarjetas de servicio ---------- */
.cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.card {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 6px;
	padding: 28px;
	transition: box-shadow .2s, transform .2s;
}

.card:hover {
	box-shadow: var(--shadow);
	transform: translateY(-3px);
}

.card__icon {
	display: grid;
	place-items: center;
	width: 54px;
	height: 54px;
	background: #eef2f8;
	color: var(--c-primary);
	border-radius: 8px;
	font-size: 1.6rem;
	margin-bottom: 16px;
}

.card__title {
	font-size: 1.2rem;
	color: var(--c-primary);
	margin-bottom: 8px;
}

.card__text {
	color: var(--c-muted);
	margin: 0;
	font-size: .95rem;
}

/* ---------- Pasos ---------- */
.steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	list-style: none;
	margin: 0;
	padding: 0;
	counter-reset: step;
}

.step {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 6px;
	padding: 26px;
	position: relative;
}

.step__num {
	display: grid;
	place-items: center;
	width: 38px;
	height: 38px;
	background: var(--c-primary);
	color: var(--c-accent);
	font-family: var(--font-serif);
	font-weight: 700;
	border-radius: 50%;
	margin-bottom: 14px;
}

.step__title {
	font-size: 1.1rem;
	color: var(--c-primary);
	margin-bottom: 6px;
}

.step__text {
	color: var(--c-muted);
	margin: 0;
	font-size: .92rem;
}

/* ---------- Precios ---------- */
.pricing {
	display: flex;
	justify-content: center;
}

.pricing__card {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-top: 4px solid var(--c-accent);
	border-radius: 6px;
	box-shadow: var(--shadow);
	padding: 36px;
	max-width: 420px;
	width: 100%;
	text-align: center;
}

.pricing__label {
	display: block;
	color: var(--c-muted);
	font-weight: 600;
	text-transform: uppercase;
	font-size: .8rem;
	letter-spacing: .5px;
}

.pricing__amount {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: 4px;
	margin: 10px 0 4px;
	color: var(--c-primary);
}

.pricing__currency {
	font-family: var(--font-serif);
	font-size: 1.4rem;
	margin-top: 8px;
}

.pricing__value {
	font-family: var(--font-serif);
	font-size: 3.4rem;
	font-weight: 700;
	line-height: 1;
}

.pricing__unit {
	color: var(--c-muted);
	font-size: .9rem;
}

.pricing__features {
	list-style: none;
	margin: 24px 0;
	padding: 0;
	text-align: left;
}

.pricing__features li {
	padding: 8px 0;
	border-bottom: 1px solid var(--c-border);
	color: var(--c-text);
	font-size: .95rem;
}

.pricing__features li:last-child {
	border-bottom: none;
}

.pricing__features i {
	color: var(--c-success);
	margin-right: 8px;
}

/* ---------- Desarrolladores ---------- */
.devs {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: 48px;
	align-items: center;
}

.devs__lead {
	color: #c5d0de;
	font-size: 1.05rem;
}

.devs__list {
	list-style: none;
	padding: 0;
	margin: 20px 0 0;
}

.devs__list li {
	padding: 6px 0;
	color: #e6ecf3;
}

.devs__list i {
	color: var(--c-accent);
	margin-right: 8px;
}

.code {
	background: #0a1626;
	border: 1px solid #2a3f5f;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: var(--shadow);
}

.code__head {
	display: flex;
	align-items: center;
	gap: 6px;
	background: #11203a;
	padding: 10px 14px;
	font-size: .8rem;
	color: #8fa3bf;
}

.code__dot {
	width: 11px;
	height: 11px;
	border-radius: 50%;
	background: #34507a;
	display: inline-block;
}

.code__title {
	margin-left: 8px;
}

.code__body {
	margin: 0;
	padding: 18px;
	overflow-x: auto;
}

.code__body code {
	font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', monospace;
	font-size: .85rem;
	color: #c8e1ff;
	line-height: 1.6;
	white-space: pre-wrap;
	/* <- CAMBIADO: Permite que el texto se ajuste al contenedor */
	word-break: break-word;
	/* Agrega esto para evitar palabras ultra largas desbordadas */
}

/* ---------- CTA ---------- */
.cta {
	background: var(--c-primary-dark);
	color: #fff;
}

.cta__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 32px;
	padding: 44px 24px;
	flex-wrap: wrap;
}

.cta__title {
	font-size: 1.6rem;
	color: #fff;
	margin-bottom: 6px;
}

.cta__text {
	color: #c5d0de;
	margin: 0;
}

.cta__actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
}

/* ---------- Footer ---------- */
.footer {
	background: var(--c-primary);
	color: #c5d0de;
}

.footer__grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1fr;
	gap: 32px;
	padding: 48px 24px 32px;
}

.brand--footer .brand__mark {
	width: 38px;
	height: 38px;
	font-size: 1.2rem;
}

.brand--footer .brand__name {
	font-size: 1.1rem;
	color: #fff;
}

.brand--footer .brand__name strong {
	color: var(--c-accent-soft);
}

.footer__desc {
	font-size: .9rem;
	margin: 14px 0 0;
	color: #a9b8cc;
}

.footer__title {
	color: #fff;
	font-size: .95rem;
	margin-bottom: 14px;
	font-family: var(--font-sans);
	text-transform: uppercase;
	letter-spacing: .5px;
}

.footer__links {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer__links li {
	padding: 5px 0;
}

.footer__links a {
	color: #c5d0de;
	font-size: .9rem;
}

.footer__links a:hover {
	color: var(--c-accent-soft);
}

.footer__bar {
	background: var(--c-primary-dark);
	padding: 16px 0;
}

.footer__bar-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: .82rem;
	color: #a9b8cc;
	flex-wrap: wrap;
	gap: 8px;
}

.footer__bar-inner i {
	color: var(--c-accent);
}

.footer__disclaimer {
	font-size: .76rem;
	color: #7e90a8;
	margin: 10px 0 0;
}

/* ---------- Responsive ---------- */
@media (max-width: 992px) {

	/* El Hero y la sección de desarrolladores pasan a una sola columna */
	.hero__inner,
	.devs {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	/* En móviles, muestra primero el texto del Hero y abajo la tarjeta de ejemplo */
	.hero__panel {
		order: initial;
	}

	/* Las tarjetas de servicio y pasos bajan a 2 columnas */
	.cards,
	.steps {
		grid-template-columns: repeat(2, 1fr);
	}

	/* El footer baja a 2 columnas */
	.footer__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {

	/* Hace que la marca del Masthead colapse en columna si no cabe horizontalmente */
	.masthead__inner {
		flex-direction: column;
		gap: 16px;
		text-align: center;
	}

	.brand {
		flex-direction: column;
		gap: 8px;
	}

	.brand__tagline {
		border-left: none;
		padding-left: 0;
	}

	.hero__title {
		font-size: 2rem;
	}

	.hero__actions {
		flex-direction: column;
	}

	.hero__actions .btn {
		width: 100%;
		justify-content: center;
	}
}

@media (max-width: 560px) {

	/* Todo el contenido pasa a una sola columna estricta */
	.cards,
	.steps,
	.footer__grid {
		grid-template-columns: 1fr;
	}

	/* Alineación de los botones de llamada a la acción */
	.cta__inner {
		flex-direction: column;
		align-items: stretch;
		text-align: center;
	}

	.cta__actions {
		flex-direction: column;
		width: 100%;
	}

	.cta__actions .btn {
		width: 100%;
		justify-content: center;
	}
}

/* =========================================================================
   Autenticación (login / registro)
   ========================================================================= */
.authwrap {
	display: flex;
	justify-content: center;
	padding: 56px 24px;
	min-height: 50vh;
}

.authcard {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-top: 4px solid var(--c-accent);
	border-radius: 6px;
	box-shadow: var(--shadow);
	padding: 36px;
	width: 100%;
	max-width: 440px;
}

.authcard__head {
	text-align: center;
	margin-bottom: 24px;
}

.authcard__icon {
	display: inline-grid;
	place-items: center;
	width: 54px;
	height: 54px;
	background: var(--c-primary);
	color: var(--c-accent);
	border-radius: 50%;
	font-size: 1.5rem;
	margin-bottom: 14px;
}

.authcard__title {
	font-size: 1.6rem;
	color: var(--c-primary);
}

.authcard__sub {
	color: var(--c-muted);
	margin: 6px 0 0;
	font-size: .95rem;
}

.authcard__foot {
	text-align: center;
	margin: 22px 0 0;
	font-size: .92rem;
	color: var(--c-muted);
}

/* ---------- Formularios ---------- */
.form {
	display: flex;
	flex-direction: column;
}

.form__label {
	font-size: .85rem;
	font-weight: 600;
	color: var(--c-text);
	margin: 14px 0 6px;
}

.form__input {
	font-family: var(--font-sans);
	font-size: .98rem;
	padding: .7em .9em;
	border: 1px solid var(--c-border);
	border-radius: var(--radius);
	background: #fff;
	color: var(--c-text);
	transition: border-color .15s, box-shadow .15s;
}

.form__input:focus {
	outline: none;
	border-color: var(--c-primary-light);
	box-shadow: 0 0 0 3px rgba(37, 69, 122, .15);
}

.form__input.is-invalid {
	border-color: #c0392b;
}

.form__error {
	color: #c0392b;
	font-size: .82rem;
	margin-top: 5px;
}

.form .btn {
	margin-top: 22px;
}

/* ---------- Alertas ---------- */
.alert {
	display: flex;
	align-items: center;
	gap: .6em;
	padding: .8em 1em;
	border-radius: var(--radius);
	font-size: .9rem;
	margin-bottom: 18px;
	border: 1px solid transparent;
}

.alert--error {
	background: #fdecea;
	color: #a3261a;
	border-color: #f5c6c0;
}

.alert--ok {
	background: #e3f3ea;
	color: var(--c-success);
	border-color: #bfe3cd;
}

/* ---------- Barra superior: usuario / logout ---------- */
.topbar__user {
	display: inline-flex;
	align-items: center;
	gap: 12px;
}

.topbar__user i {
	color: var(--c-accent);
}

.topbar__logout {
	display: inline;
	margin: 0;
}

.topbar__logout-btn {
	background: none;
	border: none;
	color: #e6ecf3;
	font: inherit;
	font-size: .82rem;
	font-weight: 600;
	cursor: pointer;
	padding: 0;
	display: inline-flex;
	align-items: center;
	gap: .35em;
}

.topbar__logout-btn:hover {
	color: var(--c-accent-soft);
}

/* =========================================================================
   Panel del cliente (dashboard)
   ========================================================================= */
.dash,
.authwrap {
    padding: 48px 0 64px;
    flex: 1; /* === ESTO EMPUJA EL FOOTER HASTA ABAJO EN AMBAS VISTAS === */
}

.dash__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
	flex-wrap: wrap;
	margin-bottom: 28px;
	padding-bottom: 22px;
	border-bottom: 1px solid var(--c-border);
}

.dash__title {
	font-size: 1.8rem;
	color: var(--c-primary);
}

.dash__sub {
	color: var(--c-muted);
	margin: 4px 0 0;
}

.rolebadge {
	display: inline-flex;
	align-items: center;
	gap: .4em;
	background: #eef2f8;
	color: var(--c-primary);
	font-weight: 700;
	font-size: .82rem;
	padding: .4em .9em;
	border-radius: 999px;
	text-transform: uppercase;
	letter-spacing: .5px;
}

.rolebadge--admin {
	background: var(--c-accent-soft);
	color: var(--c-accent-dark);
}

.dash__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	/* Subimos a 240px para mejor legibilidad */
	grid-auto-rows: 1fr;
	/* <- MAGIA: Hace que todas las tarjetas midan lo mismo de alto */
	gap: 24px;
	/* Un poco más de aire entre elementos */
	align-items: stretch;
}

.metric {
	background: var(--c-primary);
	color: #fff;
	border-radius: 8px;
	padding: 24px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	/* Distribuye el contenido uniformemente de arriba a abajo */
	gap: 8px;
}

.metric__label {
	font-size: .85rem;
	color: #c5d0de;
	font-weight: 600;
}

.metric__value {
	font-family: var(--font-sans);
	/* Cambiar a sans para un look de software más moderno */
	font-size: 2.5rem;
	/* Ajustamos ligeramente el tamaño */
	font-weight: 700;
	line-height: 1.1;
	color: var(--c-accent);
	/* Cambiado a dorado para que resalte inmediatamente el saldo */
	margin: 8px 0;
}

.metric__hint {
	font-size: .82rem;
	color: var(--c-accent-soft);
}

.action {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 8px;
	padding: 24px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	/* Alinea los textos a la izquierda */
	justify-content: flex-start;
	gap: 8px;
	transition: box-shadow .2s, transform .2s, border-color .2s;
	height: 100%;
	/* Asegura llenar el espacio del contenedor Grid */
}

.action:hover {
	box-shadow: var(--shadow);
	transform: translateY(-3px);
	border-color: var(--c-accent);
	color: var(--c-text);
}

.action__icon {
	display: grid;
	place-items: center;
	width: 44px;
	height: 44px;
	background: var(--c-surface-alt);
	color: var(--c-primary);
	border-radius: 6px;
	font-size: 1.25rem;
	margin-bottom: 4px;
}

.action__title {
	font-weight: 700;
	color: var(--c-primary);
	font-size: 1.05rem;
}

.action__text {
	color: var(--c-muted);
	font-size: .9rem;
}

.action--admin .action__icon {
	background: var(--c-accent-soft);
	color: var(--c-accent-dark);
}

/* =========================================================================
   Enlaces sociales (contacto + footer)
   ========================================================================= */
.social {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	margin-top: 18px;
}

.social__link {
	display: inline-flex;
	align-items: center;
	gap: .5em;
	color: #c5d0de;
	font-size: .92rem;
	font-weight: 600;
}

.social__link:hover {
	color: var(--c-accent-soft);
}

.social__link i {
	font-size: 1.15rem;
	color: var(--c-accent);
}

.footer__social {
	display: flex;
	gap: 12px;
	margin-top: 16px;
}

.footer__social a {
	display: grid;
	place-items: center;
	width: 36px;
	height: 36px;
	background: var(--c-primary-dark);
	color: #c5d0de;
	border-radius: 6px;
	font-size: 1.1rem;
	transition: background .15s, color .15s;
}

.footer__social a:hover {
	background: var(--c-accent);
	color: #fff;
}

/* =========================================================================
   Páginas de contenido (documentación, legal)
   ========================================================================= */
.pagehead {
	background: var(--c-primary);
	color: #fff;
	padding: 40px 0;
}

.pagehead__kicker {
	color: var(--c-accent-soft);
	font-weight: 700;
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: 1px;
}

.pagehead__title {
	font-size: 2rem;
	color: #fff;
	margin: 6px 0 0;
}

.pagehead__sub {
	color: #c5d0de;
	margin: 8px 0 0;
}

.doc {
	padding: 48px 0 64px;
}

.doc__layout {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 40px;
	align-items: start;
}

.doc__toc {
	position: sticky;
	top: 24px;
	border: 1px solid var(--c-border);
	border-radius: 6px;
	padding: 18px;
	background: var(--c-surface);
}

.doc__toc h4 {
	font-family: var(--font-sans);
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: .5px;
	color: var(--c-muted);
	margin-bottom: 10px;
}

.doc__toc ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.doc__toc li {
	padding: 5px 0;
}

.doc__toc a {
	font-size: .92rem;
}

.doc__content h2 {
	font-size: 1.5rem;
	color: var(--c-primary);
	margin: 36px 0 12px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--c-border);
}

.doc__content h2:first-child {
	margin-top: 0;
}

.doc__content h3 {
	font-size: 1.15rem;
	color: var(--c-primary);
	margin: 24px 0 8px;
}

.doc__content p,
.doc__content li {
	color: var(--c-text);
}

.doc__content ul {
	padding-left: 20px;
}

.doc__content .code {
	margin: 16px 0;
}

.method {
	display: inline-block;
	font-family: var(--font-sans);
	font-weight: 700;
	font-size: .75rem;
	padding: .2em .6em;
	border-radius: 4px;
	color: #fff;
	margin-right: 8px;
}

.method--post {
	background: var(--c-success);
}

.method--get {
	background: var(--c-primary-light);
}

.method--delete {
	background: #c0392b;
}

.endpoint {
	font-family: 'SFMono-Regular', Consolas, monospace;
	background: #eef2f8;
	padding: .2em .5em;
	border-radius: 4px;
	font-size: .9rem;
	color: var(--c-primary);
}

.legal {
	padding: 40px 0 64px;
	max-width: 820px;
}

.legal h2 {
	font-size: 1.3rem;
	color: var(--c-primary);
	margin: 30px 0 10px;
}

.legal p,
.legal li {
	color: var(--c-text);
	line-height: 1.7;
}

.legal__updated {
	color: var(--c-muted);
	font-size: .88rem;
	font-style: italic;
}
/* ========================= Panel: API Keys ========================= */
.backlink { font-size: .9rem; font-weight: 600; }
.muted { color: var(--c-muted); }
.panelcard { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 8px; padding: 24px; margin: 20px 0; }
.panelcard__title { font-size: 1.2rem; color: var(--c-primary); margin-bottom: 16px; }
.keyform__row { display: grid; grid-template-columns: 2fr 1fr auto; gap: 14px; align-items: end; }
.keyform__row .btn { height: 42px; }
.btn--sm { padding: .45em .8em; font-size: .85rem; }
.btn--danger { background: #c0392b; color: #fff; border-color: #c0392b; }
.btn--danger:hover { background: #a3261a; border-color: #a3261a; color: #fff; }
.badge--off { background: #f0e3e1; color: #a3261a; }
.ktable { width: 100%; border-collapse: collapse; }
.ktable th { text-align: left; font-size: .78rem; text-transform: uppercase; letter-spacing: .5px; color: var(--c-muted); padding: 10px 12px; border-bottom: 2px solid var(--c-border); }
.ktable td { padding: 12px; border-bottom: 1px solid var(--c-border); font-size: .92rem; vertical-align: middle; }
.ktable code { background: #eef2f8; padding: .2em .5em; border-radius: 4px; font-size: .85rem; color: var(--c-primary); }
.keyreveal { background: #fffbe9; border: 1px solid var(--c-accent); border-left: 4px solid var(--c-accent); border-radius: 6px; padding: 20px; margin: 20px 0; }
.keyreveal__head { font-size: 1.05rem; color: var(--c-primary); font-weight: 700; margin-bottom: 8px; }
.keyreveal__warn { color: var(--c-accent-dark); font-size: .9rem; margin: 0 0 12px; }
.keyreveal__value { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.keyreveal__value code { background: var(--c-primary); color: #fff; padding: .7em 1em; border-radius: 4px; font-size: .9rem; word-break: break-all; flex: 1; min-width: 240px; }
@media (max-width:560px){ .keyform__row { grid-template-columns: 1fr; } }

/* ========================= Panel: Comprar tokens ========================= */
.buycard { max-width: 480px; margin: 20px auto; }
.buyqty { display: flex; align-items: stretch; gap: 8px; max-width: 220px; }
.buyqty__btn { width: 44px; border: 1px solid var(--c-border); background: var(--c-surface-alt); color: var(--c-primary); font-size: 1.3rem; font-weight: 700; border-radius: var(--radius); cursor: pointer; }
.buyqty__btn:hover { background: var(--c-primary); color: #fff; }
.buyqty__input { text-align: center; font-size: 1.2rem; font-weight: 700; }
.buyhint { font-size: .82rem; color: var(--c-muted); margin: 8px 0 0; }
.buytotal { background: var(--c-surface-alt); border: 1px solid var(--c-border); border-radius: 8px; padding: 20px; margin: 22px 0; text-align: center; }
.buytotal__label { display: block; color: var(--c-muted); font-size: .85rem; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.buytotal__value { display: block; font-family: var(--font-serif); font-size: 2.4rem; font-weight: 700; color: var(--c-primary); line-height: 1.2; }
.buytotal__unit { font-size: .85rem; color: var(--c-muted); }

/* ========================= Resultado de pago ========================= */
.resultcard { max-width: 520px; margin: 40px auto; background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 8px; box-shadow: var(--shadow); padding: 40px; text-align: center; }
.resultcard__icon { display: inline-grid; place-items: center; width: 72px; height: 72px; border-radius: 50%; font-size: 2.2rem; margin-bottom: 16px; }
.resultcard__icon--ok { background: #e3f3ea; color: var(--c-success); }
.resultcard__icon--warn { background: #fff4e0; color: var(--c-accent-dark); }
.resultcard__icon--err { background: #fdecea; color: #a3261a; }
.resultcard__title { font-size: 1.6rem; color: var(--c-primary); margin-bottom: 8px; }
.resultcard__text { color: var(--c-muted); margin: 0 0 18px; }
.resultcard__data { display: grid; grid-template-columns: auto 1fr; gap: 8px 16px; max-width: 260px; margin: 0 auto 24px; text-align: left; }
.resultcard__data dt { color: var(--c-muted); font-size: .85rem; font-weight: 600; }
.resultcard__data dd { margin: 0; font-weight: 700; color: var(--c-text); }
.resultcard__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ========================= Panel admin: logs y paginación ========================= */
.badge--warn { background: #fff4e0; color: var(--c-accent-dark); }
.logmsg { max-width: 420px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pager { display: flex; align-items: center; justify-content: center; gap: 16px; margin-top: 20px; }
.pager__info { font-size: .9rem; color: var(--c-muted); }

/* ========================= Consulta de cédula (panel) ========================= */
.consform__row { display: flex; gap: 12px; align-items: stretch; }
.consform__row .form__input { flex: 1; font-size: 1.1rem; text-align: center; letter-spacing: 1px; }
.consform__row .btn { white-space: nowrap; }
.idcard { max-width: 720px; }
.idresult { display: flex; gap: 28px; align-items: flex-start; flex-wrap: wrap; }
/* Foto: recorta la parte inferior (object-position top + cover en 200x230) */
.idphoto { width: 200px; height: 230px; flex: none; overflow: hidden; border-radius: 6px;
	border: 1px solid var(--c-border); box-shadow: var(--shadow); background: var(--c-surface-alt); }
.idphoto img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
.idphoto--empty { display: grid; place-items: center; color: var(--c-muted); font-size: 3rem; }
.idgrid { flex: 1; min-width: 260px; margin: 0; display: grid; grid-template-columns: 1fr; gap: 2px 16px; }
.idgrid dt { color: var(--c-muted); font-size: .78rem; font-weight: 600; text-transform: uppercase; letter-spacing: .4px; margin-top: 12px; }
.idgrid dt:first-child { margin-top: 0; }
.idgrid dd { margin: 0; color: var(--c-text); font-weight: 600; font-size: 1.02rem; }
.idcard__foot { margin: 22px 0 0; display: flex; align-items: center; gap: 10px; }
@media (max-width:560px){ .consform__row { flex-direction: column; } .idphoto { margin: 0 auto; } }

/* Tarjeta destacada del dashboard (consultar) */
.action--primary { background: var(--c-primary); border-color: var(--c-primary); }
.action--primary .action__icon { background: rgba(255,255,255,.12); color: var(--c-accent); }
.action--primary .action__title { color: #fff; }
.action--primary .action__text { color: #c5d0de; }
.action--primary:hover { border-color: var(--c-accent); }

/* Aviso de onboarding (crear API Key) */
.notice { display: flex; align-items: center; gap: 14px; background: #fffbe9; border: 1px solid var(--c-accent);
	border-left: 4px solid var(--c-accent); border-radius: 6px; padding: 14px 18px; margin-bottom: 20px; }
.notice > i { font-size: 1.5rem; color: var(--c-accent-dark); flex: none; }
.notice > div { flex: 1; font-size: .92rem; color: var(--c-text); }
.notice strong { color: var(--c-primary); }

/* Banner de cookies (fijo abajo) */
.cookiebar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 1000;
	display: flex; align-items: center; gap: 16px; flex-wrap: wrap; justify-content: center;
	background: var(--c-primary-dark); color: #e6ecf3; padding: 14px 24px;
	border-top: 3px solid var(--c-accent); box-shadow: 0 -4px 18px rgba(13,29,54,.18); }
.cookiebar__text { margin: 0; font-size: .9rem; max-width: 820px; }
.cookiebar__text i { color: var(--c-accent); margin-right: 6px; }
.cookiebar__text a { color: var(--c-accent-soft); text-decoration: underline; }
.cookiebar[hidden] { display: none; }

/* Botón Google + divisor en login */
.authdiv { display: flex; align-items: center; text-align: center; color: var(--c-muted); font-size: .8rem; margin: 18px 0; }
.authdiv::before, .authdiv::after { content: ""; flex: 1; height: 1px; background: var(--c-border); }
.authdiv span { padding: 0 12px; }
.btn--google { background: #fff; color: var(--c-text); border-color: var(--c-border); }
.btn--google:hover { background: var(--c-surface-alt); border-color: var(--c-primary-light); color: var(--c-text); }
.btn--google i { color: #4285F4; }

/* Avatar del usuario en el topbar */
.topbar__avatar { width: 22px; height: 22px; border-radius: 50%; object-fit: cover;
	border: 1px solid var(--c-accent); vertical-align: middle; }

/* Código en la página de error */
.errorcode { color: var(--c-muted); font-size: .85rem; font-weight: 600; letter-spacing: .5px; margin: 0 0 18px; }

/* =========================================================================
   Landing — bloques nuevos (vías de uso, confianza, FAQ)
   ========================================================================= */

/* Subtítulo de sección */
.section__sub { color: var(--c-muted); font-size: 1.02rem; margin: 10px auto 0; max-width: 640px; }
.section--dark .section__sub { color: #c5d0de; }
.container--narrow { max-width: 820px; }

/* Hero: tarjeta de resultado con "foto" + datos */
.hero__card-body { display: grid; grid-template-columns: 96px 1fr; gap: 18px; padding: 18px; align-items: start; }
.hero__photo { width: 96px; height: 112px; border-radius: 6px; display: grid; place-items: center;
	background: #eef2f8; border: 1px solid var(--c-border); color: var(--c-primary-light); font-size: 2.6rem; }
.hero__card-body .hero__data { padding: 0; }
@media (max-width: 520px) { .hero__card-body { grid-template-columns: 1fr; } .hero__photo { width: 96px; } }

/* Dos formas de usarlo */
.cards--two { grid-template-columns: repeat(2, 1fr); }
.card--feature { display: flex; flex-direction: column; }
.card--feature .card__text { margin-bottom: 14px; }
.featurelist { list-style: none; margin: 0 0 22px; padding: 0; }
.featurelist li { padding: 6px 0; color: var(--c-text); font-size: .95rem; }
.featurelist i { color: var(--c-success); margin-right: 8px; }
.featurelist code { background: #eef2f8; border: 1px solid var(--c-border); border-radius: 3px;
	padding: 1px 6px; font-size: .85em; color: var(--c-primary); }
.card--feature .btn { margin-top: auto; }

/* Seguridad / confianza */
.trust { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.trust__item { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 6px; padding: 24px; }
.trust__icon { display: grid; place-items: center; width: 46px; height: 46px; border-radius: 8px;
	background: var(--c-primary); color: var(--c-accent); font-size: 1.3rem; margin-bottom: 14px; }
.trust__title { font-size: 1.08rem; color: var(--c-primary); margin: 0 0 6px; }
.trust__text { color: var(--c-muted); margin: 0; font-size: .92rem; }

/* FAQ (acordeón nativo) */
.faq { display: grid; gap: 12px; }
.faq__item { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 6px; padding: 0 18px; }
.faq__q { cursor: pointer; list-style: none; padding: 16px 28px 16px 0; position: relative;
	font-weight: 600; color: var(--c-primary); font-family: var(--font-serif); }
.faq__q::-webkit-details-marker { display: none; }
.faq__q::after { content: "\F282"; font-family: "bootstrap-icons"; position: absolute; right: 2px; top: 16px;
	color: var(--c-accent); transition: transform .2s; }
.faq__item[open] .faq__q::after { transform: rotate(180deg); }
.faq__a { color: var(--c-muted); margin: 0 0 16px; font-size: .95rem; }

@media (max-width: 900px) {
	.cards--two { grid-template-columns: 1fr; }
	.trust { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.trust { grid-template-columns: 1fr; }
}

/* =========================================================================
   Consulta de cédula — overlay de carga + validación
   ========================================================================= */

/* Campo inválido */
.form__input.is-invalid {
	border-color: #c0392b;
	box-shadow: 0 0 0 3px rgba(192, 57, 43, .12);
}
.buyhint.is-error { color: #c0392b; font-weight: 600; }

/* Overlay */
.consloader {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 2000;
	align-items: center;
	justify-content: center;
	padding: 24px;
	background: rgba(13, 29, 54, .55);
	backdrop-filter: blur(3px);
	animation: cl-fade .2s ease;
}
.consloader.is-active { display: flex; }

@keyframes cl-fade { from { opacity: 0; } to { opacity: 1; } }

.consloader__card {
	background: var(--c-surface);
	border-radius: 10px;
	border-top: 4px solid var(--c-accent);
	box-shadow: 0 20px 60px rgba(13, 29, 54, .35);
	padding: 34px 30px 28px;
	max-width: 380px;
	width: 100%;
	text-align: center;
}

/* Spinner: anillo girando + icono al centro */
.consloader__spinner {
	position: relative;
	width: 76px;
	height: 76px;
	margin: 0 auto 18px;
	display: grid;
	place-items: center;
}
.consloader__ring {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	border: 4px solid var(--c-border);
	border-top-color: var(--c-accent);
	animation: cl-spin .9s linear infinite;
}
.consloader__spinner i {
	font-size: 1.9rem;
	color: var(--c-primary);
	animation: cl-pulse 1.6s ease-in-out infinite;
}
@keyframes cl-spin { to { transform: rotate(360deg); } }
@keyframes cl-pulse { 0%, 100% { opacity: .55; } 50% { opacity: 1; } }

.consloader__title {
	font-size: 1.25rem;
	color: var(--c-primary);
	margin: 0 0 4px;
}
.consloader__step {
	margin: 0 0 16px;
	color: var(--c-text);
	font-weight: 600;
	min-height: 1.4em;
	transition: opacity .2s;
}
.consloader__hint {
	margin: 14px 0 0;
	color: var(--c-muted);
	font-size: .85rem;
}

/* Barra indeterminada */
.consloader__bar {
	height: 5px;
	border-radius: 999px;
	background: var(--c-border);
	overflow: hidden;
}
.consloader__bar span {
	display: block;
	height: 100%;
	width: 40%;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--c-accent), var(--c-accent-dark));
	animation: cl-bar 1.2s ease-in-out infinite;
}
@keyframes cl-bar {
	0%   { margin-left: -40%; }
	100% { margin-left: 100%; }
}

@media (prefers-reduced-motion: reduce) {
	.consloader__ring, .consloader__spinner i, .consloader__bar span { animation: none; }
}
