/**
 * Homepage sections — conversion layout, responsive, aligned buttons.
 * Mobile-first; touch targets and spacing via design tokens.
 */

/* Front page: full-width content, no sidebar */
.gp-front-page-body .ast-container {
	max-width: none;
	width: 100%;
	padding: 0;
}

.gp-front-page {
	width: 100%;
	max-width: none;
	padding: 0;
}

/* Mobile: comfortable section padding and no overflow */
@media (max-width: 47.9375rem) {
	.gp-section {
		padding-block: clamp(2rem, 6vw, 3rem);
	}
}

/* Hero */
.gp-hero .gp-container {
	display: grid;
	gap: var(--gp-space-2xl);
	align-items: center;
}

@media (min-width: 48rem) {
	.gp-hero .gp-container {
		grid-template-columns: 1fr 1fr;
	}
}

.gp-hero__content {
	max-width: 32em;
}

.gp-hero__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	gap: var(--gp-space-md);
	margin-top: 0;
}

.gp-hero__actions .gp-btn {
	flex-shrink: 0;
}

/* Mobile: stack hero buttons for easy tap, no horizontal scroll */
@media (max-width: 30rem) {
	.gp-hero__actions {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
	}
	.gp-hero__actions .gp-btn {
		width: 100%;
		min-width: 0;
	}
}

@media (min-width: 30.0625rem) and (max-width: 40rem) {
	.gp-hero__actions {
		flex-wrap: nowrap;
	}
}

@media (min-width: 40.0625rem) {
	.gp-hero__actions {
		flex-wrap: nowrap;
	}
}

.gp-hero__visual {
	min-height: 10rem;
}

@media (min-width: 36rem) {
	.gp-hero__visual {
		min-height: 12rem;
	}
}

.gp-hero__visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Trust bar */
.gp-trust__list {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gp-space-xl);
	list-style: none;
	margin: 0;
	padding: 0;
	text-align: center;
}

@media (min-width: 25rem) {
	.gp-trust__list {
		grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr));
	}
}

.gp-trust__icon {
	display: block;
	margin-bottom: var(--gp-space-sm);
	color: var(--gp-color-brand);
}

.gp-trust__value {
	display: block;
	font-size: var(--gp-font-size-2xl);
	font-weight: 700;
	color: var(--gp-color-brand);
	margin-bottom: var(--gp-space-xs);
}

.gp-trust__label {
	margin: 0;
}

/* How it works */
.gp-how__list {
	display: grid;
	gap: var(--gp-space-lg);
	list-style: none;
	margin: 0;
	padding: 0;
	counter-reset: step;
}

@media (min-width: 40rem) {
	.gp-how__list {
		grid-template-columns: repeat(3, 1fr);
	}
}

.gp-how__item {
	position: relative;
	padding: var(--gp-space-lg) var(--gp-space-lg) var(--gp-space-lg) 4rem;
	min-height: 5rem;
}

@media (max-width: 39.9375rem) {
	.gp-how__list {
		grid-template-columns: 1fr;
	}
}

.gp-how__step,
.gp-how__icon {
	position: absolute;
	left: var(--gp-space-lg);
	top: var(--gp-space-lg);
	width: 2rem;
	height: 2rem;
}

.gp-how__step {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--gp-color-brand);
	color: var(--gp-button-text);
	font-weight: 700;
	font-size: var(--gp-font-size-sm);
	border-radius: var(--gp-radius-full);
}

.gp-how__icon {
	display: block;
	color: var(--gp-color-brand);
}

.gp-how__item h3 {
	margin-top: 0;
}

/* Benefits grid */
.gp-benefits__list {
	display: grid;
	gap: var(--gp-space-md);
	grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
	list-style: none;
	margin: 0;
	padding: 0;
}

.gp-benefits__item {
	display: flex;
	align-items: center;
	gap: var(--gp-space-sm);
	padding: var(--gp-space-md);
}

.gp-benefits__icon {
	flex-shrink: 0;
	color: var(--gp-color-brand);
}

/* Testimonials */
.gp-testimonials__list {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gp-space-lg);
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 36rem) {
	.gp-testimonials__list {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 55rem) {
	.gp-testimonials__list {
		grid-template-columns: repeat(3, 1fr);
	}
}

.gp-testimonials__quote {
	margin: 0;
}

.gp-testimonials__quote footer {
	margin-top: var(--gp-space-md);
}

.gp-testimonials__author {
	font-style: normal;
	font-weight: 600;
	color: var(--gp-color-text);
}

.gp-testimonials__role {
	display: block;
	margin-top: var(--gp-space-xs);
}

/* CTA block & final CTA */
.gp-cta-block__inner,
.gp-final-cta__inner {
	text-align: center;
	max-width: 36em;
	margin-inline: auto;
	padding-inline: var(--gp-container-padding);
}

.gp-cta-block__icon,
.gp-final-cta__icon {
	display: block;
	margin-bottom: var(--gp-space-md);
	color: var(--gp-color-brand);
}

/* CTA blocks use .gp-section-actions for aligned buttons */

/* FAQ */
.gp-faq__list {
	margin: 0;
	padding: 0;
	max-width: 40rem;
}

.gp-faq__item {
	border-bottom: 1px solid var(--gp-color-border);
	padding: var(--gp-space-md) 0;
}

.gp-faq__item:first-child {
	padding-top: 0;
}

.gp-faq__q {
	font-weight: 600;
	font-size: var(--gp-font-size-base);
	margin: 0 0 var(--gp-space-xs);
	color: var(--gp-color-text);
}

.gp-faq__a {
	margin: 0;
}

/* --- USP section --- */
.gp-usp__header {
	margin-bottom: var(--gp-space-2xl);
	max-width: 40em;
}

.gp-usp__lead {
	margin-bottom: 0;
}

.gp-usp__list {
	display: grid;
	gap: var(--gp-space-lg);
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 36rem) {
	.gp-usp__list {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 60rem) {
	.gp-usp__list {
		grid-template-columns: repeat(3, 1fr);
	}
}

.gp-usp__item {
	display: flex;
	flex-direction: column;
}

.gp-usp__item .gp-heading-card {
	margin-bottom: var(--gp-space-xs);
}

.gp-usp__icon {
	display: block;
	margin-bottom: var(--gp-space-sm);
	color: var(--gp-color-brand);
}

.gp-usp__desc {
	margin: 0;
	flex: 1;
}

/* --- Owner: Get projections & contracts + Request proposal --- */
.gp-owner-get-more__header {
	margin-bottom: var(--gp-space-2xl);
	max-width: 40em;
}

.gp-owner-get-more__grid {
	display: grid;
	gap: var(--gp-space-lg);
	grid-template-columns: 1fr;
}

@media (min-width: 40rem) {
	.gp-owner-get-more__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 55rem) {
	.gp-owner-get-more__grid {
		grid-template-columns: 1fr 1fr 1fr;
		grid-template-rows: auto auto;
	}

	.gp-owner-get-more__cta-cell {
		grid-column: span 2;
	}
}

.gp-owner-get-more__item,
.gp-owner-get-more__cta {
	display: flex;
	flex-direction: column;
}

.gp-owner-get-more__icon {
	display: block;
	margin-bottom: var(--gp-space-md);
	color: var(--gp-color-brand);
}

.gp-owner-get-more__cta .gp-btn {
	margin-top: auto;
	padding-top: var(--gp-space-md);
}

/* For property managers (20% strip) */
.gp-for-managers {
	background: var(--gp-color-bg-alt);
	border-top: 1px solid var(--gp-color-border);
}

.gp-for-managers__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--gp-space-md);
	justify-content: center;
	text-align: center;
}

@media (max-width: 25rem) {
	.gp-for-managers__inner .gp-btn {
		width: 100%;
	}
}

@media (min-width: 36rem) {
	.gp-for-managers__inner {
		justify-content: center;
		text-align: left;
	}
}

.gp-for-managers__icon {
	display: block;
	color: var(--gp-color-brand);
}

.gp-for-managers__text {
	margin: 0;
	flex: 1;
	min-width: 12rem;
}

/* --- Bento grid (mixed-size cards) --- */
.gp-bento__title {
	margin-bottom: var(--gp-space-2xl);
}

.gp-bento__card-icon {
	display: block;
	margin-bottom: var(--gp-space-sm);
	color: var(--gp-color-brand);
}

.gp-bento__grid {
	display: grid;
	gap: var(--gp-space-md);
	grid-template-columns: 1fr;
	grid-auto-rows: minmax(8rem, auto);
}

@media (min-width: 36rem) {
	.gp-bento__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 55rem) {
	.gp-bento__grid {
		grid-template-columns: repeat(4, 1fr);
		grid-auto-flow: dense;
		gap: var(--gp-space-lg);
	}

	.gp-bento__cell--large {
		grid-column: span 2;
		grid-row: span 2;
	}

	.gp-bento__cell--wide {
		grid-column: 1 / -1;
	}

	.gp-bento__cell--tall {
		grid-row: span 2;
	}
}

.gp-bento__card {
	height: 100%;
	display: flex;
	flex-direction: column;
	padding: var(--gp-space-lg);
	min-height: 10rem;
}

.gp-bento__cell--large .gp-bento__card {
	min-height: 14rem;
	padding: var(--gp-space-xl);
}

.gp-bento__cell--wide .gp-bento__card {
	min-height: auto;
}

.gp-bento__card-title {
	margin: 0 0 var(--gp-space-sm);
}

.gp-bento__card-desc {
	margin: 0 0 var(--gp-space-md);
	flex: 1;
}

.gp-bento__card-cta {
	margin: 0;
	margin-top: auto;
	padding-top: var(--gp-space-md);
}

/* Bento highlights: stats + short copy */
.gp-bento__value {
	display: block;
	font-size: var(--gp-font-size-3xl);
	font-weight: 700;
	color: var(--gp-color-brand);
	line-height: var(--gp-line-height-tight);
	margin-bottom: var(--gp-space-xs);
}

.gp-bento__label {
	margin: 0;
}

.gp-bento__grid--highlights .gp-bento__card {
	text-align: center;
}

@media (min-width: 55rem) {
	.gp-bento__grid--highlights .gp-bento__cell--wide .gp-bento__card {
		text-align: left;
		display: flex;
		flex-direction: column;
		align-items: flex-start;
	}

	.gp-bento__grid--highlights .gp-bento__cell--wide .gp-bento__card-cta {
		margin-top: auto;
	}
}

/* --- Problem / Solution --- */
.gp-problem-solution__header {
	margin-bottom: var(--gp-space-2xl);
	max-width: 40em;
}

.gp-problem-solution__lead {
	margin-bottom: 0;
}

.gp-problem-solution__list {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gp-space-lg);
	list-style: none;
	margin: 0 0 var(--gp-space-2xl);
	padding: 0;
}

@media (min-width: 36rem) {
	.gp-problem-solution__list {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 55rem) {
	.gp-problem-solution__list {
		grid-template-columns: repeat(3, 1fr);
	}
}

.gp-problem-solution__item {
	display: flex;
	flex-direction: column;
}

.gp-problem-solution__icon {
	display: block;
	margin-bottom: var(--gp-space-sm);
	color: var(--gp-color-brand);
}

.gp-problem-solution__problem {
	margin: 0 0 var(--gp-space-xs);
	font-size: var(--gp-font-size-base);
	color: var(--gp-color-text);
}

.gp-problem-solution__solution {
	margin: 0;
	flex: 1;
}

/* --- Pricing strip --- */
.gp-pricing-strip__title {
	text-align: center;
	margin-bottom: var(--gp-space-xl);
}

.gp-pricing-strip__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--gp-space-lg) var(--gp-space-2xl);
	list-style: none;
	margin: 0;
	padding: 0;
}

.gp-pricing-strip__item {
	display: flex;
	align-items: center;
	gap: var(--gp-space-sm);
	min-height: 2.75rem;
}

.gp-pricing-strip__check {
	flex-shrink: 0;
	color: var(--gp-color-brand);
}

/* --- Locations --- */
.gp-locations__header {
	margin-bottom: var(--gp-space-2xl);
	max-width: 40em;
}

.gp-locations__lead {
	margin-bottom: 0;
}

.gp-locations__list {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--gp-space-md);
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 25rem) {
	.gp-locations__list {
		grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr));
	}
}

.gp-locations__item {
	display: flex;
	align-items: center;
	gap: var(--gp-space-sm);
	padding: var(--gp-space-md);
}

.gp-locations__item .gp-icon {
	flex-shrink: 0;
}

/* --- Summary strip --- */
.gp-summary-strip__inner {
	text-align: center;
	max-width: 40rem;
	margin-inline: auto;
}

.gp-summary-strip__title {
	margin-bottom: var(--gp-space-xl);
}

.gp-summary-strip__list {
	list-style: none;
	margin: 0 0 var(--gp-space-xl);
	padding: 0;
	text-align: left;
	display: inline-block;
}

.gp-summary-strip__item {
	display: flex;
	align-items: center;
	gap: var(--gp-space-sm);
	margin-bottom: var(--gp-space-sm);
	min-height: 2.75rem;
}

.gp-summary-strip__item:last-child {
	margin-bottom: 0;
}

.gp-summary-strip__check {
	flex-shrink: 0;
	color: var(--gp-color-brand);
}
