.ggg-report {
	max-width: 1120px;
	margin: 0 auto;
}

.ggg-report-tool {
	display: grid;
	grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
	gap: 18px;
	align-items: stretch;
	margin-bottom: 18px;
}

.ggg-report-intro,
.ggg-report-form,
.ggg-report-result,
.ggg-report-context,
.ggg-report-trend,
.ggg-report-next,
.ggg-report-agents,
.ggg-report-empty {
	border: 1px solid var(--ggg-hairline);
	border-radius: 18px;
	background: rgba(255, 255, 255, .88);
}

.ggg-report-intro {
	min-height: 242px;
	padding: 28px;
	background:
		linear-gradient(135deg, rgba(15, 143, 106, .12), rgba(255, 255, 255, .74) 46%),
		var(--ggg-card);
}

.ggg-report-intro h1 {
	max-width: 620px;
	margin: 0 0 12px;
	color: var(--ggg-ink);
	font-size: clamp(28px, 4vw, 48px);
	font-weight: 860;
	line-height: 1.04;
	letter-spacing: 0;
}

.ggg-report-intro p:last-child {
	max-width: 620px;
	margin: 0;
	color: var(--ggg-body);
	font-size: 16px;
	font-weight: 640;
	line-height: 1.65;
}

.ggg-report-form {
	padding: 22px;
}

.ggg-report-form-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
}

.ggg-report-form label {
	margin-bottom: 6px;
	color: var(--ggg-ink);
	font-size: 13px;
	font-weight: 820;
}

.ggg-report-form .form-control {
	min-height: 48px;
	border-color: var(--ggg-hairline);
	border-radius: 12px;
	background: #fbfcfb;
	color: var(--ggg-ink);
	font-weight: 740;
}

.ggg-report-form .form-control:focus {
	border-color: rgba(15, 143, 106, .45);
	box-shadow: 0 0 0 3px rgba(15, 143, 106, .12);
}

.ggg-report-form .hint-block {
	margin-top: 5px;
	color: var(--ggg-muted);
	font-size: 12px;
	font-weight: 620;
	line-height: 1.45;
}

.ggg-report-submit,
.ggg-report-link {
	display: inline-flex;
	min-height: 46px;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 0 16px;
	border: 1px solid transparent;
	border-radius: 12px;
	background: var(--ggg-primary);
	color: #fff;
	font-weight: 820;
	text-decoration: none;
	transition: transform .16s ease, background .16s ease, border-color .16s ease;
}

.ggg-report-submit {
	width: 100%;
	margin-top: 6px;
	cursor: pointer;
}

.ggg-report-submit:hover,
.ggg-report-link:hover {
	background: var(--ggg-primary-hover);
	color: #fff;
	text-decoration: none;
}

.ggg-report-submit:active,
.ggg-report-link:active {
	transform: translateY(1px);
}

.ggg-report-link-soft {
	border-color: rgba(15, 143, 106, .18);
	background: var(--ggg-primary-soft);
	color: var(--ggg-primary-hover);
}

.ggg-report-link-soft:hover {
	border-color: rgba(15, 143, 106, .28);
	background: #d2ede3;
	color: var(--ggg-primary-hover);
}

.ggg-report-link-finance {
	border-color: rgba(15, 143, 106, .22);
	background: #f7fbf9;
	color: var(--ggg-primary-hover);
}

.ggg-report-link-finance:hover {
	border-color: rgba(15, 143, 106, .34);
	background: var(--ggg-primary-soft);
	color: var(--ggg-primary-hover);
}

.ggg-report-track {
	cursor: pointer;
}

.ggg-report-track.is-saved {
	border-color: rgba(47, 155, 119, .3);
	background: rgba(47, 155, 119, .1);
	color: #257c62;
}

.ggg-report-track.is-error,
.ggg-report-track-note {
	border-color: #d8bab4;
	background: #fff7f5;
	color: var(--ggg-warn);
}

.ggg-report-track:disabled {
	cursor: progress;
	opacity: .72;
}

.ggg-report-track-note {
	display: inline-flex;
	min-height: 46px;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 0 16px;
	border: 1px solid #d8bab4;
	border-radius: 12px;
	font-weight: 820;
}

.ggg-report-empty {
	padding: 22px;
}

.ggg-report-empty h2 {
	margin: 0 0 8px;
	color: var(--ggg-ink);
	font-size: 22px;
	font-weight: 840;
}

.ggg-report-empty p {
	margin: 0 0 14px;
	color: var(--ggg-muted);
	font-weight: 640;
	line-height: 1.6;
}

.ggg-report-result {
	display: grid;
	grid-template-columns: minmax(0, .95fr) minmax(0, 1.35fr);
	gap: 12px;
	margin-bottom: 16px;
	padding: 14px;
}

.ggg-report-estimate {
	padding: 16px;
	border-radius: 14px;
	background: var(--ggg-ink);
	color: #fff;
}

.ggg-report-estimate p {
	margin: 0 0 8px;
	color: rgba(255, 255, 255, .72);
	font-size: 13px;
	font-weight: 760;
}

.ggg-report-estimate h2 {
	margin: 0 0 14px;
	color: #fff;
	font-size: clamp(26px, 4vw, 40px);
	font-weight: 880;
	line-height: 1.08;
	letter-spacing: 0;
	overflow-wrap: anywhere;
}

.ggg-report-confidence {
	display: inline-flex;
	min-height: 30px;
	align-items: center;
	padding: 0 11px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .12);
	color: rgba(255, 255, 255, .86);
	font-size: 12px;
	font-weight: 820;
}

.ggg-report-confidence.is-good {
	background: rgba(57, 191, 137, .22);
	color: #bdf3dd;
}

.ggg-report-confidence.is-ok {
	background: rgba(235, 174, 73, .22);
	color: #ffe3aa;
}

.ggg-report-confidence.is-thin,
.ggg-report-confidence.is-empty {
	background: rgba(214, 91, 68, .22);
	color: #ffc1b5;
}

.ggg-report-facts {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}

.ggg-report-facts div {
	min-width: 0;
	padding: 14px;
	border: 1px solid var(--ggg-hairline);
	border-radius: 13px;
	background: var(--ggg-soft);
}

.ggg-report-facts span,
.ggg-report-facts em {
	display: block;
	color: var(--ggg-muted);
	font-size: 12px;
	font-style: normal;
	font-weight: 760;
	line-height: 1.25;
}

.ggg-report-facts strong {
	display: block;
	margin: 7px 0 5px;
	color: var(--ggg-ink);
	font-size: 24px;
	font-weight: 860;
	line-height: 1.05;
	overflow-wrap: anywhere;
}

.ggg-report-context {
	display: grid;
	grid-template-columns: minmax(0, 1.3fr) minmax(280px, .7fr);
	gap: 14px;
	align-items: center;
	margin-bottom: 18px;
	padding: 18px;
}

.ggg-report-context h2 {
	margin: 0 0 8px;
	color: var(--ggg-ink);
	font-size: 22px;
	font-weight: 840;
}

.ggg-report-context p {
	margin: 0;
	color: var(--ggg-muted);
	font-weight: 640;
	line-height: 1.6;
}

.ggg-report-mini-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 8px;
}

.ggg-report-mini-grid span {
	min-width: 0;
	padding: 12px;
	border-radius: 12px;
	background: #f2f5f2;
	color: var(--ggg-muted);
	font-size: 12px;
	font-weight: 740;
}

.ggg-report-mini-grid b {
	display: block;
	margin-bottom: 4px;
	color: var(--ggg-ink);
	font-size: 18px;
	line-height: 1.05;
}

.ggg-report-trend {
	margin-bottom: 16px;
	padding: 12px;
}

.ggg-report-trend-row {
	display: grid;
	grid-template-columns: 72px minmax(120px, 1fr) 116px 38px;
	gap: 10px;
	align-items: center;
	min-height: 34px;
	color: var(--ggg-muted);
	font-size: 12px;
	font-weight: 780;
}

.ggg-report-trend-row div {
	overflow: hidden;
	height: 10px;
	border-radius: 999px;
	background: #e5ebe6;
}

.ggg-report-trend-row i {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: #2f9b77;
}

.ggg-report-trend-row strong {
	color: var(--ggg-ink);
	font-size: 13px;
	text-align: right;
}

.ggg-report-trend-row em {
	display: inline-flex;
	width: 30px;
	height: 24px;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: var(--ggg-soft);
	color: var(--ggg-muted);
	font-style: normal;
}

.ggg-report-table {
	margin-bottom: 14px;
}

.ggg-report-next {
	display: grid;
	grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr);
	gap: 14px;
	align-items: start;
	margin: 0 0 16px;
	padding: 16px;
}

.ggg-report-next-copy p {
	margin: 0 0 7px;
	color: var(--ggg-primary-hover);
	font-size: 12px;
	font-weight: 840;
	text-transform: uppercase;
}

.ggg-report-next-copy h2 {
	margin: 0 0 8px;
	color: var(--ggg-ink);
	font-size: 22px;
	font-weight: 860;
	line-height: 1.15;
}

.ggg-report-next-copy span {
	display: block;
	color: var(--ggg-muted);
	font-size: 14px;
	font-weight: 640;
	line-height: 1.55;
}

.ggg-report-next-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 9px;
}

.ggg-report-next-card {
	display: grid;
	grid-template-columns: 34px minmax(0, 1fr);
	grid-template-rows: auto auto;
	gap: 2px 10px;
	min-height: 78px;
	align-items: center;
	padding: 12px;
	border: 1px solid rgba(15, 143, 106, .16);
	border-radius: 12px;
	background: #f8fbf9;
	color: var(--ggg-ink);
	text-decoration: none;
	transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.ggg-report-next-card:hover {
	border-color: rgba(15, 143, 106, .3);
	background: var(--ggg-primary-soft);
	color: var(--ggg-ink);
	text-decoration: none;
}

.ggg-report-next-card:active {
	transform: translateY(1px);
}

.ggg-report-next-card .fa {
	grid-row: 1 / span 2;
	display: inline-flex;
	width: 34px;
	height: 34px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: #fff;
	color: var(--ggg-primary-hover);
	font-size: 15px;
}

.ggg-report-next-card strong {
	min-width: 0;
	color: var(--ggg-ink);
	font-size: 14px;
	font-weight: 840;
	line-height: 1.2;
}

.ggg-report-next-card span {
	min-width: 0;
	color: var(--ggg-muted);
	font-size: 12px;
	font-weight: 640;
	line-height: 1.25;
}

.ggg-report-next-actions {
	grid-column: 1 / -1;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	padding-top: 2px;
}

.ggg-report-agents {
	margin: 0 0 16px;
	padding: 16px;
}

.ggg-report-agent-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
}

.ggg-report-agent-head p {
	margin: 0 0 6px;
	color: var(--ggg-primary-hover);
	font-size: 12px;
	font-weight: 840;
	text-transform: uppercase;
}

.ggg-report-agent-head h2 {
	margin: 0;
	color: var(--ggg-ink);
	font-size: 22px;
	font-weight: 860;
	line-height: 1.16;
}

.ggg-report-text-link {
	flex: 0 0 auto;
	color: var(--ggg-primary-hover);
	font-size: 13px;
	font-weight: 820;
	text-decoration: none;
}

.ggg-report-text-link:hover {
	color: var(--ggg-primary);
	text-decoration: none;
}

.ggg-report-agent-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}

.ggg-report-agent-card {
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr);
	gap: 10px;
	min-width: 0;
	padding: 13px;
	border: 1px solid rgba(15, 143, 106, .14);
	border-radius: 13px;
	background: #f8fbf9;
}

.ggg-report-agent-mark {
	display: inline-flex;
	width: 42px;
	height: 42px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--ggg-ink);
	color: #fff;
	font-size: 16px;
	font-weight: 860;
}

.ggg-report-agent-copy {
	min-width: 0;
}

.ggg-report-agent-copy h3 {
	margin: 0 0 4px;
	font-size: 15px;
	font-weight: 860;
	line-height: 1.2;
}

.ggg-report-agent-copy h3 a {
	color: var(--ggg-ink);
	text-decoration: none;
	overflow-wrap: anywhere;
}

.ggg-report-agent-copy p {
	margin: 0 0 9px;
	color: var(--ggg-muted);
	font-size: 12px;
	font-weight: 660;
	line-height: 1.3;
	overflow-wrap: anywhere;
}

.ggg-report-agent-meta {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 7px;
	margin-bottom: 8px;
}

.ggg-report-agent-meta span {
	min-width: 0;
	padding: 8px;
	border-radius: 10px;
	background: #fff;
	color: var(--ggg-muted);
	font-size: 11px;
	font-weight: 700;
	line-height: 1.25;
}

.ggg-report-agent-meta b {
	display: block;
	margin-bottom: 2px;
	color: var(--ggg-ink);
	font-size: 15px;
	line-height: 1.05;
	overflow-wrap: anywhere;
}

.ggg-report-agent-copy em {
	display: block;
	color: var(--ggg-muted);
	font-size: 11px;
	font-style: normal;
	font-weight: 680;
	line-height: 1.35;
}

.ggg-report-agent-actions {
	grid-column: 1 / -1;
	display: flex;
	flex-wrap: wrap;
	gap: 7px;
}

.ggg-report-agent-action {
	display: inline-flex;
	min-height: 34px;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 0 10px;
	border: 1px solid rgba(15, 143, 106, .18);
	border-radius: 10px;
	background: #fff;
	color: var(--ggg-primary-hover);
	font-size: 12px;
	font-weight: 820;
	text-decoration: none;
}

.ggg-report-agent-action:hover,
.ggg-report-agent-action.is-contact {
	background: var(--ggg-primary);
	color: #fff;
	text-decoration: none;
}

.ggg-report-agent-empty {
	display: grid;
	gap: 8px;
	padding: 14px;
	border-radius: 13px;
	background: #f8fbf9;
}

.ggg-report-agent-empty strong {
	color: var(--ggg-ink);
	font-size: 16px;
	font-weight: 860;
}

.ggg-report-agent-empty span {
	max-width: 760px;
	color: var(--ggg-muted);
	font-size: 13px;
	font-weight: 640;
	line-height: 1.55;
}

.ggg-report-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0 0 18px;
}

@media ( max-width : 767px) {
	.ggg-report-tool,
	.ggg-report-result,
	.ggg-report-context {
		grid-template-columns: 1fr;
	}
	.ggg-report-tool {
		gap: 12px;
	}
	.ggg-report-intro,
	.ggg-report-form,
	.ggg-report-result,
	.ggg-report-context,
	.ggg-report-trend,
	.ggg-report-next,
	.ggg-report-agents,
	.ggg-report-empty {
		border-radius: 14px;
	}
	.ggg-report-intro {
		min-height: auto;
		padding: 20px;
	}
	.ggg-report-intro h1 {
		font-size: 30px;
	}
	.ggg-report-form {
		padding: 16px;
	}
	.ggg-report-result {
		padding: 10px;
	}
	.ggg-report-facts,
	.ggg-report-mini-grid {
		grid-template-columns: 1fr;
		gap: 8px;
	}
	.ggg-report-estimate {
		padding: 14px;
	}
	.ggg-report-estimate h2 {
		font-size: 27px;
	}
	.ggg-report-trend-row {
		grid-template-columns: 66px minmax(90px, 1fr) 92px 34px;
		gap: 7px;
	}
	.ggg-report-next {
		grid-template-columns: 1fr;
		padding: 12px;
	}
	.ggg-report-next-grid {
		grid-template-columns: 1fr;
	}
	.ggg-report-next-actions {
		display: grid;
		grid-template-columns: 1fr;
	}
	.ggg-report-next-actions > * {
		width: 100%;
	}
	.ggg-report-agent-head {
		display: grid;
		grid-template-columns: 1fr;
	}
	.ggg-report-agent-grid {
		grid-template-columns: 1fr;
	}
	.ggg-report-agent-meta {
		grid-template-columns: 1fr;
	}
	.ggg-report-agent-actions {
		display: grid;
		grid-template-columns: 1fr;
	}
	.ggg-report-agent-action {
		width: 100%;
	}
	.ggg-report-actions {
		display: grid;
		grid-template-columns: 1fr;
	}
	.ggg-report-actions > * {
		width: 100%;
	}
}

.ggg-report-intro p.ggg-report-switch {
	margin: 14px 0 0;
	font-size: 14px;
	font-weight: 600;
}

.ggg-report-switch a {
	color: var(--ggg-accent, #0f8f6a);
	text-decoration: none;
	border-bottom: 1px dashed currentColor;
}

.ggg-report-switch a:hover {
	opacity: .82;
}
