/* ═══ Hero — full-width banner с декоративным фоном ══════════ */

/* Предотвратить горизонтальный скролл от full-width hero */
html{overflow-x:hidden}

.chero{
  position:relative;overflow:hidden;
  min-height:min(640px,78vh);
  /* Full-bleed: вырываемся из любого контейнера */
  width:100vw;
  margin-left:calc(-50vw + 50%);
  margin-top:-32px;
  border-radius:0;
  background:linear-gradient(135deg,#fef7ed 0%,#fcebd4 50%,#f8d9a0 100%)
}
.chero__art{
  position:absolute;top:0;bottom:0;right:-5%;width:65%;z-index:1;
  background:url("/modules/calculator/templates/calculator-hero.webp") center center / cover no-repeat
}
.chero__mask{
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(90deg,
    #fef7ed 0%,#fef7ed 30%,
    rgba(254,247,237,.95) 40%,rgba(254,247,237,.7) 52%,
    rgba(254,247,237,.25) 64%,rgba(254,247,237,0) 78%)
}
.chero__inner{
  position:relative;z-index:3;
  max-width:1140px;margin:0 auto;
  display:flex;align-items:center;
  min-height:min(580px,70vh);padding:40px 40px
}
.chero__content{max-width:560px}
.chero__pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,.82);backdrop-filter:blur(6px);
  color:#b45309;font-size:13px;font-weight:700;
  box-shadow:0 2px 8px rgba(0,0,0,.05)
}
.chero h1{margin:18px 0 14px;font-size:clamp(26px,3.4vw,42px);line-height:1.12;letter-spacing:-.02em;font-weight:800;color:#1a1a2e}
.chero__lead{margin:0 0 24px;font-size:16px;max-width:480px;color:#4a4a5a;line-height:1.6}
.chero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.chero__btn{border:none;border-radius:14px;padding:14px 24px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;font-family:inherit;transition:transform .15s,box-shadow .15s}
.chero__btn:hover{transform:translateY(-1px)}
.chero__btn--primary{background:#b45309;color:#fff;box-shadow:0 4px 16px rgba(180,83,9,.3)}
.chero__btn--primary:hover{box-shadow:0 6px 20px rgba(180,83,9,.4)}
.chero__btn--secondary{background:rgba(255,255,255,.82);color:#b45309;border:1px solid rgba(180,83,9,.12);backdrop-filter:blur(4px)}
.chero__stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:14px}
.chero__stat{background:rgba(255,255,255,.82);backdrop-filter:blur(4px);box-shadow:0 2px 10px rgba(0,0,0,.05);border-radius:14px;padding:14px 16px}
.chero__stat strong{display:block;font-size:20px;color:#b45309;margin-bottom:2px}
.chero__stat span{font-size:11px;color:#6b7280;line-height:1.35}
.chero__tags{display:flex;flex-wrap:wrap;gap:8px}
.chero__tags span{display:inline-flex;align-items:center;padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.6);font-size:13px;font-weight:600;color:#374151}
.chero-anim{opacity:0;transform:translateY(22px);animation:cheroUp .7s ease-out forwards}
.chero-anim--d1{animation-delay:.18s}
.chero-anim--d2{animation-delay:.32s}
@keyframes cheroUp{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.chero-anim{opacity:1;transform:none;animation:none}}

/* ═══ Page ═══════════════════════════════════════════════════ */

.calc-page{max-width:780px;margin:0 auto;padding:28px 0 20px}

/* ═══ Cards ══════════════════════════════════════════════════ */

.calc-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:28px 32px;margin-bottom:16px;box-shadow:0 2px 12px rgba(0,0,0,.03);transition:opacity .2s}
.calc-card--disabled{opacity:.45;pointer-events:none}
.calc-step-header{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.calc-step-num{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:#eef2ff;color:#4f46e5;font-weight:700;font-size:16px}
.calc-step-num--done{background:#d1fae5;color:#059669}
.calc-step-header h2{margin:0;font-size:19px;font-weight:700;color:#0e2850}
.calc-step-desc{margin:2px 0 0;font-size:13px;color:#9ca3af}

/* ═══ Country Grid ═══════════════════════════════════════════ */

.calc-country-grid{display:flex;flex-wrap:wrap;gap:8px}
.calc-country{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-size:13px;font-weight:500;color:#374151;transition:all .12s;font-family:inherit}
.calc-country:hover{border-color:#a5b4fc;background:#eef2ff}
.calc-country--active{border-color:#4f46e5;background:#eef2ff;color:#4f46e5;box-shadow:0 0 0 2px rgba(79,70,229,.15)}
.calc-country-flag{width:24px;height:16px;border-radius:2px;object-fit:cover;flex-shrink:0;box-shadow:0 0 0 1px rgba(0,0,0,.08)}
.calc-country-name{white-space:nowrap}
.calc-loading-inline{padding:12px;color:#9ca3af;font-size:14px}

/* ═══ Form Controls ══════════════════════════════════════════ */

.calc-field{margin-bottom:16px}
.calc-field label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}
.calc-field select,.calc-field input[type="text"],.calc-field input[type="tel"],.calc-field input[type="email"]{width:100%;height:46px;padding:0 14px;font-size:15px;color:#1f2937;background:#f9fafb;border:1px solid #d1d5db;border-radius:12px;outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;font-family:inherit}
.calc-field select:focus,.calc-field input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px rgba(79,70,229,.1)}
.calc-hint{font-size:12px;color:#9ca3af;margin-top:6px}
.calc-hint-link{color:#4f46e5;text-decoration:none}
.calc-hint-link:hover{text-decoration:underline}

/* ═══ Searchable Dropdown ════════════════════════════════════ */

.calc-search-select{position:relative}
#calcReleaseInput{padding-right:36px}
.calc-search-dropdown{display:none;position:absolute;top:100%;left:0;right:0;max-height:280px;overflow-y:auto;background:#fff;border:1px solid #d1d5db;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:50;margin-top:4px}
.calc-dd-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .1s;border-bottom:1px solid #f3f4f6}
.calc-dd-item:last-child{border-bottom:none}
.calc-dd-item:hover{background:#f5f3ff}
.calc-dd-item--current{background:#f0fdf4}
.calc-dd-ver{font-family:'SF Mono','Consolas',monospace;font-size:14px;font-weight:600;color:#1f2937}
.calc-dd-date{font-size:12px;color:#9ca3af}
.calc-dd-badge{font-size:10px;font-weight:700;text-transform:uppercase;color:#059669;background:#d1fae5;padding:2px 8px;border-radius:6px;letter-spacing:.5px}
.calc-dd-empty{padding:16px;text-align:center;color:#9ca3af;font-size:14px}

/* ═══ Button ═════════════════════════════════════════════════ */

.calc-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:48px;padding:0 28px;font-size:15px;font-weight:600;color:#fff;background:linear-gradient(135deg,#4f46e5 0%,#4338ca 100%);border:none;border-radius:14px;cursor:pointer;transition:transform .12s,box-shadow .15s;box-shadow:0 4px 16px rgba(79,70,229,.3);width:100%;font-family:inherit}
.calc-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(79,70,229,.4)}
.calc-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.calc-btn svg{width:18px;height:18px;flex-shrink:0}

/* ═══ Checkbox ═══════════════════════════════════════════════ */

.calc-checkbox{display:flex;align-items:flex-start;gap:10px;margin-bottom:18px;cursor:pointer;font-size:14px;color:#374151;line-height:1.4}
.calc-checkbox--small{font-size:13px}
.calc-checkbox input[type="checkbox"]{margin-top:3px;width:18px;height:18px;flex-shrink:0;accent-color:#4f46e5}

/* ═══ States ═════════════════════════════════════════════════ */

.calc-warning{background:#fef3c7;border:1px solid #fde68a;border-radius:12px;padding:14px 18px;margin-bottom:16px;font-size:13px;color:#92400e;line-height:1.5}
.calc-warning strong{display:block;margin-bottom:4px}
.calc-loading{text-align:center;padding:24px;color:#6b7280;font-size:14px}
.calc-spinner{display:inline-block;width:28px;height:28px;border:3px solid #e5e7eb;border-top-color:#4f46e5;border-radius:50%;animation:calc-spin .7s linear infinite;margin-bottom:10px}
@keyframes calc-spin{to{transform:rotate(360deg)}}
.calc-error{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;padding:14px 18px;margin-bottom:16px;font-size:14px;color:#991b1b;line-height:1.5}

/* ═══ Result ═════════════════════════════════════════════════ */

.calc-result-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.calc-result-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600}
.calc-result-badge.ok{background:#d1fae5;color:#065f46}
.calc-result-badge.steps{background:#e0e7ff;color:#3730a3}
.calc-result-badge.warn{background:#fef3c7;color:#92400e}
.calc-result-info{display:flex;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.calc-result-info div{flex:1;min-width:140px;background:#f9fafb;border-radius:10px;padding:12px 16px}
.calc-result-info div span{display:block;font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.calc-result-info div strong{font-size:16px;color:#0e2850}

.calc-route{position:relative;padding-left:28px}
.calc-route::before{content:'';position:absolute;left:9px;top:12px;bottom:12px;width:2px;background:#d1d5db}
.calc-route-step{position:relative;padding:8px 0 8px 16px;font-size:14px;color:#374151;font-family:'SF Mono','Consolas',monospace}
.calc-route-step::before{content:'';position:absolute;left:-22px;top:50%;transform:translateY(-50%);width:10px;height:10px;border-radius:50%;background:#d1d5db;border:2px solid #fff;box-shadow:0 0 0 1px #d1d5db}
.calc-route-step:first-child::before{background:#ef4444;box-shadow:0 0 0 1px #ef4444}
.calc-route-step:last-child::before{background:#22c55e;box-shadow:0 0 0 1px #22c55e}
.step-num{display:inline-block;width:28px;color:#9ca3af;font-size:12px}
.step-label{font-size:11px;font-family:-apple-system,sans-serif;color:#9ca3af;margin-left:8px}

.calc-modified-notice{background:#fff7ed;border:1px solid #fed7aa;border-radius:12px;padding:14px 18px;margin-top:20px;font-size:13px;color:#9a3412;line-height:1.5}
.calc-modified-notice strong{display:block;margin-bottom:4px}

/* ═══ CTA Buttons ════════════════════════════════════════════ */

.calc-cta-row{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.calc-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;border:none;cursor:pointer;font-size:14px;font-weight:600;transition:all .15s;font-family:inherit}
.calc-cta svg{width:18px;height:18px;flex-shrink:0}
.calc-cta--subscribe{background:#4f46e5;color:#fff;box-shadow:0 4px 12px rgba(79,70,229,.25)}
.calc-cta--subscribe:hover{background:#4338ca;transform:translateY(-1px)}
.calc-cta--help{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}
.calc-cta--help:hover{background:#e5e7eb;border-color:#9ca3af}

/* ═══ Modal ══════════════════════════════════════════════════ */

.calc-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;backdrop-filter:blur(4px)}
.calc-modal{background:#fff;border-radius:20px;padding:32px;max-width:440px;width:100%;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.2);animation:calcModalIn .25s ease-out}
@keyframes calcModalIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.calc-modal-close{position:absolute;top:14px;right:16px;width:32px;height:32px;border:none;background:none;font-size:24px;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px}
.calc-modal-close:hover{background:#f3f4f6;color:#374151}
.calc-modal h3{margin:0 0 4px;font-size:20px;font-weight:700;color:#0e2850}
.calc-modal-subtitle{margin:0 0 20px;font-size:14px;color:#6b7280}
.calc-modal input[type="text"],.calc-modal input[type="tel"],.calc-modal input[type="email"]{width:100%;height:44px;padding:0 14px;font-size:14px;border:1px solid #d1d5db;border-radius:10px;margin-bottom:12px;box-sizing:border-box;outline:none;font-family:inherit}
.calc-modal input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px rgba(79,70,229,.1)}
.calc-modal-captcha{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.calc-modal-captcha span{font-weight:600;color:#374151;white-space:nowrap;font-size:15px}
.calc-modal-captcha input{width:60px;text-align:center}
.calc-modal-msg{margin-top:12px;font-size:13px;min-height:16px;text-align:center}
.calc-modal-msg.is-success{color:#059669}
.calc-modal-msg.is-error{color:#dc2626}

.calc-howto{margin:16px 0;padding-left:20px;font-size:14px;color:#374151;line-height:1.8}
.calc-howto code{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-size:13px}

/* ═══ Share: uses ak-repost from shared.css ═══════════════════ */

.calc-repost-title{margin:0 0 12px;font-size:15px;font-weight:600;color:#374151;line-height:1.4}

/* ═══ Responsive ═════════════════════════════════════════════ */

@media(max-width:900px){
  .chero__art{width:50%;opacity:.3}
  .chero__mask{background:linear-gradient(90deg,#fef7ed 0%,#fef7ed 35%,rgba(254,247,237,.9) 55%,rgba(254,247,237,.4) 80%,rgba(254,247,237,0) 100%)}
  .chero__inner{padding:28px 24px;min-height:auto}
  .chero{min-height:auto;padding:24px 0}
}
@media(max-width:640px){
  .chero{min-height:auto;padding:0;margin-top:-12px}
  .chero__art{position:relative;width:100%;height:200px;right:auto}
  .chero__mask{display:none}
  .chero__inner{flex-direction:column;min-height:auto;padding:20px 16px}
  .chero__content{max-width:100%}
  .chero h1{font-size:24px}
  .chero__lead{font-size:15px}
  .chero__stats{grid-template-columns:1fr;gap:8px}
  .chero__actions{width:100%}
  .chero__btn{width:100%}
  .calc-page{padding:20px 0 16px}
  .calc-card{padding:20px 18px;border-radius:14px}
  .calc-country-grid{gap:6px}
  .calc-country{padding:6px 10px;font-size:12px}
  .calc-result-info{flex-direction:column;gap:8px}
  .calc-cta-row{flex-direction:column}
  .calc-cta{width:100%;justify-content:center}
  .calc-modal{padding:24px 20px;border-radius:16px}
}

/* v2.0.157: "Купить весь маршрут" — кнопка под .calc-route */
/* v2.0.233: кнопка теперь sibling .calc-route, не child — убрали отрицательный margin/width */
.calc-route-buy-all{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin:16px 0 0 0;padding:13px 16px;font-family:inherit;font-size:14px;font-weight:600;color:#4f46e5;background:#eef2ff;border:1.5px dashed #6366f1;border-radius:12px;cursor:pointer;transition:all .15s}
.calc-route-buy-all:hover{background:#e0e7ff;border-style:solid;transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,.15)}
.calc-route-buy-all:active{transform:translateY(0);box-shadow:none}
.calc-route-buy-all svg{flex-shrink:0}
