/* Lifeline · Porcelain — токены и компоненты (light). Тёмная тема — позже. */
:root{
  --app:#FBFCFE; --card:#FFFFFF; --ink:#15191F; --soft:#5C6471; --faint:#A2AAB6;
  --line:#EEF1F5; --line2:#E4E8EE;
  --acc:#2E62F0; --accInk:#1E49C2; --accSoft:#E9EFFE; --green:#0EA371; --greenSoft:#E4F6EF;
  --ease-out:cubic-bezier(.23,1,.32,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:'Geist',system-ui,-apple-system,sans-serif;color:var(--ink);
  background:radial-gradient(120% 60% at 50% -5%,#EFF3F8,#E7ECF2);
  display:flex;justify-content:center}
#app{width:100%;max-width:460px;min-height:100dvh;background:var(--app);display:flex;flex-direction:column;position:relative;
  box-shadow:0 0 80px -30px rgba(30,40,60,.25)}
#screen{flex:1;padding:22px 18px 0;overflow-y:auto}
.mono{font-family:'Geist Mono',monospace;font-variant-numeric:tabular-nums}
.eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--faint)}

.top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.brand{display:flex;align-items:center;gap:9px}
.dot{width:27px;height:27px;border-radius:9px;background:var(--acc);display:grid;place-items:center;color:#fff;box-shadow:0 6px 14px -3px var(--acc)}
.dot i{font-size:15px}.brand b{font-size:15px;font-weight:600;letter-spacing:-.01em}
.top .r{display:flex;align-items:center;gap:8px;color:var(--soft);font-size:12px}
.ib{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;background:var(--card);border:1px solid var(--line2);color:var(--soft);box-shadow:0 2px 5px rgba(30,40,60,.05);cursor:pointer;transition:transform .14s var(--ease-out)}
.ib i{font-size:17px}.ib:active{transform:scale(.92)}

.card{background:var(--card);border:1px solid var(--line);border-radius:26px;padding:18px;box-shadow:0 2px 6px rgba(30,40,60,.04),0 18px 36px -24px rgba(30,40,60,.22);margin-bottom:12px}
.card.sm{border-radius:22px;padding:15px 16px;margin-bottom:0}
.tap{cursor:pointer;transition:transform .16s var(--ease-out),box-shadow .2s var(--ease-out)}
.tap:active{transform:scale(.975)}
.tap:focus-visible{outline:2px solid var(--acc);outline-offset:3px}
@media (hover:hover) and (pointer:fine){.tap:hover{transform:translateY(-2px);box-shadow:0 4px 10px rgba(30,40,60,.06),0 24px 46px -22px rgba(30,40,60,.3)}}

.h2{font-size:21px;font-weight:600;letter-spacing:-.02em;margin-top:7px}
.next{display:flex;align-items:center;justify-content:space-between;margin-top:0}
.next .big{font-family:'Geist Mono',monospace;font-size:46px;font-weight:300;letter-spacing:-.03em;line-height:.9}
.next .u{font-size:12px;color:var(--faint);text-transform:uppercase;letter-spacing:.14em;margin-top:4px;text-align:right}
.months{display:flex;justify-content:space-between;font-size:10px;letter-spacing:.1em;color:var(--faint);margin-top:10px;text-transform:uppercase}
.months b{color:var(--acc);font-weight:600}
.bento{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.lab{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--soft)}.lab i{font-size:15px;color:var(--faint)}
.val{font-size:22px;margin-top:9px;letter-spacing:-.01em;font-weight:500}.meta{font-size:12px;color:var(--faint);margin-top:5px}
.pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:3px 9px;border-radius:100px;font-weight:500;background:var(--greenSoft);color:var(--green)}
.bar{height:7px;border-radius:100px;background:var(--line2);overflow:hidden}
.bar i{display:block;height:100%;border-radius:100px;background:var(--acc);width:0;transition:width .9s var(--ease-out)}
.sec{margin:22px 4px 11px;display:flex;align-items:center;justify-content:space-between}.sec h3{font-size:13px;font-weight:600}.sec a{font-size:12px;color:var(--soft);text-decoration:none;cursor:pointer}
.row{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:12px 14px;margin-bottom:9px;box-shadow:0 2px 5px rgba(30,40,60,.04)}
.row .ic{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;flex:none}.row .ic i{font-size:18px}
.row .body{flex:1;min-width:0}.row .ttl{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row .when{font-size:12px;color:var(--faint);margin-top:1px}.row .amt{font-size:13px;text-align:right;white-space:nowrap}
.tone-acc{background:var(--accSoft);color:var(--accInk)}.tone-green{background:var(--greenSoft);color:var(--green)}.tone-mut{background:var(--line);color:var(--soft)}

.empty{color:var(--faint);text-align:center;padding:60px 20px;font-size:14px}

.tabs{position:sticky;bottom:0;padding:11px 14px calc(18px + env(safe-area-inset-bottom));background:rgba(251,252,254,.82);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--line);display:flex;justify-content:space-between}
.tab{display:flex;flex-direction:column;align-items:center;gap:5px;font-size:10px;color:var(--faint);flex:1;cursor:pointer;transition:transform .14s var(--ease-out),color .18s ease;background:none;border:none}
.tab i{font-size:21px}.tab:active{transform:scale(.9)}.tab.on{color:var(--acc)}
.tab .u2{height:2px;width:0;border-radius:2px;background:var(--acc);transition:width .2s var(--ease-out)}.tab.on .u2{width:18px}

.rv{opacity:0;transform:translateY(10px);animation:rv .45s var(--ease-out) forwards}
@keyframes rv{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.rv{animation:none;opacity:1;transform:none}.bar i{transition:none}}

/* split / mini rows */
.split{display:flex}.split .c{flex:1}.split .c+.c{border-left:1px solid var(--line);padding-left:14px}.split .c{padding-right:14px}
.k{font-size:11px;color:var(--faint);letter-spacing:.04em}
.av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:600;flex:none}
.cat{display:flex;align-items:center;gap:11px;margin-bottom:13px}.cat .nm{font-size:13px;width:88px;flex:none;color:var(--soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat .bw{flex:1}.cat .am{font-size:12px;width:60px;text-align:right}.cat:last-child{margin-bottom:0}

/* back link */
.back{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--soft);cursor:pointer;background:none;border:none;padding:6px 0;margin-bottom:6px}.back i{font-size:18px}

/* FAB */
.fab{position:absolute;right:18px;bottom:90px;width:54px;height:54px;border-radius:18px;background:var(--acc);color:#fff;border:none;display:grid;place-items:center;box-shadow:0 10px 24px -6px var(--acc);cursor:pointer;transition:transform .15s var(--ease-out);z-index:20}
.fab i{font-size:26px}.fab:active{transform:scale(.92)}

/* overlay + sheet */
.overlay{position:fixed;inset:0;background:rgba(20,25,35,.42);display:flex;align-items:flex-end;justify-content:center;z-index:50;opacity:0;animation:fade .2s ease forwards}
@keyframes fade{to{opacity:1}}
.sheet{width:100%;max-width:460px;background:var(--app);border-radius:28px 28px 0 0;padding:10px 20px calc(22px + env(safe-area-inset-bottom));max-height:92dvh;overflow-y:auto;transform:translateY(20px);animation:up .32s var(--ease-out) forwards}
@keyframes up{to{transform:none}}
.grab{width:40px;height:5px;border-radius:3px;background:var(--line2);margin:2px auto 16px}
.sheet .hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.sheet .hd .t{font-size:17px;font-weight:600}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.opt{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:15px;display:flex;flex-direction:column;gap:9px;box-shadow:0 2px 6px rgba(30,40,60,.05);cursor:pointer;transition:transform .15s var(--ease-out)}
.opt:active{transform:scale(.97)}.opt .ci{width:40px;height:40px;border-radius:12px;display:grid;place-items:center}.opt .ci i{font-size:20px}.opt b{font-size:14px;font-weight:500}.opt small{font-size:12px;color:var(--faint);margin-top:-3px}
.field{margin-bottom:14px}.field label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:7px;font-weight:500}
.input{width:100%;background:var(--card);border:1px solid var(--line2);border-radius:14px;padding:13px 14px;font-size:15px;color:var(--ink);font-family:inherit;outline:none}
.input:focus{border-color:var(--acc);box-shadow:0 0 0 3px var(--accSoft)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.seg{display:flex;background:var(--line);border-radius:14px;padding:4px;gap:4px;margin-bottom:16px}
.seg button{flex:1;padding:10px;border-radius:10px;font-size:13px;color:var(--soft);font-weight:500;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}
.seg button.on{background:var(--card);color:var(--ink);box-shadow:0 2px 5px rgba(30,40,60,.08)}.seg button.on.out{color:var(--red)}.seg button.on.in{color:var(--green)}
.amt-in{width:100%;text-align:center;border:none;outline:none;background:none;font-family:'Geist Mono',monospace;font-size:40px;font-weight:500;letter-spacing:-.02em;color:var(--ink);padding:8px 0 14px}
.amt-in.out{color:var(--red)}
.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:8px 13px;border-radius:100px;border:1px solid var(--line2);font-size:13px;color:var(--soft);background:var(--card);cursor:pointer;display:flex;align-items:center;gap:6px}.chip i{font-size:15px}.chip.on{background:var(--accSoft);border-color:transparent;color:var(--accInk);font-weight:500}
.btn{width:100%;background:var(--acc);color:#fff;border:none;border-radius:16px;padding:16px;font-size:15px;font-weight:500;box-shadow:0 10px 22px -8px var(--acc);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:transform .15s var(--ease-out)}
.btn:active{transform:scale(.98)}.btn[disabled]{opacity:.5}
.var-red{color:var(--red)}.var-green{color:var(--green)}
.danger{--acc:var(--red)}
/* задачи */
.chk{width:24px;height:24px;border-radius:8px;border:1.8px solid var(--line2);background:var(--card);display:grid;place-items:center;flex:none;cursor:pointer;color:#fff;transition:transform .14s var(--ease-out)}
.chk.done{background:var(--acc);border-color:var(--acc)}.chk i{font-size:14px}.chk:active{transform:scale(.88)}
.iconx{background:none;border:none;color:var(--faint);cursor:pointer;padding:6px 2px 6px 8px;flex:none}.iconx i{font-size:16px}
.pri{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px;vertical-align:middle}
.pri-high{background:var(--red)}.pri-med{background:var(--amber)}.pri-low{background:var(--faint)}
.due-over{color:var(--red)}
/* цели */
.gchip{display:inline-block;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accInk);background:var(--accSoft);padding:3px 9px;border-radius:100px;font-weight:600}
.ms{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px solid var(--line)}
.ms .chk{width:21px;height:21px;border-radius:7px}.ms .t{flex:1;font-size:13px}.ms .t.done{text-decoration:line-through;color:var(--faint)}
.glink{background:none;border:none;color:var(--accInk);font-size:12px;cursor:pointer;padding:8px 0 0;display:inline-flex;align-items:center;gap:5px}
