:root{--bg-warm:#f5f5f5;--bg-card:#fff;--accent:#f57c00;--accent-dark:#e65100;--text-primary:#263238;--text-secondary:#546e7a;--text-muted:#90a4ae;--border:#e0e0e0;--radius:12px;--shadow:0 2px 8px #00000014;--shadow-lg:0 4px 20px #0000001f}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background-color:#f5f5f5;background-color:var(--bg-warm);color:#263238;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.loading-screen{align-items:center;color:#546e7a;color:var(--text-secondary);display:flex;flex-direction:column;gap:12px;height:100vh;justify-content:center}.loading-icon{animation:bounce 1s ease infinite;font-size:48px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-page{align-items:center;background:linear-gradient(135deg,#ffe0b2,#ffcc80 50%,#ffb74d);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;background:var(--bg-card);border-radius:20px;box-shadow:0 4px 20px #0000001f;box-shadow:var(--shadow-lg);max-width:400px;padding:32px 24px;text-align:center;width:100%}.login-title{color:#263238;color:var(--text-primary);font-size:24px;margin-bottom:4px}.login-subtitle{color:#546e7a;color:var(--text-secondary);font-size:15px;margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{border:2px solid #e0e0e0;border:2px solid var(--border);border-radius:12px;border-radius:var(--radius);font-family:inherit;font-size:16px;padding:14px 16px;text-align:center;transition:border-color .2s;width:100%}.login-input:focus{border-color:#f57c00;border-color:var(--accent);outline:none}.login-button{background:#f57c00;background:var(--accent);border:none;border-radius:12px;border-radius:var(--radius);color:#fff;cursor:pointer;font-family:inherit;font-size:16px;font-weight:600;padding:14px;transition:background-color .2s}.login-button:hover{background:#e65100;background:var(--accent-dark)}.login-button:disabled{cursor:not-allowed;opacity:.6}.login-error{color:#d32f2f;font-size:14px;margin-top:8px}.shake{animation:shake .5s ease}@keyframes shake{0%,to{transform:translateX(0)}20%,60%{transform:translateX(-8px)}40%,80%{transform:translateX(8px)}}.dashboard{display:flex;flex-direction:column;margin:0 auto;max-width:480px;min-height:100vh}.dashboard-header{align-items:center;background:#fff;background:var(--bg-card);border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 20px;position:sticky;top:0;z-index:10}.dashboard-title{color:#263238;color:var(--text-primary);font-size:20px}.dashboard-user{align-items:center;display:flex;gap:8px}.user-badge{align-items:center;border-radius:20px;color:#fff;display:inline-flex;font-size:13px;font-weight:600;gap:4px;padding:4px 10px}.logout-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:20px;padding:4px;transition:background-color .2s}.logout-btn:hover{background-color:#e0e0e0;background-color:var(--border)}.tabs{background:#fff;background:var(--bg-card);border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border);display:flex;padding:0 20px}.tab{background:none;border:none;border-bottom:3px solid #0000;color:#90a4ae;color:var(--text-muted);cursor:pointer;flex:1 1;font-family:inherit;font-size:15px;font-weight:600;padding:12px;transition:all .2s}.tab.active{border-bottom-color:#f57c00;border-bottom-color:var(--accent);color:#f57c00;color:var(--accent)}.tab:hover:not(.active){color:#546e7a;color:var(--text-secondary)}.tab-content{flex:1 1;padding:16px 20px 80px}.item-list{display:flex;flex-direction:column;gap:16px}.category-group{background:#fff;background:var(--bg-card);border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);overflow:hidden}.category-header{align-items:center;background:none;border:none;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border);color:#263238;color:var(--text-primary);cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:700;justify-content:space-between;letter-spacing:.5px;padding:12px 16px;text-transform:uppercase;width:100%}.category-arrow{display:inline-block;transition:transform .25s ease}.category-arrow.collapsed{transform:rotate(-90deg)}.category-count{color:#90a4ae;color:var(--text-muted);font-size:12px;font-weight:400;text-transform:none}.category-items-wrapper{display:grid;grid-template-rows:1fr;transition:grid-template-rows .25s ease}.category-items-wrapper.collapsed{grid-template-rows:0fr}.category-items-wrapper>.category-items{overflow:hidden}.category-items{list-style:none}.shopping-item{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border);display:flex;gap:10px;min-height:48px;padding:12px 16px;transition:background-color .15s}.shopping-item:last-child{border-bottom:none}.shopping-item:active{background-color:#fff3e0}.shopping-item.checked .item-name{color:#90a4ae;color:var(--text-muted);text-decoration:line-through;transition:color .3s ease}@keyframes checkPulse{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.item-checkbox.just-checked{animation:checkPulse .3s ease}.item-checkbox{background:none;border:none;cursor:pointer}.item-checkbox,.item-status-icon{align-items:center;display:flex;font-size:20px;justify-content:center;line-height:1;margin:-8px;min-height:44px;min-width:44px;padding:10px}.item-status-icon{opacity:.6}.item-info{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.item-name{color:#263238;color:var(--text-primary);font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-quantity{background:#e0e0e0;background:var(--border);border-radius:10px;color:#546e7a;color:var(--text-secondary);flex-shrink:0;font-size:12px;padding:2px 8px;white-space:nowrap}.item-owner{border-radius:50%;flex-shrink:0;height:30px;width:30px}.item-delete,.item-owner{align-items:center;display:flex;font-size:16px;justify-content:center}.item-delete{background:none;border:none;cursor:pointer;margin:-8px;min-height:44px;min-width:44px;opacity:.4;padding:12px;transition:opacity .2s}.item-delete:hover{opacity:1}.checked-section{background:#fff;background:var(--bg-card);border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);margin-top:16px;overflow:hidden}.checked-header{color:#90a4ae;color:var(--text-muted);cursor:pointer;font-size:14px;list-style:none;padding:12px 16px}.checked-header::-webkit-details-marker{display:none}.readonly-banner{background:#fff3e0;border-radius:12px;border-radius:var(--radius);color:#e65100;font-size:13px;font-weight:500;margin-bottom:12px;padding:8px 16px;text-align:center}.empty-state{color:#546e7a;color:var(--text-secondary);padding:48px 20px;text-align:center}.empty-icon{display:block;font-size:48px;margin-bottom:12px}.empty-hint{font-size:13px;margin-top:4px}.empty-hint,.loading-text{color:#90a4ae;color:var(--text-muted)}.loading-text{padding:24px;text-align:center}.fab{align-items:center;background:#f57c00;background:var(--accent);border:none;border-radius:50%;bottom:24px;box-shadow:0 4px 12px #e64a1959;color:#fff;cursor:pointer;display:flex;font-size:28px;font-weight:300;height:56px;justify-content:center;position:fixed;right:24px;transition:all .2s;width:56px;z-index:20}.fab:hover{background:#e65100;background:var(--accent-dark);transform:scale(1.08)}.fab:active{transform:scale(.95)}.modal-overlay{align-items:flex-end;animation:fadeIn .2s ease;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:30}.modal-content{animation:slideUp .3s ease;background:#fff;background:var(--bg-card);border-radius:20px 20px 0 0;max-width:480px;padding:24px 20px 32px;width:100%}.modal-title{color:#263238;color:var(--text-primary);font-size:18px;margin-bottom:20px;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.add-form{gap:16px}.add-form,.form-group{display:flex;flex-direction:column}.form-group{gap:4px}.form-group label{color:#546e7a;color:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1 1}.add-form input,.add-form select{background:#fff;background:var(--bg-card);border:2px solid #e0e0e0;border:2px solid var(--border);border-radius:10px;color:#263238;color:var(--text-primary);font-family:inherit;font-size:16px;padding:12px 14px;transition:border-color .2s}.add-form input:focus,.add-form select:focus{border-color:#f57c00;border-color:var(--accent);outline:none}.form-actions{display:flex;gap:12px;margin-top:4px}.btn-primary,.btn-secondary{border:none;border-radius:12px;border-radius:var(--radius);cursor:pointer;flex:1 1;font-family:inherit;font-size:15px;font-weight:600;padding:14px;transition:all .2s}.btn-primary{background:#f57c00;background:var(--accent);color:#fff}.btn-primary:hover{background:#e65100;background:var(--accent-dark)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background:#e0e0e0;background:var(--border);color:#546e7a;color:var(--text-secondary)}.btn-secondary:hover{background:#bdbdbd}.item-owners{display:flex;flex-shrink:0;gap:2px}.item-owners .item-owner{font-size:14px;height:26px;margin-left:-4px;width:26px}.item-owners .item-owner:first-child{margin-left:0}.btn-clear-checked{background:none;border:1px solid #ef9a9a;border-radius:8px;color:#e57373;cursor:pointer;float:right;font-family:inherit;font-size:12px;padding:4px 10px;transition:all .2s}.btn-clear-checked:hover{background:#ffebee;border-color:#e57373;color:#d32f2f}.btn-load-more{background:#fff8e1;border:2px dashed #d7ccc8;border-radius:12px;color:#8d6e63;cursor:pointer;display:block;font-family:inherit;font-size:14px;font-weight:500;margin:12px 0;padding:12px;transition:all .2s;width:100%}.btn-load-more:hover{background:#fff3e0;border-color:#ffb74d;color:#e65100}.toast{align-items:center;animation:toastSlideUp .3s ease;background:#333;border-radius:12px;bottom:calc(90px + env(safe-area-inset-bottom, 0px));box-shadow:0 4px 12px #0000004d;color:#fff;display:flex;gap:12px;left:50%;max-width:calc(100vw - 32px);padding:12px 20px;position:fixed;transform:translateX(-50%);z-index:1000}@keyframes toastSlideUp{0%{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.toast-message{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-undo{background:none;border:1px solid #fff6;border-radius:6px;color:#ffb74d;cursor:pointer;font-size:13px;font-weight:600;padding:4px 12px;white-space:nowrap}.toast-undo:hover{background:#ffffff1a}.toast.toast-success{background:#2e7d32}.toast.toast-error{background:#c62828}.shopping-item.editing{background:#fff8e1;border:2px solid #ffb74d;border-radius:12px;flex-wrap:wrap;gap:8px;padding:8px 12px}.edit-fields{display:flex;flex:1 1;flex-wrap:wrap;gap:6px;min-width:0}.edit-input{border:1px solid #d7ccc8;border-radius:8px;font-family:inherit;font-size:14px;outline:none;padding:6px 10px}.edit-input:focus{border-color:#ffb74d;box-shadow:0 0 0 2px #ffb74d33}.edit-name{flex:2 1;min-width:100px}.edit-quantity{flex:0 0 60px;width:60px}.edit-category{flex:1 1;min-width:100px}.edit-actions{display:flex;gap:4px}.edit-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;width:36px}.edit-btn.save{background:#81c784;color:#fff}.edit-btn.save:hover{background:#66bb6a}.edit-btn.cancel{background:#e0e0e0;color:#757575}.edit-btn.cancel:hover{background:#bdbdbd}.item-edit{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:14px;justify-content:center;margin:-8px;min-height:44px;min-width:44px;opacity:.5;padding:12px;transition:opacity .2s}.item-edit:hover{opacity:1}.btn-reorder-toggle{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e0e0e0;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);color:#546e7a;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:600;gap:4px;justify-content:center;padding:8px 12px;transition:all .2s;width:100%}.btn-reorder-toggle.active,.btn-reorder-toggle:hover{border-color:#f57c00;border-color:var(--accent);color:#f57c00;color:var(--accent)}.btn-reorder-toggle.active{background:#fff3e0}.reorder-list{background:#fff;background:var(--bg-card);border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow)}.sortable-wrapper{align-items:center;display:flex}.sortable-wrapper .shopping-item{flex:1 1}.drag-handle{align-items:center;background:none;border:none;color:#90a4ae;color:var(--text-muted);cursor:grab;display:flex;flex-shrink:0;font-size:22px;height:48px;justify-content:center;padding-left:8px;touch-action:none;width:32px}.drag-handle:active{color:#f57c00;color:var(--accent);cursor:grabbing}.admin-panel{display:flex;flex-direction:column;gap:16px}.admin-title{color:#263238;color:var(--text-primary);font-size:18px}.admin-users{display:flex;flex-direction:column;gap:8px}.admin-user-card{align-items:center;background:#fff;background:var(--bg-card);border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);display:flex;gap:12px;padding:12px 16px}.admin-user-emoji{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:20px;height:40px;justify-content:center;width:40px}.admin-user-name{color:#263238;color:var(--text-primary);flex:1 1;font-size:15px;font-weight:600}.admin-badge{background:#fff3e0;border-radius:6px;color:#f57c00;color:var(--accent);font-size:11px;font-weight:700;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.admin-user-delete{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:16px;justify-content:center;min-height:44px;min-width:44px;opacity:.4;padding:8px;transition:opacity .2s}.admin-user-delete:hover{opacity:1}.admin-add-btn{margin-top:8px}.admin-form{background:#fff;background:var(--bg-card);border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 8px #00000014;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px;padding:16px}.admin-form input{border:2px solid #e0e0e0;border:2px solid var(--border);border-radius:10px;color:#263238;color:var(--text-primary);font-family:inherit;font-size:16px;padding:12px 14px;transition:border-color .2s}.admin-form input:focus{border-color:#f57c00;border-color:var(--accent);outline:none}.admin-color-grid,.admin-emoji-grid{display:flex;flex-wrap:wrap;gap:8px}.admin-emoji-btn{align-items:center;background:#fff;background:var(--bg-card);border:2px solid #e0e0e0;border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;font-size:22px;height:44px;justify-content:center;transition:all .2s;width:44px}.admin-emoji-btn.selected{background:#fff3e0;border-color:#f57c00;border-color:var(--accent)}.admin-color-btn{border:3px solid #0000;border-radius:50%;cursor:pointer;height:36px;transition:all .2s;width:36px}.admin-color-btn.selected{border-color:#263238;border-color:var(--text-primary);transform:scale(1.15)}:focus-visible{outline:2px solid #f57c00;outline:2px solid var(--accent);outline-offset:2px}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid #f57c00;outline:2px solid var(--accent);outline-offset:2px}@media (max-width:767px){.tab-content{padding-bottom:calc(80px + env(safe-area-inset-bottom, 0px))}.fab{bottom:calc(28px + env(safe-area-inset-bottom, 0px));font-size:30px;height:60px;width:60px}.dashboard-header{padding:12px 16px}.dashboard-title{font-size:18px}}@media (min-width:768px){.login-card{padding:40px 32px}.modal-content{border-radius:20px;margin-bottom:10vh}.modal-overlay{align-items:center}}
/*# sourceMappingURL=main.a0bc1c31.css.map*/