.dsc-calculator {
	max-width: 720px;
	padding: 24px;
	border: 1px solid #d9dee5;
	border-radius: var(--dsc-radius, 16px);
	background: linear-gradient(180deg, #ffffff 0%, #f7f9fc 100%);
}

.dsc-calculator__form {
	display: grid;
	gap: 18px;
}

.dsc-field {
	display: grid;
	gap: 8px;
}

.dsc-field__label {
	font-weight: 600;
	color: #1f2937;
}

.dsc-field__control {
	width: 100%;
}

.dsc-field__control[type='text'],
.dsc-field__control[type='date'],
.dsc-field__control[type='number'],
.dsc-field__control,
textarea.dsc-field__control {
	padding: 8px 10px;
	border: 1px solid #cbd5e1;
	border-radius: 10px;
}

.dsc-toggle {
	display: inline-flex;
	align-items: center;
	gap: 12px;
}

.dsc-toggle input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.dsc-toggle__track {
	position: relative;
	width: 42px;
	height: 24px;
	border-radius: 999px;
	background: #cbd5e1;
	transition: background 0.2s ease;
}

.dsc-toggle__thumb {
	position: absolute;
	top: 3px;
	left: 3px;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.2);
	transition: transform 0.2s ease;
}

.dsc-toggle input:checked + .dsc-toggle__track {
	background: var(--dsc-accent, #4caf50);
}

.dsc-toggle input:checked + .dsc-toggle__track .dsc-toggle__thumb {
	transform: translateX(18px);
}

.dsc-toggle input:focus-visible + .dsc-toggle__track {
	outline: 2px solid rgba(59, 130, 246, 0.5);
	outline-offset: 2px;
}

.dsc-range-wrap {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	gap: 12px;
}

.dsc-range-wrap__value {
	min-width: 88px;
	text-align: right;
	font-weight: 600;
}

.dsc-choices {
	display: grid;
	gap: 10px;
}

.dsc-choice {
	display: flex;
	align-items: center;
	gap: 10px;
}

.dsc-total {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 8px;
	padding-top: 18px;
	border-top: 1px solid #d9dee5;
}

.dsc-total__label {
	font-size: 1rem;
	font-weight: 600;
}

.dsc-total__value {
	font-size: 1.5rem;
	line-height: 1;
	color: var(--dsc-accent, #4caf50);
}

.dsc-notice {
	padding: 12px 14px;
	border-left: 4px solid #d63638;
	background: #fff;
}

@media (max-width: 640px) {
	.dsc-calculator {
		padding: 18px;
	}

	.dsc-total {
		align-items: flex-start;
		flex-direction: column;
		gap: 8px;
	}
}
