.items-app{max-width:480px;margin:0 auto;min-height:100vh;padding:0 12px 32px;background:#f5f5f7;color:#1d1d1f}.items-header{padding:16px 4px 12px}.items-header-top{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:start}.items-header-label{margin:0;font-size:13px;color:#86868b}.items-header-value{margin:4px 0 0;font-size:28px;font-weight:700;letter-spacing:-.5px}.items-header-sub{margin:4px 0 0;font-size:20px;font-weight:700;text-align:right}.items-header-right{text-align:right}.items-add-btn{width:40px;height:40px;border:none;border-radius:12px;background:#1d1d1f;color:#fff;font-size:24px;line-height:1;cursor:pointer}.items-status-summary{margin-top:16px;display:flex;flex-direction:column;gap:8px}.items-status-row{display:grid;grid-template-columns:88px 1fr;gap:10px;align-items:center;font-size:12px;color:#86868b}.items-status-bar{height:6px;background:#e5e5ea;border-radius:999px;overflow:hidden}.items-status-bar i{display:block;height:100%;border-radius:999px}.items-status-bar i.active{background:#34c759}.items-status-bar i.retired{background:#ff9500}.items-status-bar i.sold{background:#aeaeb2}.items-categories{display:flex;gap:8px;overflow-x:auto;padding:8px 0 12px;-webkit-overflow-scrolling:touch}.items-category{flex-shrink:0;border:none;background:#fff;border-radius:12px;padding:10px 14px;font-size:13px;font-weight:600;color:#1d1d1f;box-shadow:0 1px 3px #0000000f;cursor:pointer;display:flex;align-items:center;gap:4px}.items-category.active{background:#1d1d1f;color:#fff}.items-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.items-filters{display:flex;gap:8px;overflow-x:auto}.items-filter{flex-shrink:0;border:none;background:#fff;border-radius:999px;padding:8px 14px;font-size:13px;color:#86868b;cursor:pointer}.items-filter.active{background:#1d1d1f;color:#fff;font-weight:600}.items-toolbar-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;position:relative}.items-icon-btn{width:32px;height:32px;border:none;border-radius:8px;background:#fff;color:#636366;font-size:16px;cursor:pointer;box-shadow:0 1px 3px #0000000f}.items-icon-btn.active{background:#1d1d1f;color:#fff}.items-sort-wrap{position:relative}.items-sort-menu{position:absolute;top:36px;right:0;z-index:20;min-width:140px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:6px;display:flex;flex-direction:column;gap:2px}.items-sort-menu button{border:none;background:transparent;text-align:left;padding:8px 10px;border-radius:8px;font-size:13px;cursor:pointer}.items-sort-menu button.active,.items-sort-menu button:hover{background:#f2f2f7}.items-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.items-grid.list{grid-template-columns:1fr}.items-grid.list .item-card{display:grid;grid-template-columns:120px 1fr}.items-grid.list .item-card-media{aspect-ratio:auto;min-height:120px}.items-count{font-size:12px;color:#86868b;flex-shrink:0;min-width:36px;text-align:right}.item-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 10px #0000000d}.item-card-media{position:relative;aspect-ratio:1;background:#f2f2f7;display:block;width:100%;padding:0;border:none;cursor:pointer;text-align:left}.item-card-media-btn:focus-visible{outline:2px solid #007aff;outline-offset:-2px}.item-card-media img{width:100%;height:100%;object-fit:cover}.item-card-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;font-size:28px;font-weight:700;color:#c7c7cc}.item-card-placeholder-text{font-size:28px}.item-card-add-image{font-size:12px;font-weight:600;color:#007aff}.item-card-change-image{position:absolute;left:8px;bottom:8px;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:600;color:#fff;background:#00000073}.item-status-badge{position:absolute;top:8px;right:8px;display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:600;background:#ffffffeb}.item-status-badge i{width:6px;height:6px;border-radius:50%;display:inline-block}.item-status-badge.active i{background:#34c759}.item-status-badge.retired i{background:#ff9500}.item-status-badge.sold i{background:#aeaeb2}.item-card-body{padding:10px}.item-card-body h3{margin:0 0 6px;font-size:13px;font-weight:700;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.item-card-meta{display:flex;justify-content:space-between;align-items:flex-start;gap:6px;font-size:11px;color:#86868b}.item-card-meta>span:first-child{display:flex;flex-direction:column;gap:2px;color:#1d1d1f;font-weight:600;flex:1;min-width:0}.item-card-sub{font-size:10px;font-weight:400;color:#86868b;line-height:1.3}.items-sold-summary{margin:0 0 12px;font-size:14px;color:#636366}.items-sold-summary strong{color:#1d1d1f}.item-daily-cost{margin:8px 0 6px;font-size:18px;font-weight:700;color:#1d1d1f}.item-progress-track{height:4px;background:#e5e5ea;border-radius:999px;overflow:hidden}.item-progress-fill{height:100%;background:#34c759;border-radius:999px}.item-remain{margin:6px 0 0;font-size:11px;color:#86868b}.item-remain.muted{margin-top:8px}.item-actions{display:flex;gap:6px;margin-top:8px}.item-action{flex:1;border:none;border-radius:8px;padding:6px 0;font-size:12px;font-weight:600;cursor:pointer}.item-action.retire{background:#fff3e0;color:#e65100}.item-action.sold{background:#f2f2f7;color:#636366}.item-delete{margin-top:8px;border:none;background:transparent;color:#ff3b30;font-size:11px;cursor:pointer;padding:0}.items-hint{font-size:13px;color:#86868b;text-align:center;padding:8px 0}.items-hint.error{color:#ff3b30}.items-empty{text-align:center;color:#86868b;font-size:14px;padding:40px 0}.items-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#00000059;display:flex;align-items:flex-end;justify-content:center;padding:16px}.items-modal{width:100%;max-width:480px;max-height:90vh;overflow:auto;background:#fff;border-radius:20px 20px 16px 16px;padding:20px 16px 16px}.items-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.items-modal-header h2{margin:0;font-size:18px}.items-modal-close{border:none;background:#f2f2f7;width:32px;height:32px;border-radius:50%;font-size:22px;color:#86868b;cursor:pointer}.items-modal label{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;font-size:13px;font-weight:600;color:#86868b}.items-modal input,.items-modal select{border:1px solid #e5e5ea;border-radius:10px;padding:10px 12px;font-size:15px;color:#1d1d1f}.items-error{color:#ff3b30;font-size:13px;margin:0 0 12px}.items-modal-actions{display:flex;gap:10px;margin-top:8px}.items-modal-actions .btn-secondary,.items-modal-actions .btn-primary{flex:1;border:none;border-radius:12px;padding:12px;font-size:15px;font-weight:600;cursor:pointer}.items-modal-actions .btn-secondary{background:#f2f2f7}.items-modal-actions .btn-primary{background:#007aff;color:#fff}.items-modal-actions .btn-danger{flex:1;border:none;border-radius:12px;padding:12px;font-size:15px;font-weight:600;cursor:pointer;background:#fff0f0;color:#ff3b30}.items-image-modal .items-image-item-name{margin:0 0 12px;font-size:14px;font-weight:600;color:#1d1d1f}.items-image-preview{aspect-ratio:1;border-radius:12px;overflow:hidden;background:#f2f2f7;margin-bottom:12px}.items-image-preview img{width:100%;height:100%;object-fit:cover}.items-image-preview-empty{width:100%;height:100%;min-height:200px;display:flex;align-items:center;justify-content:center;font-size:13px;color:#86868b}.items-image-pick{margin-bottom:12px}.items-image-pick-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.items-image-pick-btn{border:none;border-radius:12px;padding:12px 10px;font-size:14px;font-weight:600;background:#f2f2f7;color:#1d1d1f;cursor:pointer}.items-image-pick-btn:disabled{opacity:.5;cursor:not-allowed}.items-image-input-hidden{display:none}.items-image-url-details{margin-bottom:12px;font-size:13px;color:#86868b}.items-image-url-details summary{cursor:pointer;margin-bottom:8px;-webkit-user-select:none;user-select:none}.items-form-preview{margin-bottom:12px;aspect-ratio:16 / 10;min-height:0}@media (min-width: 481px){.items-modal-overlay{align-items:center}.items-modal{border-radius:20px}}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Segoe UI,sans-serif;background:#f5f5f7;color:#1d1d1f;-webkit-font-smoothing:antialiased}.app{max-width:480px;margin:0 auto;min-height:100vh;padding:0 16px 32px}.header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 0 8px;background:#f5f5f7eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.month-picker{display:flex;gap:8px}.month-picker select{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:#fff;border-radius:10px;padding:8px 12px;font-size:15px;font-weight:600;color:#1d1d1f;box-shadow:0 1px 3px #0000000f}.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.person-tabs{display:flex;gap:8px;overflow-x:auto;padding:0 0 8px;-webkit-overflow-scrolling:touch}.person-tab{flex-shrink:0;border:none;background:#fff;border-radius:999px;padding:8px 14px;font-size:14px;font-weight:600;color:#86868b;box-shadow:0 1px 3px #0000000f;cursor:pointer}.person-tab.active{background:#1d1d1f;color:#fff}.settings-btn{border:none;background:#fff;border-radius:10px;padding:8px 12px;font-size:13px;font-weight:600;color:#1d1d1f;box-shadow:0 1px 3px #0000000f;cursor:pointer}.settings-btn:active{transform:scale(.98)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:flex-end;justify-content:center;padding:16px;background:#00000059}.modal-panel{width:100%;max-width:480px;max-height:min(85vh,640px);overflow:auto;background:#fff;border-radius:20px 20px 16px 16px;padding:20px 16px 16px;box-shadow:0 8px 32px #00000026}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.modal-header h2{margin:0;font-size:18px;font-weight:700}.modal-close{border:none;background:#f2f2f7;width:32px;height:32px;border-radius:50%;font-size:22px;line-height:1;color:#86868b;cursor:pointer}.modal-desc{margin:0 0 16px;font-size:13px;color:#86868b;line-height:1.5}.budget-table-head,.budget-table-body li{display:grid;grid-template-columns:1fr 96px 52px;gap:8px;align-items:center}.budget-table-head{margin-bottom:8px;font-size:12px;font-weight:600;color:#86868b}.budget-table-body{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.budget-table-body input{width:100%;border:1px solid #e5e5ea;border-radius:10px;padding:10px 12px;font-size:15px;color:#1d1d1f;background:#fff}.budget-table-body input:focus{outline:none;border-color:#007aff}.budget-row-delete{border:none;background:transparent;color:#ff3b30;font-size:13px;font-weight:600;cursor:pointer;padding:8px 0}.budget-add-row{width:100%;margin-top:12px;border:1px dashed #c7c7cc;background:#fafafa;border-radius:12px;padding:12px;font-size:14px;font-weight:600;color:#007aff;cursor:pointer}.modal-error{margin:12px 0 0;font-size:13px;color:#ff3b30}.modal-hint{margin:12px 0 0;font-size:13px;color:#86868b;line-height:1.4}.modal-actions{display:flex;gap:10px;margin-top:16px}.btn-secondary,.btn-primary{flex:1;border:none;border-radius:12px;padding:12px;font-size:15px;font-weight:600;cursor:pointer}.btn-secondary{background:#f2f2f7;color:#1d1d1f}.btn-primary{background:#007aff;color:#fff}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}@media (min-width: 481px){.modal-overlay{align-items:center}.modal-panel{border-radius:20px}}.hint{font-size:12px;color:#86868b}.hint.error{color:#ff3b30}.main{display:flex;flex-direction:column;gap:16px}.hero{background:#fff;border-radius:20px;padding:24px 20px;box-shadow:0 2px 12px #0000000a;text-align:center}.hero-label{margin:0;font-size:14px;color:#86868b}.hero-amount{margin:8px 0 16px;font-size:44px;font-weight:700;letter-spacing:-1px;line-height:1.1}.status-pill{display:inline-block;padding:6px 14px;border-radius:999px;font-size:14px;font-weight:600}.status-pill.ok{background:#e8f8ef;color:#1a7f4b}.status-pill.over{background:#ffeceb;color:#d70015}.hero-sub{margin:14px 0 16px;font-size:13px;color:#86868b}.overall-bar{height:8px;background:#e5e5ea;border-radius:999px;overflow:hidden}.overall-bar-fill{height:100%;background:#34c759;border-radius:999px;transition:width .3s ease}.overall-bar-fill.over{background:#ff3b30}.overall-meta{margin:10px 0 0;font-size:12px;color:#86868b}.section{background:#fff;border-radius:20px;padding:16px;box-shadow:0 2px 12px #0000000a}.section h2{margin:0 0 10px;font-size:17px;font-weight:600}.chart-section{padding-bottom:12px}.cat-chart{height:240px;display:flex;flex-direction:column}.cat-chart-body{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-height:0;overflow:visible}.cat-chart-row{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:8px;height:20px}.cat-chart-label{font-size:11px;font-weight:600;color:#1d1d1f;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-chart-track{position:relative;height:10px;background:#f2f2f7;border-radius:4px;overflow:visible}.cat-chart-track .bar{position:absolute;left:0;top:0;height:100%;border-radius:4px;transition:width .3s ease;z-index:2}.cat-chart-track .bar.spent[data-tone=ok]{background:#34c759}.cat-chart-track .bar.spent[data-tone=near]{background:#ff9500}.cat-chart-track .bar.spent[data-tone=over]{background:#ff3b30}.cat-chart-track .marker.expected{position:absolute;top:-2px;bottom:-2px;width:2px;margin-left:-1px;background:#aeaeb2;border-radius:1px;z-index:3;pointer-events:none}.cat-chart-val{font-size:10px;font-weight:600;text-align:right;color:#1d1d1f;white-space:nowrap;min-width:72px}.cat-chart-val.ok{color:#1a7f4b}.cat-chart-val.near{color:#c93400}.cat-chart-val.over{color:#d70015}.chart-empty{margin:0;padding:40px 0;text-align:center;font-size:13px;color:#86868b}.toggle-records{width:100%;display:flex;justify-content:space-between;align-items:center;border:none;background:transparent;padding:0;font-size:15px;font-weight:600;color:#1d1d1f;cursor:pointer}.toggle-records span{font-size:13px;font-weight:400;color:#86868b}.record-list{list-style:none;margin:12px 0 0;padding:0;border-top:1px solid #e5e5ea}.record-list li{padding:12px 0;border-bottom:1px solid #f0f0f2}.record-main{display:flex;justify-content:space-between;gap:12px}.record-desc{font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.record-amount{font-size:15px;font-weight:600;flex-shrink:0}.record-sub{margin-top:4px;font-size:12px;color:#86868b}@media (min-width: 481px){body{padding-top:16px}}
