/*
 * Connective CAC Calculator
 * All selectors scoped under .cwd-cac-calc to prevent style leakage.
 * Design tokens pulled from the live Elementor kit (post-2.css, 2026-06).
 */

.cwd-cac-calc {
	--cwd-cac-orange: #F05A28;
	--cwd-cac-orange-soft: rgba(240, 90, 40, 0.15);
	--cwd-cac-dark: #333333;
	--cwd-cac-text: #666666;
	--cwd-cac-bg: #F9F9F9;
	--cwd-cac-bg-cream: #F6F5F1;
	--cwd-cac-border: #C7C7C7;
	--cwd-cac-border-light: #E8E8E8;
	--cwd-cac-green: #2D7D46;
	--cwd-cac-green-bg: #ECF6EE;
	--cwd-cac-yellow: #C77800;
	--cwd-cac-yellow-bg: #FDF5E7;
	--cwd-cac-red: #C42B2B;
	--cwd-cac-red-bg: #FCEDED;
	--cwd-cac-serif: "Noto Serif", Georgia, "Times New Roman", serif;
	--cwd-cac-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

	font-family: var(--cwd-cac-sans);
	font-size: 16px;
	line-height: 1.5;
	letter-spacing: -0.01em;
	color: var(--cwd-cac-dark);
	background: var(--cwd-cac-bg);
	border: 1px solid var(--cwd-cac-border-light);
	border-radius: 8px;
	padding: 32px;
	margin: 32px 0;
	box-sizing: border-box;
}

.cwd-cac-calc *,
.cwd-cac-calc *::before,
.cwd-cac-calc *::after {
	box-sizing: border-box;
}

.cwd-cac-calc__intro {
	margin: 0 0 24px;
	font-size: 15px;
	color: var(--cwd-cac-text);
}
.cwd-cac-calc__intro p {
	margin: 0;
}

.cwd-cac-calc__grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 32px;
	align-items: start;
}

@media (max-width: 820px) {
	.cwd-cac-calc {
		padding: 20px;
		margin: 24px 0;
	}
	.cwd-cac-calc__grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
}

.cwd-cac-calc__section {
	border: none;
	padding: 0;
	margin: 0 0 24px;
}
.cwd-cac-calc__section:last-child {
	margin-bottom: 0;
}
.cwd-cac-calc__section legend {
	font-family: var(--cwd-cac-serif);
	font-size: 20px;
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: -0.02em;
	color: var(--cwd-cac-dark);
	margin: 0 0 16px;
	padding: 0;
	float: none;
	width: 100%;
}

.cwd-cac-calc__field {
	display: block;
	margin-bottom: 16px;
}
.cwd-cac-calc__field:last-child {
	margin-bottom: 0;
}

.cwd-cac-calc__label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: var(--cwd-cac-dark);
	margin-bottom: 6px;
	letter-spacing: -0.005em;
}

.cwd-cac-calc__field input[type="number"] {
	display: block;
	width: 100%;
	height: 44px;
	padding: 0 14px;
	font: inherit;
	font-size: 16px;
	color: var(--cwd-cac-dark);
	background: #ffffff;
	border: 1px solid var(--cwd-cac-border);
	border-radius: 6px;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	-moz-appearance: textfield;
	appearance: textfield;
}
.cwd-cac-calc__field input[type="number"]::-webkit-outer-spin-button,
.cwd-cac-calc__field input[type="number"]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
.cwd-cac-calc__field input[type="number"]:hover {
	border-color: var(--cwd-cac-dark);
}
.cwd-cac-calc__field input[type="number"]:focus {
	outline: none;
	border-color: var(--cwd-cac-orange);
	box-shadow: 0 0 0 3px var(--cwd-cac-orange-soft);
}

.cwd-cac-calc__help {
	display: block;
	font-size: 13px;
	color: var(--cwd-cac-text);
	margin-top: 6px;
	line-height: 1.45;
}

/* Results column */
.cwd-cac-calc__results {
	display: flex;
	flex-direction: column;
	gap: 14px;
	position: sticky;
	top: 24px;
	align-self: start;
}
@media (max-width: 820px) {
	.cwd-cac-calc__results {
		position: static;
	}
}

.cwd-cac-calc__result {
	background: #ffffff;
	border: 1px solid var(--cwd-cac-border-light);
	border-left: 3px solid var(--cwd-cac-border);
	border-radius: 6px;
	padding: 16px 20px;
	transition: background-color 0.2s ease, border-color 0.2s ease;
}
.cwd-cac-calc__result[data-status="green"] {
	background: var(--cwd-cac-green-bg);
	border-color: var(--cwd-cac-green);
	border-left-color: var(--cwd-cac-green);
}
.cwd-cac-calc__result[data-status="yellow"] {
	background: var(--cwd-cac-yellow-bg);
	border-color: var(--cwd-cac-yellow);
	border-left-color: var(--cwd-cac-yellow);
}
.cwd-cac-calc__result[data-status="red"] {
	background: var(--cwd-cac-red-bg);
	border-color: var(--cwd-cac-red);
	border-left-color: var(--cwd-cac-red);
}

.cwd-cac-calc__result-label {
	display: block;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--cwd-cac-text);
	margin-bottom: 6px;
}

.cwd-cac-calc__result-value {
	display: block;
	font-family: var(--cwd-cac-serif);
	font-size: 34px;
	font-weight: 700;
	line-height: 1.1;
	color: var(--cwd-cac-dark);
	letter-spacing: -0.02em;
	margin: 0;
}
.cwd-cac-calc__result[data-status="green"] .cwd-cac-calc__result-value {
	color: var(--cwd-cac-green);
}
.cwd-cac-calc__result[data-status="yellow"] .cwd-cac-calc__result-value {
	color: var(--cwd-cac-yellow);
}
.cwd-cac-calc__result[data-status="red"] .cwd-cac-calc__result-value {
	color: var(--cwd-cac-red);
}

.cwd-cac-calc__result-detail {
	font-size: 13px;
	color: var(--cwd-cac-text);
	margin: 6px 0 0;
	line-height: 1.45;
}

.cwd-cac-calc__privacy {
	margin: 24px 0 0;
	padding-top: 16px;
	border-top: 1px solid var(--cwd-cac-border-light);
	font-size: 12px;
	color: var(--cwd-cac-text);
	letter-spacing: 0.005em;
}
