/**
 * Blink n' Smile Price Simulator
 * Flat, dark, no glows / gradients / neon. Scoped under .mss-widget so it neither
 * leaks into Elementor nor inherits theme styles.
 */

.mss-widget {
	--mss-bg: #0e0e0e;
	--mss-surface: #161616;
	--mss-surface-2: #1b1b1b;
	--mss-border: #2a2a2a;
	--mss-accent: #6ec1e4;
	--mss-text: #f0f0f0;
	--mss-muted: #888888;
	--mss-content: #aaaaaa;
	--mss-btn-bg: #1e1e1e;

	font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: var(--mss-text);
	width: 100%;
	box-sizing: border-box;
}

.mss-widget *,
.mss-widget *::before,
.mss-widget *::after {
	box-sizing: border-box;
}

/* --- Elementor / theme leak guards --- */
.mss-widget a {
	color: var(--mss-accent) !important;
	text-decoration: none;
}
.mss-widget a:hover {
	color: var(--mss-text) !important;
}
.mss-widget *:hover {
	color: inherit;
}

/*
 * Themes / Elementor frequently force a background (often red) and a box-shadow
 * on button :hover / :focus. Neutralise that for every button in the widget,
 * then re-assert each button's own background below. !important is required here
 * because the theme rules are themselves !important / higher specificity.
 */
.mss-widget button {
	background-image: none !important;
}
.mss-widget button:hover,
.mss-widget button:focus,
.mss-widget button:active,
.mss-widget button:focus-visible {
	box-shadow: none !important;
	outline: none;
	background-image: none !important;
}

/* Secondary button — scoped with :not() so it never matches a primary button. */
.mss-widget .mss-btn:not(.mss-btn-primary),
.mss-widget .mss-btn:not(.mss-btn-primary):hover,
.mss-widget .mss-btn:not(.mss-btn-primary):focus {
	background-color: var(--mss-btn-bg) !important;
	color: var(--mss-text) !important;
}

/* Primary buttons (start / submit / finish / select). The .mss-btn.mss-btn-primary
   compound selector outranks the secondary rule so the accent fill always wins. */
.mss-widget .mss-btn.mss-btn-primary,
.mss-widget .mss-select-btn {
	background-color: var(--mss-accent) !important;
	color: var(--mss-bg) !important;
}
.mss-widget .mss-btn.mss-btn-primary:hover,
.mss-widget .mss-btn.mss-btn-primary:focus,
.mss-widget .mss-select-btn:hover,
.mss-widget .mss-select-btn:focus {
	background-color: #5cb2d6 !important;
	color: var(--mss-bg) !important;
}

/* Borderless buttons (back link, slider arrows). */
.mss-widget .mss-back,
.mss-widget .mss-back:hover,
.mss-widget .mss-back:focus,
.mss-widget .mss-nav,
.mss-widget .mss-nav:hover,
.mss-widget .mss-nav:focus {
	background-color: transparent !important;
}

/* Choice cards (jaw options, estimator options). Background stays flat on hover;
   only the border changes. The selected state wins via later source order. */
.mss-widget .mss-option,
.mss-widget .mss-option:hover,
.mss-widget .mss-option:focus,
.mss-widget .mss-est-opt,
.mss-widget .mss-est-opt:hover,
.mss-widget .mss-est-opt:focus {
	background-color: var(--mss-surface-2) !important;
}
.mss-widget .mss-option.mss-chosen,
.mss-widget .mss-est-opt.mss-selected {
	background-color: var(--mss-surface) !important;
}

/* Dots. */
.mss-widget .mss-dot,
.mss-widget .mss-dot:hover,
.mss-widget .mss-dot:focus {
	background-color: var(--mss-border) !important;
}
.mss-widget .mss-dot:hover {
	background-color: var(--mss-muted) !important;
}
.mss-widget .mss-dot.mss-active {
	background-color: var(--mss-accent) !important;
}

/* ---------------------------------------------------------------------------
 * Shell
 * ------------------------------------------------------------------------ */
.mss-simulator {
	position: relative;
	width: 100%;
	min-height: 600px;
	background: var(--mss-surface);
	border: 1px solid var(--mss-border);
	padding: 40px;
	display: flex;
	flex-direction: column;
}

/* ---------------------------------------------------------------------------
 * Progress
 * ------------------------------------------------------------------------ */
.mss-progress {
	display: flex;
	align-items: center;
	gap: 28px;
	list-style: none;
	margin: 0 0 36px;
	padding: 0;
	flex-wrap: wrap;
}

.mss-prog {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-weight: 500;
	color: var(--mss-muted);
}

.mss-prog-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border: 1px solid var(--mss-border);
	border-radius: 50%;
	font-size: 11px;
	color: var(--mss-muted);
	background: var(--mss-bg);
}

.mss-prog.mss-active {
	color: var(--mss-text);
}
.mss-prog.mss-active .mss-prog-num {
	background: var(--mss-accent);
	border-color: var(--mss-accent);
	color: var(--mss-bg);
}
.mss-prog.mss-done {
	color: var(--mss-content);
}
.mss-prog.mss-done .mss-prog-num {
	border-color: var(--mss-accent);
	color: var(--mss-accent);
}

/* ---------------------------------------------------------------------------
 * Steps
 * ------------------------------------------------------------------------ */
.mss-steps {
	position: relative;
	flex: 1 1 auto;
}

.mss-step {
	display: none;
	opacity: 0;
	transform: translateX(24px);
	transition: opacity 400ms ease, transform 400ms ease;
}

.mss-step.mss-active {
	display: block;
	opacity: 1;
	transform: translateX(0);
}

.mss-step-head {
	margin-bottom: 20px;
}

/* --- Typography --- */
.mss-eyebrow {
	display: block;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--mss-muted);
	font-weight: 400;
	margin-bottom: 14px;
}

.mss-h2 {
	margin: 0 0 16px;
	font-size: 28px;
	font-weight: 300;
	line-height: 1.25;
	color: var(--mss-text);
}

.mss-lead {
	margin: 0 0 28px;
	font-size: 15px;
	line-height: 1.7;
	color: var(--mss-content);
}

.mss-note {
	margin: 24px 0 0;
	font-size: 13px;
	line-height: 1.7;
	color: var(--mss-muted);
}

.mss-rich {
	font-size: 14px;
	line-height: 1.8;
	color: var(--mss-content);
}
.mss-rich p { margin: 0 0 1em; }
.mss-rich p:last-child { margin-bottom: 0; }

/* --- Callouts (disclaimer / check) --- */
.mss-callout {
	border: 1px solid var(--mss-border);
	border-left: 2px solid var(--mss-accent);
	background: var(--mss-surface-2);
	padding: 18px 20px;
	margin-bottom: 16px;
}
.mss-callout-title {
	margin: 0 0 8px;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-weight: 600;
	color: var(--mss-text);
}
.mss-callout-text {
	margin: 0;
	font-size: 13px;
	line-height: 1.7;
	color: var(--mss-content);
}

/* ---------------------------------------------------------------------------
 * Buttons
 * ------------------------------------------------------------------------ */
.mss-actions {
	margin-top: 32px;
}

.mss-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 46px;
	padding: 0 28px;
	font-family: inherit;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-weight: 500;
	cursor: pointer;
	border: 1px solid var(--mss-border);
	border-radius: 2px;
	background: var(--mss-btn-bg);
	color: var(--mss-text);
	appearance: none;
	-webkit-appearance: none;
	box-shadow: none;
	transition: background 120ms ease, color 120ms ease, border-color 120ms ease;
}
.mss-btn:hover {
	border-color: var(--mss-muted);
	color: var(--mss-text);
}

.mss-btn-primary {
	background: var(--mss-accent);
	border-color: var(--mss-accent);
	color: var(--mss-bg);
}
.mss-btn-primary:hover {
	background: #5cb2d6;
	border-color: #5cb2d6;
	color: var(--mss-bg);
}
.mss-btn:disabled {
	opacity: 0.55;
	cursor: default;
}

.mss-back {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: none;
	border: none;
	padding: 0;
	font-family: inherit;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-weight: 500;
	color: var(--mss-muted);
	cursor: pointer;
	box-shadow: none;
	transition: color 120ms ease;
}
.mss-back::before {
	content: "‹";
	font-size: 16px;
	line-height: 1;
}
.mss-back:hover {
	color: var(--mss-text);
	background: none;
}

/* ---------------------------------------------------------------------------
 * Jaw options
 * ------------------------------------------------------------------------ */
.mss-options {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
	margin-top: 8px;
}

.mss-option {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	min-height: 110px;
	padding: 20px;
	background: var(--mss-surface-2);
	border: 1px solid var(--mss-border);
	border-radius: 2px;
	cursor: pointer;
	font-family: inherit;
	box-shadow: none;
	transition: border-color 120ms ease, background 120ms ease;
}
.mss-option:hover {
	border-color: var(--mss-muted);
}
.mss-option.mss-chosen {
	border-color: var(--mss-accent);
	background: var(--mss-surface);
}
.mss-option-label {
	font-size: 14px;
	font-weight: 400;
	color: var(--mss-text);
	line-height: 1.4;
}

/* ---------------------------------------------------------------------------
 * Model slider (selector)
 * ------------------------------------------------------------------------ */
.mss-slider {
	position: relative;
	display: flex;
	align-items: flex-start;
	gap: 8px;
	width: 100%;
	margin-top: 8px;
}

.mss-track {
	position: relative;
	flex: 1 1 auto;
	width: 100%;
	min-height: 520px;
	background: var(--mss-bg);
	border: 1px solid var(--mss-border);
	overflow: hidden;
}

.mss-slide {
	position: absolute;
	inset: 0;
	display: block;
	opacity: 0;
	transform: translateX(40px);
	transition: opacity 400ms ease, transform 400ms ease;
	pointer-events: none;
	visibility: hidden;
}
.mss-slide.mss-active {
	position: relative;
	opacity: 1;
	transform: translateX(0);
	pointer-events: auto;
	visibility: visible;
}
.mss-slide.mss-leaving {
	opacity: 0;
	transform: translateX(-40px);
}

.mss-viewer-wrap {
	width: 100%;
	background: var(--mss-bg);
	border-bottom: 1px solid var(--mss-border);
}

.mss-model-viewer {
	display: block;
	width: 100%;
	height: 340px;
	background: var(--mss-bg);
	pointer-events: auto;
	--poster-color: transparent;
}

.mss-slide-body {
	padding: 24px;
}
.mss-slide-title {
	margin: 0 0 10px;
	font-size: 18px;
	font-weight: 400;
	color: var(--mss-text);
}
.mss-slide-desc {
	font-size: 14px;
	line-height: 1.8;
	color: var(--mss-content);
	margin-bottom: 20px;
}
.mss-slide-desc p { margin: 0 0 1em; }
.mss-slide-desc p:last-child { margin-bottom: 0; }

.mss-select-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 42px;
	padding: 0 24px;
	font-family: inherit;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-weight: 500;
	cursor: pointer;
	border: 1px solid var(--mss-accent);
	border-radius: 2px;
	background: var(--mss-accent);
	color: var(--mss-bg);
	box-shadow: none;
	transition: background 120ms ease, border-color 120ms ease;
}
.mss-select-btn:hover {
	background: #5cb2d6;
	border-color: #5cb2d6;
	color: var(--mss-bg);
}

/* Arrows */
.mss-nav {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	margin-top: 150px;
	padding: 0;
	background: none;
	border: none;
	color: #444;
	cursor: pointer;
	box-shadow: none;
	transition: color 120ms ease;
}
.mss-nav:hover {
	color: var(--mss-text);
	background: none;
}
.mss-nav:disabled {
	opacity: 0.35;
	cursor: default;
}
.mss-nav svg { display: block; }

/* Dots */
.mss-dots {
	position: absolute;
	left: 50%;
	bottom: 14px;
	transform: translateX(-50%);
	display: flex;
	align-items: center;
	gap: 8px;
	z-index: 2;
}
.mss-dot {
	width: 5px;
	height: 5px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: var(--mss-border);
	cursor: pointer;
	box-shadow: none;
	transition: background 120ms ease;
}
.mss-dot:hover { background: var(--mss-muted); }
.mss-dot.mss-active { background: var(--mss-accent); }
.mss-dot.mss-active:hover { background: var(--mss-accent); }

/* ---------------------------------------------------------------------------
 * Form
 * ------------------------------------------------------------------------ */
.mss-form {
	max-width: 640px;
}
.mss-field-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.mss-field {
	display: block;
	margin-bottom: 16px;
}
.mss-field-label {
	display: block;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--mss-muted);
	margin-bottom: 8px;
}
.mss-field input,
.mss-field textarea {
	width: 100%;
	font-family: inherit;
	font-size: 14px;
	color: var(--mss-text);
	background: var(--mss-bg);
	border: 1px solid var(--mss-border);
	border-radius: 2px;
	padding: 11px 12px;
	box-shadow: none;
	transition: border-color 120ms ease;
}
.mss-field input:focus,
.mss-field textarea:focus {
	outline: none;
	border-color: var(--mss-accent);
}
.mss-field textarea {
	resize: vertical;
	min-height: 60px;
}

/* Honeypot — visually hidden but not display:none (bots skip display:none). */
.mss-hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.mss-checkbox {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 8px 0 4px;
	font-size: 13px;
	color: var(--mss-content);
	cursor: pointer;
}
.mss-checkbox input {
	width: 16px;
	height: 16px;
	accent-color: var(--mss-accent);
}

.mss-form-error {
	display: none;
	margin: 14px 0 0;
	font-size: 13px;
	color: #e06c6c;
}

/* ---------------------------------------------------------------------------
 * Summary (price step)
 * ------------------------------------------------------------------------ */
.mss-summary {
	margin-top: 28px;
	border: 1px solid var(--mss-border);
	background: var(--mss-surface-2);
	padding: 20px 22px;
}
.mss-summary-title {
	display: block;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--mss-muted);
	margin-bottom: 14px;
}
.mss-summary ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.mss-summary li {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 8px 0;
	border-bottom: 1px solid var(--mss-border);
	font-size: 14px;
}
.mss-summary li:last-child { border-bottom: none; }
.mss-summary-key { color: var(--mss-muted); }
.mss-summary-val { color: var(--mss-text); text-align: right; }

/* ---------------------------------------------------------------------------
 * Price estimator
 * ------------------------------------------------------------------------ */
.mss-estimator {
	margin-top: 28px;
}

.mss-est-step {
	padding: 20px 0;
	border-top: 1px solid var(--mss-border);
}
.mss-est-step:first-child {
	border-top: none;
	padding-top: 0;
}

.mss-est-step-head {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 14px;
}
.mss-est-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border: 1px solid var(--mss-border);
	border-radius: 50%;
	font-size: 11px;
	color: var(--mss-muted);
	background: var(--mss-bg);
	flex: 0 0 auto;
}
.mss-est-step-title {
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-weight: 500;
	color: var(--mss-text);
}

/* Step 1 auto row */
.mss-est-auto-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 14px 16px;
	background: var(--mss-surface-2);
	border: 1px solid var(--mss-border);
	border-left: 2px solid var(--mss-accent);
}

/* Option buttons */
.mss-est-options {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}
.mss-est-opt {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	text-align: left;
	padding: 16px 18px;
	background: var(--mss-surface-2);
	border: 1px solid var(--mss-border);
	border-radius: 2px;
	cursor: pointer;
	font-family: inherit;
	box-shadow: none;
	transition: border-color 120ms ease, background 120ms ease;
}
.mss-est-opt:hover {
	border-color: var(--mss-muted);
}
.mss-est-opt.mss-selected {
	border-color: var(--mss-accent);
	background: var(--mss-surface);
}
.mss-est-opt.mss-disabled {
	opacity: 0.4;
	cursor: default;
}
.mss-est-opt.mss-disabled:hover {
	border-color: var(--mss-border);
}
.mss-est-opt-label {
	font-size: 14px;
	color: var(--mss-text);
}
.mss-est-opt-price {
	font-size: 13px;
	color: var(--mss-muted);
	white-space: nowrap;
}
.mss-est-opt.mss-selected .mss-est-opt-price {
	color: var(--mss-accent);
}

.mss-est-locked-note {
	margin: 12px 0 0;
	font-size: 12px;
	color: var(--mss-muted);
}

/* Total */
.mss-est-total {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 16px;
	margin-top: 8px;
	padding: 22px 0 6px;
	border-top: 1px solid var(--mss-border);
}
.mss-est-total-label {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--mss-muted);
}
.mss-est-total-value {
	font-size: 32px;
	font-weight: 300;
	color: var(--mss-text);
}
.mss-est-both-note {
	margin: 0 0 8px;
	font-size: 12px;
	color: var(--mss-accent);
}

.mss-est-result {
	margin-top: 24px;
	padding: 20px 22px;
	border: 1px solid var(--mss-border);
	border-left: 2px solid var(--mss-accent);
	background: var(--mss-surface-2);
}

/*
 * Lock estimator text colours on hover. The option rows are <button>s, so themes
 * try to recolour their text (and the summary text) on hover — pin every label
 * to its intended colour so nothing shifts when the pointer moves over it.
 */
.mss-widget .mss-est-opt:hover .mss-est-opt-label,
.mss-widget .mss-est-opt:focus .mss-est-opt-label {
	color: var(--mss-text) !important;
}
.mss-widget .mss-est-opt:hover .mss-est-opt-price,
.mss-widget .mss-est-opt:focus .mss-est-opt-price {
	color: var(--mss-muted) !important;
}
.mss-widget .mss-est-opt.mss-selected .mss-est-opt-price,
.mss-widget .mss-est-opt.mss-selected:hover .mss-est-opt-price {
	color: var(--mss-accent) !important;
}
.mss-widget .mss-est-step-title,
.mss-widget .mss-est-step-title:hover,
.mss-widget .mss-est-total-value,
.mss-widget .mss-est-total-value:hover,
.mss-widget .mss-summary-val,
.mss-widget .mss-summary-val:hover {
	color: var(--mss-text);
}
.mss-widget .mss-est-total-label,
.mss-widget .mss-est-total-label:hover,
.mss-widget .mss-est-locked-note,
.mss-widget .mss-est-locked-note:hover,
.mss-widget .mss-summary-key,
.mss-widget .mss-summary-key:hover {
	color: var(--mss-muted);
}

/* ---------------------------------------------------------------------------
 * Responsive
 * ------------------------------------------------------------------------ */
@media (max-width: 640px) {
	.mss-simulator { padding: 24px; }
	.mss-h2 { font-size: 22px; }
	.mss-options { grid-template-columns: 1fr; }
	.mss-est-options { grid-template-columns: 1fr; }
	.mss-est-total-value { font-size: 26px; }
	.mss-field-row { grid-template-columns: 1fr; gap: 0; }
	.mss-progress { gap: 14px; }
	.mss-prog-text { display: none; }
	.mss-model-viewer { height: 260px; }
	.mss-nav { margin-top: 110px; width: 28px; }
	.mss-track { min-height: 460px; }
}
