/**
 * Calculator Rates Block Frontend Styles
 */

:root {
	/* Colors */
	--calc-primary-color: #2E4A54;
	--calc-dark-color: #1d2327;
	--calc-gray-color: #666;
	--calc-light-gray: #eee;
	--calc-light-bg: #f7f7f6;
	--calc-white: #fff;
	--calc-border-color: #686e77;
	--calc-spinner-bg: #f3f3f3;
	--calc-tooltip-bg: #1d2327;
	--calc-tooltip-text: #fff;

	/* Spacing */
	--calc-spacing-xs: 10px;
	--calc-spacing-sm: 15px;
	--calc-spacing-md: 20px;
	--calc-spacing-lg: 30px;
	--calc-spacing-xl: 40px;
	--calc-spacing-xxl: 60px;

	/* Font Sizes */
	--calc-font-size-xs: 12px;
	--calc-font-size-sm: 13px;
	--calc-font-size-base: 14px;
	--calc-font-size-md: 16px;
	--calc-font-size-lg: 28px;
	--calc-font-size-amount: clamp(1.25rem, 0.8125rem + 2.1875vw, 3rem);
	--calc-font-size-label: clamp(0.75rem, 0.6875rem + 0.3125vw, 1rem);

	/* Font Weights */
	--calc-font-weight-normal: 400;
	--calc-font-weight-medium: 500;
	--calc-font-weight-semibold: 600;
	--calc-font-weight-bold: 700;

	/* Font Families */
	--calc-font-primary: 'Rubik', sans-serif;
	--calc-font-secondary: 'Merriweather', serif;

	/* Transitions */
	--calc-transition-fast: 0.2s ease;
	--calc-transition-normal: 0.3s ease;

	/* Z-Index */
	--calc-z-loading: 1000;
	--calc-z-tooltip: 10000;

	/* Border Radius */
	--calc-radius-none: 0;
	--calc-radius-sm: 4px;
	--calc-radius-md: 6px;
	--calc-radius-full: 50%;

	/* Layout */
	--calc-container-gap: 60px;
	--calc-container-gap-mobile: 30px;
	--calc-results-gap: 10px;
	--calc-comparison-gap: 20px;
	--calc-sticky-top: 20px;
	--calc-wrapper-margin: 60px 0;
	--calc-wrapper-margin-mobile: 40px 0;
	--calc-max-width-wide: 1200px;

	/* Loading Overlay */
	--calc-loading-bg: rgba(255, 255, 255, 0.95);
	--calc-spinner-size: 40px;
	--calc-spinner-border: 4px;
}

.calculator-rates-block-wrapper {
	margin: var(--calc-wrapper-margin);
	position: relative;
}

/* Loading Indicator */
.calculator-rates-loading-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: var(--calc-loading-bg);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	z-index: var(--calc-z-loading);
	transition: opacity var(--calc-transition-normal), visibility var(--calc-transition-normal);
}

.calculator-rates-block-wrapper:not(.calculator-rates-loading) .calculator-rates-loading-overlay {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.calculator-rates-spinner {
	width: var(--calc-spinner-size);
	height: var(--calc-spinner-size);
	border: var(--calc-spinner-border) solid var(--calc-spinner-bg);
	border-top: var(--calc-spinner-border) solid var(--calc-dark-color);
	border-radius: var(--calc-radius-full);
	animation: calculator-rates-spin 1s linear infinite;
	margin-bottom: var(--calc-spacing-sm);
}

@keyframes calculator-rates-spin {
	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}

.calculator-rates-loading-overlay p {
	margin: 0;
	color: var(--calc-dark-color);
	font-size: var(--calc-font-size-md);
	font-weight: var(--calc-font-weight-bold);
	font-family: var(--calc-font-secondary);
}

.calculator-rates-block-container {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--calc-container-gap);
	align-items: start;
}

.calculator-rates-block-form {
	position: sticky;
	top: var(--calc-sticky-top);
}

.calculator-rates-form-header {
	margin-bottom: var(--calc-spacing-lg);
}

.calculator-rates-form-header h2 {
	margin-top: 0;
	margin-bottom: 0;
	color: var(--calc-primary-color);
	font-size: var(--calc-font-size-lg);
	font-weight: var(--calc-font-weight-semibold);
}

.calculator-rates-block-results {
	background: var(--calc-white);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--calc-results-gap);
	align-items: start;
}

.calculator-rates-results-header h2 {
	margin-top: 0;
	margin-bottom: var(--calc-spacing-lg);
	color: var(--calc-primary-color);
	font-size: var(--calc-font-size-lg);
	font-weight: var(--calc-font-weight-semibold);
}

.calculator-rates-results-header {
	grid-column: 1 / -1;
}

.calculator-rates-results-comparison {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--calc-comparison-gap);
	grid-column: 1 / -1;
}

.calculator-rates-result-box {
	background: var(--calc-light-bg);
	border-radius: var(--calc-radius-none);
	padding: var(--calc-spacing-md) var(--calc-spacing-md);
	text-align: center;
	transition: transform var(--calc-transition-fast);
	border: 1px solid var(--calc-border-color);
}

.calculator-rates-result-box .result-title {
	font-family: var(--calc-font-secondary);
	font-size: clamp(1.125rem, 0.875rem + 1.25vw, 1.5rem);
	font-weight: var(--calc-font-weight-bold);
	color: var(--calc-primary-color);
	margin-bottom: var(--calc-spacing-xs);
	line-height: 1.2;
}

.calculator-rates-result-box .result-amount {
	font-size: var(--calc-font-size-amount);
	font-weight: var(--calc-font-weight-bold);
	color: var(--calc-primary-color);
	margin-bottom: var(--calc-spacing-xs);
	line-height: 1.2;
}

.calculator-rates-result-box .result-label {
	font-size: var(--calc-font-size-label);
	color: var(--calc-gray-color);
	font-weight: var(--calc-font-weight-medium);
	font-family: var(--calc-font-primary);
}

.calculator-rates-residual-info {
	display: flex;
	align-items: center;
	gap: var(--calc-spacing-xs);
	grid-column: 2;
	justify-self: start;
	width: 100%;
	text-align: center;
	justify-content: center;
}

.calculator-rates-residual-info .residual-text {
	font-size: var(--calc-font-size-base);
	color: var(--calc-dark-color);
	font-weight: var(--calc-font-weight-medium);
}

.calculator-rates-residual-info .residual-icon {
	cursor: help;
	font-size: var(--calc-font-size-md);
	opacity: 0.6;
	position: relative;
	display: inline-block;
	isolation: isolate;
}

.calculator-rates-residual-info .residual-icon .residual-tooltip {
	visibility: hidden;
	opacity: 0;
	position: absolute;
	top: 125%;
	left: 50%;
	transform: translateX(-50%);
	background-color: var(--calc-tooltip-bg);
	color: var(--calc-tooltip-text);
	text-align: center;
	padding: var(--calc-spacing-xs) var(--calc-spacing-xs);
	border-radius: var(--calc-radius-md);
	font-size: var(--calc-font-size-sm);
	font-weight: var(--calc-font-weight-normal);
	white-space: normal;
	max-width: 250px;
	width: max-content;
	min-width: 150px;
	z-index: var(--calc-z-tooltip);
	transition: opacity var(--calc-transition-fast), visibility var(--calc-transition-fast);
	pointer-events: none;
	margin-top: var(--calc-spacing-xs);
	word-wrap: break-word;
	box-sizing: border-box;
	filter: none;
	font-family: var(--calc-font-primary);
}

/* Adjust tooltip position to stay within viewport */
.calculator-rates-residual-info .residual-icon .residual-tooltip {
	left: 50%;
	transform: translateX(-50%);
}

/* Ensure tooltip stays on screen - adjust if too far right */
@media (min-width: 768px) {
	.calculator-rates-residual-info .residual-icon .residual-tooltip {
		left: auto;
		right: 0;
		transform: none;
	}

	.calculator-rates-residual-info .residual-icon .residual-tooltip::after {
		left: auto;
		right: var(--calc-spacing-sm);
		transform: none;
	}
}

/* Increase parent icon opacity on hover so tooltip is fully visible */
.calculator-rates-residual-info .residual-icon:hover {
	opacity: 1;
}

.calculator-rates-residual-info .residual-icon:hover .residual-tooltip {
	visibility: visible;
	opacity: 1 !important;
	background-color: var(--calc-tooltip-bg) !important;
}

.calculator-rates-block-content {
	padding-top: var(--calc-spacing-md);
	border-top: 1px solid var(--calc-light-gray);
	grid-column: 1 / -1;
}

/* Alignment support */
.calculator-rates-block-wrapper.alignwide {
	max-width: var(--calc-max-width-wide);
	margin-left: auto;
	margin-right: auto;
}

.calculator-rates-block-wrapper.alignfull {
	max-width: 100%;
	width: 100%;
}

/* Responsive */
@media screen and (max-width: 1024px) {
	.calculator-rates-block-wrapper {
		margin: var(--calc-wrapper-margin-mobile);
	}

	.calculator-rates-block-container {
		grid-template-columns: 1fr;
		gap: var(--calc-container-gap-mobile);
	}

	.calculator-rates-block-form {
		position: static;
	}
}


/* Hide */
#field_56_1 .instruction,
#field_56_18 .instruction,
#gform_wrapper_56 .partial_entry_warning {
	display: none;
}

.calculator-rates-block-wrapper .gfield--input-type-html {
	font-size: clamp(0.75rem, 0.75rem + ((1vw - 0.2rem) * 0.417), 1rem);
}