:root {
  --dominion-primary: #111827;
  --dominion-gold: #c9a227;
  --dominion-light: #f8f9fb;
  --dominion-border: #d9dce3;
  --risk-red: #dc2626;
  --risk-yellow: #f59e0b;
  --risk-green: #16a34a;
  --black: var(--dominion-primary);
  --ink: #2b2f36;
  --muted: #69717e;
  --gold: var(--dominion-gold);
  --paper: #fff;
  --bg: var(--dominion-light);
  --line: var(--dominion-border);
  --red: var(--risk-red);
  --red-soft: #fde9e9;
  --green: var(--risk-green);
  --green-soft: #e7f5ed;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
body { margin: 0; color: var(--ink); background: var(--bg); }
a { color: inherit; text-decoration: none; }
input, select, textarea, button { font: inherit; }
input, select, textarea {
  width: 100%;
  min-height: 42px;
  padding: 10px 11px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--paper);
}
textarea { min-height: 110px; resize: vertical; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 12px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
th { color: var(--black); background: #f8fafc; }
small { color: var(--muted); }

.app-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px clamp(16px, 4vw, 46px);
  color: var(--paper);
  background: linear-gradient(180deg, #111827 0%, #0b1220 100%);
  border-bottom: 3px solid var(--gold);
  box-shadow: 0 10px 30px rgba(17, 24, 39, .18);
}
.app-header nav { display: flex; flex-wrap: wrap; gap: 16px; font-size: 14px; }
.app-header nav a { color: #f7f8fb; opacity: .92; }
.app-header nav a:hover { color: var(--gold); opacity: 1; }
.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand-logo {
  display: block;
  width: clamp(142px, 18vw, 220px);
  max-height: 58px;
  object-fit: contain;
}
.brand strong, .brand small { display: block; }
.brand small { color: #d8dce2; }
.container { width: min(1180px, calc(100% - 32px)); margin: 28px auto; }
.topbar { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 18px; }
.topbar h1 { margin: 4px 0 0; color: var(--black); }
.eyebrow { margin: 0; color: #927028; font-size: 12px; font-weight: 800; text-transform: uppercase; }
.panel, .login-panel, .notice-strip, .security-warning {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  box-shadow: 0 10px 28px rgba(17,17,17,.05);
  margin-bottom: 18px;
}
.notice-strip { background: #fbf4e4; border-color: #ead39d; line-height: 1.55; }
.security-warning, .alert.danger { color: #5c211f; background: var(--red-soft); border-color: #e7bcbc; }
.alert.success { color: var(--green); background: var(--green-soft); border-color: #bfe2cf; }
.warning-text { padding: 12px; border-radius: 8px; color: #5c211f; background: var(--red-soft); }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.form-grid.single { grid-template-columns: 1fr; }
.full { grid-column: 1 / -1; }
label { display: grid; gap: 7px; font-size: 14px; font-weight: 750; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--paper);
  color: var(--black);
  cursor: pointer;
  font-weight: 750;
}
.button.primary { color: var(--paper); background: var(--black); border-color: var(--black); box-shadow: inset 0 -3px 0 rgba(201, 162, 39, .45); }
.button.danger { color: #fff; background: var(--red); border-color: var(--red); }
.button.small { min-height: 34px; padding: 6px 10px; font-size: 13px; }
.actions, .form-actions, .search-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.search-bar { margin-bottom: 18px; }
.search-bar input { flex: 1 1 320px; }
.status { display: inline-block; padding: 4px 9px; border-radius: 999px; background: #eef2f6; font-weight: 800; font-size: 12px; }
.status.red { color: var(--risk-red); background: #fee2e2; }
.status.yellow { color: #92400e; background: #fef3c7; }
.status.green { color: var(--risk-green); background: #dcfce7; }
.score-grid,
.dashboard-cards,
.trend-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.score-card { padding: 14px; border: 1px solid var(--line); border-radius: 8px; background: #fafbfc; }
.score-card strong, .score-card span { display: block; }
.score-card span { margin-top: 6px; color: var(--dominion-primary); font-size: 24px; font-weight: 850; }
.trend-point { display: grid; gap: 4px; padding: 12px; border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.trend-point span { color: var(--muted); font-size: 13px; }
.two-column { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; align-items: start; }
.note-card { padding: 14px 0; border-bottom: 1px solid var(--line); }
.site-footer { padding: 24px; color: #d9dde3; background: var(--black); text-align: center; }
.login-page .container { min-height: calc(100vh - 110px); display: grid; place-items: center; }
.login-panel { width: min(480px, 100%); border-top: 5px solid var(--gold); }
.login-brand { color: var(--black); margin-bottom: 18px; }
.login-brand small { color: var(--muted); }
.login-brand .brand-logo { width: min(250px, 100%); max-height: 76px; }

@media (max-width: 820px) {
  .app-header, .topbar { align-items: flex-start; flex-direction: column; }
  .form-grid, .two-column, .score-grid, .dashboard-cards, .trend-grid { grid-template-columns: 1fr; }
  table { display: block; overflow-x: auto; }
  .brand-logo { width: min(190px, 54vw); }
}
