/* ===== Blaivybės sezonas — Fazė 1.1 (distiliuota) ===== */
:root{
  --bg:oklch(0.96 0.012 85);
  --surface:oklch(0.99 0.008 85);
  --surface-2:oklch(0.93 0.014 80);
  --ink:oklch(0.28 0.03 312);
  --soft:oklch(0.54 0.022 312);
  --line:oklch(0.28 0.03 312 / .10);
  --line-2:oklch(0.28 0.03 312 / .16);
  --grape:oklch(0.55 0.19 295);
  --grape-2:oklch(0.66 0.16 300);
  --p:oklch(0.60 0.11 155);
  --c:oklch(0.70 0.10 72);
  --f:oklch(0.64 0.11 14);
  --r:20px; --r-lg:28px; --r-sm:13px;
  --disp:'Fraunces',Georgia,serif;
  --ui:'Hanken Grotesk',-apple-system,system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:540px;
}
html[data-theme="dark"]{
  --bg:oklch(0.18 0.022 308);
  --surface:oklch(0.23 0.026 308);
  --surface-2:oklch(0.28 0.03 308);
  --ink:oklch(0.94 0.02 320);
  --soft:oklch(0.72 0.03 316);
  --line:oklch(0.94 0.02 320 / .10);
  --line-2:oklch(0.94 0.02 320 / .17);
  --grape:oklch(0.74 0.15 300);
  --grape-2:oklch(0.82 0.12 300);
  --p:oklch(0.74 0.12 155);
  --c:oklch(0.78 0.10 72);
  --f:oklch(0.74 0.12 16);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:var(--ui); background:var(--bg); color:var(--ink); line-height:1.45;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  touch-action:manipulation; /* kills double-tap zoom + tap delay */
  padding:env(safe-area-inset-top) env(safe-area-inset-right) 0 env(safe-area-inset-left);
  background-image:radial-gradient(130% 55% at 85% -8%, color-mix(in oklab,var(--grape) 12%,transparent),transparent 60%);
  background-attachment:fixed;
  transition:background .5s,color .4s;
}
button,input,select{font-family:inherit;touch-action:manipulation}
main{max-width:var(--maxw);margin:0 auto;padding:0 18px}

/* Top */
.top{max-width:var(--maxw);margin:0 auto;padding:16px 18px 4px;display:flex;align-items:center;justify-content:space-between}
.dateline{font-size:14px;font-weight:600;color:var(--soft);text-transform:capitalize}
.top-actions{display:flex;gap:8px}
.ico{width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:17px;cursor:pointer}
.ico:active{transform:scale(.92)}

/* Hero */
.hero{padding:14px 0 4px;display:flex;flex-direction:column;align-items:center}
.ring-wrap{position:relative;width:clamp(190px,58vw,224px);aspect-ratio:1;display:grid;place-items:center}
.ring{width:100%;height:100%}
.ring-bg{fill:none;stroke:var(--surface-2);stroke-width:12}
.ring-fg{fill:none;stroke:var(--grape);stroke-width:12;stroke-linecap:round;stroke-dasharray:502.65;stroke-dashoffset:502.65;transition:stroke-dashoffset 1s var(--ease)}
.ring-fg.over{stroke:var(--f)}
.ring-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring-n{font-family:var(--disp);font-weight:900;font-size:clamp(46px,14vw,60px);line-height:.9;letter-spacing:-.02em;font-feature-settings:"tnum" 1}
.ring-n.neg{color:var(--f)}
.ring-l{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);margin-top:6px}
.ring-s{font-size:12.5px;color:var(--soft);font-weight:600;margin-top:2px;font-feature-settings:"tnum" 1}

.macros{width:100%;max-width:380px;margin-top:18px;display:flex;flex-direction:column;gap:13px}
.m-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}
.m-name{font-size:13.5px;font-weight:700}
.m-val{font-size:13px;font-weight:800;font-feature-settings:"tnum" 1}
.m-val i{font-style:normal;font-weight:600;color:var(--soft)}
.m-bar{height:6px;border-radius:99px;background:var(--surface-2);overflow:hidden}
.m-bar span{display:block;height:100%;border-radius:99px;transition:width .9s var(--ease)}
.m-p .m-bar span{background:var(--p)} .m-p .m-name{color:var(--p)}
.m-c .m-bar span{background:var(--c)}
.m-f .m-bar span{background:var(--f)}

/* Sections */
.sec{font-family:var(--disp);font-weight:600;font-size:18px;margin:26px 2px 12px;display:flex;align-items:center;gap:8px}
.count{font-family:var(--ui);font-size:12px;font-weight:700;color:var(--soft);background:var(--surface-2);border-radius:99px;padding:1px 8px}
.muted-line{color:var(--soft);font-size:14px;padding:2px 2px 6px}

/* Suggestions */
.suggest{display:flex;gap:10px;overflow-x:auto;padding:2px 2px 8px;scroll-snap-type:x mandatory}
.suggest::-webkit-scrollbar{display:none}
.sg{flex:none;width:128px;scroll-snap-align:start;text-align:left;cursor:pointer;color:var(--ink);
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:13px 13px 12px;
  display:flex;flex-direction:column;gap:3px}
.sg:active{transform:scale(.97)}
.sg-p{font-family:var(--disp);font-weight:700;font-size:22px;color:var(--p);line-height:1;font-feature-settings:"tnum" 1}
.sg-p i{font-style:normal;font-size:13px}
.sg-n{font-weight:700;font-size:13.5px;line-height:1.2;margin-top:3px}
.sg-m{font-size:11.5px;color:var(--soft);font-weight:600}

/* Log */
#logList{display:flex;flex-direction:column;gap:7px}
.li{width:100%;display:flex;align-items:center;gap:12px;cursor:pointer;text-align:left;color:var(--ink);
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:11px 8px 11px 12px;
  animation:pop .35s var(--ease)}
.li:active{transform:scale(.99)}
.li-e{font-size:20px;flex:none;width:30px;text-align:center}
.li-b{flex:1;min-width:0;display:flex;flex-direction:column}
.li-n{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.li-a{font-size:11.5px;color:var(--soft);font-weight:600}
.li-k{font-family:var(--disp);font-weight:700;font-size:16px;flex:none;font-feature-settings:"tnum" 1;display:flex;flex-direction:column;align-items:flex-end;line-height:1}
.li-k i{font-style:normal;font-size:9.5px;font-weight:600;color:var(--soft);font-family:var(--ui);letter-spacing:.04em;text-transform:uppercase}
.li-x{flex:none;width:34px;height:34px;display:grid;place-items:center;border-radius:9px;color:var(--soft);font-size:14px;opacity:.55}
.li-x:active{opacity:1;background:color-mix(in oklab,var(--f) 16%,transparent);color:var(--f)}
.empty{text-align:center;color:var(--soft);padding:26px 16px;font-weight:700;font-size:14.5px}
.empty span{font-weight:500;font-size:13px;opacity:.85}
.foot{height:100px}

/* FAB */
.fab{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(18px + env(safe-area-inset-bottom));z-index:40;
  border:none;cursor:pointer;display:flex;align-items:center;gap:7px;padding:15px 28px;border-radius:99px;
  font-weight:800;font-size:16px;color:oklch(0.99 0.01 300);background:var(--grape);
  box-shadow:0 8px 24px -6px color-mix(in oklab,var(--grape) 60%,transparent)}
.fab span{font-size:19px}
.fab:active{transform:translateX(-50%) scale(.95)}

/* Sheets */
.scrim{position:fixed;inset:0;z-index:50;background:oklch(0.15 0.02 305 / .5);opacity:0;pointer-events:none;transition:opacity .3s}
.scrim.on{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:60;max-width:var(--maxw);margin:0 auto;
  background:var(--bg);border-radius:26px 26px 0 0;border:1px solid var(--line);border-bottom:none;
  padding:8px 18px calc(22px + env(safe-area-inset-bottom));transform:translateY(102%);
  transition:transform .42s var(--ease);max-height:90vh;display:flex;flex-direction:column;overflow:hidden;
  box-shadow:0 -10px 40px -12px oklch(0.15 0.02 305 / .35)}
.sheet.on{transform:translateY(0)}
.grip{width:40px;height:5px;border-radius:99px;background:var(--line-2);margin:6px auto 14px;flex:none}
.sheet h3{font-family:var(--disp);font-weight:600;font-size:21px;margin-bottom:12px}

/* Bank sheet: sticky top + scrolling list (fixes search jank) */
.bank-top{flex:none}
.search{width:100%;padding:13px 15px;border-radius:var(--r);border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font-size:16px}
.search:focus{outline:none;border-color:var(--grape)}
.bank-actions{display:flex;gap:8px;margin:10px 0 4px}
.chip-btn{flex:1;text-align:center;padding:11px;border-radius:var(--r);border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font-weight:700;font-size:13.5px;cursor:pointer}
.chip-btn:active{transform:scale(.98);border-color:var(--grape)}
.bank-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;margin-top:8px;display:flex;flex-direction:column;gap:6px;padding-bottom:4px}
.bc{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--soft);margin:12px 2px 3px}
.bi{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line);cursor:pointer;text-align:left;color:var(--ink)}
.bi:active{transform:scale(.99);border-color:var(--grape)}
.bi-e{font-size:18px;flex:none;width:26px;text-align:center}
.bi-b{flex:1;min-width:0;display:flex;flex-direction:column}
.bi-n{font-weight:700;font-size:14px} .bi-n em{font-style:normal;color:var(--p)}
.bi-m{font-size:11.5px;color:var(--soft);font-weight:600}
.bi-p{font-family:var(--disp);font-weight:700;font-size:15px;color:var(--p);flex:none}

/* Amount */
.am-head{text-align:center;margin-bottom:16px}
.am-name{font-family:var(--disp);font-weight:600;font-size:22px}
.am-cat{font-size:12.5px;color:var(--soft);font-weight:600}
.am-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:14px}
.step{width:50px;height:50px;border-radius:15px;border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font-size:25px;cursor:pointer}
.step:active{transform:scale(.9)}
.am-field{display:flex;align-items:baseline;gap:6px;background:var(--surface);border:1px solid var(--line-2);border-radius:15px;padding:6px 16px;min-width:135px;justify-content:center}
.am-field input{width:84px;border:none;background:transparent;color:var(--ink);font-family:var(--disp);font-weight:700;font-size:32px;text-align:center}
.am-field input:focus{outline:none}
.am-field span{font-size:15px;color:var(--soft);font-weight:600}
.quick{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.qk{padding:7px 13px;border-radius:99px;border:1px solid var(--line);background:var(--surface);color:var(--soft);font-weight:700;font-size:13px;cursor:pointer}
.qk:active{border-color:var(--grape);color:var(--grape)}
.am-pv{display:flex;justify-content:space-around;padding:14px;margin-bottom:16px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line)}
.pv{text-align:center;display:flex;flex-direction:column}
.pv b{font-family:var(--disp);font-weight:700;font-size:20px;font-feature-settings:"tnum" 1}
.pv i{font-style:normal;font-size:10.5px;color:var(--soft);font-weight:700;text-transform:uppercase;letter-spacing:.03em;margin-top:1px}

/* Photo sheet */
.ph-icon{text-align:center;font-size:40px;margin:4px 0 6px}
.ph-text{color:var(--soft);font-size:14.5px;line-height:1.5;margin-bottom:18px}
.ph-text b{color:var(--ink)}

/* Buttons / forms */
.primary{width:100%;padding:15px;border:none;border-radius:var(--r);cursor:pointer;font-weight:800;font-size:16px;
  color:oklch(0.99 0.01 300);background:var(--grape);box-shadow:0 6px 18px -6px color-mix(in oklab,var(--grape) 55%,transparent)}
.primary:active{transform:scale(.98)}
.ghost{padding:11px 14px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface);color:var(--ink);font-weight:700;font-size:14px;cursor:pointer}
.ghost.danger{color:var(--f);border-color:color-mix(in oklab,var(--f) 40%,transparent)}
.f{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.f span{font-size:12px;font-weight:700;color:var(--soft);padding-left:2px}
.f input,.f select{padding:12px 13px;border-radius:var(--r-sm);border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font-size:16px}
.f input:focus,.f select:focus{outline:none;border-color:var(--grape)}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.seg{display:flex;gap:5px;background:var(--surface-2);padding:5px;border-radius:var(--r-sm);margin-bottom:12px}
.seg button{flex:1;padding:10px;border:none;border-radius:9px;background:transparent;color:var(--soft);font-weight:700;font-size:13px;cursor:pointer;transition:.2s}
.seg button.on{background:var(--surface);color:var(--ink)}
.set-row{display:flex;gap:9px;margin-top:13px}
.set-row .ghost{flex:1}
.tiny{font-size:11px;color:var(--soft);text-align:center;margin-top:14px}

/* Confetti */
.confetti{position:fixed;inset:0;z-index:80;pointer-events:none;overflow:hidden}
.confetti i{position:absolute;top:-20px;width:9px;height:13px;border-radius:2px;animation:fall var(--dur,1.5s) var(--ease) forwards}
@keyframes fall{0%{transform:translateY(-10px) rotate(0);opacity:1}100%{transform:translateY(101vh) rotate(680deg);opacity:.15}}

/* Reveal */
.reveal{opacity:0;transform:translateY(14px);animation:reveal .6s var(--ease) forwards;animation-delay:var(--d,0s)}
@keyframes reveal{to{opacity:1;transform:none}}
@keyframes pop{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
