/**
 * IceRink Master Tools - Premium Design System
 *
 * @package IceRink_Master_Tools
 * @version 2.0.0
 */

/* =============================================
   CORE DESIGN TOKENS
   ============================================= */

:root {
	--ir-primary-blue: #0056b3;
	--ir-accent-blue: #00a8e8;
	--ir-success-green: #28a745;
	--ir-text-dark: #2c3e50;
	--ir-text-light: #7f8c8d;
	--ir-bg-light: #f8fbfd;
	--ir-white: #ffffff;
	--ir-shadow-soft: 0 10px 30px -5px rgba(0, 86, 179, 0.1);
	--ir-shadow-hover: 0 20px 40px -5px rgba(0, 86, 179, 0.2);
	--ir-radius-lg: 16px;
	--ir-radius-md: 12px;
	--ir-font-stack: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* =============================================
   GLOBAL RESET FOR TOOL WRAPPER
   ============================================= */

.icerink-tool-wrapper {
	font-family: var(--ir-font-stack);
	color: var(--ir-text-dark);
	line-height: 1.6;
	box-sizing: border-box;
}

.icerink-tool-wrapper * {
	box-sizing: border-box;
}


/* =============================================
   CARD COMPONENT
   ============================================= */

.ir-card {
	background: var(--ir-white);
	border-radius: var(--ir-radius-lg);
	box-shadow: var(--ir-shadow-soft);
	padding: 40px;
	max-width: 800px;
	margin: 20px auto;
	border: 1px solid #eef2f7;
}

.ir-card-header {
	text-align: center;
	margin-bottom: 35px;
}

.ir-card-title {
	font-size: 28px;
	font-weight: 700;
	color: var(--ir-text-dark);
	margin: 0 0 8px 0;
}

.ir-card-subtitle {
	font-size: 16px;
	color: var(--ir-text-light);
	margin: 0;
}

/* =============================================
   SECTIONS
   ============================================= */

.ir-section {
	margin-bottom: 30px;
}

.ir-section-title {
	font-size: 14px;
	font-weight: 600;
	color: var(--ir-text-light);
	text-transform: uppercase;
	letter-spacing: 1px;
	margin: 0 0 20px 0;
	padding-bottom: 10px;
	border-bottom: 1px solid #eef2f7;
}

/* =============================================
   INPUT GRID
   ============================================= */

.ir-input-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 25px;
	margin-bottom: 30px;
}

@media (max-width: 768px) {
	.ir-input-grid {
		grid-template-columns: 1fr;
	}
}

/* =============================================
   FIELD GROUPS & INPUTS
   ============================================= */

.ir-field-group {
	display: flex;
	flex-direction: column;
}

.ir-field-group label {
	display: block;
	font-weight: 600;
	margin-bottom: 10px;
	color: var(--ir-text-dark);
	font-size: 15px;
}

/* Field hint text */
.ir-field-hint {
	display: block;
	margin-top: 8px;
	font-size: 12px;
	color: var(--ir-text-light);
	line-height: 1.4;
}

.ir-input-wrapper {
	position: relative;
	display: flex;
	align-items: center;
	min-width: 0;
}

/* =============================================
   PREMIUM INPUT STYLING
   ============================================= */

.ir-input-field {
	width: 100%;
	min-width: 0;
	flex: 1;
	padding: 15px 20px;
	border: 1px solid #e0e6ed;
	border-radius: var(--ir-radius-md);
	font-size: 16px;
	font-family: var(--ir-font-stack);
	font-weight: 600;
	color: #2d3748;
	background: #f8f9fa;
	transition: all 0.2s ease;
	font-variant-numeric: tabular-nums;
	text-overflow: clip;
	overflow: visible;
}

.ir-input-field:focus {
	border-color: var(--ir-primary-blue);
	background: var(--ir-white);
	box-shadow: 0 0 0 4px rgba(0, 86, 179, 0.1);
	outline: none;
}

.ir-input-field::placeholder {
	color: #a0aec0;
	font-weight: 400;
}

.ir-input-large {
	font-size: 22px;
	font-weight: 700;
	padding: 16px 55px 16px 18px;
	text-align: left;
	color: var(--ir-primary-blue);
}

.ir-input-suffix {
	position: absolute;
	right: 18px;
	font-size: 15px;
	font-weight: 600;
	color: var(--ir-text-light);
	pointer-events: none;
}

/* Select Styling */
.ir-select {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237f8c8d' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	padding-right: 50px;
	cursor: pointer;
}


/* =============================================
   RADIO CARDS
   ============================================= */

.ir-radio-cards {
	display: flex;
	gap: 12px;
}

.ir-radio-card {
	flex: 1;
	cursor: pointer;
}

.ir-radio-card input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.ir-radio-card-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 20px 15px;
	background: var(--ir-white);
	border: 2px solid #e0e7eb;
	border-radius: var(--ir-radius-md);
	transition: all 0.3s ease;
	text-align: center;
}

.ir-radio-card input:checked + .ir-radio-card-inner {
	border-color: var(--ir-accent-blue);
	background: rgba(0, 168, 232, 0.05);
	box-shadow: 0 0 0 4px rgba(0, 168, 232, 0.1);
}

.ir-radio-card:hover .ir-radio-card-inner {
	border-color: var(--ir-accent-blue);
}

.ir-radio-icon {
	font-size: 28px;
	margin-bottom: 8px;
}

.ir-radio-label {
	font-size: 14px;
	font-weight: 600;
	color: var(--ir-text-dark);
}

/* =============================================
   RESULT BOX
   ============================================= */

.ir-result-box {
	background: var(--ir-bg-light);
	padding: 35px 30px;
	border-radius: var(--ir-radius-md);
	text-align: center;
	border: 2px solid var(--ir-accent-blue);
	margin-top: 10px;
}

.ir-result-title {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: var(--ir-text-light);
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 8px;
}

.ir-result-value {
	font-size: 36px;
	font-weight: 800;
	color: var(--ir-primary-blue);
	display: block;
	margin-bottom: 8px;
	line-height: 1.2;
}

.ir-result-value.ir-placeholder {
	font-size: 18px;
	font-weight: 500;
	color: var(--ir-text-light);
}

.ir-result-meta {
	font-size: 14px;
	color: var(--ir-text-light);
	margin-bottom: 20px;
}

/* =============================================
   BUTTONS
   ============================================= */

.ir-btn-primary {
	background: var(--ir-accent-blue);
	color: white;
	padding: 18px 35px;
	border: none;
	border-radius: var(--ir-radius-md);
	font-size: 18px;
	font-weight: 700;
	font-family: var(--ir-font-stack);
	cursor: pointer;
	width: 100%;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.ir-btn-primary:hover:not(:disabled) {
	transform: translateY(-3px);
	box-shadow: var(--ir-shadow-hover);
	background: #0097d1;
}

.ir-btn-primary:active:not(:disabled) {
	transform: translateY(-1px);
}

.ir-btn-primary:disabled {
	background: #b0bec5;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

/* =============================================
   RESPONSIVE ADJUSTMENTS
   ============================================= */

@media (max-width: 768px) {
	.ir-card {
		padding: 25px 20px;
		margin: 10px;
		border-radius: var(--ir-radius-md);
	}

	.ir-card-title {
		font-size: 22px;
	}

	.ir-input-large {
		font-size: 18px;
		padding: 14px 50px 14px 14px;
	}

	.ir-result-value {
		font-size: 28px;
	}

	.ir-radio-cards {
		flex-direction: column;
	}

	.ir-btn-primary {
		padding: 16px 25px;
		font-size: 16px;
	}

	.ir-input-transparent {
		font-size: 18px;
		max-width: 100px;
	}

	.ir-input-transparent.ir-input-wide {
		max-width: 120px;
	}
}


/* =============================================
   ROI CALCULATOR - FINANCIAL DASHBOARD
   ============================================= */

.ir-dashboard-layout .ir-card {
	max-width: 1000px;
}

.icerink-roi-calculator {
	max-width: 1000px;
}

/* Dashboard Grid Layout */
.ir-dashboard-grid {
	display: grid;
	grid-template-columns: 1.2fr 0.8fr;
	gap: 35px;
	align-items: start;
}

@media (max-width: 900px) {
	.ir-dashboard-grid {
		grid-template-columns: 1fr;
		gap: 30px;
	}
}

/* =============================================
   INPUTS PANEL (Left Column)
   ============================================= */

.ir-inputs-panel {
	display: flex;
	flex-direction: column;
	gap: 25px;
}

/* Parameter Cards */
.ir-param-card {
	background: var(--ir-white);
	border: 1px solid #e8ecf1;
	border-radius: var(--ir-radius-md);
	padding: 25px;
}

.ir-param-title {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 16px;
	font-weight: 700;
	color: var(--ir-text-dark);
	margin: 0 0 20px 0;
	padding-bottom: 15px;
	border-bottom: 1px solid #eef2f7;
}

.ir-param-icon {
	font-size: 20px;
}

/* =============================================
   CONTROL GROUPS (Modern Input Style)
   ============================================= */

.ir-control-group {
	background: #f4f6f9;
	padding: 18px 20px;
	border-radius: 12px;
	margin-bottom: 16px;
	border: 2px solid transparent;
	transition: all 0.2s ease;
}

.ir-control-group:last-child {
	margin-bottom: 0;
}

.ir-control-group:focus-within {
	background: var(--ir-white);
	border-color: var(--ir-accent-blue);
	box-shadow: 0 4px 12px rgba(0, 168, 232, 0.1);
}

.ir-control-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 12px;
}

.ir-control-header label {
	font-size: 14px;
	font-weight: 600;
	color: var(--ir-text-dark);
	margin: 0;
}

.ir-input-suffix-wrapper {
	display: flex;
	align-items: center;
	gap: 4px;
	min-width: 0;
	flex-shrink: 0;
}

/* Dashboard Transparent Input (inside control groups) */
.ir-input-transparent {
	background: transparent;
	border: none;
	text-align: right;
	font-size: 20px;
	font-weight: 700;
	color: var(--ir-primary-blue);
	min-width: 60px;
	width: auto;
	max-width: 120px;
	padding: 0;
	font-family: var(--ir-font-stack);
	font-variant-numeric: tabular-nums;
	text-overflow: clip;
	overflow: visible;
}

.ir-input-transparent:focus {
	outline: none;
}

.ir-input-transparent.ir-input-wide {
	min-width: 80px;
	max-width: 140px;
}

/* Remove spinner buttons from number inputs */
.ir-input-transparent::-webkit-outer-spin-button,
.ir-input-transparent::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.ir-input-transparent[type="number"] {
	-moz-appearance: textfield;
	appearance: textfield;
}

.ir-suffix {
	font-size: 14px;
	font-weight: 600;
	color: var(--ir-text-light);
	white-space: nowrap;
}

.ir-control-hint {
	display: block;
	margin-top: 10px;
	font-size: 12px;
	color: var(--ir-text-light);
}

/* =============================================
   MODERN RANGE SLIDER
   ============================================= */

.ir-range-modern {
	-webkit-appearance: none;
	appearance: none;
	width: 100%;
	height: 6px;
	background: #dfe6ed;
	border-radius: 3px;
	outline: none;
	cursor: pointer;
	transition: background 0.2s ease;
}

.ir-range-modern::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 22px;
	height: 22px;
	background: var(--ir-accent-blue);
	border: 3px solid var(--ir-white);
	border-radius: 50%;
	cursor: pointer;
	box-shadow: 0 2px 8px rgba(0, 168, 232, 0.4);
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.ir-range-modern::-webkit-slider-thumb:hover {
	transform: scale(1.15);
	box-shadow: 0 4px 12px rgba(0, 168, 232, 0.5);
}

.ir-range-modern::-moz-range-thumb {
	width: 22px;
	height: 22px;
	background: var(--ir-accent-blue);
	border: 3px solid var(--ir-white);
	border-radius: 50%;
	cursor: pointer;
	box-shadow: 0 2px 8px rgba(0, 168, 232, 0.4);
	transition: transform 0.15s ease;
}

.ir-range-modern::-moz-range-thumb:hover {
	transform: scale(1.15);
}

.ir-range-modern::-moz-range-track {
	height: 6px;
	border-radius: 3px;
	background: #dfe6ed;
}

/* =============================================
   RESULTS PANEL (Right Column - Sticky)
   ============================================= */

.ir-results-panel {
	background: var(--ir-white);
	padding: 30px;
	border-radius: var(--ir-radius-lg);
	box-shadow: 0 15px 40px -10px rgba(0, 0, 0, 0.12);
	border: 1px solid #e8ecf1;
	position: sticky;
	top: 20px;
}

@media (max-width: 900px) {
	.ir-results-panel {
		position: static;
	}
}

/* Hero Metrics */
.ir-hero-metric {
	text-align: center;
	margin-bottom: 25px;
	padding-bottom: 25px;
	border-bottom: 1px solid #eef2f7;
}

.ir-hero-metric:last-of-type {
	border-bottom: none;
	margin-bottom: 20px;
	padding-bottom: 20px;
}

.ir-hero-label {
	display: block;
	font-size: 12px;
	text-transform: uppercase;
	color: #8898aa;
	letter-spacing: 1px;
	font-weight: 600;
	margin-bottom: 8px;
}

.ir-hero-value {
	display: block;
	font-size: 38px;
	font-weight: 800;
	line-height: 1.1;
	font-variant-numeric: tabular-nums;
	transition: color 0.2s ease;
}

.ir-profit-value {
	color: var(--ir-success-green);
}

.ir-profit-value.negative {
	color: #dc3545;
}

.ir-breakeven-value {
	color: var(--ir-primary-blue);
	font-size: 32px;
}

.ir-breakeven-value.negative {
	color: #dc3545;
	font-size: 22px;
}

/* Secondary Stats Grid */
.ir-secondary-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	margin-bottom: 20px;
}

.ir-mini-stat {
	background: #f8f9fa;
	padding: 16px 12px;
	border-radius: 10px;
	text-align: center;
}

.ir-mini-label {
	display: block;
	font-size: 11px;
	text-transform: uppercase;
	color: #8898aa;
	letter-spacing: 0.5px;
	font-weight: 600;
	margin-bottom: 6px;
}

.ir-mini-value {
	display: block;
	font-size: 18px;
	font-weight: 700;
	color: var(--ir-text-dark);
	font-variant-numeric: tabular-nums;
}

.ir-mini-profit {
	color: var(--ir-success-green);
}

.ir-mini-profit.negative {
	color: #dc3545;
}

/* ROI Warning */
.ir-roi-warning {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	margin-bottom: 20px;
	padding: 14px 16px;
	background: #fff5f5;
	border: 1px solid #feb2b2;
	border-radius: var(--ir-radius-md);
	color: #c53030;
	font-size: 13px;
	font-weight: 600;
}

.ir-warning-icon {
	font-size: 16px;
}

/* CTA Button with Icon */
.ir-btn-cta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
}

.ir-btn-icon {
	font-size: 18px;
}

/* Secondary Button */
.ir-btn-secondary {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	margin-top: 12px;
	padding: 14px 20px;
	background: #fff;
	color: var(--ir-primary-blue);
	border: 2px solid var(--ir-primary-blue);
	border-radius: 12px;
	font-size: 16px;
	font-weight: 700;
	font-family: var(--ir-font-stack);
	cursor: pointer;
	transition: all 0.2s ease;
}

.ir-btn-secondary:hover {
	background: #f0f7ff;
	color: var(--ir-primary-blue);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.ir-btn-secondary:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

/* =============================================
   ROI RESPONSIVE ADJUSTMENTS
   ============================================= */

@media (max-width: 600px) {
	.ir-hero-value {
		font-size: 32px;
	}

	.ir-breakeven-value {
		font-size: 26px;
	}

	.ir-secondary-grid {
		grid-template-columns: 1fr;
		gap: 10px;
	}

	.ir-control-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
	}

	.ir-input-suffix-wrapper {
		align-self: flex-end;
	}

	.ir-input-transparent {
		font-size: 18px;
	}
}


/* =============================================
   RADIO CARD GROUP (Energy & Recommender)
   ============================================= */

.ir-radio-card-group {
	display: flex;
	gap: 20px;
}

.ir-radio-card-option {
	flex: 1;
	position: relative;
	cursor: pointer;
}

.ir-radio-card-option input[type="radio"] {
	opacity: 0;
	position: absolute;
	width: 100%;
	height: 100%;
	cursor: pointer;
	z-index: 2;
	margin: 0;
}

.ir-radio-card-face {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 30px 20px;
	border: 2px solid #e0e7eb;
	border-radius: var(--ir-radius-md);
	text-align: center;
	transition: all 0.3s ease;
	background: var(--ir-bg-light);
}

.ir-radio-card-option input:checked + .ir-radio-card-face {
	border-color: var(--ir-accent-blue);
	background: var(--ir-white);
	box-shadow: 0 0 0 4px rgba(0, 168, 232, 0.1);
}

.ir-radio-card-option:hover .ir-radio-card-face {
	border-color: var(--ir-accent-blue);
	transform: translateY(-2px);
}

.ir-radio-card-icon {
	font-size: 40px;
	margin-bottom: 12px;
}

.ir-radio-card-title {
	display: block;
	font-size: 18px;
	font-weight: 700;
	color: var(--ir-text-dark);
	margin-bottom: 6px;
}

.ir-radio-card-option input:checked + .ir-radio-card-face .ir-radio-card-title {
	color: var(--ir-accent-blue);
}

.ir-radio-card-desc {
	font-size: 13px;
	color: var(--ir-text-light);
}

@media (max-width: 600px) {
	.ir-radio-card-group {
		flex-direction: column;
	}
}


/* =============================================
   ENERGY CALCULATOR SPECIFIC
   ============================================= */

.icerink-energy-calculator {
	max-width: 700px;
}

.ir-energy-details {
	transition: opacity 0.3s ease, max-height 0.3s ease;
}

.ir-energy-details.hidden {
	opacity: 0.4;
	pointer-events: none;
}

/* Zero Energy Celebration */
.ir-zero-celebration {
	text-align: center;
	padding: 40px 30px;
	background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
	border-radius: var(--ir-radius-lg);
	border: 2px solid var(--ir-success-green);
	margin-top: 20px;
}

.ir-zero-icon {
	font-size: 60px;
	margin-bottom: 15px;
	animation: bounce 1s ease infinite;
}

@keyframes bounce {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-10px); }
}

.ir-zero-title {
	font-size: 28px;
	font-weight: 800;
	color: #2e7d32;
	margin: 0 0 10px 0;
}

.ir-zero-desc {
	font-size: 16px;
	color: #388e3c;
	margin: 0 0 25px 0;
	line-height: 1.6;
}

.ir-zero-badges {
	display: flex;
	justify-content: center;
	gap: 15px;
	flex-wrap: wrap;
}

.ir-zero-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 18px;
	background: var(--ir-white);
	border-radius: 50px;
	font-size: 14px;
	font-weight: 600;
	color: #2e7d32;
	box-shadow: 0 2px 8px rgba(46, 125, 50, 0.15);
}

/* Energy Result States */
.ir-result-box.ir-zero-energy {
	background: #e8f5e9;
	border-color: var(--ir-success-green);
}

.ir-result-box.ir-zero-energy .ir-result-value {
	color: var(--ir-success-green);
}

.ir-result-box.ir-high-energy {
	background: #fff8e1;
	border-color: #ffb300;
}

.ir-result-box.ir-high-energy .ir-result-value {
	color: #e65100;
}


/* =============================================
   WIZARD (Product Recommender)
   ============================================= */

.icerink-recommender {
	max-width: 650px;
}

/* Progress */
.ir-wizard-progress {
	margin-bottom: 30px;
}

.ir-progress-track {
	height: 6px;
	background: #e0e7eb;
	border-radius: 3px;
	overflow: hidden;
	margin-bottom: 8px;
}

.ir-progress-fill {
	height: 100%;
	width: 50%;
	background: linear-gradient(90deg, var(--ir-primary-blue), var(--ir-accent-blue));
	border-radius: 3px;
	transition: width 0.4s ease;
}

.ir-progress-text {
	font-size: 13px;
	color: var(--ir-text-light);
}

/* Wizard Steps */
.ir-wizard-step {
	display: none;
}

.ir-wizard-step.active {
	display: block;
	animation: fadeIn 0.4s ease;
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(15px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.ir-wizard-question {
	font-size: 22px;
	font-weight: 700;
	color: var(--ir-text-dark);
	text-align: center;
	margin: 0 0 30px 0;
}

/* Wizard Options */
.ir-wizard-options {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.ir-wizard-option {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 30px 25px;
	background: var(--ir-white);
	border: 2px solid #e0e7eb;
	border-radius: var(--ir-radius-lg);
	cursor: pointer;
	transition: all 0.3s ease;
	text-align: center;
	width: 100%;
	font-family: var(--ir-font-stack);
}

.ir-wizard-option:hover {
	border-color: var(--ir-accent-blue);
	transform: translateY(-4px);
	box-shadow: var(--ir-shadow-hover);
}

.ir-wizard-option:active {
	transform: translateY(-2px);
}

.ir-wizard-option-icon {
	font-size: 48px;
	margin-bottom: 12px;
}

.ir-wizard-option-title {
	display: block;
	font-size: 20px;
	font-weight: 700;
	color: var(--ir-text-dark);
	margin-bottom: 6px;
}

.ir-wizard-option-desc {
	font-size: 14px;
	color: var(--ir-text-light);
}

/* Back & Restart Buttons */
.ir-wizard-back,
.ir-wizard-restart {
	display: inline-block;
	margin-top: 25px;
	padding: 12px 24px;
	background: transparent;
	border: 2px solid #e0e7eb;
	border-radius: var(--ir-radius-md);
	font-size: 15px;
	font-weight: 600;
	color: var(--ir-text-light);
	cursor: pointer;
	transition: all 0.2s ease;
	font-family: var(--ir-font-stack);
}

.ir-wizard-back:hover,
.ir-wizard-restart:hover {
	border-color: var(--ir-accent-blue);
	color: var(--ir-accent-blue);
}


/* =============================================
   WIZARD RESULT CARDS
   ============================================= */

.ir-wizard-result {
	text-align: center;
}

.ir-result-card {
	position: relative;
	padding: 45px 35px 35px;
	border-radius: var(--ir-radius-lg);
	border: 3px solid;
	text-align: center;
}

.ir-result-badge {
	position: absolute;
	top: -14px;
	left: 50%;
	transform: translateX(-50%);
	padding: 8px 24px;
	background: var(--ir-primary-blue);
	color: var(--ir-white);
	font-size: 12px;
	font-weight: 700;
	border-radius: 50px;
	text-transform: uppercase;
	letter-spacing: 1px;
	white-space: nowrap;
}

.ir-result-icon {
	font-size: 64px;
	margin-bottom: 15px;
}

.ir-result-name {
	font-size: 28px;
	font-weight: 800;
	margin: 0 0 25px 0;
}

/* Synthetic Result */
.ir-result-synthetic {
	background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
	border-color: var(--ir-success-green);
}

.ir-result-synthetic .ir-result-badge {
	background: var(--ir-success-green);
}

.ir-result-synthetic .ir-result-name {
	color: #2e7d32;
}

/* Real Ice Result */
.ir-result-real {
	background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
	border-color: var(--ir-primary-blue);
}

.ir-result-real .ir-result-badge {
	background: var(--ir-primary-blue);
}

.ir-result-real .ir-result-name {
	color: var(--ir-primary-blue);
}

/* Features Grid */
.ir-result-features {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	margin-bottom: 25px;
}

.ir-feature {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 15px;
	background: rgba(255, 255, 255, 0.7);
	border-radius: var(--ir-radius-md);
	font-size: 14px;
	font-weight: 600;
	color: var(--ir-text-dark);
}

.ir-feature span {
	font-size: 18px;
}

.ir-feature-highlight {
	grid-column: span 2;
	background: rgba(255, 255, 255, 0.9);
	font-size: 16px;
	padding: 15px;
}

.ir-result-synthetic .ir-feature-highlight {
	color: #2e7d32;
}

.ir-result-real .ir-feature-highlight {
	color: var(--ir-primary-blue);
}

.ir-result-summary {
	font-size: 15px;
	color: var(--ir-text-muted);
	line-height: 1.6;
	margin: 0 0 25px 0;
}

/* Result CTA Buttons */
.ir-result-synthetic .ir-btn-primary {
	background: var(--ir-success-green);
}

.ir-result-synthetic .ir-btn-primary:hover {
	background: #218838;
}

.ir-result-real .ir-btn-primary {
	background: var(--ir-primary-blue);
}

.ir-result-real .ir-btn-primary:hover {
	background: #004494;
}

@media (max-width: 500px) {
	.ir-result-features {
		grid-template-columns: 1fr;
	}

	.ir-feature-highlight {
		grid-column: span 1;
	}

	.ir-wizard-option {
		padding: 25px 20px;
	}

	.ir-wizard-option-icon {
		font-size: 40px;
	}

	.ir-wizard-option-title {
		font-size: 18px;
	}
}


/* =============================================
   LAYOUT STABILITY REFINEMENTS
   ============================================= */

/* Tabular Numbers - Prevents jitter when numbers change */
.ir-result-value,
.ir-hero-value,
.ir-mini-value,
.ir-input-transparent,
.ir-number-input,
.ir-input-large,
.ir-input-field {
	font-variant-numeric: tabular-nums;
	font-feature-settings: "tnum" 1;
}

/* Allow text to display fully - NO truncation */
.ir-input-transparent,
.ir-input-field,
.ir-input-large {
	text-overflow: clip;
	overflow: visible;
	white-space: nowrap;
}

/* =============================================
   STABLE ROI RESULT PANEL
   ============================================= */

.ir-results-panel {
	contain: layout style;
}

.ir-hero-value {
	min-width: 150px;
}

.ir-mini-value {
	min-width: 80px;
}

/* =============================================
   STABLE COST RESULT BOX
   ============================================= */

.ir-result-box {
	min-height: 180px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.ir-result-value {
	min-width: 200px;
	text-align: center;
	display: block;
}

/* =============================================
   IMPROVED TOUCH TARGETS (Fitts's Law)
   ============================================= */

/* Range Slider - Larger touch area */
.ir-range-input {
	height: 12px;
	padding: 8px 0;
	margin: 8px 0;
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
}

.ir-range-input::-webkit-slider-thumb {
	width: 28px;
	height: 28px;
	margin-top: -8px;
}

.ir-range-input::-moz-range-thumb {
	width: 28px;
	height: 28px;
}

/* Buttons - Minimum touch target */
.ir-btn-primary,
.ir-wizard-option,
.ir-radio-card-face {
	min-height: 50px;
}

.ir-btn-primary {
	padding: 16px 35px;
}

/* Wizard options - larger touch area */
.ir-wizard-option {
	min-height: 100px;
	padding: 25px 20px;
}

@media (max-width: 768px) {
	.ir-btn-primary {
		min-height: 54px;
		padding: 18px 30px;
	}

	.ir-wizard-option {
		min-height: 90px;
	}

	/* Larger slider thumb on mobile */
	.ir-range-input::-webkit-slider-thumb {
		width: 32px;
		height: 32px;
	}

	.ir-range-input::-moz-range-thumb {
		width: 32px;
		height: 32px;
	}
}

/* =============================================
   LEAD FORM CONTAINER
   ============================================= */

.ir-lead-form-container {
	display: none;
	margin-top: 30px;
	padding: 30px;
	background: #f8f9fa;
	border-radius: var(--ir-radius-md);
	border: 1px solid #e0e7eb;
	border-top: 3px solid var(--ir-accent-blue);
}

.ir-lead-form-container.active {
	display: block;
	animation: irSlideDown 0.4s ease-out;
}

@keyframes irSlideDown {
	from {
		opacity: 0;
		transform: translateY(-20px);
		max-height: 0;
	}
	to {
		opacity: 1;
		transform: translateY(0);
		max-height: 500px;
	}
}

.ir-lead-form-container h3 {
	margin: 0 0 8px 0;
	font-size: 20px;
	font-weight: 700;
	color: var(--ir-text-dark);
	text-align: center;
}

.ir-lead-form-container p {
	text-align: center;
	color: var(--ir-text-light);
	margin-bottom: 25px;
}

.ir-lead-form-container .ir-input-grid {
	margin-bottom: 20px;
}

/* Full width field */
.ir-field-full {
	margin-bottom: 20px;
}

/* KVKK Note */
.ir-kvkk-note {
	font-size: 12px;
	color: var(--ir-text-light);
	text-align: center;
	margin: 15px 0 0;
	line-height: 1.5;
}

/* =============================================
   LEAD FORM BUTTON STATES
   ============================================= */

.ir-btn-submit {
	position: relative;
	min-width: 200px;
}

.ir-btn-text,
.ir-btn-loading {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

/* Spinner */
.ir-spinner {
	display: inline-block;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: #ffffff;
	border-radius: 50%;
	animation: irSpin 0.8s linear infinite;
}

@keyframes irSpin {
	to {
		transform: rotate(360deg);
	}
}

/* =============================================
   LEAD FORM SUCCESS STATE
   ============================================= */

.ir-lead-success {
	text-align: center;
	padding: 30px 20px;
}

.ir-success-icon {
	font-size: 48px;
	display: block;
	margin-bottom: 15px;
}

.ir-lead-success h4 {
	font-size: 22px;
	font-weight: 700;
	color: var(--ir-success-green);
	margin: 0 0 10px;
}

.ir-lead-success p {
	font-size: 16px;
	color: var(--ir-text-light);
	margin: 0;
}

/* =============================================
   LEAD FORM ERROR STATE
   ============================================= */

.ir-lead-error {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 15px 20px;
	background: #fff5f5;
	border: 1px solid #feb2b2;
	border-radius: var(--ir-radius-md);
	margin-top: 15px;
}

.ir-error-icon {
	font-size: 20px;
}

.ir-lead-error p {
	color: #c53030;
	font-size: 14px;
	font-weight: 600;
	margin: 0;
	text-align: left;
}

/* =============================================
   ENERGY QUOTE WRAPPER
   ============================================= */

.ir-energy-quote-wrapper {
	margin-top: 20px;
	text-align: center;
}

/* =============================================
   PREVENT CONTAINER RESIZE
   ============================================= */

/* Fixed width containers for dynamic content */
.icerink-cost-calculator .ir-result-box,
.icerink-roi-calculator .ir-roi-results,
.icerink-energy-calculator .ir-result-box {
	contain: layout style;
}

/* Stable card heights */
.ir-card {
	min-height: 400px;
}

.icerink-roi-calculator {
	min-height: 600px;
}

/* Energy result stability */
.icerink-energy-calculator .ir-result-box,
.icerink-energy-calculator .ir-zero-celebration {
	min-height: 160px;
}

/* Wizard step stability */
.ir-wizard-step {
	min-height: 250px;
}

.ir-wizard-result .ir-result-card {
	min-height: 380px;
}

/* =============================================
   SMOOTH VALUE TRANSITIONS
   ============================================= */

.ir-result-value,
.ir-roi-result-value {
	transition: color 0.2s ease;
}

/* Prevent text selection during interactions */
.ir-range-input,
.ir-wizard-option,
.ir-radio-card-option {
	user-select: none;
	-webkit-user-select: none;
}

/* =============================================
   ACCESSIBILITY IMPROVEMENTS
   ============================================= */

/* Focus visible states */
.ir-input-field:focus-visible,
.ir-btn-primary:focus-visible,
.ir-wizard-option:focus-visible {
	outline: 3px solid var(--ir-accent-blue);
	outline-offset: 2px;
}

/* Reduced motion preference */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

/* High contrast mode */
@media (prefers-contrast: high) {
	.ir-input-field,
	.ir-btn-primary,
	.ir-result-box {
		border-width: 3px;
	}
}


/* =============================================
   HOTEL WIZARD - MULTI-STEP
   ============================================= */

.ir-hotel-wizard {
	max-width: 800px;
}

/* Progress Bar */
.ir-hw-progress {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	margin-bottom: 35px;
	padding-bottom: 25px;
	border-bottom: 1px solid #eef2f7;
}

.ir-hw-progress-item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 6px 12px;
	border-radius: 20px;
	transition: all 0.3s ease;
}

.ir-hw-progress-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: #e0e7eb;
	color: #a0aec0;
	font-size: 13px;
	font-weight: 700;
	transition: all 0.3s ease;
}

.ir-hw-progress-label {
	font-size: 14px;
	font-weight: 600;
	color: #a0aec0;
	transition: color 0.3s ease;
}

.ir-hw-progress-item.active .ir-hw-progress-num {
	background: var(--ir-accent-blue);
	color: #fff;
}

.ir-hw-progress-item.active .ir-hw-progress-label {
	color: var(--ir-text-dark);
}

.ir-hw-progress-item.completed .ir-hw-progress-num {
	background: var(--ir-success-green);
	color: #fff;
}

.ir-hw-progress-item.completed .ir-hw-progress-label {
	color: var(--ir-success-green);
}

.ir-hw-progress-line {
	width: 40px;
	height: 2px;
	background: #e0e7eb;
	margin: 0 4px;
	transition: background 0.3s ease;
}

.ir-hw-progress-line.completed {
	background: var(--ir-success-green);
}

/* Wizard Steps */
.ir-hw-step {
	display: none;
	animation: fadeIn 0.4s ease;
}

.ir-hw-step.active {
	display: block;
}

/* Bridge Box (Step 2 cost result) */
.ir-hw-bridge-box {
	text-align: center;
	padding: 40px 30px;
	background: var(--ir-bg-light);
	border: 2px solid var(--ir-accent-blue);
	border-radius: var(--ir-radius-lg);
	margin-bottom: 25px;
}

.ir-hw-bridge-label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: var(--ir-text-light);
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 10px;
}

.ir-hw-bridge-value {
	display: block;
	font-size: 42px;
	font-weight: 800;
	color: var(--ir-primary-blue);
	line-height: 1.2;
	margin-bottom: 8px;
	font-variant-numeric: tabular-nums;
}

.ir-hw-bridge-meta {
	display: block;
	font-size: 14px;
	color: var(--ir-text-light);
}

/* Back Button */
.ir-hw-back-btn {
	display: block;
	width: 100%;
	margin-top: 12px;
	padding: 14px 20px;
	background: transparent;
	border: 2px solid #e0e7eb;
	border-radius: var(--ir-radius-md);
	font-size: 15px;
	font-weight: 600;
	color: var(--ir-text-light);
	cursor: pointer;
	transition: all 0.2s ease;
	font-family: var(--ir-font-stack);
	text-align: center;
}

.ir-hw-back-btn:hover {
	border-color: var(--ir-accent-blue);
	color: var(--ir-accent-blue);
}

/* Results Grid in Step 4 */
.ir-hw-results-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	margin-bottom: 20px;
}

.ir-hw-results-grid .ir-hero-metric {
	background: var(--ir-bg-light);
	padding: 25px 20px;
	border-radius: var(--ir-radius-md);
	border: 1px solid #eef2f7;
	margin-bottom: 0;
	padding-bottom: 25px;
	border-bottom: none;
}

@media (max-width: 600px) {
	.ir-hw-progress-label {
		display: none;
	}

	.ir-hw-progress {
		gap: 0;
		justify-content: center;
	}

	.ir-hw-bridge-value {
		font-size: 32px;
	}

	.ir-hw-results-grid {
		grid-template-columns: 1fr;
	}
}


/* =============================================
   COST BREAKDOWN - TEXT LINK BUTTON
   ============================================= */

.ir-btn-text-only {
	background: none;
	border: none;
	color: var(--ir-text-light);
	text-decoration: underline;
	cursor: pointer;
	font-size: 14px;
	margin-top: 10px;
	display: inline-block;
}

.ir-btn-text-only:hover {
	color: var(--ir-primary);
}


/* =============================================
   COST BREAKDOWN - MODAL OVERLAY
   ============================================= */

.ir-modal {
	display: none;
	position: fixed;
	z-index: 9999999;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(2px);
	justify-content: center;
	align-items: center;
	animation: fadeIn 0.3s;
}

.ir-modal-content {
	background-color: #fff;
	padding: 30px;
	border-radius: var(--ir-radius);
	width: 90%;
	max-width: 600px;
	max-height: 80vh;
	overflow-y: auto;
	position: relative;
	box-shadow: 0 20px 50px rgba(0, 0, 0, 0.2);
}

.ir-close {
	position: absolute;
	top: 15px;
	right: 20px;
	color: #aaa;
	font-size: 28px;
	font-weight: bold;
	cursor: pointer;
}

.ir-close:hover {
	color: #000;
}


/* =============================================
   COST BREAKDOWN - TABLE STYLING
   ============================================= */

.ir-modal-body-table table {
	width: 100%;
	border-collapse: collapse;
	margin-top: 20px;
	font-size: 15px;
}

.ir-modal-body-table th {
	background-color: var(--ir-bg);
	color: var(--ir-text-dark);
	font-weight: 700;
	text-align: left;
	padding: 12px;
	border-bottom: 2px solid #eee;
}

.ir-modal-body-table td {
	padding: 12px;
	border-bottom: 1px solid #eee;
	color: var(--ir-secondary);
}

.ir-modal-body-table tr:last-child td {
	border-bottom: none;
}

.ir-modal-body-table tr:hover {
	background-color: #f9f9f9;
}


/* =============================================
   COST BREAKDOWN - LINK BUTTON (VISIBLE)
   ============================================= */

.ir-link-btn {
	background: none;
	border: none;
	color: var(--ir-primary);
	font-size: 14px;
	font-weight: 600;
	text-decoration: underline;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 10px;
	transition: color 0.2s;
}

.ir-link-btn:hover {
	color: var(--ir-secondary);
}


/* =============================================
   COMPACT GRID - ROI INPUTS SIDE-BY-SIDE
   ============================================= */

.ir-compact-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 15px;
	margin-bottom: 20px;
}

.ir-compact-grid .ir-control-group {
	margin-bottom: 0;
	padding: 10px;
}

@media (max-width: 500px) {
	.ir-compact-grid {
		grid-template-columns: 1fr;
	}
}


/* =============================================
   MODAL - SMALL VARIANT (Lead Form)
   ============================================= */

.ir-modal-sm {
	max-width: 480px;
}


/* =============================================
   INVESTMENT QUOTE CARD (Step 2 Redesign)
   ============================================= */

.ir-investment-card {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 10px 30px -5px rgba(0, 0, 0, 0.08);
	max-width: 600px;
	margin: 0 auto;
	text-align: center;
}

.ir-inv-card-header {
	background: #f8fafc;
	padding: 20px;
	border-bottom: 1px solid #edf2f7;
}

.ir-badge {
	background: #e0f2fe;
	color: #0284c7;
	font-size: 12px;
	font-weight: 700;
	padding: 5px 10px;
	border-radius: 20px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	display: inline-block;
}

.ir-inv-card-header h3 {
	margin: 10px 0 0;
	font-size: 18px;
	color: #475569;
}

.ir-inv-card-body {
	padding: 30px;
}

.ir-price-display {
	font-size: 36px;
	font-weight: 800;
	color: var(--ir-primary);
	margin-bottom: 15px;
	letter-spacing: -1px;
}

.ir-meta-line {
	font-size: 13px;
	color: #94a3b8;
	margin-bottom: 15px;
}

.ir-product-tag {
	color: #64748b;
	font-size: 14px;
	margin-bottom: 5px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
}

.ir-product-tag .dashicons {
	color: var(--ir-success, #48bb78);
	font-size: 18px;
	width: 18px;
	height: 18px;
}

.ir-inv-card-footer {
	padding: 15px;
	background: #f8fafc;
	border-top: 1px solid #edf2f7;
}

.ir-btn-outline {
	background: transparent;
	border: 1px solid #cbd5e1;
	color: #475569;
	padding: 10px 20px;
	border-radius: 8px;
	cursor: pointer;
	font-weight: 600;
	font-size: 13px;
	transition: all 0.2s;
	display: inline-flex;
	align-items: center;
	gap: 5px;
}

.ir-btn-outline:hover {
	border-color: var(--ir-primary);
	color: var(--ir-primary);
	background: #fff;
}

.ir-btn-pulse {
	box-shadow: 0 0 0 0 rgba(13, 110, 253, 0.7);
	animation: pulse-blue 2s infinite;
}

@keyframes pulse-blue {
	0% { box-shadow: 0 0 0 0 rgba(13, 110, 253, 0.4); }
	70% { box-shadow: 0 0 0 10px rgba(13, 110, 253, 0); }
	100% { box-shadow: 0 0 0 0 rgba(13, 110, 253, 0); }
}

.ir-back-link {
	color: #94a3b8;
	text-decoration: none;
	font-size: 14px;
	transition: color 0.2s;
}

.ir-back-link:hover {
	color: #64748b;
}


/* =============================================
   EXECUTIVE RESULTS DASHBOARD (Step 4)
   ============================================= */

.ir-result-dashboard {
	background: #fff;
	border-radius: 20px;
	padding: 10px;
}

.ir-dashboard-title {
	text-align: center;
	color: #64748b;
	margin-bottom: 25px;
	font-weight: 600;
}

/* Hero Grid */
.ir-hero-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	margin-bottom: 25px;
}

@media (max-width: 600px) {
	.ir-hero-grid {
		grid-template-columns: 1fr;
	}
}

/* Hero Cards */
.ir-hero-card {
	padding: 25px;
	border-radius: 16px;
	text-align: center;
	color: #fff;
	position: relative;
	overflow: hidden;
}

.ir-card-green {
	background: linear-gradient(135deg, #10b981 0%, #059669 100%);
	box-shadow: 0 10px 25px rgba(16, 185, 129, 0.2);
}

.ir-card-blue {
	background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
	box-shadow: 0 10px 25px rgba(59, 130, 246, 0.2);
}

.ir-hero-card .ir-hero-label {
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 1px;
	opacity: 0.9;
	display: block;
	margin-bottom: 10px;
	color: #fff;
}

.ir-hero-card .ir-hero-value {
	font-size: 32px;
	font-weight: 800;
	line-height: 1.1;
	margin-bottom: 5px;
	color: #fff;
}

.ir-hero-trend {
	font-size: 12px;
	background: rgba(255, 255, 255, 0.2);
	padding: 4px 10px;
	border-radius: 10px;
	display: inline-block;
}

.ir-hero-sub {
	font-size: 14px;
	opacity: 0.8;
}

/* Stats Strip */
.ir-stats-strip {
	background: #f8fafc;
	border-radius: 12px;
	padding: 20px;
	display: flex;
	justify-content: space-around;
	align-items: center;
	margin-bottom: 30px;
	border: 1px solid #e2e8f0;
}

.ir-stat-item {
	text-align: center;
}

.ir-stat-label {
	font-size: 12px;
	color: #64748b;
	display: block;
	margin-bottom: 5px;
	text-transform: uppercase;
}

.ir-stat-val {
	font-size: 20px;
	font-weight: 700;
	color: #334155;
}

.ir-stat-divider {
	width: 1px;
	height: 40px;
	background: #cbd5e1;
}

/* Action Area */
.ir-action-area {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.ir-btn-lg {
	padding: 18px 30px;
	font-size: 16px;
	border-radius: 12px;
	width: 100%;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 8px;
}

.ir-btn-ghost {
	background: transparent;
	border: 2px solid #e2e8f0;
	color: #64748b;
	padding: 15px;
	border-radius: 12px;
	font-weight: 600;
	width: 100%;
	cursor: pointer;
	transition: all 0.2s;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 8px;
	font-size: 14px;
}

.ir-btn-ghost:hover {
	border-color: var(--ir-primary);
	color: var(--ir-primary);
	background: #fff;
}


/* =============================================
   PROFITABILITY SIMULATOR (Step 3 Redesign)
   ============================================= */

/* Investment Anchor Bar */
.ir-invest-anchor {
	background: #f1f5f9;
	border: 1px solid #cbd5e1;
	padding: 20px;
	border-radius: 12px;
	margin-bottom: 25px;
	position: relative;
}

.ir-invest-label {
	font-weight: 600;
	color: #475569;
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 5px;
}

.ir-invest-input-wrapper {
	display: flex;
	align-items: baseline;
	border-bottom: 2px solid #cbd5e1;
	padding-bottom: 5px;
	margin-bottom: 10px;
}

.ir-invest-input-wrapper:focus-within {
	border-color: var(--ir-primary);
}

.ir-invest-value {
	background: transparent;
	border: none;
	font-size: 28px;
	font-weight: 800;
	color: #0f172a;
	width: 100%;
	outline: none;
}

.ir-currency-symbol {
	font-size: 20px;
	font-weight: 700;
	color: #64748b;
}

/* Minimal Range Slider */
.ir-range-minimal {
	width: 100%;
	height: 4px;
	background: #cbd5e1;
	-webkit-appearance: none;
	appearance: none;
	border-radius: 2px;
	outline: none;
}

.ir-range-minimal::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 16px;
	height: 16px;
	background: #64748b;
	border-radius: 50%;
	cursor: pointer;
}

.ir-range-minimal::-moz-range-thumb {
	width: 16px;
	height: 16px;
	background: #64748b;
	border-radius: 50%;
	cursor: pointer;
	border: none;
}

/* Parameter Cards Grid */
.ir-params-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

@media (max-width: 600px) {
	.ir-params-grid {
		grid-template-columns: 1fr;
	}
}

.ir-param-card-v2 {
	background: #fff;
	border: 1px solid #e2e8f0;
	padding: 20px;
	border-radius: 12px;
	transition: transform 0.2s, box-shadow 0.2s;
}

.ir-param-card-v2:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 20px -5px rgba(0, 0, 0, 0.05);
	border-color: #cbd5e1;
}

.ir-param-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 15px;
}

.ir-param-header label {
	font-weight: 600;
	color: #334155;
	font-size: 14px;
}

.ir-mini-input {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	padding: 5px 10px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 700;
	color: var(--ir-primary);
	display: flex;
	align-items: center;
	gap: 4px;
}

.ir-mini-input input {
	background: transparent;
	border: none;
	width: 60px;
	text-align: right;
	font-weight: 700;
	color: inherit;
	padding: 0;
	outline: none;
}

/* Blue Range Slider */
.ir-range-blue {
	width: 100%;
	height: 6px;
	background: #e2e8f0;
	border-radius: 3px;
	-webkit-appearance: none;
	appearance: none;
	margin-bottom: 8px;
	outline: none;
}

.ir-range-blue::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 20px;
	height: 20px;
	background: var(--ir-primary);
	border: 3px solid #fff;
	border-radius: 50%;
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
	cursor: pointer;
	transition: transform 0.1s;
}

.ir-range-blue::-webkit-slider-thumb:hover {
	transform: scale(1.2);
}

.ir-range-blue::-moz-range-thumb {
	width: 20px;
	height: 20px;
	background: var(--ir-primary);
	border: 3px solid #fff;
	border-radius: 50%;
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
	cursor: pointer;
	border: none;
}

.ir-param-desc {
	font-size: 11px;
	color: #94a3b8;
	display: block;
}

/* Text Button */
.ir-btn-text {
	background: none;
	border: none;
	color: #94a3b8;
	font-size: 14px;
	cursor: pointer;
	transition: color 0.2s;
}

.ir-btn-text:hover {
	color: #64748b;
	text-decoration: underline;
}
