*,:before,:after{box-sizing:border-box}body{color:#1a1a1a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;margin:0}#root{min-height:100dvh}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}.app{max-width:600px;min-height:100vh;margin:0 auto;padding-bottom:40px;font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic UI,sans-serif}.header{z-index:10;background:#fff;border-bottom:1px solid #e8e8e8;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;top:0}.header-title{color:#1a1a1a;white-space:nowrap;margin:0;font-size:1.1rem;font-weight:700}.header-nav{gap:6px;display:flex}.nav-btn{color:#555;cursor:pointer;background:#fff;border:1.5px solid #d0d0d0;border-radius:20px;padding:6px 14px;font-size:.85rem;transition:all .15s}.nav-btn.active{color:#fff;background:#3b82f6;border-color:#3b82f6;font-weight:600}.option-section{background:#f8f9fa;border-bottom:1px solid #e8e8e8;flex-wrap:wrap;align-items:center;gap:10px;padding:12px 16px;display:flex}.option-label{color:#888;white-space:nowrap;margin:0;font-size:.78rem;font-weight:600}.option-buttons{flex-wrap:wrap;gap:8px;display:flex}.option-btn{cursor:pointer;color:#444;background:#fff;border:1.5px solid #d0d0d0;border-radius:20px;padding:5px 14px;font-size:.85rem;transition:all .15s}.option-btn.selected{color:#065f46;background:#d1fae5;border-color:#10b981;font-weight:600}.category-section{margin:0;padding:0 16px}.category-heading{color:#888;text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:6px;margin:20px 0 6px;font-size:.85rem;font-weight:600;display:flex}.optional-tag{color:#065f46;text-transform:none;letter-spacing:0;background:#d1fae5;border-radius:10px;padding:1px 7px;font-size:.7rem;font-weight:500}.item-list{border:1px solid #eee;border-radius:10px;margin:0;padding:0;list-style:none;overflow:hidden}.item-row{cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid #f0f0f0;align-items:center;gap:10px;padding:13px 14px;transition:background .1s;display:flex}.item-row:last-child{border-bottom:none}.item-row:hover{background:#f7f7f7}.item-row.checked{background:#f0fdf4}.item-row.checked .item-name{color:#a3a3a3;text-decoration:line-through}.checkbox{flex-shrink:0;font-size:1.1rem}.item-name{color:#1a1a1a;flex:1;font-size:.95rem}.progress-bar-wrap{margin:14px 16px}.progress-info{color:#888;margin-bottom:5px;font-size:.8rem}.progress-bar{background:#e8e8e8;border-radius:3px;height:6px;overflow:hidden}.progress-fill{background:#3b82f6;border-radius:3px;height:100%;transition:width .3s}.complete-banner{text-align:center;background:linear-gradient(135deg,#d1fae5 0%,#a7f3d0 100%);border:1.5px solid #6ee7b7;border-radius:16px;margin:20px 16px;padding:28px 20px}.complete-icon{margin-bottom:8px;font-size:2.5rem;animation:.6s bounce;display:block}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.complete-text{color:#065f46;margin:0 0 16px;font-size:1.3rem;font-weight:700}.reset-btn{color:#065f46;cursor:pointer;background:#fff;border:1.5px solid #10b981;border-radius:20px;padding:8px 22px;font-size:.9rem;font-weight:600;transition:all .15s}.reset-btn:hover{color:#fff;background:#10b981}.cat-manage-wrap{border:1.5px solid #e8e8e8;border-radius:10px;margin:12px 16px 4px;overflow:hidden}.section-toggle{color:#444;cursor:pointer;text-align:left;background:#f8f9fa;border:none;justify-content:space-between;align-items:center;width:100%;padding:12px 14px;font-size:.9rem;font-weight:600;transition:background .1s;display:flex}.section-toggle:hover{background:#f0f0f0}.toggle-arrow{color:#999;font-size:.75rem}.cat-manage-body{border-top:1px solid #e8e8e8;flex-direction:column;gap:12px;padding:12px 14px;display:flex}.cat-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.cat-row{border-radius:6px;align-items:center;gap:8px;padding:6px 4px;display:flex}.cat-row:hover{background:#f7f7f7}.cat-icon{flex-shrink:0;font-size:1.1rem}.cat-name{color:#1a1a1a;flex:1;font-size:.9rem}.cat-type-badge{border-radius:10px;flex-shrink:0;padding:2px 8px;font-size:.7rem;font-weight:600}.cat-type-badge.regular{color:#1e40af;background:#dbeafe}.cat-type-badge.optional{color:#065f46;background:#d1fae5}.cat-add-form{border-top:1px dashed #e0e0e0;flex-direction:column;gap:8px;padding-top:8px;display:flex}.cat-add-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.type-toggle{border:1.5px solid #d0d0d0;border-radius:8px;flex-shrink:0;display:flex;overflow:hidden}.type-btn{cursor:pointer;color:#666;background:#fff;border:none;padding:7px 12px;font-size:.8rem;transition:all .15s}.type-btn.active{color:#fff;background:#3b82f6;font-weight:600}.icon-picker{flex-wrap:wrap;gap:6px;display:flex}.icon-option{cursor:pointer;background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .1s;display:flex}.icon-option.selected{background:#eff6ff;border-color:#3b82f6}.manage-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:16px 16px 4px;display:flex}.manage-header h2{color:#1a1a1a;margin:0;font-size:1rem;font-weight:700}.manage-actions{gap:8px;display:flex}.add-btn{color:#fff;cursor:pointer;background:#3b82f6;border:1.5px solid #3b82f6;border-radius:20px;padding:7px 16px;font-size:.85rem;font-weight:600;transition:all .15s}.add-btn:hover,.add-btn.cancel{background:#2563eb;border-color:#2563eb}.import-btn{color:#fff;cursor:pointer;background:#8b5cf6;border:1.5px solid #8b5cf6;border-radius:20px;padding:7px 14px;font-size:.85rem;font-weight:600;transition:all .15s}.import-btn:hover,.import-btn.cancel{background:#7c3aed;border-color:#7c3aed}.import-form{flex-direction:column;gap:8px;margin:10px 16px 4px;display:flex}.import-hint{color:#888;margin:0;font-size:.8rem}.import-textarea{resize:vertical;box-sizing:border-box;border:1.5px solid #d0d0d0;border-radius:8px;outline:none;width:100%;padding:10px 12px;font-family:inherit;font-size:.9rem;line-height:1.6;transition:border-color .15s}.import-textarea:focus{border-color:#8b5cf6}.import-success{color:#065f46;text-align:center;background:#d1fae5;border-radius:8px;padding:10px 14px;font-size:.9rem;font-weight:600}.add-form{flex-wrap:wrap;gap:8px;margin:10px 16px 4px;display:flex}.add-input{border:1.5px solid #d0d0d0;border-radius:8px;outline:none;flex:160px;padding:9px 12px;font-size:.9rem;transition:border-color .15s}.add-input:focus{border-color:#3b82f6}.add-select{cursor:pointer;background:#fff;border:1.5px solid #d0d0d0;border-radius:8px;outline:none;flex:140px;padding:9px 10px;font-size:.9rem}.add-submit-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:8px;padding:9px 18px;font-size:.9rem;font-weight:600;transition:background .15s}.add-submit-btn:hover:not(:disabled){background:#2563eb}.add-submit-btn:disabled{opacity:.45;cursor:not-allowed}.manage-item{cursor:default;gap:6px}.manage-item:hover{background:#fafafa}.drag-handle{color:#ccc;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;flex-shrink:0;padding:0 2px;font-size:1.1rem;line-height:1}.drag-handle:active{cursor:grabbing;color:#999}.rename-input{border:1.5px solid #3b82f6;border-radius:6px;outline:none;flex:1;min-width:0;padding:4px 8px;font-family:inherit;font-size:.95rem}.rename-cancel-btn{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px 6px;font-size:.85rem;transition:background .1s}.rename-cancel-btn:hover{color:#555;background:#f0f0f0}.edit-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px 6px;font-size:.95rem;line-height:1;transition:background .1s}.edit-btn:hover{background:#eff6ff}.delete-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px 6px;font-size:.95rem;line-height:1;transition:background .1s}.delete-btn:hover{background:#fee2e2}
