/* Finland — design system. OpenAI-minimal: monochrome, hairlines, air, Geist. */
@import url('https://fonts.googleapis.com/css2?family=Geist:wght@400;450;500;600&family=Geist+Mono:wght@400;500&display=swap');

:root{
  --ink:#0c0c0d; --ink-2:#5b5b5e; --ink-3:#8d8d92; --ink-4:#b6b6ba;
  --bg:#faf9f7; --paper:#ffffff; --paper-2:#f6f5f2;
  --line:#ececea; --line-2:#e2e1de; --line-3:#d6d5d1;
  --pos:#2f6b4f; --pos-bg:#eef3ef; --neg:#9c4a2e; --neg-bg:#f6efea;
  --neu:#3a5a80; --neu-bg:#eef1f5; --mut:#6f6f73; --mut-bg:#f0efec;
  --slack:#4a154b;
  --r:10px; --r-lg:14px; --r-xl:20px; --page-max:1120px;
  /* Top bar width is CONSTANT across pages (pages only override --page-max for
     their content). Keeps the nav/brand/logout from reflowing between pages. */
  --chrome-max:1120px;
  --sans:'Geist',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'Geist Mono',ui-monospace,Menlo,monospace;
  --shadow:0 1px 2px rgba(12,12,13,.04), 0 8px 24px -16px rgba(12,12,13,.18);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-size:14px;line-height:1.55;font-weight:400;letter-spacing:-0.006em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit}
h1,h2,h3{margin:0;font-weight:500;letter-spacing:-0.022em;line-height:1.15}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* layout */
.wrap{max-width:var(--page-max);margin:0 auto;padding:0 28px}
.page{padding:28px 0 64px}
.muted{color:var(--ink-2)}.dim{color:var(--ink-3)}
.off{opacity:.45}

/* page header (eyebrow / title / sub) */
.page-head{margin-bottom:20px}
.page-head.split{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.page-title{font-size:25px;font-weight:500;letter-spacing:-0.022em;line-height:1.15;margin-top:8px}

/* top bar */
.topbar{position:sticky;top:0;z-index:20;background:rgba(250,249,247,.82);
  backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line)}
.topbar-in{max-width:var(--chrome-max);margin:0 auto;padding:0 28px;height:58px;display:flex;align-items:center;gap:20px}
.brand{display:flex;align-items:center;gap:9px;font-weight:500;letter-spacing:-0.02em;font-size:15px}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--ink);position:relative}
.brand .dot::after{content:"";position:absolute;inset:-4px;border:1px solid var(--line-3);border-radius:50%}
.nav{display:flex;align-items:center;gap:2px}
.nav a{padding:7px 12px;border-radius:8px;color:var(--ink-2);text-decoration:none;font-size:13.5px;
  font-weight:450;transition:color .15s,background .15s;white-space:nowrap}
.nav a:hover{color:var(--ink);background:var(--paper-2)}
.nav a.on{color:var(--ink);background:var(--paper);box-shadow:inset 0 0 0 1px var(--line-2)}
.spacer{flex:1}
.who{font-size:13px;color:var(--ink-3);display:flex;align-items:center;gap:8px}
.avatar{width:26px;height:26px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;
  font-size:11px;font-weight:500;letter-spacing:0}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:7px;font:inherit;font-size:13.5px;font-weight:450;
  padding:8px 14px;border-radius:8px;border:1px solid var(--line-2);background:var(--paper);color:var(--ink);
  cursor:pointer;text-decoration:none;transition:background .15s,border-color .15s,transform .06s}
.btn:hover{background:var(--paper-2);border-color:var(--line-3)}
.btn:active{transform:scale(.985)}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-primary:hover{background:#26262a;border-color:#26262a}
.btn-sm{padding:5px 10px;font-size:12.5px;border-radius:7px}
.btn-pos{background:var(--pos);border-color:var(--pos);color:#fff}.btn-pos:hover{filter:brightness(1.08)}
.btn-neg{background:var(--neg);border-color:var(--neg);color:#fff}.btn-neg:hover{filter:brightness(1.08)}

/* segmented toggle */
.seg{display:inline-flex;background:var(--paper-2);border:1px solid var(--line-2);border-radius:9px;padding:2px}
.seg button{border:0;background:transparent;font:inherit;font-size:13px;font-weight:450;color:var(--ink-2);
  padding:5px 12px;border-radius:7px;cursor:pointer;transition:all .15s}
.seg button.on{background:var(--paper);color:var(--ink);box-shadow:var(--shadow)}

/* cards / panels */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg)}
.panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px}
.panel-h{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}
.panel-h h3{font-size:13px;font-weight:500;color:var(--ink-2);letter-spacing:-0.01em}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:22px}
.kpi{background:var(--paper);padding:16px 18px}
.kpi .l{font-size:12px;color:var(--ink-3);font-weight:450;display:flex;align-items:center;gap:6px}
.kpi .v{font-family:var(--mono);font-size:23px;font-weight:500;margin-top:6px;letter-spacing:-0.02em}
.kpi .s{font-size:11.5px;color:var(--ink-4);margin-top:2px}
.tick{width:7px;height:7px;border-radius:2px;display:inline-block}

/* charts */
.cw{position:relative;width:100%}
.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--ink-2);margin-bottom:4px}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legend i{width:9px;height:9px;border-radius:2px}

/* tables */
.tablewrap{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.thead{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--line)}
.thead .t{font-size:13px;font-weight:500}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;padding:10px 18px;color:var(--ink-3);font-weight:450;font-size:11.5px;
  letter-spacing:0.02em;text-transform:uppercase;border-bottom:1px solid var(--line);background:var(--paper)}
tbody td{padding:11px 18px;border-bottom:1px solid var(--line);color:var(--ink);vertical-align:top}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover td{background:var(--paper-2)}
td.r,th.r{text-align:right}
td.num,.amt{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-0.01em}

/* badges */
.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:20px;font-size:11.5px;
  font-weight:450;letter-spacing:.01em;border:1px solid transparent}
.b-income{background:var(--pos-bg);color:var(--pos)}.b-expense{background:var(--neg-bg);color:var(--neg)}
.b-transfer{background:var(--neu-bg);color:var(--neu)}.b-other{background:var(--mut-bg);color:var(--mut)}
.b-PENDING{background:#f5efe2;color:#866118}.b-APPROVE{background:var(--pos-bg);color:var(--pos)}
.b-DENY{background:var(--neg-bg);color:var(--neg)}
.b-PAID{background:var(--neu-bg);color:var(--neu)}

/* forms */
.field{margin-bottom:15px}
label{display:block;font-size:12.5px;color:var(--ink-2);margin-bottom:6px;font-weight:450}
label .req{color:var(--neg)}
input,select,textarea{width:100%;font:inherit;font-size:14px;color:var(--ink);background:var(--paper);
  border:1px solid var(--line-2);border-radius:9px;padding:9px 11px;transition:border-color .15s,box-shadow .15s}
input:hover,select:hover,textarea:hover{border-color:var(--line-3)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--ink-3);box-shadow:0 0 0 3px rgba(12,12,13,.06)}
select[multiple]{height:auto;min-height:120px}
textarea{resize:vertical;min-height:64px}
.hint{font-size:11.5px;color:var(--ink-3);margin-top:5px}
.sens{background:#fdfbf6;border-color:#e7dcc6}

/* misc */
.notice{padding:10px 13px;border-radius:10px;font-size:13px;margin-bottom:14px;display:none}
.notice.ok{background:var(--pos-bg);color:var(--pos)}.notice.err{background:var(--neg-bg);color:var(--neg)}
.sub{color:var(--ink-2);font-size:13.5px;margin:2px 0 0}
.eyebrow{font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);font-weight:500}
.foot{color:var(--ink-3);font-size:12px;margin-top:16px}
hr{border:0;border-top:1px solid var(--line);margin:0}

/* entrance motion */
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.rise{animation:rise .5s cubic-bezier(.22,.61,.36,1) both}
.d1{animation-delay:.04s}.d2{animation-delay:.09s}.d3{animation-delay:.14s}.d4{animation-delay:.19s}.d5{animation-delay:.24s}
@media (prefers-reduced-motion:reduce){.rise{animation:none}}

/* mobile */
@media (max-width:640px){
  .wrap{padding:0 16px}
  .topbar-in{flex-wrap:wrap;height:auto;padding:9px 16px;gap:8px 10px}
  .spacer{display:none}
  .who span:last-child{display:none}
  .nav a{padding:9px 11px}
  .btn-sm{padding:8px 11px}
  .kpis{grid-template-columns:repeat(auto-fit,minmax(128px,1fr))}
}
