.tool-page { display: flex; flex-direction: column; gap: 16px; }

.card {
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 14px;
  background: rgba(255,255,255,0.92);
  overflow: hidden;
}

.card-header { padding: 16px 16px 6px 16px; }
.title-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.card-header h1 { margin: 0; font-size: 22px; }

.muted { opacity: 0.75; margin: 6px 0 0 0; }
.small { font-size: 12px; }

.notice {
  margin: 0 16px 16px 16px;
  padding: 12px 12px;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 12px;
  background: rgba(255, 246, 214, 0.70);
}

.toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: end;
  padding: 0 16px 16px 16px;
}

.field { display: flex; flex-direction: column; gap: 6px; min-width: 220px; }
.field.grow { flex: 1; min-width: 280px; }
.field label { font-size: 12px; opacity: 0.85; }

.field input,
.field select {
  border: 1px solid rgba(0,0,0,0.18);
  border-radius: 10px;
  padding: 10px 12px;
  background: #fff;
}

.btn {
  border: 1px solid rgba(0,0,0,0.18);
  border-radius: 10px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.9);
  cursor: pointer;
}

.grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; padding: 0 16px 16px 16px; }
@media (max-width: 980px) { .grid { grid-template-columns: 1fr; } }

.panel {
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255,255,255,0.75);
}

.panel h2 { margin: 0 0 10px 0; font-size: 16px; }

.table-wrap {
  width: 100%;
  overflow: auto;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.10);
  background: #fff;
}

.tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.tbl th, .tbl td { padding: 10px 10px; border-bottom: 1px solid rgba(0,0,0,0.08); vertical-align: top; }
.tbl th { text-align: left; font-size: 12px; opacity: 0.8; background: rgba(0,0,0,0.03); position: sticky; top: 0; }
.tbl tr:last-child td { border-bottom: none; }
