:root {
  --bg: #eff4f8;
  --panel: #ffffff;
  --ink: #102132;
  --ink-soft: #445c76;
  --line: #c7d8e8;
  --brand: #2f5d90;
  --brand-2: #6fa6d8;
  --accent: #86cbb6;
  --ok: #1d7a57;
  --warn: #a56b24;
  --danger: #b23c3c;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  background: linear-gradient(160deg, #f8fbfd 0%, var(--bg) 55%, #e8eff6 100%);
  color: var(--ink);
  font-family: "Manrope", sans-serif;
}

.bg-orbs {
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(700px 360px at -5% -10%, rgba(111, 166, 216, 0.23) 0%, transparent 68%),
    radial-gradient(780px 380px at 104% -10%, rgba(134, 203, 182, 0.22) 0%, transparent 70%);
}

.shell {
  position: relative;
  z-index: 1;
  max-width: 1400px;
  margin: 0 auto;
  padding: 22px 14px 40px;
  display: grid;
  gap: 14px;
}

.panel {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  box-shadow: 0 14px 36px rgba(20, 39, 64, 0.08);
}

.hero {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding: 18px;
}

.hero h1 {
  font-family: "Sora", sans-serif;
  margin: 8px 0;
  font-size: clamp(1.45rem, 2.7vw, 2.05rem);
  letter-spacing: -0.02em;
}

.hero p {
  margin: 0;
  max-width: 74ch;
  color: var(--ink-soft);
}

.badge {
  display: inline-flex;
  border-radius: 999px;
  border: 1px solid #9dbde2;
  background: linear-gradient(140deg, #edf5ff 0%, #f1fbf7 100%);
  padding: 6px 11px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--brand);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;
  justify-content: flex-end;
  gap: 8px;
  max-width: 500px;
}

.btn {
  border: 0;
  cursor: pointer;
  border-radius: 11px;
  padding: 9px 12px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
}

.btn.secondary {
  border: 1px solid #b8cbde;
  color: #22425f;
  background: linear-gradient(180deg, #fbfdff 0%, #eff6fc 100%);
}

.btn.soft {
  border: 1px solid #8bb2d8;
  color: var(--brand);
  background: linear-gradient(180deg, #f3f8ff 0%, #ebf5ff 100%);
}

.top-meta {
  padding: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: 2fr 1fr 1fr 1.2fr;
}

.import-panel {
  padding: 14px;
}

.layout {
  display: grid;
  gap: 14px;
}

.section {
  padding: 14px;
}

.section-head h2 {
  margin: 0;
  font-family: "Sora", sans-serif;
  font-size: 1.04rem;
}

.section-head p {
  margin: 4px 0 0;
  font-size: 14px;
  color: var(--ink-soft);
}

.actions {
  margin-top: 10px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

label {
  display: grid;
  gap: 6px;
  font-size: 12.5px;
  color: #35506a;
  font-weight: 700;
}

input,
select,
textarea {
  width: 100%;
  border-radius: 10px;
  border: 1px solid #b9cbdd;
  padding: 9px 10px;
  font: inherit;
  color: var(--ink);
  background: #fff;
}

.table-wrap {
  margin-top: 10px;
  border: 1px solid var(--line);
  border-radius: 13px;
  overflow: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 950px;
}

th,
td {
  border-bottom: 1px solid #dce7f2;
  padding: 8px;
  font-size: 12.5px;
  text-align: left;
  vertical-align: middle;
}

th {
  position: sticky;
  top: 0;
  background: linear-gradient(180deg, #edf3fb 0%, #e2edf8 100%);
  color: #173754;
  z-index: 1;
}

tr:last-child td {
  border-bottom: 0;
}

.row-input {
  border: 1px solid #c2d5e8;
  border-radius: 8px;
  padding: 6px 7px;
  font-size: 12px;
  width: 100%;
}

.row-mini-btn {
  border: 1px solid #d2a6a6;
  background: #fff5f5;
  color: var(--danger);
  border-radius: 7px;
  padding: 6px 8px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}

.suppliers-grid {
  margin-top: 10px;
  display: grid;
  gap: 12px;
}

.supplier-card {
  border: 1px solid #c8d9eb;
  border-radius: 13px;
  background: linear-gradient(180deg, #ffffff 0%, #f6fbff 100%);
  padding: 10px;
}

.supplier-head {
  display: grid;
  gap: 8px;
  grid-template-columns: 1.7fr 0.8fr 0.8fr auto;
  align-items: end;
}

.supplier-kpi {
  margin-top: 9px;
  display: flex;
  gap: 14px;
  font-size: 12px;
  color: #24435f;
  flex-wrap: wrap;
}

.supplier-kpi strong {
  color: var(--ink);
}

.weights-grid {
  margin-top: 10px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tag {
  display: inline-flex;
  border-radius: 999px;
  padding: 4px 8px;
  border: 1px solid #d2e0ef;
  background: #f8fbff;
  font-size: 11px;
  font-weight: 700;
}

.tag.ok {
  border-color: #9dd4bf;
  background: #edfaf4;
  color: var(--ok);
}

.tag.warn {
  border-color: #ebca9d;
  background: #fff7ec;
  color: var(--warn);
}

.tag.risk {
  border-color: #ebb0b0;
  background: #fff4f4;
  color: var(--danger);
}

.recommendation {
  margin-top: 12px;
  border: 1px solid #bfd8f0;
  border-radius: 13px;
  background: linear-gradient(145deg, #f3f9ff 0%, #edf9f5 100%);
  padding: 12px;
}

.recommendation h3 {
  margin: 0;
  font-family: "Sora", sans-serif;
  font-size: 0.95rem;
}

.recommendation p {
  margin: 6px 0 0;
  font-size: 13px;
  color: #294764;
}

.charts-grid {
  margin-top: 12px;
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr 1fr;
}

.chart-card {
  border: 1px solid #c9d9ea;
  border-radius: 13px;
  background: #f8fbff;
  padding: 10px;
}

.chart-card h3 {
  margin: 0 0 6px;
  font-size: 0.92rem;
  font-family: "Sora", sans-serif;
  color: #1f4261;
}

.chart-card canvas {
  width: 100% !important;
  height: 230px !important;
}

.analysis-card {
  margin-top: 12px;
  border: 1px solid #bfd8f0;
  border-radius: 13px;
  background: #f6fbff;
  padding: 12px;
}

.analysis-card h3 {
  margin: 0;
  font-family: "Sora", sans-serif;
  font-size: 0.95rem;
}

#analysisReport {
  margin-top: 8px;
  display: grid;
  gap: 8px;
}

#analysisReport .analysis-block {
  border: 1px solid #d4e3f1;
  border-radius: 10px;
  background: #fff;
  padding: 8px 10px;
}

#analysisReport .analysis-block h4 {
  margin: 0;
  font-size: 0.84rem;
  color: #284864;
}

#analysisReport .analysis-block p {
  margin: 6px 0 0;
  font-size: 13px;
  color: #335571;
}

.risk-list {
  margin-top: 12px;
  border: 1px solid #e2c6a0;
  border-radius: 13px;
  background: #fffaf2;
  padding: 12px;
}

.risk-list h3 {
  margin: 0;
  font-size: 0.95rem;
  font-family: "Sora", sans-serif;
}

.risk-list ul {
  margin: 8px 0 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
  color: #66411d;
  font-size: 13px;
}

.muted {
  color: #5c738a;
}

@media (max-width: 1120px) {
  .top-meta {
    grid-template-columns: 1fr 1fr;
  }

  .weights-grid {
    grid-template-columns: 1fr 1fr;
  }

  .supplier-head {
    grid-template-columns: 1fr 1fr;
  }

  .charts-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  .hero {
    flex-direction: column;
  }

  .hero-actions {
    justify-content: flex-start;
    max-width: 100%;
  }

  .top-meta {
    grid-template-columns: 1fr;
  }

  .weights-grid {
    grid-template-columns: 1fr;
  }

  .supplier-head {
    grid-template-columns: 1fr;
  }
}
