*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}*{margin:0;padding:0}:root{--primary: #007AFF;--danger: #FF3B30;--success: #34C759;--warning: #FF9500;--bg: #F2F2F7;--card: #FFFFFF;--text: #1C1C1E;--text-secondary: #8E8E93;--separator: #E5E5EA;--border: #C6C6C8;--header-h: 56px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}html{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;font-size:17px;background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%}body{min-height:100vh;min-height:100dvh;overscroll-behavior:none;-webkit-overflow-scrolling:touch;background:var(--bg)}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}button,input,select,textarea{font-family:inherit;font-size:17px;color:var(--text)}input,textarea{font-size:16px}.screen{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background:var(--bg)}.header{position:sticky;top:0;z-index:100;background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--separator);padding-top:var(--safe-top)}.header-inner{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 8px;gap:4px}.header-title{font-size:17px;font-weight:600;flex:1;text-align:center;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 8px}.header-btn{background:none;border:none;color:var(--primary);font-size:17px;min-width:44px;min-height:44px;padding:0 8px;cursor:pointer;border-radius:10px;display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap;flex-shrink:0}.header-btn:active{background:var(--separator)}.header-btn.danger{color:var(--danger)}.header-btn.muted{color:var(--text-secondary);font-size:15px}.offline-banner{background:var(--warning);color:#fff;text-align:center;padding:7px 16px;font-size:14px;font-weight:500;letter-spacing:.2px}.content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(88px + var(--safe-bottom))}.section-header{padding:16px 20px 8px;font-size:28px;font-weight:700;color:var(--text)}.lists-grid{padding:8px 16px;display:flex;flex-direction:column;gap:2px}.list-card{background:var(--card);border-radius:0;display:flex;align-items:center;padding:15px 16px;gap:12px;cursor:pointer;border-bottom:1px solid var(--separator)}.lists-grid .list-card:first-child{border-radius:14px 14px 0 0}.lists-grid .list-card:last-child{border-radius:0 0 14px 14px;border-bottom:none}.lists-grid .list-card:only-child{border-radius:14px}.list-card:active{background:var(--bg)}.list-card-icon{font-size:32px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:10px;flex-shrink:0}.list-card-info{flex:1;min-width:0}.list-card-name{font-size:20px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-card-meta{font-size:13px;color:var(--text-secondary);margin-top:2px}.list-card-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.badge-new{background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;letter-spacing:.5px}.chevron{color:var(--border);font-size:18px;font-weight:600}.category-section{margin-bottom:2px}.category-section-header{padding:20px 20px 6px;display:flex;align-items:center;gap:8px}.category-section-name{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;flex:1}.category-section-count{font-size:13px;color:var(--text-secondary)}.category-section-card{background:var(--card);border-radius:14px;margin:0 16px;overflow:hidden}.item-row{display:flex;align-items:center;padding:12px 16px;gap:12px;border-bottom:1px solid var(--separator);background:var(--card);min-height:54px}.item-row:last-child{border-bottom:none}.checkbox{width:26px;height:26px;border-radius:50%;border:2px solid var(--border);background:transparent;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.checkbox.checked{background:var(--success);border-color:var(--success)}.checkbox.checked:after{content:"";display:block;width:5px;height:10px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg);margin-top:-3px}.item-text{flex:1;min-width:0}.item-name{font-size:17px;color:var(--text);word-break:break-word}.item-quantity{font-size:13px;color:var(--text-secondary);margin-top:2px}.item-row.is-checked .item-name{color:var(--text-secondary);text-decoration:line-through}.item-row.is-checked .item-quantity{text-decoration:line-through}.item-actions{display:flex;gap:2px;flex-shrink:0}.item-action-btn{background:none;border:none;cursor:pointer;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:18px;color:var(--text-secondary)}.item-action-btn:active{background:var(--separator)}.item-action-btn.delete{color:var(--danger)}.add-bar{position:fixed;bottom:0;left:0;right:0;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--separator);padding:10px 16px;padding-bottom:calc(10px + var(--safe-bottom));z-index:100}.add-bar-button{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:14px;padding:13px 16px;font-size:17px;color:var(--text-secondary);text-align:left;cursor:pointer;display:flex;align-items:center;gap:10px}.add-bar-button:active{background:var(--separator)}.add-bar-plus{width:26px;height:26px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:300;flex-shrink:0;line-height:1}.overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;display:flex;align-items:flex-end}.bottom-sheet{background:var(--card);border-radius:20px 20px 0 0;width:100%;max-height:92vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--safe-bottom)}.sheet-drag-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:12px auto 4px}.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--separator)}.sheet-title{font-size:17px;font-weight:600;color:var(--text)}.sheet-close{background:none;border:none;color:var(--primary);font-size:17px;cursor:pointer;padding:4px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.sheet-body{padding:20px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}.form-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:13px 16px;font-size:16px;color:var(--text);outline:none}.form-input:focus{border-color:var(--primary);background:#fff}.form-input::placeholder{color:var(--border)}.chips-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 0 10px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.chips-scroll::-webkit-scrollbar{display:none}.chip{padding:8px 16px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg);color:var(--text);font-size:15px;cursor:pointer;white-space:nowrap;flex-shrink:0;min-height:38px}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:500}.chip:active{opacity:.7}.btn{width:100%;border:none;border-radius:14px;padding:16px;font-size:17px;font-weight:600;cursor:pointer;margin-top:8px}.btn:active{opacity:.8}.btn:disabled{opacity:.4;pointer-events:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary.first-btn{margin-top:0}.btn-danger-outline{background:transparent;color:var(--danger);border:1.5px solid var(--danger)}.auth-screen{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px calc(40px + var(--safe-bottom));padding-top:calc(40px + var(--safe-top));background:var(--bg)}.auth-emoji{font-size:72px;margin-bottom:20px;line-height:1}.auth-title{font-size:30px;font-weight:700;color:var(--text);margin-bottom:8px;text-align:center}.auth-sub{font-size:17px;color:var(--text-secondary);text-align:center;margin-bottom:40px}.auth-form{width:100%;max-width:380px}.auth-error{color:var(--danger);font-size:15px;text-align:center;margin-top:14px}.confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px}.confirm-dialog{background:var(--card);border-radius:16px;overflow:hidden;width:100%;max-width:300px}.confirm-title{font-size:17px;font-weight:600;padding:20px 20px 8px;text-align:center}.confirm-text{font-size:14px;color:var(--text-secondary);padding:0 20px 20px;text-align:center}.confirm-actions{border-top:1px solid var(--separator);display:flex}.confirm-btn{flex:1;padding:16px;border:none;background:none;font-size:17px;cursor:pointer;border-right:1px solid var(--separator)}.confirm-btn:last-child{border-right:none}.confirm-btn.cancel{color:var(--primary)}.confirm-btn.danger{color:var(--danger);font-weight:600}.cat-row{display:flex;align-items:center;padding:12px 16px;gap:10px;border-bottom:1px solid var(--separator);background:var(--card);min-height:54px}.cat-row:last-child{border-bottom:none}.cat-row-order{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.order-btn{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;width:30px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}.order-btn:active{background:var(--separator)}.order-btn:disabled{opacity:.2;pointer-events:none}.cat-row-name-wrap{flex:1;min-width:0}.cat-row-name{font-size:17px;color:var(--text)}.cat-inline-input{background:transparent;border:none;border-bottom:2px solid var(--primary);font-size:17px;color:var(--text);outline:none;padding:2px 0;width:100%}.cat-row-actions{display:flex;gap:4px;flex-shrink:0}.cat-action-btn{background:none;border:none;cursor:pointer;font-size:18px;min-width:38px;min-height:38px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:var(--text-secondary)}.cat-action-btn:active{background:var(--separator)}.cat-action-btn.danger{color:var(--danger)}.cat-action-btn.confirm-save{color:var(--success)}.cat-add-row{padding:16px;display:flex;gap:10px}.cat-add-row .form-input{margin:0}.cat-add-btn{background:var(--primary);color:#fff;border:none;border-radius:10px;padding:0 18px;font-size:17px;font-weight:600;cursor:pointer;flex-shrink:0;min-height:50px}.cat-add-btn:active{opacity:.8}.cat-add-btn:disabled{opacity:.4}.input-row{display:flex;gap:10px}.input-row .form-input{flex:1}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center}.empty-icon{font-size:64px;margin-bottom:16px}.empty-title{font-size:22px;font-weight:600;margin-bottom:8px;color:var(--text)}.empty-text{font-size:17px;color:var(--text-secondary)}.divider{height:1px;background:var(--separator);margin:0 16px}.section-bg-card{background:var(--card);border-radius:14px;margin:0 16px 16px;overflow:hidden}.header-right-group{display:flex;align-items:center;gap:0}
