/* TSA Dashboard — Trophy Solutions Africa brand */
:root {
  --primary: #87241F;      /* brick red */
  --primary-dark: #6b1c18;
  --accent: #BA825A;       /* camel */
  --secondary: #715F4B;    /* taupe */
  --gold: #DCA54A;
  --cream: #FAF5E5;
  --cream-border: #e5dcc3;
  --ink: #1B1B1B;
  --ink-soft: #2E2D2A;
  --text-muted: #7A7A7A;
  --white: #ffffff;
  --ok: #4a7c2f;
  --warn: #b07d10;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Raleway', sans-serif;
  background: var(--cream);
  color: var(--ink);
  min-height: 100vh;
}

h1, h2, h3, .brand {
  font-family: 'Fjalla One', sans-serif;
  font-weight: 400;
  letter-spacing: 0.02em;
}

a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

/* top bar */
.topbar {
  background: var(--ink);
  color: var(--cream);
  display: flex;
  align-items: center;
  gap: 28px;
  padding: 0 28px;
  height: 58px;
}
.topbar .brand {
  color: var(--cream);
  font-size: 19px;
  letter-spacing: 0.09em;
}
.topbar .brand span { color: var(--accent); }
.topbar nav { display: flex; gap: 4px; flex: 1; }
.topbar nav a {
  color: #d9d2c0;
  padding: 8px 14px;
  border-radius: 4px;
  font-size: 14px;
}
.topbar nav a:hover { background: var(--ink-soft); text-decoration: none; color: var(--cream); }
.topbar nav a.active { background: var(--primary); color: var(--cream); }
.topbar .userbox { color: #b5ad99; font-size: 13px; }
.topbar .userbox a { color: var(--accent); margin-left: 10px; }

.page { max-width: 1180px; margin: 0 auto; padding: 28px 24px 60px; }

.page-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 22px; }
.page-head h1 { font-size: 26px; color: var(--ink); }
.page-head .sub { color: var(--text-muted); font-size: 14px; }

/* stat cards */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; margin-bottom: 26px; }
.stat {
  background: var(--white);
  border-radius: 8px;
  padding: 16px 18px;
  border-top: 3px solid var(--accent);
}
.stat.red { border-top-color: var(--primary); }
.stat.gold { border-top-color: var(--gold); }
.stat .label { font-size: 13px; color: var(--secondary); }
.stat .value { font-size: 30px; font-family: 'Fjalla One', sans-serif; color: var(--ink); }

/* cards & tables */
.card {
  background: var(--white);
  border: 1px solid var(--cream-border);
  border-radius: 8px;
  padding: 20px 22px;
  margin-bottom: 20px;
}
.card h2 { font-size: 17px; color: var(--primary); margin-bottom: 14px; letter-spacing: 0.04em; }

table { width: 100%; border-collapse: collapse; font-size: 14px; }
th {
  text-align: left;
  font-family: 'Fjalla One', sans-serif;
  font-weight: 400;
  font-size: 12.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--secondary);
  padding: 8px 10px;
  border-bottom: 2px solid var(--cream-border);
}
td { padding: 9px 10px; border-bottom: 1px solid #f1ecdd; vertical-align: top; }
tr:hover td { background: #fdfaf1; }
td.center, th.center { text-align: center; }

/* badges */
.badge {
  display: inline-block;
  font-size: 12px;
  padding: 3px 10px;
  border-radius: 10px;
  white-space: nowrap;
}
.badge.open { background: var(--cream); color: var(--secondary); border: 1px solid var(--cream-border); }
.badge.complete { background: #eef4e6; color: var(--ok); }
.badge.shipped { background: #f4ecdf; color: var(--warn); }
.badge.cites { background: #f7e8e7; color: var(--primary); }
.badge.tops { background: #f4ecdf; color: var(--warn); }
.badge.plain { background: var(--cream); color: var(--secondary); }

.dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; background: var(--cream-border); }
.dot.on { background: var(--ok); }

/* buttons */
.btn {
  display: inline-block;
  font-family: 'Raleway', sans-serif;
  font-size: 14px;
  padding: 9px 20px;
  border-radius: 4px;
  border: none;
  cursor: pointer;
  background: var(--primary);
  color: var(--cream);
}
.btn:hover { background: var(--primary-dark); text-decoration: none; }
.btn.ghost { background: var(--white); color: var(--primary); border: 1px solid var(--accent); }
.btn.ghost:hover { background: var(--cream); }
.btn.sm { padding: 5px 12px; font-size: 12.5px; }

/* forms */
input[type=text], input[type=password], input[type=search], input[type=file], select {
  font-family: 'Raleway', sans-serif;
  font-size: 14px;
  padding: 9px 12px;
  border: 1px solid var(--cream-border);
  border-radius: 4px;
  background: var(--white);
  width: 100%;
}
input:focus { outline: 2px solid var(--accent); border-color: var(--accent); }
label { font-size: 13px; color: var(--secondary); display: block; margin: 12px 0 4px; }

/* login */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--ink); }
.login-card {
  background: var(--cream);
  border-radius: 10px;
  padding: 40px 42px;
  width: 380px;
  border-top: 5px solid var(--primary);
}
.login-card .brand { font-size: 21px; color: var(--ink); letter-spacing: 0.08em; margin-bottom: 4px; }
.login-card .tagline { color: var(--accent); font-size: 12.5px; letter-spacing: 0.22em; text-transform: uppercase; margin-bottom: 24px; }
.login-card .btn { width: 100%; margin-top: 20px; }
.error { background: #f7e8e7; color: var(--primary); padding: 10px 14px; border-radius: 4px; font-size: 13.5px; margin-top: 14px; }
.success { background: #eef4e6; color: var(--ok); padding: 10px 14px; border-radius: 4px; font-size: 13.5px; margin-bottom: 14px; }

/* phase tracker */
.phases { display: flex; flex-direction: column; gap: 0; }
.phase {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 4px;
  border-bottom: 1px solid #f1ecdd;
  font-size: 14px;
}
.phase:last-child { border-bottom: none; }
.phase .meta { margin-left: auto; color: var(--text-muted); font-size: 12.5px; white-space: nowrap; }
.phase form { display: inline; }
.phase button.tick {
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid var(--cream-border); background: var(--white);
  cursor: pointer; color: transparent; font-size: 12px; line-height: 1;
}
.phase.done button.tick { background: var(--ok); border-color: var(--ok); color: #fff; }
.phase.done .plabel { color: var(--text-muted); }

/* progress bar */
.progress { height: 7px; background: var(--cream); border-radius: 4px; overflow: hidden; min-width: 90px; }
.progress > div { height: 100%; background: var(--accent); }

/* two-col layout on detail page */
.cols { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; align-items: start; }
@media (max-width: 900px) { .cols { grid-template-columns: 1fr; } }

.kv { font-size: 14px; }
.kv div { display: flex; padding: 5px 0; border-bottom: 1px solid #f1ecdd; }
.kv div:last-child { border-bottom: none; }
.kv dt { width: 150px; color: var(--secondary); flex-shrink: 0; }
.kv dd { color: var(--ink); }
.kv dd.empty { color: #c9c2ae; }

/* doc checklist */
.doclist { display: grid; grid-template-columns: 1fr 1fr; gap: 2px 16px; }
.doc { display: flex; align-items: center; gap: 8px; font-size: 13.5px; padding: 5px 0; }
.doc form { display: inline; }
.doc button {
  width: 18px; height: 18px; border-radius: 4px;
  border: 2px solid var(--cream-border); background: var(--white);
  cursor: pointer; color: transparent; font-size: 10px; line-height: 1;
}
.doc.on button { background: var(--accent); border-color: var(--accent); color: #fff; }

.searchbar { display: flex; gap: 10px; margin-bottom: 18px; max-width: 420px; }

.empty-state { text-align: center; padding: 48px 20px; color: var(--text-muted); }
.empty-state .big { font-family: 'Fjalla One', sans-serif; font-size: 19px; color: var(--secondary); margin-bottom: 8px; }
