/* ============================================================
   Tallybook — precision ledger fintech
   Ink navy + warm parchment, amber money accent, teal confirm
   ============================================================ */
:root{
  --ink:#10202b;            /* deep ink navy */
  --ink-2:#1b3140;
  --paper:#f4ede0;          /* warm parchment */
  --paper-2:#ece2d2;
  --card:#fbf7ef;
  --line:#d9cdba;
  --line-strong:#c3b39a;
  --muted:#5f6b6e;
  --amber:#e0902b;          /* money / gold */
  --amber-deep:#b86f12;
  --teal:#127f73;           /* confirm */
  --teal-soft:#dcefe9;
  --red:#bb4231;
  --red-soft:#f6dcd6;
  --warn:#b8862a;
  --warn-soft:#f5e7c8;
  --ok-soft:#d4ece6;
  --shadow:0 1px 0 #fff inset, 0 14px 34px -22px rgba(16,32,43,.55);
  --r:14px;
  --display:'Bricolage Grotesque',serif;
  --sans:'IBM Plex Sans',system-ui,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:
    radial-gradient(1200px 600px at 80% -10%, #fff7ea 0%, transparent 60%),
    radial-gradient(900px 500px at -10% 10%, #f0e7d6 0%, transparent 55%),
    var(--paper);
  line-height:1.55;-webkit-font-smoothing:antialiased;
}
.mono{font-family:var(--mono);font-feature-settings:"tnum" 1;letter-spacing:-.01em}

/* grain overlay */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

a{color:inherit}
.backlink{
  position:fixed;left:16px;bottom:16px;z-index:60;
  font-family:var(--mono);font-size:12px;text-decoration:none;
  background:var(--ink);color:var(--paper);padding:7px 12px;border-radius:999px;
  box-shadow:0 10px 24px -12px rgba(16,32,43,.7);transition:transform .18s,background .18s;
}
.backlink:hover{transform:translateY(-2px);background:var(--ink-2)}

/* ---------- top bar ---------- */
.topbar{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:22px;
  padding:14px clamp(16px,4vw,46px);
  background:rgba(244,237,224,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;font-weight:800;font-family:var(--display)}
.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;background:var(--ink);color:var(--amber)}
.brand-name{font-size:19px;letter-spacing:-.02em}
.mainnav{display:flex;gap:6px;margin-left:8px}
.mainnav a{
  text-decoration:none;font-weight:600;font-size:14.5px;color:var(--muted);
  padding:8px 14px;border-radius:999px;display:flex;align-items:center;gap:7px;transition:.18s;
}
.mainnav a:hover{color:var(--ink);background:var(--paper-2)}
.mainnav a.is-active{color:var(--ink);background:var(--card);box-shadow:inset 0 0 0 1px var(--line)}
.nav-badge{font-family:var(--mono);font-size:11px;background:var(--amber);color:#fff;border-radius:999px;padding:1px 7px;line-height:1.5}
.nav-cta{margin-left:auto}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--sans);font-weight:600;font-size:14.5px;cursor:pointer;border:none;
  padding:12px 20px;border-radius:11px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  transition:transform .16s ease, box-shadow .16s, background .16s;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ink);color:var(--paper);box-shadow:0 12px 26px -14px rgba(16,32,43,.85)}
.btn-primary:hover{background:var(--ink-2);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line-strong)}
.btn-ghost:hover{background:var(--card)}
.btn-pill{padding:9px 16px;border-radius:999px;font-size:13.5px;background:var(--ink);color:var(--paper)}
.btn-pill:hover{background:var(--amber-deep)}

/* ---------- panels ---------- */
.panel{max-width:1180px;margin:0 auto;padding:clamp(26px,5vw,64px) clamp(16px,4vw,46px) 90px}
.panel[hidden]{display:none}

/* ---------- HERO ---------- */
.hero{position:relative;display:grid;grid-template-columns:1.5fr .9fr;gap:46px;align-items:center;
  padding:clamp(28px,5vw,64px) 0 56px}
.hero-grid{position:absolute;inset:-40px -40px auto -40px;height:340px;z-index:0;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:34px 34px;mask:radial-gradient(420px 280px at 30% 30%,#000,transparent 75%)}
.hero-inner{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12.5px;
  color:var(--amber-deep);background:var(--warn-soft);padding:6px 13px;border-radius:999px;margin-bottom:22px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 4px rgba(224,144,43,.2)}
.hero-title{font-family:var(--display);font-weight:800;font-size:clamp(44px,7.4vw,84px);line-height:.96;
  letter-spacing:-.03em;margin:0 0 22px}
.ink-accent{position:relative;color:var(--amber-deep)}
.ink-accent::after{content:"";position:absolute;left:0;right:0;bottom:.07em;height:.12em;background:var(--amber);opacity:.32;border-radius:2px}
.hero-lede{font-size:clamp(16px,1.7vw,19px);color:var(--ink-2);max-width:52ch;margin:0 0 30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:42px}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:24px}
.stat-num{font-family:var(--mono);font-size:30px;font-weight:600;display:block;letter-spacing:-.02em}
.stat-label{font-size:13px;color:var(--muted)}

.hero-card{position:relative;z-index:1;background:var(--ink);color:var(--paper);border-radius:18px;
  padding:24px;box-shadow:0 30px 60px -30px rgba(16,32,43,.8);transform:rotate(1.3deg);
  border:1px solid #24414f}
.hc-head{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#a9bcc4;margin-bottom:14px;font-family:var(--mono)}
.hc-pill{font-size:11px;padding:3px 9px;border-radius:999px;font-weight:600}
.hc-pill.ok{background:rgba(18,127,115,.25);color:#7fe6d4}
.hc-bar{height:8px;border-radius:999px;background:#24414f;overflow:hidden;margin-bottom:18px}
.hc-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--amber),#f3b65b);border-radius:999px}
.hc-row{display:flex;justify-content:space-between;font-size:14px;padding:5px 0;border-bottom:1px dashed #2c4b59}
.hc-row.muted{color:#9fb3bb;border:none}
.hc-row b{font-size:14px}
.hc-spark{color:var(--amber);margin-top:14px;height:42px}
.hc-spark svg{width:100%;height:100%}

/* ---------- features ---------- */
.section-tag{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--amber-deep);margin-bottom:8px}
.features{padding-top:24px}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:18px}
.feat{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow);transition:transform .2s,border-color .2s}
.feat:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.feat-ix{font-family:var(--mono);font-size:13px;color:var(--amber);margin-bottom:16px}
.feat h3{font-family:var(--display);font-size:19px;margin:0 0 8px;letter-spacing:-.01em}
.feat p{font-size:14px;color:var(--muted);margin:0}

.cta-band{margin-top:48px;background:var(--ink);color:var(--paper);border-radius:20px;padding:clamp(32px,5vw,56px);text-align:center;
  background-image:radial-gradient(500px 200px at 50% 0%,rgba(224,144,43,.22),transparent 70%)}
.cta-band h2{font-family:var(--display);font-size:clamp(26px,4vw,40px);margin:0 0 10px;letter-spacing:-.02em}
.cta-band p{color:#a9bcc4;margin:0 0 24px}

/* ---------- page heads ---------- */
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:30px;
  border-bottom:1px solid var(--line);padding-bottom:22px}
.page-title{font-family:var(--display);font-size:clamp(30px,4.4vw,48px);margin:6px 0 0;letter-spacing:-.025em}
.page-sub{color:var(--muted);max-width:46ch;margin:0;font-size:15px}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}

/* ---------- submit ---------- */
.submit-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}
.form{padding:24px;display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field-full{grid-column:1/-1}
.field label{font-size:13px;font-weight:600;color:var(--ink-2)}
input,select,textarea{
  font-family:var(--sans);font-size:15px;color:var(--ink);background:#fff;
  border:1.5px solid var(--line-strong);border-radius:10px;padding:11px 13px;width:100%;transition:.16s;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 4px rgba(224,144,43,.16)}
textarea{resize:vertical;font-family:var(--sans)}
.input-money{display:flex;align-items:center;background:#fff;border:1.5px solid var(--line-strong);border-radius:10px;overflow:hidden;transition:.16s}
.input-money:focus-within{border-color:var(--amber);box-shadow:0 0 0 4px rgba(224,144,43,.16)}
.input-money span{padding:0 4px 0 13px;font-family:var(--mono);color:var(--muted);font-size:16px}
.input-money input{border:none;box-shadow:none;font-family:var(--mono)}
.dropzone{display:flex;align-items:center;gap:12px;border:1.5px dashed var(--line-strong);border-radius:10px;
  padding:16px;cursor:pointer;color:var(--muted);background:#fff;transition:.16s;font-size:14px}
.dropzone:hover,.dropzone.drag{border-color:var(--amber);background:#fff7ec;color:var(--ink)}
.dropzone em{font-style:normal;font-size:12px;opacity:.7}
.dropzone.has-file{border-style:solid;border-color:var(--teal);background:var(--teal-soft);color:var(--ink)}
.dropzone-preview{display:flex;align-items:center;gap:12px;width:100%}
.dropzone-thumb{width:42px;height:42px;border-radius:8px;object-fit:cover;border:1px solid var(--line);background:var(--paper-2);flex:none}
.dropzone-file-ico{width:42px;height:42px;border-radius:8px;display:grid;place-items:center;background:var(--card);border:1px solid var(--line);font-size:18px;flex:none}
.dropzone-text{min-width:0;flex:1}
.dropzone-text b{display:block;font-size:13.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dropzone-text small{font-size:11.5px;color:var(--muted)}
.form-actions{grid-column:1/-1;display:flex;justify-content:flex-end;gap:12px;border-top:1px solid var(--line);padding-top:18px}

.submit-side{display:flex;flex-direction:column;gap:20px}
.preview{padding:22px;position:relative;overflow:hidden}
.preview::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 18px,rgba(224,144,43,.03) 18px,rgba(224,144,43,.03) 36px);pointer-events:none}
.preview-tag{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--amber-deep)}
.preview-amount{font-size:42px;font-weight:600;margin:10px 0 18px;letter-spacing:-.03em}
.preview-rows{display:grid;gap:1px;background:var(--line);border-radius:10px;overflow:hidden;margin-bottom:16px}
.preview-rows>div{display:flex;justify-content:space-between;background:var(--card);padding:10px 14px;font-size:14px}
.preview-rows span{color:var(--muted)}
.preview-rows b{font-weight:600;text-align:right;max-width:60%}
.preview-note{font-size:13.5px;color:var(--muted);font-style:italic;min-height:20px;margin-bottom:16px}
.preview-foot .hc-pill.warn{background:var(--warn-soft);color:var(--amber-deep)}

.recents{padding:20px 22px}
.recents-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.recents-head h3{font-family:var(--display);font-size:17px;margin:0}
.count,.legend .lg{font-family:var(--mono)}
.count{font-size:12px;background:var(--paper-2);padding:2px 9px;border-radius:999px;color:var(--muted)}
.recent-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.recent-list li{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px dashed var(--line);gap:10px}
.recent-list li:last-child{border:none}
.ri-main{display:flex;flex-direction:column;gap:2px;min-width:0}
.ri-main b{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ri-main small{font-size:12px;color:var(--muted)}
.ri-amt{font-family:var(--mono);font-weight:600;font-size:14px}
.empty{color:var(--muted);font-size:14px;padding:18px 0;text-align:center}

/* status pills */
.status{font-family:var(--mono);font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;white-space:nowrap}
.s-submitted{background:var(--warn-soft);color:var(--amber-deep)}
.s-manager{background:#dbe6f0;color:#2f5a7a}
.s-finance{background:var(--ok-soft);color:#0e6a60}
.s-paid{background:var(--teal-soft);color:var(--teal)}
.s-rejected{background:var(--red-soft);color:var(--red)}

/* ---------- approvals ---------- */
.pipeline{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:24px}
.pl-stage{flex:1;min-width:120px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px;text-align:center;box-shadow:var(--shadow)}
.pl-stage b{display:block;font-size:13px;color:var(--ink-2)}
.pl-stage span{font-family:var(--mono);font-size:26px;font-weight:600;color:var(--amber-deep)}
.pl-arrow{color:var(--line-strong);font-size:20px;font-weight:700}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:22px}
.chip{font-family:var(--sans);font-size:13.5px;font-weight:600;color:var(--muted);background:var(--card);
  border:1px solid var(--line);padding:7px 15px;border-radius:999px;cursor:pointer;transition:.16s}
.chip:hover{border-color:var(--line-strong);color:var(--ink)}
.chip.is-active{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.approval-list{display:flex;flex-direction:column;gap:14px}
.approval{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;background:var(--card);
  border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;box-shadow:var(--shadow);
  animation:rise .35s ease both}
.ap-left{display:flex;flex-direction:column;gap:8px;min-width:0}
.ap-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.ap-amt{font-family:var(--mono);font-size:20px;font-weight:600}
.ap-merchant{font-weight:600}
.ap-meta{font-size:13px;color:var(--muted);display:flex;gap:14px;flex-wrap:wrap}
.ap-meta .mono{color:var(--ink-2)}
.ap-progress{display:flex;gap:5px;margin-top:2px}
.ap-progress i{height:5px;width:30px;border-radius:999px;background:var(--line)}
.ap-progress i.done{background:var(--teal)}
.ap-progress i.cur{background:var(--amber)}
.ap-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.ap-btns{display:flex;gap:8px}
.btn-sm{font-size:13px;padding:8px 16px;border-radius:9px;font-weight:600;cursor:pointer;border:none;transition:.16s}
.btn-approve{background:var(--teal);color:#fff}.btn-approve:hover{background:#0f6a60;transform:translateY(-1px)}
.btn-reject{background:var(--red-soft);color:var(--red)}.btn-reject:hover{background:#efc8c0}
.btn-sm:disabled{opacity:.4;cursor:not-allowed;transform:none}
.ap-done{font-family:var(--mono);font-size:12px;color:var(--muted)}

/* ---------- budget ---------- */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;box-shadow:var(--shadow)}
.kpi .k-label{font-size:12.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.kpi .k-val{font-family:var(--mono);font-size:27px;font-weight:600;letter-spacing:-.02em;margin-top:6px}
.kpi .k-sub{font-size:12.5px;margin-top:4px}
.k-sub.up{color:var(--teal)}.k-sub.down{color:var(--red)}

.dash-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:20px}
.chart-card,.alerts-card{padding:22px}
.alerts-card{grid-column:1/-1}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.card-head h3{font-family:var(--display);font-size:18px;margin:0}
.legend{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--muted)}
.lg{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:5px;vertical-align:-1px}
.lg-spent{background:var(--amber)}.lg-alloc{background:var(--line-strong)}

.bars{display:flex;flex-direction:column;gap:18px}
.bar-row{display:grid;grid-template-columns:160px 1fr auto;gap:14px;align-items:center}
.bar-name{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{position:relative;height:22px;background:var(--line-strong);border-radius:7px;overflow:hidden}
.bar-fill{position:absolute;inset:0;width:0;background:linear-gradient(90deg,var(--amber),#f1b257);border-radius:7px;transition:width 1s cubic-bezier(.2,.8,.2,1)}
.bar-fill.over{background:linear-gradient(90deg,var(--red),#d6644f)}
.bar-val{font-family:var(--mono);font-size:13px;white-space:nowrap}
.bar-val .over{color:var(--red);font-weight:600}

.donut-wrap{position:relative;display:grid;place-items:center;margin:6px 0 18px}
.donut{width:190px;height:190px;transform:rotate(-90deg)}
.donut-hole{fill:none;stroke:var(--paper-2);stroke-width:5}
.donut .seg{fill:none;stroke-width:5;transition:stroke-dasharray 1s cubic-bezier(.2,.8,.2,1)}
.donut-center{position:absolute;text-align:center}
.donut-center .mono{font-size:24px;font-weight:600;display:block}
.donut-center small{font-size:11px;color:var(--muted)}
.cat-legend{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.cat-legend li{display:flex;align-items:center;gap:8px;font-size:13px}
.cat-legend .sw{width:11px;height:11px;border-radius:3px}
.cat-legend .amt{margin-left:auto;font-family:var(--mono);font-size:12.5px;color:var(--muted)}

.alert-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.alert{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:11px;font-size:14px;border:1px solid}
.alert.danger{background:var(--red-soft);border-color:#e9b8ad;color:#7c2c20}
.alert.warn{background:var(--warn-soft);border-color:#e4cf9b;color:#7d5a14}
.alert.ok{background:var(--ok-soft);border-color:#aedcd2;color:#0e5b52}
.alert .a-ico{font-size:18px}
.alert b{font-family:var(--mono)}

/* footer */
.foot{max-width:1180px;margin:0 auto;padding:26px clamp(16px,4vw,46px);display:flex;justify-content:space-between;
  border-top:1px solid var(--line);color:var(--muted);font-size:13px}
.foot span:first-child{font-family:var(--display);font-weight:800;color:var(--ink)}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(140%);z-index:80;
  background:var(--ink);color:var(--paper);padding:13px 22px;border-radius:12px;font-size:14px;font-weight:500;
  box-shadow:0 20px 40px -18px rgba(16,32,43,.8);transition:transform .4s cubic-bezier(.2,.9,.2,1);max-width:90vw}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast b{color:var(--amber)}

/* ---------- expense detail drawer ---------- */
.drawer-overlay{position:fixed;inset:0;z-index:90;background:rgba(16,32,43,.42);backdrop-filter:blur(2px);opacity:0;transition:opacity .25s}
.drawer-overlay.show{opacity:1}
.drawer-overlay[hidden]{display:none}
.drawer{
  position:fixed;top:0;right:0;z-index:91;height:100%;width:min(440px,92vw);
  background:var(--paper);border-left:1px solid var(--line-strong);
  box-shadow:-30px 0 60px -30px rgba(16,32,43,.5);
  transform:translateX(100%);transition:transform .34s cubic-bezier(.2,.85,.25,1);
  display:flex;flex-direction:column;
}
.drawer.open{transform:translateX(0)}
.drawer[hidden]{display:none}
.drawer-head{display:flex;justify-content:space-between;align-items:center;
  padding:18px 22px;border-bottom:1px solid var(--line);background:var(--card)}
.drawer-tag{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--amber-deep)}
.drawer-close{background:none;border:none;font-size:24px;line-height:1;color:var(--muted);cursor:pointer;padding:4px 8px;border-radius:8px;transition:.16s}
.drawer-close:hover{background:var(--paper-2);color:var(--ink)}
.drawer-body{overflow-y:auto;padding:22px;flex:1}
.d-amt{font-family:var(--mono);font-size:30px;font-weight:600;letter-spacing:-.02em}
.d-merchant{font-family:var(--display);font-size:20px;font-weight:800;margin:4px 0 10px;letter-spacing:-.01em}
.d-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.d-section{margin-bottom:20px}
.d-section h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin:0 0 8px}
.d-notes{font-size:14px;color:var(--ink-2);background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 14px;line-height:1.55}
.d-receipt{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px}
.d-receipt img{width:74px;height:74px;border-radius:8px;object-fit:cover;border:1px solid var(--line);flex:none;background:var(--paper-2)}
.d-receipt .d-file-ico{width:74px;height:74px;border-radius:8px;display:grid;place-items:center;background:var(--paper-2);border:1px solid var(--line);font-size:26px;flex:none}
.d-receipt .d-file-meta{min-width:0}
.d-receipt .d-file-meta b{display:block;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.d-receipt .d-file-meta small{font-size:12px;color:var(--muted)}
.d-empty{font-size:13.5px;color:var(--muted);font-style:italic}

/* audit timeline */
.timeline{list-style:none;margin:0;padding:0;position:relative}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--line)}
.timeline li{position:relative;padding:0 0 18px 32px;font-size:14px}
.timeline li:last-child{padding-bottom:0}
.timeline li::before{content:"";position:absolute;left:4px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--card);border:2px solid var(--line-strong)}
.timeline li.done::before{background:var(--teal);border-color:var(--teal)}
.timeline li.cur::before{background:var(--amber);border-color:var(--amber-deep);box-shadow:0 0 0 4px rgba(224,144,43,.18)}
.timeline li.rej::before{background:var(--red);border-color:var(--red)}
.timeline .tl-stage{font-weight:600;color:var(--ink)}
.timeline .tl-ts{font-family:var(--mono);font-size:11.5px;color:var(--muted);display:block}
.d-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px;padding-top:18px;border-top:1px solid var(--line)}
.btn-resubmit{background:var(--amber);color:#fff}.btn-resubmit:hover{background:var(--amber-deep)}
.btn-remove{background:var(--red-soft);color:var(--red)}.btn-remove:hover{background:#efc8c0}

/* clickable rows */
.recent-list li{cursor:pointer;transition:background .14s}
.recent-list li:hover{background:var(--paper-2)}
.approval{cursor:pointer}
.approval:hover{border-color:var(--line-strong)}
.ap-btns{cursor:default}

@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.panel:not([hidden]) .feat,.panel:not([hidden]) .stat,.panel:not([hidden]) .kpi{animation:rise .5s ease both}
.feat:nth-child(2){animation-delay:.05s}.feat:nth-child(3){animation-delay:.1s}.feat:nth-child(4){animation-delay:.15s}

/* ---------- responsive ---------- */
@media(max-width:960px){
  .hero{grid-template-columns:1fr}.hero-card{transform:none;max-width:420px}
  .feat-grid{grid-template-columns:1fr 1fr}
  .submit-layout,.dash-grid{grid-template-columns:1fr}
  .kpi-row{grid-template-columns:1fr 1fr}
  .nav-cta{display:none}
}
@media(max-width:620px){
  .mainnav{gap:0}.mainnav a{padding:8px 10px;font-size:13px}
  .brand-name{display:none}
  .feat-grid,.kpi-row{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .approval{grid-template-columns:1fr}.ap-actions{align-items:stretch}.ap-btns{justify-content:stretch}.ap-btns .btn-sm{flex:1}
  .bar-row{grid-template-columns:1fr;gap:6px}.bar-val{justify-self:end}
  .pl-arrow{display:none}.pl-stage{min-width:calc(50% - 8px)}
  .drawer{width:100vw}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}}
