:root {
	--pga-navy: #101528;
	--pga-navy-2: #1f2641;
	--pga-blue: #30bced;
	--pga-yellow: #fcba04;
	--pga-ink: #202638;
	--pga-muted: #60697c;
	--pga-soft: #f4f7fa;
	--pga-white: #ffffff;
	--pga-border: #dfe5ec;
	--pga-radius: 18px;
	--pga-shadow: 0 22px 60px rgba(16, 21, 40, 0.12);
}

.pga-landing {
	color: var(--pga-ink);
	font-family: inherit;
	line-height: 1.65;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	max-width: none;
	overflow: clip;
	width: 100vw;
}

.pga-landing-page .site.grid-container,
.pga-landing-page .site-content,
.pga-landing-page .content-area,
.pga-landing-page .site-main,
.pga-landing-page .inside-article,
.pga-landing-page .entry-content {
	margin: 0;
	max-width: none;
	padding: 0;
	width: 100%;
}

.pga-landing-page .site-content {
	display: block;
}

.pga-landing-page .entry-content:not(:first-child) {
	margin-top: 0;
}

/*
 * GeneratePress may add legacy inner wrappers to every Group block.
 * Removing their layout box lets the pattern classes control their own
 * width, grid and spacing without inheriting the theme's 1200px container.
 */
.pga-landing-page .pga-landing .wp-block-group__inner-container {
	display: contents;
	margin: 0 !important;
	max-width: none !important;
	padding: 0 !important;
}

.pga-landing-page #page.site.grid-container {
	max-width: none !important;
	width: 100% !important;
}

.pga-landing-page.separate-containers .inside-article,
.pga-landing-page .site-main .wp-block-group__inner-container {
	padding: 0 !important;
}

.pga-landing *,
.pga-landing *::before,
.pga-landing *::after {
	box-sizing: border-box;
}

.pga-landing :where(h1, h2, h3, p, ul, figure) {
	margin-top: 0;
}

.pga-landing h1,
.pga-landing h2,
.pga-landing h3 {
	color: var(--pga-navy);
	font-weight: 750;
	letter-spacing: -0.03em;
	line-height: 1.12;
}

.pga-landing h1 {
	font-size: clamp(2.55rem, 4.2vw, 4.35rem);
	margin-bottom: 24px;
}

.pga-landing h2 {
	font-size: clamp(2rem, 3.6vw, 3.25rem);
	margin-bottom: 22px;
}

.pga-landing h3 {
	font-size: clamp(1.15rem, 2vw, 1.4rem);
	margin-bottom: 12px;
}

.pga-landing a {
	color: var(--pga-navy);
	text-underline-offset: 3px;
}

.pga-landing a:focus-visible,
.pga-landing summary:focus-visible {
	border-radius: 4px;
	outline: 3px solid var(--pga-yellow);
	outline-offset: 4px;
}

.pga-shell {
	margin-inline: auto;
	max-width: 1200px;
	padding-inline: 32px;
	width: 100%;
}

.pga-section {
	padding-block: clamp(76px, 9vw, 128px);
}

.pga-eyebrow {
	color: #137fa3;
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	margin-bottom: 18px;
	text-transform: uppercase;
}

.pga-lead {
	color: #d9e1ee;
	font-size: clamp(1.08rem, 2vw, 1.28rem);
	max-width: 680px;
}

.pga-hero {
	background:
		radial-gradient(circle at 88% 15%, rgba(48, 188, 237, 0.22), transparent 28%),
		linear-gradient(135deg, var(--pga-navy) 0%, var(--pga-navy-2) 100%);
	color: var(--pga-white);
	padding-block: clamp(74px, 9vw, 130px);
	position: relative;
}

.pga-hero .pga-eyebrow {
	color: var(--pga-yellow);
}

.pga-hero h1 {
	color: var(--pga-white);
}

.pga-hero-grid {
	align-items: center;
	display: grid;
	gap: clamp(48px, 7vw, 90px);
	grid-template-columns: minmax(0, 1.12fr) minmax(360px, 0.88fr);
}

.pga-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-block: 34px 28px;
}

.pga-button .wp-block-button__link {
	align-items: center;
	border: 2px solid transparent;
	border-radius: 999px;
	display: inline-flex;
	font-weight: 750;
	justify-content: center;
	min-height: 52px;
	padding: 12px 24px;
	text-decoration: none;
	transition: transform 180ms ease, background-color 180ms ease, color 180ms ease;
}

.pga-button .wp-block-button__link:hover {
	transform: translateY(-2px);
}

.pga-button-primary .wp-block-button__link {
	background: var(--pga-yellow);
	color: var(--pga-navy);
}

.pga-button-secondary .wp-block-button__link {
	background: transparent;
	border-color: rgba(255, 255, 255, 0.6);
	color: var(--pga-white);
}

.pga-button-dark .wp-block-button__link {
	background: var(--pga-navy);
	color: var(--pga-white);
}

.pga-button-outline .wp-block-button__link {
	background: transparent;
	border-color: var(--pga-navy);
	color: var(--pga-navy);
	margin-top: 34px;
}

.pga-button-yellow .wp-block-button__link {
	background: var(--pga-yellow);
	color: var(--pga-navy);
}

.pga-hero-points,
.pga-check-list,
.pga-contact-list {
	list-style: none;
	padding: 0;
}

.pga-hero-points {
	color: #e8edf6;
	display: flex;
	flex-wrap: wrap;
	font-size: 0.94rem;
	gap: 12px 24px;
}

.pga-hero-points li::before,
.pga-check-list li::before {
	color: var(--pga-yellow);
	content: "✓";
	font-weight: 900;
	margin-right: 9px;
}

.pga-hero-media {
	position: relative;
}

.pga-hero-image img,
.pga-split-media img {
	border-radius: var(--pga-radius);
	display: block;
	height: auto;
	width: 100%;
}

.pga-hero-image img {
	aspect-ratio: 3 / 4;
	box-shadow: var(--pga-shadow);
	object-fit: cover;
}

.pga-float-card {
	background: var(--pga-white);
	border-radius: 14px;
	bottom: -32px;
	box-shadow: var(--pga-shadow);
	color: var(--pga-muted);
	left: -48px;
	max-width: 285px;
	padding: 22px;
	position: absolute;
}

.pga-float-card p {
	margin-bottom: 0;
}

.pga-float-title {
	color: var(--pga-navy);
	font-weight: 800;
	margin-bottom: 5px !important;
}

.pga-trust {
	background: var(--pga-white);
	border-bottom: 1px solid var(--pga-border);
}

.pga-trust-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.pga-trust-item {
	padding: 38px;
}

.pga-trust-item + .pga-trust-item {
	border-left: 1px solid var(--pga-border);
}

.pga-trust-item h2 {
	font-size: 1.25rem;
	margin-bottom: 8px;
}

.pga-trust-item p:last-child {
	color: var(--pga-muted);
	margin-bottom: 0;
}

.pga-kicker,
.pga-card-number {
	color: #137fa3;
	font-size: 0.78rem;
	font-weight: 850;
	letter-spacing: 0.12em;
}

.pga-section-heading {
	margin-bottom: 48px;
	max-width: 780px;
}

.pga-section-heading > p:last-child {
	color: var(--pga-muted);
	font-size: 1.08rem;
}

.pga-section-heading-center {
	margin-inline: auto;
	text-align: center;
}

.pga-card-grid {
	display: grid;
	gap: 24px;
}

.pga-card-grid-3 {
	grid-template-columns: repeat(3, 1fr);
}

.pga-card-grid-4 {
	grid-template-columns: repeat(4, 1fr);
}

.pga-service-card,
.pga-info-card,
.pga-step {
	background: var(--pga-white);
	border: 1px solid var(--pga-border);
	border-radius: var(--pga-radius);
	padding: clamp(26px, 3vw, 38px);
}

.pga-service-card {
	box-shadow: 0 12px 34px rgba(16, 21, 40, 0.06);
}

.pga-service-card p:not(.pga-card-number),
.pga-info-card p,
.pga-step p {
	color: var(--pga-muted);
}

.pga-service-card a,
.pga-text-link {
	font-weight: 800;
}

.pga-business {
	background: var(--pga-soft);
}

.pga-split {
	align-items: center;
	display: grid;
	gap: clamp(46px, 7vw, 92px);
	grid-template-columns: 1fr 1fr;
}

.pga-split-media {
	position: relative;
}

.pga-split-media::before {
	background: var(--pga-yellow);
	border-radius: var(--pga-radius);
	content: "";
	inset: 22px -22px -22px 22px;
	position: absolute;
	z-index: 0;
}

.pga-split-media figure {
	margin: 0;
	position: relative;
	z-index: 1;
}

.pga-check-list li {
	border-bottom: 1px solid var(--pga-border);
	padding-block: 11px;
}

.pga-private {
	background: var(--pga-white);
}

.pga-info-card {
	border-top: 5px solid var(--pga-blue);
}

.pga-dgt {
	background: var(--pga-navy);
	color: #dce4f1;
}

.pga-dgt h2,
.pga-dgt h3 {
	color: var(--pga-white);
}

.pga-dgt .pga-eyebrow {
	color: var(--pga-yellow);
}

.pga-dgt-grid {
	display: grid;
	gap: clamp(46px, 7vw, 100px);
	grid-template-columns: 0.85fr 1.15fr;
}

.pga-dgt-row {
	align-items: start;
	border-top: 1px solid rgba(255, 255, 255, 0.18);
	display: grid;
	gap: 22px;
	grid-template-columns: 42px 1fr;
	padding-block: 22px;
}

.pga-dgt-row > span {
	color: var(--pga-yellow);
	font-weight: 850;
}

.pga-dgt-row p,
.pga-dgt-row h3 {
	margin-bottom: 0;
}

.pga-process {
	background: var(--pga-soft);
}

.pga-step span {
	align-items: center;
	background: var(--pga-yellow);
	border-radius: 50%;
	color: var(--pga-navy);
	display: inline-flex;
	font-weight: 850;
	height: 42px;
	justify-content: center;
	margin-bottom: 26px;
	width: 42px;
}

.pga-about-grid,
.pga-faq-grid,
.pga-contact-grid {
	display: grid;
	gap: clamp(46px, 7vw, 92px);
	grid-template-columns: 1fr 1fr;
}

.pga-college-card {
	background: var(--pga-soft);
	border-radius: var(--pga-radius);
	padding: clamp(28px, 4vw, 48px);
}

.pga-college-card img {
	height: auto;
	margin-bottom: 28px;
	max-width: 100%;
	width: 100%;
}

.pga-faq {
	background: var(--pga-soft);
}

.pga-accordion details {
	background: var(--pga-white);
	border: 1px solid var(--pga-border);
	border-radius: 12px;
	margin-bottom: 13px;
	padding: 18px 20px;
}

.pga-accordion summary {
	color: var(--pga-navy);
	cursor: pointer;
	font-weight: 800;
}

.pga-accordion details p {
	color: var(--pga-muted);
	margin: 14px 0 2px;
}

.pga-contact {
	background: linear-gradient(135deg, var(--pga-navy-2), var(--pga-navy));
	color: #dce4f1;
}

.pga-contact h2,
.pga-contact h3 {
	color: var(--pga-white);
}

.pga-contact .pga-eyebrow {
	color: var(--pga-yellow);
}

.pga-contact-list {
	margin-top: 30px;
}

.pga-contact-list li {
	border-bottom: 1px solid rgba(255, 255, 255, 0.16);
	padding-block: 12px;
}

.pga-contact-list a {
	color: var(--pga-white);
}

.pga-small,
.pga-form-note {
	font-size: 0.86rem;
}

.pga-form-card {
	background: var(--pga-white);
	border-radius: var(--pga-radius);
	box-shadow: var(--pga-shadow);
	color: var(--pga-muted);
	padding: clamp(28px, 4vw, 48px);
}

.pga-form-card :where(input:not([type="checkbox"]):not([type="radio"]), select, textarea) {
	background: #fff;
	border: 1px solid #b9c2cf;
	border-radius: 8px;
	font: inherit;
	margin-top: 6px;
	min-height: 48px;
	padding: 10px 12px;
	width: 100%;
}

.pga-form-card textarea {
	min-height: 130px;
}

.pga-form-card :where(button, input[type="submit"]) {
	background: var(--pga-yellow);
	border: 0;
	border-radius: 999px;
	color: var(--pga-navy);
	cursor: pointer;
	font: inherit;
	font-weight: 800;
	min-height: 50px;
	padding: 12px 24px;
}

.pga-mobile-bar {
	display: none;
}

@media (max-width: 960px) {
	.pga-hero-grid,
	.pga-split,
	.pga-dgt-grid,
	.pga-about-grid,
	.pga-faq-grid,
	.pga-contact-grid {
		grid-template-columns: 1fr;
	}

	.pga-hero-media {
		margin-inline: auto;
		max-width: 620px;
	}

	.pga-hero-image img {
		aspect-ratio: 4 / 3;
	}

	.pga-card-grid-3,
	.pga-card-grid-4 {
		grid-template-columns: repeat(2, 1fr);
	}

	.pga-dgt-intro {
		max-width: 720px;
	}
}

@media (max-width: 680px) {
	.pga-shell {
		padding-inline: 20px;
	}

	.pga-section {
		padding-block: 70px;
	}

	.pga-landing h1 {
		font-size: clamp(2.35rem, 12vw, 3.25rem);
	}

	.pga-trust-grid,
	.pga-card-grid-3,
	.pga-card-grid-4 {
		grid-template-columns: 1fr;
	}

	.pga-trust-item {
		padding: 28px 20px;
	}

	.pga-trust-item + .pga-trust-item {
		border-left: 0;
		border-top: 1px solid var(--pga-border);
	}

	.pga-float-card {
		bottom: -25px;
		left: 14px;
		right: 14px;
	}

	.pga-split-media::before {
		inset: 12px -10px -12px 10px;
	}

	.pga-actions,
	.pga-actions .wp-block-button,
	.pga-actions .wp-block-button__link {
		width: 100%;
	}

	.pga-mobile-bar {
		background: var(--pga-white);
		border-top: 1px solid var(--pga-border);
		bottom: 0;
		box-shadow: 0 -8px 24px rgba(16, 21, 40, 0.12);
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		left: 0;
		position: fixed;
		right: 0;
		z-index: 999;
	}

	.pga-mobile-bar a {
		font-size: 0.85rem;
		font-weight: 800;
		padding: 14px 8px;
		text-align: center;
		text-decoration: none;
	}

	.pga-mobile-bar a:nth-child(2) {
		background: var(--pga-yellow);
	}

	body {
		padding-bottom: 48px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.pga-landing *,
	.pga-landing *::before,
	.pga-landing *::after {
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
	}
}
