/**
 * Mezonot Calculator Pro – base styles.
 * Modern SaaS / Fintech dashboard aesthetic. Mobile-first.
 * Per-instance theming is injected via CSS variables on the .mezcp root.
 */

.mezcp {
	--mezcp-primary: #4f46e5;
	--mezcp-secondary: #06b6d4;
	--mezcp-bg: #f5f7fb;
	--mezcp-gradient: linear-gradient(135deg, #4f46e5 0%, #06b6d4 100%);
	--mezcp-radius: 24px;
	--mezcp-ink: #0f172a;
	--mezcp-muted: #64748b;
	--mezcp-line: #e2e8f0;
	--mezcp-card: rgba(255, 255, 255, 0.72);
	--mezcp-shadow: 0 20px 45px -20px rgba(15, 23, 42, 0.35);
	--mezcp-shadow-sm: 0 6px 18px -8px rgba(15, 23, 42, 0.25);

	/* Per-element color tokens (overridable from Elementor "צבעים לפי אלמנט").
	   Each falls back to a base token so defaults look identical when unset. */
	--mezcp-title-color: var(--mezcp-ink);
	--mezcp-subtitle-color: var(--mezcp-muted);
	--mezcp-step-heading-color: var(--mezcp-ink);
	--mezcp-step-desc-color: var(--mezcp-muted);
	--mezcp-step-name-color: var(--mezcp-muted);
	--mezcp-dot-bg: #ffffff;
	--mezcp-dot-color: var(--mezcp-ink);
	--mezcp-dot-active-color: var(--mezcp-primary);
	--mezcp-dot-done-bg: var(--mezcp-gradient);
	--mezcp-dot-done-color: #ffffff;
	--mezcp-progress-track-color: var(--mezcp-line);
	--mezcp-progress-fill-color: var(--mezcp-gradient);
	--mezcp-card-bg: var(--mezcp-card);
	--mezcp-label-color: var(--mezcp-ink);
	--mezcp-input-bg: #ffffff;
	--mezcp-input-border-color: var(--mezcp-line);
	--mezcp-input-text: var(--mezcp-ink);
	--mezcp-input-radius: 14px;
	--mezcp-btn-bg: var(--mezcp-gradient);
	--mezcp-btn-text: #ffffff;
	--mezcp-btn-hover-bg: var(--mezcp-btn-bg);
	--mezcp-btn-hover-text: var(--mezcp-btn-text);
	--mezcp-btn-radius: 14px;
	--mezcp-btn-font-size: 1rem;
	--mezcp-btn-ghost-bg: #ffffff;
	--mezcp-btn-ghost-text: var(--mezcp-ink);
	--mezcp-btn-ghost-border: var(--mezcp-line);
	--mezcp-btn-ghost-hover-bg: var(--mezcp-btn-ghost-bg);
	--mezcp-btn-ghost-hover-border: var(--mezcp-primary);
	--mezcp-btn-ghost-hover-text: var(--mezcp-primary);
	--mezcp-amount-bg: var(--mezcp-gradient);
	--mezcp-amount-text: #ffffff;
	--mezcp-cta-bg: var(--mezcp-gradient);
	--mezcp-cta-text: #ffffff;
	--mezcp-cta-border: transparent;
	--mezcp-cta-hover-bg: var(--mezcp-cta-bg);
	--mezcp-cta-hover-text: var(--mezcp-cta-text);
	--mezcp-cta-hover-border: var(--mezcp-cta-border);
	--mezcp-disclaimer-bg: rgba(255, 255, 255, 0.6);
	--mezcp-disclaimer-text: var(--mezcp-muted);
	--mezcp-disclaimer-border: var(--mezcp-line);
	--mezcp-source-text: var(--mezcp-muted);

	box-sizing: border-box;
	max-width: 720px;
	margin-inline: auto;
	padding: clamp(18px, 4vw, 34px);
	background:
		radial-gradient(120% 120% at 100% 0%, rgba(255, 255, 255, 0.6) 0%, transparent 50%),
		var(--mezcp-bg);
	border-radius: var(--mezcp-radius);
	box-shadow: var(--mezcp-shadow);
	color: var(--mezcp-ink);
	font-family: inherit;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
}

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

/* ---------- Header ---------- */
.mezcp-header {
	text-align: center;
	margin-bottom: 22px;
}
.mezcp-title {
	font-size: clamp(1.4rem, 4vw, 1.9rem);
	font-weight: 800;
	margin: 0 0 6px;
	letter-spacing: -0.01em;
	color: var(--mezcp-title-color);
}
.mezcp-subtitle {
	margin: 0;
	color: var(--mezcp-subtitle-color);
	font-size: 0.98rem;
}

/* ---------- Progress ---------- */
.mezcp-progress {
	margin: 22px 0 8px;
}
.mezcp-progress-track {
	height: 8px;
	background: var(--mezcp-progress-track-color);
	border-radius: 999px;
	overflow: hidden;
}
.mezcp-progress-fill {
	height: 100%;
	width: 0;
	background: var(--mezcp-progress-fill-color);
	border-radius: 999px;
	transition: width 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.mezcp-stepper {
	display: flex;
	justify-content: space-between;
	margin-top: 14px;
	gap: 6px;
}
.mezcp-dot {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	font-size: 0.72rem;
	color: var(--mezcp-step-name-color);
	text-align: center;
}
.mezcp-dot-num {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	display: grid;
	place-items: center;
	background: var(--mezcp-dot-bg);
	color: var(--mezcp-dot-color);
	border: 2px solid var(--mezcp-line);
	font-weight: 700;
	transition: all 0.35s ease;
}
.mezcp-dot.is-current .mezcp-dot-num {
	border-color: var(--mezcp-dot-active-color);
	color: var(--mezcp-dot-active-color);
	transform: scale(1.08);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--mezcp-dot-active-color) 16%, transparent);
}
.mezcp-dot.is-done .mezcp-dot-num {
	background: var(--mezcp-dot-done-bg);
	border-color: transparent;
	color: var(--mezcp-dot-done-color);
}
.mezcp-step-label {
	text-align: center;
	font-size: 0.8rem;
	color: var(--mezcp-muted);
	margin-top: 10px;
}

/* ---------- Card / steps ---------- */
.mezcp-card {
	margin-top: 16px;
	position: relative;
}
.mezcp-step {
	display: none;
	background: var(--mezcp-card-bg);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border: 1px solid rgba(255, 255, 255, 0.6);
	border-radius: calc(var(--mezcp-radius) - 6px);
	padding: clamp(16px, 3.5vw, 26px);
	box-shadow: var(--mezcp-shadow-sm);
}
.mezcp-step.is-active {
	display: block;
	animation: mezcp-fade-in 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}
.mezcp-step-heading {
	font-size: 1.15rem;
	font-weight: 700;
	margin: 0 0 4px;
	color: var(--mezcp-step-heading-color);
}
.mezcp-step-desc {
	margin: 0 0 18px;
	color: var(--mezcp-step-desc-color, var(--mezcp-muted));
	font-size: 0.9rem;
}

/* ---------- Fields ---------- */
.mezcp-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 14px;
}
@media (min-width: 560px) {
	.mezcp-grid.cols-2 { grid-template-columns: 1fr 1fr; }
}
.mezcp-field {
	position: relative;
}
.mezcp-field label {
	display: block;
	font-size: 0.86rem;
	font-weight: 600;
	margin-bottom: 6px;
	color: var(--mezcp-label-color);
}
.mezcp-field .mezcp-input,
.mezcp-field select {
	width: 100%;
	padding: 12px 14px;
	font-size: 1rem;
	font-family: inherit;
	color: var(--mezcp-input-text, var(--mezcp-ink));
	background-color: var(--mezcp-input-bg);
	border: 1.5px solid var(--mezcp-input-border-color);
	border-radius: var(--mezcp-input-radius, 14px);
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.05s ease;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
/* Default (LTR) chevron for selects; RTL stylesheet flips it to the left. */
.mezcp-field select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 14px 14px;
	padding-right: 38px;
}
/* Hide the legacy IE/Edge select arrow so only our chevron shows. */
.mezcp-field select::-ms-expand { display: none; }
.mezcp-field .mezcp-input:focus,
.mezcp-field select:focus {
	border-color: var(--mezcp-primary);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--mezcp-primary) 14%, transparent);
}
.mezcp-field.is-valid .mezcp-input,
.mezcp-field.is-valid select {
	border-color: #10b981;
}
.mezcp-field.is-invalid .mezcp-input,
.mezcp-field.is-invalid select {
	border-color: #ef4444;
}
.mezcp-control {
	position: relative;
	display: block;
}
.mezcp-control.has-suffix .mezcp-input {
	padding-left: 42px; /* keep digits clear of the currency mark on the left */
}
.mezcp-suffix {
	position: absolute;
	top: 50%;
	left: 14px;
	right: auto;
	transform: translateY(-50%);
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--mezcp-muted);
	pointer-events: none;
	line-height: 1;
}
.mezcp-error {
	display: block;
	min-height: 1em;
	margin-top: 5px;
	font-size: 0.78rem;
	color: #ef4444;
}
.mezcp-hint {
	font-size: 0.8rem;
	color: var(--mezcp-muted);
	margin-top: 4px;
}

/* ---------- Two-parent columns ---------- */
.mezcp-parent-cols {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}
@media (min-width: 600px) {
	.mezcp-parent-cols { grid-template-columns: 1fr 1fr; }
}
.mezcp-parent-col {
	background: var(--mezcp-input-bg, #fff);
	border: 1.5px solid var(--mezcp-input-border-color, var(--mezcp-line));
	border-radius: calc(var(--mezcp-radius) - 8px);
	padding: 16px;
	display: grid;
	gap: 12px;
	align-content: start;
}
.mezcp-parent-title {
	font-weight: 800;
	font-size: 1rem;
	color: var(--mezcp-step-heading-color, var(--mezcp-ink));
	padding-bottom: 6px;
	border-bottom: 2px solid color-mix(in srgb, var(--mezcp-primary) 30%, transparent);
}
.mezcp-check {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.82rem;
	color: var(--mezcp-label-color, var(--mezcp-ink));
	cursor: pointer;
	line-height: 1.3;
}
.mezcp-check input[type="checkbox"] {
	width: 18px;
	height: 18px;
	accent-color: var(--mezcp-primary);
	flex: 0 0 auto;
	cursor: pointer;
}

/* ---------- Dynamic per-child age fields ---------- */
.mezcp-children-ages > label {
	display: block;
	font-size: 0.86rem;
	font-weight: 600;
	margin-bottom: 8px;
	color: var(--mezcp-label-color);
}
.mezcp-children-ages-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
	gap: 12px;
}
.mezcp-child-age-field {
	position: relative;
	animation: mezcp-fade-in 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.mezcp-child-age-field label {
	font-size: 0.8rem;
}

/* ---------- Buttons ---------- */
.mezcp-nav {
	display: flex;
	gap: 12px;
	margin-top: 20px;
	align-items: center;
	justify-content: space-between;
}
.mezcp-btn {
	appearance: none;
	border: none;
	cursor: pointer;
	font-family: inherit;
	font-size: var(--mezcp-btn-font-size, 1rem);
	font-weight: 700;
	padding: 13px 22px;
	border-radius: var(--mezcp-btn-radius, 14px);
	transition: transform 0.12s ease, box-shadow 0.2s ease, opacity 0.2s ease, background 0.2s ease, color 0.2s ease;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.mezcp-btn:active { transform: translateY(1px) scale(0.99); }
.mezcp-btn-primary {
	background: var(--mezcp-btn-bg);
	color: var(--mezcp-btn-text);
	box-shadow: 0 12px 24px -10px color-mix(in srgb, var(--mezcp-primary) 80%, transparent);
	flex: 1;
	justify-content: center;
}
.mezcp-btn-primary:hover {
	background: var(--mezcp-btn-hover-bg, var(--mezcp-btn-bg));
	color: var(--mezcp-btn-hover-text, var(--mezcp-btn-text));
	box-shadow: 0 16px 30px -10px color-mix(in srgb, var(--mezcp-primary) 80%, transparent);
}
.mezcp-btn-ghost {
	background: var(--mezcp-btn-ghost-bg, #fff);
	color: var(--mezcp-btn-ghost-text, var(--mezcp-ink));
	border: 1.5px solid var(--mezcp-btn-ghost-border, var(--mezcp-line));
}
.mezcp-btn-ghost:hover {
	background: var(--mezcp-btn-ghost-hover-bg, var(--mezcp-btn-ghost-bg));
	border-color: var(--mezcp-btn-ghost-hover-border, var(--mezcp-primary));
	color: var(--mezcp-btn-ghost-hover-text, var(--mezcp-primary));
}

/* Visible formula box. */
.mezcp-formula {
	background: color-mix(in srgb, var(--mezcp-primary) 7%, #fff);
	border: 1px solid color-mix(in srgb, var(--mezcp-primary) 22%, transparent);
	border-radius: 14px;
	padding: 14px 16px;
	margin-bottom: 18px;
	text-align: center;
}
.mezcp-formula-title {
	font-weight: 700;
	font-size: 0.9rem;
	margin-bottom: 8px;
	color: var(--mezcp-ink);
}
.mezcp-formula-eq {
	direction: ltr;
	font-size: clamp(0.95rem, 3.5vw, 1.15rem);
	font-weight: 700;
	line-height: 1.8;
	font-variant-numeric: tabular-nums;
}
.mezcp-formula-eq .mezcp-fnum { color: var(--mezcp-ink); }
.mezcp-formula-eq .mezcp-fop { color: var(--mezcp-muted); margin: 0 2px; }
.mezcp-formula-eq .mezcp-fres {
	color: var(--mezcp-primary);
	background: color-mix(in srgb, var(--mezcp-primary) 12%, transparent);
	padding: 2px 8px;
	border-radius: 8px;
}
.mezcp-formula-legend {
	font-size: 0.78rem;
	color: var(--mezcp-muted);
	margin-top: 8px;
}

/* Result-screen CTA button. */
.mezcp-cta-wrap {
	margin-top: 18px;
	text-align: center;
}
/* When the CTA sits inside the result (amount) box. */
.mezcp-amount .mezcp-cta-wrap {
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid rgba(255, 255, 255, 0.18);
}
.mezcp-cta-icon {
	display: inline-flex;
	align-items: center;
}
.mezcp-cta-icon svg { width: 1.1em; height: 1.1em; fill: currentColor; }
.mezcp-cta-icon i { font-size: 1.05em; }
.mezcp-btn-cta,
.mezcp-btn-cta:link,
.mezcp-btn-cta:visited,
.mezcp-btn-cta:hover,
.mezcp-btn-cta:focus,
.mezcp-btn-cta:active {
	text-decoration: none !important;
	/* !important so the theme's global link color cannot override the chosen one. */
	color: var(--mezcp-cta-text) !important;
}
.mezcp-btn-cta {
	display: inline-flex;
	background: var(--mezcp-cta-bg);
	border: 1.5px solid var(--mezcp-cta-border);
	box-shadow: 0 12px 24px -10px color-mix(in srgb, var(--mezcp-primary) 80%, transparent);
}
.mezcp-btn-cta:hover {
	background: var(--mezcp-cta-hover-bg, var(--mezcp-cta-bg));
	color: var(--mezcp-cta-hover-text, var(--mezcp-cta-text)) !important;
	border-color: var(--mezcp-cta-hover-border, var(--mezcp-cta-border));
	box-shadow: 0 16px 30px -10px color-mix(in srgb, var(--mezcp-primary) 80%, transparent);
}
.mezcp-btn[disabled] { opacity: 0.7; cursor: default; }
.mezcp-btn.is-loading { position: relative; color: transparent; }
.mezcp-btn.is-loading::after {
	content: "";
	position: absolute;
	inset: 0;
	margin: auto;
	width: 18px;
	height: 18px;
	border: 2.5px solid rgba(255, 255, 255, 0.5);
	border-top-color: #fff;
	border-radius: 50%;
	animation: mezcp-spin 0.7s linear infinite;
}

/* ---------- Summary ---------- */
.mezcp-verdict {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px 18px;
	border-radius: 16px;
	font-weight: 700;
	margin-bottom: 18px;
}
.mezcp-verdict.is-eligible {
	background: color-mix(in srgb, #10b981 12%, #fff);
	color: #047857;
}
.mezcp-verdict.is-not {
	background: color-mix(in srgb, #ef4444 12%, #fff);
	color: #b91c1c;
}
.mezcp-verdict-icon {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: grid;
	place-items: center;
	color: #fff;
	font-size: 1.1rem;
	flex: 0 0 auto;
}
.mezcp-verdict.is-eligible .mezcp-verdict-icon { background: #10b981; }
.mezcp-verdict.is-not .mezcp-verdict-icon { background: #ef4444; }

.mezcp-amount {
	text-align: center;
	padding: 26px 18px;
	border-radius: 18px;
	background: var(--mezcp-amount-bg);
	color: var(--mezcp-amount-text);
	margin-bottom: 18px;
	box-shadow: var(--mezcp-shadow-sm);
}
.mezcp-amount-label { font-size: 0.9rem; opacity: 0.92; }
.mezcp-amount-value {
	font-size: clamp(2.2rem, 9vw, 3rem);
	font-weight: 800;
	line-height: 1.1;
	margin: 4px 0;
	/* Force the ₪ to sit on the visual LEFT of the number. Markup order is
	   number then currency; an explicit LTR flex row + reverse puts the
	   currency on the left and the number on the right, deterministically
	   (independent of the surrounding RTL inline flow that mis-placed it). */
	display: flex;
	direction: ltr;
	flex-direction: row-reverse;
	align-items: baseline;
	justify-content: center;
	gap: 4px;
}
.mezcp-amount-value .mezcp-cur { font-size: 0.55em; margin: 0; opacity: 0.9; color: inherit; }
.mezcp-amount-sub { font-size: 0.85rem; opacity: 0.9; }
.mezcp-estimate-flag {
	margin-top: 10px;
	font-size: 0.78rem;
	background: rgba(255, 255, 255, 0.18);
	padding: 6px 10px;
	border-radius: 10px;
	display: inline-block;
}

.mezcp-reasons {
	list-style: none;
	padding: 0;
	margin: 0 0 18px;
	display: grid;
	gap: 8px;
}
.mezcp-reasons li {
	background: #fff;
	border: 1px solid var(--mezcp-line);
	border-radius: 12px;
	padding: 10px 14px;
	font-size: 0.9rem;
	position: relative;
	padding-inline-start: 30px;
}
.mezcp-reasons li::before {
	content: "•";
	position: absolute;
	inset-inline-start: 12px;
	color: var(--mezcp-primary);
	font-weight: 800;
}

.mezcp-breakdown {
	background: #fff;
	border: 1px solid var(--mezcp-line);
	border-radius: 16px;
	padding: 6px 16px;
	margin-bottom: 18px;
}
.mezcp-breakdown-title {
	font-weight: 700;
	padding: 12px 0 6px;
	font-size: 0.95rem;
}
.mezcp-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 11px 0;
	border-top: 1px dashed var(--mezcp-line);
	font-size: 0.92rem;
}
.mezcp-row-label { color: var(--mezcp-muted); }
.mezcp-row-value { font-weight: 600; white-space: nowrap; }
.mezcp-row.is-strong {
	font-size: 1.05rem;
	border-top: 2px solid var(--mezcp-ink);
	margin-top: 4px;
}
.mezcp-row.is-strong .mezcp-row-label { color: var(--mezcp-ink); font-weight: 700; }
.mezcp-num { font-variant-numeric: tabular-nums; }
.mezcp-cur { margin-inline-start: 3px; color: var(--mezcp-muted); font-size: 0.85em; }

.mezcp-debug {
	background: #0f172a;
	color: #e2e8f0;
	border-radius: 14px;
	padding: 12px 16px;
	font-size: 0.8rem;
	margin-bottom: 18px;
}
.mezcp-debug summary { cursor: pointer; font-weight: 700; margin-bottom: 8px; }
.mezcp-debug pre { white-space: pre-wrap; word-break: break-word; margin: 0; }

/* ---------- Disclaimer ---------- */
.mezcp-disclaimer {
	font-size: 0.78rem;
	color: var(--mezcp-disclaimer-text, var(--mezcp-muted));
	line-height: 1.5;
	background: var(--mezcp-disclaimer-bg, rgba(255, 255, 255, 0.6));
	border: 1px dashed var(--mezcp-disclaimer-border, var(--mezcp-line));
	border-radius: 12px;
	padding: 12px 14px;
	margin-top: 18px;
}
.mezcp-source-note {
	font-size: 0.72rem;
	color: var(--mezcp-source-text, var(--mezcp-muted));
	text-align: center;
	margin-top: 10px;
	opacity: 0.85;
}

/* ---------- Animations ---------- */
@keyframes mezcp-fade-in {
	from { opacity: 0; transform: translateY(10px); }
	to { opacity: 1; transform: translateY(0); }
}
@keyframes mezcp-spin { to { transform: rotate(360deg); } }
@keyframes mezcp-shake {
	10%, 90% { transform: translateX(-2px); }
	20%, 80% { transform: translateX(4px); }
	30%, 50%, 70% { transform: translateX(-7px); }
	40%, 60% { transform: translateX(7px); }
}
.mezcp-shake { animation: mezcp-shake 0.5s cubic-bezier(0.36, 0.07, 0.19, 0.97); }
@keyframes mezcp-pop {
	0% { transform: scale(0.97); opacity: 0.6; }
	60% { transform: scale(1.01); }
	100% { transform: scale(1); opacity: 1; }
}
.mezcp-pop { animation: mezcp-pop 0.5s cubic-bezier(0.22, 1, 0.36, 1); }

@media (prefers-reduced-motion: reduce) {
	.mezcp *, .mezcp *::before, .mezcp *::after {
		animation-duration: 0.001ms !important;
		transition-duration: 0.001ms !important;
	}
}
