*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}:root{--primary:#007aff;--primary-light:#e8f2ff;--danger:#ff3b30;--danger-light:#fff0ef;--warning:#ff9500;--warning-light:#fff8ed;--caution:#ff9500;--success:#34c759;--success-light:#edfbf1;--gray-50:#f2f2f7;--gray-100:#e5e5ea;--gray-200:#d1d1d6;--gray-300:#c7c7cc;--gray-400:#aeaeb2;--gray-500:#8e8e93;--gray-600:#636366;--gray-700:#48484a;--gray-800:#2c2c2e;--gray-900:#1c1c1e;--radius:12px;--card-radius:14px;--shadow-sm:0 1px 2px #0000000a;--shadow:0 2px 8px #0000000f;--shadow-lg:0 8px 30px #0000001f}body{background:var(--gray-50);color:var(--gray-900);overscroll-behavior:none;-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Hiragino Sans,Hiragino Kaku Gothic ProN,sans-serif;font-size:15px;line-height:1.5}.pull-indicator{background:var(--gray-50);flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;overflow:hidden}.pull-icon-wrapper{justify-content:center;align-items:center;width:28px;height:28px;display:flex}.pull-arrow{color:var(--gray-500);font-size:18px}.pull-loading-spinner{border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.pull-text{color:var(--gray-500);font-size:12px;font-weight:500}.pull-text.refreshing{color:var(--primary)}.login-screen{background:linear-gradient(160deg,#007aff 0%,#5856d6 50%,#af52de 100%);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.login-card{-webkit-backdrop-filter:blur(20px);width:100%;max-width:340px;box-shadow:var(--shadow-lg);text-align:center;background:#fffffff2;border-radius:20px;padding:44px 28px}.login-card h1{color:var(--gray-900);letter-spacing:-.3px;margin-bottom:4px;font-size:24px;font-weight:700}.login-subtitle{color:var(--gray-500);margin-bottom:28px;font-size:14px}.login-card input{border-radius:var(--radius);background:var(--gray-50);border:none;outline:none;width:100%;margin-bottom:14px;padding:14px 16px;font-size:16px;transition:box-shadow .2s}.login-card input:focus{box-shadow:0 0 0 3px #007aff4d}.login-card button{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;width:100%;padding:15px;font-size:16px;font-weight:600;transition:opacity .2s}.login-card button:disabled{opacity:.4}.login-error{color:var(--danger);margin-top:12px;font-size:13px}.app-header{z-index:100;-webkit-backdrop-filter:blur(20px);background:#ffffffd9;border-bottom:.5px solid #0000001a;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;top:0}.app-header h1{letter-spacing:-.2px;font-size:17px;font-weight:700}.header-actions{align-items:center;gap:8px;display:flex}.help-btn{background:var(--gray-50);width:28px;height:28px;color:var(--gray-500);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.mode-btn{background:var(--primary-light);color:var(--primary);cursor:pointer;border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;transition:all .2s}.mode-btn.active{background:var(--primary);color:#fff}.logout-btn{color:var(--gray-500);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 10px;font-size:12px}.mode-banner{background:var(--primary-light);color:var(--primary);text-align:center;padding:8px;font-size:13px;font-weight:500}.filter-bar{-webkit-backdrop-filter:blur(20px);background:#ffffffd9;gap:0;padding:8px 16px;display:flex}.filter-btn{color:var(--gray-500);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:7px 8px;font-size:13px;font-weight:500;transition:all .2s}.filter-btn.active{color:var(--gray-900);background:#fff;font-weight:600;box-shadow:0 1px 4px #0000001a}.bulk-actions{gap:8px;padding:8px 12px;display:flex}.bulk-btn{cursor:pointer;border:none;border-radius:10px;flex:1;padding:8px;font-size:13px;font-weight:600}.bulk-add{background:var(--success-light);color:var(--success)}.bulk-clear{background:var(--gray-50);color:var(--gray-500)}.loading{min-height:100dvh;color:var(--gray-500);justify-content:center;align-items:center;font-size:15px;display:flex}.categories-list{flex-direction:column;gap:10px;padding:8px 12px 80px;display:flex}.category-section{border-radius:var(--card-radius);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.category-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:11px 14px;display:flex;position:relative}.category-color-bar{border-radius:2px;flex-shrink:0;width:4px;height:24px}.category-delete-btn{border:1px solid var(--danger);color:var(--danger);cursor:pointer;background:#fff;border-radius:6px;margin-left:auto;padding:4px 10px;font-size:11px}.category-delete-btn.confirm{background:var(--danger);color:#fff;font-weight:600}.collapse-icon{color:var(--gray-400);text-align:center;width:14px;font-size:9px;transition:transform .2s}.collapse-icon.collapsed{transform:rotate(-90deg)}.category-name{color:var(--gray-800);letter-spacing:-.1px;font-size:15px;font-weight:600}.needed-badge{color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:700;display:flex}.category-items{padding-bottom:2px}.group-label{text-transform:uppercase;letter-spacing:.5px;opacity:.8;padding:6px 14px 2px 58px;font-size:11px;font-weight:600}.item-row-wrapper{position:relative;overflow:hidden}.item-row-wrapper.needed{background:var(--danger-light)}.swipe-bg{color:#fff;letter-spacing:.3px;align-items:center;padding:0 24px;font-size:13px;font-weight:600;display:flex;position:absolute;inset:0}.swipe-bg.right{justify-content:flex-end}.swipe-bg-needed{background:var(--success)}.swipe-bg-purchase,.swipe-bg-edit{background:var(--primary)}.swipe-bg-delete{background:var(--danger)}.item-row{-webkit-user-select:none;user-select:none;z-index:1;background:#fff;align-items:center;gap:0;padding:6px 14px;display:flex;position:relative}.item-row.needed{background:var(--danger-light)}.item-tap-target{cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;margin-right:4px;display:flex}.item-tap-target:active{background:#0000000a}.item-status{flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.status-needed{background:var(--danger);border-radius:50%;width:22px;height:22px;position:relative}.status-needed:after{content:"";background:#fff;border-radius:50%;width:8px;height:8px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.status-edit{border:2px solid var(--primary);background:var(--primary-light);border-radius:6px;width:22px;height:22px}.edit-mode-row{background:#fff!important}.item-edit-icon{color:var(--gray-400);flex-shrink:0}.edit-chevron{font-size:20px;line-height:1}.item-type-toggle{background:var(--gray-100);border-radius:8px;flex-shrink:0;gap:0;padding:2px;display:flex}.type-btn{color:var(--gray-500);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:500;line-height:1.2;transition:all .2s}.type-btn.active{color:var(--primary);background:#fff;font-weight:600;box-shadow:0 1px 3px #0000001a}.status-done{border:2px solid var(--gray-300);background:#fff;border-radius:50%;width:22px;height:22px;transition:border-color .15s}.item-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.item-name{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.1px;font-size:15px;overflow:hidden}.item-row.needed .item-name{color:var(--gray-900);font-weight:600}.item-qty-label{color:var(--gray-500);font-size:11px}.item-memo{color:var(--primary);white-space:nowrap;text-overflow:ellipsis;opacity:.8;font-size:11px;overflow:hidden}.item-purchase-info{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;padding:4px 0 4px 8px}.purchase-summary{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.purchase-detail{color:var(--gray-500);white-space:nowrap;font-size:10px}.no-purchase{color:var(--gray-400);font-size:11px}.days-badge{color:var(--gray-500);background:var(--gray-50);white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:12px;font-weight:500}.days-badge.days-caution{background:var(--warning-light);color:var(--warning);font-weight:600}.days-badge.days-warning{background:var(--danger-light);color:var(--danger);font-weight:700}.add-item-btn{cursor:pointer;text-align:center;background:0 0;border:none;width:100%;padding:10px;font-size:13px;font-weight:500}.show-hidden-btn{width:100%;color:var(--gray-500);cursor:pointer;text-align:center;background:0 0;border:none;padding:6px;font-size:12px}.bottom-actions{padding:10px 12px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0));-webkit-backdrop-filter:blur(20px);z-index:100;background:#ffffffd9;border-top:.5px solid #0000001a;position:fixed;bottom:0;left:0;right:0}.add-category-btn{border:1.5px dashed var(--gray-300);border-radius:var(--radius);width:100%;color:var(--gray-500);cursor:pointer;background:#fff;padding:12px;font-size:14px}.dialog-overlay{-webkit-backdrop-filter:blur(4px);z-index:200;-webkit-overflow-scrolling:touch;padding-top:max(40px, env(safe-area-inset-top,40px));padding-bottom:env(safe-area-inset-bottom,0);background:#0000004d;justify-content:center;align-items:flex-start;animation:.15s fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.dialog{background:#fff;border-radius:20px;width:calc(100% - 24px);max-width:480px;margin-bottom:40px;padding:24px 20px;animation:.25s cubic-bezier(.32,.72,0,1) slideDown}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.dialog h3{color:var(--gray-900);letter-spacing:-.2px;margin-bottom:14px;font-size:18px;font-weight:700}.dialog-item-name{color:var(--gray-700);margin-bottom:16px;font-size:15px}.dialog-quantity-hint{color:var(--gray-500);margin-top:-12px;margin-bottom:16px;font-size:12px}.dialog-loading,.dialog-empty{text-align:center;color:var(--gray-500);padding:20px 0;font-size:14px}.quantity-input{margin-bottom:20px}.quantity-input label{color:var(--gray-600);margin-bottom:8px;font-size:13px;display:block}.quantity-controls{justify-content:center;align-items:center;gap:20px;display:flex}.quantity-controls button{background:var(--gray-50);cursor:pointer;width:44px;height:44px;color:var(--gray-700);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:background .15s;display:flex}.quantity-controls button:active{background:var(--gray-200)}.quantity-controls button:disabled{opacity:.3}.quantity-value{text-align:center;letter-spacing:-.5px;min-width:48px;font-size:32px;font-weight:700}.dialog-actions{gap:8px;margin-top:16px;display:flex}.dialog-actions-right{gap:8px;margin-left:auto;display:flex}.btn-cancel{border-radius:var(--radius);background:var(--gray-50);color:var(--gray-700);cursor:pointer;border:none;padding:12px 20px;font-size:15px;font-weight:500}.btn-confirm{border-radius:var(--radius);background:var(--primary);color:#fff;cursor:pointer;border:none;padding:12px 20px;font-size:15px;font-weight:600}.btn-confirm:disabled{opacity:.4}.btn-delete{border-radius:var(--radius);background:var(--danger);color:#fff;cursor:pointer;border:none;padding:12px 20px;font-size:15px;font-weight:600}.btn-delete-outline{border-radius:var(--radius);background:var(--danger-light);color:var(--danger);cursor:pointer;border:none;padding:12px 20px;font-size:15px;font-weight:500}.form-field{margin-bottom:14px}.form-field label{color:var(--gray-600);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-field input,.form-field select{background:var(--gray-50);appearance:none;border:none;border-radius:10px;outline:none;width:100%;padding:12px 14px;font-size:16px;transition:box-shadow .2s}.form-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%238e8e93'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.form-field input:focus,.form-field select:focus{box-shadow:0 0 0 3px #007aff33}.radio-group{gap:8px;display:flex}.radio-option{cursor:pointer;background:var(--gray-50);color:var(--gray-600);border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:14px;transition:all .2s;display:flex}.radio-option input{display:none}.radio-option.active{background:var(--primary-light);color:var(--primary);font-weight:600}.menu-dialog{padding-bottom:calc(12px + env(safe-area-inset-bottom,0))}.menu-options{flex-direction:column;gap:2px;display:flex}.menu-options button{background:var(--gray-50);text-align:left;cursor:pointer;width:100%;color:var(--gray-800);border:none;border-radius:10px;padding:14px 16px;font-size:15px}.menu-options button:active{background:var(--gray-200)}.menu-options .menu-cancel{text-align:center;color:var(--gray-500);background:0 0;margin-top:8px}.history-list{max-height:300px;margin:8px 0;overflow-y:auto}.history-row{border-bottom:1px solid var(--gray-50);justify-content:space-between;padding:10px 4px;font-size:14px;display:flex}.history-date{color:var(--gray-700)}.history-qty{color:var(--gray-500);font-weight:500}.help-dialog{max-height:85dvh;overflow-y:auto}.help-content,.help-section{margin-bottom:16px}.help-section h4{color:var(--primary);border-bottom:1px solid var(--gray-50);margin-bottom:6px;padding-bottom:4px;font-size:14px;font-weight:700}.help-section ul{padding:0;list-style:none}.help-section li{color:var(--gray-700);padding:3px 0 3px 12px;font-size:13px;position:relative}.help-section li:before{content:"";background:var(--gray-300);border-radius:50%;width:5px;height:5px;position:absolute;top:10px;left:0}.help-section p{color:var(--gray-700);font-size:13px;line-height:1.6}
