/* Bonjo reports — light & clean theme */
:root{
  --bg:#f5f6f8;
  --panel:#ffffff;
  --panel-2:#fbfbfd;
  --ink:#161b22;
  --ink-soft:#3c4654;
  --muted:#8a93a0;
  --line:#e9ebf0;
  --line-2:#f0f2f5;
  --accent:#3b6ef0;
  --accent-soft:#eaf0fe;
  --green:#11a36b;
  --green-soft:#e7f6ef;
  --red:#e0533d;
  --red-soft:#fcebe7;
  --amber:#c9870b;
  --shadow:0 1px 2px rgba(16,24,40,.04), 0 6px 24px rgba(16,24,40,.05);
  --shadow-lg:0 8px 40px rgba(16,24,40,.10);
  --radius:16px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:"Inter",system-ui,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--ink);
  display:flex;min-height:100vh;-webkit-font-smoothing:antialiased;
  font-size:14px;line-height:1.5;
}

/* ---------- sidebar ---------- */
.sidebar{
  width:248px;flex-shrink:0;background:var(--panel);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:22px 16px;gap:6px;
  position:sticky;top:0;height:100vh;
}
.brand{display:flex;align-items:center;gap:12px;padding:4px 8px 20px}
.logo{
  width:40px;height:40px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,#3b6ef0,#6f8ff6);color:#fff;font-weight:700;font-size:20px;
  box-shadow:0 4px 12px rgba(59,110,240,.35);
}
.brand-name{font-weight:700;font-size:16px;letter-spacing:-.01em}
.brand-sub{font-size:12px;color:var(--muted)}
#nav{display:flex;flex-direction:column;gap:2px;flex:1}
.nav-item{
  display:flex;align-items:center;gap:11px;width:100%;text-align:left;
  background:none;border:none;cursor:pointer;color:var(--ink-soft);
  padding:10px 12px;border-radius:10px;font:inherit;font-weight:500;font-size:13.5px;
  transition:background .12s,color .12s;
}
.nav-item .ico{width:18px;text-align:center;color:var(--muted);font-size:14px}
.nav-item:hover{background:var(--line-2);color:var(--ink)}
.nav-item.active{background:var(--accent-soft);color:var(--accent)}
.nav-item.active .ico{color:var(--accent)}
.ask-nav{margin-top:8px;color:var(--accent);font-weight:600}
.ask-nav .ico{color:var(--accent)}
.updated{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);padding:12px 10px 2px;border-top:1px solid var(--line);margin-top:6px}
.dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px var(--green-soft)}

/* ---------- main ---------- */
.main{flex:1;min-width:0;display:flex;flex-direction:column;padding:26px 34px 40px;max-width:1320px}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.topbar h1{margin:0;font-size:24px;font-weight:700;letter-spacing:-.02em}
.period{color:var(--muted);font-size:13px;margin-top:3px}
.topbar-right{display:flex;align-items:center;gap:10px}
#range-label{color:var(--ink-soft);font-size:13px;font-weight:600;background:var(--panel);border:1px solid var(--line);padding:7px 13px;border-radius:10px;box-shadow:var(--shadow);white-space:nowrap}
#range-label:empty{display:none}
.refresh-btn{
  font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;
  color:#fff;background:var(--accent);border:1px solid var(--accent);
  padding:8px 14px;border-radius:10px;box-shadow:var(--shadow);
  transition:filter .12s ease,opacity .12s ease;
}
.refresh-btn:hover:not(:disabled){filter:brightness(1.07)}
.refresh-btn:disabled{opacity:.65;cursor:default}

/* ---------- controls bar ---------- */
.controls-bar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:22px}
.controls-bar:empty{display:none}
.ctrl-group{
  display:flex;align-items:center;gap:6px;background:var(--panel);
  border:1px solid var(--line);border-radius:12px;padding:6px;box-shadow:var(--shadow);
}
.ctrl-label{font-size:12px;color:var(--muted);font-weight:600;padding:0 6px}
.month-strip{display:flex;gap:3px;flex-wrap:wrap}
.month-chip{
  border:none;background:transparent;color:var(--ink-soft);cursor:pointer;
  padding:7px 13px;border-radius:8px;font:inherit;font-size:13px;font-weight:500;
  transition:background .12s,color .12s;white-space:nowrap;
}
.month-chip:hover{background:var(--line-2)}
.month-chip.in-range{background:var(--accent-soft);color:var(--accent);font-weight:600}
.month-chip.edge{background:var(--accent);color:#fff;font-weight:600}
.preset-btn{
  border:1px solid var(--line);background:var(--panel-2);color:var(--ink-soft);cursor:pointer;
  padding:8px 13px;border-radius:10px;font:inherit;font-size:12.5px;font-weight:600;
  box-shadow:var(--shadow);transition:background .12s,border-color .12s;
}
.preset-btn:hover{border-color:var(--accent);color:var(--accent)}
.ctrl-hint{font-size:12px;color:var(--muted)}
.seg{display:flex;gap:3px;background:var(--line-2);border-radius:9px;padding:3px}
.seg-btn{border:none;background:transparent;color:var(--ink-soft);cursor:pointer;padding:7px 13px;border-radius:7px;font:inherit;font-size:12.5px;font-weight:600;white-space:nowrap;transition:background .12s,color .12s}
.seg-btn:hover{color:var(--ink)}
.seg-btn.active{background:var(--panel);color:var(--accent);box-shadow:var(--shadow)}

/* product picker */
.picker{position:relative}
.picker-btn{
  display:flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--panel);
  color:var(--ink-soft);cursor:pointer;padding:9px 14px;border-radius:11px;font:inherit;
  font-size:13px;font-weight:600;box-shadow:var(--shadow);
}
.picker-btn:hover{border-color:var(--accent)}
.picker-btn .caret{color:var(--muted);font-size:11px}
.picker-panel{
  position:absolute;top:calc(100% + 6px);left:0;z-index:30;width:300px;max-height:340px;overflow:auto;
  background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:8px;
}
.picker-panel.hidden{display:none}
.picker-search{width:100%;border:1px solid var(--line);border-radius:8px;padding:8px 10px;font:inherit;font-size:13px;margin-bottom:6px;outline:none}
.picker-search:focus{border-color:var(--accent)}
.picker-opt{display:flex;align-items:center;gap:9px;padding:8px 9px;border-radius:8px;cursor:pointer;font-size:13px}
.picker-opt:hover{background:var(--line-2)}
.picker-opt input{accent-color:var(--accent);width:15px;height:15px}
.picker-clear{width:100%;text-align:center;padding:8px;border:none;background:none;color:var(--accent);font:inherit;font-weight:600;cursor:pointer;border-top:1px solid var(--line);margin-top:4px}

/* ---------- KPIs ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:22px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.kpi .label{font-size:12.5px;color:var(--muted);font-weight:600;margin-bottom:8px}
.kpi .value{font-size:24px;font-weight:700;letter-spacing:-.02em;line-height:1.1}
.kpi .value.green{color:var(--green)}
.kpi .value.red{color:var(--red)}
.kpi .sub{font-size:12px;color:var(--muted);margin-top:7px;display:flex;align-items:center;gap:6px}

/* ---------- panels & grids ---------- */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.grid.one{grid-template-columns:1fr}
.grid.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:980px){.grid,.grid.three{grid-template-columns:1fr}}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);min-width:0}
.panel h3{margin:0 0 2px;font-size:15px;font-weight:700;letter-spacing:-.01em}
.panel .hint{margin:0 0 14px;font-size:12.5px;color:var(--muted)}
.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.panel-head .hint{margin-bottom:14px}
.chart-tools{display:flex;gap:3px;flex-shrink:0;background:var(--line-2);border-radius:9px;padding:3px}
.ctype{border:none;background:transparent;color:var(--muted);cursor:pointer;width:30px;height:28px;border-radius:7px;font-size:14px;line-height:1;display:grid;place-items:center;transition:background .12s,color .12s}
.ctype:hover{color:var(--ink)}
.ctype.active{background:var(--panel);color:var(--accent);box-shadow:var(--shadow)}
.chart-wrap{position:relative;height:260px}
.chart-wrap.tall{height:320px}

/* ---------- narrative & notes ---------- */
.narrative{
  background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:14px;padding:18px 20px;margin-bottom:22px;box-shadow:var(--shadow);
  font-size:15px;line-height:1.6;color:var(--ink-soft);
}
.narrative b{color:var(--ink)}
.note{background:var(--accent-soft);border:1px solid #d6e2fd;border-radius:12px;padding:13px 16px;font-size:13px;color:var(--ink-soft);margin-top:18px}
.pos{color:var(--green)} .neg{color:var(--red)}
.green{color:var(--green)} .red{color:var(--red)}

/* ---------- tables ---------- */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line-2)}
th{font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600}
tbody tr:last-child td{border-bottom:none}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tbody tr:hover{background:var(--panel-2)}
th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
th.sortable:hover{color:var(--accent)}
th.sortable .sort-ind{display:inline-block;width:0;margin-left:4px;opacity:.5;font-size:10px}
th.sortable[data-dir] .sort-ind{width:auto}
th.sortable[data-dir="asc"] .sort-ind::after{content:"▲"}
th.sortable[data-dir="desc"] .sort-ind::after{content:"▼"}
th.sortable[data-dir]{color:var(--accent)}
.empty{color:var(--muted);font-size:13px;padding:24px;text-align:center}

/* financial statement */
.statement td{padding:8px 6px;border-bottom:1px solid var(--line-2)}
.statement tr.section td{font-weight:700;color:var(--ink);padding-top:16px;font-size:12px;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--line)}
.statement tr.line td{color:var(--ink-soft)}
.statement tr.subtotal td{font-weight:700;border-top:1px solid var(--line);border-bottom:none}
.statement tr.grand td{font-weight:700;font-size:15px;border-top:2px solid var(--ink);border-bottom:none;padding-top:12px}
.statement td.amt{text-align:right;font-variant-numeric:tabular-nums}
.statement td.amt.pos{color:var(--green)} .statement td.amt.neg{color:var(--red)} .statement td.amt.muted{color:var(--muted)}

/* clickable drill rows */
.drill-row{cursor:pointer}
.drill-row .chev{display:inline-block;width:14px;color:var(--muted);transition:transform .15s}
.drill-row.open .chev{transform:rotate(90deg)}
.drill-detail td{background:var(--panel-2);padding:0}
.drill-detail .inner{padding:6px 14px 12px}
.drill-detail.hidden{display:none}

/* deltas */
.delta{font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:3px}
.delta.up{color:var(--green)} .delta.down{color:var(--red)}

/* ---------- Ask assistant ---------- */
.ask-wrap{display:flex;flex-direction:column;gap:18px;max-width:880px}
.ask-intro{font-size:14px;color:var(--ink-soft)}
.ask-suggest{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.ask-chip{border:1px solid var(--line);background:var(--panel);color:var(--ink-soft);cursor:pointer;padding:8px 14px;border-radius:20px;font:inherit;font-size:13px;box-shadow:var(--shadow)}
.ask-chip:hover{border-color:var(--accent);color:var(--accent)}
.ask-form{display:flex;gap:10px;position:sticky;bottom:0}
.ask-input{flex:1;border:1px solid var(--line);border-radius:12px;padding:14px 16px;font:inherit;font-size:14.5px;outline:none;box-shadow:var(--shadow);background:var(--panel)}
.ask-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.ask-send{border:none;background:var(--accent);color:#fff;border-radius:12px;padding:0 22px;font:inherit;font-weight:600;cursor:pointer;font-size:14px}
.ask-send:hover{background:#2f5fda}
.ask-log{display:flex;flex-direction:column;gap:14px}
.ask-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow)}
.ask-card .q{font-weight:600;color:var(--accent);margin-bottom:10px;font-size:14px}
.ask-card .a{font-size:14.5px;line-height:1.6;color:var(--ink-soft)}
.ask-card .a b{color:var(--ink)}
.ask-card .chart-wrap{margin-top:14px;height:240px}
.ask-mini{font-size:12px;color:var(--muted);margin-top:10px}

/* ---------- misc ---------- */
.loading{padding:60px;text-align:center;color:var(--muted)}
.error{background:var(--red-soft);border:1px solid #f3c9c0;border-radius:14px;padding:20px;color:#9b2f1c;font-size:14px;line-height:1.6}
.error code{background:#fff;padding:1px 6px;border-radius:5px;font-size:13px}
.foot{margin-top:auto;padding-top:28px;color:var(--muted);font-size:12px}
code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
