:root {
	--acep-bg: #f8fafc;
	--acep-card: #ffffff;
	--acep-card-2: #f1f5f9;
	--acep-border: #e2e8f0;
	--acep-text: #0f172a;
	--acep-muted: #64748b;
	--acep-primary: #4f46e5;
	--acep-primary-2: #6366f1;
	--acep-success: #16a34a;
	--acep-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
}

.acep-estimator {
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	color: var(--acep-text);
	padding: 24px;
}

.acep-hero {
	display: flex;
	justify-content: space-between;
	gap: 18px;
	align-items: center;
	margin-bottom: 22px;
}

.acep-kicker {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: #c4b5fd;
	font-size: 12px;
	font-weight: 700;
	margin: 0 0 6px;
}

.acep-hero h2 {
	font-size: clamp(28px, 4vw, 44px);
	line-height: 1.05;
	margin: 0 0 8px;
}

.acep-hero p {
	max-width: 60ch;
	color: var(--acep-muted);
	margin: 0;
}

.acep-hero-chip {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.acep-hero-chip span,
.acep-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 14px;
	border: 1px solid var(--acep-border);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.04);
	backdrop-filter: blur(10px);
	color: var(--acep-text);
	font-size: 13px;
}

.acep-shell {
	background: radial-gradient(circle at top, rgba(99, 102, 241, 0.12), transparent 42%), #f8fafc;
	border-radius: 24px;
	padding: 18px;
}

.acep-steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-bottom: 16px;
}

.acep-step {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	border: 1px solid var(--acep-border);
	background: #ffffff;
	border-radius: 18px;
	opacity: 0.7;
	transition: 0.25s ease;
}

.acep-step.is-active {
	opacity: 1;
	transform: translateY(-1px);
	border-color: rgba(139, 92, 246, 0.45);
	box-shadow: 0 10px 35px rgba(124, 58, 237, 0.16);
}

.acep-step span {
	width: 34px;
	height: 34px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: rgba(124, 58, 237, 0.16);
	font-weight: 700;
}

.acep-step strong {
	font-size: 14px;
}

.acep-grid {
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: 18px;
}

.acep-form-card,
.acep-results-card {
	background: #ffffff;
	border: 1px solid var(--acep-border);
	border-radius: 22px;
	padding: 18px;
}

.acep-step-panel {
	display: none;
	animation: acepFade 0.24s ease;
}

.acep-step-panel.is-active {
	display: block;
}

@keyframes acepFade {
	from {
		opacity: 0;
		transform: translateY(8px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.acep-step-panel h3,
.acep-breakdown-head h4,
.acep-results-head h3 {
	margin: 0 0 8px;
}

.acep-help,
.acep-results-head p,
.acep-breakdown-head p {
	margin: 0;
	color: var(--acep-muted);
	font-size: 14px;
}

.acep-field,
.acep-textarea {
	display: grid;
	gap: 8px;
	margin-top: 16px;
}

.acep-field span,
.acep-textarea span {
	font-size: 13px;
	color: #cbd5e1;
	font-weight: 600;
}

.acep-field input,
.acep-field select,
.acep-textarea textarea {
	width: stretch;
	border-radius: 14px;
	border: 1px solid rgba(148, 163, 184, 0.22);
	background: #ffffff;
	color: var(--acep-text);
	padding: 14px 15px;
	outline: none;
	transition: 0.2s ease;
	box-shadow: none;
}

.acep-field input:focus,
.acep-field select:focus,
.acep-textarea textarea:focus {
	border-color: rgba(139, 92, 246, 0.72);
	box-shadow: 0 0 0 4px rgba(124, 58, 237, 0.12);
}

.acep-field-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

.acep-segmented {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	margin-top: 16px;
}

.acep-segmented--small {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.acep-segmented label {
	position: relative;
}

.acep-segmented input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.acep-segmented span {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 14px 16px;
	border-radius: 16px;
	border: 1px solid rgba(148, 163, 184, 0.18);
	background: rgba(255, 255, 255, 0.03);
	color: #e2e8f0;
	font-weight: 600;
	transition: 0.2s ease;
}

.acep-segmented input:checked+span {
	background-color: transparent;
    background-image: linear-gradient(180deg, #7c6ce4 0, #624de3 100%);
    border: 1px solid #0000001A;
    color: #fff;
    box-shadow: 0 2px 6px 0 rgba(0, 0, 0, .1), 0 -1px 0 1px rgba(0, 0, 0, .25) inset, 0 2px 0 0 rgba(255, 255, 255, .2) inset;
}

.acep-actions {
	display: flex;
	justify-content: flex-end;
	margin-top: 18px;
}

.acep-actions--split {
	justify-content: space-between;
}

.acep-btn {
	border: 0;
	border-radius: 8px;
	padding: 14px 18px;
	font-weight: 700;
	cursor: pointer;
	transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}

.acep-btn:hover {
	transform: translateY(-1px);
}

.acep-btn-primary {
	background-color: transparent;
	background-image: linear-gradient(180deg, #7c6ce4 0, #624de3 100%);
	border: 1px solid #0000001A;
	color: #fff;
	box-shadow: 0 2px 6px 0 rgba(0, 0, 0, .1), 0 -1px 0 1px rgba(0, 0, 0, .25) inset, 0 2px 0 0 rgba(255, 255, 255, .2) inset;
}

.acep-btn-ghost {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(148, 163, 184, 0.18);
}

.acep-results-head {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	align-items: center;
	margin-bottom: 16px;
}

.acep-summary-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	margin-bottom: 18px;
}

.acep-summary {
	border: 1px solid var(--acep-border);
	background: rgba(255, 255, 255, 0.03);
	border-radius: 18px;
	padding: 16px;
}

.acep-summary span {
	display: block;
	font-size: 12px;
	color: var(--acep-muted);
	margin-bottom: 8px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.acep-summary strong {
	font-size: 26px;
	line-height: 1.1;
}

.acep-summary--accent {
	background: linear-gradient(135deg, rgba(124, 58, 237, 0.18), rgba(34, 197, 94, 0.12));
	border-color: rgba(139, 92, 246, 0.3);
}

.acep-breakdown {
	margin-top: 8px;
	padding-top: 16px;
	border-top: 1px solid rgba(148, 163, 184, 0.14);
}

.acep-breakdown-list {
	display: grid;
	gap: 12px;
	margin-top: 14px;
}

.acep-item {
	border: 1px solid rgba(148, 163, 184, 0.14);
	background: rgba(255, 255, 255, 0.03);
	border-radius: 18px;
	padding: 15px;
}

.acep-item-top {
	display: flex;
	justify-content: space-between;
	gap: 10px;
	align-items: center;
	margin-bottom: 10px;
}

.acep-item-top h5 {
	margin: 0;
	font-size: 15px;
}

.acep-item-top span {
	font-weight: 700;
	background: linear-gradient(180deg, #7c6ce4 0, #624de3 100%);
	background-clip: text;
	color: transparent;
}

.acep-item-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

.acep-mini {
	background: linear-gradient(335deg, rgba(99, 102, 241, 0.12), transparent);
	border: 1px solid rgba(148, 163, 184, 0.12);
	border-radius: 14px;
	padding: 12px;
}

.acep-mini label {
	display: block;
	color: var(--acep-muted);
	font-size: 12px;
	margin-bottom: 6px;
}

.acep-mini strong {
	font-size: 15px;
}

.acep-empty {
	padding: 20px;
	text-align: center;
	color: var(--acep-muted);
	border: 1px dashed rgba(148, 163, 184, 0.18);
	border-radius: 16px;
}

@media (max-width: 980px) {

	.acep-grid,
	.acep-item-grid,
	.acep-field-grid,
	.acep-steps,
	.acep-summary-grid {
		grid-template-columns: 1fr;
	}

	.acep-hero {
		flex-direction: column;
		align-items: flex-start;
	}
}

@media (max-width: 640px) {
	.acep-estimator {
		padding: 14px;
	}

	.acep-shell {
		padding: 12px;
	}

	.acep-form-card,
	.acep-results-card {
		padding: 14px;
	}

	.acep-segmented {
		grid-template-columns: 1fr;
	}
}