/**
 * Colonia Colonos - estilos del panel de cuenta.
 */

.colonia-panel {
	--colonia-accent: #1f6f54;
	--colonia-accent-soft: #e8f3ee;
	--colonia-border: #e2e5e9;
	--colonia-radius: 10px;
}

.colonia-intro {
	color: #555;
	margin-bottom: 1.5em;
}

.colonia-empty {
	padding: 1.5em;
	background: #f7f8fa;
	border-radius: var(--colonia-radius);
}

/* Selector de colonos */
.colonia-selector {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5em;
	margin-bottom: 1.5em;
	padding: 0.75em 1em;
	background: var(--colonia-accent-soft);
	border-radius: var(--colonia-radius);
}

.colonia-chip {
	display: inline-flex;
	flex-direction: column;
	padding: 0.35em 0.75em;
	background: #fff;
	border: 1px solid var(--colonia-border);
	border-radius: 999px;
	text-decoration: none;
	font-size: 0.9em;
	line-height: 1.2;
}

.colonia-chip small {
	color: #888;
	font-size: 0.78em;
}

.colonia-chip:hover {
	border-color: var(--colonia-accent);
}

/* Tarjeta de colono */
.colonia-card {
	border: 1px solid var(--colonia-border);
	border-radius: var(--colonia-radius);
	margin-bottom: 2em;
	overflow: hidden;
	scroll-margin-top: 1em;
}

.colonia-card__head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 1em;
	padding: 1em 1.25em;
	background: var(--colonia-accent);
	color: #fff;
}

.colonia-card__head h3 {
	margin: 0;
	color: #fff;
}

.colonia-order {
	font-size: 0.85em;
	opacity: 0.9;
}

/* Badge de apto */
.colonia-badge {
	margin: 0;
	padding: 0.6em 1.25em;
	font-size: 0.9em;
	font-weight: 600;
}

.colonia-badge--ok {
	background: #e6f4ea;
	color: #1a7f37;
}

.colonia-badge--warn {
	background: #fff4e5;
	color: #b06000;
}

.colonia-badge--danger {
	background: #fce8e6;
	color: #b32d2e;
}

/* Secciones colapsables */
.colonia-section {
	border-top: 1px solid var(--colonia-border);
}

.colonia-section summary {
	cursor: pointer;
	padding: 0.9em 1.25em;
	font-weight: 600;
	list-style: none;
	user-select: none;
}

.colonia-section summary::-webkit-details-marker {
	display: none;
}

.colonia-section summary::after {
	content: "+";
	float: right;
	font-weight: 400;
	opacity: 0.5;
}

.colonia-section[open] summary::after {
	content: "\2212";
}

.colonia-section__body {
	padding: 0 1.25em 1.25em;
}

/* Formularios */
.colonia-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 0.75em 1em;
}

.colonia-field {
	margin: 0.4em 0;
}

.colonia-field--full {
	grid-column: 1 / -1;
}

.colonia-field label {
	display: block;
	font-size: 0.9em;
	font-weight: 500;
	margin-bottom: 0.25em;
}

.colonia-field input[type="text"],
.colonia-field input[type="date"],
.colonia-field input[type="email"],
.colonia-field select,
.colonia-field textarea {
	width: 100%;
	box-sizing: border-box;
}

.colonia-checks,
.colonia-check label {
	display: flex;
	gap: 0.5em;
	align-items: center;
	flex-wrap: wrap;
}

.colonia-checks {
	gap: 1.5em;
	margin: 1em 0;
}

.colonia-apto,
.colonia-intereses {
	border: 1px solid var(--colonia-border);
	border-radius: var(--colonia-radius);
	padding: 1em;
	margin: 1em 0;
}

.colonia-note {
	font-size: 0.85em;
	color: #777;
	background: #f7f8fa;
	padding: 0.6em 0.85em;
	border-radius: 6px;
}

/* Listas y tablas */
.colonia-authorized-list {
	list-style: none;
	margin: 0 0 1em;
	padding: 0;
}

.colonia-authorized-item {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75em;
	padding: 0.6em 0;
	border-bottom: 1px solid var(--colonia-border);
}

.colonia-authorized-info {
	flex: 1 1 200px;
}

.colonia-authorized-thumbs a {
	margin-right: 0.5em;
	font-size: 0.85em;
}

.colonia-table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 1em;
	font-size: 0.9em;
}

.colonia-table th,
.colonia-table td {
	text-align: left;
	padding: 0.45em 0.6em;
	border-bottom: 1px solid var(--colonia-border);
}

.colonia-inline-form {
	display: inline;
	margin: 0;
}

.colonia-del {
	background: #fce8e6 !important;
	color: #b32d2e !important;
	border-color: #f1b0ad !important;
}

/* Bloques de novedades / contacto */
.colonia-news-block,
.colonia-contact-block {
	margin-top: 2em;
	padding-top: 1em;
	border-top: 2px solid var(--colonia-border);
}

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

.colonia-news li {
	display: flex;
	justify-content: space-between;
	gap: 1em;
	padding: 0.5em 0;
	border-bottom: 1px solid var(--colonia-border);
}

.colonia-news time {
	color: #888;
	font-size: 0.85em;
	white-space: nowrap;
}

/* ----------------------------------------------------------------------
 * Estados controlados por JS (mejora progresiva)
 * -------------------------------------------------------------------- */
.colonia-chip.is-active {
	background: var(--colonia-accent);
	color: #fff;
	border-color: var(--colonia-accent);
}

.colonia-chip.is-active small {
	color: rgba( 255, 255, 255, 0.85 );
}

.colonia-card.is-active {
	box-shadow: 0 0 0 2px var(--colonia-accent);
}

.colonia-card {
	scroll-margin-top: 1.5em;
	transition: box-shadow 0.2s ease;
}

button.is-loading,
.colonia-btn.is-loading {
	opacity: 0.6;
	cursor: progress;
}

.colonia-file-name {
	display: inline-block;
	margin-left: 0.5em;
	font-size: 0.85em;
	color: #555;
	word-break: break-all;
}

@media ( prefers-reduced-motion: reduce ) {
	.colonia-card {
		transition: none;
	}
}

/* ===== v1.5.0: facturante, fotos, noticias, progreso ===== */

.colonia-facturante {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
	padding: 14px 16px;
	background: #fff;
	border: 1px solid #e6e6e6;
	border-radius: 12px;
	margin-bottom: 18px;
}
.colonia-facturante__avatar img,
.colonia-card__avatar img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border-radius: 50%;
	display: block;
}
.colonia-avatar-ph {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: #2271b1;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 26px;
	font-weight: 600;
}
.colonia-facturante__info { display: flex; flex-direction: column; gap: 2px; }
.colonia-facturante__info span { font-size: 13px; color: #555; }

.colonia-inline-form {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	margin: 8px 0;
}
.colonia-inline-form--photo { margin-bottom: 14px; }
.colonia-photo-label { font-size: 13px; color: #444; }

.colonia-card__head {
	display: flex;
	align-items: center;
	gap: 14px;
}
.colonia-card__title h3 { margin: 0; }
.colonia-card__title .colonia-order { font-size: 13px; color: #666; }

/* Noticias */
.colonia-news-block {
	background: #f0f6fc;
	border: 1px solid #c5d9ed;
	border-radius: 12px;
	padding: 14px 18px;
	margin-bottom: 20px;
}
.colonia-news-block h3 { margin-top: 0; }
.colonia-news { list-style: none; margin: 0; padding: 0; }
.colonia-news-item {
	padding: 10px 12px;
	border-radius: 8px;
	background: #fff;
	margin-bottom: 8px;
	border-left: 4px solid #2271b1;
}
.colonia-news-item--urgent {
	border-left-color: #b32d2e;
	background: #fcf0f1;
}
.colonia-news-item time { font-size: 12px; color: #777; }

/* Badges */
.colonia-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
}
.colonia-badge--ok { background: #edfaef; color: #1a7f37; }
.colonia-badge--danger { background: #fcf0f1; color: #b32d2e; }
.colonia-badge--warn { background: #fcf9e8; color: #8a6d00; }
.colonia-badge--muted { background: #f0f0f1; color: #555; }

.colonia-pill {
	display: inline-block;
	padding: 2px 8px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
}
.colonia-pill--alto { background: #fcf0f1; color: #b32d2e; }

/* Barra de progreso */
.colonia-progress { margin: 12px 0 16px; }
.colonia-progress__bar {
	height: 10px;
	background: #e8e8e8;
	border-radius: 999px;
	overflow: hidden;
}
.colonia-progress__bar span {
	display: block;
	height: 100%;
	background: #1a7f37;
	transition: width .4s ease;
}
.colonia-progress__label { font-size: 12px; color: #555; margin-top: 4px; }
.colonia-progress__steps {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 8px 0 0;
	padding: 0;
	font-size: 12px;
}
.colonia-progress__steps li { color: #888; }
.colonia-progress__steps li.is-done { color: #1a7f37; }

@media ( max-width: 600px ) {
	.colonia-facturante { flex-direction: column; align-items: flex-start; }
	.colonia-card__head { flex-direction: row; }
}

@media ( prefers-reduced-motion: reduce ) {
	.colonia-progress__bar span { transition: none; }
}
