/* базовое */
*{box-sizing:border-box}
body{font-family:Arial, sans-serif;background:#f4f7f9;margin:0;padding:20px}
.container{max-width:1200px;margin:auto;background:#fff;padding:20px;border-radius:10px;box-shadow:0 0 10px rgba(0,0,0,.1);position:relative}
h1{color:#333}

/* табы */
.tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.tabs .tablink{border:1px solid #d1d5db;background:#fff;color:#0f172a;border-radius:999px;padding:8px 14px;font-weight:600;cursor:pointer;transition:.15s;line-height:1}
.tabs .tablink:hover{background:#2563eb;border-color:#2563eb;color:#fff}
.tabs .tablink.active{background:#2563eb;border-color:#2563eb;color:#fff;box-shadow:0 2px 6px rgba(20,30,55,.15)}
.tab-content{display:none}
.tab-content.active{display:block}

.row{display:flex;flex-wrap:wrap;gap:30px}
.column{flex:1;min-width:300px}

/* таблицы/формулы */
#formulas,#cargo_table,#cargo_output,#its_output{background:#f0f0f0;padding:15px;border-radius:8px;font-size:14px;line-height:1.5}
.formula-title{font-weight:700;margin-top:10px}
table{width:100%;border-collapse:collapse;margin-top:10px}
table,th,td{border:1px solid #ccc}
th,td{padding:8px;text-align:center}

/* карточки */
.input-card{background:#fff;border:1px solid #e6e9ee;border-radius:10px;box-shadow:0 2px 6px rgba(20,30,55,.04);padding:12px 14px;margin-bottom:12px;transition:box-shadow .15s,border-color .15s,background .15s}
.input-card h4{margin:0 0 8px;font-size:15px;color:#0f172a}
.input-card.is-active{border-color:#2563eb;background:#f5faff;box-shadow:0 0 0 2px rgba(37,99,235,.15)}
.card-actions{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}

/* сетки ввода */
.input-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px 14px}
.input-grid--two{grid-template-columns:repeat(2,minmax(0,1fr));align-items:end}
.input-grid label{font-size:13px;font-weight:500;color:#0f172a;margin-bottom:4px;display:block}
.input-grid > div{display:grid;grid-template-rows:auto 1fr;min-width:0}
.input-grid input,.input-grid select{width:100%;padding:8px 10px;font-size:14px;border:1px solid #d1d5db;border-radius:8px;background:#fff;transition:all .15s}
.input-grid input:focus,.input-grid select:focus{border-color:#1b1e24;box-shadow:0 0 0 2px rgba(37,99,235,.15);outline:none}
@media (max-width:800px){.input-grid--two{grid-template-columns:1fr;align-items:stretch}}

/* строка валюты / кнопки */
.currency-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.select-label{font-size:13px;color:#0f172a;font-weight:600}
.select-wrap{position:relative;display:inline-block}
.select-pill{appearance:none;padding:8px 36px 8px 12px;border:1px solid #d1d5db;border-radius:999px;background:#fff;font-weight:600;line-height:1}
.select-wrap::after{content:"▾";position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;font-size:12px;color:#6b7280}

.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid #d1d5db;border-radius:999px;background:#f8fafc;color:#111827;cursor:pointer;transition:.15s;line-height:1}
.btn svg{width:14px;height:14px}
.btn:hover{background:#2563eb;border-color:#2563eb;color:#fff}
.btn--sm{padding:8px 12px;font-size:12px}
.btn--ghost{background:#fff}
.currency-row .btn{width:auto;white-space:nowrap}

/* формулы/карточки справа */
.formula-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}
.formula-card{background:#fff;border:1px solid #e6e9ee;border-radius:10px;box-shadow:0 2px 6px rgba(20,30,55,.04);padding:12px 14px}
.kv{display:grid;grid-template-columns:1fr auto;gap:6px 12px;font-size:13px;align-items:center}
.kv div{color:#334155;word-break:break-word}
.kv div strong{color:#0f172a}
.hr-soft{height:1px;background:linear-gradient(90deg,transparent,#eaeef5,transparent);margin:10px 0}
.badge{display:inline-block;background:#eef6ff;color:#2563eb;padding:2px 8px;border-radius:999px;font-size:12px}
.total-big{font-weight:700;font-size:16px;color:#0f172a}
.small-dim{color:#6b7280;font-size:12px}
.muted-note{color:#64748b;font-size:12px;margin-top:6px}

/* подчистили глобальные */
form input{width:100%}
form button{width:auto}

/* фиксы для "Доставка и комиссии" */
.input-grid--two{grid-template-columns: repeat(2, minmax(0, 1fr));align-items:end;gap:12px 14px}
.input-grid > div,.input-grid--two > div{min-width:0;display:grid;grid-template-rows:auto 1fr}
@media (max-width:800px){.input-grid--two{grid-template-columns:1fr;align-items:stretch}}


/* --- фикс лэйаута в формуле ИТС --- */
#its_output .kv{
  display: grid;
  grid-template-columns: 220px 1fr; /* метки ~220px, значение занимает остаток */
  gap: 6px 12px;
  align-items: start;
}

#its_output .kv > div{
  color: #334155;
  word-break: normal;          /* не ломать по каждой букве */
  overflow-wrap: anywhere;     /* переносить длинные слова/кодировки */
  white-space: normal;
}

/* — кнопка — */
.btn--primary{background:#2563eb;border-color:#2563eb;color:#fff}
.btn--primary:hover{filter:brightness(.95)}


/* — печатная версия КП — */
.kp-doc{max-width:800px;margin:0 auto;font-family:Arial, sans-serif;color:#0f172a}
.kp-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}
.kp-title{font-size:20px;font-weight:700;margin:0}
.kp-meta{font-size:12px;color:#64748b}
.kp-table{width:100%;border-collapse:collapse;margin:10px 0}
.kp-table th,.kp-table td{border:1px solid #e6e9ee;padding:8px 10px;font-size:13px;text-align:left}
.kp-table th{background:#f8fafc}
.kp-block{margin:14px 0}
.kp-note{font-size:12px;color:#64748b;margin-top:8px}
.kp-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kp-h3{font-size:16px;margin:10px 0;font-weight:700}

/* печать: показываем только документ */
@media print{
  body{background:#fff}
  body *{visibility:hidden}
  .kp-doc,.kp-doc *{visibility:visible}
  .kp-doc{position:absolute;left:0;top:0;right:0;margin:0;padding:0}
}

/* ——— Панель курсов ЦБ: компактный вид ——— */
#cbr-controls.input-card{ padding:10px 12px; }
.cbr-toolbar{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.cbr-title{ font-weight:600; }
.cbr-sep{ width:1px; height:20px; background:#e2e8f0; margin:0 4px; }

#cbr-controls label{ font-size:13px; color:#475569; margin-right:4px; }

/* маленькая кнопка */
.btn--xs{ padding:4px 10px; font-size:13px; line-height:1; height:30px; }
#cbr-controls .btn{ width:auto; } /* чтобы кнопка не растягивалась */

/* компактные селекты */
#cbr-controls select.cbr-select{
  height:30px;
  padding:4px 8px;
  font-size:14px;
  width:auto;
  min-width:110px;
  max-width:150px;
  border-radius:8px;
}

#pairValue{ min-width:120px; font-weight:700; }

/* Вкладка "Поиск кода ТН ВЭД": обёртка и iframe */
.tnved-iframe-wrap{
  height: 78vh;               /* занимает почти весь экран */
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}
#tnvedFrame{
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
@media (max-width: 768px){
  .tnved-iframe-wrap{ height: 70vh; }
}

/* пояснения в сетке формулы на всю ширину */
.kv-span{ grid-column: 1 / -1; }

/* Подбор */
/* ====== Подбор: выравнивание и визуал ====== */
.sourcing-layout{
  display:grid; gap:16px;
  grid-template-columns: 1.2fr 0.8fr; /* левый шире */
  align-items:start;
}
@media (max-width: 1200px){
  .sourcing-layout{ grid-template-columns: 1fr; }
}

.s-col{ min-width:0; }
.s-col--right{ position:relative; }
.s-sticky{
  position:sticky; top:88px;  /* ниже шапки */
  max-height: calc(100vh - 110px);
  overflow:auto;
}

/* Карточки «как в калькуляторе» */
.input-card__title{
  font-weight:600; font-size:15px; margin:2px 0 10px;
}

.s-form label{ display:flex; flex-direction:column; gap:6px; font-size:14px; }
.s-form input, .s-form select, .s-form textarea{
  height:36px; padding:6px 10px; border:1px solid #e5e7eb; border-radius:10px; background:#fff;
}
.s-form textarea{ height:auto; min-height:70px; resize:vertical; }

/* Мини-превью */
.s-thumbs{ display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }
.s-thumbs img{ width:84px; height:84px; object-fit:cover; border-radius:10px; border:1px solid #e5e7eb; }


.s-actions{
  display:flex; justify-content:space-between; align-items:center; gap:12px;
  padding-top:6px; border-top:1px dashed #e5e7eb; margin-top:4px;
}
.s-actions__right{ display:flex; gap:8px; }

/* Список найденных */
.s-list{ display:grid; gap:10px; }
.s-card{ border:1px solid #e5e7eb; border-radius:10px; padding:10px; background:#fafafa; }
.s-head{ display:flex; justify-content:space-between; gap:8px; margin-bottom:6px; }
.s-title{ font-weight:600; }
.s-muted{ opacity:.7; font-size:12px; }
.s-items{ display:grid; gap:8px; }
.s-item{ border:1px dashed #e5e7eb; border-radius:8px; padding:8px; background:#fff; }
.s-row{ margin:2px 0; }

/* Табы — чтобы кнопка «Подбор» выглядела как активная */
.tablink{ height:34px; padding:0 12px; border-radius:999px; }
.tablink.active{ background:#2d5cff; color:#fff; border-color:#2d5cff; }

/* Светло-серый фон вкладки, но без лишних «ям» */
#sourcing.tab-content{ background:#f5f7fb; border-radius:12px; padding:12px; }
/* ===== Подбор: более видимые границы, единый стиль ===== */
.s-form input,
.s-form select,
.s-form textarea{
  border: 1.5px solid #cbd5e1; /* slate-300, как в остальном UI, но на полтона контрастнее */
  background: #fff;
}
.s-form input:focus,
.s-form select:focus,
.s-form textarea:focus{
  border-color: #2d5cff;
  box-shadow: 0 0 0 3px rgba(45, 92, 255, .12);
  outline: 0;
}

/* Карточки и элементы списка «Найденных» — усилить линию */
.s-card, .s-item{ border-color: #dbe3ef; }

/* Разлепить кнопки, если нет родительского gap */
.btn + .btn { margin-left: 8px; }
.card-actions .btn + .btn { margin-left: 8px; }

/* На всякий случай — для табов, если разметка без .tabs или gap не сработал */
.tablink + .tablink { margin-left: 8px; }

.btn-group { display:flex; flex-wrap:wrap; gap:8px; }
/* Табы: убрать подчёркивание у ссылок, привести к виду "пилюля" */
.tabs .tablink,
.tabs a.tablink { 
  text-decoration: none;
  display: inline-flex; 
  align-items: center; 
  justify-content: center;
  white-space: nowrap;
}

/* На всякий: и для обычных кнопок-ссылок */
a.btn { text-decoration: none; }
a.btn:hover { text-decoration: none; }

/* Чёткая высота "пилюль" табов по всей системе */
.tablink{ height:34px; padding:0 12px; border-radius:999px; line-height:1; }

/* Если где-то включили underline глобально для ссылок — защищаем кнопки */
.btn, .tablink { text-decoration: none !important; }

/* Страховка от "впрыгиваний" из-за нестандартных line-height */
.btn, .tablink { line-height: 1; }

/* Если местами flex-gap не сработал (старые контейнеры) — запасной отступ */
.btn + .btn, .tablink + .tablink { margin-left: 8px; }

