:root{--bg-main:#f8f9fa;--bg-card:#fff;--text-main:#333;--accent:#007bff}@media (prefers-color-scheme:dark){:root{--bg-main:#121212;--bg-card:#1e1e1e;--text-main:#f5f5f5;--accent:#0a84ff}}html,body{width:100%;height:100dvh;color:var(--text-main);-webkit-text-size-adjust:100%;background-color:#f1f3f5;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:fixed;overflow:hidden}.app-wrapper{background:var(--bg-main);flex-direction:column;max-width:500px;height:100dvh;margin:0 auto;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 30px #0000000d}.bottom-nav{width:100%;height:calc(60px + clamp(0px, env(safe-area-inset-bottom,0px), 15px));background:var(--bg-card);z-index:999;box-sizing:border-box;padding-bottom:clamp(0px, env(safe-area-inset-bottom,0px), 15px);border-top:1px solid #0000000f;justify-content:space-around;align-items:flex-start;display:flex;position:absolute;bottom:0;left:0}.nav-item{color:#888;cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;height:60px;margin:0;padding:0;font-size:11px;line-height:1.2;display:flex}.nav-item.active{color:var(--accent)}.nav-icon{margin-bottom:2px;font-size:20px}.float-add-btn{background:var(--accent);color:#fff;cursor:pointer;z-index:998;border:none;border-radius:28px;justify-content:center;align-items:center;width:56px;height:56px;font-size:32px;display:flex;position:absolute;bottom:80px;right:20px;box-shadow:0 4px 10px #007bff66}.timeline-container{-webkit-overflow-scrolling:touch;box-sizing:border-box;flex:1;padding:15px 15px 90px;overflow-y:auto}.summary-card{background:var(--bg-card,#fff);border-radius:12px;margin-bottom:20px;padding:15px;box-shadow:0 2px 8px #0000000d}.summary-title{color:#888;font-size:14px}.summary-amount{margin-top:5px;font-size:28px;font-weight:700}.summary-detail{border-top:1px solid #f1f3f5;justify-content:space-between;margin-top:15px;padding-top:10px;display:flex}.detail-item span{color:#888;font-size:12px;display:block}.detail-item strong{color:#333;font-size:16px}.budget-bar-container{margin-top:12px}.budget-label{color:#666;justify-content:space-between;margin-bottom:4px;font-size:11px;display:flex}.budget-track{background:#e9ecef;border-radius:3px;width:100%;height:6px;overflow:hidden}.budget-fill{background:#52c41a;border-radius:3px;height:100%;transition:width .3s}.budget-fill.warning{background:#ff9c12}.budget-fill.danger{background:#ff4d4f}.timeline-group{margin-bottom:20px}.timeline-date-header{color:#888;border-bottom:1px solid #f1f3f5;justify-content:space-between;margin-bottom:10px;padding:4px 0;font-size:12px;display:flex}.transaction-list{flex-direction:column;gap:8px;display:flex}.transaction-item{background:#fff;border-radius:10px;align-items:center;padding:12px;transition:background .2s;display:flex;box-shadow:0 1px 4px #00000005}.item-icon{margin-right:12px;font-size:22px}.item-info{flex:1}.item-cat{color:#333;font-size:14px;font-weight:500}.item-remark{color:#888;margin-top:2px;font-size:12px}.item-value{text-align:right}.item-amount{font-size:16px;font-weight:700}.item-amount.expense{color:#ff4d4f}.item-amount.income{color:#52c41a}.btn-delete{color:#999;cursor:pointer;background:0 0;border:none;margin-left:10px;font-size:14px}.btn-delete:hover{color:#ff4d4f}.no-data{text-align:center;color:#999;padding:40px 0}.stats-container{-webkit-overflow-scrolling:touch;box-sizing:border-box;flex:1;padding:15px 15px 90px;overflow-y:auto}.month-selector{background:var(--bg-card,#fff);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:10px 15px;display:flex;box-shadow:0 1px 4px #00000008}.month-btn{cursor:pointer;color:#007bff;background:0 0;border:none;font-size:16px}.chart-card{background:var(--bg-card,#fff);border-radius:12px;flex-direction:column;align-items:center;margin-bottom:20px;padding:20px;display:flex;box-shadow:0 2px 8px #0000000a}.chart-wrapper{width:200px;height:200px;margin-bottom:15px;position:relative}.chart-center{text-align:center;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.chart-center .title{color:#888;font-size:12px}.chart-center .value{color:var(--text-main,#333);font-size:18px;font-weight:700}.ranking-card{background:var(--bg-card,#fff);border-radius:12px;padding:15px;box-shadow:0 2px 8px #0000000a}.rank-title{color:var(--text-main,#333);margin-bottom:15px;font-size:14px;font-weight:700}.rank-item{align-items:center;margin-bottom:12px;display:flex}.rank-icon{margin-right:10px;font-size:20px}.rank-info{flex:1}.rank-meta{justify-content:space-between;margin-bottom:4px;font-size:13px;display:flex}.rank-cat{color:var(--text-main,#333);font-weight:500}.rank-amt{color:#555;font-weight:700}.progress-track{background:#e9ecef;border-radius:3px;height:6px}.progress-fill{background:#007bff;border-radius:3px;height:100%;transition:width .3s}.settings-container{-webkit-overflow-scrolling:touch;box-sizing:border-box;flex:1;padding:15px 15px 90px;overflow-y:auto}.settings-card{background:var(--bg-card,#fff);border-radius:12px;margin-bottom:20px;padding:15px;box-shadow:0 2px 8px #0000000a}.settings-group{margin-bottom:15px}.settings-group h3{color:var(--text-main,#333);margin-bottom:10px;font-size:14px}.settings-input{box-sizing:border-box;background:var(--bg-card,#fff);width:100%;color:var(--text-main,#333);border:1px solid #ddd;border-radius:8px;padding:10px;font-size:16px}.action-row{flex-direction:column;gap:10px;display:flex}.btn-primary,.btn-secondary,.btn-danger{cursor:pointer;text-align:center;border:none;border-radius:8px;padding:12px;font-size:14px;font-weight:700;transition:opacity .2s}.btn-primary{color:#fff;background:#007bff}.btn-secondary{color:#fff;background:#6c757d}.btn-danger{color:#fff;background:#dc3545}.btn-primary:active,.btn-secondary:active,.btn-danger:active{opacity:.8}.category-manager{margin-top:15px}.add-cat-form{gap:8px;margin-bottom:10px;display:flex}.cat-list-edit{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.cat-chip{color:#333;background:#f1f3f5;border-radius:15px;align-items:center;gap:4px;padding:6px 12px;font-size:13px;display:flex}.btn-del-chip{color:#999;cursor:pointer;background:0 0;border:none;font-size:11px}.btn-del-chip:hover{color:#ff4d4f}.drawer-overlay{z-index:1000;background:#0006;justify-content:center;align-items:flex-end;animation:.2s ease-out fadeIn;display:flex;position:absolute;inset:0}.drawer-content{background:var(--bg-card,#fff);box-sizing:border-box;border-top-left-radius:16px;border-top-right-radius:16px;width:100%;max-width:500px;padding:20px;animation:.25s cubic-bezier(.1,.76,.55,.94) slideUp}.drawer-header{justify-content:space-between;align-items:center;margin-bottom:15px;display:flex}.type-tabs{background:#eee;border-radius:8px;padding:3px;display:flex}.type-tab{cursor:pointer;color:#666;background:0 0;border:none;border-radius:6px;padding:6px 16px;font-size:14px;font-weight:700}.type-tab.active{color:#007bff;background:#fff;box-shadow:0 2px 4px #0000001a}.amount-display{text-align:right;word-wrap:break-word;color:var(--text-main,#333);border-bottom:2px solid #eee;margin-bottom:15px;padding:10px 0;font-family:monospace;font-size:32px;font-weight:700}.category-grid{grid-template-columns:repeat(4,1fr);gap:12px;max-height:140px;margin-bottom:15px;display:grid;overflow-y:auto}.category-item{cursor:pointer;background:#f8f9fa;border:1px solid #0000;border-radius:10px;flex-direction:column;align-items:center;padding:8px;display:flex}.category-item.active{background:#e6f7ff;border-color:#007bff}.category-icon{margin-bottom:4px;font-size:24px}.category-name{color:#333;font-size:12px}.extra-inputs{gap:10px;margin-bottom:15px;display:flex}.extra-inputs input{border:1px solid #ddd;border-radius:8px;padding:8px 12px;font-size:16px}.input-remark{flex:1}.input-date{width:120px}.numpad{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.num-btn{cursor:pointer;color:#333;background:#f1f3f5;border:none;border-radius:8px;padding:15px 0;font-size:20px;font-weight:700;transition:active .1s}.num-btn:active{background:#dee2e6}.num-btn.operator{color:#007bff;background:#e9ecef}.num-btn.confirm{color:#fff;background:#007bff;grid-row:span 2;height:100%}.num-btn.confirm:active{background:#0056b3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}
