:root {
       --color-green: #30B45B;
       --color-dark: #1C1D1E;
   }
   
   .calc-wrapper {margin-top: 20px !important; width: 100%; max-width: 1506px; margin: 0 auto; display: flex; flex-direction: column; gap: clamp(15px, 2vw, 25px); font-family: 'Matahari', sans-serif, Arial; }
    
    /* Шапка */
    .calc-header-section { display: flex; flex-direction: column; align-items: flex-start; gap: 15px; }
    .badge-calc { background: #E0F4E7; border-radius: 8px; padding: 8px 16px; font-weight: 600; font-size: 16px; text-transform: uppercase; color: #1C1D1E; }
    .calc-header-section h2 { font-weight: 800; font-size: clamp(24px, 3vw, 32px); line-height: 110%; color: #1C1D1E; }
    .calc-header-section h2 span { color: #30B45B; }
    .calc-header-section p { font-weight: 400; font-size: clamp(15px, 1.5vw, 18px); line-height: 120%; color: #1C1D1E; }
    
    .calc-body-wrapper { background: #FFFFFF; border-radius: 12px; box-shadow: 0 4px 15px rgba(0,0,0,0.05); overflow: hidden; }
    
    .calc-tabs { display: flex; background: #F4F5F7; border-radius: 8px; padding: 4px; overflow: hidden; }
    .calc-tab { flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px; padding: clamp(10px, 1.2vw, 12px); font-weight: 700; font-size: clamp(13px, 1.2vw, 15px); cursor: pointer; color: #8c8c8c; border-radius: 6px; transition: all 0.3s ease; white-space: nowrap; }
    .calc-tab svg { width: 18px; height: 18px; fill: currentColor; flex-shrink: 0; }
    .calc-tab.active { color: #FFFFFF; background: #30B45B; box-shadow: 0 2px 5px rgba(0,0,0,0.05); }
    
    .calc-panel { display: none; padding: clamp(15px, 2vw, 25px); flex-direction: column; gap: clamp(15px, 2vw, 20px); }
    .calc-panel.active { display: flex; }
    
    /* Шаги */
    .steps-nav { display: flex; justify-content: center; align-items: center; gap: clamp(15px, 2vw, 25px); font-size: 18px; font-weight: 700; color: #8c8c8c; margin-bottom: 0px; }
    .steps-nav > div:not(.step-line) { display: flex; align-items: center; gap: 12px; }
    .step-circle { display: flex; justify-content: center; align-items: center; width: 36px; height: 36px; border-radius: 50%; background: #F0F0F0; color: #8c8c8c; font-size: 15px; font-weight: 700; margin: 0; border: none; }
    .step-active { color: #30B45B; }
    .step-active .step-circle { background: #30B45B; color: #fff; width: 36px; height: 36px; font-size: 18px; }
    .step-line { width: clamp(30px, 4vw, 60px); height: 2px; background: #F0F0F0; }
    
    .current-step-header { background: #30B45B; color: #fff; padding: 15px 30px; border-radius: 8px; font-weight: 700; font-size: clamp(16px, 1.5vw, 20px); display: flex; align-items: center; width: 100%; margin-bottom: 5px; }
    .header-number-circle { background: green; display: inline-flex; justify-content: center; align-items: center; width: 30px; height: 30px; border-radius: 50%; margin-right: 15px; font-size: 16px; font-weight: 800; flex-shrink: 0; }
    
    /* Сетка и поля ввода */
    .form-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(10px, 1.5vw, 15px); }
    #col-category, #col-poroda { grid-column: span 2; }
    .input-group { display: flex; flex-direction: column; gap: 5px; }
    .input-group label { font-weight: 700; font-size: clamp(13px, 1vw, 15px); color: #1C1D1E; }
    .input-group select, .input-group input { width: 100%; padding: clamp(10px, 1.2vw, 14px); border: 1px solid #ddd; border-radius: 6px; font-family: inherit; font-size: clamp(14px, 1.2vw, 15px); background: #ffffff; outline: none; transition: border-color 0.2s; box-sizing: border-box;}
    .input-group select:focus, .input-group input:focus { border-color: #30B45B; }
    
    /* Секция количества */
    .quantity-section { display: flex; flex-direction: column; gap: 10px; margin-top: 5px; }
    .toggle-wrapper { display: flex; background: #f5f5f5; border-radius: 8px; overflow: hidden; width: 100%; }
    .toggle-btn { flex: 1; text-align: center; padding: 10px; font-weight: 600; font-size: clamp(13px, 1.2vw, 15px); cursor: pointer; color: #8c8c8c; transition: all 0.3s; }
    .toggle-btn.active { background: #30B45B; color: #fff; }
    .qty-input-row { display: flex; align-items: center; gap: 15px; }
    .qty-input-row input { width: clamp(100px, 15vw, 120px); border: 1px solid #ddd; border-radius: 5px; background: #F8F9FA; height: 35px; padding-left: 10px; font-size: 15px;}
    .qty-result { font-size: clamp(14px, 1.2vw, 16px); color: #666; font-weight: 500; }
    
    /* Превью карточка */
    .product-preview-box { display: none; align-items: center; gap: 12px; padding: 10px 15px; background: #fdfdfd; border: 1px solid #30b45b40; border-radius: 8px; box-shadow: 0 4px 10px rgba(48,180,91,0.05); }
    .product-preview-box.active { display: flex; }
    .preview-img { width: 45px; height: 45px; object-fit: cover; border-radius: 6px; border: 1px solid #eee; }
    .preview-info { display: flex; flex-direction: column; gap: 2px; }
    .preview-title { font-weight: 700; font-size: 14px; color: #1C1D1E; }
    .preview-qty { font-size: 13px; color: #666; }
    
    /* Кнопки действий */
    .add-position-btn { width: 100%; padding: 12px; border: 1px dashed #30B45B; background: transparent; color: #30B45B; border-radius: 8px; font-weight: 600; font-size: clamp(13px, 1.2vw, 15px); cursor: pointer; transition: background 0.2s; }
    .add-position-btn:hover { background: #E0F4E7; }
    .next-step-btn { align-self: flex-end; padding: 10px 25px; background: #90d6a8; color: #fff; border: none; border-radius: 8px; font-weight: 600; font-size: 15px; cursor: pointer; margin-top: 5px; transition: background 0.2s; }
    .next-step-btn.active-btn { background: #30B45B; }
    
    /* Таблица корзины */
    .order-table-section { display: none; width: 100%; margin-top: 10px; background: #fdfdfd; border: 1px solid #eee; border-radius: 8px; padding: 15px; }
    .order-table-section h3 { margin-bottom: 10px; color: #1C1D1E; font-size: 18px; }
    .table-responsive { width: 100%; overflow-x: auto; }
    .order-table { width: 100%; border-collapse: collapse; min-width: 600px; }
    .order-table th { text-align: left; background: #f5f5f5; padding: 10px; font-size: 13px; color: #666; border-bottom: 2px solid #ddd; }
    .order-table td { padding: 12px 10px; border-bottom: 1px solid #eee; vertical-align: middle; font-size: 14px; color: #1C1D1E; }
    .cart-item-wrapper { display: flex; align-items: center; gap: 12px; }
    .cart-item-img { width: 45px; height: 45px; object-fit: cover; border-radius: 6px; border: 1px solid #eee; }
    .cart-item-link { color: #1C1D1E; text-decoration: none; font-weight: 600; transition: color 0.2s; }
    .cart-item-link:hover { color: #30B45B; text-decoration: underline; }
    .item-desc { font-size: 12px; color: #888; margin-top: 2px; }
    .delete-btn { background: #ffebeb; color: #d93025; border: none; width: 26px; height: 26px; border-radius: 4px; cursor: pointer; font-weight: bold; transition: 0.2s; }
    .delete-btn:hover { background: #d93025; color: #fff; }
    .order-total-row { display: flex; justify-content: flex-end; padding-top: 15px; font-size: 18px; font-weight: 700; color: #1C1D1E; }
    .order-total-row span { color: #30B45B; margin-left: 10px; }

    /* ========================================= */
    /* СТИЛИ НОВОГО КУБАТУРНИКА (ПО СКРИНШОТУ) */
    /* ========================================= */

    .kub-main-toggle { display: flex; border-radius: 6px; overflow: hidden; background: #F4F5F7; margin-bottom: clamp(20px, 3vw, 30px); }
    .kub-toggle-btn { flex: 1; display: flex; align-items: center; justify-content: center; gap: 10px; padding: clamp(12px, 1.5vw, 15px); font-weight: 700; font-size: clamp(14px, 1.2vw, 16px); color: #8c8c8c; cursor: pointer; transition: 0.3s; }
    .kub-toggle-btn.active { background: var(--color-green); color: #fff; }
    .kub-toggle-btn svg { width: 14px; height: 14px; }
    
    .kub-section-header { font-size: clamp(16px, 1.5vw, 18px); font-weight: 700; color: var(--color-dark); margin-bottom: clamp(15px, 2vw, 20px); display: flex; align-items: center; }
    .kub-section-header::before { content: ''; display: block; width: 3px; height: 18px; background: var(--color-green); margin-right: 10px; }
    
    .kub-inputs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(15px, 2vw, 25px); margin-bottom: clamp(20px, 3vw, 40px); }
    
    .kub-results-container { background: #E8F5E9; border-radius: 8px; padding: clamp(15px, 2vw, 25px); }
    .kub-res-title { font-weight: 700; font-size: clamp(16px, 1.5vw, 18px); margin-bottom: clamp(10px, 1.5vw, 15px); color: var(--color-dark); }
    .kub-res-cards { display: flex; gap: clamp(10px, 1.5vw, 20px); flex-wrap: wrap; }
    
    .kub-res-card { flex: 1; background: #fff; border-radius: 6px; padding: clamp(12px, 1.5vw, 16px); display: flex; align-items: center; justify-content: space-between; min-width: 200px; box-shadow: 0 2px 10px rgba(0,0,0,0.03); }
    .kub-res-lbl { font-size: clamp(13px, 1.1vw, 15px); color: #666; }
    .kub-res-val { font-size: clamp(16px, 1.5vw, 20px); font-weight: 700; color: var(--color-dark); }
    .kub-res-val.text-green { color: var(--color-green); }
    
    /* Адаптивность общая */
    @media (max-width: 1024px) {
        .form-grid { grid-template-columns: repeat(2, 1fr); }
        #col-category, #col-poroda { grid-column: span 1; } 
    }
    @media (max-width: 600px) {
        .form-grid { grid-template-columns: 1fr; }
        .qty-input-row { flex-direction: column; align-items: flex-start; }
        .toggle-wrapper { flex-direction: column; }
        
        /* Адаптив для кубатурника */
        .kub-inputs-grid { grid-template-columns: 1fr; gap: 15px; }
        .kub-res-card { width: 100%; flex: none; flex-direction: column; align-items: flex-start; gap: 5px; }

        /* Шаги на мобилках */
        .step-circle{font-size: 14px; width: 30px; height: 30px;}
        .step-active .step-circle{font-size: 13px; width: 30px; height: 30px;}
        .steps-nav{gap: 3px; font-size: 13px;}
        .calc-wrapper{padding: 5px;}
        .current-step-header{padding: 5px 10px; font-size: 15px;}
        .header-number-circle {margin-right: 10px; width: 25px; height: 25px; font-size: 15px;}
        .quantity-section{margin-top: 0px; gap: 5px;}
        .toggle-wrapper { flex-direction: row; }
    }
/* ========================================= */
    /* СТИЛИ ВЕРХНЕГО БАННЕРА КУБАТУРНИКА        */
    /* ========================================= */
    .kub-top-banner {
        display: flex;
        align-items: center;
        background: #F0F7F3; /* Светло-зеленый фон по макету */
        border-radius: 8px;
        padding: clamp(12px, 1.5vw, 15px) clamp(15px, 2vw, 20px);
        margin-bottom: clamp(15px, 2vw, 20px);
        gap: clamp(15px, 2vw, 20px);
    }
    
    .kub-banner-left {
        display: flex;
        align-items: center;
        gap: 12px;
    }
    
    .kub-banner-icon {
        width: 20px;
        height: 20px;
        object-fit: contain;
    }
    
    .kub-banner-title {
        font-weight: 800;
        font-size: clamp(15px, 1.2vw, 17px);
        color: var(--color-dark);
    }
    
    .kub-banner-divider {
        width: 1px;
        height: 20px;
        background-color: #D1D5DB; /* Светло-серый разделитель */
    }
    
    .kub-banner-right {
        font-weight: 400;
        font-size: clamp(13px, 1vw, 15px);
        color: #4B5563; /* Серый текст описания */
    }

    /* Адаптив для баннера на смартфонах */
    @media (max-width: 600px) {
        .kub-top-banner {
            flex-direction: column;
            align-items: flex-start;
            gap: 8px;
        }
        .kub-banner-divider {
            display: none; /* Прячем разделитель, так как текст ушел на новую строку */
        }
    }
/* Кнопка вызова (как на макете) */
.send-calc-wrapper { display: flex; justify-content: center; margin-top: clamp(20px, 3vw, 30px); }
.send-calc-mail-btn {
    background-color: var(--color-green); color: #fff; border: none; border-radius: 6px;
    padding: clamp(12px, 1.5vw, 15px) clamp(25px, 3vw, 40px); font-weight: 700;
    font-size: clamp(14px, 1.2vw, 16px); cursor: pointer; transition: background 0.3s;
}
.send-calc-mail-btn:hover { background-color: #259648; }

/* Модальное окно */
.calc-modal-overlay {
    display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(28, 29, 30, 0.7); z-index: 10000; align-items: center; justify-content: center;
    backdrop-filter: blur(4px); opacity: 0; transition: opacity 0.3s ease;
}
.calc-modal-overlay.active { display: flex; opacity: 1; }
.calc-modal-content {
    background: #fff; border-radius: 12px; padding: clamp(25px, 4vw, 40px);
    width: 90%; max-width: 450px; position: relative; box-shadow: 0 10px 40px rgba(0,0,0,0.2);
    transform: translateY(20px); transition: transform 0.3s ease;
}
.calc-modal-overlay.active .calc-modal-content { transform: translateY(0); }

.calc-modal-close {
    position: absolute; top: 15px; right: 20px; font-size: 28px; cursor: pointer; color: #888; transition: 0.3s;
}
.calc-modal-close:hover { color: var(--color-dark); }
.calc-modal-title { margin: 0 0 10px 0; font-size: 22px; font-weight: 800; color: var(--color-dark); }
.calc-modal-desc { font-size: 14px; color: var(--color-gray-text); margin-bottom: 20px; line-height: 1.4; }

.submit-calc-btn {
    width: 100%; padding: 14px; background: var(--color-dark); color: #fff; border: none; border-radius: 6px;
    font-size: 16px; font-weight: 700; cursor: pointer; margin-top: 15px; transition: 0.3s;
}
.submit-calc-btn:hover { background: #333; }

.calc-success-msg {
    display: none; text-align: center; color: var(--color-green); font-weight: 700; margin-top: 20px;
}
.calc-success-msg svg { width: 40px; height: 40px; fill: var(--color-green); display: block; margin: 0 auto 10px auto; }
/* ========================================= */
/* СТИЛИ ШАГА 2: ДОСТАВКА                    */
/* ========================================= */
.step-active-line { background: var(--color-green) !important; }

.delivery-header { margin-bottom: 20px; }

.delivery-type-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 25px; }
.delivery-type-card { display: flex; align-items: center; padding: 15px 20px; border: 1px solid #ddd; border-radius: 8px; cursor: pointer; transition: 0.3s; background: #fff; gap: 15px; }
.delivery-type-card.active { border-color: var(--color-green); background: #E0F4E7; }
.delivery-type-card input { display: none; }
.radio-custom { width: 20px; height: 20px; border: 2px solid #ccc; border-radius: 50%; display: inline-block; position: relative; flex-shrink: 0; background: #fff;}
.delivery-type-card.active .radio-custom { border-color: var(--color-green); }
.delivery-type-card.active .radio-custom::after { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 10px; height: 10px; background: var(--color-green); border-radius: 50%; }
.del-card-content { display: flex; flex-direction: column; gap: 4px; }
.del-card-content b { font-size: 15px; color: var(--color-dark); }
.del-card-content span { font-size: 13px; color: #666; }

.delivery-route-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 15px; }
.distance-input-wrapper { display: flex; align-items: center; gap: 15px; }
.distance-input-wrapper input { width: 100px !important; }
.warehouse-info { font-size: 13px; color: var(--color-dark); }

.compact-map { width: 100%; height: 200px; border-radius: 8px; overflow: hidden; background: #eee; margin-bottom: 25px; }

.transport-section-title { font-weight: 700; font-size: 15px; color: var(--color-dark); margin-bottom: 15px; }
.transport-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 15px; margin-bottom: 25px; }
.transport-card { border: 1px solid #ddd; border-radius: 8px; padding: 15px; cursor: pointer; transition: 0.3s; display: flex; flex-direction: column; gap: 10px; background: #fff; }
.transport-card.selected { border-color: var(--color-green); background: #E0F4E7; }
.transport-title { font-weight: 700; font-size: 14px; color: var(--color-dark); }
.transport-vol { font-size: 12px; color: #666; }
.transport-price { font-weight: 800; font-size: 16px; color: var(--color-green); margin-top: auto; }
.transport-card.recommended { position: relative; }
.rec-badge { position: absolute; bottom: 0; right: 0; background: var(--color-green); color: #fff; font-size: 10px; padding: 4px 8px; border-radius: 4px 0 8px 0; font-weight: bold; text-transform: uppercase;}

.delivery-total-box { background: #F4F5F7; border-radius: 8px; padding: 20px; display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.delivery-total-box span { font-size: 14px; color: #666; }
.del-total-sum { font-weight: 800 !important; font-size: 24px !important; color: var(--color-green) !important; }

.step-actions { display: flex; justify-content: space-between; align-items: center; }
.back-step-btn { background: #fff; border: 1px solid #ddd; padding: 10px 25px; border-radius: 8px; font-weight: 600; cursor: pointer; color: var(--color-dark); transition: 0.2s;}
.back-step-btn:hover { background: #f5f5f5; }

.pickup-info-box { background: #E0F4E7; padding: 20px; border-radius: 8px; margin-bottom: 20px; color: var(--color-dark); font-size: 15px; line-height: 1.5; }
.vol-badge { background: var(--color-green); color: #fff; padding: 2px 8px; border-radius: 4px; font-weight: bold; }

@media (max-width: 768px) {
    .delivery-type-grid, .delivery-route-grid { grid-template-columns: 1fr; gap: 10px; }
    .delivery-total-box { flex-direction: column; align-items: flex-start; gap: 10px; }
}
/* Главный контейнер подсказок */
.suggestions-suggestions {
    background: #ffffff !important;
    border: 1px solid #ccc !important;
    border-radius: 6px !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15) !important;
    z-index: 99999 !important; /* Чтобы точно было поверх карты */
}

/* Каждая отдельная строка */
.suggestions-suggestion {
    padding: 10px 12px !important;
    background: #ffffff !important;
    color: #1C1D1E !important;
    font-size: 14px !important;
    line-height: 1.4 !important; /* Убирает наложение строк по вертикали */
    cursor: pointer !important;
    display: block !important;
}

/* Наведение на подсказку */
.suggestions-suggestion:hover {
    background: #E0F4E7 !important; /* Ваш фирменный светло-зеленый */
    color: #30B45B !important;
}

/* Скрываем логотип DaData, чтоб не мешал */
.suggestions-addon {
    display: none !important;
}
/* ========================================= */
    /* СТИЛИ ШАГА 3: ОФОРМЛЕНИЕ ЗАЯВКИ           */
    /* ========================================= */
    .order-summary-box { background: #fdfdfd; border-radius: 8px; border: 1px solid #eee; padding: clamp(15px, 2vw, 25px); margin-bottom: 20px; display: flex; flex-direction: column; gap: 12px; }
    
    .summary-row { display: flex; align-items: flex-end; font-size: clamp(13px, 1.2vw, 15px); color: var(--color-dark); }
    .sum-label { color: #666; white-space: nowrap; }
    .sum-dots { flex-grow: 1; border-bottom: 1px dashed #ddd; margin: 0 10px; position: relative; top: -4px; }
    .summary-row b { white-space: nowrap; }
    
    .summary-total-wrapper { display: flex; justify-content: space-between; align-items: center; background: #F4F5F7; border-radius: 6px; padding: 15px 20px; margin-top: 10px; }
    .summary-total-wrapper span { font-weight: 700; font-size: clamp(14px, 1.2vw, 16px); color: var(--color-green); text-transform: uppercase; }
    .summary-total-wrapper b { font-weight: 800; font-size: clamp(20px, 2.5vw, 28px); color: var(--color-green); }
    
    .order-warning-box { display: flex; align-items: center; gap: 15px; background: #FFFDE7; border-radius: 8px; padding: 15px 20px; margin-bottom: 25px; border-left: 4px solid #FFD54F; }
    .order-warning-box span { font-size: clamp(13px, 1.1vw, 14px); color: var(--color-dark); line-height: 1.4; }
    .order-warning-box svg { flex-shrink: 0; opacity: 0.8; }
    
    .order-form-section { background: #fdfdfd; border-radius: 8px; border: 1px solid #eee; padding: clamp(20px, 3vw, 30px); }
    .form-section-title { font-size: 18px; font-weight: 800; color: var(--color-dark); margin-bottom: 20px; }
    
    .form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }
    
    .agreement-label { display: flex; align-items: center; gap: 10px; font-size: 13px; color: #888; cursor: pointer; user-select: none; }
    .agreement-label input { display: none; }
    .checkmark { width: 18px; height: 18px; border: 1px solid #ccc; border-radius: 4px; display: inline-block; position: relative; background: #fff; transition: 0.2s; flex-shrink: 0;}
    .agreement-label input:checked ~ .checkmark { background: var(--color-green); border-color: var(--color-green); }
    .agreement-label input:checked ~ .checkmark::after { content: ''; position: absolute; left: 5px; top: 2px; width: 4px; height: 8px; border: solid white; border-width: 0 2px 2px 0; transform: rotate(45deg); }
    
    @media (max-width: 768px) {
        .form-grid-2 { grid-template-columns: 1fr; }
        .summary-total-wrapper { flex-direction: column; align-items: flex-start; gap: 5px; }
    }