/**
 * Estilos para el acordeón de fases de barrio
 * Shortcode [barrio_fases]
 *
 * @package MadridCrece
 */

/* ============================================
   ACORDEÓN DE FASES DE BARRIO
   ============================================ */

.mc-barrio-fases-accordion {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.mc-fase-item {
	background: #A3A3A3;
	border-radius: 20px;
	margin-bottom: 16px;
	overflow: hidden;
	transition: background-color 0.9s cubic-bezier(0.68, -0.55, 0.265, 1.55), box-shadow 0.9s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

.mc-fase-item[open] {
	background: #252525;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.mc-fase-header {
	cursor: pointer;
	padding: 0;
	margin: 0;
	list-style: none;
}

/* Acordeón no expandible (post_id pasado o fase sin repeater) */
.mc-barrio-fases-accordion--no-expandible .mc-fase-header,
.mc-fase-item--no-expandible .mc-fase-header {
	cursor: default;
	pointer-events: none; /* Bloquear clics para que no se abra el details */
}

.mc-fase-header::-webkit-details-marker {
	display: none;
}

.mc-fase-header-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px;
	gap: 16px;
}

.mc-fase-title {
	font-size: 18px;
	font-weight: 600;
	color: #ffffff;
	flex-shrink: 0;
	width: 150px; /* Ancho fijo para que todos los títulos ocupen el mismo espacio */
	min-width: 150px;
}

.mc-fase-progress {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-shrink: 0;
}

.mc-fase-progress-bar {
	width: 100px; /* Ancho fijo igual para todas las barras */
	height: 8px;
	background: #ffffff;
	border-radius: 4px;
	overflow: hidden;
	position: relative;
	flex-shrink: 0;
}

.mc-fase-progress-fill {
	height: 100%;
	background: #3986df;
	border-radius: 4px;
	transition: width 0.3s ease;
}

.mc-fase-porcentaje {
	font-size: 16px;
	font-weight: 600;
	color: #ffffff;
	min-width: 45px;
	text-align: right;
}

.mc-fase-toggle {
	background: #252525 !important;
	border: none;
	border-radius: 50%;
	width: 40px;
	height: 40px;
	min-width: 40px;
	min-height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	flex-shrink: 0;
	transition: transform 0.8s cubic-bezier(0.68, -0.55, 0.265, 1.55), background-color 0.7s cubic-bezier(0.19, 1, 0.22, 1);
	color: #ffffff;
	padding: 0;
	position: relative;
	overflow: visible;
}

.mc-fase-toggle:hover {
	background: #1a1a1a;
	transform: scale(1.02);
}

/* Animación de rotación del botón cuando se abre */
.mc-fase-item[open] .mc-fase-toggle {
	transform: rotate(180deg);
}

.mc-fase-item[open] .mc-fase-toggle:hover {
	transform: rotate(180deg) scale(1.03);
}

.mc-fase-toggle-icon {
	width: 32px;
	height: 32px;
	min-width: 32px;
	min-height: 32px;
	flex-shrink: 0;
	position: relative;
	z-index: 10;
	object-fit: contain;
	transition: opacity 0.7s cubic-bezier(0.19, 1, 0.22, 1), transform 0.7s cubic-bezier(0.19, 1, 0.22, 1);
	max-width: 100%;
	max-height: 100%;
	opacity: 1;
	visibility: visible;
}

/* Icono para abrir (visible cuando está cerrado) */
.mc-fase-item:not([open]) .mc-fase-toggle-icon-open {
	display: block !important;
	opacity: 1;
	transform: scale(1) rotate(0deg);
	transition: opacity 0.7s cubic-bezier(0.19, 1, 0.22, 1), transform 0.7s cubic-bezier(0.19, 1, 0.22, 1);
}

.mc-fase-item:not([open]) .mc-fase-toggle-icon-close {
	display: none !important;
	opacity: 0;
	transform: scale(0.95) rotate(-30deg);
	transition: opacity 0.7s cubic-bezier(0.19, 1, 0.22, 1), transform 0.7s cubic-bezier(0.19, 1, 0.22, 1);
}

/* Icono para cerrar (visible cuando está abierto) */
.mc-fase-item[open] .mc-fase-toggle-icon-open {
	display: none !important;
	opacity: 0;
	transform: scale(0.95) rotate(30deg);
	transition: opacity 0.7s cubic-bezier(0.19, 1, 0.22, 1), transform 0.7s cubic-bezier(0.19, 1, 0.22, 1);
}

.mc-fase-item[open] .mc-fase-toggle-icon-close {
	display: block !important;
	opacity: 1;
	transform: scale(1) rotate(0deg);
	transition: opacity 0.7s cubic-bezier(0.19, 1, 0.22, 1), transform 0.7s cubic-bezier(0.19, 1, 0.22, 1);
}

.mc-fase-content {
	padding: 0 24px 24px 24px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	margin-top: 0;
	overflow: hidden;
	/* Transición con efecto elástico - duración más rápida */
	transition: opacity 0.9s cubic-bezier(0.68, -0.55, 0.265, 1.55),
	            transform 0.9s cubic-bezier(0.68, -0.55, 0.265, 1.55),
	            padding-top 0.9s cubic-bezier(0.68, -0.55, 0.265, 1.55),
	            padding-bottom 0.9s cubic-bezier(0.68, -0.55, 0.265, 1.55);
	opacity: 0;
	/* Movimiento muy sutil - solo 3px */
	transform: translateY(-3px);
	padding-top: 0;
	padding-bottom: 0;
}

/* Estado abierto */
.mc-fase-item[open] .mc-fase-content {
	opacity: 1;
	transform: translateY(0);
	padding-top: 0;
	padding-bottom: 24px;
}

/* Animación con efecto elástico más pronunciado al abrir - más rápida */
.mc-fase-item.mc-fase-opening .mc-fase-content {
	animation: slideDownContentElastic 1s cubic-bezier(0.68, -0.55, 0.265, 1.55) forwards;
}

/* Animación suave al cerrar */
.mc-fase-item.mc-fase-closing .mc-fase-content {
	animation: slideUpContent 0.8s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

@keyframes slideDownContentElastic {
	0% {
		opacity: 0;
		transform: translateY(-3px);
		max-height: 0;
	}
	50% {
		opacity: 0.7;
		transform: translateY(4px); /* Rebote más pronunciado hacia abajo */
	}
	70% {
		opacity: 0.9;
		transform: translateY(-2px); /* Rebote más pronunciado hacia arriba */
	}
	85% {
		opacity: 0.98;
		transform: translateY(1px); /* Segundo rebote sutil hacia abajo */
	}
	100% {
		opacity: 1;
		transform: translateY(0);
		max-height: 2000px;
	}
}

@keyframes slideUpContent {
	from {
		opacity: 1;
		transform: translateY(0);
		max-height: 2000px;
	}
	to {
		opacity: 0;
		/* Movimiento muy sutil - solo 3px */
		transform: translateY(-3px);
		max-height: 0;
	}
}

.mc-fase-items {
	list-style: none;
	padding: 0;
	margin: 16px 0 0 0;
	/* Animación con efecto elástico más pronunciado y delay reducido */
	animation: fadeInItemsElastic 0.9s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0.2s both;
}

@keyframes fadeInItemsElastic {
	0% {
		opacity: 0;
		transform: translateY(-2px);
	}
	50% {
		opacity: 0.6;
		transform: translateY(3px); /* Rebote más pronunciado */
	}
	70% {
		opacity: 0.85;
		transform: translateY(-1.5px); /* Rebote más pronunciado */
	}
	85% {
		opacity: 0.95;
		transform: translateY(0.5px); /* Segundo rebote sutil */
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

.mc-fase-item-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 8px 0;
	border-bottom: 1px solid #ffffff4f;
	gap: 16px;
}

.mc-fase-item-row:last-child {
	border-bottom: none;
}

.mc-fase-item-numero {
	font-size: 16px;
	font-weight: 600;
	color: #ffffff;
	min-width: 24px;
	text-align: left;
	flex-shrink: 0;
}

.mc-fase-item-texto {
	font-size: 16px;
	color: #ffffff;
	flex: 1;
	line-height: 1.5;
	word-wrap: break-word;
}

.mc-fase-item-icons {
	display: flex;
	align-items: center;
	gap: 12px;
}

.mc-fase-icon-check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	flex-shrink: 0;
}

.mc-fase-icon-check img {
	width: 24px;
	height: 24px;
	object-fit: contain;
	display: block;
}

.mc-fase-icon-download {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	text-decoration: none;
	transition: opacity 0.2s ease;
	width: 24px;
	height: 24px;
	flex-shrink: 0;
}

.mc-fase-icon-download:hover {
	opacity: 0.8;
}

.mc-fase-icon-download img {
	width: 24px;
	height: 24px;
	object-fit: contain;
	display: block;
	transition: transform 0.2s ease;
}

.mc-fase-icon-download:hover img {
	transform: scale(1.1);
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 768px) {
	.mc-fase-header-content {
		flex-wrap: wrap;
		padding: 16px;
	}

	.mc-fase-title {
		width: 120px; /* Ancho fijo más pequeño en móviles */
		min-width: 120px;
		margin-bottom: 12px;
	}

	.mc-fase-progress {
		flex-shrink: 0;
	}

	.mc-fase-progress-bar {
		width: 150px; /* Ancho fijo más pequeño en móviles */
	}

	.mc-fase-toggle {
		width: 36px;
		height: 36px;
	}

	.mc-fase-toggle-icon {
		width: 28px;
		height: 28px;
		min-width: 28px;
		min-height: 28px;
	}

	.mc-fase-toggle-icon {
		width: 28px;
		height: 28px;
		min-width: 28px;
		min-height: 28px;
	}

	.mc-fase-content {
		padding: 0 16px 16px 16px;
	}

	.mc-fase-item-row {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
	}

	.mc-fase-item-icons {
		align-self: flex-end;
	}
}

/* ============================================
   ACCESIBILIDAD
   ============================================ */

@media (prefers-reduced-motion: reduce) {
	.mc-fase-item,
	.mc-fase-progress-fill,
	.mc-fase-toggle,
	.mc-fase-toggle svg {
		transition: none;
	}
}
