:root {
  --bg: #f7f2e8;
  --paper: #fffdf8;
  --ink: #172322;
  --muted: #5f6f6c;
  --line: #e4dacb;
  --accent: #d35c2b;
  --accent-2: #0f7c69;
  --warn: #d03d3d;
  --amber: #d79a20;
  --shadow: 0 18px 40px rgba(17, 27, 26, 0.10);
  font-family: "Space Grotesk", system-ui, sans-serif;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(243, 213, 180, 0.5), transparent 28%),
    radial-gradient(circle at top right, rgba(183, 226, 214, 0.5), transparent 30%),
    linear-gradient(180deg, #f8f3ea 0%, #edf3ef 100%);
  color: var(--ink);
}
a { color: inherit; text-decoration: none; }
h1, h2, p { margin: 0; }
.login-shell { min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.login-card, .panel, .stat-card, .hero { background: rgba(255,253,248,0.92); border: 1px solid rgba(0,0,0,0.05); border-radius: 24px; box-shadow: var(--shadow); }
.login-card { width: min(440px, 100%); padding: 32px; display: grid; gap: 14px; }
.layout { display: grid; grid-template-columns: 280px 1fr; min-height: 100vh; }
.sidebar { background: linear-gradient(180deg, #132623, #18322e); color: #f4efe4; padding: 28px 22px; display: flex; flex-direction: column; gap: 24px; }
.brand { font-size: 28px; font-weight: 700; }
.nav { display: grid; gap: 10px; }
.nav a { padding: 12px 14px; border-radius: 14px; background: rgba(255,255,255,0.05); }
.nav a.active { background: rgba(211, 92, 43, 0.22); }
.user-card { margin-top: auto; display: grid; gap: 10px; }
.main { padding: 28px; display: grid; gap: 22px; }
.hero { padding: 28px; }
.eyebrow, .pill { display: inline-flex; padding: 6px 12px; border-radius: 999px; background: #efe3d1; font-size: 12px; font-weight: 700; }
.pill.warn { background: #f4d7d7; color: #8f2525; }
.version, .footer, .muted, .small { color: var(--muted); }
.page-head, .panel-head, .result-head, .person-top, .person-meta, .list-row { display: flex; justify-content: space-between; gap: 12px; align-items: center; }
.stats-grid, .grid-two { display: grid; gap: 18px; }
.stats-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.grid-two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-two.wide-left { grid-template-columns: minmax(360px, 460px) 1fr; }
.full-width-panel, .client-form-panel { width: 100%; }
.stat-card, .panel { padding: 20px; }
.stat-card strong { font-size: 34px; }
.search, input, select, textarea, button { font: inherit; }
.search, input, select, textarea { width: 100%; padding: 12px 14px; border-radius: 14px; border: 1px solid var(--line); background: #fffdfa; }
select[multiple] { min-height: 140px; }
textarea { resize: vertical; }
label { display: block; margin-bottom: 8px; font-size: 13px; font-weight: 700; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.span-2 { grid-column: 1 / -1; }
.form-actions { display: flex; gap: 10px; }
.button { display: inline-flex; align-items: center; justify-content: center; border: 0; border-radius: 999px; padding: 11px 18px; background: linear-gradient(135deg, var(--accent), #b64218); color: white; cursor: pointer; font-weight: 700; }
.button.ghost { background: #e9e0d1; color: var(--ink); }
.button.mini { padding: 8px 12px; font-size: 13px; }
.alert { padding: 14px 16px; border-radius: 16px; }
.alert.success { background: rgba(15,124,105,0.10); border: 1px solid rgba(15,124,105,0.22); }
.alert.error { background: rgba(208,61,61,0.10); border: 1px solid rgba(208,61,61,0.22); }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { text-align: left; padding: 14px 10px; border-bottom: 1px solid var(--line); vertical-align: top; }
.meter { height: 12px; background: #eadfce; border-radius: 999px; overflow: hidden; }
.meter.compact { height: 10px; }
.meter span { display: block; height: 100%; }
.meter.green span { background: linear-gradient(90deg, #177f6a, #57c9ab); }
.meter.orange span { background: linear-gradient(90deg, #b57a18, #efbf57); }
.meter.red span { background: linear-gradient(90deg, #bb3f3f, #f07e7e); }
.person-card { padding: 14px 0; border-bottom: 1px solid var(--line); display: grid; gap: 10px; }
.person-card:last-child, .list-row:last-child { border-bottom: 0; }
.list-row { padding: 12px 0; border-bottom: 1px solid var(--line); }
.capacity-board { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.capacity-card { border: 1px solid var(--line); border-radius: 18px; padding: 16px; background: rgba(255,255,255,0.75); display: grid; gap: 10px; }
.capacity-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.assignments-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.assignment-stack { display: grid; gap: 10px; }
.assignment-row { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(180px, 0.9fr) auto; gap: 10px; align-items: center; padding: 12px; border: 1px solid var(--line); border-radius: 16px; background: rgba(255,255,255,0.72); }
.summary-card { display: flex; justify-content: space-between; gap: 16px; align-items: center; border: 1px solid rgba(15,124,105,0.18); border-radius: 20px; padding: 18px; margin-bottom: 16px; background: linear-gradient(135deg, rgba(239,250,246,0.95), rgba(255,253,248,0.98)); }
.result-card { border: 1px solid var(--line); border-radius: 20px; padding: 16px; margin-bottom: 14px; background: #fffdfa; }
.result-card.recommended { background: linear-gradient(180deg, rgba(242,251,248,0.95), #fffdfa); border-color: rgba(15,124,105,0.25); }
.result-card.blocked { background: linear-gradient(180deg, rgba(252,243,243,0.95), #fffdfa); border-color: rgba(208,61,61,0.22); }
.result-tradeoff { margin-top: 10px; color: var(--accent); font-weight: 600; }
.reason-list { margin: 14px 0 0; padding-left: 18px; color: var(--muted); }
.score { text-align: right; font-weight: 700; margin-top: 8px; }
@media (max-width: 1080px) {
  .layout { grid-template-columns: 1fr; }
  .grid-two, .grid-two.wide-left { grid-template-columns: 1fr; }
  .capacity-board { grid-template-columns: 1fr; }
  .summary-card { display: grid; }
}
@media (max-width: 720px) {
  .main { padding: 16px; }
  .hero, .panel, .stat-card, .login-card { padding: 16px; }
  .page-head, .panel-head, .result-head, .person-top, .person-meta { display: grid; }
  .form-grid { grid-template-columns: 1fr; }
  .assignment-row { grid-template-columns: 1fr; }
  .assignments-head { display: grid; }
}
