*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #22c55e;--green-bg: #dcfce7;--yellow: #eab308;--yellow-bg: #fef9c3;--red: #ef4444;--red-bg: #fee2e2;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}html,body,#root{height:100%;margin:0;padding:0;-webkit-text-size-adjust:100%;overscroll-behavior:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.5;color:var(--gray-800);background:#fff;-webkit-font-smoothing:antialiased}h1{font-size:1.5rem;font-weight:700;color:var(--gray-900)}.subtitle{color:var(--gray-500);margin-bottom:1.5rem}input[type=text]{width:100%;padding:14px 16px;font-size:16px;border:2px solid var(--gray-200);border-radius:12px;outline:none;transition:border-color .15s;background:var(--gray-50);-webkit-appearance:none;-moz-appearance:none;appearance:none}input[type=text]:focus{border-color:var(--gray-400);background:#fff}input[type=text]::placeholder{color:var(--gray-400)}button{font-size:16px;font-weight:600;padding:14px 24px;border:none;border-radius:12px;cursor:pointer;transition:background-color .15s,opacity .15s;-webkit-tap-highlight-color:transparent;min-height:48px}button:active{opacity:.8}button:disabled{opacity:.4;cursor:default}.screen{height:100%;display:flex;align-items:center;justify-content:center;padding:24px;padding-top:calc(24px + var(--safe-top));padding-bottom:calc(24px + var(--safe-bottom))}.screen-content{width:100%;max-width:400px}.screen-content h1{margin-bottom:4px}.screen-content form{display:flex;flex-direction:column;gap:12px}.screen-content button{width:100%;background:var(--gray-900);color:#fff}.screen-content button.secondary{background:var(--gray-100);color:var(--gray-700)}.screen-content button.auth-primary{background:var(--gray-900);color:#fff}.screen-content button.auth-secondary{background:var(--gray-100);color:var(--gray-700);margin-top:12px}.rename-link{color:var(--gray-400)!important;font-size:14px!important;padding:0!important;min-height:auto!important;background:none!important;font-weight:400!important;text-decoration:underline}.rename-form{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.rename-form input{flex:1 1 auto;min-width:120px}.rename-form button{flex:0 0 auto;padding:10px 14px!important;min-height:44px!important;font-size:14px!important;width:auto!important}.list-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.list-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding:16px!important;background:var(--gray-50)!important;border:1px solid var(--gray-200)!important;border-radius:12px!important;color:var(--gray-800)!important;width:100%}.list-card:active{background:var(--gray-100)!important}.list-card-name{font-size:16px;font-weight:600;color:var(--gray-900)}.list-card-meta{font-size:13px;color:var(--gray-400);margin-top:2px}.create-list-form{display:flex;flex-direction:column;gap:12px}.create-list-form button{width:100%;background:var(--gray-900);color:#fff}.loading-text,.empty-state-text{color:var(--gray-400);text-align:center;padding:24px 0}.text-button{background:none!important;color:var(--gray-400)!important;font-weight:500!important;padding:8px!important;min-height:auto!important}.change-name{margin-top:24px;width:100%;text-align:center}.code-input{text-align:center;font-family:SF Mono,Menlo,Consolas,monospace;font-size:20px!important;letter-spacing:4px;font-weight:600}.error{color:var(--red);font-size:14px;text-align:center;margin-top:4px}.grocery-list-screen{display:flex;flex-direction:column;height:100%;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}.loading-screen{text-align:center}.freshness-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;flex-shrink:0}.freshness-bar.connected{color:var(--gray-500);background:var(--gray-50)}.freshness-bar.connected.normal{color:var(--gray-500)}.freshness-bar.connected.stale{color:var(--yellow);background:var(--yellow-bg)}.freshness-bar.connected.very-stale,.freshness-bar.offline{color:var(--red);background:var(--red-bg)}.freshness-bar.reconnecting{color:var(--yellow);background:var(--yellow-bg)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.connected{background:var(--green)}.status-dot.offline{background:var(--red)}.status-dot.reconnecting{background:var(--yellow);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.refresh-btn{margin-left:auto;font-size:13px!important;color:var(--red)!important;text-decoration:underline;padding:4px 8px!important}.list-header{padding:12px 16px 8px;border-bottom:1px solid var(--gray-100);flex-shrink:0}.list-header-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}.list-header-top h1{font-size:1.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.back-btn{background:none!important;color:var(--gray-500)!important;font-size:28px!important;font-weight:300!important;padding:0 4px!important;min-height:44px!important;min-width:32px;line-height:1;flex-shrink:0}.member-presence{display:flex;flex-wrap:wrap;gap:4px 16px;font-size:13px}.member{display:flex;align-items:center;gap:5px;color:var(--gray-500)}.presence-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.presence-dot.online{background:var(--green)}.presence-dot.away{background:var(--gray-300)}.member-name{font-weight:500;color:var(--gray-700)}.member-ago{color:var(--gray-400);font-size:12px}.items-container{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:8px;min-height:0}.empty-state{text-align:center;padding:48px 24px;color:var(--gray-400)}.item-row{position:relative;overflow:hidden}.item-main{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;position:relative;z-index:1;transition:transform .2s ease;min-height:56px}.item-row.swiped .item-main{transform:translate(-80px)}.delete-btn{position:absolute;right:0;top:0;bottom:0;width:80px;background:var(--red)!important;color:#fff!important;font-size:14px!important;font-weight:600!important;padding:0!important;border-radius:0!important;min-height:auto!important;z-index:0}.item-row+.item-row{border-top:1px solid var(--gray-100)}.item-row.pending{opacity:.5}.item-row.checked .item-content{opacity:.6}.checkbox{width:28px;height:28px;min-width:28px;border-radius:50%;border:2px solid var(--gray-300)!important;background:none!important;display:flex;align-items:center;justify-content:center;padding:0!important;min-height:auto!important;flex-shrink:0;-webkit-tap-highlight-color:transparent}.checkbox.checked{background:var(--green)!important;border-color:var(--green)!important}.checkmark{color:#fff;font-size:14px;font-weight:700;line-height:1}.item-content{flex:1;min-width:0;cursor:pointer;-webkit-tap-highlight-color:transparent}.item-text{display:block;font-size:16px;color:var(--gray-800);word-break:break-word}.item-text.struck{text-decoration:line-through;color:var(--gray-400)}.item-qty{color:var(--gray-500);font-weight:400}.item-meta{display:block;font-size:12px;color:var(--gray-400);margin-top:1px}.item-row.animate-in .item-main{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.item-row.editing{padding:12px 16px;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.item-row.editing form{display:flex;flex-direction:column;gap:8px}.edit-text{font-size:16px}.edit-qty{font-size:14px!important;padding:10px 12px!important}.edit-actions{display:flex;gap:8px}.save-btn{flex:1;background:var(--gray-900)!important;color:#fff!important;padding:10px!important;border-radius:8px!important;font-size:14px!important}.cancel-btn{flex:1;background:var(--gray-100)!important;color:var(--gray-600)!important;padding:10px!important;border-radius:8px!important;font-size:14px!important}.checked-divider{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px!important;background:none!important;min-height:auto!important;border-radius:0!important}.divider-line{flex:1;height:1px;background:var(--gray-200)}.divider-text{color:var(--gray-400);font-size:13px;font-weight:500;white-space:nowrap}.add-item-wrapper{position:relative;flex-shrink:0}.add-item{display:flex;gap:8px;padding:12px 16px;padding-bottom:calc(12px + var(--safe-bottom));border-top:1px solid var(--gray-200);background:#fff}.quick-add-trigger{background:var(--gray-100)!important;color:var(--gray-700)!important;font-size:13px!important;font-weight:600!important;padding:6px 10px!important;border-radius:8px!important;min-height:auto!important;flex-shrink:0;margin-left:auto}.quick-add-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;z-index:200;display:flex;flex-direction:column;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);animation:quickAddSlide .22s ease-out}@keyframes quickAddSlide{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.quick-add-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--gray-100);flex-shrink:0}.quick-add-header h2{font-size:1.25rem;font-weight:700;color:var(--gray-900)}.quick-add-close{background:none!important;color:var(--gray-500)!important;font-size:28px!important;font-weight:300!important;padding:4px 8px!important;min-height:auto!important;line-height:1}.quick-add-search{padding:12px 16px;border-bottom:1px solid var(--gray-100);flex-shrink:0}.quick-add-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 16px;min-height:0}.quick-add-loading,.quick-add-empty{text-align:center;color:var(--gray-400);padding:32px 16px}.quick-add-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.qa-chip{display:flex;align-items:center;gap:8px;padding:14px!important;border-radius:12px!important;text-align:left;min-height:52px!important;font-size:15px!important;font-weight:500!important;background:var(--gray-50)!important;color:var(--gray-900)!important;border:1px solid var(--gray-200)!important;overflow:hidden;transition:transform .15s ease,background-color .15s}.qa-chip.history{background:#fff!important;border-color:var(--gray-200)!important}.qa-chip.seeded .qa-chip-text{color:var(--gray-600)}.qa-chip:active:not(:disabled){transform:scale(.97);background:var(--gray-100)!important}.qa-chip.on-list{opacity:.5;background:var(--gray-100)!important;border-style:dashed!important}.qa-chip.pulse{animation:qaPulse .55s ease}@keyframes qaPulse{0%{background:var(--green-bg)!important;transform:scale(1)}40%{background:var(--green-bg)!important;transform:scale(1.03)}to{background:#fff!important;transform:scale(1)}}.qa-chip-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qa-chip-count{color:var(--gray-400);font-size:12px;font-weight:500;flex-shrink:0}.qa-chip-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--green);color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.suggestions{position:absolute;left:8px;right:8px;bottom:100%;display:flex;flex-direction:column;gap:1px;background:#fff;border:1px solid var(--gray-200);border-bottom:none;border-top-left-radius:12px;border-top-right-radius:12px;overflow:hidden;box-shadow:0 -8px 24px #0000000f;z-index:5}.suggestion{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px!important;background:#fff!important;color:var(--gray-800)!important;text-align:left;border:none!important;border-radius:0!important;min-height:44px!important;font-size:15px!important;font-weight:500!important}.suggestion+.suggestion{border-top:1px solid var(--gray-100)!important}.suggestion:active{background:var(--gray-100)!important}.suggestion-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.suggestion.history .suggestion-text{color:var(--gray-900)}.suggestion.seeded .suggestion-text{color:var(--gray-500)}.suggestion-count{color:var(--gray-400);font-size:12px;font-weight:500;flex-shrink:0}.suggestion.on-list{opacity:.55}.suggestion.on-list .suggestion-text{text-decoration:line-through;color:var(--gray-500)}.suggestion-badge{color:var(--gray-500);font-size:14px;flex-shrink:0}.toast-stack{position:fixed;left:12px;right:12px;bottom:calc(88px + var(--safe-bottom));display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none;z-index:300}.toast{max-width:420px;width:fit-content}.toast{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;font-size:14px;font-weight:500;box-shadow:0 6px 18px #0000001f;animation:toastInOut 1.8s ease forwards;transform-origin:bottom center}.toast-success{background:var(--gray-900);color:#fff}.toast-info{background:#fff;color:var(--gray-800);border:1px solid var(--gray-200)}.toast-check{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--green);color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.toast-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@keyframes toastInOut{0%{opacity:0;transform:translateY(8px) scale(.96)}10%{opacity:1;transform:translateY(0) scale(1)}80%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-4px) scale(.98)}}.add-item input{flex:1;border-radius:24px;padding:12px 20px}.add-item button{width:48px;height:48px;min-height:48px;border-radius:50%!important;background:var(--gray-900)!important;color:#fff!important;font-size:24px!important;font-weight:400!important;padding:0!important;display:flex;align-items:center;justify-content:center;flex-shrink:0}.add-item button:disabled{background:var(--gray-200)!important}.add-item.duplicate input{border-color:var(--danger, #dc2626)!important;background:#fff5f5}.duplicate-hint{position:absolute;left:20px;bottom:calc(100% + 4px);font-size:12px;font-weight:500;color:var(--danger, #dc2626);background:#fff;padding:2px 8px;border-radius:8px;box-shadow:0 1px 4px #00000014;pointer-events:none;z-index:6}
