/* ══════════════════════════════════════════
   HERO BUTTONS
   ══════════════════════════════════════════ */

.hero-btn-primary
{
	background: var(--rojo-mibsa);
	color: var(--blanco);
	padding: 0.62rem 1.6rem;
	border-radius: 8px;
	font-size: 0.8rem;
	font-weight: 600;
	transition: all 0.3s;
	box-shadow: 0 4px 16px rgba(229, 27, 66, 0.22)
}

.hero-btn-primary:hover
{
	background: var(--rojo-mibsa-hover);
	transform: translateY(-2px)
}

.hero-btn-secondary
{
	background: var(--rojo-mibsa);
	color: var(--blanco);
	padding: 0.62rem 1.6rem;
	border-radius: 8px;
	font-size: 0.8rem;
	font-weight: 600;
	transition: all 0.3s;
	box-shadow: 0 4px 16px rgba(229, 27, 66, 0.22)
}

.hero-btn-secondary:hover
{
	background: var(--rojo-mibsa-hover);
	transform: translateY(-2px)
}

/* ══════════════════════════════════════════
   PROJECTS
   ══════════════════════════════════════════ */

.projects
{
	background: var(--bg2)
}

.projects-header
{
	margin-bottom: 1rem
}

.project-filters
{
	display: flex;
	flex-wrap: wrap;
	gap: 0.3rem;
	margin-bottom: 1.5rem
}

.pf-btn
{
	padding: 0.35rem 0.85rem;
	border-radius: 100px;
	font-size: 0.67rem;
	font-weight: 500;
	border: 1px solid rgba(0, 0, 0, 0.1);
	color: var(--texto-dim);
	cursor: pointer;
	transition: all 0.25s;
	background: var(--bg2)
}

.pf-btn:hover
{
	background: var(--rojo-mibsa-soft);
	border-color: var(--rojo-mibsa-border);
	color: var(--rojo-mibsa)
}

.pf-btn.active
{
	background: var(--rojo-mibsa);
	color: var(--blanco);
	border-color: var(--rojo-mibsa)
}

.projects-grid
{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0.9rem
}

/* Layout especial para home (3 proyectos + botón) */
.projects-grid-home
{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0.9rem;
}

.projects-grid-home .project-card:nth-child(1)
{
	grid-column: 1;
	grid-row: 1;
	aspect-ratio: 4/3;
}

.projects-grid-home .project-card:nth-child(2)
{
	grid-column: 2 / 4;
	grid-row: 1;
	aspect-ratio: 8/3;
}

.projects-grid-home .project-card:nth-child(3)
{
	grid-column: 1 / 3;
	grid-row: 2;
	aspect-ratio: 8/3;
}

.projects-grid-home .project-more-btn
{
	grid-column: 3;
	grid-row: 2;
	aspect-ratio: 4/3;
}

.project-card
{
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 4/3;
	transition: all 0.35s;
	cursor: pointer;
	display: block
}

.project-card.hidden
{
	display: none
}

.project-card img
{
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s
}

.project-card:hover img
{
	transform: scale(1.05)
}

.project-overlay
{
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(27, 31, 43, 0.88) 0%, rgba(27, 31, 43, 0.22) 50%, rgba(27, 31, 43, 0.04) 100%)
}

.project-info
{
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 1.2rem;
	z-index: 1
}

.project-info h3
{
	font-family: 'DM Sans', sans-serif;
	font-size: 1.1rem;
	color: var(--blanco);
	margin-bottom: 0.15rem;
	font-weight: 600;
	line-height: 1.2;
}

.project-info p
{
	/* font-size: 0.65rem; */
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.7)
}

.pcats
{
	display: flex;
	gap: 0.2rem;
	flex-wrap: wrap;
	margin-top: 0.35rem;
	max-height: 33px;
	overflow: hidden;
}

.pcats span
{
	display: inline-block;
	background: rgba(255, 255, 255, 0.25);
	color: #fff;
	padding: 0.4rem 0.9rem;
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 500;
	backdrop-filter: blur(4px);
	border: 0.5px solid rgba(255, 255, 255, 0.3);
	white-space: nowrap;
}

.project-more-btn
{
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--radius-lg);
	/* aspect-ratio: 4/3; */
	border: 2px dashed rgba(0, 0, 0, 0.1);
	color: var(--texto-dim);
	font-size: 2rem;
	transition: all 0.3s;
	background: var(--bg)
}

.project-more-btn:hover
{
	border-color: var(--rojo-mibsa);
	color: var(--rojo-mibsa);
	background: var(--rojo-mibsa-soft)
}


/* ══════════════════════════════════════════
   SERVICE DETAIL
   ══════════════════════════════════════════ */

.service-detail-grid
{
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2.5rem;
	align-items: start;
	padding: 2.5rem 0
}

.service-detail-img
{
	border-radius: var(--radius-lg);
	overflow: hidden
}

.service-detail-img img
{
	width: 100%;
	height: 360px;
	object-fit: cover
}

.service-detail-content h2
{
	font-family: 'Instrument Serif', serif;
	font-size: clamp(1.5rem, 2.5vw, 2.2rem);
	color: var(--texto);
	margin-bottom: 0.8rem;
	font-weight: 400
}

.service-detail-content p
{
	font-size: 0.88rem;
	color: var(--texto-dim);
	line-height: 1.8
}


/* Actualizar .project-info h3 para una sola línea (project-title) */
.project-info h3
{
	max-height: 26px;
	overflow-y: hidden;
}

/* ══════════════════════════════════════════
   RESPONSIVE (servicios)
   ══════════════════════════════════════════ */

@media (max-width: 1024px)
{
	.projects-grid
	{
		grid-template-columns: repeat(2, 1fr)
	}

	.service-detail-grid
	{
		grid-template-columns: 1fr
	}
}

@media (max-width: 900px)
{
	.projects-grid
	{
		grid-template-columns: 1fr
	}
}

@media (max-width: 768px)
{
	.projects-grid
	{
		grid-template-columns: 1fr
	}
}

@media (max-width: 480px)
{
	.projects-grid
	{
		grid-template-columns: 1fr;
	}
}
