*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}*{margin:0;padding:0}:root{--primary: #4A7C59;--primary-light: #e8f0eb;--primary-dark: #3a6347;--danger: #C4704B;--danger-light: #fdf0eb;--success: #4A7C59;--warning: #D4A04A;--warning-light: #fef8ec;--bg: #FAF8F5;--bg-warm: #F5F1EC;--card: #FFFFFF;--text: #2D2A26;--text-secondary: #8C8580;--text-tertiary: #B5AFA9;--separator: #EDE9E4;--border: #DDD7D0;--header-h: 56px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--radius-sm: 10px;--radius-md: 16px;--radius-lg: 22px;--shadow-sm: 0 1px 3px rgba(45, 42, 38, .06), 0 1px 2px rgba(45, 42, 38, .04);--shadow-md: 0 4px 12px rgba(45, 42, 38, .08), 0 1px 4px rgba(45, 42, 38, .04);--shadow-lg: 0 8px 28px rgba(45, 42, 38, .12), 0 2px 8px rgba(45, 42, 38, .06);--font-display: "DM Serif Display", Georgia, "Times New Roman", serif;--font-body: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif}html{font-family:var(--font-body);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);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");background-size:200px 200px}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}button,input,select,textarea{font-family:var(--font-body);font-size:17px;color:var(--text)}input,textarea,select{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:#faf8f5e0;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);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;position:relative}.header-title{font-family:var(--font-display);font-size:24px;font-weight:400;position:absolute;left:50%;transform:translate(-50%);text-align:center;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%;pointer-events:none;padding:0 8px;letter-spacing:-.01em}.header-btn{background:none;border:none;color:var(--primary);font-size:16px;font-weight:500;min-width:44px;min-height:44px;padding:0 10px;cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap;flex-shrink:0;transition:background .15s ease;letter-spacing:.01em}.header-btn:active{background:var(--primary-light)}.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(96px + var(--safe-bottom))}.section-header{padding:20px 20px 12px;font-family:var(--font-display);font-size:32px;font-weight:400;color:var(--text);letter-spacing:-.01em}.lists-grid{padding:0 16px;display:flex;flex-direction:column;gap:10px}.list-card{background:var(--card);border-radius:var(--radius-md);display:flex;align-items:center;padding:16px;gap:14px;cursor:pointer;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.03);transition:transform .15s ease,box-shadow .15s ease}.lists-grid .list-card:first-child{border-radius:var(--radius-md)}.lists-grid .list-card:last-child{border-radius:var(--radius-md);border-bottom:none}.lists-grid .list-card:only-child{border-radius:var(--radius-md)}.list-card:active{transform:scale(.985);box-shadow:var(--shadow-md)}.list-card-icon{font-size:28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:14px;flex-shrink:0}.list-card-info{flex:1;min-width:0}.list-card-name{font-family:var(--font-body);font-size:22px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em}.list-card-meta{font-size:15px;color:var(--text-secondary);margin-top:3px;font-weight:400}.drag-handle{font-size:18px;color:var(--text-tertiary);padding:0 4px 0 0;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;flex-shrink:0;opacity:.5;letter-spacing:1px}.drag-handle:active{cursor:grabbing}.list-card-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.badge-new{background:var(--danger);color:#fff;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;letter-spacing:.6px;text-transform:uppercase}.chevron{color:var(--text-tertiary);font-size:20px;font-weight:300}.category-section{margin-bottom:8px}.category-section-header{padding:20px 20px 8px;display:flex;align-items:center;gap:8px}.category-section-name{font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:1px;flex:1}.category-section-count{font-size:13px;color:var(--text-tertiary);font-weight:500;background:var(--bg-warm);padding:2px 8px;border-radius:10px}.category-section-card{background:var(--card);border-radius:var(--radius-md);margin:0 16px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.03)}.item-row{display:flex;align-items:center;padding:14px 16px;gap:14px;border-bottom:1px solid var(--separator);background:var(--card);min-height:56px;transition:background .12s ease}.item-row:last-child{border-bottom:none}.checkbox{width:24px;height:24px;border-radius:8px;border:2px solid var(--border);background:transparent;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s cubic-bezier(.34,1.56,.64,1)}.checkbox.checked{background:var(--primary);border-color:var(--primary);transform:scale(1.05)}.checkbox.checked:after{content:"";display:block;width:5px;height:9px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg);margin-top:-2px}.item-text{flex:1;min-width:0}.item-name{font-size:18px;font-weight:400;color:var(--text);word-break:break-word;line-height:1.35}.item-quantity{font-size:15px;color:var(--text-secondary);margin-top:2px}.item-row.is-checked .item-name,.item-row.is-checked .item-quantity{color:var(--text-tertiary);text-decoration:line-through;text-decoration-color:var(--border)}.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:var(--radius-sm);font-size:18px;color:var(--text-tertiary);transition:color .15s ease,background .15s ease}.item-action-btn:active{background:var(--bg-warm);color:var(--text-secondary)}.item-action-btn.delete{color:var(--danger)}.fab{position:fixed;bottom:calc(24px + var(--safe-bottom));left:50%;transform:translate(-50%);height:52px;padding:0 28px;border-radius:26px;background:var(--primary);color:#fff;font-size:16px;font-weight:600;line-height:1;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;box-shadow:0 4px 20px #4a7c5959,0 2px 8px #4a7c5933;z-index:100;transition:transform .15s ease,box-shadow .15s ease;letter-spacing:.02em}.fab:active{transform:translate(-50%) scale(.95);box-shadow:0 2px 12px #4a7c594d}.overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d2a2666;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;animation:fadeIn .2s ease;touch-action:none;overscroll-behavior:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.bottom-sheet{background:var(--card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-height:92vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--safe-bottom);box-shadow:0 -8px 40px #2d2a2626;animation:sheetIn .3s cubic-bezier(.32,.72,0,1)}@keyframes sheetIn{0%{opacity:0;margin-bottom:-40%}to{opacity:1;margin-bottom:0}}.sheet-drag-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:10px auto 4px;opacity:.6}.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--separator)}.sheet-title{font-family:var(--font-display);font-size:19px;font-weight:400;color:var(--text)}.sheet-header-actions{display:flex;align-items:center;gap:4px}.sheet-action-btn{background:none;border:none;color:var(--primary);font-size:16px;font-weight:600;cursor:pointer;padding:4px 8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .15s ease}.sheet-action-btn:active{background:var(--primary-light)}.sheet-action-btn:disabled{opacity:.35;pointer-events:none}.sheet-close{background:none;border:none;color:var(--primary);font-size:16px;font-weight:500;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:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}.form-input{width:100%;background:var(--bg);border:1.5px solid transparent;border-radius:var(--radius-sm);padding:13px 16px;font-size:16px;color:var(--text);outline:none;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.form-input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #4a7c591f}.form-input::placeholder{color:var(--text-tertiary)}.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(--card);color:var(--text);font-size:14px;cursor:pointer;white-space:nowrap;flex-shrink:0;min-height:38px;transition:all .15s ease;font-weight:500}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600;box-shadow:0 2px 8px #4a7c5940}.chip:active{opacity:.7}.btn{width:100%;border:none;border-radius:var(--radius-sm);padding:15px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px;transition:transform .1s ease,opacity .15s ease;letter-spacing:.02em}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.35;pointer-events:none}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #4a7c5933}.btn-primary.first-btn{margin-top:0}.btn-danger-outline{background:transparent;color:var(--danger);border:1.5px solid var(--danger)}.btn-danger-outline:active{background:var(--danger-light)}.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);background-image:radial-gradient(ellipse 60% 50% at 50% 30%,rgba(74,124,89,.08) 0%,transparent 70%),radial-gradient(ellipse 40% 30% at 70% 70%,rgba(196,112,75,.06) 0%,transparent 70%)}.auth-emoji{font-size:64px;margin-bottom:20px;line-height:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.auth-title{font-family:var(--font-display);font-size:34px;font-weight:400;color:var(--text);margin-bottom:8px;text-align:center;letter-spacing:-.02em}.auth-sub{font-size:16px;color:var(--text-secondary);text-align:center;margin-bottom:40px;line-height:1.5}.auth-form{width:100%;max-width:360px}.auth-error{color:var(--danger);font-size:15px;text-align:center;margin-top:14px;font-weight:500}.confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d2a2673;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .15s ease}.confirm-dialog{background:var(--card);border-radius:var(--radius-md);overflow:hidden;width:100%;max-width:300px;box-shadow:var(--shadow-lg);animation:scaleIn .2s cubic-bezier(.32,.72,0,1)}@keyframes scaleIn{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.confirm-title{font-family:var(--font-display);font-size:18px;font-weight:400;padding:22px 22px 8px;text-align:center}.confirm-text{font-size:14px;color:var(--text-secondary);padding:0 22px 22px;text-align:center;line-height:1.5}.confirm-actions{border-top:1px solid var(--separator);display:flex}.confirm-btn{flex:1;padding:16px;border:none;background:none;font-size:16px;cursor:pointer;border-right:1px solid var(--separator);transition:background .12s ease;font-weight:500}.confirm-btn:last-child{border-right:none}.confirm-btn:active{background:var(--bg-warm)}.confirm-btn.cancel{color:var(--primary)}.confirm-btn.danger{color:var(--danger);font-weight:600}.cat-row{display:flex;align-items:center;padding:13px 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-tertiary);font-size:13px;cursor:pointer;width:30px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .12s ease,color .12s ease}.order-btn:active{background:var(--primary-light);color:var(--primary)}.order-btn:disabled{opacity:.15;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:16px;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:17px;min-width:38px;min-height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);transition:background .12s ease}.cat-action-btn:active{background:var(--bg-warm)}.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:var(--radius-sm);padding:0 20px;font-size:22px;font-weight:300;cursor:pointer;flex-shrink:0;min-height:50px;transition:transform .1s ease;box-shadow:0 2px 6px #4a7c5933}.cat-add-btn:active{transform:scale(.95)}.cat-add-btn:disabled{opacity:.35}.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:56px;margin-bottom:16px;filter:grayscale(.15)}.empty-title{font-family:var(--font-display);font-size:22px;font-weight:400;margin-bottom:8px;color:var(--text)}.empty-text{font-size:16px;color:var(--text-secondary);line-height:1.5}.divider{height:1px;background:var(--separator);margin:0 16px}.section-bg-card{background:var(--card);border-radius:var(--radius-md);margin:0 16px 16px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.03)}.header-right-group{display:flex;align-items:center;gap:0}
