:root{--bg: #f7f7f8;--surface: #ffffff;--ink: #0f172a;--muted: #64748b;--rule: #e2e8f0;--accent: #0f766e;--accent-2: #115e59;--neg: #b91c1c;--ok: #047857;--badge-bg: #f1f5f9;--shadow: 0 1px 2px rgba(15,23,42,.04), 0 4px 12px rgba(15,23,42,.05)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--ink);font-feature-settings:"tnum" 1,"lnum" 1}.shell{display:flex;flex-direction:column;min-height:100vh}.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 28px;background:#fff;border-bottom:1px solid var(--rule)}.brand{display:flex;align-items:center;gap:8px;font-size:15px}.brand .logo{color:var(--accent);font-weight:800}.brand .sep{color:var(--muted)}.topbar nav{display:flex;gap:18px}.topbar nav a{color:var(--ink);text-decoration:none;font-size:14px}.topbar nav a:hover{color:var(--accent)}main{flex:1;padding:24px 28px}footer{padding:18px 28px;color:var(--muted);border-top:1px solid var(--rule);background:#fff}h1{margin:0 0 4px;font-size:22px}h3{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.meta{color:var(--muted);font-size:13px}.currency-pill{background:var(--badge-bg);border-radius:999px;padding:2px 8px;font-size:11px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.date-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding:12px 16px;margin-bottom:18px;background:var(--surface);border:1px solid var(--rule);border-radius:12px;box-shadow:var(--shadow)}.date-pickers{display:flex;gap:14px;align-items:center}.date-pickers label{display:flex;gap:6px;align-items:center;font-size:13px;color:var(--muted)}.date-pickers input[type=month]{padding:6px 10px;border:1px solid var(--rule);border-radius:8px;font-size:13px;font-family:inherit;color:var(--ink)}.quick-jumps{display:flex;gap:8px;flex-wrap:wrap}.quick-jumps .btn{padding:6px 10px;font-size:12px}.quick-jumps .btn:hover{color:var(--accent);border-color:var(--accent)}.btn{display:inline-block;padding:8px 14px;border-radius:8px;border:1px solid var(--rule);background:#fff;cursor:pointer;font-size:14px}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover{background:var(--accent-2)}.btn.primary:disabled{background:var(--muted);cursor:wait}.btn.ghost{color:var(--muted)}.card{background:var(--surface);border:1px solid var(--rule);border-radius:12px;padding:20px;box-shadow:var(--shadow);margin-bottom:18px}.card.error{border-color:var(--neg);color:var(--neg)}.connect-cta{text-align:center;padding:60px 20px}.connect-cta a{display:inline-block;margin-top:14px}.kpi-section{margin-bottom:26px}.table-scroll{overflow-x:auto;background:var(--surface);border:1px solid var(--rule);border-radius:12px;box-shadow:var(--shadow)}.kpi-table{border-collapse:collapse;width:100%;font-size:13px}.kpi-table th,.kpi-table td{padding:8px 12px;text-align:right;white-space:nowrap}.kpi-table th{background:#f8fafc;color:var(--muted);font-weight:600;border-bottom:1px solid var(--rule);position:sticky;top:0}.kpi-table tr+tr td{border-top:1px solid var(--rule)}.kpi-table tbody tr:hover td{background:#fafafa}.kpi-table .sticky-col{position:sticky;left:0;text-align:left;background:var(--surface);z-index:1;border-right:1px solid var(--rule);min-width:280px}.kpi-table th.sticky-col{background:#f8fafc}.kpi-table .label{font-weight:500}.kpi-table .neg{color:var(--neg)}.kpi-table .muted{color:var(--muted)}.kpi-table .avg{font-weight:600;background:#f8fafc}.kpi-table .remark{text-align:left;font-size:12px;color:var(--muted);white-space:normal;max-width:280px}.kpi-table td.ok{color:var(--ok)}.small{font-size:12px}.badge{font-size:10px;margin-left:8px;padding:1px 6px;border-radius:999px;vertical-align:middle}.badge.derived{background:#eef2ff;color:#4338ca}.badge.manual{background:#fef3c7;color:#92400e}.manual-form{display:flex;gap:8px;margin:12px 0 18px;flex-wrap:wrap}.manual-form input,select{padding:7px 10px;border:1px solid var(--rule);border-radius:8px;font-size:13px}
