/* ============================================================
   components.css — Buttons, forms, cards, tables, badges
   ============================================================ */

/* ─── Buttons ─── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  border: none;
  border-radius: var(--r2);
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: .2s;
  white-space: nowrap;
}
.btn-p   { background: linear-gradient(135deg, var(--gold), var(--gold2)); color: var(--navy); }
.btn-p:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(201,168,76,.3); }
.btn-p:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.btn-s   { background: rgba(255,255,255,.07); color: var(--white); border: 1px solid rgba(255,255,255,.1); }
.btn-s:hover { background: rgba(255,255,255,.13); }
.btn-d   { background: rgba(224,85,85,.12); color: var(--red);    border: 1px solid rgba(224,85,85,.25); }
.btn-d:hover { background: rgba(224,85,85,.22); }
.btn-g   { background: rgba(58,170,110,.12); color: var(--green); border: 1px solid rgba(58,170,110,.25); }
.btn-pur { background: rgba(123,94,167,.12); color: var(--purple);border: 1px solid rgba(123,94,167,.25); }
.btn-pur:hover { background: rgba(123,94,167,.22); }
.btn-teal{ background: rgba(42,157,143,.12); color: var(--teal);  border: 1px solid rgba(42,157,143,.25); }
.btn-o   { background: rgba(224,122,53,.12); color: var(--orange);border: 1px solid rgba(224,122,53,.25); }
.btn.sm  { padding: 5px 10px; font-size: 11px; }
.btn.full{ width: 100%; justify-content: center; }

/* ─── Form groups ─── */
.fg { margin-bottom: 14px; }
.fg label {
  display: block;
  font-size: 12px;
  color: var(--gray2);
  margin-bottom: 5px;
  font-weight: 600;
}
.fg input, .fg select, .fg textarea {
  width: 100%;
  background: rgba(15,31,61,.7);
  border: 1.5px solid rgba(201,168,76,.2);
  border-radius: var(--r2);
  padding: 9px 13px;
  color: var(--white);
  font-family: inherit;
  font-size: 13px;
  transition: .2s;
}
.fg input:focus, .fg select:focus, .fg textarea:focus {
  outline: none;
  border-color: var(--gold);
}
.fg select option { background: var(--navy2); }
.fg textarea { resize: vertical; min-height: 65px; }
.fr { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }

/* Filter bar */
.filter-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 11px;
}
.search-input {
  flex: 1;
  min-width: 160px;
  background: rgba(15,31,61,.6);
  border: 1.5px solid rgba(201,168,76,.13);
  border-radius: var(--r2);
  padding: 7px 12px;
  color: var(--white);
  font-family: inherit;
  font-size: 13px;
}
.search-input:focus { outline: none; border-color: var(--gold); }
select.filter-select {
  background: rgba(15,31,61,.6);
  border: 1.5px solid rgba(201,168,76,.13);
  border-radius: var(--r2);
  padding: 7px 11px;
  color: var(--white);
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
}
select.filter-select:focus { outline: none; border-color: var(--gold); }

/* ─── Cards ─── */
.card {
  background: var(--navy2);
  border: 1px solid rgba(201,168,76,.1);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 14px;
}
.card-header {
  padding: 11px 16px;
  border-bottom: 1px solid rgba(201,168,76,.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.card-title { font-size: 13px; font-weight: 700; }
.card-body  { padding: 14px; }

/* ─── Stat cards ─── */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(175px, 1fr));
  gap: 11px;
  margin-bottom: 18px;
}
.stat {
  background: var(--navy2);
  border: 1px solid rgba(201,168,76,.1);
  border-radius: var(--r);
  padding: 15px;
}
.stat .icon { font-size: 22px; margin-bottom: 7px; }
.stat .val  { font-size: 19px; font-weight: 900; }
.stat .lbl  { font-size: 11px; color: var(--gray); margin-top: 2px; }
.stat .tr   { font-size: 11px; margin-top: 5px; font-weight: 600; color: var(--green); }

/* ─── Tables ─── */
.tbl-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
th {
  padding: 7px 10px;
  text-align: right;
  font-size: 11px;
  font-weight: 700;
  color: var(--gray);
  border-bottom: 1px solid rgba(255,255,255,.05);
}
td {
  padding: 9px 10px;
  font-size: 12px;
  border-bottom: 1px solid rgba(255,255,255,.03);
  vertical-align: middle;
}
tr:hover td { background: rgba(255,255,255,.02); }

/* ─── Badges ─── */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
}
.bg     { background: rgba(58,170,110,.13); color: var(--green); }
.bo     { background: rgba(224,122,53,.13); color: var(--orange); }
.bb     { background: rgba(58,123,213,.13); color: var(--blue); }
.bgy    { background: rgba(138,154,181,.13); color: var(--gray); }
.bgold  { background: rgba(201,168,76,.13); color: var(--gold); }
.bpur   { background: rgba(123,94,167,.15); color: #b39ddb; }
.bteal  { background: rgba(42,157,143,.15); color: var(--teal); }
.br     { background: rgba(224,85,85,.13);  color: var(--red); }

/* ─── Progress bar ─── */
.progress-wrap {
  background: rgba(255,255,255,.05);
  border-radius: 10px;
  height: 7px;
  overflow: hidden;
  margin-top: 4px;
}
.progress-bar {
  height: 100%;
  border-radius: 10px;
  transition: width .4s;
}
.progress-bar.safe   { background: linear-gradient(90deg, var(--green), #5fd49c); }
.progress-bar.warn   { background: linear-gradient(90deg, var(--orange), #f5a45a); }
.progress-bar.danger { background: linear-gradient(90deg, var(--red), #f08080); }

/* ─── Alerts ─── */
.alert {
  padding: 10px 13px;
  border-radius: var(--r2);
  font-size: 12px;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.alert-warn   { background: rgba(224,122,53,.1); border: 1px solid rgba(224,122,53,.25); color: var(--orange); }
.alert-danger { background: rgba(224,85,85,.1);  border: 1px solid rgba(224,85,85,.25);  color: var(--red); }
.alert-ok     { background: rgba(58,170,110,.1); border: 1px solid rgba(58,170,110,.25); color: var(--green); }
.alert-info   { background: rgba(58,123,213,.08);border: 1px solid rgba(58,123,213,.18); color: var(--blue); }

/* IQD helper box */
.iqd-box {
  display: none;
  background: rgba(123,94,167,.1);
  border: 1px solid rgba(123,94,167,.25);
  border-radius: var(--r2);
  padding: 9px 13px;
  font-size: 12px;
  color: #b39ddb;
  margin-top: 5px;
}

/* Section title inside form */
.section-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: .5px;
  padding: 8px 0 5px;
  border-bottom: 1px solid rgba(201,168,76,.1);
  margin-bottom: 11px;
}

/* Tabs */
.tab-bar { display: flex; gap: 6px; margin-bottom: 14px; flex-wrap: wrap; }
.tab {
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  border: 1.5px solid rgba(201,168,76,.15);
  color: var(--gray2);
  transition: .2s;
}
.tab:hover  { border-color: var(--gold); color: var(--gold); }
.tab.active { background: rgba(201,168,76,.12); border-color: var(--gold); color: var(--gold); }
