/* Hilte Premium Web App - Премиальный UI с Glassmorphism */

/* Корпоративные luxury шрифты */
:root {
    --font-primary: 'Space Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-accent: 'Cormorant Garamond', Georgia, serif;
    --font-elegant: 'Cormorant Garamond', 'Times New Roman', serif;
    
    /* Цветовая палитра Hilte - Бежевые тона (как на сайте) */
    --color-beige: #F5F2ED;
    --color-beige-dark: #EDE8E0;
    --color-beige-light: #FAF8F5;
    --color-ivory: #FAFAF8;
    --color-ivory-dark: #F5F5F0;
    --color-obsidian: #2C2820;
    --color-obsidian-light: #5A5448;
    --color-champagne: #B8A082;
    --color-champagne-light: #D4C4AA;
    --color-champagne-dark: #9B8668;
    --color-platinum: #E8E4DD;
    --color-platinum-dark: #D9D4CB;
    
    /* Glassmorphism эффекты */
    --glass-bg: rgba(255, 255, 255, 0.7);
    --glass-border: rgba(255, 255, 255, 0.3);
    --glass-shadow: rgba(0, 0, 0, 0.1);
    
    /* Градиенты - бежевые тона */
    --gradient-bg: linear-gradient(135deg, #FAF8F5 0%, #F5F2ED 50%, #EDE8E0 100%);
    --gradient-accent: linear-gradient(135deg, #B8A082 0%, #D4C4AA 100%);
    
    /* Отступы и размеры */
    --spacing-xs: 8px;
    --spacing-sm: 12px;
    --spacing-md: 20px;
    --spacing-lg: 32px;
    --spacing-xl: 48px;
    
    --radius-sm: 12px;
    --radius-md: 16px;
    --radius-lg: 24px;
    
    /* Типографика — единая система */
    --font-size-xs: 11px;
    --font-size-sm: 13px;
    --font-size-md: 15px;
    --font-size-lg: 18px;
    --font-size-xl: 24px;
    --font-size-2xl: 28px;
    
    --line-height-tight: 1.2;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.7;
    
    --font-weight-light: 300;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    
    /* Анимации */
    --transition-fast: 0.2s ease;
    --transition-medium: 0.3s ease;
    --transition-slow: 0.5s ease;
}

/* Темная тема */
[data-theme="dark"], 
body.tg-theme-dark {
    --color-ivory: #1A1A1A;
    --color-ivory-dark: #151515;
    --color-obsidian: #FAFAF8;
    --color-obsidian-light: #E5E5E0;
    --color-platinum: #2C2C2C;
    --color-platinum-dark: #404040;
    
    --glass-bg: rgba(28, 28, 28, 0.8);
    --glass-border: rgba(255, 255, 255, 0.1);
    --glass-shadow: rgba(0, 0, 0, 0.3);
    
    --gradient-bg: linear-gradient(135deg, #1A1A1A 0%, #151515 100%);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-primary);
    background: var(--gradient-bg);
    color: var(--color-obsidian);
    line-height: 1.6;
    min-height: 100vh;
    padding: 0;
    margin: 0;
    overflow-x: hidden;
    /* Отступ сверху для статус-бара Telegram */
    padding-top: env(safe-area-inset-top, 0);
    
    /* Шум и текстура фона - бежевые тона */
    background-image: 
        radial-gradient(circle at 20% 50%, rgba(184, 160, 130, 0.04) 0%, transparent 50%),
        radial-gradient(circle at 80% 80%, rgba(184, 160, 130, 0.04) 0%, transparent 50%),
        var(--gradient-bg);
}

/* Прогресс-бар */
.progress-container {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    padding: var(--spacing-md) var(--spacing-md) var(--spacing-sm);
    padding-top: calc(var(--spacing-md) + env(safe-area-inset-top, 0));
    background: var(--glass-bg);
    backdrop-filter: blur(30px) saturate(180%);
    -webkit-backdrop-filter: blur(30px) saturate(180%);
    border-bottom: 1px solid var(--glass-border);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
    height: auto;
    box-sizing: border-box;
    transform: translateY(0);
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
    opacity: 1;
    will-change: transform, opacity;
}

/* Скрытое состояние прогресс-бара */
.progress-container.hidden {
    transform: translateY(-100%) !important;
    opacity: 0;
    pointer-events: none;
}

.progress-bar {
    height: 2px;
    background: var(--gradient-accent);
    transition: width 0.5s cubic-bezier(0.16, 1, 0.3, 1);
    border-radius: 2px;
    margin-bottom: var(--spacing-sm);
    box-shadow: 0 2px 8px rgba(184, 160, 130, 0.3);
}

.progress-steps {
    display: flex;
    justify-content: space-between;
    max-width: 400px;
    margin: 0 auto;
}

.step-number {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--color-platinum);
    color: var(--color-obsidian-light);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    transition: all var(--transition-medium);
}

.step-number.active {
    background: var(--color-champagne);
    color: white;
}

/* Glass контейнер */
.glass-container {
    max-width: 600px;
    margin: 0 auto;
    padding: var(--spacing-xl) var(--spacing-md);
    padding-top: calc(100px + var(--spacing-sm));
    margin-top: 0;
    min-height: calc(100vh - 100px);
    display: flex;
    flex-direction: column;
    position: relative;
    overflow-x: hidden;
    box-sizing: border-box;
    width: 100%;
}

/* Убрали постоянный shimmer эффект - он раздражал */

/* Шаги */
.step {
    display: none;
    animation: fadeInSlide 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.step.active {
    display: flex;
    flex-direction: column;
}

@keyframes fadeInSlide {
    from {
        opacity: 0;
        transform: translateY(24px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* Типографика */
.step-title {
    font-family: var(--font-elegant);
    font-size: 30px;
    font-weight: 400;
    font-style: italic;
    color: var(--color-obsidian);
    margin-bottom: var(--spacing-sm);
    margin-top: 0;
    padding-top: 0;
    text-align: center;
    line-height: 1.2;
    letter-spacing: 0.02em;
    animation: titleFadeIn 0.6s cubic-bezier(0.16, 1, 0.3, 1) backwards;
    animation-delay: 0.1s;
    position: relative;
    z-index: 1;
}

@keyframes titleFadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.step-subtitle {
    font-family: var(--font-primary);
    font-size: 14px;
    color: var(--color-obsidian-light);
    text-align: center;
    margin-bottom: var(--spacing-lg);
    font-weight: 300;
    line-height: 1.6;
    letter-spacing: 0.03em;
    animation: subtitleFadeIn 0.6s cubic-bezier(0.16, 1, 0.3, 1) backwards;
    animation-delay: 0.2s;
}

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

.section-title {
    font-family: var(--font-accent);
    font-size: 24px;
    font-weight: 400;
    color: var(--color-obsidian);
    margin-bottom: var(--spacing-md);
}

.section-title-small {
    font-family: var(--font-accent);
    font-size: 20px;
    font-weight: 400;
    color: var(--color-obsidian);
    margin: var(--spacing-lg) 0 var(--spacing-md);
}

.section-hint {
    font-size: 14px;
    color: var(--color-obsidian-light);
    margin-bottom: var(--spacing-md);
    font-weight: 300;
}

/* Glass карточки */
.radio-group.premium,
.checkbox-group.premium {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
    width: 100%;
    box-sizing: border-box;
    overflow: visible;
}

.radio-card,
.checkbox-card {
    background: var(--glass-bg);
    backdrop-filter: blur(30px) saturate(180%);
    -webkit-backdrop-filter: blur(30px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
    overflow: hidden;
    animation: cardFadeIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) backwards;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
}

.radio-card:nth-child(1) { animation-delay: 0.1s; }
.radio-card:nth-child(2) { animation-delay: 0.2s; }
.radio-card:nth-child(3) { animation-delay: 0.3s; }
.checkbox-card:nth-child(1) { animation-delay: 0.1s; }
.checkbox-card:nth-child(2) { animation-delay: 0.15s; }
.checkbox-card:nth-child(3) { animation-delay: 0.2s; }
.checkbox-card:nth-child(4) { animation-delay: 0.25s; }

@keyframes cardFadeIn {
    from {
        opacity: 0;
        transform: translateY(12px) scale(0.96);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* Тонкий блик только при hover (не постоянно) */
.radio-card::before,
.checkbox-card::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: linear-gradient(
        45deg,
        transparent 40%,
        rgba(255, 255, 255, 0.08) 50%,
        transparent 60%
    );
    transform: rotate(45deg);
    transition: all 0.4s ease;
    opacity: 0;
    pointer-events: none;
}

.radio-card:hover::before,
.checkbox-card:hover::before {
    opacity: 1;
    transform: translateX(50%) translateY(50%) rotate(45deg);
}

/* Убираем постоянную анимацию glare */

/* Selected state */
.radio-card::after,
.checkbox-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(139, 105, 20, 0.08) 0%, rgba(168, 130, 28, 0.05) 100%);
    opacity: 0;
    transition: opacity var(--transition-medium);
    border-radius: var(--radius-md);
}

.radio-card:hover,
.checkbox-card:hover {
    border-color: var(--color-champagne);
    transform: translateY(-4px) scale(1.01);
    box-shadow: 0 12px 40px rgba(184, 160, 130, 0.2);
}

.radio-card:active,
.checkbox-card:active {
    transform: translateY(-2px) scale(0.99);
    box-shadow: 0 6px 20px rgba(184, 160, 130, 0.15);
    transition: all 0.15s cubic-bezier(0.16, 1, 0.3, 1);
}

.radio-card input[type="radio"]:checked + .card-content,
.checkbox-card input[type="checkbox"]:checked + .card-content {
    position: relative;
}

.radio-card input[type="radio"]:checked,
.checkbox-card input[type="checkbox"]:checked {
    accent-color: var(--color-champagne);
}

.radio-card input[type="radio"]:checked,
.checkbox-card input[type="checkbox"]:checked {
    accent-color: var(--color-champagne);
}

/* Эффект "зажимания" при выборе */
.radio-card:has(input[type="radio"]:checked),
.checkbox-card:has(input[type="checkbox"]:checked) {
    transform: scale(0.96);
    border-color: var(--color-champagne);
    border-width: 2px;
    background: rgba(184, 160, 130, 0.1);
    box-shadow: inset 0 2px 8px rgba(184, 160, 130, 0.15), 0 4px 16px rgba(184, 160, 130, 0.2);
    transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}

.radio-card input[type="radio"]:checked ~ .card-content,
.checkbox-card input[type="checkbox"]:checked ~ .card-content {
    color: var(--color-champagne);
}

.radio-card input[type="radio"]:checked ~ .card-content .card-title,
.checkbox-card input[type="checkbox"]:checked ~ .card-content .card-title {
    color: var(--color-champagne);
    font-weight: 600;
}

.radio-card input[type="radio"]:checked::after,
.checkbox-card input[type="checkbox"]:checked::after {
    opacity: 1;
}

.radio-card.large,
.checkbox-card.large {
    padding: var(--spacing-lg);
}

.card-content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    position: relative;
    z-index: 1;
}

.card-title {
    font-family: var(--font-elegant);
    font-size: 17px;
    font-weight: 500;
    color: var(--color-obsidian);
    letter-spacing: 0.02em;
    transition: color var(--transition-medium);
}

.card-description {
    font-size: 13px;
    color: var(--color-obsidian-light);
    font-weight: 300;
}

.card-price {
    font-size: 14px;
    color: var(--color-champagne);
    font-weight: 500;
    margin-top: var(--spacing-xs);
}

/* Поля ввода */
.input-premium {
    width: 100%;
    padding: var(--spacing-md);
    background: var(--glass-bg);
    backdrop-filter: blur(30px) saturate(180%);
    -webkit-backdrop-filter: blur(30px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    font-size: 16px;
    font-family: var(--font-primary);
    color: var(--color-obsidian);
    transition: all var(--transition-medium);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.05);
}

/* Явные стили для всех input, включая date и time */
input.input-premium[type="date"],
input.input-premium[type="time"] {
    color: var(--color-obsidian) !important;
    -webkit-text-fill-color: var(--color-obsidian) !important;
    background-color: var(--glass-bg) !important;
}

/* Принудительно устанавливаем цвет для всех элементов внутри date/time */
input[type="date"] *,
input[type="time"] * {
    color: var(--color-obsidian) !important;
}

.input-premium:focus {
    outline: none;
    border-color: var(--color-champagne);
    box-shadow: 0 0 0 3px rgba(184, 160, 130, 0.15), 0 4px 12px rgba(184, 160, 130, 0.1);
    transform: translateY(-1px);
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.input-premium::placeholder {
    color: var(--color-obsidian-light);
    opacity: 0.6;
}

/* Стили для полей даты и времени */
input[type="date"],
input[type="time"] {
    color: var(--color-obsidian) !important;
    background-color: var(--glass-bg) !important;
    -webkit-text-fill-color: var(--color-obsidian) !important;
    opacity: 1 !important;
}

/* Принудительно показываем значение в полях даты/времени */
input[type="date"]:not(:placeholder-shown),
input[type="time"]:not(:placeholder-shown) {
    color: var(--color-obsidian) !important;
    -webkit-text-fill-color: var(--color-obsidian) !important;
}

/* Принудительно белый/светлый текст для темной темы */
[data-theme="dark"] input[type="date"],
[data-theme="dark"] input[type="time"],
body.tg-theme-dark input[type="date"],
body.tg-theme-dark input[type="time"] {
    color: #FAFAF8 !important;
    -webkit-text-fill-color: #FAFAF8 !important;
    opacity: 1 !important;
}

/* Принудительно темный текст для светлой темы */
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="date"],
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="time"] {
    color: #2C2820 !important;
    -webkit-text-fill-color: #2C2820 !important;
    opacity: 1 !important;
}

/* WebKit (Chrome, Safari, Edge) */
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator {
    filter: invert(0.4) brightness(1.2);
    cursor: pointer;
    opacity: 0.8;
}

input[type="date"]::-webkit-datetime-edit,
input[type="time"]::-webkit-datetime-edit {
    color: var(--color-obsidian) !important;
    -webkit-text-fill-color: var(--color-obsidian) !important;
}

input[type="date"]::-webkit-datetime-edit-fields-wrapper,
input[type="time"]::-webkit-datetime-edit-fields-wrapper {
    color: var(--color-obsidian) !important;
    -webkit-text-fill-color: var(--color-obsidian) !important;
}

input[type="date"]::-webkit-datetime-edit-text,
input[type="time"]::-webkit-datetime-edit-text {
    color: var(--color-obsidian) !important;
    opacity: 0.7;
}

input[type="date"]::-webkit-datetime-edit-month-field,
input[type="date"]::-webkit-datetime-edit-day-field,
input[type="date"]::-webkit-datetime-edit-year-field,
input[type="time"]::-webkit-datetime-edit-hour-field,
input[type="time"]::-webkit-datetime-edit-minute-field {
    color: var(--color-obsidian) !important;
    -webkit-text-fill-color: var(--color-obsidian) !important;
}

/* Для светлой темы - темный текст */
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="date"]::-webkit-datetime-edit,
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="time"]::-webkit-datetime-edit,
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="date"]::-webkit-datetime-edit-fields-wrapper,
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="time"]::-webkit-datetime-edit-fields-wrapper,
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="date"]::-webkit-datetime-edit-month-field,
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="date"]::-webkit-datetime-edit-day-field,
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="date"]::-webkit-datetime-edit-year-field,
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="time"]::-webkit-datetime-edit-hour-field,
body:not([data-theme="dark"]):not(.tg-theme-dark) input[type="time"]::-webkit-datetime-edit-minute-field {
    color: #2C2820 !important;
    -webkit-text-fill-color: #2C2820 !important;
}

/* Firefox */
input[type="date"]::-moz-placeholder,
input[type="time"]::-moz-placeholder {
    color: var(--color-obsidian-light) !important;
    opacity: 0.6;
}

/* Для темной темы - обновляем все внутренние элементы */
[data-theme="dark"] input[type="date"],
[data-theme="dark"] input[type="time"],
body.tg-theme-dark input[type="date"],
body.tg-theme-dark input[type="time"] {
    color: #FAFAF8 !important;
    -webkit-text-fill-color: #FAFAF8 !important;
    background-color: var(--glass-bg) !important;
}

[data-theme="dark"] input[type="date"]::-webkit-datetime-edit,
[data-theme="dark"] input[type="time"]::-webkit-datetime-edit,
body.tg-theme-dark input[type="date"]::-webkit-datetime-edit,
body.tg-theme-dark input[type="time"]::-webkit-datetime-edit {
    color: #FAFAF8 !important;
    -webkit-text-fill-color: #FAFAF8 !important;
}

[data-theme="dark"] input[type="date"]::-webkit-datetime-edit-fields-wrapper,
[data-theme="dark"] input[type="time"]::-webkit-datetime-edit-fields-wrapper,
body.tg-theme-dark input[type="date"]::-webkit-datetime-edit-fields-wrapper,
body.tg-theme-dark input[type="time"]::-webkit-datetime-edit-fields-wrapper {
    color: #FAFAF8 !important;
}

[data-theme="dark"] input[type="date"]::-webkit-datetime-edit-month-field,
[data-theme="dark"] input[type="date"]::-webkit-datetime-edit-day-field,
[data-theme="dark"] input[type="date"]::-webkit-datetime-edit-year-field,
[data-theme="dark"] input[type="time"]::-webkit-datetime-edit-hour-field,
[data-theme="dark"] input[type="time"]::-webkit-datetime-edit-minute-field,
body.tg-theme-dark input[type="date"]::-webkit-datetime-edit-month-field,
body.tg-theme-dark input[type="date"]::-webkit-datetime-edit-day-field,
body.tg-theme-dark input[type="date"]::-webkit-datetime-edit-year-field,
body.tg-theme-dark input[type="time"]::-webkit-datetime-edit-hour-field,
body.tg-theme-dark input[type="time"]::-webkit-datetime-edit-minute-field {
    color: #FAFAF8 !important;
    -webkit-text-fill-color: #FAFAF8 !important;
}

[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator,
[data-theme="dark"] input[type="time"]::-webkit-calendar-picker-indicator,
body.tg-theme-dark input[type="date"]::-webkit-calendar-picker-indicator,
body.tg-theme-dark input[type="time"]::-webkit-calendar-picker-indicator {
    filter: invert(0.8) brightness(1.3);
    opacity: 0.9;
}

.input-premium.small {
    padding: var(--spacing-sm);
    font-size: 14px;
}

.input-hint {
    display: block;
    margin-top: var(--spacing-xs);
    font-size: 13px;
    color: var(--color-obsidian-light);
    font-weight: 300;
}

/* Стили для доп. специалиста удалены - теперь использует .addon-simple-card */

/* Группа специалистов */
.specialists-group {
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-platinum);
}
    transition: all var(--transition-fast);
    font-family: var(--font-primary);
}

.btn-remove-cleaner:hover {
    background: var(--color-champagne);
    color: white;
}

.label-hint {
    opacity: 0.7;
    font-weight: 400;
    margin-left: var(--spacing-xs);
    font-size: 0.9em;
}

.form-hint {
    margin-bottom: var(--spacing-sm);
    opacity: 0.8;
    font-size: 0.9em;
    color: var(--color-obsidian-light);
}

/* Подсказки с отступами и иконками */
.ir-param-hint.centered {
    margin-top: var(--spacing-sm);
    text-align: center;
}

.dc-param-hint.spaced {
    margin-top: var(--spacing-sm);
}

.hint-icon {
    width: 14px;
    height: 14px;
    vertical-align: middle;
    opacity: 0.6;
}

.label-premium {
    display: block;
    margin-bottom: var(--spacing-sm);
    font-size: 15px;
    font-weight: 500;
    color: var(--color-obsidian);
}

/* Пресеты */
.preset-group {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-md);
}

.preset-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    color: var(--color-obsidian);
    cursor: pointer;
    transition: all var(--transition-medium);
    font-family: var(--font-primary);
}

.preset-btn:hover {
    border-color: var(--color-champagne);
    color: var(--color-champagne);
}

.preset-btn.active {
    background: var(--color-champagne);
    color: white;
    border-color: var(--color-champagne);
}

/* Кнопки */
.btn-primary {
    width: 100%;
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--gradient-accent);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 16px;
    font-weight: 500;
    color: white;
    cursor: pointer;
    transition: all var(--transition-medium);
    font-family: var(--font-primary);
    margin-top: var(--spacing-md);
    box-shadow: 0 4px 16px rgba(139, 105, 20, 0.3);
}

.btn-primary {
    position: relative;
    overflow: hidden;
}

.btn-primary::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    transform: translate(-50%, -50%);
    transition: width 0.6s, height 0.6s;
}

.btn-primary:hover::before {
    width: 300px;
    height: 300px;
}

.btn-primary:hover {
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 8px 32px rgba(184, 160, 130, 0.35);
}

.btn-primary:active {
    transform: translateY(-1px) scale(1);
    transition: all 0.15s cubic-bezier(0.16, 1, 0.3, 1);
}

.btn-secondary {
    width: 100%;
    padding: var(--spacing-md) var(--spacing-lg);
    background: transparent;
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    font-size: 16px;
    font-weight: 500;
    color: var(--color-obsidian);
    cursor: pointer;
    transition: all var(--transition-medium);
    font-family: var(--font-primary);
}

.btn-secondary:hover {
    border-color: var(--color-champagne);
    color: var(--color-champagne);
}

.btn-link {
    background: none;
    border: none;
    color: var(--color-champagne);
    font-size: 14px;
    cursor: pointer;
    padding: var(--spacing-sm) 0;
    text-decoration: underline;
    text-decoration-color: transparent;
    transition: all var(--transition-medium);
    font-family: var(--font-primary);
}

.btn-link:hover {
    text-decoration-color: var(--color-champagne);
}

.actions {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-lg);
}

.actions .btn-primary,
.actions .btn-secondary {
    flex: 1;
}

/* Форма группы */
.form-group {
    margin-bottom: var(--spacing-md);
}

.row {
    display: flex;
    gap: var(--spacing-sm);
}

.col {
    flex: 1;
}

/* ==========================================
   LUXURY RESIDENCE ILLUSTRATIONS
   Four Seasons / Aman / Bulgari Style
   ========================================== */

.residence-selection {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-lg);
    max-width: 500px;
    margin: 0 auto var(--spacing-lg);
}

.residence-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-xl) var(--spacing-lg);
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.residence-card:hover {
    border-color: rgba(184, 160, 130, 0.4);
    transform: translateY(-4px);
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.08);
}

.residence-card:has(input:checked) {
    border-color: var(--color-champagne);
    border-width: 2px;
    background: rgba(184, 160, 130, 0.05);
    box-shadow: 
        inset 0 0 40px rgba(184, 160, 130, 0.06),
        0 12px 40px rgba(184, 160, 130, 0.12);
}

.residence-illustration {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: var(--spacing-lg) var(--spacing-md);
}

.residence-icon {
    width: 100%;
    max-width: 90px;
    height: auto;
    color: var(--color-obsidian-light);
    opacity: 0.8;
    transition: all 0.4s ease;
}

.residence-card:hover .residence-icon {
    color: var(--color-champagne);
    opacity: 0.9;
    transform: scale(1.02);
}

.residence-card:has(input:checked) .residence-icon {
    color: var(--color-champagne);
    opacity: 1;
}

/* ==========================================
   АНИМАЦИИ ИКОНОК РЕЗИДЕНЦИЙ
   NYC Tower & London Townhouse
   Premium Animation System
   ========================================== */

/* ===== NYC TOWER — ПЛАВНЫЕ АНИМАЦИИ ===== */

/* Башня — прорисовка корпуса */
.tower-icon .tower-body {
    stroke-dasharray: 300;
    stroke-dashoffset: 300;
    animation: drawTower 2s ease-out forwards;
}

/* Окна башни — каскадное появление */
.tower-icon .window {
    opacity: 0;
    transform: scale(0.8);
    animation: windowAppear 0.5s ease-out forwards;
}

/* Последовательность появления окон снизу вверх */
.tower-icon .window:nth-child(3) { animation-delay: 0.4s; }
.tower-icon .window:nth-child(4) { animation-delay: 0.45s; }
.tower-icon .window:nth-child(5) { animation-delay: 0.5s; }
.tower-icon .window:nth-child(6) { animation-delay: 0.55s; }
.tower-icon .window:nth-child(7) { animation-delay: 0.6s; }
.tower-icon .window:nth-child(8) { animation-delay: 0.65s; }
.tower-icon .window:nth-child(9) { animation-delay: 0.7s; }
.tower-icon .window:nth-child(10) { animation-delay: 0.75s; }
.tower-icon .window:nth-child(11) { animation-delay: 0.8s; }
.tower-icon .window:nth-child(12) { animation-delay: 0.85s; }
.tower-icon .window:nth-child(13) { animation-delay: 0.9s; }
.tower-icon .window:nth-child(14) { animation-delay: 0.95s; }
.tower-icon .window:nth-child(15) { animation-delay: 1.0s; }
.tower-icon .window:nth-child(16) { animation-delay: 1.05s; }
.tower-icon .window:nth-child(17) { animation-delay: 1.1s; }
.tower-icon .window:nth-child(18) { animation-delay: 1.15s; }
.tower-icon .window:nth-child(19) { animation-delay: 1.2s; }
.tower-icon .window:nth-child(20) { animation-delay: 1.25s; }
.tower-icon .window:nth-child(21) { animation-delay: 1.3s; }
.tower-icon .window:nth-child(22) { animation-delay: 1.35s; }
.tower-icon .window:nth-child(23) { animation-delay: 1.4s; }

/* Лобби башни */
.tower-icon .lobby-arch {
    stroke-dasharray: 60;
    stroke-dashoffset: 60;
    animation: drawElement 0.6s ease-out 1.5s forwards;
}

/* Деревья */
.tower-icon .tree {
    opacity: 0;
    transform: scale(0.5) translateY(5px);
    animation: growTree 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

.tower-icon .tree:first-of-type { animation-delay: 1.8s; }
.tower-icon .tree:last-of-type { animation-delay: 2.0s; }

/* ===== ДЕРЕВЬЯ И РАСТИТЕЛЬНОСТЬ ===== */

/* ===== BELGRAVIA MANSION — ПЛАВНЫЕ АНИМАЦИИ ===== */

/* Фасад особняка — прорисовка */
.mansion-icon .facade {
    stroke-dasharray: 400;
    stroke-dashoffset: 400;
    animation: drawFacade 1.5s ease-out forwards;
}

/* Фронтон */
.mansion-icon .pediment {
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    animation: drawElement 0.6s ease-out 0.5s forwards;
}

/* Слуховое окно */
.mansion-icon .dormer {
    opacity: 0;
    transform: scale(0.5);
    animation: scaleIn 0.4s ease-out 0.8s forwards;
}

/* Верхние окна */
.mansion-icon .upper-window {
    opacity: 0;
    transform: scale(0.9);
    animation: windowAppear 0.4s ease-out forwards;
}

.mansion-icon .upper-window:nth-of-type(1) { animation-delay: 0.6s; }
.mansion-icon .upper-window:nth-of-type(2) { animation-delay: 0.7s; }
.mansion-icon .upper-window:nth-of-type(3) { animation-delay: 0.8s; }
.mansion-icon .upper-window:nth-of-type(4) { animation-delay: 0.9s; }

/* Арочные окна */
.mansion-icon .window-arch {
    stroke-dasharray: 80;
    stroke-dashoffset: 80;
    animation: drawElement 0.6s ease-out forwards;
}

.mansion-icon .window-arch:first-of-type { animation-delay: 1.0s; }
.mansion-icon .window-arch:last-of-type { animation-delay: 1.1s; }

/* Колонны */
.mansion-icon .column {
    stroke-dasharray: 50;
    stroke-dashoffset: 50;
    animation: drawElement 0.5s ease-out forwards;
}

.mansion-icon .column:first-of-type { animation-delay: 1.2s; }
.mansion-icon .column:last-of-type { animation-delay: 1.3s; }

/* Арка входа */
.mansion-icon .entrance-arch {
    stroke-dasharray: 50;
    stroke-dashoffset: 50;
    animation: drawElement 0.4s ease-out 1.4s forwards;
}

/* Топиарные кусты */
.mansion-icon .topiary {
    opacity: 0;
    transform: scale(0.5) translateY(5px);
    animation: growTree 0.7s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

.mansion-icon .topiary:first-of-type { animation-delay: 1.6s; }
.mansion-icon .topiary:last-of-type { animation-delay: 1.8s; }

/* ===== KEYFRAMES ===== */

@keyframes drawTowerUp {
    0% { 
        stroke-dashoffset: 300;
        opacity: 0.3;
    }
    50% {
        opacity: 0.7;
    }
    100% { 
        stroke-dashoffset: 0;
        opacity: 1;
    }
}

@keyframes windowLightUp {
    0% { 
        opacity: 0;
        transform: scale(0.5);
    }
    60% {
        opacity: 0.9;
        transform: scale(1.1);
    }
    100% { 
        opacity: 0.7;
        transform: scale(1);
    }
}

@keyframes sketchFacade {
    0% { 
        stroke-dashoffset: 400;
        opacity: 0.2;
    }
    100% { 
        stroke-dashoffset: 0;
        opacity: 1;
    }
}

@keyframes drawArch {
    0% { 
        stroke-dashoffset: 80;
        opacity: 0;
    }
    100% { 
        stroke-dashoffset: 0;
        opacity: 1;
    }
}

@keyframes growPlant {
    0% { 
        opacity: 0;
        transform: scale(0.3) translateY(10px);
    }
    60% {
        opacity: 0.6;
        transform: scale(1.1) translateY(-2px);
    }
    100% { 
        opacity: 0.5;
        transform: scale(1) translateY(0);
    }
}

@keyframes drawPediment {
    0% { 
        stroke-dashoffset: 100;
        opacity: 0;
    }
    100% { 
        stroke-dashoffset: 0;
        opacity: 1;
    }
}

@keyframes fadeInDormer {
    0% { 
        opacity: 0;
        transform: scale(0.5);
    }
    100% { 
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes revealWindow {
    0% { 
        opacity: 0;
    }
    100% { 
        opacity: 1;
    }
}

@keyframes drawColumn {
    0% { 
        stroke-dashoffset: 40;
    }
    100% { 
        stroke-dashoffset: 0;
    }
}

/* ===== HOVER ЭФФЕКТЫ — БАШНЯ ===== */
/* Используем только filter/opacity/transform с transition чтобы не ломать animation */

.residence-card:hover .tower-icon .tower-body {
    filter: drop-shadow(0 0 6px rgba(184, 160, 130, 0.3));
    transition: filter 0.4s ease;
}

.residence-card:hover .tower-icon .window {
    opacity: 0.85 !important;
    filter: drop-shadow(0 0 2px rgba(184, 160, 130, 0.3));
    transition: opacity 0.3s ease, filter 0.3s ease;
}

.residence-card:hover .tower-icon .tree {
    opacity: 0.8 !important;
    filter: drop-shadow(0 0 2px rgba(184, 160, 130, 0.2));
    transition: opacity 0.4s ease, filter 0.4s ease;
}

/* ===== HOVER ЭФФЕКТЫ — ОСОБНЯК ===== */

.residence-card:hover .mansion-icon .facade {
    filter: drop-shadow(0 0 6px rgba(184, 160, 130, 0.3));
    transition: filter 0.4s ease;
}

.residence-card:hover .mansion-icon .window-arch {
    stroke-width: 0.9;
    filter: drop-shadow(0 0 2px rgba(184, 160, 130, 0.3));
    transition: stroke-width 0.3s ease, filter 0.3s ease;
}

.residence-card:hover .mansion-icon .upper-window {
    opacity: 0.85 !important;
    filter: drop-shadow(0 0 2px rgba(184, 160, 130, 0.3));
    transition: opacity 0.3s ease, filter 0.3s ease;
}

.residence-card:hover .mansion-icon .topiary {
    opacity: 0.8 !important;
    filter: drop-shadow(0 0 2px rgba(184, 160, 130, 0.2));
    transition: opacity 0.4s ease, filter 0.4s ease;
}

/* ===== ВЫБРАННОЕ СОСТОЯНИЕ — БАШНЯ ===== */
/* Используем только filter/opacity БЕЗ animation чтобы не ломать исходные анимации */

.residence-card:has(input:checked) .tower-icon .tower-body {
    stroke: var(--color-champagne);
    filter: drop-shadow(0 0 12px rgba(184, 160, 130, 0.5));
    transition: stroke 0.4s ease, filter 0.4s ease;
}

.residence-card:has(input:checked) .tower-icon .window {
    opacity: 0.95 !important;
    fill: rgba(184, 160, 130, 0.4);
    filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.5));
    transition: opacity 0.4s ease, fill 0.4s ease, filter 0.4s ease;
}

.residence-card:has(input:checked) .tower-icon .lobby-arch {
    stroke: var(--color-champagne);
    filter: drop-shadow(0 0 6px rgba(184, 160, 130, 0.4));
    transition: stroke 0.4s ease, filter 0.4s ease;
}

.residence-card:has(input:checked) .tower-icon .tree {
    opacity: 0.85 !important;
    filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.3));
    transform: scale(1) !important;
    transition: opacity 0.4s ease, filter 0.4s ease;
}

/* ===== ВЫБРАННОЕ СОСТОЯНИЕ — ОСОБНЯК ===== */
/* Используем только filter/opacity БЕЗ animation чтобы не ломать исходные анимации */

.residence-card:has(input:checked) .mansion-icon .facade {
    stroke: var(--color-champagne);
    filter: drop-shadow(0 0 12px rgba(184, 160, 130, 0.5));
    transition: stroke 0.4s ease, filter 0.4s ease;
}

.residence-card:has(input:checked) .mansion-icon .window-arch {
    stroke: var(--color-champagne);
    stroke-width: 1;
    filter: drop-shadow(0 0 5px rgba(184, 160, 130, 0.5));
    transition: stroke 0.4s ease, stroke-width 0.4s ease, filter 0.4s ease;
}

.residence-card:has(input:checked) .mansion-icon .upper-window {
    opacity: 1 !important;
    fill: rgba(184, 160, 130, 0.35);
    filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.5));
    transition: opacity 0.4s ease, fill 0.4s ease, filter 0.4s ease;
}

.residence-card:has(input:checked) .mansion-icon .column {
    stroke: var(--color-champagne);
    stroke-width: 1.1;
    filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.4));
    transition: stroke 0.4s ease, stroke-width 0.4s ease, filter 0.4s ease;
}

.residence-card:has(input:checked) .mansion-icon .entrance-arch {
    stroke: var(--color-champagne);
    filter: drop-shadow(0 0 5px rgba(184, 160, 130, 0.4));
    transition: stroke 0.4s ease, filter 0.4s ease;
}

.residence-card:has(input:checked) .mansion-icon .topiary {
    opacity: 0.85 !important;
    filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.3));
    transform: scale(1) !important;
    transition: opacity 0.4s ease, filter 0.4s ease;
}

.residence-card:has(input:checked) .mansion-icon .dormer {
    opacity: 1 !important;
    filter: drop-shadow(0 0 3px rgba(184, 160, 130, 0.4));
    transition: opacity 0.4s ease, filter 0.4s ease;
}

/* ===== KEYFRAMES ДЛЯ ПЛАВНЫХ АНИМАЦИЙ ===== */

/* Прорисовка башни снизу вверх */
@keyframes drawTower {
    0% {
        stroke-dashoffset: 300;
        opacity: 0.2;
    }
    30% {
        opacity: 0.6;
    }
    100% {
        stroke-dashoffset: 0;
        opacity: 1;
    }
}

/* Прорисовка фасада особняка */
@keyframes drawFacade {
    0% {
        stroke-dashoffset: 400;
        opacity: 0.2;
    }
    30% {
        opacity: 0.6;
    }
    100% {
        stroke-dashoffset: 0;
        opacity: 1;
    }
}

/* Прорисовка элементов */
@keyframes drawElement {
    0% {
        stroke-dashoffset: inherit;
        opacity: 0.2;
    }
    100% {
        stroke-dashoffset: 0;
        opacity: 1;
    }
}

/* Появление окна с мягким масштабированием */
@keyframes windowAppear {
    0% {
        opacity: 0;
        transform: scale(0.3);
    }
    50% {
        opacity: 0.5;
        transform: scale(1.15);
    }
    70% {
        opacity: 0.7;
        transform: scale(0.95);
    }
    100% {
        opacity: 0.7;
        transform: scale(1);
    }
}

/* Мягкое масштабирование */
@keyframes scaleIn {
    0% {
        opacity: 0;
        transform: scale(0.3);
    }
    60% {
        opacity: 0.9;
        transform: scale(1.1);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

/* Рост дерева/куста с пружинным эффектом */
@keyframes growTree {
    0% {
        opacity: 0;
        transform: scale(0.2) translateY(10px);
    }
    50% {
        opacity: 0.5;
        transform: scale(1.2) translateY(-3px);
    }
    70% {
        opacity: 0.6;
        transform: scale(0.9) translateY(1px);
    }
    100% {
        opacity: 0.6;
        transform: scale(1) translateY(0);
    }
}

/* Пульсация окна */
@keyframes windowPulse {
    0%, 100% { 
        opacity: 0.6;
        transform: scale(1);
    }
    50% { 
        opacity: 0.95;
        transform: scale(1.08);
    }
}

/* Свечение окна */
@keyframes windowGlow {
    0%, 100% { 
        opacity: 0.7;
        filter: drop-shadow(0 0 2px rgba(184, 160, 130, 0.4));
    }
    50% { 
        opacity: 1;
        filter: drop-shadow(0 0 8px rgba(184, 160, 130, 0.8));
    }
}

/* Пульсация арки */
@keyframes archPulse {
    0%, 100% { 
        stroke-width: 0.6;
        opacity: 0.8;
    }
    50% { 
        stroke-width: 1;
        opacity: 1;
    }
}

/* Покачивание растений на ветру */
@keyframes swayPlant {
    0%, 100% { 
        transform: translateX(0) rotate(0deg) scale(1);
    }
    25% { 
        transform: translateX(-1.5px) rotate(-2deg) scale(1.02);
    }
    50% {
        transform: translateX(0) rotate(0deg) scale(1);
    }
    75% { 
        transform: translateX(1.5px) rotate(2deg) scale(1.02);
    }
}

/* Мобильная адаптация */
@media (max-width: 480px) {
    .residence-selection {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }
    
    .residence-card {
        padding: var(--spacing-lg) var(--spacing-md);
        flex-direction: row;
        gap: var(--spacing-md);
    }
    
    .residence-illustration {
        width: auto;
        padding: var(--spacing-sm);
        flex-shrink: 0;
    }
    
    .residence-icon {
        max-width: 70px;
    }
    
    .card-content {
        text-align: left;
    }
}

@keyframes drawResidence {
    to {
        stroke-dashoffset: 0;
    }
}

@keyframes drawResidenceDetail {
    to {
        stroke-dashoffset: 0;
    }
}

/* Иллюстрации окон */
.windows-visual {
    display: flex;
    gap: var(--spacing-lg);
    justify-content: center;
    margin: var(--spacing-lg) 0;
    padding: var(--spacing-lg);
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
}

.window-type {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-md);
}

.window-icon {
    width: 80px;
    height: 100px;
    color: var(--color-obsidian-light);
    transition: color var(--transition-medium);
    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.1));
}

.window-type:hover .window-icon {
    color: var(--color-champagne);
    filter: drop-shadow(0 4px 12px rgba(139, 105, 20, 0.2));
}

/* SVG animation - drawing effect для окон (только один раз при первом показе) */
.window-frame.animated {
    stroke-dasharray: 360;
    stroke-dashoffset: 360;
    animation: drawFrame 1.2s ease-out forwards;
}

.window-line.animated {
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    animation: drawLine 0.8s ease-out forwards;
}

.window-line-v.animated {
    animation-delay: 0.5s;
}

.window-line-h.animated {
    animation-delay: 0.7s;
}

.window-line-v2.animated {
    animation-delay: 0.9s;
}

.window-dot.animated {
    opacity: 0;
    animation: fadeInDot 0.4s ease-out forwards;
    animation-delay: 1.1s;
}

/* Статичное состояние (без анимации при возврате) */
.window-frame:not(.animated) {
    stroke-dasharray: none;
    stroke-dashoffset: 0;
}

.window-line:not(.animated) {
    stroke-dasharray: none;
    stroke-dashoffset: 0;
}

.window-dot:not(.animated) {
    opacity: 0.5;
}

@keyframes drawFrame {
    to {
        stroke-dashoffset: 0;
    }
}

@keyframes drawLine {
    to {
        stroke-dashoffset: 0;
    }
}

@keyframes fadeInDot {
    to {
        opacity: 0.5;
    }
}

.window-input-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
}

.window-label {
    font-size: 13px;
    color: var(--color-obsidian-light);
    font-weight: 500;
}

/* Сворачиваемые секции */
.section-toggle {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md);
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-medium);
    margin: var(--spacing-lg) 0 var(--spacing-sm);
}

.section-toggle:hover {
    border-color: var(--color-champagne);
}

.toggle-icon {
    font-size: 12px;
    color: var(--color-obsidian-light);
    transition: transform var(--transition-medium);
}

.section-toggle.active .toggle-icon {
    transform: rotate(180deg);
}

.collapsible-section {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-slow), opacity var(--transition-medium);
    opacity: 0;
}

.collapsible-section.active {
    max-height: 2000px;
    opacity: 1;
    margin-bottom: var(--spacing-lg);
}

/* Результат расчета */
.quote-total-premium {
    font-family: var(--font-accent);
    font-size: 48px;
    font-weight: 400;
    color: var(--color-champagne);
    text-align: center;
    margin: var(--spacing-lg) 0;
    animation: priceBounce 0.8s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes priceBounce {
    0% {
        opacity: 0;
        transform: scale(0.5);
    }
    60% {
        transform: scale(1.05);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.quote-breakdown-premium {
    margin: var(--spacing-lg) 0;
}

.breakdown-item-premium {
    display: flex;
    justify-content: space-between;
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--glass-border);
    font-size: 14px;
}

.breakdown-item-premium:last-child {
    border-bottom: none;
}

.breakdown-name-premium {
    color: var(--color-obsidian);
    font-weight: 300;
}

.breakdown-amount-premium {
    font-weight: 500;
    color: var(--color-obsidian);
}

/* ==========================================
   ПРЕМИАЛЬНЫЙ ЭКРАН УСПЕХА — FOUR SEASONS СТИЛЬ
   ========================================== */

/* Контейнер успеха */
.success-step {
    min-height: 100vh;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: var(--spacing-xl) var(--spacing-md) calc(var(--spacing-xl) + 12px);
}

.success-container {
    width: 100%;
    max-width: 480px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

/* Иконка подтверждения — минималистичная, матовая */
.success-check {
    color: var(--color-champagne);
    opacity: 0.8;
    margin-bottom: 32px;
    animation: successFadeIn 0.8s ease-out;
}

.success-check svg {
    width: 56px;
    height: 56px;
}

/* Заголовок */
.success-title {
    font-family: var(--font-accent);
    font-size: 28px;
    font-weight: 400;
    color: var(--color-obsidian);
    margin: 0 0 8px 0;
    letter-spacing: 0.02em;
}

/* Подзаголовок */
.success-subtitle {
    font-size: 15px;
    line-height: 1.7;
    color: var(--color-obsidian-light);
    margin: 0 0 40px 0;
    max-width: 380px;
}

/* Карточка стоимости */
.success-price-card {
    width: 100%;
    background: var(--glass-bg);
    border: 1px solid var(--color-platinum);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg) var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-sm);
}

.success-price-label {
    font-size: 13px;
    color: var(--color-obsidian-light);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.success-price-value {
    font-family: var(--font-accent);
    font-size: 36px;
    font-weight: 500;
    color: var(--color-champagne);
    letter-spacing: -0.01em;
}

.success-price-disclaimer {
    display: block;
    font-size: 11px;
    font-weight: 400;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-top: var(--spacing-sm);
    line-height: 1.4;
    max-width: 280px;
    text-align: center;
}

.success-price-note {
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    max-width: 300px;
    line-height: 1.5;
}

/* Секции */
.success-services,
.success-next-steps,
.success-contacts {
    width: 100%;
    text-align: left;
    margin-bottom: 28px;
}

.success-section-title {
    font-family: var(--font-primary);
    font-size: 13px;
    font-weight: 500;
    color: var(--color-obsidian-light);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin: 0 0 16px 0;
}

/* Состав услуги */
.success-service-item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--color-platinum);
}

.success-service-item:last-child {
    border-bottom: none;
}

.success-service-name {
    font-size: 14px;
    color: var(--color-obsidian);
    flex: 1;
    min-width: 0;
    line-height: 1.4;
}

.success-service-price {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-obsidian);
    flex-shrink: 0;
    white-space: nowrap;
    text-align: right;
}

/* Что дальше — элегантный стиль без точек */
.success-steps-elegant {
    margin: 0 0 20px 0;
}

.success-steps-elegant p {
    font-size: 14px;
    line-height: 1.6;
    color: var(--color-obsidian);
    margin: 0 0 8px 0;
    opacity: 0.9;
}

.success-steps-elegant p:last-child {
    margin-bottom: 0;
}

.success-relax-note {
    font-size: 14px;
    color: var(--color-champagne);
    margin: 0;
    font-weight: 400;
}

/* Контакты — минималистичные, в одну линию */
.success-contacts {
    padding-top: 24px;
    margin-top: 16px;
    border-top: 1px solid var(--color-platinum);
    text-align: center;
}

.success-contacts-links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.success-contact-link {
    font-size: 14px;
    color: var(--color-champagne);
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.success-contact-link:hover {
    opacity: 0.7;
}

.success-contact-divider {
    color: var(--color-obsidian-light);
    opacity: 0.4;
}

/* Кнопка новой заявки — сдержанная */
.success-btn {
    margin-top: var(--spacing-xl);
    width: 100%;
    max-width: 280px;
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: 14px;
    letter-spacing: 0.05em;
}

/* Анимация появления */
@keyframes successFadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 0.8;
        transform: translateY(0);
    }
}

/* Анимация контента */
.success-content {
    animation: contentFadeIn 0.6s ease-out 0.2s both;
}

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

/* Тёмная тема */
[data-theme="dark"] .success-price-card {
    background: rgba(255, 255, 255, 0.03);
    border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .success-service-item,
[data-theme="dark"] .success-contacts {
    border-color: rgba(255, 255, 255, 0.1);
}

/* Загрузка */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(26, 26, 26, 0.7);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

.spinner-premium {
    width: 48px;
    height: 48px;
    border: 3px solid var(--glass-border);
    border-top-color: var(--color-champagne);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

.loading-overlay p {
    margin-top: var(--spacing-md);
    color: var(--color-ivory);
    font-size: 14px;
    font-weight: 300;
}

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

/* Адаптивность */
@media (max-width: 480px) {
    .glass-container {
        padding: var(--spacing-lg) var(--spacing-md);
        padding-top: calc(75px + var(--spacing-sm));
        margin-top: 0;
    }
    
    .step-title {
        font-size: var(--font-size-xl);
        padding-top: 0;
        margin-top: 0;
    }
    
    .step-subtitle {
        font-size: var(--font-size-sm);
        margin-bottom: var(--spacing-md);
    }
    
    /* Текстовые карточки площади на мобильных */
    .area-ranges-text {
        gap: var(--spacing-xs);
    }
    
    .area-range-text-card {
        padding: var(--spacing-sm) var(--spacing-md);
    }
    
    .range-value {
        font-size: 14px;
    }
    
    .range-name {
        font-size: 12px;
    }
    
    /* Резиденции на мобильных */
    .residence-grid {
        gap: var(--spacing-sm);
    }
    
    .residence-card {
        padding: var(--spacing-md);
    }
    
    /* Кнопки действий */
    .actions {
        gap: var(--spacing-sm);
    }
    
    .btn-primary,
    .btn-secondary {
        padding: var(--spacing-md);
        font-size: 14px;
    }
    
    /* Форма контактов */
    .form-section {
        padding: var(--spacing-md);
    }
    
    .form-input {
        padding: var(--spacing-sm) var(--spacing-md);
        font-size: 14px;
    }
    
    /* Модули доп. услуг */
    .addon-module-unified {
        margin-bottom: var(--spacing-sm);
    }
    
    .addon-module-title {
        font-size: 13px;
    }
    
    .addon-module-hint {
        font-size: 11px;
    }
    
    /* Общая стоимость доп. услуг */
    .addons-summary {
        padding: var(--spacing-md);
    }
    
    .addons-summary-label {
        font-size: 13px;
    }
    
    .addons-summary-value {
        font-size: 18px;
    }
}

/* Для планшетов и средних экранов */
@media (min-width: 481px) and (max-width: 768px) {
    .glass-container {
        padding-top: calc(85px + var(--spacing-md));
        margin-top: 0;
    }
}

/* Для больших экранов */
@media (min-width: 769px) {
    .glass-container {
        padding-top: calc(90px + var(--spacing-md));
        margin-top: 0;
    }
}

/* Скрытие элементов */
input[type="radio"],
input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

/* Гарантируем что label получает все клики */
label.radio-card,
label.checkbox-card {
    display: block;
    user-select: none;
    -webkit-user-select: none;
}

/* Прелоадер с логотипом */
.splash-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: #E8E3D6; /* Бежевый фон на весь экран */
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    animation: splashFadeIn 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.splash-screen.fade-out {
    animation: splashFadeOut 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes splashFadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes splashFadeOut {
    from {
        opacity: 1;
    }
    to {
        opacity: 0;
        transform: scale(0.95);
    }
}

.splash-content {
    display: flex;
    align-items: center;
    justify-content: center;
    animation: logoAppear 1.5s cubic-bezier(0.16, 1, 0.3, 1) backwards;
}

@keyframes logoAppear {
    0% {
        opacity: 0;
        transform: scale(0.8);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.hilte-logo {
    width: 200px;
    height: 50px;
    position: relative;
    overflow: hidden;
}


.logo-path {
    fill: #000000;
    opacity: 0;
    clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
    animation: logoDrawLeftToRight 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Анимация логотипа слева направо по порядку */
.logo-path:nth-child(1) {
    animation-delay: 0.3s;
}

.logo-path:nth-child(2) {
    animation-delay: 0.5s;
}

.logo-path:nth-child(3) {
    animation-delay: 0.7s;
}

.logo-path:nth-child(4) {
    animation-delay: 0.9s;
}

.logo-path:nth-child(5) {
    animation-delay: 1.1s;
}

@keyframes logoDrawLeftToRight {
    0% {
        opacity: 0;
        clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
        transform: translateX(-10px);
    }
    50% {
        opacity: 1;
    }
    100% {
        opacity: 1;
        clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
        transform: translateX(0);
    }
}

/* Чекбокс согласия с условиями */
.agreement-group {
    margin: var(--spacing-lg) 0;
}

.agreement-checkbox {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    cursor: pointer;
    transition: all 0.3s ease;
}

.agreement-checkbox:hover {
    border-color: rgba(184, 160, 130, 0.4);
}

.agreement-checkbox:has(input:checked) {
    border-color: var(--color-champagne);
    background: rgba(184, 160, 130, 0.08);
}

/* Показываем чекбокс согласия */
.agreement-checkbox input[type="checkbox"] {
    position: relative !important;
    opacity: 1 !important;
    width: 22px !important;
    height: 22px !important;
    accent-color: var(--color-champagne);
    cursor: pointer;
    flex-shrink: 0;
}

.agreement-checkbox .card-content {
    flex: 1;
    font-size: 14px;
    line-height: 1.5;
    color: var(--color-obsidian);
}

.agreement-checkbox .card-title {
    font-size: 14px;
    font-weight: 400;
}

.agreement-link {
    color: var(--color-champagne);
    text-decoration: underline;
    transition: color 0.3s ease;
}

.agreement-link:hover {
    color: var(--color-champagne-dark);
}

#submit-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

#submit-btn:disabled:hover {
    transform: none;
    box-shadow: none;
}

/* ==========================================
   МОДУЛЬ ХИМЧИСТКИ — ПРЕМИАЛЬНЫЙ СТИЛЬ
   ========================================== */

/* Химчистка и глажка — с разделителем сверху */
.dry-cleaning-module,
.ironing-module {
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-platinum);
}

/* Toggle карточка */
.toggle-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.3s ease;
}

.toggle-card:hover {
    border-color: var(--color-champagne);
}

.toggle-card.small {
    padding: var(--spacing-sm) var(--spacing-md);
}

.toggle-content {
    flex: 1;
}

.toggle-title {
    display: block;
    font-size: 16px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: 4px;
}

.toggle-hint {
    font-size: 13px;
    color: var(--color-obsidian-light);
}

.toggle-price {
    font-size: 14px;
    color: var(--color-champagne);
    font-weight: 500;
}

/* Toggle переключатель */
.toggle-switch {
    width: 48px;
    height: 28px;
    background: var(--color-platinum);
    border-radius: 14px;
    position: relative;
    margin-left: var(--spacing-md);
    transition: background 0.3s ease;
    flex-shrink: 0;
}

.toggle-switch::after {
    content: '';
    position: absolute;
    width: 22px;
    height: 22px;
    background: white;
    border-radius: 50%;
    top: 3px;
    left: 3px;
    transition: transform 0.3s ease;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.toggle-card input:checked + .toggle-content + .toggle-switch,
.toggle-card input:checked ~ .toggle-switch {
    background: var(--color-champagne);
}

.toggle-card input:checked + .toggle-content + .toggle-switch::after,
.toggle-card input:checked ~ .toggle-switch::after {
    transform: translateX(20px);
}

/* Блок химчистки — стили уже в унифицированной секции */

@keyframes dcSlideDown {
    from {
        opacity: 0;
        max-height: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        max-height: 2000px;
        transform: translateY(0);
    }
}

.dry-cleaning-intro {
    font-size: 14px;
    color: var(--color-obsidian-light);
    margin: 0 0 var(--spacing-lg) 0;
    text-align: center;
}

/* Категории химчистки */
.dc-categories {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.dc-category-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-md);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.3s ease;
    color: var(--color-obsidian);
    font-size: 12px;
    text-align: center;
}

.dc-category-card:hover {
    transform: scale(1.02);
    border-color: var(--color-champagne);
}

.dc-category-card.active {
    border-color: var(--color-champagne);
    background: rgba(var(--color-champagne-rgb), 0.1);
}

.dc-category-card.active .dc-icon {
    color: var(--color-champagne);
}

.dc-icon {
    width: 32px;
    height: 32px;
    color: var(--color-obsidian-light);
    transition: color 0.3s ease;
}

/* Параметры категории */
.dc-params {
    animation: dcFadeIn 0.3s ease-out;
}

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

.dc-param-group {
    margin-bottom: var(--spacing-lg);
    padding: var(--spacing-md);
    background: var(--glass-bg);
    border-radius: var(--radius-md);
    border: 1px solid var(--glass-border);
}

.dc-param-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: var(--spacing-sm);
}

.dc-param-hint {
    font-size: 12px;
    color: var(--color-obsidian-light);
    margin-bottom: var(--spacing-md);
    line-height: 1.5;
}

/* Селектор количества */
.dc-quantity {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.dc-qty-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    color: var(--color-obsidian);
    font-size: 20px;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.dc-qty-btn:hover {
    border-color: var(--color-champagne);
    color: var(--color-champagne);
}

.dc-qty-btn:active {
    transform: scale(0.95);
}

.dc-qty-value {
    font-size: 20px;
    font-weight: 500;
    color: var(--color-obsidian);
    min-width: 40px;
    text-align: center;
}

/* Выбор материала */
.dc-materials {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

.dc-material-btn {
    flex: 1;
    min-width: 120px;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: center;
}

.dc-material-btn:hover {
    border-color: var(--color-champagne);
}

.dc-material-btn.active {
    border-color: var(--color-champagne);
    background: rgba(var(--color-champagne-rgb), 0.1);
}

.dc-material-name {
    display: block;
    font-size: 13px;
    color: var(--color-obsidian);
    margin-bottom: 4px;
}

.dc-material-price {
    font-size: 12px;
    color: var(--color-champagne);
}

/* Выбор типа */
.dc-types {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.dc-type-btn {
    flex: 1;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 14px;
    color: var(--color-obsidian);
}

.dc-type-btn:hover {
    border-color: var(--color-champagne);
}

.dc-type-btn.active {
    border-color: var(--color-champagne);
    background: rgba(var(--color-champagne-rgb), 0.1);
}

/* Поле площади */
.dc-area-input {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.dc-area-input input {
    width: 100px;
    padding: var(--spacing-sm);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    color: var(--color-obsidian);
    font-size: 16px;
    text-align: center;
}

.dc-area-input input:focus {
    border-color: var(--color-champagne);
    outline: none;
}

.dc-area-input span {
    font-size: 14px;
    color: var(--color-obsidian-light);
}

/* Дополнение биозагрязнения */
.dc-addon {
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-platinum);
}

.dc-addon-note {
    font-size: 12px;
    color: var(--color-obsidian-light);
    margin: var(--spacing-sm) 0 0 0;
    text-align: center;
}

/* Итог по химчистке */
.dc-total {
    margin-top: var(--spacing-lg);
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--glass-bg);
    border: 1px solid var(--color-champagne);
    border-radius: var(--radius-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dc-total-label {
    font-size: 14px;
    color: var(--color-obsidian);
}

.dc-total-value {
    font-size: 20px;
    font-weight: 500;
    color: var(--color-champagne);
}

/* Адаптивность химчистки */
@media (max-width: 480px) {
    .dc-categories {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .dc-materials {
        flex-direction: column;
    }
    
    .dc-material-btn {
        min-width: 100%;
    }
    
    .toggle-card {
        flex-wrap: wrap;
        gap: var(--spacing-sm);
    }
    
    .toggle-switch {
        margin-left: 0;
    }
}

/* Описание материала */
.dc-material-desc {
    display: block;
    font-size: 11px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-top: 2px;
}

.dc-material-btn.active .dc-material-desc {
    opacity: 0.9;
}

/* Подсказка по выбору материала */
.dc-material-tip {
    font-size: 12px;
    color: var(--color-obsidian-light);
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(255, 255, 255, 0.03);
    border-radius: var(--radius-sm);
    text-align: center;
}

/* Улучшенный glow для активного материала */
.dc-material-btn.active {
    box-shadow: 
        inset 0 0 20px rgba(184, 160, 130, 0.15),
        0 4px 16px rgba(184, 160, 130, 0.2);
    transform: scale(1.02);
}

.dc-material-btn.active .dc-material-name {
    color: var(--color-champagne);
}

/* Haptic pulse animation */
@keyframes hapticPulse {
    0% { transform: scale(1); }
    50% { transform: scale(0.98); }
    100% { transform: scale(1); }
}

@keyframes hapticSuccess {
    0% { transform: scale(1); }
    25% { transform: scale(1.02); }
    50% { transform: scale(0.98); }
    75% { transform: scale(1.01); }
    100% { transform: scale(1); }
}

.haptic-pulse {
    animation: hapticPulse 0.15s ease-out;
}

.haptic-success {
    animation: hapticSuccess 0.3s ease-out;
}

/* Улучшенный стиль биозагрязнений */
.dc-addon .toggle-title {
    font-size: 15px;
}

.dc-addon-note {
    font-size: 12px !important;
    line-height: 1.5 !important;
    opacity: 0.7;
}

/* ==========================================
   ПЕРЕКЛЮЧАТЕЛЬ БИОЗАГРЯЗНЕНИЙ — ЛЮКСОВЫЙ
   ========================================== */

.dc-bio-toggle-wrapper {
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-lg);
    border-top: 1px solid rgba(139, 105, 20, 0.1);
}

.dc-bio-toggle {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md) var(--spacing-lg);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.dc-bio-toggle:hover {
    border-color: rgba(139, 105, 20, 0.3);
    box-shadow: 0 4px 16px rgba(139, 105, 20, 0.1);
}

.dc-bio-toggle.active {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.08);
    box-shadow: 
        inset 0 0 20px rgba(184, 160, 130, 0.1),
        0 4px 16px rgba(139, 105, 20, 0.15);
}

.dc-bio-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(139, 105, 20, 0.1);
    border-radius: var(--radius-sm);
    color: var(--color-champagne);
    flex-shrink: 0;
    transition: all var(--transition-fast);
}

.dc-bio-toggle.active .dc-bio-icon {
    background: var(--color-champagne);
    color: var(--color-ivory);
}

.dc-bio-content {
    flex: 1;
    min-width: 0;
}

.dc-bio-title {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: 2px;
}

.dc-bio-desc {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    line-height: 1.4;
}

.dc-bio-price {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-champagne);
    white-space: nowrap;
    margin-right: var(--spacing-sm);
}

.dc-bio-switch {
    position: relative;
    width: 48px;
    height: 28px;
    flex-shrink: 0;
}

.dc-bio-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.dc-bio-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(139, 105, 20, 0.15);
    border-radius: 14px;
    transition: all var(--transition-fast);
}

.dc-bio-slider::before {
    position: absolute;
    content: "";
    height: 22px;
    width: 22px;
    left: 3px;
    bottom: 3px;
    background: var(--color-ivory);
    border-radius: 50%;
    transition: all var(--transition-fast);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.dc-bio-switch input:checked + .dc-bio-slider {
    background: var(--color-champagne);
}

.dc-bio-switch input:checked + .dc-bio-slider::before {
    transform: translateX(20px);
}

/* Адаптив для мобильных */
@media (max-width: 480px) {
    .dc-bio-toggle {
        flex-wrap: wrap;
        gap: var(--spacing-sm);
    }
    
    .dc-bio-content {
        order: 2;
        width: calc(100% - 60px);
    }
    
    .dc-bio-price {
        order: 3;
    }
    
    .dc-bio-switch {
        order: 4;
    }
}

/* ==========================================
   МОДУЛЬ ОКОН — РАСКРЫВАЮЩИЙСЯ БЛОК
   ========================================== */

/* Окна — первый модуль */
.windows-module {
    margin-bottom: var(--spacing-md);
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ==========================================
   МОДУЛЬ МЫТЬЯ ОКОН — ПОЛНАЯ ПЕРЕРАБОТКА
   ========================================== */

.windows-visual-compact {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
}

.window-type-compact {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    transition: all 0.3s ease;
}

.window-type-compact:hover {
    background: rgba(184, 160, 130, 0.06);
    border-color: rgba(184, 160, 130, 0.3);
}

.window-icon-compact {
    width: 56px;
    height: 56px;
    color: var(--color-champagne);
    opacity: 0.8;
    flex-shrink: 0;
}

/* Анимация рисования окон */
.window-icon-compact .window-frame {
    stroke-dasharray: 360;
    stroke-dashoffset: 360;
    animation: drawWindowFrame 1s ease-out forwards;
}

.window-icon-compact .window-line {
    stroke-dasharray: 120;
    stroke-dashoffset: 120;
    animation: drawWindowLine 0.6s ease-out forwards;
}

.window-icon-compact .window-line:nth-child(2) {
    animation-delay: 0.4s;
}

.window-icon-compact .window-line:nth-child(3) {
    animation-delay: 0.6s;
}

@keyframes drawWindowFrame {
    to { stroke-dashoffset: 0; }
}

@keyframes drawWindowLine {
    to { stroke-dashoffset: 0; }
}
}

.window-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.window-info .window-label {
    font-size: 15px;
    font-weight: 500;
    color: var(--color-obsidian);
    font-weight: 500;
    color: var(--color-obsidian);
}

.window-info .window-price {
    font-size: 13px;
    color: var(--color-champagne);
    font-weight: 500;
}

.window-counter {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-shrink: 0;
}

.counter-btn {
    width: 40px;
    height: 40px;
    border: 1px solid var(--glass-border);
    background: rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-md);
    color: var(--color-obsidian);
    font-size: 20px;
    font-weight: 300;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.counter-btn:hover {
    background: rgba(184, 160, 130, 0.15);
    border-color: var(--color-champagne);
    color: var(--color-champagne);
}

.counter-btn:active {
    transform: scale(0.95);
}

.counter-btn:hover {
    border-color: var(--color-champagne);
    color: var(--color-champagne);
}

.counter-btn:active {
    transform: scale(0.95);
}

.counter-value {
    width: 50px;
    height: 40px;
    text-align: center;
    border: 1px solid var(--glass-border);
    background: rgba(255, 255, 255, 0.03);
    border-radius: var(--radius-md);
    color: var(--color-obsidian);
    font-size: 18px;
    font-weight: 500;
    -moz-appearance: textfield;
}

.counter-value::-webkit-outer-spin-button,
.counter-value::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.windows-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md);
    margin-top: var(--spacing-md);
    background: rgba(139, 105, 20, 0.08);
    border-radius: var(--radius-md);
    animation: fadeIn 0.3s ease;
}

.windows-total-label {
    font-size: 14px;
    color: var(--color-obsidian);
}

.windows-total-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-champagne);
}

/* Мобильная адаптация модуля окон */
@media (max-width: 480px) {
    .window-type-compact {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto;
        gap: var(--spacing-md);
        text-align: center;
        padding: var(--spacing-lg);
    }
    
    .window-icon-compact {
        width: 48px;
        height: 48px;
        margin: 0 auto;
    }
    
    .window-info {
        align-items: center;
    }
    
    .window-counter {
        justify-content: center;
        margin-top: var(--spacing-xs);
    }
    
    .counter-btn {
        width: 44px;
        height: 44px;
    }
    
    .counter-value {
        width: 56px;
        height: 44px;
        font-size: 20px;
    }
}

/* Десктоп — горизонтальная раскладка */
@media (min-width: 768px) {
    .windows-visual-compact {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-lg);
    }
    
    .window-type-compact {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: var(--spacing-xl);
        gap: var(--spacing-md);
    }
    
    .window-icon-compact {
        width: 64px;
        height: 64px;
        margin-bottom: var(--spacing-sm);
    }
    
    .window-info {
        align-items: center;
        margin-bottom: var(--spacing-sm);
    }
    
    .window-info .window-label {
        font-size: 16px;
    }
    
    .window-counter {
        margin-top: var(--spacing-sm);
    }
}

/* ==========================================
   МОДУЛЬ ГЛАЖКИ — ПРЕМИАЛЬНЫЙ СТИЛЬ
   ========================================== */

/* Глажка — стили уже определены выше в унифицированной секции */

.ironing-intro {
    text-align: center;
    color: var(--color-obsidian-light);
    font-size: 14px;
    margin-bottom: var(--spacing-lg);
}

.ir-categories {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.ir-category-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
    cursor: pointer;
    transition: all var(--transition-fast);
    text-align: center;
}

.ir-category-card:hover {
    border-color: rgba(139, 105, 20, 0.3);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(139, 105, 20, 0.15);
}

.ir-category-card.active {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.08);
    box-shadow: 
        inset 0 0 20px rgba(184, 160, 130, 0.1),
        0 4px 16px rgba(139, 105, 20, 0.2);
}

.ir-icon {
    width: 36px;
    height: 36px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    transition: all var(--transition-fast);
}

.ir-category-card.active .ir-icon {
    color: var(--color-champagne);
    opacity: 1;
}

.ir-category-card span:first-of-type {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-obsidian);
    transition: color var(--transition-fast);
}

.ir-category-card.active span:first-of-type {
    color: var(--color-champagne);
}

.ir-hint {
    font-size: 11px;
    color: var(--color-obsidian-light);
    opacity: 0.6;
}

.ir-params {
    margin-bottom: var(--spacing-xl);
    animation: fadeIn 0.3s ease;
}

.ir-param-group {
    margin-bottom: var(--spacing-lg);
}

.ir-param-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: var(--spacing-sm);
}

.ir-param-hint {
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-bottom: var(--spacing-md);
    line-height: 1.5;
}

/* Счётчик количества */
.ir-quantity {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
}

.ir-qty-btn {
    width: 44px;
    height: 44px;
    border: 1px solid var(--glass-border);
    background: var(--glass-bg);
    border-radius: var(--radius-sm);
    color: var(--color-obsidian);
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.ir-qty-btn:hover {
    border-color: var(--color-champagne);
    color: var(--color-champagne);
}

.ir-qty-btn:active {
    transform: scale(0.95);
}

.ir-qty-value {
    font-size: 24px;
    font-weight: 500;
    color: var(--color-obsidian);
    min-width: 48px;
    text-align: center;
}

/* Выбор типа ткани */
.ir-materials {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-sm);
}

.ir-material-btn {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    text-align: left;
}

.ir-material-btn:hover {
    border-color: rgba(139, 105, 20, 0.3);
}

.ir-material-btn.active {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.08);
    box-shadow: inset 0 0 20px rgba(184, 160, 130, 0.1);
}

.ir-material-name {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: 2px;
    transition: color var(--transition-fast);
}

.ir-material-btn.active .ir-material-name {
    color: var(--color-champagne);
}

.ir-material-desc {
    display: block;
    font-size: 11px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-bottom: 4px;
}

.ir-material-price {
    display: block;
    font-size: 12px;
    color: var(--color-champagne);
    opacity: 0.9;
}

/* Премиальные опции */
.ir-options {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-lg);
}

.ir-option-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.ir-option-toggle:hover {
    border-color: rgba(139, 105, 20, 0.3);
}

.ir-option-toggle.active {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.08);
}

.ir-option-info {
    flex: 1;
}

.ir-option-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.ir-option-desc {
    font-size: 11px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
}

/* ==========================================
   МОДУЛЬ ШТОР
   ========================================== */

.curtains-service {
    margin-bottom: var(--spacing-sm);
}

.curtains-quantity {
    margin-top: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.curtains-type {
    margin-bottom: var(--spacing-lg);
}

.addon-param-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: var(--spacing-sm);
}

.quantity-control {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
}

.qty-btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid var(--glass-border);
    background: var(--glass-bg);
    color: var(--color-obsidian);
    font-size: 20px;
    font-weight: 300;
    cursor: pointer;
    transition: all 0.2s ease;
}

.qty-btn:hover {
    border-color: var(--color-champagne);
    background: rgba(184, 160, 130, 0.1);
}

.qty-btn:active {
    transform: scale(0.95);
}

.qty-value {
    font-size: 24px;
    font-weight: 500;
    color: var(--color-champagne);
    min-width: 40px;
    text-align: center;
}

.addon-note {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.8;
    padding: var(--spacing-md);
    background: rgba(184, 160, 130, 0.05);
    border-radius: var(--radius-md);
    margin-top: var(--spacing-md);
    line-height: 1.5;
}

.addon-note .hint-icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    margin-top: 2px;
}

.ir-option-price {
    font-size: 13px;
    color: var(--color-champagne);
    margin-right: var(--spacing-md);
}

/* Переключатель опций глажки */
.ir-option-switch {
    width: 44px;
    height: 26px;
    background: rgba(184, 160, 130, 0.2);
    border-radius: 13px;
    position: relative;
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.ir-option-switch::before {
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    background: var(--color-ivory);
    border-radius: 50%;
    top: 3px;
    left: 3px;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.ir-option-switch.active {
    background: var(--color-champagne);
}

.ir-option-switch.active::before {
    transform: translateX(18px);
}

/* Итог по глажке */
.ir-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md);
    background: rgba(139, 105, 20, 0.08);
    border-radius: var(--radius-md);
    margin-top: var(--spacing-lg);
    animation: fadeIn 0.3s ease;
}

.ir-total-label {
    font-size: 14px;
    color: var(--color-obsidian);
}

.ir-total-value {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-champagne);
}

/* Адаптив для десктопа */
@media (min-width: 768px) {
    .ir-categories {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* ==========================================
   ПРЕМИАЛЬНЫЕ МОДУЛИ ДОПЛН. ОПЦИЙ
   ========================================== */

/* ============================================
   УНИФИЦИРОВАННАЯ СИСТЕМА ДОПОЛНИТЕЛЬНЫХ ОПЦИЙ
   ============================================ */

/* Контейнер всех опций */
.addons-section {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

/* Разделитель секций */
.addons-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-platinum), transparent);
    margin: var(--spacing-md) 0;
}

/* Заголовок группы опций */
.addons-group-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-obsidian-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--spacing-sm);
    padding-left: 4px;
}

/* Простые опции (холодильник, духовка) */
.simple-addons {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.addon-toggle-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md) var(--spacing-lg);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.addon-toggle-card:hover {
    border-color: rgba(139, 105, 20, 0.3);
}

.addon-toggle-card:has(input:checked) {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.08);
}

.addon-toggle-card input[type="checkbox"] {
    display: none;
}

.addon-content {
    flex: 1;
}

.addon-title {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.addon-hint {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
}

.addon-price {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-champagne);
    white-space: nowrap;
}

.addon-switch {
    width: 44px;
    height: 26px;
    background: rgba(139, 105, 20, 0.15);
    border-radius: 13px;
    position: relative;
    transition: all var(--transition-fast);
    flex-shrink: 0;
}

.addon-switch::before {
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    background: var(--color-ivory);
    border-radius: 50%;
    top: 3px;
    left: 3px;
    transition: all var(--transition-fast);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.addon-toggle-card:has(input:checked) .addon-switch {
    background: var(--color-champagne);
}

.addon-toggle-card:has(input:checked) .addon-switch::before {
    transform: translateX(18px);
}

/* ============================================
   МОДУЛИ ДОПОЛНИТЕЛЬНЫХ ОПЦИЙ — ЕДИНЫЙ СТИЛЬ
   ============================================ */

.addon-module,
.windows-module,
.dry-cleaning-module,
.ironing-module {
    margin-bottom: var(--spacing-md);
    border-radius: var(--radius-md);
    overflow: hidden;
}

/* Убираем дублирующиеся отступы */
.addon-module .toggle-card,
.windows-module .toggle-card,
.dry-cleaning-module .toggle-card,
.ironing-module .toggle-card {
    margin-bottom: 0;
    border-radius: var(--radius-md);
}

/* Единый стиль раскрывающихся блоков */
.addon-block,
.windows-block,
.dry-cleaning-block,
.ironing-block {
    margin-top: var(--spacing-xs);
    padding: var(--spacing-lg);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-top: none;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    animation: slideDown 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Когда модуль раскрыт — toggle-card со скруглением только сверху */
.addon-module:has(.addon-block[style*="block"]) .toggle-card,
.windows-module:has(.windows-block[style*="block"]) .toggle-card,
.dry-cleaning-module:has(.dry-cleaning-block[style*="block"]) .toggle-card,
.ironing-module:has(.ironing-block[style*="block"]) .toggle-card {
    border-radius: var(--radius-md) var(--radius-md) 0 0;
    border-bottom: none;
}

/* Опции внутри модулей */
.addon-options {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.addon-option {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.addon-option:hover {
    border-color: rgba(139, 105, 20, 0.3);
}

.addon-option.active,
.addon-option:has(input:checked) {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.08);
}

.addon-option input[type="radio"] {
    display: none;
}

.option-content {
    flex: 1;
}

.option-title {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.option-desc {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-top: 2px;
}

.option-badge {
    font-size: 12px;
    font-weight: 500;
    color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.15);
    padding: 4px var(--spacing-sm);
    border-radius: 12px;
}

.option-price {
    font-size: 13px;
    color: var(--color-champagne);
}

/* Подопция */
.addon-sub-option {
    margin-top: var(--spacing-md);
    padding: var(--spacing-md);
    background: rgba(255, 255, 255, 0.02);
    border-radius: var(--radius-md);
    animation: fadeIn 0.3s ease;
}

.sub-toggle {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    cursor: pointer;
}

.sub-toggle input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-champagne);
}

.sub-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.sub-desc {
    flex: 1;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
}

.sub-price {
    font-size: 13px;
    color: var(--color-champagne);
}

/* Подсказка */
.addon-info-tip {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(139, 105, 20, 0.05);
    border-radius: var(--radius-sm);
}

.addon-info-tip .info-icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    opacity: 0.6;
    margin-top: 2px;
}

.addon-info-tip span {
    font-size: 12px;
    color: var(--color-obsidian-light);
    line-height: 1.5;
}

/* Особые поручения */
.errands-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.errands-list .errand-items {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

/* Старые стили (для обратной совместимости) */
.errands-categories {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.errand-category {
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--glass-border);
}

.errand-category:last-child {
    border-bottom: none;
}

.errand-cat-title {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-champagne);
    margin-bottom: var(--spacing-sm);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.errand-items {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.errand-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 14px;
    color: var(--color-obsidian);
    cursor: pointer;
    padding: var(--spacing-xs) 0;
}

.errand-item input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--color-champagne);
}

.errand-custom {
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--glass-border);
}

.errand-item.custom {
    font-weight: 500;
    color: var(--color-champagne);
}

.custom-field {
    margin-top: var(--spacing-md);
    animation: fadeIn 0.3s ease;
}

.custom-field textarea {
    width: 100%;
    padding: var(--spacing-md);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    color: var(--color-obsidian);
    font-family: inherit;
    font-size: 14px;
    resize: vertical;
    transition: border-color var(--transition-fast);
}

.custom-field textarea:focus {
    outline: none;
    border-color: var(--color-champagne);
}

.custom-hint {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-top: var(--spacing-xs);
}

/* Поля ключей */
.keys-fields {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

/* Оборудование */
.equipment-list {
    padding: var(--spacing-md);
    background: rgba(255, 255, 255, 0.03);
    border-radius: var(--radius-md);
}

.equipment-title {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: var(--spacing-sm);
}

.equipment-items {
    list-style: none;
    padding: 0;
    margin: 0;
}

.equipment-items li {
    font-size: 14px;
    color: var(--color-obsidian-light);
    padding: var(--spacing-xs) 0;
    padding-left: var(--spacing-md);
    position: relative;
}

.equipment-items li::before {
    content: "•";
    position: absolute;
    left: 0;
    color: var(--color-champagne);
}

/* ==========================================
   ДИАПАЗОНЫ ПЛОЩАДИ — ПРЕМИАЛЬНЫЙ СТИЛЬ
   ========================================== */

.area-ranges {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.area-range-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.area-range-card:hover {
    border-color: rgba(139, 105, 20, 0.3);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(139, 105, 20, 0.1);
}

.area-range-card:has(input:checked) {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.08);
    box-shadow: 
        inset 0 0 20px rgba(184, 160, 130, 0.1),
        0 4px 16px rgba(139, 105, 20, 0.15);
}

.area-range-card input[type="radio"] {
    display: none;
}

.range-content {
    flex: 1;
}

.range-title {
    display: block;
    font-size: 16px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: 2px;
    transition: color var(--transition-fast);
}

.area-range-card:has(input:checked) .range-title {
    color: var(--color-champagne);
}

.range-desc {
    display: block;
    font-size: 13px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
}

.area-hint {
    text-align: center;
    font-size: 13px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-bottom: var(--spacing-xl);
}

/* Корректоры сложности */
.complexity-section {
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--glass-border);
}

.complexity-title {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: var(--spacing-xs);
}

.complexity-hint {
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-bottom: var(--spacing-md);
}

.complexity-items {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.complexity-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.complexity-item:hover {
    border-color: rgba(139, 105, 20, 0.3);
}

.complexity-item:has(input:checked) {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.1);
}

.complexity-item input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--color-champagne);
}

.complexity-text {
    font-size: 13px;
    color: var(--color-obsidian);
}

.complexity-item:has(input:checked) .complexity-text {
    color: var(--color-champagne);
}

/* Адаптив */
@media (min-width: 768px) {
    .area-ranges {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ==========================================
   РАСШИРЕННАЯ СЕТКА ДИАПАЗОНОВ ПЛОЩАДИ
   ========================================== */

.area-ranges-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.area-ranges-grid .area-range-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--spacing-md);
    min-height: 120px;
    gap: var(--spacing-xs);
}

/* Архитектурные иконки форматов пространства */
.range-icon {
    width: 48px;
    height: 48px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    transition: all var(--transition-medium);
    flex-shrink: 0;
}

.area-range-card:hover .range-icon {
    color: var(--color-champagne);
    opacity: 0.9;
    transform: scale(1.05);
}

.area-range-card:has(input:checked) .range-icon {
    color: var(--color-champagne);
    opacity: 1;
    transform: scale(1.08);
    filter: drop-shadow(0 2px 4px rgba(139, 105, 20, 0.2));
}

.area-ranges-grid .range-title {
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 0;
    line-height: 1.2;
}

.area-ranges-grid .range-desc {
    font-size: 11px;
    opacity: 0.7;
    line-height: 1.2;
}

/* Адаптив для маленьких экранов */
@media (max-width: 380px) {
    .range-icon {
        width: 40px;
        height: 40px;
    }
    
    .area-ranges-grid .area-range-card {
        min-height: 100px;
        padding: var(--spacing-sm);
    }
    
    .area-ranges-grid .range-title {
        font-size: 12px;
    }
    
    .area-ranges-grid .range-desc {
        font-size: 10px;
    }
}

/* Уровень загрузки */
.load-level-section {
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--glass-border);
    margin-bottom: var(--spacing-lg);
}

/* Формат сервиса */
.service-format-section {
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--glass-border);
    margin-top: var(--spacing-lg);
}

.service-format-section .radio-group.compact {
    gap: var(--spacing-sm);
}

.service-format-section .radio-card {
    padding: var(--spacing-md);
}

.service-format-section .card-title {
    font-size: 15px;
}

.service-format-section .card-description {
    font-size: 12px;
}

/* ==========================================
   АНИМИРОВАННЫЕ ИКОНКИ ФОРМАТОВ СЕРВИСА
   ========================================== */

.service-format-cards {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

.service-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg) !important;
}

.service-icon-box {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    background: rgba(184, 160, 130, 0.08);
    transition: all 0.4s ease;
}

.service-card:has(input:checked) .service-icon-box {
    background: rgba(184, 160, 130, 0.15);
    box-shadow: 0 0 20px rgba(184, 160, 130, 0.2);
}

.service-icon {
    width: 40px;
    height: 40px;
    color: var(--color-obsidian-light);
    transition: color 0.4s ease;
}

.service-card:has(input:checked) .service-icon {
    color: var(--color-champagne);
}

/* ===== РЕГУЛЯРНЫЙ УХОД — Элегантный интерьер ===== */

.regular-icon .room-outline {
    stroke-dasharray: 250;
    stroke-dashoffset: 250;
    animation: drawRoomOutline 1.2s ease-out forwards;
}

.regular-icon .furn-sofa {
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    animation: drawFurniture 0.6s ease-out 0.4s forwards;
}

.regular-icon .furn-table {
    opacity: 0;
    animation: fadeInScale 0.4s ease-out 0.6s forwards;
}

.regular-icon .furn-art {
    opacity: 0;
    animation: fadeInScale 0.4s ease-out 0.8s forwards;
}

.regular-icon .furn-plant {
    opacity: 0;
    animation: plantGrow 0.5s ease-out 1.0s forwards;
}

.regular-icon .sparkle {
    animation: sparkleShine 0.4s ease-out forwards;
}

.regular-icon .s1 { animation-delay: 1.2s; }
.regular-icon .s2 { animation-delay: 1.4s; }
.regular-icon .s3 { animation-delay: 1.6s; }

/* При выборе — блики мерцают */
.service-card:has(input:checked) .regular-icon .sparkle {
    animation: sparkleGlow 2s ease-in-out infinite;
}

.service-card:has(input:checked) .regular-icon .room-outline {
    filter: drop-shadow(0 0 6px rgba(184, 160, 130, 0.4));
}

/* ===== ГЕНЕРАЛЬНЫЙ УХОД — Волна очищения ===== */

.deep-icon .room-outline {
    stroke-dasharray: 250;
    stroke-dashoffset: 250;
    animation: drawRoomOutline 1s ease-out forwards;
}

.deep-icon .wave {
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    animation: waveFlow 0.8s ease-out forwards;
}

.deep-icon .w1 { animation-delay: 0.3s; }
.deep-icon .w2 { animation-delay: 0.5s; }
.deep-icon .w3 { animation-delay: 0.7s; }
.deep-icon .w4 { animation-delay: 0.9s; }

.deep-icon .dust {
    opacity: 0.7;
    animation: dustRise 1s ease-out forwards;
}

.deep-icon .d1 { animation-delay: 1.0s; }
.deep-icon .d2 { animation-delay: 1.1s; }
.deep-icon .d3 { animation-delay: 1.2s; }
.deep-icon .d4 { animation-delay: 1.3s; }

.deep-icon .arrow-up {
    stroke-dasharray: 40;
    stroke-dashoffset: 40;
    animation: arrowDraw 0.5s ease-out 1.4s forwards;
}

/* При выборе — волны движутся, пыль улетает */
.service-card:has(input:checked) .deep-icon .wave {
    animation: waveMove 3s ease-in-out infinite;
}

.service-card:has(input:checked) .deep-icon .dust {
    animation: dustFlyUp 2.5s ease-in-out infinite;
}

.service-card:has(input:checked) .deep-icon .arrow-up {
    animation: arrowPulse 1.5s ease-in-out infinite;
}

/* ===== ПОСЛЕСТРОИТЕЛЬНЫЙ УХОД — Хаос → Порядок ===== */

.post-icon .room-outline {
    stroke-dasharray: 250;
    stroke-dashoffset: 250;
    animation: drawRoomOutline 1s ease-out forwards;
}

.post-icon .debris {
    opacity: 0;
    animation: debrisAppear 0.4s ease-out forwards;
}

.post-icon .db1 { animation-delay: 0.3s; }
.post-icon .db2 { animation-delay: 0.4s; }
.post-icon .db3 { animation-delay: 0.5s; }

.post-icon .particle {
    opacity: 0;
    animation: particleFloat 0.5s ease-out forwards;
}

.post-icon .p1 { animation-delay: 0.5s; }
.post-icon .p2 { animation-delay: 0.6s; }
.post-icon .p3 { animation-delay: 0.65s; }
.post-icon .p4 { animation-delay: 0.7s; }
.post-icon .p5 { animation-delay: 0.75s; }
.post-icon .p6 { animation-delay: 0.8s; }
.post-icon .p7 { animation-delay: 0.85s; }
.post-icon .p8 { animation-delay: 0.9s; }

.post-icon .brush-handle {
    opacity: 0;
    animation: fadeInScale 0.4s ease-out 0.2s forwards;
}

.post-icon .bristle {
    opacity: 0;
    animation: fadeInScale 0.3s ease-out 0.4s forwards;
}

/* При выборе — частицы уносятся */
.service-card:has(input:checked) .post-icon .particle {
    animation: particleClear 2.5s ease-in-out infinite;
}

.service-card:has(input:checked) .post-icon .brush-handle {
    animation: brushSweep 1.5s ease-in-out infinite;
}

.service-card:has(input:checked) .post-icon .debris {
    filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.3));
}

/* ===== KEYFRAMES ДЛЯ СЕРВИСОВ ===== */

@keyframes drawRoomOutline {
    0% { stroke-dashoffset: 250; opacity: 0.2; }
    100% { stroke-dashoffset: 0; opacity: 1; }
}

@keyframes drawFurniture {
    0% { stroke-dashoffset: 100; opacity: 0.3; }
    100% { stroke-dashoffset: 0; opacity: 1; }
}

@keyframes plantGrow {
    0% { opacity: 0; transform: scale(0.5) translateY(5px); }
    70% { opacity: 1; transform: scale(1.1) translateY(-2px); }
    100% { opacity: 1; transform: scale(1) translateY(0); }
}

@keyframes sparkleShine {
    0% { opacity: 0; transform: scale(0); }
    60% { opacity: 1; transform: scale(1.3); }
    100% { opacity: 0.8; transform: scale(1); }
}

@keyframes sparkleGlow {
    0%, 100% { opacity: 0.5; transform: scale(1); }
    50% { opacity: 1; transform: scale(1.5); filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.6)); }
}

@keyframes waveFlow {
    0% { stroke-dashoffset: 100; opacity: 0.2; }
    100% { stroke-dashoffset: 0; opacity: 0.8; }
}

@keyframes waveMove {
    0%, 100% { transform: translateY(0); opacity: 0.7; }
    50% { transform: translateY(-3px); opacity: 1; }
}

@keyframes dustRise {
    0% { opacity: 0.7; transform: translateY(0); }
    100% { opacity: 0.3; transform: translateY(-8px); }
}

@keyframes dustFlyUp {
    0%, 100% { opacity: 0.4; transform: translateY(0); }
    50% { opacity: 0; transform: translateY(-15px); }
}

@keyframes arrowDraw {
    0% { stroke-dashoffset: 40; opacity: 0.3; }
    100% { stroke-dashoffset: 0; opacity: 1; }
}

@keyframes arrowPulse {
    0%, 100% { transform: translateY(0); opacity: 1; }
    50% { transform: translateY(-3px); opacity: 0.8; filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.5)); }
}

@keyframes debrisAppear {
    0% { opacity: 0; transform: scale(0.9); }
    100% { opacity: 0.8; transform: scale(1); }
}

@keyframes particleFloat {
    0% { opacity: 0; }
    100% { opacity: 0.6; }
}

@keyframes particleClear {
    0%, 100% { opacity: 0.5; transform: translate(0, 0); }
    25% { opacity: 0.3; transform: translate(3px, -5px); }
    50% { opacity: 0; transform: translate(8px, -12px); }
    75% { opacity: 0.2; transform: translate(4px, -6px); }
}

@keyframes brushSweep {
    0%, 100% { transform: translateX(0) rotate(0deg); }
    25% { transform: translateX(3px) rotate(5deg); }
    75% { transform: translateX(-3px) rotate(-5deg); }
}

.section-label {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: var(--spacing-xs);
}

.section-hint {
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-bottom: var(--spacing-md);
}

.load-levels {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.load-level-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md) var(--spacing-lg);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.load-level-card:hover {
    border-color: rgba(139, 105, 20, 0.3);
}

.load-level-card:has(input:checked),
.load-level-card.active {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.08);
}

.load-level-card input[type="radio"] {
    display: none;
}

.load-content {
    flex: 1;
}

.load-title {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: 2px;
}

.load-level-card:has(input:checked) .load-title {
    color: var(--color-champagne);
}

.load-desc {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
}

/* Адаптив для десктопа */
@media (min-width: 768px) {
    .area-ranges-grid {
        grid-template-columns: repeat(5, 1fr);
    }
    
    .load-levels {
        flex-direction: row;
    }
    
    .load-level-card {
        flex: 1;
    }
}

/* ==========================================
   ВИЗУАЛЬНЫЕ КАРТОЧКИ УРОВНЯ ЗАГРУЗКИ
   ========================================== */

.load-levels-visual {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
}

@media (max-width: 767px) {
    .load-levels-visual {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--spacing-sm);
    }
    
    .load-visual-card {
        padding: var(--spacing-md) var(--spacing-sm);
    }
    
    .load-visual-card .load-title {
        font-size: 12px;
    }
    
    .load-visual-card .load-desc {
        font-size: 10px;
        line-height: 1.3;
    }
    
    .room-svg {
        max-width: 80px;
    }
    
    .load-illustration {
        padding: var(--spacing-sm) 0;
        margin-bottom: var(--spacing-sm);
    }
    
    /* Скрываем индикатор выбора на мобильных */
    .load-visual-card::after {
        width: 16px;
        height: 16px;
        top: var(--spacing-sm);
        right: var(--spacing-sm);
    }
}

.load-visual-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    overflow: hidden;
    position: relative;
}

.load-visual-card:hover {
    border-color: rgba(139, 105, 20, 0.4);
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(139, 105, 20, 0.15);
}

.load-visual-card:has(input:checked),
.load-visual-card.active {
    border-color: var(--color-champagne);
    background: rgba(139, 105, 20, 0.08);
    box-shadow: 
        inset 0 0 30px rgba(184, 160, 130, 0.1),
        0 8px 32px rgba(139, 105, 20, 0.2);
}

.load-visual-card input[type="radio"] {
    display: none;
}

/* Иллюстрация комнаты */
.load-illustration {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: var(--spacing-md) 0;
    margin-bottom: var(--spacing-md);
}

.room-svg {
    width: 100%;
    max-width: 200px;
    height: auto;
    color: var(--color-obsidian-light);
    transition: color 0.4s ease;
}

.load-visual-card:has(input:checked) .room-svg,
.load-visual-card.active .room-svg {
    color: var(--color-champagne);
}

/* ===== ПРЕМИАЛЬНЫЕ АНИМАЦИИ КОМНАТ ===== */

/* Рамка комнаты — элегантная прорисовка */
.room-frame {
    stroke-dasharray: 400;
    stroke-dashoffset: 400;
    animation: drawRoomFrame 1.5s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* Окно — появление с мягким свечением */
.room-window {
    opacity: 0;
    animation: windowReveal 0.6s ease-out 0.5s forwards;
}

/* Пол комнаты */
.room-floor {
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    animation: floorDraw 0.5s ease-out 0.3s forwards;
}

/* Мебель — плавное "расставление" с разных направлений */
.furniture {
    opacity: 0;
}

/* Минималистичная комната — мебель появляется слева */
.minimal-room .furniture {
    transform: translateX(-10px);
    animation: furnitureSlideIn 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

/* Стандартная комната — мебель появляется снизу */
.standard-room .furniture {
    transform: translateY(8px);
    animation: furnitureRiseUp 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

/* Насыщенная комната — мебель "заполняет" пространство */
.heavy-room .furniture {
    transform: scale(0.3);
    animation: furnitureFillIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

/* Задержки для последовательного появления */
.furn-1 { animation-delay: 0.6s; }
.furn-2 { animation-delay: 0.7s; }
.furn-3 { animation-delay: 0.8s; }
.furn-4 { animation-delay: 0.9s; }
.furn-5 { animation-delay: 1.0s; }
.furn-6 { animation-delay: 1.1s; }
.furn-7 { animation-delay: 1.15s; }
.furn-8 { animation-delay: 1.2s; }
.furn-9 { animation-delay: 1.25s; }
.furn-10 { animation-delay: 1.3s; }
.furn-11 { animation-delay: 1.35s; }
.furn-12 { animation-delay: 1.4s; }

/* Hover — элегантная подсветка */
.load-visual-card:hover .room-frame {
    filter: drop-shadow(0 0 6px rgba(184, 160, 130, 0.25));
    transition: filter 0.4s ease;
}

.load-visual-card:hover .furniture {
    filter: drop-shadow(0 0 2px rgba(184, 160, 130, 0.2));
    transition: filter 0.3s ease;
}

.load-visual-card:hover .room-window {
    fill: rgba(184, 160, 130, 0.08);
    transition: fill 0.3s ease;
}

/* Выбранное состояние — премиальное золотистое свечение */
.load-visual-card:has(input:checked) .room-frame,
.load-visual-card.active .room-frame {
    stroke: var(--color-champagne);
    filter: drop-shadow(0 0 10px rgba(184, 160, 130, 0.5));
    transition: stroke 0.4s ease, filter 0.4s ease;
}

.load-visual-card:has(input:checked) .room-window,
.load-visual-card.active .room-window {
    stroke: var(--color-champagne);
    fill: rgba(184, 160, 130, 0.12);
    filter: drop-shadow(0 0 5px rgba(184, 160, 130, 0.3));
    transition: all 0.4s ease;
}

.load-visual-card:has(input:checked) .furniture,
.load-visual-card.active .furniture {
    stroke: var(--color-champagne);
    filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.35));
    transition: stroke 0.4s ease, filter 0.4s ease;
}

/* ===== KEYFRAMES ДЛЯ КОМНАТ ===== */

@keyframes drawRoomFrame {
    0% {
        stroke-dashoffset: 400;
        opacity: 0.1;
    }
    30% {
        opacity: 0.5;
    }
    100% {
        stroke-dashoffset: 0;
        opacity: 1;
    }
}

@keyframes floorDraw {
    0% {
        stroke-dashoffset: 100;
        opacity: 0;
    }
    100% {
        stroke-dashoffset: 0;
        opacity: 0.4;
    }
}

@keyframes windowReveal {
    0% {
        opacity: 0;
        transform: scale(0.95);
    }
    60% {
        opacity: 0.9;
        transform: scale(1.02);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes furnitureSlideIn {
    0% {
        opacity: 0;
        transform: translateX(-10px);
    }
    60% {
        opacity: 0.9;
        transform: translateX(2px);
    }
    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes furnitureRiseUp {
    0% {
        opacity: 0;
        transform: translateY(8px);
    }
    60% {
        opacity: 0.9;
        transform: translateY(-2px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes furnitureFillIn {
    0% {
        opacity: 0;
        transform: scale(0.3);
    }
    50% {
        opacity: 0.8;
        transform: scale(1.1);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes fadeInScale {
    0% {
        opacity: 0;
        transform: scale(0.9);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

/* Информация под иллюстрацией */
.load-info {
    text-align: center;
    padding-top: var(--spacing-md);
    width: 100%;
}

.load-visual-card .load-title {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-obsidian);
    margin-bottom: 4px;
    transition: color 0.3s ease;
    white-space: normal;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
    text-align: center;
    line-height: 1.3;
}

.load-visual-card:has(input:checked) .load-title,
.load-visual-card.active .load-title {
    color: var(--color-champagne);
}

.load-visual-card .load-desc {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.8;
    line-height: 1.4;
}

/* Индикатор выбора */
.load-visual-card::after {
    content: '';
    position: absolute;
    top: var(--spacing-md);
    right: var(--spacing-md);
    width: 24px;
    height: 24px;
    border: 2px solid var(--glass-border);
    border-radius: 50%;
    transition: all 0.3s ease;
}

.load-visual-card:has(input:checked)::after,
.load-visual-card.active::after {
    border-color: var(--color-champagne);
    background: var(--color-champagne);
    box-shadow: inset 0 0 0 4px var(--color-ivory);
}

/* Адаптив для десктопа */
@media (min-width: 768px) {
    .load-visual-card {
        min-height: 200px;
    }
    
    .room-svg {
        max-width: 140px;
    }
}

/* ==========================================
   ПРЕМИАЛЬНАЯ ФОРМА КОНТАКТОВ
   ========================================== */

.contact-form-premium {
    max-width: 500px;
    margin: 0 auto;
}

.premium-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

/* Секции формы */
.form-section {
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
}

.form-section-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--glass-border);
}

.form-section-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: rgba(139, 105, 20, 0.1);
    border-radius: 10px;
    color: var(--color-champagne);
}

.form-section-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Ряд из 3 колонок */
.row-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
}

@media (max-width: 480px) {
    .row-3 {
        grid-template-columns: 1fr 1fr;
    }
    
    .row-3 .col:last-child {
        grid-column: span 2;
    }
}

/* Кнопка отправки с иконкой */
.btn-submit {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    font-size: 15px;
    letter-spacing: 0.03em;
    padding: var(--spacing-lg);
}

.btn-submit svg {
    transition: transform 0.3s ease;
}

.btn-submit:hover svg {
    transform: translateX(4px);
}

.btn-submit:disabled svg {
    opacity: 0.5;
}

/* ==========================================
   ACCESSIBILITY — FOCUS VISIBLE STYLES
   ========================================== */

/* Глобальные focus-visible стили */
*:focus-visible {
    outline: 2px solid var(--color-champagne);
    outline-offset: 2px;
}

/* Убираем outline для mouse-кликов */
*:focus:not(:focus-visible) {
    outline: none;
}

/* Карточки */
.area-range-card:focus-visible,
.load-visual-card:focus-visible,
.radio-card:focus-visible,
.checkbox-card:focus-visible,
.residence-card:focus-visible {
    outline: 2px solid var(--color-champagne);
    outline-offset: 3px;
    box-shadow: 0 0 0 4px rgba(184, 160, 130, 0.2);
}

/* Кнопки */
.btn-primary:focus-visible,
.btn-secondary:focus-visible,
.counter-btn:focus-visible,
.dc-qty-btn:focus-visible,
.ir-qty-btn:focus-visible {
    outline: 2px solid var(--color-champagne);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px rgba(184, 160, 130, 0.25);
}

/* Toggle переключатели */
.toggle-card:focus-visible,
.addon-toggle-card:focus-visible {
    outline: 2px solid var(--color-champagne);
    outline-offset: 2px;
}

/* Поля ввода */
.input-premium:focus-visible {
    outline: none; /* Уже есть стили для focus */
    border-color: var(--color-champagne);
    box-shadow: 0 0 0 3px rgba(184, 160, 130, 0.15);
}

/* Категории химчистки и глажки */
.dc-category-card:focus-visible,
.ir-category-card:focus-visible,
.dc-material-btn:focus-visible,
.ir-material-btn:focus-visible {
    outline: 2px solid var(--color-champagne);
    outline-offset: 2px;
}

/* Ссылки */
a:focus-visible {
    outline: 2px solid var(--color-champagne);
    outline-offset: 2px;
    border-radius: 2px;
}

/* Skip to content link (для screen readers) */
.skip-link {
    position: absolute;
    top: -100px;
    left: 0;
    background: var(--color-champagne);
    color: white;
    padding: var(--spacing-sm) var(--spacing-md);
    z-index: 10001;
    font-size: 14px;
    font-weight: 500;
    border-radius: 0 0 var(--radius-sm) 0;
    transition: top 0.3s ease;
}

.skip-link:focus {
    top: 0;
}

/* ==========================================
   ТЕКСТОВЫЕ КАРТОЧКИ ПЛОЩАДИ (БЕЗ ИКОНОК)
   ========================================== */

.area-ranges-text {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-lg);
}

.area-range-text-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md) var(--spacing-lg);
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.area-range-text-card:hover {
    border-color: rgba(184, 160, 130, 0.4);
    background: rgba(184, 160, 130, 0.05);
}

.area-range-text-card:has(input:checked) {
    border-color: var(--color-champagne);
    border-width: 2px;
    background: rgba(184, 160, 130, 0.08);
    box-shadow: inset 0 0 20px rgba(184, 160, 130, 0.1);
}

.area-range-text-card input[type="radio"] {
    display: none;
}

.range-value {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-obsidian);
    transition: color 0.3s ease;
}

.area-range-text-card:has(input:checked) .range-value {
    color: var(--color-champagne);
}

.range-name {
    font-size: 13px;
    color: var(--color-obsidian-light);
    text-align: right;
    transition: color 0.3s ease;
}

.area-range-text-card:has(input:checked) .range-name {
    color: var(--color-champagne);
    opacity: 0.9;
}

/* Десктоп: 2 колонки */
@media (min-width: 600px) {
    .area-ranges-text {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-sm);
    }
    
    .area-range-text-card {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-xs);
        padding: var(--spacing-md);
    }
    
    .range-name {
        text-align: left;
    }
}

/* ==========================================
   РАСКРЫВАЮЩИЕСЯ ГРУППЫ ДОПЛН. ОПЦИЙ
   ========================================== */

.addons-group {
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    margin-bottom: var(--spacing-md);
    overflow: hidden;
}

.addons-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: var(--spacing-md) var(--spacing-lg);
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background 0.2s ease;
}

.addons-group-header:hover {
    background: rgba(184, 160, 130, 0.05);
}

.addons-group-title {
    font-size: 15px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.addons-group-toggle {
    font-size: 12px;
    color: var(--color-obsidian-light);
    transition: transform 0.3s ease;
}

.addons-group.collapsed .addons-group-content {
    display: none;
}

.addons-group:not(.collapsed) .addons-group-toggle {
    transform: rotate(180deg);
}

.addons-group-content {
    padding: var(--spacing-md) var(--spacing-lg) var(--spacing-lg);
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* ==========================================
   УНИФИЦИРОВАННЫЕ МОДУЛИ ДОПЛН. ОПЦИЙ
   ========================================== */

.addon-module-unified {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: var(--spacing-sm);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.addon-module-unified:last-child {
    margin-bottom: 0;
}

.addon-module-unified:has(input:checked) {
    border-color: rgba(184, 160, 130, 0.4);
    box-shadow: 0 4px 20px rgba(184, 160, 130, 0.1);
}

.addon-module-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    cursor: pointer;
    transition: background 0.2s ease;
}

.addon-module-header:hover {
    background: rgba(184, 160, 130, 0.05);
}

.addon-module-header input[type="checkbox"] {
    display: none;
}

/* Иконка модуля */
.addon-module-icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    background: rgba(184, 160, 130, 0.08);
    transition: all 0.4s ease;
}

.addon-module-header:has(input:checked) .addon-module-icon {
    background: rgba(184, 160, 130, 0.15);
    box-shadow: 0 0 15px rgba(184, 160, 130, 0.2);
}

.addon-module-icon svg {
    width: 26px;
    height: 26px;
    color: var(--color-obsidian-light);
    transition: color 0.3s ease;
}

.addon-module-header:has(input:checked) .addon-module-icon svg {
    color: var(--color-champagne);
}

.addon-module-info {
    flex: 1;
    min-width: 0;
}

.addon-module-title {
    display: block;
    font-size: 15px;
    font-weight: 500;
    color: var(--color-obsidian);
    line-height: 1.3;
}

.addon-module-hint {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-top: 3px;
    line-height: 1.4;
}

.addon-module-price {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-champagne);
    white-space: nowrap;
    padding: 4px 10px;
    background: rgba(184, 160, 130, 0.1);
    border-radius: var(--radius-sm);
}

/* ===== АНИМАЦИИ ИКОНОК МОДУЛЕЙ ===== */

/* Базовые элементы иконок */
.addon-module-icon .icon-element {
    opacity: 0;
    animation: iconElementAppear 0.4s ease-out forwards;
}

.addon-module-icon .icon-frame {
    stroke-dasharray: 200;
    stroke-dashoffset: 200;
    animation: drawIconFrame 0.8s ease-out forwards;
}

.addon-module-icon .icon-detail {
    opacity: 0;
    animation: iconDetailFade 0.3s ease-out forwards;
}

/* Задержки для элементов */
.addon-module-icon .el-1 { animation-delay: 0.2s; }
.addon-module-icon .el-2 { animation-delay: 0.35s; }
.addon-module-icon .el-3 { animation-delay: 0.5s; }
.addon-module-icon .el-4 { animation-delay: 0.65s; }

/* Hover эффекты */
.addon-module-header:hover .addon-module-icon svg {
    filter: drop-shadow(0 0 3px rgba(184, 160, 130, 0.3));
}

/* Активное состояние — плавная подсветка (без глитчей) */
.addon-module-header:has(input:checked) .addon-module-icon .icon-frame {
    filter: drop-shadow(0 0 6px rgba(184, 160, 130, 0.6));
    transition: filter 0.3s ease, transform 0.3s ease;
}

.addon-module-header:has(input:checked) .addon-module-icon .icon-element {
    filter: drop-shadow(0 0 4px rgba(184, 160, 130, 0.5));
    opacity: 1;
    transition: filter 0.3s ease, opacity 0.3s ease;
}

/* Простые карточки — плавная подсветка */
.addon-simple-card:has(input:checked) .addon-module-icon svg {
    filter: drop-shadow(0 0 8px rgba(184, 160, 130, 0.6));
    transform: scale(1.05);
    transition: filter 0.3s ease, transform 0.3s ease;
}

.addon-simple-card .addon-module-icon svg {
    transition: filter 0.3s ease, transform 0.3s ease;
}

@keyframes iconElementAppear {
    0% { opacity: 0; transform: scale(0.8); }
    60% { opacity: 1; transform: scale(1.05); }
    100% { opacity: 1; transform: scale(1); }
}

@keyframes drawIconFrame {
    0% { stroke-dashoffset: 200; opacity: 0.3; }
    100% { stroke-dashoffset: 0; opacity: 1; }
}

@keyframes iconDetailFade {
    0% { opacity: 0; }
    100% { opacity: 0.7; }
}

.addon-module-switch {
    width: 44px;
    height: 26px;
    background: rgba(184, 160, 130, 0.2);
    border-radius: 13px;
    position: relative;
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.addon-module-switch::before {
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    background: var(--color-ivory);
    border-radius: 50%;
    top: 3px;
    left: 3px;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.addon-module-header:has(input:checked) .addon-module-switch {
    background: var(--color-champagne);
}

.addon-module-header:has(input:checked) .addon-module-switch::before {
    transform: translateX(18px);
}

.addon-module-body {
    padding: var(--spacing-lg);
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--glass-border);
    animation: slideDown 0.3s ease;
}

.module-intro {
    font-size: 13px;
    color: var(--color-obsidian-light);
    margin-bottom: var(--spacing-md);
}

/* Простые карточки опций */
.addon-simple-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    cursor: pointer;
    transition: all 0.3s ease;
    margin-bottom: var(--spacing-sm);
}

.addon-simple-card:last-child {
    margin-bottom: 0;
}

.addon-simple-card:hover {
    background: rgba(184, 160, 130, 0.05);
    border-color: rgba(184, 160, 130, 0.3);
}

.addon-simple-card:has(input:checked) {
    border-color: rgba(184, 160, 130, 0.4);
    background: rgba(184, 160, 130, 0.08);
    box-shadow: 0 4px 20px rgba(184, 160, 130, 0.1);
}

.addon-simple-card input[type="checkbox"] {
    display: none;
}

/* Иконка в простой карточке */
.addon-simple-card .addon-module-icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
}

.addon-simple-card:has(input:checked) .addon-module-icon {
    background: rgba(184, 160, 130, 0.15);
    box-shadow: 0 0 15px rgba(184, 160, 130, 0.2);
}

.addon-simple-card:has(input:checked) .addon-module-icon svg {
    color: var(--color-champagne);
}

.addon-simple-info {
    flex: 1;
    min-width: 0;
}

.addon-simple-title {
    display: block;
    font-size: 15px;
    font-weight: 500;
    color: var(--color-obsidian);
    line-height: 1.3;
}

.addon-simple-hint {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
    margin-top: 3px;
}

.addon-simple-price {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-champagne);
    padding: 4px 10px;
    background: rgba(184, 160, 130, 0.1);
    border-radius: var(--radius-sm);
    white-space: nowrap;
}

.addon-simple-switch {
    width: 44px;
    height: 26px;
    background: rgba(184, 160, 130, 0.2);
    border-radius: 13px;
    position: relative;
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.addon-simple-switch::before {
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    background: var(--color-ivory);
    border-radius: 50%;
    top: 3px;
    left: 3px;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.addon-simple-card:has(input:checked) .addon-simple-switch {
    background: var(--color-champagne);
}

.addon-simple-card:has(input:checked) .addon-simple-switch::before {
    transform: translateX(18px);
}

/* Опции внутри модулей */
.addon-options-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.addon-option-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
}

.addon-option-item:hover {
    border-color: rgba(184, 160, 130, 0.3);
}

.addon-option-item:has(input:checked),
.addon-option-item.active {
    border-color: var(--color-champagne);
    background: rgba(184, 160, 130, 0.08);
}

.addon-option-item input[type="radio"] {
    display: none;
}

.addon-option-content {
    flex: 1;
}

.addon-option-title {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.addon-option-desc {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
}

.addon-option-badge {
    font-size: 12px;
    font-weight: 500;
    color: var(--color-champagne);
    background: rgba(184, 160, 130, 0.15);
    padding: 4px 10px;
    border-radius: 12px;
}

.addon-option-price {
    font-size: 13px;
    color: var(--color-champagne);
}

/* Чекбокс опции */
.addon-checkbox-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    cursor: pointer;
}

.addon-checkbox-item input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-champagne);
    flex-shrink: 0;
}

.addon-checkbox-content {
    flex: 1;
}

.addon-checkbox-title {
    display: block;
    font-size: 14px;
    color: var(--color-obsidian);
}

.addon-checkbox-desc {
    display: block;
    font-size: 12px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
}

.addon-checkbox-price {
    font-size: 13px;
    color: var(--color-champagne);
    font-weight: 500;
}

/* Итог модуля */
.addon-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md) var(--spacing-lg);
    margin-top: var(--spacing-lg);
    background: linear-gradient(135deg, rgba(184, 160, 130, 0.12), rgba(184, 160, 130, 0.06));
    border: 1px solid rgba(184, 160, 130, 0.2);
    border-radius: var(--radius-lg);
}

.addon-total-label {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.addon-total-value {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-champagne);
}

@media (max-width: 480px) {
    .addon-total {
        padding: var(--spacing-sm) var(--spacing-md);
        flex-direction: column;
        gap: var(--spacing-xs);
        text-align: center;
    }
    
    .addon-total-label {
        font-size: 12px;
    }
    
    .addon-total-value {
        font-size: 16px;
    }
}

/* Итоговая стоимость доп. услуг */
.addons-summary {
    background: var(--glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 2px solid var(--color-champagne);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    margin-top: var(--spacing-lg);
    animation: fadeIn 0.3s ease;
}

.addons-summary-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.addons-summary-label {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.addons-summary-value {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-champagne);
}

/* Категории глажки без иконок */
.ir-categories {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.ir-category-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: center;
}

.ir-category-card:hover {
    border-color: rgba(184, 160, 130, 0.4);
}

.ir-category-card.active {
    border-color: var(--color-champagne);
    background: rgba(184, 160, 130, 0.08);
}

.ir-cat-title {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-obsidian);
    margin-bottom: 2px;
}

.ir-category-card.active .ir-cat-title {
    color: var(--color-champagne);
}

.ir-cat-hint {
    display: block;
    font-size: 11px;
    color: var(--color-obsidian-light);
    opacity: 0.7;
}

/* Компактные категории химчистки */
.dc-categories {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
}

@media (max-width: 480px) {
    .dc-categories {
        grid-template-columns: repeat(2, 1fr);
    }
}

.dc-category-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: var(--spacing-sm);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 11px;
    color: var(--color-obsidian);
}

.dc-category-card:hover {
    border-color: rgba(184, 160, 130, 0.4);
}

.dc-category-card.active {
    border-color: var(--color-champagne);
    background: rgba(184, 160, 130, 0.08);
}

.dc-icon {
    width: 28px;
    height: 28px;
    color: var(--color-obsidian-light);
    transition: color 0.2s ease;
}

.dc-category-card.active .dc-icon {
    color: var(--color-champagne);
}

/* Мобильные исправления */
@media (max-width: 480px) {
    .addons-group-header {
        padding: var(--spacing-md);
    }
    
    .addons-group-content {
        padding: 0 var(--spacing-md) var(--spacing-md);
    }
    
    /* Модули дополнительных опций — мобильные */
    .addon-module-header {
        padding: var(--spacing-md);
        gap: var(--spacing-sm);
    }
    
    .addon-module-icon {
        width: 38px;
        height: 38px;
    }
    
    .addon-module-icon svg {
        width: 22px;
        height: 22px;
    }
    
    .addon-module-info {
        flex: 1;
        min-width: 0;
    }
    
    .addon-module-title {
        font-size: 14px;
        line-height: 1.3;
    }
    
    .addon-module-hint {
        font-size: 11px;
        line-height: 1.4;
    }
    
    .addon-module-price {
        font-size: 12px;
        padding: 3px 8px;
    }
    
    .addon-module-switch {
        width: 40px;
        height: 24px;
        flex-shrink: 0;
    }
    
    .addon-module-switch::before {
        width: 18px;
        height: 18px;
    }
    
    .addon-module-header:has(input:checked) .addon-module-switch::before {
        transform: translateX(16px);
    }
    
    .addon-module-body {
        padding: var(--spacing-md);
        padding-top: var(--spacing-sm);
    }
    
    /* Простые карточки — мобильные */
    .addon-simple-card {
        padding: var(--spacing-md);
        gap: var(--spacing-sm);
    }
    
    .addon-simple-card .addon-module-icon {
        width: 38px;
        height: 38px;
    }
    
    .addon-simple-title {
        font-size: 14px;
    }
    
    .addon-simple-hint {
        font-size: 11px;
    }
    
    .addon-simple-price {
        font-size: 12px;
        padding: 3px 8px;
    }
    
    /* Группы — мобильные */
    .addons-group-header {
        padding: var(--spacing-md);
    }
    
    .addons-group-title {
        font-size: 14px;
    }
    
    .addons-group-content {
        padding: var(--spacing-sm) var(--spacing-md) var(--spacing-md);
    }
    
    /* Категории глажки — мобильные */
    .ir-categories {
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-xs);
    }
    
    .ir-category-card {
        padding: var(--spacing-sm);
    }
    
    .ir-cat-title {
        font-size: 12px;
    }
    
    .ir-cat-hint {
        font-size: 10px;
    }
    
    .load-visual-card .load-title {
        font-size: 12px;
        line-height: 1.25;
        white-space: normal;
        hyphens: auto;
    }
    
    .load-visual-card .load-desc {
        font-size: 10px;
        line-height: 1.3;
    }
    
    .room-svg {
        max-width: 55px;
    }
    
    .load-illustration {
        padding: var(--spacing-xs) 0;
        margin-bottom: var(--spacing-xs);
    }
}

/* ==========================================
   ПРЕМИАЛЬНОЕ ПОЛЕ ВВОДА ПЛОЩАДИ
   ========================================== */
.area-input-section {
    margin-bottom: var(--spacing-xl);
}

/* Ошибка в поле площади */
.area-input-field.error {
    border-color: #e74c3c !important;
    animation: shake 0.3s ease;
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }
}

.area-input-premium {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-xl);
    background: var(--glass-bg);
    backdrop-filter: blur(30px) saturate(180%);
    -webkit-backdrop-filter: blur(30px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xl);
}

.area-input-wrapper {
    display: flex;
    align-items: baseline;
    gap: var(--spacing-md);
    position: relative;
}

.area-input-field {
    width: 140px;
    padding: var(--spacing-sm) var(--spacing-lg);
    background: transparent;
    border: none;
    border-bottom: 2px solid rgba(184, 160, 130, 0.4);
    border-radius: 0;
    font-family: var(--font-elegant);
    font-size: 56px;
    font-weight: 300;
    color: var(--color-champagne);
    text-align: center;
    transition: all 0.3s ease;
    -moz-appearance: textfield;
}

.area-input-field::-webkit-outer-spin-button,
.area-input-field::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.area-input-field::placeholder {
    color: rgba(184, 160, 130, 0.3);
}

.area-input-field:focus {
    outline: none;
    border-bottom-color: var(--color-champagne);
}

.area-input-field:not(:placeholder-shown) {
    border-bottom-color: var(--color-champagne);
}

.area-input-unit {
    font-family: var(--font-elegant);
    font-size: 24px;
    font-weight: 400;
    color: var(--color-champagne);
    opacity: 0.7;
}

.area-input-hint {
    font-size: 13px;
    color: var(--color-obsidian);
    opacity: 0.5;
    margin: 0;
    text-align: center;
}

/* Мобильная адаптация */
@media (max-width: 480px) {
    .area-input-field {
        width: 120px;
        font-size: 44px;
        padding: var(--spacing-xs) var(--spacing-md);
    }
    
    .area-input-unit {
        font-size: 20px;
    }
    
    .area-input-premium {
        padding: var(--spacing-lg);
    }
}

/* ==========================================
   ПРОСТЫЕ КАРТОЧКИ ФОРМАТА СЕРВИСА (без иконок)
   ========================================== */
.service-card-simple {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    padding: var(--spacing-lg);
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all 0.3s ease;
}

.service-card-simple:hover {
    border-color: var(--color-champagne);
    transform: translateY(-3px);
}

.service-card-simple:has(input:checked) {
    background: rgba(184, 160, 130, 0.1);
    border-color: var(--color-champagne);
    border-width: 2px;
}

.service-card-simple .card-title {
    font-family: var(--font-elegant);
    font-size: 18px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.service-card-simple:has(input:checked) .card-title {
    color: var(--color-champagne);
}

.service-card-simple .card-description {
    font-size: 13px;
    color: var(--color-obsidian);
    opacity: 0.6;
}

/* ==========================================
   СЛОЖНАЯ СОРТИРОВКА — ВЫДЕЛЕНИЕ ПРИ ВЫБОРЕ
   ========================================== */
.addon-checkbox-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: rgba(255, 255, 255, 0.4);
    border: 1px solid rgba(184, 160, 130, 0.15);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.3s ease;
}

.addon-checkbox-item:hover {
    border-color: rgba(184, 160, 130, 0.4);
}

.addon-checkbox-item:has(input:checked) {
    background: rgba(184, 160, 130, 0.12);
    border-color: var(--color-champagne);
    box-shadow: 0 2px 12px rgba(184, 160, 130, 0.15);
}

.addon-checkbox-item input[type="checkbox"] {
    width: 20px !important;
    height: 20px !important;
    opacity: 1 !important;
    position: relative !important;
    accent-color: var(--color-champagne);
    cursor: pointer;
    flex-shrink: 0;
}

.addon-checkbox-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.addon-checkbox-title {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    color: var(--color-obsidian);
}

.addon-checkbox-desc {
    font-size: 12px;
    color: var(--color-obsidian);
    opacity: 0.6;
}

.addon-checkbox-price {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 500;
    color: var(--color-champagne);
    white-space: nowrap;
}

/* ==========================================
   ПРЕДУПРЕЖДЕНИЕ О ПЛОЩАДИ
   ========================================== */

.area-warning {
    margin-top: 16px;
    padding: 12px 16px;
    background: rgba(255, 180, 100, 0.1);
    border: 1px solid rgba(255, 180, 100, 0.3);
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-body);
    font-size: 13px;
    color: var(--color-ivory);
    animation: fadeIn 0.3s ease;
}

.area-warning .warning-icon {
    font-size: 18px;
    flex-shrink: 0;
}

.area-warning a {
    color: var(--color-champagne);
    text-decoration: none;
    font-weight: 500;
    transition: opacity 0.2s ease;
}

.area-warning a:hover {
    opacity: 0.8;
}

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