/* ===========================================================================
   Cedar Fence Direct — Freight Estimator Widget
   Brand-matched: forest green + lime + orange CTA. Clean modern industrial.
   All rules scoped under .cfd-fe to avoid leaking into the host theme.
   =========================================================================== */

.cfd-fe {
	/* Brand palette — pulled from cedarfencedirect.com */
	--cfd-green-dark:    #1F4D11;   /* top utility bar */
	--cfd-green:         #2C6019;   /* primary submit / dark accents */
	--cfd-green-deep:    #163808;   /* hover/active green */
	--cfd-lime:          #83BC42;   /* bright accent — phone strip / logo */
	--cfd-lime-hover:    #6FA536;
	--cfd-orange:        #E37935;   /* primary CTA — "Get a Quote" */
	--cfd-orange-hover:  #C9651F;
	--cfd-white:         #FFFFFF;
	--cfd-off-white:     #FAFAF7;
	--cfd-cream:         #F4EFE3;
	--cfd-text:          #2A2A2A;
	--cfd-text-mute:     #6E6E6E;
	--cfd-text-soft:     #9A9A9A;
	--cfd-border:        #DDDDDD;
	--cfd-border-mid:    #B5B5B5;
	--cfd-border-strong: #2A2A2A;
	--cfd-success:       #6FA536;
	--cfd-warn:          #C9421F;
	--cfd-shadow-sm:     0 1px 2px rgba(0,0,0,0.06);
	--cfd-shadow:        0 4px 16px -6px rgba(0,0,0,0.18);

	/* Headline stack (condensed, Oswald-style). Falls back gracefully. */
	--cfd-font-head: "Oswald", "Bebas Neue", "Helvetica Neue Condensed",
	                 "Arial Narrow Bold", "Roboto Condensed", Impact,
	                 system-ui, sans-serif;
	/* Body stack */
	--cfd-font-body: -apple-system, BlinkMacSystemFont, "Segoe UI",
	                 "Helvetica Neue", Arial, sans-serif;

	background: var(--cfd-white);
	color: var(--cfd-text);
	font-family: var(--cfd-font-body);
	border: 1px solid var(--cfd-border);
	box-shadow: var(--cfd-shadow);
	max-width: 640px;
	margin: 0 auto;
	padding: 0;
	position: relative;
	overflow: hidden;
	box-sizing: border-box;
	border-radius: 4px;
}
.cfd-fe *,
.cfd-fe *::before,
.cfd-fe *::after { box-sizing: border-box; }

/* Top utility bar — dark forest green to match site header */
.cfd-fe__bar {
	background: var(--cfd-green-dark);
	color: var(--cfd-white);
	padding: 12px 22px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}
.cfd-fe__bar-title {
	font-family: var(--cfd-font-head);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.10em;
	font-size: 14px;
	line-height: 1;
}
.cfd-fe__bar-title em {
	color: var(--cfd-lime);
	font-style: normal;
	font-weight: 700;
}
.cfd-fe__stamp {
	background: var(--cfd-lime);
	color: var(--cfd-green-dark);
	font-family: var(--cfd-font-head);
	font-size: 11px;
	letter-spacing: 0.14em;
	font-weight: 700;
	padding: 4px 9px;
	text-transform: uppercase;
	border-radius: 2px;
}

/* ===== WIZARD SCREEN STATES ===== */
.cfd-fe__screens { position: relative; }
.cfd-fe__screen { display: none; }
.cfd-fe__screen.is-active { display: block; animation: cfd-fade 180ms ease-out; }
@keyframes cfd-fade {
	from { opacity: 0; transform: translateY(4px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* Back / restart links — small, top-of-screen */
.cfd-fe__back {
	display: inline-block;
	background: none;
	border: none;
	cursor: pointer;
	font-family: inherit;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.06em;
	color: var(--cfd-text-mute);
	padding: 14px 26px 0 26px;
	transition: color 120ms ease;
}
.cfd-fe__back:hover { color: var(--cfd-green-dark); }

/* Big choice buttons (lead-type, truck size, fence type) */
.cfd-fe__choices {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
	padding: 6px 26px 26px 26px;
}
.cfd-fe__choices--3 { grid-template-columns: 1fr 1fr 1fr; }

.cfd-fe__choice {
	background: var(--cfd-white);
	border: 1px solid var(--cfd-border-mid);
	border-radius: 4px;
	padding: 22px 18px;
	cursor: pointer;
	font-family: inherit;
	text-align: left;
	display: flex;
	flex-direction: column;
	gap: 6px;
	transition: border-color 120ms ease, transform 80ms ease,
	            box-shadow 140ms ease, background-color 120ms ease;
	box-shadow: var(--cfd-shadow-sm);
	min-height: 110px;
}
.cfd-fe__choice:hover {
	border-color: var(--cfd-green);
	background: rgba(131, 188, 66, 0.06);
	box-shadow: 0 4px 14px -4px rgba(31, 77, 17, 0.18);
}
.cfd-fe__choice:active { transform: translateY(1px); }
.cfd-fe__choice-label {
	font-family: var(--cfd-font-head);
	font-size: 22px;
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--cfd-green-dark);
	text-transform: uppercase;
	line-height: 1;
}
.cfd-fe__choice-desc {
	font-size: 13px;
	color: var(--cfd-text-mute);
	line-height: 1.4;
}

/* Phone call CTA (business final + below-min screen) */
.cfd-fe__call {
	padding: 8px 26px 22px 26px;
	text-align: center;
}
.cfd-fe__call-soft {
	font-family: var(--cfd-font-head);
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--cfd-green-dark);
	font-weight: 600;
	margin-bottom: 8px;
}
.cfd-fe__phone {
	display: inline-block;
	font-family: var(--cfd-font-head);
	font-size: 38px;
	font-weight: 700;
	color: var(--cfd-orange);
	text-decoration: none;
	letter-spacing: 0.01em;
	line-height: 1;
	padding: 4px 0;
	transition: color 120ms ease;
}
.cfd-fe__phone:hover { color: var(--cfd-orange-hover); text-decoration: none; }
.cfd-fe__phone--small { font-size: 26px; }
.cfd-fe__call-foot {
	font-size: 12px;
	color: var(--cfd-text-mute);
	margin-top: 10px;
	font-style: italic;
}

.cfd-fe__call-actions {
	padding: 0 26px 22px 26px;
	text-align: center;
}
.cfd-fe__restart {
	background: none;
	border: 1px solid var(--cfd-border-mid);
	border-radius: 3px;
	padding: 9px 18px;
	font-family: var(--cfd-font-head);
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--cfd-text-mute);
	cursor: pointer;
	transition: border-color 120ms ease, color 120ms ease;
}
.cfd-fe__restart:hover {
	border-color: var(--cfd-green);
	color: var(--cfd-green-dark);
}

/* Result-screen meta strip (recap of inputs) */
.cfd-fe__result-meta {
	font-size: 12px;
	color: var(--cfd-text-mute);
	margin-bottom: 14px;
	letter-spacing: 0.04em;
}
.cfd-fe__result-meta strong {
	color: var(--cfd-green-dark);
	font-weight: 700;
}

/* ===== END WIZARD ===== */

/* Hero */
.cfd-fe__hero {
	padding: 26px 26px 18px 26px;
	background: var(--cfd-white);
	border-bottom: 1px solid var(--cfd-border);
}
.cfd-fe__hero h2 {
	font-family: var(--cfd-font-head);
	font-size: 32px;
	line-height: 1;
	margin: 0 0 8px 0;
	color: var(--cfd-text);
	text-transform: uppercase;
	letter-spacing: 0.01em;
	font-weight: 700;
}
.cfd-fe__hero h2 em {
	color: var(--cfd-green);
	font-style: normal;
}
.cfd-fe__hero p {
	margin: 0;
	color: var(--cfd-text-mute);
	font-size: 14px;
	line-height: 1.55;
}

/* Form */
.cfd-fe__form {
	padding: 22px 26px 24px 26px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px 14px;
	background: var(--cfd-off-white);
}
.cfd-fe__field { display: flex; flex-direction: column; gap: 6px; }
.cfd-fe__field--full { grid-column: 1 / -1; }

.cfd-fe label {
	font-family: var(--cfd-font-head);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	color: var(--cfd-green-dark);
}
.cfd-fe label .req { color: var(--cfd-orange); margin-left: 2px; }
.cfd-fe .hint {
	font-size: 12px;
	color: var(--cfd-text-mute);
	margin-top: 2px;
}

.cfd-fe input[type="text"],
.cfd-fe input[type="number"],
.cfd-fe select {
	appearance: none;
	-webkit-appearance: none;
	background: var(--cfd-white);
	border: 1px solid var(--cfd-border-mid);
	color: var(--cfd-text);
	font-family: inherit;
	font-size: 16px;
	font-weight: 500;
	padding: 11px 13px;
	line-height: 1.2;
	border-radius: 3px;
	transition: border-color 120ms ease, box-shadow 120ms ease;
	outline: none;
	width: 100%;
	height: 46px;
	box-shadow: var(--cfd-shadow-sm);
}
.cfd-fe select {
	background-image:
		linear-gradient(45deg, transparent 50%, var(--cfd-green) 50%),
		linear-gradient(135deg, var(--cfd-green) 50%, transparent 50%);
	background-position:
		calc(100% - 18px) 50%,
		calc(100% - 12px) 50%;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
	padding-right: 34px;
	cursor: pointer;
}
.cfd-fe input:focus,
.cfd-fe select:focus {
	border-color: var(--cfd-green);
	box-shadow: 0 0 0 3px rgba(131, 188, 66, 0.28);
}
.cfd-fe input::placeholder { color: var(--cfd-text-soft); font-weight: 400; }

/* Primary submit — dark forest green, matches site */
.cfd-fe__submit {
	grid-column: 1 / -1;
	margin-top: 6px;
	background: var(--cfd-green);
	color: var(--cfd-white);
	border: 1px solid var(--cfd-green-deep);
	font-family: var(--cfd-font-head);
	font-weight: 600;
	font-size: 16px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	padding: 15px 20px;
	cursor: pointer;
	border-radius: 3px;
	transition: background-color 140ms ease, transform 80ms ease;
	width: 100%;
	box-shadow: var(--cfd-shadow-sm);
}
.cfd-fe__submit:hover { background: var(--cfd-green-deep); }
.cfd-fe__submit:active { transform: translateY(1px); }
.cfd-fe__submit[disabled] {
	background: var(--cfd-text-soft);
	border-color: var(--cfd-text-soft);
	cursor: progress;
	opacity: 0.85;
}

/* Loading */
.cfd-fe__loading {
	display: none;
	padding: 20px 26px;
	border-top: 1px solid var(--cfd-border);
	background: rgba(131, 188, 66, 0.10);
	align-items: center;
	gap: 14px;
	font-size: 14px;
	color: var(--cfd-green-dark);
	font-weight: 600;
}
.cfd-fe__loading.is-on { display: flex; }
.cfd-fe__spinner {
	width: 22px; height: 22px;
	border: 3px solid rgba(31, 77, 17, 0.18);
	border-top-color: var(--cfd-green);
	border-radius: 50%;
	animation: cfd-spin 0.8s linear infinite;
	flex: 0 0 auto;
}
@keyframes cfd-spin { to { transform: rotate(360deg); } }

/* Result */
.cfd-fe__result {
	display: none;
	border-top: 1px solid var(--cfd-border);
	background: var(--cfd-white);
	padding: 24px 26px 26px 26px;
}
.cfd-fe__result.is-on { display: block; }

.cfd-fe__result-head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 8px;
	border-bottom: 2px solid var(--cfd-lime);
	padding-bottom: 10px;
	margin-bottom: 18px;
}
.cfd-fe__result-head h3 {
	margin: 0;
	font-family: var(--cfd-font-head);
	font-size: 18px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--cfd-green-dark);
	font-weight: 700;
}
.cfd-fe__refnum {
	font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
	font-size: 11px;
	color: var(--cfd-text-soft);
	letter-spacing: 0.06em;
}

.cfd-fe__metrics {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
	margin-bottom: 18px;
}
.cfd-fe__metric {
	background: var(--cfd-off-white);
	border: 1px solid var(--cfd-border);
	border-top: 3px solid var(--cfd-lime);
	padding: 12px 12px 10px 12px;
	text-align: left;
	border-radius: 2px;
}
.cfd-fe__metric-label {
	font-family: var(--cfd-font-head);
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--cfd-green-dark);
	font-weight: 600;
	margin-bottom: 4px;
}
.cfd-fe__metric-value {
	font-family: var(--cfd-font-head);
	font-size: 24px;
	font-weight: 700;
	line-height: 1;
	color: var(--cfd-text);
}
.cfd-fe__metric-value--mode {
	font-size: 16px;
	line-height: 1.15;
	color: var(--cfd-green-dark);
	letter-spacing: 0.02em;
	text-transform: uppercase;
}
.cfd-fe__metric-sub {
	font-size: 11px;
	color: var(--cfd-text-mute);
	margin-top: 4px;
}

/* Headline price band — dark green, lime accent */
.cfd-fe__price {
	background: var(--cfd-green-dark);
	color: var(--cfd-white);
	padding: 18px 20px;
	margin-bottom: 18px;
	border-radius: 3px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
}
.cfd-fe__price-label {
	font-family: var(--cfd-font-head);
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--cfd-lime);
	font-weight: 600;
}
.cfd-fe__price-range {
	font-family: var(--cfd-font-head);
	font-size: 28px;
	font-weight: 700;
	letter-spacing: 0.02em;
}

.cfd-fe__qualifier {
	border-left: 4px solid var(--cfd-lime);
	background: rgba(131, 188, 66, 0.10);
	padding: 12px 14px;
	margin-bottom: 14px;
	font-size: 14px;
	color: var(--cfd-text);
	line-height: 1.45;
	border-radius: 0 2px 2px 0;
}
.cfd-fe__qualifier.is-warn {
	border-left-color: var(--cfd-warn);
	background: rgba(201, 66, 31, 0.08);
}
.cfd-fe__qualifier strong {
	display: block;
	font-family: var(--cfd-font-head);
	text-transform: uppercase;
	letter-spacing: 0.10em;
	font-size: 12px;
	color: var(--cfd-green-dark);
	margin-bottom: 4px;
	font-weight: 700;
}
.cfd-fe__qualifier.is-warn strong { color: var(--cfd-warn); }

.cfd-fe__notes {
	font-size: 12px;
	color: var(--cfd-text-mute);
	line-height: 1.55;
	margin-bottom: 20px;
	padding: 11px 13px;
	background: var(--cfd-off-white);
	border: 1px solid var(--cfd-border);
	border-radius: 2px;
}

/* "Request a Formal Quote" — orange CTA matching site's "GET A QUOTE" */
.cfd-fe__cta {
	display: inline-block;
	width: 100%;
	text-align: center;
	background: var(--cfd-orange);
	color: var(--cfd-white);
	border: 1px solid var(--cfd-orange-hover);
	padding: 15px 20px;
	font-family: var(--cfd-font-head);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	font-size: 15px;
	text-decoration: none;
	border-radius: 3px;
	transition: background-color 140ms ease, transform 80ms ease;
	box-shadow: var(--cfd-shadow-sm);
}
.cfd-fe__cta:hover {
	background: var(--cfd-orange-hover);
	color: var(--cfd-white);
	text-decoration: none;
}
.cfd-fe__cta:active { transform: translateY(1px); }

.cfd-fe__error {
	display: none;
	margin: 0 26px 20px 26px;
	border-left: 4px solid var(--cfd-warn);
	background: rgba(201, 66, 31, 0.07);
	color: var(--cfd-warn);
	padding: 11px 14px;
	font-size: 13px;
	font-weight: 600;
	border-radius: 0 2px 2px 0;
}
.cfd-fe__error.is-on { display: block; }

/* Footer strip — bright lime to match site's phone bar */
.cfd-fe__foot {
	background: var(--cfd-lime);
	color: var(--cfd-green-dark);
	padding: 10px 26px;
	font-family: var(--cfd-font-head);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 600;
	text-align: center;
}
.cfd-fe__foot span { color: var(--cfd-green-dark); font-weight: 700; }

/* Mobile */
@media (max-width: 520px) {
	.cfd-fe__hero h2 { font-size: 24px; }
	.cfd-fe__form { grid-template-columns: 1fr; padding: 18px; }
	.cfd-fe__metrics { grid-template-columns: 1fr 1fr; }
	.cfd-fe__price-range { font-size: 22px; }
	.cfd-fe__bar { padding: 10px 18px; }
	.cfd-fe__hero { padding: 20px 18px 14px 18px; }
	.cfd-fe__result { padding: 18px; }
	.cfd-fe__error { margin: 0 18px 16px 18px; }
}
