:root {
	--acp-green: #52933d;
	--acp-yellow: #f2c83c;
	--acp-red: #d82f27;
	--acp-dark: #2b2b2b;
	--acp-soft: #f6f8f4;
	--acp-line: rgba(43, 43, 43, .12);
	--acp-heading: "Muring 01", Arial, sans-serif;
	--acp-body: "BD Megatoya", Arial, sans-serif;
}
.acp-page,
.acp-featured,
.acp-explorer,
.acp-lines,
.acp-stats,
.acp-territories,
.acp-gallery,
.acp-testimonials,
.acp-project-detail {
	color: var(--acp-dark);
	font-family: var(--acp-body);
}
.acp-shell,
.acp-project-detail {
	width: min(1180px, calc(100% - 40px));
	margin-inline: auto;
}
.acp-page h1,
.acp-page h2,
.acp-page h3,
.acp-featured h2,
.acp-explorer h2,
.acp-lines h2,
.acp-lines h3,
.acp-stats h2,
.acp-territories h2,
.acp-territories h3,
.acp-gallery h2,
.acp-testimonials h2,
.acp-project-detail h1,
.acp-project-detail h2,
.acp-project-detail h3 {
	font-family: var(--acp-heading);
	color: var(--acp-dark);
	line-height: 1.04;
	letter-spacing: -.02em;
	margin: 0;
}
.acp-eyebrow {
	color: var(--acp-green);
	font-weight: 700;
	margin: 0 0 12px;
}
.acp-section-head {
	margin: 0 0 24px;
}
.acp-section-head h2 {
	font-size: clamp(28px, 3vw, 44px);
}
.acp-hero {
	position: relative;
	min-height: 350px;
	display: grid;
	align-items: center;
	overflow: hidden;
	background:
		linear-gradient(90deg, rgba(9, 43, 30, .93), rgba(19, 74, 44, .72)),
		url("../images/proyectos/hero-proyectos.webp") center/cover;
}
.acp-hero::after {
	content: "";
	position: absolute;
	inset: auto -70px -120px auto;
	width: 320px;
	height: 320px;
	border-radius: 50%;
	border: 28px solid var(--acp-yellow);
	box-shadow: 26px 30px 0 var(--acp-red), -26px -12px 0 var(--acp-green);
	opacity: .9;
}
.acp-hero__inner {
	position: relative;
	z-index: 1;
	width: min(1180px, calc(100% - 40px));
	margin-inline: auto;
	color: #fff;
}
.acp-hero h1 {
	max-width: 760px;
	font-size: clamp(38px, 5vw, 74px);
	color: #fff;
}
.acp-hero p:not(.acp-eyebrow) {
	max-width: 660px;
	font-size: 18px;
	line-height: 1.65;
}
.acp-button,
.acp-load-more {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 44px;
	padding: 12px 22px;
	border-radius: 10px;
	border: 1px solid var(--acp-green);
	font-weight: 800;
	text-decoration: none;
	cursor: pointer;
	transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.acp-button:hover,
.acp-load-more:hover {
	transform: translateY(-2px);
}
.acp-button--primary,
.acp-load-more {
	background: var(--acp-green);
	color: #fff;
	box-shadow: 0 10px 24px rgba(82, 147, 61, .22);
}
.acp-button--ghost {
	background: #fff;
	color: var(--acp-green);
}
.acp-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 22px;
}
.acp-empty {
	border: 1px dashed rgba(82, 147, 61, .35);
	background: linear-gradient(180deg, #fff, var(--acp-soft));
	border-radius: 18px;
	padding: 34px;
	text-align: center;
}
.acp-empty h3 {
	font-size: clamp(24px, 3vw, 34px);
}
.acp-empty p {
	max-width: 680px;
	margin: 12px auto 0;
	line-height: 1.65;
	color: rgba(43, 43, 43, .76);
}
.acp-featured,
.acp-territories,
.acp-panel {
	background: #fff;
	border: 1px solid var(--acp-line);
	border-radius: 20px;
	box-shadow: 0 18px 45px rgba(18, 42, 27, .08);
}
.acp-featured {
	display: grid;
	grid-template-columns: minmax(260px, .92fr) 1.08fr;
	gap: 30px;
	padding: 20px;
	margin: 34px 0;
}
.acp-featured__media {
	position: relative;
	min-height: 290px;
	border-radius: 16px;
	overflow: hidden;
	background: var(--acp-soft);
}
.acp-featured__media img,
.acp-card__media img,
.acp-gallery img,
.acp-detail-hero img,
.acp-before-after img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.acp-featured__body {
	padding: 18px 8px 18px 0;
}
.acp-featured h2 {
	font-size: clamp(30px, 3.2vw, 48px);
}
.acp-featured p {
	line-height: 1.7;
	color: rgba(43, 43, 43, .78);
}
.acp-featured__facts {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
	margin-top: 18px;
}
.acp-featured__facts span,
.acp-card__meta span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: rgba(43, 43, 43, .75);
	font-size: 14px;
}
.acp-featured svg,
.acp-card svg,
.acp-stat svg,
.acp-line svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
}
.acp-pill {
	position: absolute;
	top: 14px;
	left: 14px;
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--acp-green);
	color: #fff;
	font-size: 12px;
	font-weight: 800;
}
.acp-explorer {
	margin: 34px 0;
}
.acp-filters {
	display: grid;
	grid-template-columns: 1.4fr repeat(5, 1fr) auto auto;
	gap: 12px;
	align-items: end;
	padding: 18px;
	border: 1px solid var(--acp-line);
	border-radius: 18px;
	background: #fff;
	box-shadow: 0 14px 36px rgba(18, 42, 27, .06);
}
.acp-filters label {
	display: grid;
	gap: 6px;
	font-size: 12px;
	font-weight: 800;
	color: rgba(43, 43, 43, .72);
}
.acp-filters input,
.acp-filters select {
	width: 100%;
	min-height: 44px;
	border: 1px solid var(--acp-line);
	border-radius: 10px;
	padding: 8px 12px;
	font: inherit;
	background: #fff;
}
.acp-grid,
.acp-lines__grid,
.acp-stats__grid,
.acp-testimonials__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	margin-top: 22px;
}
.acp-card,
.acp-line,
.acp-stat,
.acp-testimonial {
	background: #fff;
	border: 1px solid var(--acp-line);
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 12px 30px rgba(18, 42, 27, .06);
}
.acp-card__media {
	position: relative;
	display: block;
	aspect-ratio: 1.45 / 1;
	background: var(--acp-soft);
}
.acp-card__placeholder {
	display: grid;
	place-items: center;
	width: 100%;
	height: 100%;
	color: rgba(82, 147, 61, .45);
}
.acp-card__placeholder svg {
	width: 64px;
	height: 64px;
}
.acp-card__body {
	padding: 16px;
}
.acp-card h3 {
	font-size: 22px;
}
.acp-card p {
	color: rgba(43, 43, 43, .74);
	line-height: 1.55;
}
.acp-card__meta {
	display: grid;
	gap: 7px;
	margin: 14px 0;
}
.acp-link {
	color: var(--acp-green);
	font-weight: 800;
	text-decoration: none;
}
.acp-load-more {
	margin: 22px auto 0;
}
.acp-live {
	min-height: 1.4em;
	margin-top: 12px;
	color: rgba(43, 43, 43, .65);
}
.acp-explorer.is-loading .acp-grid {
	opacity: .55;
}
.acp-line,
.acp-stat,
.acp-testimonial {
	padding: 20px;
}
.acp-line__icon,
.acp-stat span {
	display: grid;
	place-items: center;
	width: 58px;
	height: 58px;
	border-radius: 18px;
	background: var(--acp-green);
	color: #fff;
	margin-bottom: 14px;
}
.acp-line:nth-child(2n) .acp-line__icon,
.acp-stat:nth-child(2n) span { background: var(--acp-yellow); }
.acp-line:nth-child(3n) .acp-line__icon,
.acp-stat:nth-child(3n) span { background: var(--acp-red); }
.acp-line h3 {
	font-size: 22px;
	margin-bottom: 10px;
}
.acp-line strong,
.acp-stat strong {
	display: block;
	font: 700 34px/1 var(--acp-heading);
	color: var(--acp-green);
}
.acp-stat {
	text-align: center;
}
.acp-stat span {
	margin-inline: auto;
}
.acp-territories {
	display: grid;
	grid-template-columns: .8fr 1.2fr;
	gap: 28px;
	padding: 26px;
	margin: 34px 0;
}
.acp-territories__list {
	display: grid;
	gap: 12px;
}
.acp-territories article {
	border: 1px solid var(--acp-line);
	border-radius: 14px;
	padding: 16px;
}
.acp-territories a {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 3px 12px;
	padding: 10px 0;
	color: inherit;
	text-decoration: none;
	border-top: 1px solid rgba(43, 43, 43, .08);
}
.acp-territories a span {
	color: rgba(43, 43, 43, .68);
}
.acp-territories em {
	align-self: center;
	padding: 4px 9px;
	border-radius: 999px;
	background: rgba(82, 147, 61, .12);
	color: var(--acp-green);
	font-style: normal;
	font-weight: 800;
}
.acp-gallery__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
}
.acp-gallery figure {
	position: relative;
	margin: 0;
	aspect-ratio: 1.2 / 1;
	border-radius: 16px;
	overflow: hidden;
}
.acp-gallery figcaption {
	position: absolute;
	inset: auto 10px 10px;
	padding: 6px 9px;
	border-radius: 8px;
	background: rgba(0, 0, 0, .48);
	color: #fff;
	font-size: 12px;
}
.acp-testimonial p {
	font-size: 18px;
	line-height: 1.65;
}
.acp-testimonial footer {
	color: rgba(43, 43, 43, .7);
}
.acp-breadcrumbs {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 24px 0;
	font-size: 14px;
}
.acp-breadcrumbs a {
	color: var(--acp-green);
	text-decoration: none;
}
.acp-detail-hero {
	display: grid;
	grid-template-columns: 1fr .82fr;
	gap: 34px;
	align-items: center;
	padding: 34px 0;
}
.acp-detail-hero h1 {
	font-size: clamp(40px, 5vw, 68px);
}
.acp-detail-hero figure {
	margin: 0;
	aspect-ratio: 1.4 / 1;
	border-radius: 22px;
	overflow: hidden;
	box-shadow: 0 22px 48px rgba(18, 42, 27, .12);
}
.acp-detail-grid {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 24px;
	align-items: start;
}
.acp-detail-content,
.acp-detail-side {
	display: grid;
	gap: 18px;
}
.acp-panel {
	padding: 24px;
}
.acp-panel h2 {
	font-size: 30px;
	margin-bottom: 14px;
}
.acp-panel h3 {
	font-size: 18px;
	margin-top: 14px;
}
.acp-panel p,
.acp-panel li,
.acp-detail-hero p {
	line-height: 1.68;
	color: rgba(43, 43, 43, .76);
}
.acp-panel dl {
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px;
	margin: 0;
}
.acp-panel dt {
	font-weight: 800;
}
.acp-panel dd {
	margin: 0 0 8px;
	color: rgba(43, 43, 43, .72);
}
.acp-progress {
	height: 12px;
	border-radius: 999px;
	background: rgba(82, 147, 61, .13);
	overflow: hidden;
}
.acp-progress span {
	display: block;
	height: 100%;
	background: var(--acp-green);
}
.acp-before-after > div {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}
.acp-before-after figure {
	margin: 0;
	border-radius: 16px;
	overflow: hidden;
}
.acp-detail-footer {
	margin: 26px 0 50px;
}
.acp-filters button:focus-visible,
.acp-button:focus-visible,
.acp-link:focus-visible,
.acp-load-more:focus-visible,
.acp-card a:focus-visible {
	outline: 3px solid rgba(242, 200, 60, .8);
	outline-offset: 3px;
}
@media (max-width: 1100px) {
	.acp-filters { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	.acp-featured__facts { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.acp-grid,
	.acp-lines__grid,
	.acp-stats__grid,
	.acp-testimonials__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.acp-territories,
	.acp-detail-hero,
	.acp-detail-grid { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
	.acp-shell,
	.acp-project-detail,
	.acp-hero__inner { width: min(100% - 28px, 520px); }
	.acp-hero { min-height: 430px; }
	.acp-hero::after { width: 210px; height: 210px; border-width: 18px; }
	.acp-featured,
	.acp-filters,
	.acp-grid,
	.acp-lines__grid,
	.acp-stats__grid,
	.acp-testimonials__grid,
	.acp-gallery__grid,
	.acp-before-after > div { grid-template-columns: 1fr; }
	.acp-featured { padding: 14px; }
	.acp-featured__body { padding: 4px; }
	.acp-featured__facts { grid-template-columns: 1fr; }
	.acp-filters .acp-button,
	.acp-actions .acp-button { width: 100%; }
	.acp-card h3 { font-size: 20px; }
	.acp-panel { padding: 18px; }
}
