/* ============================================================
   MONEY — Design System v3 · "Forest & Lime"
   Dark-first, mobile-first, premium-fintech look.
   Inspired by high-budget banking apps: deep green surfaces,
   lime accents, springy motion, tabular numerals.
   ============================================================ */

/* ---------------- Tokens ---------------- */
:root{
  --sans:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --disp:'Space Grotesk','Plus Jakarta Sans',sans-serif;

  /* surfaces — deep forest */
  --bg:#080c09;
  --bg2:#0c110d;
  --card:#12191382;
  --card-solid:#121913;
  --card2:#182119;
  --line:rgba(213,255,190,.075);
  --line2:rgba(213,255,190,.045);

  /* ink */
  --ink:#eef4ec;
  --ink2:#a7b4a6;
  --muted:#6b7a6b;

  /* brand */
  --lime:#d4f65f;
  --lime2:#b9e945;
  --on-lime:#111803;
  --lime-soft:rgba(212,246,95,.12);
  --lime-line:rgba(212,246,95,.28);

  /* semantic */
  --mint:#4fd88f;          /* income  */
  --mint-soft:rgba(79,216,143,.13);
  --coral:#ff8d75;         /* expense / over */
  --coral-soft:rgba(255,141,117,.13);
  --amber:#f6c65b;         /* debt / warning */
  --amber-soft:rgba(246,198,91,.13);
  --iris:#b7a9fb;          /* savings */
  --iris-soft:rgba(183,169,251,.14);

  /* shape & motion */
  --r:24px; --r-sm:16px; --r-xs:12px;
  --ease:cubic-bezier(.22,1,.36,1);
  --spring:cubic-bezier(.34,1.4,.4,1);
  --tap:44px;

  --shadow:0 2px 6px rgba(0,0,0,.28),0 14px 40px rgba(0,0,0,.42);
  --shadow-lg:0 24px 70px rgba(0,0,0,.65);
  --ring:0 0 0 3px rgba(212,246,95,.28);
  --scrim:rgba(2,5,3,.66);

  --dock-h:78px;
  --appbar-h:60px;
}

/* ---------------- Reset & base ---------------- */
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);color:var(--ink);font-size:15px;line-height:1.5;
  letter-spacing:-.008em;font-variant-numeric:tabular-nums;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background:var(--bg);min-height:100dvh;
  overscroll-behavior-y:none;
}
/* ambient glow behind the phone column */
body::before{content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(720px 420px at 82% -6%,rgba(120,190,90,.13) 0%,transparent 60%),
    radial-gradient(640px 480px at -10% 30%,rgba(212,246,95,.05) 0%,transparent 55%),
    radial-gradient(700px 520px at 60% 110%,rgba(79,216,143,.07) 0%,transparent 60%);
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
input,select,textarea{font-family:inherit;font-size:16px;color:inherit}
a{color:inherit;text-decoration:none}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:10px}
svg{display:block}
.hidden{display:none!important}
::selection{background:var(--lime-soft);color:var(--lime)}
.num{font-variant-numeric:tabular-nums}
.disp{font-family:var(--disp);letter-spacing:-.02em}

input[type=number]{-moz-appearance:textfield;appearance:textfield}
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
input[type=date]{color-scheme:dark}
select{color-scheme:dark}

::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#243026;border-radius:8px;border:3px solid transparent;background-clip:content-box}
.hscroll::-webkit-scrollbar{display:none}
.hscroll{scrollbar-width:none}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* ---------------- App frame (phone column) ---------------- */
.app{position:relative;max-width:520px;margin:0 auto;min-height:100dvh;
  background:var(--bg2);isolation:isolate}
@media(min-width:560px){
  .app{border-left:1px solid var(--line2);border-right:1px solid var(--line2);
    box-shadow:0 0 90px rgba(0,0,0,.5)}
}
/* subtle in-frame ambience */
.app::before{content:'';position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(480px 300px at 100% -4%,rgba(140,205,100,.10) 0%,transparent 58%),
    radial-gradient(420px 320px at -12% 24%,rgba(79,216,143,.06) 0%,transparent 55%)}

/* ---------------- App bar ---------------- */
.appbar{position:sticky;top:0;z-index:40;height:calc(var(--appbar-h) + env(safe-area-inset-top));
  padding:env(safe-area-inset-top) 18px 0;
  display:flex;align-items:center;gap:12px;
  background:color-mix(in srgb,var(--bg2) 78%,transparent);
  backdrop-filter:blur(18px) saturate(1.3);-webkit-backdrop-filter:blur(18px) saturate(1.3)}
.avatar{position:relative;width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#22301f,#141c12);border:1px solid var(--line);
  display:grid;place-items:center;font-weight:800;font-size:16px;color:var(--lime);
  transition:transform .18s var(--spring)}
.avatar:active{transform:scale(.9)}
.avatar .dot{position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;border-radius:50%;
  border:2.5px solid var(--bg2);background:var(--muted);transition:background .3s}
.avatar .dot.ok{background:var(--mint)}
.avatar .dot.saving{background:var(--amber)}
.avatar .dot.auth{background:var(--coral)}
.hello{flex:1;min-width:0;line-height:1.22}
.hello small{display:block;font-size:11.5px;color:var(--muted);font-weight:600}
.hello b{font-size:15.5px;font-weight:800;letter-spacing:-.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.iconbtn{width:var(--tap);height:var(--tap);border-radius:14px;display:grid;place-items:center;
  color:var(--ink2);background:var(--card);border:1px solid var(--line2);
  transition:transform .18s var(--spring),background .18s,color .18s}
.iconbtn svg{width:20px;height:20px;stroke-width:1.9}
.iconbtn:active{transform:scale(.88)}
.iconbtn:hover{color:var(--ink);background:var(--card2)}

/* ---------------- Page ---------------- */
#view{padding:6px 18px calc(var(--dock-h) + 34px + env(safe-area-inset-bottom));
  animation:pagein .38s var(--ease) both}
@keyframes pagein{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.ptitle{font-size:24px;font-weight:800;letter-spacing:-.035em;line-height:1.15;margin:10px 0 2px}
.psub{font-size:13px;color:var(--muted);margin-bottom:14px}
.sec{display:flex;align-items:baseline;justify-content:space-between;margin:26px 0 12px}
.sec h2{font-size:16.5px;font-weight:800;letter-spacing:-.02em}
.sec .lnk{font-size:12.5px;font-weight:700;color:var(--muted);padding:4px 2px;transition:color .15s}
.sec .lnk:hover{color:var(--lime)}

/* staggered entrance */
.in{animation:rise .55s var(--ease) both;animation-delay:calc(var(--i,0)*60ms)}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ---------------- Cards ---------------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:18px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.card+.card{margin-top:12px}
.pressable{transition:transform .18s var(--spring)}
.pressable:active{transform:scale(.975)}

/* hero balance card */
.hero{position:relative;overflow:hidden;border-radius:28px;padding:24px 22px 20px;
  background:linear-gradient(150deg,#1d2b1c 0%,#121b11 46%,#0d130c 100%);
  border:1px solid rgba(212,246,95,.14);box-shadow:var(--shadow)}
.hero::before{content:'';position:absolute;width:340px;height:340px;right:-120px;top:-170px;
  border-radius:50%;background:radial-gradient(circle,rgba(212,246,95,.16) 0%,transparent 65%);
  animation:drift 9s ease-in-out infinite alternate}
.hero::after{content:'';position:absolute;width:260px;height:260px;left:-110px;bottom:-150px;
  border-radius:50%;background:radial-gradient(circle,rgba(79,216,143,.13) 0%,transparent 65%);
  animation:drift 11s ease-in-out infinite alternate-reverse}
@keyframes drift{from{transform:translate(0,0)}to{transform:translate(-22px,16px)}}
.hero .lbl{font-size:12px;font-weight:700;color:var(--ink2);letter-spacing:.04em;text-transform:uppercase}
.hero .big{font-family:var(--disp);font-size:44px;font-weight:700;letter-spacing:-.03em;
  line-height:1.05;margin:6px 0 4px}
.hero .big small{font-size:24px;color:var(--ink2);font-weight:600}
.hero-chips{display:flex;gap:8px;margin-top:14px;position:relative}
.hchip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;
  padding:6px 11px;border-radius:999px;background:rgba(255,255,255,.055);border:1px solid var(--line2)}
.hchip svg{width:13px;height:13px;stroke-width:2.4}
.hchip.up{color:var(--mint)} .hchip.down{color:var(--coral)} .hchip.sv{color:var(--iris)}

/* quick actions row */
.qa-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}
.qa{display:flex;flex-direction:column;align-items:center;gap:7px;padding:13px 4px 11px;
  border-radius:var(--r-sm);background:var(--card);border:1px solid var(--line);
  transition:transform .18s var(--spring),border-color .2s}
.qa:active{transform:scale(.92)}
.qa .ic{width:40px;height:40px;border-radius:13px;display:grid;place-items:center;font-size:17px}
.qa .ic svg{width:19px;height:19px;stroke-width:2.1}
.qa span{font-size:11px;font-weight:700;color:var(--ink2)}
.qa:hover{border-color:var(--lime-line)}
.ic.lime{background:var(--lime);color:var(--on-lime)}
.ic.mint{background:var(--mint-soft);color:var(--mint)}
.ic.coral{background:var(--coral-soft);color:var(--coral)}
.ic.iris{background:var(--iris-soft);color:var(--iris)}
.ic.amber{background:var(--amber-soft);color:var(--amber)}

/* notice / RTA banner */
.notice{display:flex;align-items:center;gap:13px;margin-top:12px;padding:14px 16px;
  border-radius:var(--r-sm);cursor:pointer;
  background:linear-gradient(120deg,rgba(212,246,95,.14),rgba(212,246,95,.05));
  border:1px solid var(--lime-line);transition:transform .18s var(--spring)}
.notice:active{transform:scale(.98)}
.notice.bad{background:linear-gradient(120deg,rgba(255,141,117,.15),rgba(255,141,117,.05));
  border-color:rgba(255,141,117,.3)}
.notice .n-ic{width:38px;height:38px;border-radius:12px;background:var(--lime);color:var(--on-lime);
  display:grid;place-items:center;flex-shrink:0;font-size:17px}
.notice.bad .n-ic{background:var(--coral);color:#2b0d06}
.notice b{display:block;font-size:14px;letter-spacing:-.01em}
.notice small{font-size:12px;color:var(--ink2)}
.notice .arr{margin-left:auto;color:var(--muted)}

/* ---------------- Stat / mini cards ---------------- */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat{padding:16px;border-radius:var(--r-sm);background:var(--card);border:1px solid var(--line)}
.stat .k{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--ink2)}
.stat .k .bub{width:26px;height:26px;border-radius:9px;display:grid;place-items:center}
.stat .k .bub svg{width:14px;height:14px;stroke-width:2.4}
.stat .v{font-family:var(--disp);font-size:21px;font-weight:700;margin-top:8px;letter-spacing:-.02em}
.stat .d{font-size:11.5px;font-weight:700;margin-top:2px;color:var(--muted)}
.stat .d.up{color:var(--mint)} .stat .d.down{color:var(--coral)}

/* ---------------- Progress bars ---------------- */
.bar{height:7px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden;position:relative}
.bar i{display:block;height:100%;width:0;border-radius:99px;
  background:linear-gradient(90deg,var(--lime2),var(--lime));
  transition:width 1s var(--ease)}
.bar i.warn{background:linear-gradient(90deg,#e9b445,var(--amber))}
.bar i.over{background:linear-gradient(90deg,#f07257,var(--coral))}
.bar i.mint{background:linear-gradient(90deg,#31b877,var(--mint))}
.bar i.iris{background:linear-gradient(90deg,#8f7df0,var(--iris))}

/* ---------------- Generic rows ---------------- */
.row{display:flex;align-items:center;gap:13px;padding:13px 4px;min-height:60px;
  border-bottom:1px solid var(--line2);cursor:pointer;
  transition:transform .16s var(--spring)}
.row:last-child{border-bottom:none}
.row:active{transform:scale(.985)}
.row .bub{width:44px;height:44px;border-radius:15px;flex-shrink:0;display:grid;place-items:center;
  font-size:19px;background:var(--card2);border:1px solid var(--line2)}
.row .mid{flex:1;min-width:0}
.row .mid b{display:block;font-size:14.5px;font-weight:700;letter-spacing:-.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .mid small{display:block;font-size:12px;color:var(--muted);margin-top:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .end{text-align:right;flex-shrink:0}
.row .end b{font-family:var(--disp);font-size:15px;font-weight:700;display:block}
.row .end small{font-size:11.5px;color:var(--muted)}
.amt-in{color:var(--mint)} .amt-out{color:var(--ink)} .amt-sv{color:var(--iris)}

.day-head{display:flex;justify-content:space-between;align-items:baseline;
  margin:20px 2px 4px;font-size:11.5px;font-weight:800;letter-spacing:.07em;
  text-transform:uppercase;color:var(--muted)}
.day-head span:last-child{font-family:var(--disp);letter-spacing:0;text-transform:none;font-size:12px}

/* ---------------- Budget rows ---------------- */
.bgroup{margin-top:18px}
.bgroup-head{display:flex;align-items:baseline;justify-content:space-between;margin:0 2px 8px}
.bgroup-head h3{font-size:13px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--ink2)}
.bgroup-head small{font-size:12px;color:var(--muted);font-weight:600}
.bgroup-head small b{color:var(--ink2);font-family:var(--disp)}
.brow{padding:13px 16px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-sm);margin-bottom:8px;cursor:pointer;
  transition:transform .18s var(--spring),border-color .2s}
.brow:active{transform:scale(.98)}
.brow:hover{border-color:var(--lime-line)}
.brow-top{display:flex;align-items:center;gap:11px}
.brow-top .em{font-size:19px;width:26px;text-align:center;flex-shrink:0}
.brow-top b{flex:1;min-width:0;font-size:14.5px;font-weight:700;letter-spacing:-.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pill{font-family:var(--disp);font-size:12.5px;font-weight:700;padding:4px 10px;border-radius:999px;flex-shrink:0}
.pill.ok{background:var(--lime-soft);color:var(--lime)}
.pill.mint{background:var(--mint-soft);color:var(--mint)}
.pill.warn{background:var(--amber-soft);color:var(--amber)}
.pill.over{background:var(--coral-soft);color:var(--coral)}
.pill.mut{background:rgba(255,255,255,.06);color:var(--muted)}
.pill.iris{background:var(--iris-soft);color:var(--iris)}
.brow .bar{margin-top:10px}
.brow-sub{display:flex;justify-content:space-between;margin-top:7px;font-size:11.5px;color:var(--muted)}
.brow-sub b{color:var(--ink2);font-weight:700;font-family:var(--disp)}

.addrow{width:100%;padding:13px;border-radius:var(--r-sm);border:1.5px dashed var(--line);
  color:var(--muted);font-size:13px;font-weight:700;transition:.18s}
.addrow:hover{color:var(--lime);border-color:var(--lime-line);background:var(--lime-soft)}

/* ---------------- Month switcher & chips ---------------- */
.mnav{display:flex;align-items:center;justify-content:center;gap:6px;margin:4px 0 14px}
.mnav .mv{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;color:var(--ink2);
  background:var(--card);border:1px solid var(--line);transition:transform .16s var(--spring)}
.mnav .mv:active{transform:scale(.86)}
.mnav .mv[disabled]{opacity:.3;pointer-events:none}
.mnav .cur{min-width:150px;text-align:center;font-weight:800;font-size:15px;letter-spacing:-.01em}
.mnav .cur small{display:block;font-size:10.5px;color:var(--muted);font-weight:700;letter-spacing:.08em;text-transform:uppercase}

.chips{display:flex;gap:8px;overflow-x:auto;padding:2px 0 6px}
.chip{flex-shrink:0;padding:8px 15px;border-radius:999px;font-size:12.5px;font-weight:700;
  color:var(--ink2);background:var(--card);border:1px solid var(--line);
  transition:.18s var(--ease);white-space:nowrap}
.chip:active{transform:scale(.93)}
.chip.on{background:var(--lime);color:var(--on-lime);border-color:var(--lime)}
.chip.alert{color:var(--amber);border-color:rgba(246,198,91,.35);background:var(--amber-soft)}

/* segmented control (Semana/Mes/Año) */
.seg{display:flex;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:4px;gap:2px}
.seg button{flex:1;padding:9px 6px;border-radius:999px;font-size:13px;font-weight:700;color:var(--muted);
  transition:.22s var(--ease)}
.seg button.on{background:var(--lime);color:var(--on-lime);box-shadow:0 4px 14px rgba(212,246,95,.25)}

/* ---------------- Charts ---------------- */
.chart-card{padding:18px 10px 8px;overflow:hidden}
.grid-line{stroke:rgba(255,255,255,.05);stroke-width:1}
.axis-lbl{font-size:9.5px;fill:var(--muted);font-weight:600;font-family:var(--sans)}
.js-chart{touch-action:pan-y}

.donut-wrap{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center}
.donut-legend{flex:1;min-width:170px;display:flex;flex-direction:column;gap:9px;padding:6px 8px}
.dl-row{display:flex;align-items:center;gap:9px;font-size:12.5px}
.dl-dot{width:9px;height:9px;border-radius:4px;flex-shrink:0}
.dl-name{flex:1;min-width:0;color:var(--ink2);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dl-val{font-family:var(--disp);font-weight:700;font-size:12.5px}

/* tooltip (desktop hover) */
#tooltip{position:fixed;z-index:200;pointer-events:none;opacity:0;transition:opacity .15s;
  background:#1b241c;color:#fff;border:1px solid var(--line);border-radius:12px;
  padding:9px 12px;font-size:12px;box-shadow:var(--shadow);max-width:220px}
#tooltip b{font-size:11px;color:var(--ink2);font-weight:700}
.tt-row{display:flex;align-items:center;gap:7px;margin-top:3px;font-weight:700;font-family:var(--disp)}
.tt-dot{display:inline-block;width:8px;height:8px;border-radius:3px;margin-right:6px}

/* ---------------- Goals ---------------- */
.goal-scroll{display:flex;gap:12px;overflow-x:auto;padding:2px 2px 8px;margin:0 -18px;padding-left:18px;padding-right:18px}
.goal-mini{flex-shrink:0;width:158px;padding:15px;border-radius:20px;background:var(--card);
  border:1px solid var(--line);transition:transform .18s var(--spring)}
.goal-mini:active{transform:scale(.95)}
.goal-mini .gm-top{display:flex;align-items:center;justify-content:space-between}
.goal-mini .em{font-size:21px}
.goal-mini b{display:block;font-size:13px;font-weight:700;margin-top:9px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.goal-mini small{display:block;font-size:11px;color:var(--muted);margin:2px 0 9px}
.goal-mini .pct{font-family:var(--disp);font-size:12px;font-weight:700;color:var(--iris)}

.goal-card{padding:17px;border-radius:20px;background:var(--card);border:1px solid var(--line);
  margin-bottom:12px;transition:transform .18s var(--spring)}
.goal-card:active{transform:scale(.985)}
.gc-head{display:flex;align-items:center;gap:13px}
.gc-head .bub{width:46px;height:46px;border-radius:16px;font-size:21px;display:grid;place-items:center;
  background:var(--iris-soft);border:1px solid rgba(183,169,251,.2)}
.gc-head .mid{flex:1;min-width:0}
.gc-head b{display:block;font-size:15px;font-weight:800;letter-spacing:-.01em}
.gc-head small{font-size:12px;color:var(--muted)}
.gc-amt{text-align:right}
.gc-amt b{font-family:var(--disp);font-size:15px;display:block}
.gc-amt small{font-size:11px;color:var(--muted)}
.gc-foot{display:flex;justify-content:space-between;align-items:center;margin-top:9px;font-size:11.5px;color:var(--muted)}
.gc-foot b{color:var(--ink2);font-family:var(--disp)}
.gc-btn{font-size:12px;font-weight:800;color:var(--on-lime);background:var(--lime);
  padding:7px 14px;border-radius:999px;transition:transform .16s var(--spring)}
.gc-btn:active{transform:scale(.9)}

/* ---------------- Dock (bottom nav) ---------------- */
.dock{position:fixed;bottom:0;left:50%;transform:translateX(-50%);z-index:60;
  width:100%;max-width:520px;
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:blur(22px) saturate(1.4);-webkit-backdrop-filter:blur(22px) saturate(1.4);
  border-top:1px solid var(--line2);
  display:grid;grid-template-columns:1fr 1fr auto 1fr 1fr;align-items:center;gap:2px}
.dock-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 2px;
  color:var(--muted);position:relative;transition:color .2s;min-height:52px;justify-content:center}
.dock-item svg{width:22px;height:22px;stroke-width:1.9;transition:transform .25s var(--spring)}
.dock-item span{font-size:10px;font-weight:700;letter-spacing:-.01em}
.dock-item.active{color:var(--lime)}
.dock-item.active svg{transform:translateY(-2px) scale(1.08)}
.dock-item.active::after{content:'';position:absolute;bottom:0;width:18px;height:3px;border-radius:3px;
  background:var(--lime);animation:pop .3s var(--spring)}
.dock-item:active svg{transform:scale(.85)}
@keyframes pop{from{transform:scaleX(.2);opacity:0}to{transform:none;opacity:1}}
.dock-add{width:56px;height:56px;border-radius:19px;margin:0 8px;
  background:linear-gradient(150deg,var(--lime) 0%,var(--lime2) 100%);color:var(--on-lime);
  display:grid;place-items:center;box-shadow:0 8px 26px rgba(212,246,95,.32),inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .2s var(--spring);transform:translateY(-8px)}
.dock-add svg{width:26px;height:26px;stroke-width:2.6}
.dock-add:active{transform:translateY(-8px) scale(.86) rotate(90deg)}

/* ---------------- Sheets (bottom modals) ---------------- */
#overlay{position:fixed;inset:0;z-index:100;background:var(--scrim);
  opacity:0;pointer-events:none;transition:opacity .28s ease;
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  display:flex;align-items:flex-end;justify-content:center}
#overlay.show{opacity:1;pointer-events:auto}
.sheet{width:100%;max-width:520px;max-height:88dvh;overflow-y:auto;overscroll-behavior:contain;
  background:var(--bg2);border:1px solid var(--line);border-bottom:none;
  border-radius:28px 28px 0 0;padding:10px 20px calc(22px + env(safe-area-inset-bottom));
  transform:translateY(60px);opacity:0;transition:transform .34s var(--spring),opacity .25s ease;
  box-shadow:var(--shadow-lg)}
#overlay.show .sheet{transform:none;opacity:1}
.grab{width:40px;height:4.5px;border-radius:3px;background:rgba(255,255,255,.14);margin:4px auto 16px}
.sheet h3{font-size:19px;font-weight:800;letter-spacing:-.025em}
.sheet .mh{font-size:13px;color:var(--muted);margin:4px 0 16px;line-height:1.45}

.field{margin-bottom:13px}
.field label{display:block;font-size:11.5px;font-weight:800;letter-spacing:.05em;
  text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.field input,.field select{width:100%;padding:13px 14px;border-radius:var(--r-xs);
  background:var(--card);border:1px solid var(--line);transition:border-color .2s;min-height:48px}
.field input:focus,.field select:focus{border-color:var(--lime-line);box-shadow:none;outline:none}
.money-field{position:relative;display:block;width:100%}
.money-field::before{content:'$';position:absolute;left:14px;top:50%;transform:translateY(-50%);
  color:var(--muted);font-size:14px;font-weight:700;pointer-events:none;z-index:1}
.money-field input{padding-left:28px!important}

.sheet .seg{margin-bottom:14px}
.modal-actions{display:flex;gap:10px;margin-top:18px}
.btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 18px;border-radius:16px;font-size:14.5px;font-weight:800;letter-spacing:-.01em;
  background:var(--lime);color:var(--on-lime);min-height:52px;
  box-shadow:0 8px 22px rgba(212,246,95,.22);
  transition:transform .18s var(--spring),filter .2s}
.btn:active{transform:scale(.96)}
.btn:hover{filter:brightness(1.06)}
.btn[disabled]{opacity:.4;pointer-events:none;box-shadow:none}
.btn-ghost{background:var(--card);color:var(--ink2);border:1px solid var(--line);box-shadow:none}
.btn-ghost:hover{color:var(--ink);filter:none;background:var(--card2)}
.btn-danger{background:var(--coral);color:#2b0d06;box-shadow:0 8px 22px rgba(255,141,117,.2)}

/* emoji grid — targets holgados (≥48px) para no tocar el vecino en móvil */
.emoji-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:9px}
.emoji-opt{font-size:23px;min-height:50px;display:grid;place-items:center;border-radius:14px;
  border:1.5px solid var(--line);background:var(--card);transition:.15s var(--spring);
  touch-action:manipulation}
.emoji-opt:active{transform:scale(.88)}
.emoji-opt.sel{border-color:var(--lime);background:var(--lime-soft);
  box-shadow:0 0 0 2px var(--lime) inset,0 6px 16px rgba(212,246,95,.22);transform:scale(1.04)}

/* quick chips inside sheets */
.qchips{display:flex;gap:7px;flex-wrap:wrap;margin:-4px 0 14px}
.qchip{font-size:12px;font-weight:700;color:var(--ink2);padding:7px 12px;border-radius:999px;
  background:var(--card);border:1px solid var(--line);transition:.15s var(--spring)}
.qchip:active{transform:scale(.92)}
.qchip:hover{color:var(--lime);border-color:var(--lime-line)}

/* ---------------- Quick add (numpad) ---------------- */
.qa-type{margin-bottom:6px}
.qa-amt{text-align:center;padding:14px 0 6px}
.qa-amt .val{font-family:var(--disp);font-size:52px;font-weight:700;letter-spacing:-.03em;line-height:1;
  transition:color .2s}
.qa-amt .val small{font-size:28px;color:var(--ink2)}
.qa-amt .val.zero{color:var(--muted)}
.qa-amt .val .bump{display:inline-block;animation:bump .18s var(--spring)}
@keyframes bump{from{transform:scale(1.25)}to{transform:none}}
.qa-cats{display:flex;gap:8px;overflow-x:auto;padding:10px 2px 12px;margin:0 -2px}
.qa-cat{flex-shrink:0;display:flex;align-items:center;gap:7px;padding:9px 14px;border-radius:999px;
  background:var(--card);border:1.5px solid var(--line);font-size:12.5px;font-weight:700;color:var(--ink2);
  transition:.16s var(--spring);white-space:nowrap}
.qa-cat:active{transform:scale(.93)}
.qa-cat.sel{border-color:var(--lime);background:var(--lime-soft);color:var(--lime)}
.qa-meta{display:grid;grid-template-columns:1fr 1.4fr;gap:9px;margin-bottom:10px}
.qa-meta input{width:100%;padding:11px 12px;border-radius:var(--r-xs);background:var(--card);
  border:1px solid var(--line);font-size:13.5px;min-height:44px}
.pad{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin:4px 0 14px}
.pad button{font-family:var(--disp);font-size:23px;font-weight:600;padding:15px 0;border-radius:16px;
  transition:background .12s,transform .12s var(--spring)}
.pad button:active{background:var(--lime-soft);transform:scale(.92)}
.pad button svg{width:22px;height:22px;margin:0 auto;stroke-width:2}

/* ---------------- Categorize tool ---------------- */
.cz-kw{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;margin-bottom:10px}
.cz-kw input,.cz-kw select{padding:11px 12px;border-radius:var(--r-xs);background:var(--card);
  border:1px solid var(--line);font-size:13px;min-height:44px;min-width:0}
.cz-kw .btn{flex:0;padding:11px 16px;min-height:44px;font-size:13px}
.cz-toggle{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--ink2);margin:6px 0 10px;cursor:pointer}
.cz-toggle input{width:17px;height:17px;accent-color:var(--lime)}
.cz-list{display:flex;flex-direction:column;gap:8px;max-height:320px;overflow-y:auto;margin-top:6px}
.cz-row{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:var(--r-xs);
  background:var(--card);border:1px solid var(--line)}
.cz-info{flex:1;min-width:0}
.cz-merch{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cz-meta{font-size:11px;color:var(--muted)}
.cz-sel{max-width:150px;padding:9px 10px;border-radius:10px;background:var(--card2);
  border:1px solid var(--line);font-size:12.5px}
.cz-more{text-align:center;font-size:12px;color:var(--muted);padding:8px}
.cz-rules{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.cz-rule{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:11px;
  background:var(--card);border:1px solid var(--line);font-size:12.5px}
.cz-rule-txt{flex:1;color:var(--ink2)} .cz-rule-txt b{color:var(--ink)}
.icon-btn{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;color:var(--muted);transition:.15s}
.icon-btn:hover{color:var(--coral);background:var(--coral-soft)}
.icon-btn svg{width:15px;height:15px}

/* settings list */
.set-list{display:flex;flex-direction:column;gap:8px}
.set-item{display:flex;align-items:center;gap:13px;padding:14px 15px;border-radius:var(--r-sm);
  background:var(--card);border:1px solid var(--line);cursor:pointer;width:100%;text-align:left;
  transition:transform .16s var(--spring)}
.set-item:active{transform:scale(.98)}
.set-item .ic{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}
.set-item .ic svg{width:17px;height:17px;stroke-width:2}
.set-item b{flex:1;font-size:14px;font-weight:700}
.set-item small{font-size:12px;color:var(--muted)}
.set-item.danger b{color:var(--coral)}

/* import summary */
.imp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:8px}
.imp-stat{text-align:center;padding:13px 6px;border-radius:var(--r-xs);background:var(--card);border:1px solid var(--line)}
.imp-n{font-family:var(--disp);font-size:21px;font-weight:700}
.imp-l{font-size:11px;color:var(--muted);font-weight:700}

/* ---------------- Empty state ---------------- */
.empty-state{text-align:center;padding:36px 18px;color:var(--muted);font-size:13px}
.empty-state svg{width:42px;height:42px;margin:0 auto 10px;opacity:.4;stroke-width:1.5}
.empty-state p:first-of-type{font-weight:700;color:var(--ink2);font-size:14px}

/* ---------------- Toast ---------------- */
#toast{position:fixed;left:50%;bottom:calc(var(--dock-h) + 22px + env(safe-area-inset-bottom));
  transform:translate(-50%,16px);z-index:300;display:flex;align-items:center;gap:9px;
  background:#1c261d;color:#eef4ec;border:1px solid var(--line);
  padding:12px 18px;border-radius:16px;font-size:13.5px;font-weight:700;
  box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;
  transition:opacity .25s ease,transform .3s var(--spring);max-width:88vw}
#toast.show{opacity:1;transform:translate(-50%,0)}
#toast svg{width:17px;height:17px;color:var(--lime);flex-shrink:0}

/* ---------------- Lock screen ---------------- */
#lockScreen{position:fixed;inset:0;z-index:400;background:var(--bg);
  display:none;align-items:center;justify-content:center;padding:26px}
#lockScreen.show{display:flex}
body.locked .app,body.locked .dock{filter:blur(12px);pointer-events:none}
.lock-box{width:100%;max-width:330px;text-align:center;animation:rise .6s var(--ease) both}
.lock-logo{width:74px;height:74px;border-radius:24px;margin:0 auto 20px;
  background:linear-gradient(150deg,var(--lime),var(--lime2));color:var(--on-lime);
  display:grid;place-items:center;box-shadow:0 16px 44px rgba(212,246,95,.3);
  animation:float 4s ease-in-out infinite}
.lock-logo svg{width:36px;height:36px;stroke-width:2.2}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.lock-box h1{font-size:23px;font-weight:800;letter-spacing:-.03em}
.lock-box p{font-size:13.5px;color:var(--muted);margin:6px 0 22px}
.lock-form{display:flex;flex-direction:column;gap:11px}
.lock-form input{padding:15px 16px;border-radius:16px;background:var(--card);
  border:1px solid var(--line);text-align:center;font-size:16px;min-height:52px}
.lock-form input:focus{border-color:var(--lime-line);outline:none}
.lock-err{color:var(--coral);font-size:12.5px;font-weight:700;min-height:17px}
.lock-hint{margin-top:22px;font-size:11.5px;color:var(--muted)}
.lock-loading{display:flex;align-items:center;justify-content:center;gap:10px;
  color:var(--ink2);font-size:14px;font-weight:700;padding:14px}
.lock-spin{width:18px;height:18px;border-radius:50%;border:2.5px solid var(--line);
  border-top-color:var(--lime);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* back header for sub-pages */
.subhead{display:flex;align-items:center;gap:12px;margin:8px 0 4px}
.subhead .ptitle{margin:0;flex:1}
.back{width:40px;height:40px;border-radius:13px;display:grid;place-items:center;color:var(--ink2);
  background:var(--card);border:1px solid var(--line);flex-shrink:0;
  transition:transform .16s var(--spring)}
.back:active{transform:scale(.86)}
.back svg{width:19px;height:19px;stroke-width:2.2}
