/* company-check — минимальный профессиональный стиль */
:root {
  --bg: #fafafa;
  --fg: #1f1f1f;
  --muted: #6b7280;
  --border: #e5e7eb;
  --card: #ffffff;
  --accent: #1f3a5f;
  --accent-hover: #2a4c7a;
  --critical: #b00020;
  --critical-bg: #fde7ea;
  --warn: #a66300;
  --warn-bg: #fff6e0;
  --info: #4b5563;
  --info-bg: #f3f4f6;
  --ok: #1a7a3b;
  --ok-bg: #e6f5ea;
  --tax: #b00020;
  --link: #1f3a5f;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 15px; line-height: 1.5;
  background: var(--bg); color: var(--fg);
}
a { color: var(--link); text-decoration: none; }
a:hover { text-decoration: underline; }
.muted { color: var(--muted); }

.site-header {
  display: flex; align-items: baseline; gap: 16px;
  padding: 16px 24px; border-bottom: 1px solid var(--border);
  background: var(--card);
}
.site-header .brand {
  font-weight: 600; font-size: 16px; color: var(--accent);
}
.site-footer {
  padding: 24px; text-align: center; font-size: 13px; color: var(--muted);
}

main { max-width: 1100px; margin: 0 auto; padding: 24px; }

/* форма */
.hero h1 { margin: 0 0 8px; font-weight: 600; font-size: 28px; }
.search {
  display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
  margin-top: 20px;
}
.search input[type="text"] {
  flex: 1; min-width: 260px;
  padding: 10px 14px; font-size: 16px; font-family: ui-monospace, Menlo, Consolas, monospace;
  border: 1px solid var(--border); border-radius: 6px; background: var(--card);
}
.search input[type="text"]:focus {
  outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(31, 58, 95, 0.15);
}
.search button[type="submit"] {
  padding: 10px 20px; font-size: 15px; font-weight: 500;
  background: var(--accent); color: white; border: none; border-radius: 6px;
  cursor: pointer; transition: background 0.15s;
}
.search button[type="submit"]:hover { background: var(--accent-hover); }
.search .refresh { display: flex; align-items: center; gap: 6px; font-size: 14px; color: var(--muted); }
.examples { margin-top: 12px; font-size: 14px; }
.examples button.link {
  background: none; border: none; color: var(--link); cursor: pointer; padding: 0;
  font-family: ui-monospace, Menlo, Consolas, monospace;
}
.examples button.link:hover { text-decoration: underline; }

/* карточки отчёта */
.report { display: grid; gap: 16px; margin-top: 24px; }
.card {
  background: var(--card); border: 1px solid var(--border); border-radius: 8px;
  padding: 18px 20px;
}
.card h3 { margin: 0 0 12px; font-size: 16px; font-weight: 600; }
.card--pending { opacity: 0.7; }
.card--pending .loading::after {
  content: "..."; display: inline-block; width: 1em; text-align: left;
  animation: pulse 1.2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 1; }
}

.card--ok { border-color: var(--ok); background: var(--ok-bg); }
.card--warn { border-color: var(--warn); background: var(--warn-bg); }
.card--critical { border-color: var(--critical); background: var(--critical-bg); }
.card--flags { border-width: 2px; }

.report-header { padding: 18px 20px; background: var(--card); border: 1px solid var(--border); border-radius: 8px; }
.report-header h2 { margin: 0 0 6px; font-size: 22px; font-weight: 600; }
.inn-label { font-size: 14px; color: var(--muted); font-weight: 400; font-family: ui-monospace, Menlo, Consolas, monospace; margin-left: 10px; }

/* источники */
.sources-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.source {
  display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px;
  padding: 8px 12px; border-radius: 6px; background: var(--info-bg); font-size: 14px;
}
.source-name { font-family: ui-monospace, Menlo, Consolas, monospace; font-weight: 600; }
.source-status { font-weight: 500; }
.source--ok { background: var(--ok-bg); }
.source--ok .source-status { color: var(--ok); }
.source--not_found { background: var(--info-bg); }
.source--failed, .source--blocked { background: var(--critical-bg); }
.source--failed .source-status, .source--blocked .source-status { color: var(--critical); }
.source--captcha_required, .source--timed_out { background: var(--warn-bg); }
.source--captcha_required .source-status, .source--timed_out .source-status { color: var(--warn); }
.source-duration { font-size: 12px; margin-left: auto; }
.source-message { flex-basis: 100%; font-size: 12px; margin-top: 2px; }
.pulse { animation: pulse 1.2s ease-in-out infinite; color: var(--muted); }

/* флаги */
.flags-list { list-style: none; margin: 0; padding: 0; }
.flag {
  display: grid; grid-template-columns: 90px 1fr; gap: 8px 16px;
  padding: 10px 0; border-bottom: 1px solid var(--border);
}
.flag:last-child { border-bottom: none; }
.flag-sev {
  font-size: 12px; font-weight: 700; letter-spacing: 0.05em;
  padding: 2px 8px; border-radius: 4px; text-align: center;
  height: fit-content;
}
.flag--critical .flag-sev { background: var(--critical); color: white; }
.flag--warn .flag-sev { background: var(--warn); color: white; }
.flag--info .flag-sev { background: var(--info); color: white; }
.flag-msg { font-weight: 500; }
.flag-evidence { display: block; font-size: 13px; margin-top: 2px; }

/* пилюли */
.pill {
  display: inline-block;
  padding: 2px 8px; border-radius: 10px;
  font-size: 12px; font-weight: 500;
  margin-left: 6px;
}
.pill--ok { background: var(--ok-bg); color: var(--ok); }
.pill--warn { background: var(--warn-bg); color: var(--warn); }
.pill--critical { background: var(--critical-bg); color: var(--critical); }

/* статусы */
.status {
  display: inline-block;
  padding: 2px 10px; border-radius: 10px;
  font-size: 13px; font-weight: 500;
}
.status--active { background: var(--ok-bg); color: var(--ok); }
.status--liquidated, .status--liquidating, .status--bankruptcy { background: var(--critical-bg); color: var(--critical); }
.status--reorganizing { background: var(--warn-bg); color: var(--warn); }
.status--unknown { background: var(--info-bg); color: var(--info); }

.role--plaintiff { background: var(--ok-bg); color: var(--ok); padding: 2px 8px; border-radius: 4px; font-size: 12px; }
.role--defendant { background: var(--critical-bg); color: var(--critical); padding: 2px 8px; border-radius: 4px; font-size: 12px; }
.role--third_party, .role--other { background: var(--info-bg); color: var(--info); padding: 2px 8px; border-radius: 4px; font-size: 12px; }

/* facts dl */
.facts { display: grid; grid-template-columns: minmax(200px, auto) 1fr; gap: 8px 20px; margin: 0; }
.facts dt { color: var(--muted); font-weight: 500; }
.facts dd { margin: 0; }
.founders { list-style: none; margin: 0; padding: 0; }
.founders li { padding: 2px 0; }

/* таблицы */
table {
  width: 100%; border-collapse: collapse; font-size: 14px; margin-top: 8px;
}
table th, table td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border); vertical-align: top; }
table th { background: var(--info-bg); font-weight: 600; color: var(--fg); font-size: 13px; }
table td.num, table th.num { text-align: right; font-family: ui-monospace, Menlo, Consolas, monospace; font-variant-numeric: tabular-nums; white-space: nowrap; }
table td.total, table th.total { font-weight: 600; }
table td.tax, table th.tax { color: var(--tax); }
.subject { max-width: 360px; font-size: 13px; color: var(--muted); }
.grand-total { background: var(--info-bg); font-weight: 600; }
.ep--tax td { background: #fef6f7; }

/* actions */
.actions { margin-top: 16px; }

/* адаптив */
@media (max-width: 640px) {
  .search input[type="text"] { width: 100%; }
  .facts { grid-template-columns: 1fr; gap: 2px 0; }
  .facts dt { margin-top: 10px; }
  table { font-size: 12px; }
  table th, table td { padding: 6px 8px; }
}

.sse-error-slot:empty { display: none; }

/* HTMX-подсказки по названию */
.search-input-wrap { position: relative; flex: 1; min-width: 260px; }
.search-input-wrap input[type="text"] { width: 100%; }
.suggestions { position: absolute; top: 100%; left: 0; right: 0; z-index: 10; }
.suggestions-list {
  list-style: none; margin: 4px 0 0 0; padding: 4px 0;
  background: var(--card); border: 1px solid var(--border); border-radius: 6px;
  max-height: 360px; overflow-y: auto;
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
}
.suggestion {
  padding: 8px 14px; cursor: pointer; border-bottom: 1px solid var(--border);
}
.suggestion:last-child { border-bottom: none; }
.suggestion:hover, .suggestion:focus { background: var(--info-bg); outline: none; }
.suggestion-name strong { font-weight: 500; }
.suggestion-inn { color: var(--muted); margin-left: 8px; font-family: ui-monospace, Menlo, Consolas, monospace; font-size: 13px; }
.suggestion-meta { font-size: 13px; margin-top: 2px; }

/* Финансовая отчётность */
.finances-table .row--loss .loss { color: var(--critical); font-weight: 500; }

/* Проверки */
.inspections-table .row--violation td { background: #fef6f7; }

/* Федресурс */
.fedresurs-list { list-style: none; margin: 0; padding: 0; }
.fedresurs-item {
  display: grid; grid-template-columns: 120px 1fr; gap: 12px;
  padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 14px;
}
.fedresurs-item:last-child { border-bottom: none; }
.fedresurs-item--bankruptcy { background: #fef6f7; padding-left: 8px; margin-left: -8px; border-radius: 4px; }
.fedresurs-date { font-family: ui-monospace, Menlo, Consolas, monospace; font-size: 13px; }

/* Виджет расхода API в футере */
.site-footer { display: flex; flex-direction: column; gap: 6px; align-items: center; padding: 16px 24px; }
.usage-widget { font-size: 12px; display: inline-flex; flex-wrap: wrap; gap: 6px 10px; justify-content: center; align-items: baseline; }
.usage-widget__sep { color: var(--border); }
.usage-widget__link { color: var(--link); }
.usage-widget__local { color: var(--muted); }

/* kv-table (stats) */
.kv-table { width: 100%; border-collapse: collapse; }
.kv-table td { padding: 8px 12px; border-bottom: 1px solid var(--border); }
.kv-table td:first-child { color: var(--muted); width: 50%; }

/* Таблицы — горизонтальный скролл на узких экранах */
.card { overflow-x: auto; -webkit-overflow-scrolling: touch; }
table { width: 100%; border-collapse: collapse; min-width: 560px; }
th, td { padding: 8px 10px; text-align: left; vertical-align: top; border-bottom: 1px solid var(--border); }
th { font-size: 13px; font-weight: 500; color: var(--muted); }
.num { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }

/* Мобильный адаптив */
@media (max-width: 720px) {
  body { font-size: 14px; }
  main { padding: 12px; }
  .site-header { padding: 12px 16px; flex-wrap: wrap; gap: 8px; }
  .site-header .brand { font-size: 15px; }
  .hero h1 { font-size: 22px; }
  .search { gap: 8px; }
  .search input[type="text"] { min-width: 0; width: 100%; font-size: 16px; }   /* 16px — чтобы iOS не зумил */
  .search button[type="submit"] { width: 100%; padding: 12px; }
  .search .refresh { width: 100%; }
  .card { padding: 12px 14px; }
  .card h3 { font-size: 16px; }
  table { min-width: 480px; font-size: 13px; }
  th, td { padding: 6px 8px; }
  .fedresurs-item { grid-template-columns: 80px 1fr; gap: 8px; font-size: 13px; }
  .usage-widget { font-size: 11px; }
  .usage-widget__sep { display: none; }
}

@media (max-width: 420px) {
  main { padding: 10px; }
  .card { padding: 10px 12px; border-radius: 6px; }
  table { min-width: 420px; }
}
