/* ==========================================================================
   CPS — Footer nativo (estilos). Replica el footer original.
   Usa las variables de color definidas en header.css (:root).
   ========================================================================== */

.cps-footer {
	background: var(--cps-bg, #0d0d0d);
	color: var(--cps-text, #fff);
	/*margin-top: 60px;*/
	font-size: 15px;
}

/* Contenedor común centrado */
.cps-foot-newsletter__inner,
.cps-foot-brandbar__inner,
.cps-foot-cols__inner,
.cps-foot-bottom__inner {
	max-width: var(--cps-maxw, 1860px);
	margin-inline: auto;
	padding-inline: 32px;
}

/* ============================ 1) NEWSLETTER ============================ */
.cps-foot-newsletter {
	border-bottom: 1px solid #222;
}
.cps-foot-newsletter__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: center;
	padding-block: 36px;
}
.cps-foot-newsletter__title {
	margin: 0 0 6px;
	font-weight: 400;
	line-height: 1.35;
}
.cps-foot-newsletter__q {
	display: block;
	font-size: 22px;
	margin-bottom: 6px;
}
.cps-foot-newsletter__title strong { color: var(--cps-accent, #f4d300); }
.cps-foot-newsletter__desc {
	margin: 0;
	color: var(--cps-muted, #b8b8b8);
	line-height: 1.6;
}
.cps-foot-newsletter__form { min-width: 0; }

/* ========================= 2) LOGO + SOCIALES ========================= */
.cps-foot-brandbar {
	border-bottom: 1px solid #222;
}
.cps-foot-brandbar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding-block: 28px;
}
.cps-foot-logo__img {
	display: block;
	height: 64px;
	width: auto;
}
.cps-foot-social {
	list-style: none;
	display: flex;
	gap: 14px;
	margin: 0;
	padding: 0;
}
.cps-foot-social a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid #555;
	border-radius: 50%;
	color: var(--cps-text, #fff);
	transition: border-color .15s ease, background .15s ease;
}
.cps-foot-social a:hover {
	border-color: var(--cps-accent, #f4d300);
	background: rgba(244,211,0,.08);
}
.cps-foot-social__icon {
	width: 18px;
	height: 18px;
	object-fit: contain;
}
/* Si el icono social es un placeholder (falta ID), que no desborde el círculo */
.cps-foot-social .cps-img-placeholder {
	min-width: 0;
	min-height: 0;
	width: 100%;
	height: 100%;
	border: 0;
	font-size: 0;            /* oculta el texto largo del placeholder */
	background: rgba(255,255,255,.12);
	border-radius: 50%;
}

/* ========================= 3) COLUMNAS ENLACES ======================== */
.cps-foot-cols__inner {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	gap: 32px;
	padding-block: 44px;
}
.cps-foot-col__title {
	font-size: 16px;
	font-weight: 700;
	margin: 0 0 16px;
	color: var(--cps-text, #fff);
}
.cps-foot-col__list {
	list-style: none;
	margin: 0;
	padding: 0;
	line-height: 2;
}
.cps-foot-col__list a {
	color: var(--cps-muted, #b8b8b8);
	text-decoration: none;
	font-size: 15px;
	transition: color .15s ease;
}
.cps-foot-col__list a:hover { color: var(--cps-accent, #f4d300); }

/* La columna Maquinaria es larga: dos sub-columnas como en el original */
.cps-foot-col:first-child .cps-foot-col__list {
	columns: 2;
	column-gap: 32px;
}

/* ====================== 4) BARRA INFERIOR (LEGAL) ===================== */
.cps-foot-bottom {
	border-top: 1px solid #222;
}
.cps-foot-bottom__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
	padding-block: 28px;
	text-align: center;
}

/* Idioma GTranslate */
.cps-foot-lang { color: var(--cps-muted, #b8b8b8); }
.cps-foot-lang a { color: var(--cps-muted, #b8b8b8); text-decoration: none; margin: 0 4px; }
.cps-foot-lang a:hover,
.cps-foot-lang .gt-current-lang { color: var(--cps-text, #fff); font-weight: 700; }

/* PRTR / Next Generation EU */
.cps-foot-prtr__img {
	display: block;
	max-width: 360px;
	width: 100%;
	height: auto;
}

/* Sellos de pago */
.cps-foot-pay {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 22px;
	flex-wrap: wrap;
}
.cps-foot-pay__img {
	height: 38px;
	width: auto;
}
.cps-foot-pay__img--sequra { height: 30px; }

/* Menú legal */
.cps-foot-legal__list {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px 22px;
	margin: 0;
	padding: 0;
}
.cps-foot-legal__list a {
	color: var(--cps-muted, #b8b8b8);
	text-decoration: none;
	font-size: 14px;
}
.cps-foot-legal__list a:hover { color: var(--cps-accent, #f4d300); }

/* Copyright */
.cps-foot-copy {
	margin: 0;
	color: var(--cps-muted, #b8b8b8);
	font-size: 13px;
}

/* Placeholder de imagen mientras falta el ID en la Mediateca */
.cps-img-placeholder {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	min-height: 32px;
	padding: 4px 10px;
	border: 1px dashed #666;
	border-radius: 6px;
	color: #888;
	font-size: 11px;
	text-align: center;
	background: rgba(255,255,255,.03);
}

/* ===================== 5) BOTONES FLOTANTES FIJOS ===================== */
.cps-floating {
	position: fixed;
	right: 18px;
	bottom: 18px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	z-index: 900;
}
.cps-floating__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	border-radius: 40px;
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	color: #fff;
	box-shadow: 0 4px 12px rgba(0,0,0,.3);
	transition: transform .15s ease, filter .15s ease;
}
.cps-floating__btn:hover { transform: translateY(-2px); filter: brightness(1.05); }
.cps-floating__btn--wa   { background: #25d366; color: #073d20; }
.cps-floating__btn--call { background: var(--cps-accent, #f4d300); color: var(--cps-accent-ink, #0d0d0d); }

/* ============================== RESPONSIVE ============================= */
@media (max-width: 992px) {
	.cps-foot-newsletter__inner,
	.cps-foot-brandbar__inner,
	.cps-foot-cols__inner,
	.cps-foot-bottom__inner {
		padding-inline: 20px;
	}
	.cps-foot-cols__inner { grid-template-columns: 1fr 1fr; gap: 28px 24px; }
}
@media (max-width: 768px) {
	.cps-foot-newsletter__inner { grid-template-columns: 1fr; gap: 20px; }
	.cps-foot-brandbar__inner { flex-direction: column; align-items: center; text-align: center; }
	.cps-foot-cols__inner { grid-template-columns: 1fr; }
	.cps-foot-col:first-child .cps-foot-col__list { columns: 1; }
	.cps-floating__label { display: none; }   /* en móvil solo el botón compacto */
	.cps-floating__btn { padding: 12px; }
}