/* ===== Ledger v2 — clean rebuild (local only) ===== */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}

:root{
  --bg:#f7f4ee;
  --bg1:#faf8f3;
  --bg2:#f2ede3;
  --bg3:#ebe5d8;
  --ln:#ddd6c8;
  --ln2:#c9c1b4;

  --t0:#18140f;
  --t1:#2e2820;
  --t2:#5c5047;
  --t3:#8c7e72;

  --grn:#1a7a5e;
  --red:#c0392b;
  --blu:#2c5f8a;
  --yel:#8a6200;

  --grn-t:rgba(26,122,94,.08);
  --red-t:rgba(192,57,43,.08);
  --blu-t:rgba(44,95,138,.08);
  --yel-t:rgba(138,98,0,.08);

  --r:12px;
  --rs:8px;
  --rx:18px;

  --mono:'IBM Plex Mono', monospace;
  --sans:'IBM Plex Sans Thai', sans-serif;
  --ser:'Libre Baskerville', serif;
}

html{color-scheme:light}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--t0);
  min-height:100vh;
  font-size:15px;
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* subtle grain */
body::before{
  content:'';
  position:fixed; inset:0;
  pointer-events:none; z-index:1000;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  opacity:.5;
}

.skip{
  position:absolute; left:-9999px; top:0;
  background:#111; color:#fff;
  padding:10px 12px; border-radius:10px;
  z-index:2000;
}
.skip:focus{left:12px; top:12px}

/* header */
.top{
  position:sticky; top:0; z-index:200;
  height:56px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 24px;
  background:rgba(247,244,238,.94);
  border-bottom:1px solid var(--ln);
  backdrop-filter:blur(16px);
}
.brand{display:flex; align-items:baseline; gap:10px}
.brandDot{
  width:7px; height:7px; border-radius:50%;
  background:var(--grn);
  animation:blink 3s ease-in-out infinite;
}
@keyframes blink{0%,90%,100%{opacity:1}95%{opacity:0}}
.brandTxt{font-family:var(--ser); font-style:italic; font-size:1.35rem; letter-spacing:.02em}
.brandSub{color:var(--t2); font-size:12px; letter-spacing:.04em}
.topRight{display:flex; align-items:center; gap:12px}
.status{display:flex; align-items:center; gap:7px; font-size:12px; color:var(--t2)}
.statusDot{width:6px; height:6px; border-radius:50%; background:var(--t3)}
.statusDot.ok{background:var(--grn)}
.statusDot.warn{background:var(--yel)}
.statusDot.err{background:var(--red)}
.btnIcon{
  width:32px; height:32px;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg2);
  border:1px solid var(--ln);
  border-radius:10px;
  color:var(--t2);
  cursor:pointer;
  transition:all .15s;
}
.btnIcon:hover{border-color:var(--ln2); color:var(--t0)}

/* tabs */
.tabs{
  position:sticky; top:56px; z-index:190;
  display:flex; gap:4px;
  overflow-x:auto;
  padding:0 16px;
  background:rgba(247,244,238,.96);
  border-bottom:1px solid var(--ln);
  backdrop-filter:blur(12px);
}
.tabs::-webkit-scrollbar{display:none}
.tab{
  flex-shrink:0;
  padding:14px 14px 12px;
  font-size:12px; font-weight:600;
  letter-spacing:.03em;
  background:transparent;
  border:none;
  border-bottom:2px solid transparent;
  color:var(--t2);
  cursor:pointer;
  white-space:nowrap;
  transition:color .15s,border-color .15s;
}
.tab.on{color:var(--t0); border-color:var(--t0)}
.tab:hover{color:var(--t1)}

/* layout */
.main{max-width:1160px; margin:0 auto; padding:24px 18px; position:relative}
.page{display:none}
.page.on{display:block; animation:fadeUp .18s ease}
@keyframes fadeUp{from{opacity:0; transform:translateY(6px)}to{opacity:1; transform:none}}

.banner{
  padding:11px 15px;
  border-radius:var(--rs);
  font-size:13px; font-weight:600;
  border:1px solid;
  margin-bottom:12px;
}
.banner.ok{background:var(--grn-t); color:var(--grn); border-color:rgba(26,122,94,.22)}
.banner.err{background:var(--red-t); color:var(--red); border-color:rgba(192,57,43,.22)}
.banner.warn{background:var(--yel-t); color:var(--yel); border-color:rgba(138,98,0,.22)}

.card{
  background:var(--bg1);
  border:1px solid var(--ln);
  border-radius:var(--r);
  padding:20px 22px;
  position:relative;
  overflow:visible;
  box-shadow:0 1px 4px rgba(100,80,60,.04),0 4px 16px rgba(100,80,60,.04);
}
.card::before{
  content:'';
  position:absolute; top:0; left:22px; right:22px;
  height:2px; background:var(--t0); opacity:.06;
}
.cardInset{
  background:var(--bg2);
  border:1px solid var(--ln);
  border-radius:var(--rs);
  padding:14px 16px;
}
.cardHead{display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap}
.cardTitle{
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:.12em;
  font-weight:700;
  text-transform:uppercase;
  color:var(--t2);
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}
.cardTitle.sm{margin-bottom:10px}
.cardTitle::after{content:''; flex:1; height:1px; background:var(--ln)}
.cardHead .cardTitle{margin:0}
.cardHead .cardTitle::after{display:none}
.cardTitle, .cardHead .cardTitle{min-width:200px}

.divider{height:1px; background:var(--ln); margin:14px 0}
.hint{margin-top:10px; padding:10px 12px; border-radius:var(--rs); background:var(--bg2); color:var(--t2); font-size:12px; line-height:1.6; border-left:2px solid var(--grn)}

/* stats */
.statGrid{display:grid; grid-template-columns:repeat(5,1fr); gap:10px; margin-bottom:14px}
@media(max-width:800px){.statGrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.statGrid{grid-template-columns:1fr}}
.statCard{
  background:var(--bg1);
  border:1px solid var(--ln);
  border-radius:var(--rs);
  padding:16px 18px;
  box-shadow:0 1px 3px rgba(100,80,60,.04);
  transition:border-color .2s, box-shadow .2s;
}
.statCard:hover{border-color:var(--ln2); box-shadow:0 2px 8px rgba(100,80,60,.08)}
.statCard.inc{border-top:2px solid var(--grn)}
.statCard.exp{border-top:2px solid var(--red)}
.statCard.acc{border-top:2px solid var(--blu)}
.statCard.debt{border-top:2px solid var(--yel)}
.statLbl{font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--t2); margin-bottom:8px}
.statVal{font-family:var(--ser); font-size:1.9rem; font-weight:700; line-height:1}
.statVal.i{color:var(--grn)}
.statVal.e{color:var(--red)}
.statVal.a{color:var(--blu)}
.statVal.w{color:var(--yel)}
.statSub{margin-top:5px; font-size:12px; color:var(--t2)}

/* grids */
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:14px}
.gridChart{display:grid; grid-template-columns:3fr 2fr; gap:14px; margin-top:14px}
@media(max-width:900px){.grid2,.gridChart{grid-template-columns:1fr}}

.chartBox{position:relative; height:220px}

/* segment control */
.seg{display:flex; background:var(--bg3); border:1px solid var(--ln); border-radius:var(--rs); overflow:hidden}
.segBtn{
  flex:1;
  padding:6px 12px;
  font-size:11px;
  font-weight:600;
  letter-spacing:.02em;
  background:transparent;
  border:none;
  color:var(--t2);
  cursor:pointer;
  transition:all .15s;
}
.segBtn.on{background:var(--bg2); color:var(--t0)}
.segBtn:focus-visible{outline:2px solid var(--blu); outline-offset:-2px}

/* form */
.form{display:flex; flex-direction:column; gap:10px}
.fg{display:flex; flex-direction:column; gap:5px}
label{
  font-size:11px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--t1);
  font-weight:700;
}
input,select,textarea{
  font-family:var(--sans);
  font-size:14px;
  padding:10px 13px;
  background:var(--bg3);
  color:var(--t0);
  border:1px solid var(--ln);
  border-radius:var(--rs);
  outline:none;
  transition:border-color .15s, background .15s;
}
input:focus,select:focus,textarea:focus{border-color:var(--t1); background:var(--bg2)}
input[aria-invalid="true"]{border-color:var(--red)}
.em{min-height:14px; font-size:11px; color:var(--red)}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:10px}
@media(max-width:520px){.row2{grid-template-columns:1fr}}
.inlineForm{display:flex; gap:8px; margin-top:12px}
.inlineForm input:first-child{flex:1}
.inlineForm input:nth-child(2){width:110px}

/* buttons */
.btnP{
  width:100%;
  padding:12px;
  background:var(--t0);
  color:var(--bg1);
  border:none;
  border-radius:var(--rs);
  font-size:13px;
  font-weight:800;
  letter-spacing:.03em;
  cursor:pointer;
  transition:opacity .15s, transform .1s;
}
.btnP:hover{opacity:.86}
.btnP:active{transform:scale(.99)}
.btnP.danger{background:var(--red)}

.btnS{
  padding:7px 14px;
  background:var(--bg2);
  color:var(--t1);
  border:1px solid var(--ln2);
  border-radius:var(--rs);
  font-size:12px;
  font-weight:700;
  cursor:pointer;
  transition:all .15s;
  white-space:nowrap;
}
.btnS:hover{background:var(--bg3); border-color:var(--t2)}
.btnS.danger{color:var(--red)}
.toolbar{display:flex; gap:8px; flex-wrap:wrap; align-items:center}
.mini{padding:7px 10px; font-size:12px}

/* tx list */
.txList{display:flex; flex-direction:column; gap:6px; max-height:420px; overflow:auto; padding-right:2px}
.txList::-webkit-scrollbar{width:3px}
.txList::-webkit-scrollbar-thumb{background:var(--ln2); border-radius:3px}
.txRow{
  display:flex; align-items:center; gap:10px;
  padding:10px 12px;
  background:var(--bg2);
  border:1px solid var(--ln);
  border-radius:var(--rs);
  transition:background .15s, border-color .15s;
  flex-wrap:wrap;
  min-width:0;
}
.txRow:hover{background:var(--bg3); border-color:var(--ln2)}
.txIcon{
  width:32px; height:32px;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:14px;
  flex-shrink:0;
}
.txIcon.i{background:var(--grn-t); border:1px solid rgba(26,122,94,.15)}
.txIcon.e{background:var(--red-t); border:1px solid rgba(192,57,43,.15)}
.txMain{flex:1; min-width:0; overflow:hidden}
.txDesc{font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.txMeta{margin-top:2px; font-size:11px; color:var(--t2)}
.txAmt{font-family:var(--mono); font-size:13px; font-weight:700; flex-shrink:0}
.txAmt.i{color:var(--grn)}
.txAmt.e{color:var(--red)}
.btnGhost{
  background:none;
  border:none;
  color:var(--t3);
  cursor:pointer;
  font-size:13px;
  padding:4px 6px;
  border-radius:8px;
  transition:color .15s, background .15s;
}
.btnGhost:hover{color:var(--red); background:var(--red-t)}

.empty{padding:26px; text-align:center; color:var(--t2); font-size:13px; line-height:1.8}

/* progress */
.pb{background:var(--bg3); border-radius:99px; height:3px; overflow:hidden; margin:10px 0 4px}
.pf{height:100%; border-radius:99px; background:var(--grn); transition:width .6s cubic-bezier(.34,1.3,.64,1)}
.pf.warn{background:var(--yel)}

/* badges */
.badge{
  font-size:10px; font-weight:800; letter-spacing:.04em;
  padding:3px 9px;
  border-radius:4px;
  border:1px solid;
  display:inline-flex;
}
.badge.ok{background:var(--grn-t); color:var(--grn); border-color:rgba(26,122,94,.22)}
.badge.warn{background:var(--yel-t); color:var(--yel); border-color:rgba(138,98,0,.22)}

/* report */
.rTitle{font-family:var(--ser); font-size:1.7rem; font-weight:700; letter-spacing:-.01em}
.rSub{margin-top:4px; font-size:12px; color:var(--t2)}

/* modal */
.modalOverlay{
  position:fixed; inset:0;
  background:rgba(28,24,20,.7);
  z-index:600;
  display:flex; align-items:center; justify-content:center;
  backdrop-filter:blur(10px);
}
.modal{
  width:min(560px, 94vw);
  background:var(--bg1);
  border:1px solid var(--ln2);
  border-radius:var(--rx);
  box-shadow:0 12px 60px rgba(28,24,20,.18);
  overflow:hidden;
}
.modalHead{
  display:flex; justify-content:space-between; align-items:flex-start;
  padding:18px 18px 0;
}
.modalTitle{font-family:var(--ser); font-size:1.4rem; font-weight:700}
.modalSub{font-size:11px; color:var(--t2); margin-top:3px; letter-spacing:.04em; text-transform:uppercase}
.modalBody{padding:14px 18px 18px}

@media print{
  body{background:#fff;color:#111}
  body::before{display:none}
  header,nav,.banner,.modalOverlay,.skip,.btnIcon,.toolbar,.btnP,.btnS,.btnGhost{display:none!important}
  .main{padding:0}
  .page{display:block!important}
  .card{background:#fff;border:1px solid #ddd;box-shadow:none}
  .card::before{display:none}
}

