:root{--bg: oklch(97% .004 245);--surface: oklch(99% .002 245);--surface-strong: oklch(100% 0 0);--fg: oklch(19% .012 245);--muted: oklch(52% .012 245);--soft: oklch(94% .006 245);--border: oklch(88% .006 245);--accent: oklch(56% .12 28);--income: oklch(53% .12 155);--expense: oklch(56% .12 28);--dark-card: oklch(22% .018 245);--blue-grey: oklch(48% .035 230);--sage: oklch(61% .045 150);--steel: oklch(43% .025 260);--font-display: -apple-system, BlinkMacSystemFont, "SF Pro Display", "PingFang SC", system-ui, sans-serif;--font-body: -apple-system, BlinkMacSystemFont, "SF Pro Text", "PingFang SC", system-ui, sans-serif;--font-mono: ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box}html,body,#app{width:100%;min-height:100%;margin:0}body{min-height:100vh;font-family:var(--font-body);color:var(--fg);background:radial-gradient(circle at 50% -10%,rgba(255,255,255,.92),transparent 420px),linear-gradient(180deg,#f7f9fa,#e1e5e8);display:flex;justify-content:center}button,input,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}.stage{width:min(100%,430px);min-height:100vh}.screen{position:relative;width:100%;min-height:100vh;overflow:hidden;background:radial-gradient(circle at 82% 10%,rgba(255,255,255,.95),transparent 120px),linear-gradient(180deg,var(--surface-strong) 0%,var(--bg) 68%,oklch(94% .006 245) 100%)}.page-main{position:absolute;top:0;right:0;bottom:0;left:0;padding:36px 20px 22px}.scroll{height:100%;overflow:auto;padding:2px 6px 120px;scrollbar-width:none}.scroll::-webkit-scrollbar,.sheet-body::-webkit-scrollbar{display:none}.home-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.hello small{display:block;margin-bottom:6px;color:var(--muted);font-size:13px}.hello h1{margin:0;font-family:var(--font-display);font-size:31px;line-height:1.06;letter-spacing:0;font-weight:760}.inline-count{margin:8px 0 0;color:var(--muted);font-size:13px}.avatar{width:40px;height:40px;border-radius:15px;display:grid;place-items:center;color:#fff;font-size:18px;font-weight:760;background:linear-gradient(145deg,#2c343b,#0d1217);box-shadow:0 12px 24px #15181c24,inset 0 1px #ffffff2e}.summary-card{position:relative;overflow:hidden;padding:20px;border-radius:28px;color:#fff;background:radial-gradient(circle at 86% 8%,rgba(255,255,255,.22),transparent 90px),linear-gradient(145deg,#293139,#0d1217);box-shadow:0 20px 46px #15181c2e}.summary-top,.summary-grid{position:relative;z-index:1}.summary-top{display:flex;justify-content:space-between;color:#ffffffb8;font-size:13px}.summary-total{position:relative;z-index:1;margin:18px 0}.summary-total span{display:block;margin-bottom:7px;color:#ffffffb8;font-size:13px}.summary-total strong{display:block;font-family:var(--font-display);font-size:39px;line-height:1;letter-spacing:0;font-weight:780;font-variant-numeric:tabular-nums}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.metric{padding:12px;border-radius:18px;border:1px solid rgba(255,255,255,.13);background:#ffffff1a;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.metric span{display:block;margin-bottom:5px;color:#ffffffa8;font-size:12px}.metric strong{font-size:17px;font-weight:760;font-variant-numeric:tabular-nums}.section{margin-top:16px;padding:16px;border-radius:25px;border:1px solid rgba(255,255,255,.74);background:#ffffffb8;box-shadow:0 14px 34px #15181c14,inset 0 1px #ffffffd1;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-title h2{margin:0;font-size:16px;line-height:1.2;font-weight:760;letter-spacing:0}.section-title span{color:var(--muted);font-size:12px}.records{display:grid;gap:10px}.empty-text{margin:0;padding:18px 0;color:var(--muted);text-align:center;font-size:13px}.record{display:grid;grid-template-columns:38px 1fr auto;align-items:center;gap:10px}.record-icon{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;border:1px solid color-mix(in oklch,var(--border),white 18%);background:#ffffffc2;color:var(--fg);font-size:14px;font-weight:760}.record-info{min-width:0}.record-info strong{display:block;color:var(--fg);font-size:14px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.record-info span{display:block;margin-top:4px;color:var(--muted);font-size:12px}.amount{font-size:14px;font-weight:780;font-variant-numeric:tabular-nums}.amount.income,.income-text{color:var(--income)}.amount.expense,.expense-text{color:var(--expense)}.tabbar{position:absolute;left:22px;right:22px;bottom:18px;z-index:10;height:58px;border-radius:24px;border:1px solid rgba(255,255,255,.74);background:#ffffffb3;box-shadow:0 16px 34px #15181c1a;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);display:grid;grid-template-columns:repeat(2,1fr);align-items:center;padding:0 8px}.tab{border:0;background:transparent;color:var(--muted);display:grid;place-items:center;gap:3px;font-size:11px;padding:8px 0;cursor:pointer}.tab.active{color:var(--fg)}.tab svg{width:20px;height:20px}.fab{position:absolute;right:28px;bottom:34px;z-index:12;width:70px;height:70px;border:0;border-radius:24px;display:grid;place-items:center;color:#fff;background:linear-gradient(180deg,color-mix(in oklch,var(--accent),white 12%),var(--accent));box-shadow:0 20px 32px color-mix(in oklch,var(--accent),transparent 58%),inset 0 1px #ffffff52;cursor:pointer}.fab svg{width:32px;height:32px}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;background:#0c0e1133;opacity:0;pointer-events:none;transition:opacity .24s ease}.overlay.open{opacity:1;pointer-events:auto}.sheet{position:absolute;left:10px;right:10px;bottom:10px;z-index:31;display:flex;flex-direction:column;height:620px;padding:16px;border-radius:34px;border:1px solid rgba(255,255,255,.78);background:#ffffffdb;box-shadow:0 -20px 54px #15181c2e,inset 0 1px #ffffffeb;-webkit-backdrop-filter:blur(28px);backdrop-filter:blur(28px);transform:translateY(calc(100% + 18px));transition:transform .28s cubic-bezier(.2,.9,.2,1)}.sheet.open{transform:translateY(0)}.sheet.sheet-locked{pointer-events:none}.grabber{width:42px;height:5px;margin:0 auto 14px;border-radius:999px;background:color-mix(in oklch,var(--muted),white 42%)}.sheet-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.sheet-head h2{margin:0;font-size:20px;line-height:1.2;font-weight:780;letter-spacing:0}.close{width:34px;height:34px;border:0;border-radius:13px;background:var(--soft);color:var(--muted);display:grid;place-items:center;font-size:22px;line-height:1;cursor:pointer}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;border-radius:18px;background:var(--soft);margin-bottom:14px}.segmented button{height:40px;border:0;border-radius:14px;background:transparent;color:var(--muted);font-size:14px;font-weight:720;cursor:pointer}.segmented button.active{color:#fff;background:var(--active-color);box-shadow:0 8px 18px color-mix(in oklch,var(--active-color),transparent 74%)}.sheet-body{min-height:0;overflow:auto;padding-right:2px;padding-bottom:84px;scrollbar-width:none}.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}.category{height:58px;border:1px solid var(--border);border-radius:17px;background:#ffffffbd;color:var(--fg);display:grid;place-items:center;gap:3px;cursor:pointer}.category span:first-child{font-size:17px;font-weight:780;line-height:1}.category span:last-child{font-size:12px;color:var(--muted)}.category.active{border-color:color-mix(in oklch,var(--accent),white 18%);background:color-mix(in oklch,var(--accent),white 88%)}.entry-form,.picker-panel,.confirm-body{display:grid;gap:10px}.input-row{min-height:52px;border:1px solid var(--border);border-radius:16px;background:#ffffffc7;display:grid;grid-template-columns:72px 1fr;align-items:center;padding:0 14px}.input-row label{color:var(--muted);font-size:13px}.input-row input,.input-row textarea{width:100%;border:0;outline:0;background:transparent;color:var(--fg);font-size:15px;font-weight:560}.input-row textarea{min-height:46px;padding:13px 0;resize:none}.picker-value{width:100%;border:0;outline:0;background:transparent;color:var(--fg);text-align:left;font-size:15px;font-weight:650;cursor:pointer}.picker-value.placeholder{color:color-mix(in oklch,var(--muted),white 18%);font-weight:480}.smoke-spec-row{align-items:stretch;padding-top:8px;padding-bottom:8px}.smoke-select-actions{display:grid;grid-template-columns:minmax(0,1fr) 58px;gap:8px;align-items:center}.smoke-scan-button{min-height:36px;border:0;border-radius:13px;color:#fff;background:linear-gradient(180deg,color-mix(in oklch,var(--accent),white 10%),var(--accent));font-size:13px;font-weight:760;cursor:pointer}.picker-panel{padding:14px;margin-bottom:12px;border:1px solid var(--border);border-radius:20px;background:#ffffffd1;box-shadow:0 12px 24px #15181c14}.picker-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.picker-head strong{display:block;font-size:15px}.picker-head span{display:block;margin-top:4px;color:var(--muted);font-size:12px;line-height:1.35}.picker-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-height:190px;overflow:auto}.picker-option,.picker-confirm,.picker-reset{border:0;cursor:pointer}.picker-option{min-height:40px;padding:0 12px;border-radius:14px;background:var(--soft);color:var(--fg);text-align:center;font-size:14px;font-weight:760}.picker-confirm,.picker-reset{min-height:34px;padding:0 14px;border-radius:13px;background:var(--fg);color:#fff;font-size:13px;font-weight:700}.picker-reset{background:var(--soft);color:var(--muted)}.picker-confirm{width:100%;min-height:40px;border-radius:14px;background:linear-gradient(180deg,color-mix(in oklch,var(--accent),white 12%),var(--accent))}.picker-complete p{margin:0 0 10px;color:var(--muted);font-size:13px;line-height:1.5}.barcode-scanner{display:grid;gap:12px;padding:14px;margin-bottom:12px;border:1px solid var(--border);border-radius:20px;background:#ffffffdb;box-shadow:0 12px 24px #15181c14}.barcode-scanner-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.barcode-scanner-head strong,.barcode-scanner-head span{display:block}.barcode-scanner-head strong{font-size:15px}.barcode-scanner-head span{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.35}.barcode-cancel{min-height:34px;padding:0 14px;border:0;border-radius:13px;color:var(--muted);background:var(--soft);font-size:13px;font-weight:700;cursor:pointer}.barcode-preview{position:relative;overflow:hidden;aspect-ratio:4 / 5;min-height:260px;border-radius:18px;background:#101817}.barcode-video{width:100%;height:100%;display:block;object-fit:cover}.barcode-guide{position:absolute;top:18%;right:18%;bottom:18%;left:18%;border:2px solid rgba(255,255,255,.88);border-radius:14px;pointer-events:none}.barcode-guide span{position:absolute;left:12%;right:12%;top:50%;height:2px;background:#34d399;box-shadow:0 0 12px #34d399b3}.barcode-error,.barcode-matching{margin:0;padding:10px 12px;border-radius:14px;font-size:12px;line-height:1.45}.barcode-error{color:var(--expense);background:color-mix(in oklch,var(--expense),white 91%);border:1px solid color-mix(in oklch,var(--expense),white 76%)}.barcode-matching{margin-bottom:12px;color:var(--accent);background:color-mix(in oklch,var(--accent),white 91%);border:1px solid color-mix(in oklch,var(--accent),white 76%)}.barcode-action{min-height:42px;border:0;border-radius:15px;color:#fff;background:linear-gradient(180deg,color-mix(in oklch,var(--fg),white 10%),var(--fg));font-size:14px;font-weight:760;cursor:pointer}.barcode-action:disabled{cursor:progress;opacity:.72}.save{position:absolute;left:16px;right:16px;bottom:16px;height:52px;border:0;border-radius:18px;color:#fff;background:linear-gradient(180deg,color-mix(in oklch,var(--income),white 10%),var(--income));font-size:16px;font-weight:760;box-shadow:0 16px 28px color-mix(in oklch,var(--income),transparent 72%);cursor:pointer}.confirm-sheet{position:absolute;left:10px;right:10px;bottom:10px;z-index:32;padding:16px;border-radius:30px;border:1px solid rgba(255,255,255,.78);background:#ffffffe6;box-shadow:0 -20px 54px #15181c2e,inset 0 1px #ffffffeb;-webkit-backdrop-filter:blur(28px);backdrop-filter:blur(28px)}.confirm-subtitle{margin:6px 0 0;color:var(--muted);font-size:12px}.confirm-row{min-height:46px;padding:0 14px;border:1px solid var(--border);border-radius:16px;background:#ffffffc7;display:flex;align-items:center;justify-content:space-between;gap:12px}.confirm-row span{color:var(--muted);font-size:13px}.confirm-row strong{color:var(--fg);font-size:15px;font-weight:720;text-align:right}.confirm-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:14px}.confirm-actions button{min-height:46px;border:0;border-radius:16px;font-size:14px;font-weight:720;cursor:pointer}.confirm-cancel{color:var(--fg);background:var(--soft)}.confirm-save{color:#fff;background:linear-gradient(180deg,color-mix(in oklch,var(--income),white 10%),var(--income))}.filter-section{display:grid;gap:14px}.segment-control,.records-total-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.segment-control{padding:6px;border-radius:18px;background:color-mix(in oklch,var(--soft),white 18%);border:1px solid rgba(255,255,255,.72)}.segment-button{min-height:36px;border:0;border-radius:14px;background:transparent;color:var(--muted);font-size:13px;font-weight:650}.segment-button.active{background:#ffffffeb;color:var(--fg);box-shadow:0 8px 18px #15181c14}.date-grid{display:grid;gap:10px}.date-field{display:grid;gap:6px;color:var(--muted);font-size:12px}.date-field input{width:100%;min-height:42px;padding:0 14px;border-radius:16px;border:1px solid rgba(255,255,255,.76);background:#fffc;color:var(--fg);outline:none}.quick-filters{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{min-width:68px;min-height:34px;padding:0 14px;border:0;border-radius:14px;color:var(--muted);background:var(--soft)}.filter-chip.active{color:#fff;background:var(--fg)}.records-total-strip{grid-template-columns:repeat(2,1fr)}.records-total-card{min-height:70px;padding:14px;border-radius:20px;background:#ffffffc2;border:1px solid var(--border)}.records-total-card span{color:var(--muted);font-size:12px}.records-total-card strong{display:block;margin-top:8px;font-size:20px;font-weight:780}.record-group{display:grid;gap:10px;margin-top:14px}.record-group-date{color:var(--muted);font-size:12px;font-weight:700}.record-shell{border-radius:18px;background:#ffffffb3;border:1px solid var(--border)}.record-action{width:100%;border:0;background:transparent;padding:12px;text-align:left;cursor:pointer}.record-detail{padding:0 14px 14px}.detail-grid{display:grid;gap:8px}.detail-row{display:flex;justify-content:space-between;gap:12px;margin:0;color:var(--muted);font-size:12px}.detail-row dd{margin:0;color:var(--fg);text-align:right}.login-screen{min-height:100vh;background:radial-gradient(circle at 76% 12%,rgba(255,255,255,.95),transparent 128px),linear-gradient(180deg,#fffbf6,#fdf3e8 72%,#f4ede4)}.login-main{position:relative;z-index:2;min-height:100vh;padding:54px 26px 28px;display:flex;flex-direction:column}.brand{padding-top:20px}.brand-mark{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;color:#fffbf6;font-family:var(--font-display);font-size:29px;font-weight:700;background:linear-gradient(145deg,#3b2d24,#1a120c);box-shadow:inset 0 1px #ffffff38,0 16px 30px #4331252e}.brand h1{margin:24px 0 8px;font-family:var(--font-display);font-size:42px;line-height:1.05;font-weight:700;letter-spacing:0;color:var(--fg)}.deck{margin:0;max-width:270px;color:var(--muted);font-size:15px;line-height:1.65;letter-spacing:0}.line-art{position:absolute;left:24px;right:24px;top:238px;height:82px;opacity:.42;pointer-events:none}.line-art svg{width:100%;height:100%;overflow:visible}.login-panel{margin-top:auto;padding:18px;border-radius:26px;border:1px solid rgba(255,255,255,.76);background:#ffffff9e;box-shadow:0 18px 48px #3a2f271a,inset 0 1px #ffffffc7;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.field-group{display:grid;gap:12px}.field{height:56px;border:1px solid color-mix(in oklch,var(--border),var(--fg) 4%);border-radius:16px;background:#ffffffbd;display:flex;align-items:center;padding:0 15px;transition:border-color .2s ease,background .2s ease}.field:focus-within{border-color:color-mix(in oklch,var(--accent),white 10%);background:#ffffffeb}.field label{width:58px;flex:0 0 auto;color:var(--muted);font-size:14px}.field input{width:100%;border:0;outline:0;background:transparent;color:var(--fg);font:500 16px/1.2 var(--font-body);letter-spacing:0}.field input::placeholder{color:color-mix(in oklch,var(--muted),white 26%);font-weight:400}.captcha-row{display:grid;grid-template-columns:1fr 104px;gap:10px}.captcha-row .field label{width:44px}.captcha-code{height:56px;width:100%;padding:0;border:1px solid color-mix(in oklch,var(--border),var(--fg) 5%);border-radius:16px;background:repeating-linear-gradient(-12deg,rgba(61,49,40,.05) 0 8px,transparent 8px 16px),#ffffffb8;display:grid;place-items:center;color:var(--fg);font-family:ui-monospace,JetBrains Mono,Menlo,monospace;font-size:18px;font-weight:700;letter-spacing:.08em;-webkit-user-select:none;user-select:none;cursor:pointer;overflow:hidden}.captcha-code img{width:100%;height:100%;object-fit:cover}.options{margin:14px 2px 8px;min-height:28px;display:flex;align-items:center;justify-content:space-between;color:var(--muted);font-size:14px}.remember{display:inline-flex;align-items:center;gap:9px;cursor:pointer}.remember input{position:absolute;opacity:0;pointer-events:none}.check{width:20px;height:20px;border-radius:7px;border:1px solid color-mix(in oklch,var(--border),var(--fg) 18%);background:#ffffffb8;display:grid;place-items:center;transition:all .18s ease}.check svg{width:13px;height:13px;opacity:0;transform:scale(.82);transition:all .18s ease}.remember input:checked+.check{border-color:var(--accent);background:var(--accent)}.remember input:checked+.check svg{opacity:1;transform:scale(1)}.secure{font-size:12px;color:color-mix(in oklch,var(--muted),white 12%)}.submit{width:100%;height:56px;border:0;border-radius:18px;color:#fff;font:700 17px/1 var(--font-body);background:linear-gradient(180deg,color-mix(in oklch,var(--accent),white 12%),var(--accent));box-shadow:0 16px 30px color-mix(in oklch,var(--accent),transparent 66%),inset 0 1px #ffffff47;cursor:pointer;letter-spacing:0}.submit:disabled,.confirm-actions button:disabled{cursor:not-allowed;opacity:.68}.api-error{margin:-4px 0 12px;padding:10px 12px;border-radius:14px;color:var(--expense);background:color-mix(in oklch,var(--expense),white 91%);border:1px solid color-mix(in oklch,var(--expense),white 76%);font-size:12px;line-height:1.45}.bottom-note{margin:16px 0 0;text-align:center;color:color-mix(in oklch,var(--muted),white 8%);font-size:12px;line-height:1.5}.bottom-note a{color:inherit;text-decoration:none}.error-text{min-height:20px;margin:0 0 10px;color:var(--expense);font-size:13px}.beian-footer{position:absolute;left:0;right:0;bottom:10px;text-align:center;font-size:11px;color:color-mix(in oklch,var(--muted),white 20%)}.beian-footer a{color:inherit;text-decoration:none}
