/* app.css — layout + components. Consumes tokens.css; no hard-coded palette. */

#app { min-height: 100vh; }

/* ── App shell ── */
.shell { display: grid; grid-template-columns: var(--sidebar-w, 232px) 1fr; min-height: 100vh; }
.shell.collapsed { --sidebar-w: 64px; }

.sidebar {
  position: sticky; top: 0; align-self: start; height: 100vh;
  display: flex; flex-direction: column; gap: var(--sp-2);
  padding: var(--sp-4) var(--sp-3); border-right: 1px solid var(--border);
  background: var(--bg-elevated);
}
.brand { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-2); margin-bottom: var(--sp-2); }
.brand .mark { width: 28px; height: 28px; border-radius: 7px; background: var(--accent);
  display: grid; place-items: center; color: white; font-family: var(--font-serif); font-size: 18px; flex: none; }
.brand .name { font-family: var(--font-serif); font-size: 19px; letter-spacing: -0.01em; }
.collapsed .brand .name, .collapsed .nav-label, .collapsed .side-foot .lbl { display: none; }

.nav { display: flex; flex-direction: column; gap: 2px; overflow-y: auto; }
.nav a {
  display: flex; align-items: center; gap: var(--sp-3); padding: 9px var(--sp-3);
  border-radius: var(--radius-sm); color: var(--text-2); font-weight: 500; font-size: 13.5px;
  transition: background var(--transition), color var(--transition); white-space: nowrap;
}
.nav a .ico { width: 18px; text-align: center; flex: none; font-size: 15px; opacity: 0.9; }
.nav a:hover { background: var(--bg-hover); color: var(--text); }
.nav a.active { background: var(--accent-soft); color: var(--accent-text); }
.nav a .kbd { margin-left: auto; font-size: 10px; color: var(--text-3); }
.collapsed .nav a .kbd { display: none; }

.side-foot { margin-top: auto; display: flex; flex-direction: column; gap: 2px; padding-top: var(--sp-2); border-top: 1px solid var(--border); }
.side-foot button { display: flex; align-items: center; gap: var(--sp-3); width: 100%; padding: 9px var(--sp-3);
  background: none; border: none; color: var(--text-2); cursor: pointer; border-radius: var(--radius-sm); font-size: 13px; }
.side-foot button:hover { background: var(--bg-hover); color: var(--text); }

/* ── Main ── */
.main { display: flex; flex-direction: column; min-width: 0; }
.topbar { position: sticky; top: 0; z-index: 5; display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-5); border-bottom: 1px solid var(--border); background: color-mix(in oklab, var(--bg) 82%, transparent);
  backdrop-filter: blur(10px); }
.topbar h1 { font-size: 15px; font-weight: 600; margin: 0; letter-spacing: -0.01em; }
.topbar .spacer { flex: 1; }
.pill { font-size: 11px; padding: 3px 9px; border-radius: 99px; border: 1px solid var(--border-strong);
  color: var(--text-2); display: inline-flex; align-items: center; gap: 6px; }
.pill.demo { color: var(--warn); border-color: color-mix(in oklab, var(--warn) 40%, transparent); }
.pill .dot { width: 6px; height: 6px; border-radius: 99px; background: currentColor; }
.cmdk-hint { font-size: 12px; color: var(--text-3); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 4px 8px; cursor: pointer; }
.cmdk-hint kbd { font-family: var(--font-mono); font-size: 11px; }

.content { padding: var(--sp-5); max-width: var(--maxw); width: 100%; margin: 0 auto; }
.page-head { margin-bottom: var(--sp-5); }
.page-head h2 { font-family: var(--font-serif); font-size: 26px; font-weight: 500; margin: 0 0 4px; letter-spacing: -0.01em; }
.page-head p { color: var(--text-3); margin: 0; font-size: 13px; }

/* ── Cards / grid ── */
.grid { display: grid; gap: var(--sp-4); }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1000px) { .cols-3, .cols-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px) {
  .shell { grid-template-columns: 1fr; }
  /* Sidebar becomes a slide-in drawer; a hamburger in the top bar toggles it. */
  .sidebar { position: fixed; top: 0; left: 0; bottom: 0; width: 270px; z-index: 60;
    transform: translateX(-100%); transition: transform 180ms cubic-bezier(0.2,0,0,1); will-change: transform; }
  .shell.nav-open .sidebar { transform: none; box-shadow: var(--shadow); }
  .cols-2, .cols-3, .cols-4 { grid-template-columns: 1fr; }
  .content { padding: var(--sp-4); }
  .topbar { padding: var(--sp-3) var(--sp-4); }
}
/* Hamburger + scrim — hidden on desktop, shown by the media query above. */
.menu-btn { display: none; background: none; border: none; color: var(--text); font-size: 20px;
  line-height: 1; cursor: pointer; padding: 4px 8px; margin-right: 2px; border-radius: var(--radius-sm); }
.menu-btn:hover { background: var(--bg-hover); }
.scrim { position: fixed; inset: 0; background: oklch(0 0 0 / 0.5); z-index: 55; opacity: 0;
  pointer-events: none; transition: opacity 180ms; }
.shell.nav-open .scrim { opacity: 1; pointer-events: auto; }
@media (max-width: 720px) { .menu-btn { display: inline-flex; } }

.card { background: var(--bg-elevated); border: 1px solid var(--border); border-radius: var(--radius);
  padding: var(--sp-4); box-shadow: var(--shadow); }
.card.pad-lg { padding: var(--sp-5); }
.card h3 { margin: 0 0 var(--sp-3); font-size: 12px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text-3); }
.stat-label { font-size: 12px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.05em; }
.stat-hero { font-family: var(--font-serif); font-size: 46px; font-weight: 500; line-height: 1.05; letter-spacing: -0.02em; margin: 6px 0; }
.stat-value { font-family: var(--font-serif); font-size: 28px; font-weight: 500; margin: 4px 0; }
.delta { font-size: 13px; font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }

/* ── Tables ── */
table.tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.tbl th { text-align: left; font-weight: 600; color: var(--text-3); font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.05em; padding: 8px 10px; border-bottom: 1px solid var(--border); position: sticky; top: 0; }
.tbl td { padding: 9px 10px; border-bottom: 1px solid var(--border); }
.tbl tr:hover td { background: var(--bg-hover); }
.tbl td.num, .tbl th.num { text-align: right; font-feature-settings: var(--tnum); font-variant-numeric: tabular-nums; }
.tbl .muted { color: var(--text-3); }

/* ── Controls ── */
button.btn, .btn { font-family: inherit; font-size: 13px; font-weight: 500; padding: 8px 14px; border-radius: var(--radius-sm);
  border: 1px solid var(--border-strong); background: var(--bg-raised); color: var(--text); cursor: pointer;
  transition: background var(--transition), border-color var(--transition); display: inline-flex; align-items: center; gap: 6px; }
button.btn:hover { background: var(--bg-hover); }
button.btn.primary, .btn.primary { background: var(--accent); border-color: var(--accent); color: white; }
button.btn.primary:hover { filter: brightness(1.08); }
button.btn.danger { color: var(--neg); border-color: color-mix(in oklab, var(--neg) 50%, transparent); }
button.btn.ghost { background: none; border-color: transparent; }
button.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-sm { padding: 4px 9px; font-size: 12px; }

input, select, textarea { font-family: inherit; font-size: 13px; padding: 8px 10px; border-radius: var(--radius-sm);
  border: 1px solid var(--border-strong); background: var(--bg); color: var(--text); width: 100%; }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--accent-soft); border-color: var(--accent); }
label.field { display: flex; flex-direction: column; gap: 5px; font-size: 12px; color: var(--text-2); }
.row { display: flex; gap: var(--sp-3); align-items: center; flex-wrap: wrap; }
input[type=range] { accent-color: var(--accent); padding: 0; }

.chip { font-size: 12px; padding: 3px 9px; border-radius: 99px; background: var(--bg-raised); border: 1px solid var(--border);
  color: var(--text-2); cursor: pointer; }
.chip.on { background: var(--accent-soft); border-color: var(--accent); color: var(--accent-text); }

.badge { font-size: 11px; padding: 2px 7px; border-radius: 6px; background: var(--bg-raised); border: 1px solid var(--border); color: var(--text-2); }
.badge.pos { color: var(--pos); border-color: color-mix(in oklab, var(--pos) 40%, transparent); background: var(--pos-soft); }
.badge.neg { color: var(--neg); border-color: color-mix(in oklab, var(--neg) 40%, transparent); background: var(--neg-soft); }
.badge.warn { color: var(--warn); }

.progress { height: 7px; border-radius: 99px; background: var(--bg-raised); overflow: hidden; }
.progress > span { display: block; height: 100%; background: var(--accent); border-radius: 99px; }
.progress.over > span { background: var(--neg); }

/* ── Insight cards ── */
.insight { display: flex; gap: var(--sp-3); padding: var(--sp-3) var(--sp-4); border: 1px solid var(--border);
  border-radius: var(--radius); background: var(--bg-elevated); }
.insight .accent-bar { width: 3px; border-radius: 99px; background: var(--accent); flex: none; }
.insight.negative .accent-bar { background: var(--neg); }
.insight.positive .accent-bar { background: var(--pos); }
.insight b { font-weight: 600; font-size: 13.5px; }
.insight small { color: var(--text-3); }

/* ── chart wrappers ── */
.chart-wrap { position: relative; width: 100%; }
.chart-wrap.h-sm { height: 200px; } .chart-wrap.h-md { height: 280px; } .chart-wrap.h-lg { height: 420px; }

/* ── skeleton / empty / error ── */
.skel { background: linear-gradient(90deg, var(--bg-raised) 25%, var(--bg-hover) 50%, var(--bg-raised) 75%);
  background-size: 200% 100%; animation: shimmer 1.3s infinite; border-radius: var(--radius-sm); }
@keyframes shimmer { to { background-position: -200% 0; } }
.empty, .errbox { text-align: center; padding: var(--sp-7); color: var(--text-3); }
.errbox { color: var(--neg); }

/* ── login ── */
.login { min-height: 100vh; display: grid; place-items: center; padding: var(--sp-4); }
.login .box { width: 360px; max-width: 100%; background: var(--bg-elevated); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: var(--sp-6); box-shadow: var(--shadow); }
.login .mark { width: 44px; height: 44px; border-radius: 11px; background: var(--accent); color: white;
  display: grid; place-items: center; font-family: var(--font-serif); font-size: 26px; margin: 0 auto var(--sp-4); }
.login h1 { font-family: var(--font-serif); font-weight: 500; text-align: center; margin: 0 0 var(--sp-1); font-size: 24px; }
.login p { text-align: center; color: var(--text-3); margin: 0 0 var(--sp-5); font-size: 13px; }
.login form { display: flex; flex-direction: column; gap: var(--sp-3); }
.login .err { color: var(--neg); font-size: 12.5px; text-align: center; min-height: 16px; }

/* ── toasts ── */
#toasts { position: fixed; bottom: var(--sp-5); right: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-2); z-index: 100; }
.toast { background: var(--bg-raised); border: 1px solid var(--border-strong); border-radius: var(--radius);
  padding: 10px 14px; font-size: 13px; box-shadow: var(--shadow); min-width: 220px; animation: slidein 160ms ease-out; }
.toast.success { border-left: 3px solid var(--pos); } .toast.error { border-left: 3px solid var(--neg); }
.toast.info { border-left: 3px solid var(--accent); }
@keyframes slidein { from { transform: translateY(8px); opacity: 0; } }

/* ── modal / command palette ── */
.overlay { position: fixed; inset: 0; background: oklch(0 0 0 / 0.5); display: grid; place-items: start center;
  padding-top: 12vh; z-index: 80; animation: fade 120ms ease-out; }
@keyframes fade { from { opacity: 0; } }
.modal { background: var(--bg-elevated); border: 1px solid var(--border-strong); border-radius: var(--radius-lg);
  width: 520px; max-width: 94vw; box-shadow: var(--shadow); overflow: hidden; }
.modal .m-head { padding: var(--sp-4) var(--sp-5); border-bottom: 1px solid var(--border); font-weight: 600; }
.modal .m-body { padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-3); max-height: 70vh; overflow: auto; }
.modal .m-foot { padding: var(--sp-3) var(--sp-5); border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: var(--sp-2); }

.cmdk input { font-size: 15px; padding: var(--sp-4) var(--sp-5); border: none; border-bottom: 1px solid var(--border); border-radius: 0; background: none; }
.cmdk .list { max-height: 56vh; overflow: auto; padding: var(--sp-2); }
.cmdk .item { display: flex; align-items: center; gap: var(--sp-3); padding: 10px 12px; border-radius: var(--radius-sm); cursor: pointer; font-size: 13.5px; }
.cmdk .item .ico { width: 18px; text-align: center; }
.cmdk .item.sel { background: var(--accent-soft); color: var(--accent-text); }
.cmdk .item small { margin-left: auto; color: var(--text-3); font-size: 11px; }

.kbd { font-family: var(--font-mono); font-size: 11px; background: var(--bg-raised); border: 1px solid var(--border);
  border-radius: 4px; padding: 1px 5px; }

.cat-link { cursor: pointer; text-decoration: none; border-radius: var(--radius-sm); transition: color var(--transition); }
.cat-link:hover { color: var(--accent-text) !important; }
.flex { display: flex; } .between { justify-content: space-between; } .items-center { align-items: center; }
.gap-2 { gap: var(--sp-2); } .gap-3 { gap: var(--sp-3); } .gap-4 { gap: var(--sp-4); }
.mt-3 { margin-top: var(--sp-3); } .mt-4 { margin-top: var(--sp-4); } .mt-5 { margin-top: var(--sp-5); }
.mb-3 { margin-bottom: var(--sp-3); } .wrap { flex-wrap: wrap; } .grow { flex: 1; }
.text-2 { color: var(--text-2); } .text-3 { color: var(--text-3); } .tr { text-align: right; }
.small { font-size: 12px; } .nowrap { white-space: nowrap; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 99px; border: 2px solid var(--bg); }

/* ── Print (Reports → ⎙ Print) — strip chrome, keep the report ── */
@media print {
  .sidebar, .topbar, .scrim, .menu-btn, .page-head .row, .btn, button { display: none !important; }
  .shell { display: block; }
  .main { display: block; }
  .content { max-width: 100%; padding: 0; margin: 0; }
  .card { box-shadow: none; border: 1px solid #ddd; break-inside: avoid; }
  body, .card { background: #fff !important; color: #111 !important; }
  .page-head h2, .stat-value, .stat-hero { color: #111 !important; }
  a { color: #111 !important; }
}
