:root{
  --desk:#141e1a; --desk2:#1b2823; --line:#2c3b34;
  --paper:#f3eddd; --paper-edge:#e3dac1; --ink:#232b26; --ink-soft:#5c645c;
  --cream:#ece5d1; --cream-soft:#9aa495;
  --brass:#c79a3a; --brass-bright:#e3bb58; --clay:#c2603f; --sage:#85a473;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ height:100%; }
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  color:var(--cream); line-height:1.45; -webkit-font-smoothing:antialiased;
  background:radial-gradient(120% 80% at 50% -10%, #1d2c26 0%, var(--desk) 60%) fixed;
  min-height:100%;
}
h1,h2,.gt-value,.num,.env-total,.entry-gross,.send-val{ font-family:Georgia,"Times New Roman",serif; }
.num,.gt-value,input[type=number]{ font-variant-numeric:tabular-nums; }
[hidden]{ display:none !important; }
.mark{ color:var(--brass-bright); text-shadow:0 0 18px rgba(199,154,58,.35); }

/* ---------- AUTH ---------- */
.auth-wrap{ min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px; }
.auth-card{ width:100%; max-width:380px; background:var(--desk2); border:1px solid var(--line);
  border-radius:18px; padding:30px 26px; box-shadow:0 20px 60px rgba(0,0,0,.4); }
.auth-brand{ text-align:center; margin-bottom:22px; }
.auth-brand .mark{ font-size:40px; }
.auth-brand h1{ font-size:30px; letter-spacing:.5px; margin-top:6px; }
.auth-brand .tag{ color:var(--cream-soft); font-size:13px; margin-top:4px; }
.auth-tabs{ display:flex; gap:4px; background:#0f1815; border:1px solid var(--line);
  border-radius:10px; padding:4px; margin-bottom:20px; }
.auth-tab{ flex:1; background:none; border:none; color:var(--cream-soft); cursor:pointer;
  font-size:14px; padding:9px; border-radius:7px; font-family:inherit; transition:.15s; }
.auth-tab.is-active{ background:var(--desk2); color:var(--brass-bright); box-shadow:0 1px 4px rgba(0,0,0,.3); }
.afield{ display:block; font-size:12px; color:var(--cream-soft); margin-bottom:14px; letter-spacing:.3px; }
.afield input{ display:block; width:100%; margin-top:6px; background:#0f1815; border:1px solid var(--line);
  color:var(--cream); border-radius:9px; padding:11px 12px; font-size:15px; font-family:inherit; }
.afield input:focus{ outline:none; border-color:var(--brass); }
.auth-error{ color:#f0c5b3; background:rgba(194,96,63,.16); border:1px solid rgba(194,96,63,.5);
  border-radius:8px; padding:9px 12px; font-size:13px; margin-bottom:14px; }
.auth-submit{ width:100%; background:linear-gradient(180deg,var(--brass-bright),var(--brass)); color:#2a2008;
  border:none; border-radius:10px; padding:13px; font-weight:700; font-size:15px; cursor:pointer;
  font-family:inherit; letter-spacing:.3px; transition:filter .15s; }
.auth-submit:hover{ filter:brightness(1.06); }
.auth-submit:disabled{ filter:grayscale(.6) brightness(.8); cursor:not-allowed; }
.auth-or{ display:flex; align-items:center; gap:12px; margin:18px 0; color:var(--cream-soft); font-size:12px; }
.auth-or::before,.auth-or::after{ content:""; flex:1; height:1px; background:var(--line); }
.google-btn{ display:flex; align-items:center; justify-content:center; gap:10px; width:100%;
  background:#0f1815; border:1px solid var(--line); color:var(--cream); border-radius:10px;
  padding:12px; font-size:14.5px; font-weight:600; text-decoration:none; transition:border-color .15s, background .15s; }
.google-btn:hover{ border-color:var(--brass); background:#13201b; }
.g-mark{ display:inline-flex; align-items:center; justify-content:center; width:22px; height:22px;
  border-radius:50%; background:#fff; color:#4285f4; font-weight:800; font-family:Georgia,serif; font-size:14px; }

/* ---------- APP SHELL ---------- */
.desk{ max-width:1100px; margin:0 auto; padding:26px clamp(14px,4vw,40px) 60px; }
.topbar{ display:flex; justify-content:space-between; align-items:flex-end; gap:18px;
  flex-wrap:wrap; padding-bottom:20px; border-bottom:1px solid var(--line); }
.brand{ display:flex; gap:14px; align-items:center; }
.brand .mark{ font-size:34px; }
.topbar h1{ font-size:clamp(22px,3.4vw,30px); font-weight:600; letter-spacing:.3px; }
.tag{ color:var(--cream-soft); font-size:13px; }
.topbar-right{ display:flex; align-items:flex-end; gap:22px; flex-wrap:wrap; }
.grandtotal{ text-align:right; }
.gt-label{ display:block; font-size:11px; text-transform:uppercase; letter-spacing:1.5px; color:var(--cream-soft); }
.gt-value{ font-size:clamp(22px,3.6vw,32px); color:var(--brass-bright); font-weight:700; }
.account{ display:flex; align-items:center; gap:12px; }
.user-email{ font-size:12px; color:var(--cream-soft); }
.logout-btn{ background:none; border:1px solid var(--line); color:var(--cream-soft); border-radius:8px;
  padding:7px 12px; font-size:12px; cursor:pointer; font-family:inherit; transition:.15s; }
.logout-btn:hover{ border-color:var(--clay); color:#f0a98e; }

.tabs{ display:flex; gap:4px; margin:22px 0 24px; border-bottom:1px solid var(--line); }
.tab{ background:none; border:none; color:var(--cream-soft); cursor:pointer; font-size:14px;
  letter-spacing:.4px; padding:10px 16px; position:relative; font-family:inherit; transition:color .2s; }
.tab:hover{ color:var(--cream); }
.tab.is-active{ color:var(--brass-bright); }
.tab.is-active::after{ content:""; position:absolute; left:12px; right:12px; bottom:-1px; height:2px;
  background:var(--brass); border-radius:2px; }

.panel{ display:none; animation:fade .35s ease; }
.panel.is-active{ display:block; }
@keyframes fade{ from{opacity:0; transform:translateY(6px);} to{opacity:1; transform:none;} }

.income-form{ display:flex; gap:12px; flex-wrap:wrap; align-items:flex-end; background:var(--desk2);
  border:1px solid var(--line); border-radius:14px; padding:16px; }
.field{ display:flex; flex-direction:column; gap:5px; min-width:130px; }
.field.grow{ flex:1 1 220px; }
.field label{ font-size:11px; text-transform:uppercase; letter-spacing:1px; color:var(--cream-soft); }
input[type=date],input[type=text],input[type=number],select{
  background:#0f1815; border:1px solid var(--line); color:var(--cream); border-radius:8px;
  padding:10px 12px; font-size:15px; font-family:inherit; width:100%; }
input:focus,select:focus{ outline:none; border-color:var(--brass); }
.add-btn{ background:linear-gradient(180deg,var(--brass-bright),var(--brass)); color:#2a2008; border:none;
  border-radius:9px; padding:12px 20px; cursor:pointer; font-weight:700; font-size:14px; letter-spacing:.3px;
  font-family:inherit; white-space:nowrap; transition:transform .1s, filter .15s; }
.add-btn:hover{ filter:brightness(1.06); }
.add-btn:active{ transform:translateY(1px); }

.balance-warn{ margin-top:12px; color:#f0c5b3; background:rgba(194,96,63,.16);
  border:1px solid rgba(194,96,63,.5); border-radius:8px; padding:9px 12px; font-size:13px; }

.send-card{ margin-top:18px; background:var(--desk2); border:1px solid var(--line); border-radius:14px; padding:18px; }
.send-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:18px; flex-wrap:wrap; }
.send-title{ font-size:17px; font-weight:600; }
.send-note{ color:var(--cream-soft); font-size:12.5px; margin-top:3px; max-width:42ch; }
.send-amt{ display:flex; flex-direction:column; gap:5px; min-width:150px; }
.send-amt label{ font-size:11px; text-transform:uppercase; letter-spacing:1px; color:var(--cream-soft); }
.send-list{ margin-top:16px; display:flex; flex-direction:column; gap:2px; }
.send-row{ display:flex; align-items:center; gap:12px; padding:11px 4px; border-top:1px solid var(--line); }
.send-row:first-child{ border-top:none; }
.send-dest{ font-weight:600; color:var(--cream); font-size:14.5px; flex:none; min-width:160px; }
.send-cats{ color:var(--cream-soft); font-size:12px; flex:1; }
.send-cats .sub-amt{ color:#d4c391; font-weight:600; font-variant-numeric:tabular-nums; }
.send-val{ font-size:18px; font-weight:700; color:var(--brass-bright); font-variant-numeric:tabular-nums; white-space:nowrap; }
.send-row.unalloc .send-dest,.send-row.unalloc .send-val{ color:#f0a98e; }

.section-title{ font-size:18px; font-weight:600; margin:26px 0 14px; display:flex; align-items:baseline; gap:10px; }
.hint{ font-size:12px; color:var(--cream-soft); }

.envelopes{ display:grid; gap:14px; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); }
.env{ position:relative; background:var(--paper); border:1px solid var(--paper-edge); border-radius:10px;
  padding:14px 14px 16px; overflow:hidden; box-shadow:0 6px 18px rgba(0,0,0,.28); }
.env::before{ content:""; position:absolute; inset:0 0 auto 0; background:var(--env-c); opacity:.14;
  transition:height .7s cubic-bezier(.2,.8,.2,1); height:var(--fill); }
.env-head{ display:flex; justify-content:space-between; align-items:flex-start; position:relative; gap:8px; }
.env-name{ color:var(--ink); font-weight:600; font-size:14px; line-height:1.25; }
.env-pct{ color:#fff; background:var(--env-c); font-size:11px; font-weight:700; padding:2px 7px;
  border-radius:20px; white-space:nowrap; font-variant-numeric:tabular-nums; }
.env-total{ position:relative; margin-top:14px; color:var(--ink); font-size:22px; font-weight:700; font-variant-numeric:tabular-nums; }
.env-sub{ position:relative; color:var(--ink-soft); font-size:11px; text-transform:uppercase; letter-spacing:.8px; margin-top:2px; }
.env-dest{ position:relative; margin-top:10px; font-size:12px; color:var(--ink-soft); display:flex; align-items:center; gap:5px; }
.env-dest b{ color:var(--ink); font-weight:600; }
.env-bar{ position:relative; height:4px; border-radius:3px; margin-top:10px; background:rgba(0,0,0,.1); overflow:hidden; }
.env-bar span{ position:absolute; inset:0 auto 0 0; width:var(--fill); background:var(--env-c); border-radius:3px;
  transition:width .7s cubic-bezier(.2,.8,.2,1); }

.lead{ color:var(--cream-soft); max-width:62ch; margin-bottom:20px; font-size:14.5px; }
.lead strong{ color:var(--brass-bright); }
.cat-editor{ display:flex; flex-direction:column; gap:8px; max-width:640px; }
.cat-row{ display:flex; align-items:center; gap:12px; background:var(--desk2); border:1px solid var(--line);
  border-radius:10px; padding:10px 14px; flex-wrap:wrap; }
.swatch{ width:14px; height:14px; border-radius:4px; flex:none; }
.cat-row .cname{ flex:1 1 150px; font-size:14.5px; color:var(--cream); }
.dest-input{ flex:1 1 150px; padding:7px 9px !important; font-size:13px !important; }
.pct-input{ width:72px; text-align:right; padding:7px 9px !important; }
.pct-sign{ color:var(--cream-soft); margin-left:-6px; }

.total-gauge{ max-width:640px; margin:18px 0 4px; }
.gauge-bar{ height:8px; background:var(--desk2); border:1px solid var(--line); border-radius:6px; overflow:hidden; }
.gauge-bar span{ display:block; height:100%; width:100%; background:linear-gradient(90deg,var(--brass),var(--brass-bright));
  transition:width .35s ease, background .25s; }
.gauge-read{ font-size:13px; color:var(--cream-soft); margin-top:7px; }
.gauge-read #gaugeNum{ color:var(--brass-bright); font-weight:700; font-variant-numeric:tabular-nums; }
.total-gauge.over .gauge-bar span,.total-gauge.under .gauge-bar span{ background:var(--clay); }
.total-gauge.over .gauge-read #gaugeNum,.total-gauge.under .gauge-read #gaugeNum{ color:#f0a98e; }

.editor-actions{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; margin-top:22px; max-width:640px; }
.cur-field{ font-size:12px; color:var(--cream-soft); display:flex; flex-direction:column; gap:5px; letter-spacing:.3px; }
.cur-field select{ width:auto; min-width:200px; }

.ledger{ display:flex; flex-direction:column; gap:10px; }
.entry{ background:var(--desk2); border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.entry-head{ display:flex; align-items:center; gap:14px; padding:14px 16px; cursor:pointer; }
.entry-date{ font-size:12px; color:var(--cream-soft); width:96px; flex:none; font-variant-numeric:tabular-nums; }
.entry-desc{ flex:1; font-size:15px; color:var(--cream); }
.entry-gross{ font-size:18px; font-weight:700; color:var(--brass-bright); font-variant-numeric:tabular-nums; }
.entry-caret{ color:var(--cream-soft); transition:transform .25s; font-size:12px; }
.entry.open .entry-caret{ transform:rotate(90deg); }
.entry-body{ display:none; padding:0 16px 16px; }
.entry.open .entry-body{ display:block; }
.split-grid{ display:grid; gap:6px 18px; grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  border-top:1px solid var(--line); padding-top:12px; }
.split-row{ display:flex; justify-content:space-between; gap:8px; font-size:13px; }
.split-row .sl{ color:var(--cream-soft); display:flex; align-items:center; gap:7px; }
.split-row .sv{ color:var(--cream); font-variant-numeric:tabular-nums; }
.split-row.unalloc .sl,.split-row.unalloc .sv{ color:#f0a98e; }
.dot{ width:9px; height:9px; border-radius:3px; flex:none; }
.del-entry{ margin-top:14px; background:none; border:1px solid var(--line); color:var(--cream-soft);
  border-radius:7px; padding:7px 12px; font-size:12px; cursor:pointer; font-family:inherit; transition:.15s; }
.del-entry:hover{ border-color:var(--clay); color:#f0a98e; }
.empty{ text-align:center; color:var(--cream-soft); padding:48px 20px; border:1px dashed var(--line);
  border-radius:12px; font-size:14px; }

.toast{ position:fixed; left:50%; bottom:26px; transform:translate(-50%,40px); background:var(--paper);
  color:var(--ink); padding:12px 20px; border-radius:30px; font-size:14px; font-weight:600;
  box-shadow:0 10px 30px rgba(0,0,0,.4); opacity:0; pointer-events:none; transition:.4s cubic-bezier(.2,.8,.2,1); z-index:50; }
.toast.show{ opacity:1; transform:translate(-50%,0); }

@media (max-width:560px){
  .add-btn{ width:100%; }
  .grandtotal{ text-align:left; }
  .send-dest{ min-width:120px; }
  .topbar-right{ gap:14px; }
}
@media (prefers-reduced-motion:reduce){ *{ animation:none !important; transition:none !important; } }
