:root {
  --bg: #08090c;
  --panel: #11141a;
  --panel-2: #171b23;
  --border: rgba(202, 168, 93, 0.22);
  --text: #f2efe8;
  --muted: #9b9ea7;
  --gold: #caa85d;
  --gold-2: #e4cc88;
  --danger: #ef6461;
  --ok: #58c27d;
  --warning: #d69b35;
  --radius: 18px;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  background: radial-gradient(circle at top, #151515 0, var(--bg) 48%, #050506 100%);
  color: var(--text);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Arial, sans-serif;
}
button, input, textarea, select { font: inherit; }
.app-shell { min-height: 100vh; display: grid; grid-template-columns: 300px 1fr; }
.sidebar { padding: 24px; border-right: 1px solid var(--border); background: rgba(10, 11, 15, 0.84); }
.brand { display: flex; align-items: center; gap: 14px; padding-bottom: 24px; border-bottom: 1px solid var(--border); }
.brand__logo { width: 58px; height: 58px; border-radius: 50%; object-fit: cover; border: 1px solid var(--gold); }
.brand__title { font-size: 22px; font-weight: 800; letter-spacing: .06em; color: var(--gold-2); }
.brand__subtitle { color: var(--muted); font-size: 13px; }
.nav { display: grid; gap: 10px; margin-top: 24px; }
.nav__item { text-align: left; background: transparent; color: var(--muted); border: 1px solid transparent; padding: 13px 14px; border-radius: 14px; cursor: pointer; }
.nav__item:hover, .nav__item.active { color: var(--text); background: var(--panel-2); border-color: var(--border); }
.sidebar__footer { position: fixed; bottom: 20px; left: 24px; color: var(--muted); font-size: 13px; }
.status-dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; background: var(--warning); margin-right: 6px; }
.main { padding: 30px; }
.topbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
h1 { margin: 0; font-size: 30px; }
p { color: var(--muted); }
.user-panel { display: flex; align-items: center; gap: 12px; color: var(--muted); }
.login-card { max-width: 420px; margin: 70px auto; padding: 28px; border-radius: var(--radius); border: 1px solid var(--border); background: linear-gradient(180deg, rgba(23,27,35,.95), rgba(12,13,18,.95)); box-shadow: 0 24px 90px rgba(0,0,0,.36); }

/* Auth-only screen: hide sidebar/topbar and center the login card. */
.app-shell--auth {
  grid-template-columns: 1fr;
  background: var(--bg);
}
.app-shell--auth .sidebar,
.app-shell--auth .topbar {
  display: none;
}
.app-shell--auth .main {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  min-height: 100vh;
}
.app-shell--auth .login-card {
  margin: 0;
}
.login-card__logo { width: 86px; height: 86px; border-radius: 50%; display: block; margin: 0 auto 18px; border: 1px solid var(--gold); }
label { display: block; color: var(--gold-2); margin: 14px 0 6px; font-size: 13px; }
input, textarea, select { width: 100%; background: #090b0f; color: var(--text); border: 1px solid var(--border); border-radius: 12px; padding: 12px; outline: none; }
input:focus, textarea:focus, select:focus { border-color: var(--gold); }
.btn { border: 0; border-radius: 12px; padding: 11px 16px; cursor: pointer; }
.btn--primary { width: 100%; margin-top: 18px; color: #0b0b0e; background: linear-gradient(135deg, var(--gold), var(--gold-2)); font-weight: 800; }
.btn--ghost { background: transparent; color: var(--gold-2); border: 1px solid var(--border); }
.hidden { display: none !important; }
.form-error { color: var(--danger); margin-top: 12px; }
.content { display: grid; gap: 18px; }
.grid { display: grid; gap: 16px; }
.grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.card { background: rgba(20,23,30,.92); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; }
.card__value { font-size: 30px; color: var(--gold-2); font-weight: 800; }
.table { width: 100%; border-collapse: collapse; overflow: hidden; border-radius: 16px; }
.table th, .table td { padding: 13px 12px; border-bottom: 1px solid rgba(255,255,255,.06); text-align: left; }
.table th { color: var(--gold-2); font-weight: 700; background: rgba(202,168,93,.08); }
.badge { padding: 4px 9px; border-radius: 999px; font-size: 12px; }
.badge--ok { background: rgba(88,194,125,.13); color: var(--ok); }
.badge--new { background: rgba(111,121,255,.13); color: #9da5ff; }
.badge--work { background: rgba(214,155,53,.14); color: var(--warning); }
.badge--closed { background: rgba(88,194,125,.13); color: var(--ok); }
.toolbar { display: flex; justify-content: space-between; gap: 14px; align-items: center; }
.toolbar input { max-width: 380px; }
.dialog { background: rgba(20,23,30,.98); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; color: var(--text); max-width: 720px; width: 90vw; }
.dialog::backdrop { background: rgba(0,0,0,.72); }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin-top: 16px; }
.form-grid label { margin: 0; }
.form-grid--full { grid-column: 1 / -1; }
.form-actions { display: flex; justify-content: flex-end; gap: 12px; margin-top: 20px; }
.form-actions .btn--primary { width: auto; margin: 0; }
@media (max-width: 960px) { .app-shell { grid-template-columns: 1fr; } .sidebar { position: static; } .sidebar__footer { position: static; margin-top: 24px; } .grid--4 { grid-template-columns: 1fr 1fr; } .form-grid { grid-template-columns: 1fr; } }
