/* ==========================================
   ОПТИМИЗИРОВАННЫЕ СТИЛИ КАЛЬКУЛЯТОРА ДОСТАВКИ
========================================== */
:root {
  --hc-bg: #f4f6f3;
  --hc-surface: #ffffff;
  --hc-surface-2: #f9faf8;
  --hc-surface-offset: #eef1eb;
  --hc-divider: #dde3d8;
  --hc-border: #d1d9cc;
  --hc-text: #1e2a1a;
  --hc-text-muted: #6b7a64;
  --hc-text-faint: #a8b5a0;
  --hc-primary: #26B663;
  --hc-primary-hover: #1b5e20;
  --hc-primary-light: #e8f5e9;
  --hc-primary-mid: #c8e6c9;
  --hc-success: #388e3c;
  --hc-shadow-lg: 0 12px 32px rgba(30,42,26,0.12);
}

.hc-wrap { font-family: 'Inter', 'Arial', sans-serif !important; font-size: 18px !important; color: var(--hc-text) !important; background: transparent !important; line-height: 1.5 !important; }
.hc-wrap *, .hc-wrap *::before, .hc-wrap *::after { box-sizing: border-box !important; }
.hc-wrap img, .hc-wrap svg { display: block !important; max-width: 100% !important; }
.hc-wrap button { cursor: pointer; font-family: inherit; outline: none; }
.hc-hidden { display: none !important; }

.hc-main { max-width: 1100px !important; margin: 0 auto !important; background: var(--hc-bg) !important; border-radius: 20px !important; box-shadow: var(--hc-shadow-lg) !important; border: 1px solid var(--hc-divider) !important; display: flex !important; flex-direction: column !important; position: relative; overflow: visible !important; scroll-margin-top: 20px; }
.hc-header { background: var(--hc-surface) !important; padding: 20px 30px !important; border-bottom: 1px solid var(--hc-divider) !important; text-align: center !important; border-radius: 20px 20px 0 0 !important; }
.hc-logo-text { font-weight: 800 !important; font-size: 24px !important; color: var(--hc-primary) !important; }

/* Шаги */
.hc-stepper { display: flex !important; align-items: center !important; background: var(--hc-surface) !important; padding: 16px 30px !important; border-bottom: 1px solid var(--hc-divider) !important; width: 100% !important; }
.hc-step-item { display: flex !important; align-items: center !important; gap: 12px !important; }
.hc-step-circle { width: 32px !important; height: 32px !important; border-radius: 50% !important; display: flex !important; align-items: center !important; justify-content: center !important; font-weight: bold !important; border: 2px solid var(--hc-border) !important; color: var(--hc-text-muted) !important; background: var(--hc-surface) !important; flex-shrink: 0 !important; }
.hc-step-circle.active { background: var(--hc-primary) !important; color: #fff !important; border-color: var(--hc-primary) !important; box-shadow: 0 0 0 4px var(--hc-primary-light) !important; }
.hc-step-circle.done { background: var(--hc-primary-mid) !important; color: var(--hc-primary) !important; border-color: var(--hc-primary-mid) !important; }
.hc-step-label { font-weight: 600 !important; font-size: 18px !important; color: var(--hc-text-muted) !important; white-space: nowrap !important; }
.hc-step-label.active { color: var(--hc-primary) !important; }
.hc-step-connector { flex: 1 !important; height: 2px !important; background: var(--hc-divider) !important; margin: 0 16px !important; min-width: 20px !important; }
.hc-step-connector.done { background: var(--hc-primary-mid) !important; }

.hc-step-panel:not(.active) { display: none !important; }
.hc-step-panel.active { display: block !important; padding: 30px !important; background: var(--hc-bg) !important; border-radius: 0 0 20px 20px; overflow: visible !important; }

.hc-card { background: var(--hc-surface) !important; border-radius: 12px !important; border: 1px solid var(--hc-divider) !important; margin-bottom: 20px !important; overflow: visible !important; width: 100% !important; }
.hc-card-header { padding: 16px 24px !important; border-bottom: 1px solid var(--hc-divider) !important; font-weight: 700 !important; background: var(--hc-surface-2) !important; display: flex !important; align-items: center !important; gap: 10px !important; border-radius: 12px 12px 0 0 !important; }
.hc-card-body { padding: 24px !important; width: 100% !important; }

.hc-grid-2 { display: grid !important; grid-template-columns: repeat(2, 1fr) !important; gap: 20px !important; width: 100% !important; }
.hc-col-2 { grid-column: span 2 !important; }

.hc-form-group { display: flex !important; flex-direction: column !important; gap: 8px !important; margin-bottom: 0 !important; width: 100% !important; position: relative !important; }
.hc-form-label { font-size: 16px !important; font-weight: 600 !important; color: var(--hc-text) !important; margin: 0 !important; padding: 0 !important; display: block !important; }

.hc-wrap input.hc-form-input { display: block !important; width: 100% !important; height: 48px !important; padding: 0 16px !important; margin: 0 !important; border: 1.5px solid var(--hc-border) !important; border-radius: 8px !important; background-color: var(--hc-surface) !important; color: var(--hc-text) !important; font-size: 16px !important; box-shadow: none !important; outline: none !important; }
.hc-wrap input.hc-form-input:not(:disabled):not([readonly]):focus { border-color: var(--hc-primary) !important; box-shadow: 0 0 0 3px var(--hc-primary-light) !important; }

.hc-checkbox-label { display: flex !important; align-items: center !important; gap: 8px !important; cursor: pointer !important; font-size: 14px !important; color: var(--hc-text) !important; user-select: none; }
.hc-checkbox-label input[type="radio"], .hc-checkbox-label input[type="checkbox"] { width: 18px !important; height: 18px !important; cursor: pointer !important; accent-color: var(--hc-primary) !important; margin: 0 !important; }

.hc-btn { display: inline-flex !important; align-items: center !important; justify-content: center !important; padding: 14px 24px !important; font-size: 15px !important; font-weight: 600 !important; border-radius: 8px !important; transition: 0.2s !important; text-decoration: none !important; border: 1.5px solid transparent !important; cursor: pointer !important; }
.hc-btn-primary { background-color: var(--hc-primary) !important; color: #fff !important; border-color: var(--hc-primary) !important; }
.hc-btn-primary:hover { background-color: var(--hc-primary-hover) !important; border-color: var(--hc-primary-hover) !important; }
.hc-btn-secondary { background-color: var(--hc-surface) !important; color: var(--hc-text) !important; border-color: var(--hc-border) !important; }

.hc-input-wrap { position: relative !important; display: block !important; width: 100% !important; }
.hc-input-unit { position: absolute !important; right: 36px !important; top: 50% !important; transform: translateY(-50%) !important; font-size: 16px !important; color: var(--hc-text-muted) !important; font-weight: 600 !important; pointer-events: none !important; }
.hc-input-wrap input { padding-right: 50px !important; }

/* Транспорт */
.hc-transport-grid { display: grid !important; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)) !important; gap: 12px !important; width: 100% !important; }
.hc-transport-card { position: relative; border: 2px solid var(--hc-border) !important; border-radius: 12px !important; padding: 16px !important; text-align: center !important; cursor: pointer !important; background: var(--hc-surface) !important; display: flex !important; flex-direction: column !important; justify-content: space-between !important; height: 100% !important; }
.hc-transport-card.selected { border-color: var(--hc-primary) !important; background: var(--hc-primary-light) !important; box-shadow: 0 0 0 4px var(--hc-surface), 0 0 0 6px var(--hc-primary-light) !important; }
.hc-recommended-badge { position: absolute; top: -10px; left: 50%; transform: translateX(-50%); background: var(--hc-primary); color: #fff; font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 20px; white-space: nowrap; box-shadow: 0 2px 6px rgba(0,0,0,0.15); }

/* Подсказки Яндекса поверх всего */
.ymaps-2-1-suggest, body .ymaps-2-1-suggest { z-index: 9999999 !important; border-radius: 8px !important; overflow: hidden !important; box-shadow: 0 4px 15px rgba(0,0,0,0.1) !important; border: 1px solid var(--hc-border) !important; }

.hc-toast { position: fixed !important; bottom: 30px !important; right: 30px !important; background: var(--hc-text) !important; color: #fff !important; padding: 16px 24px !important; border-radius: 8px !important; font-weight: 600 !important; transform: translateY(100px) !important; opacity: 0 !important; transition: 0.3s !important; z-index: 9999999 !important; box-shadow: var(--hc-shadow-lg) !important; }
.hc-toast.show { transform: translateY(0) !important; opacity: 1 !important; }

@media (max-width: 768px) {
  .hc-grid-2 { grid-template-columns: 1fr !important; }
  .hc-col-2 { grid-column: span 1 !important; }
  .hc-step-label { display: none !important; }
  .hc-step-panel.active { padding: 16px !important; }
  .hc-stepper { padding: 12px 16px !important; }
  .hc-step-connector { margin: 0 8px !important; min-width: 10px !important; }
}