/* =========================================================
   CMP — banner inferior + modal de preferencias
   Estilo iOS: cristal con backdrop-filter, bordes redondeados.
   ========================================================= */

.cg-cmp {
	position: fixed;
	left: 16px; right: 16px; bottom: 16px;
	z-index: 100;
	background: rgba(255, 255, 255, 0.92);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	border: 1px solid rgba(255, 255, 255, 0.6);
	border-radius: 18px;
	padding: 16px 20px;
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.18);
	max-width: 1100px;
	margin: 0 auto;
	transform: translateY(8px);
	opacity: 0;
	animation: cgCmpIn 0.35s ease-out 0.4s forwards;
}
[data-theme="dark"] .cg-cmp {
	background: rgba(20, 22, 27, 0.88);
	border-color: rgba(255, 255, 255, 0.08);
}
@keyframes cgCmpIn {
	to { transform: translateY(0); opacity: 1; }
}

.cg-cmp__inner {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 16px;
	align-items: center;
}
.cg-cmp__title {
	font-size: 1rem;
	margin: 0 0 4px;
	font-family: 'Playfair Display', Georgia, serif;
}
.cg-cmp__text { margin: 0; color: var(--text-muted); font-size: 0.92rem; line-height: 1.5; }
.cg-cmp__text a { color: var(--green); }
.cg-cmp__actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: flex-end;
}

@media (max-width: 720px) {
	.cg-cmp__inner { grid-template-columns: 1fr; }
	.cg-cmp__actions { justify-content: stretch; }
	.cg-cmp__actions .cg-btn { flex: 1 1 auto; }
}

/* ----- Modal de preferencias ----- */
.cg-cmp-modal {
	position: fixed; inset: 0; z-index: 200;
	display: flex; align-items: center; justify-content: center;
	padding: 16px;
}
.cg-cmp-modal[hidden] { display: none; }
.cg-cmp-modal__backdrop {
	position: absolute; inset: 0;
	background: rgba(15, 22, 30, 0.55);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
}
.cg-cmp-modal__content {
	position: relative;
	background: var(--surface);
	border-radius: 20px;
	box-shadow: 0 24px 60px rgba(0,0,0,0.35);
	max-width: 520px;
	width: 100%;
	max-height: 92vh;
	overflow: auto;
	display: flex; flex-direction: column;
}
.cg-cmp-modal__head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 20px 24px;
	border-bottom: 1px solid var(--border-soft);
}
.cg-cmp-modal__head h2 { margin: 0; font-family: 'Playfair Display', Georgia, serif; }
.cg-cmp-modal__close {
	background: var(--bg-soft);
	border: 0;
	width: 36px; height: 36px;
	border-radius: 999px;
	font-size: 22px;
	cursor: pointer;
	color: var(--text-strong);
}
.cg-cmp-modal__close:hover { background: color-mix(in srgb, var(--green) 15%, var(--bg-soft)); }
.cg-cmp-modal__body { padding: 20px 24px; display: grid; gap: 12px; }
.cg-cmp-row {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 12px;
	align-items: start;
	padding: 12px;
	background: var(--bg-soft);
	border-radius: 12px;
	border: 1px solid var(--border-soft);
	cursor: pointer;
}
.cg-cmp-row input { margin-top: 4px; }
.cg-cmp-row strong { display: block; color: var(--text-strong); margin-bottom: 2px; }
.cg-cmp-row small { color: var(--text-muted); line-height: 1.45; }
.cg-cmp-modal__foot {
	display: flex; gap: 8px; flex-wrap: wrap;
	padding: 16px 24px;
	border-top: 1px solid var(--border-soft);
	justify-content: flex-end;
}

.cg-cmp-relink { display: none !important; }
