.item{display:flex;align-items:center;gap:10px;background:var(--bg-card);padding:12px 14px;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:8px;transition:opacity .25s,box-shadow .15s;cursor:pointer;user-select:none;-webkit-user-select:none}.item:hover{box-shadow:var(--shadow-md)}.item.checked{opacity:.45}.item.checked .item-name{text-decoration:line-through;color:var(--text-muted)}.item.dragging{box-shadow:var(--shadow-lg);border-color:var(--green-500)}.item input[type=checkbox]{width:20px;height:20px;accent-color:var(--green-600);cursor:pointer;flex-shrink:0}.item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.item-name-row{display:flex;align-items:baseline;gap:6px;min-width:0}.item-name{font-size:.92rem;font-weight:500;word-break:break-word;color:var(--text)}.meta-aisle{font-size:.72rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.meta-price{font-size:.75rem;color:var(--green-500);font-weight:500}.qty-controls{display:flex;align-items:center;gap:2px;background:var(--bg-elevated);border-radius:var(--radius-full);padding:2px;flex-shrink:0}.qty-btn{width:26px;height:26px;border-radius:50%;border:none;background:var(--bg-card);cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:background .1s;box-shadow:var(--shadow-sm)}.qty-btn:hover{background:var(--border-light)}.qty-btn:active{transform:scale(.92)}.qty-val{min-width:24px;text-align:center;font-size:.82rem;font-weight:600;color:var(--text-secondary)}.item-actions{display:flex;gap:2px;flex-shrink:0}.item-btn{background:none;border:none;cursor:pointer;font-size:1.05rem;padding:6px;border-radius:var(--radius-sm);line-height:1;transition:background .1s,transform .1s}.item-btn:hover{background:var(--bg-elevated)}.item-btn:active{transform:scale(.9)}.item-btn.star-btn{color:var(--text-muted)}.item-btn.star-btn.starred{color:var(--gold-400)}.delete-zone{position:fixed;bottom:24px;bottom:calc(24px + env(safe-area-inset-bottom,0));left:50%;transform:translate(-50%);width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--red-500);color:#fff;font-size:1.4rem;z-index:200;box-shadow:0 4px 16px #dc354566;animation:popIn .2s ease;transition:transform .15s,background .15s}.delete-zone.over{background:#a71d2a;transform:translate(-50%) scale(1.2)}@keyframes popIn{0%{transform:translate(-50%) scale(0);opacity:0}to{transform:translate(-50%) scale(1);opacity:1}}.shop-card{background:var(--bg-card);border-radius:var(--radius);margin-bottom:8px;box-shadow:var(--shadow-sm);border:2px solid var(--border);overflow:hidden;transition:border-color .2s}.shop-card-over{border-color:var(--green-500);background:var(--green-50)}.shop-header{display:flex;align-items:center;gap:8px;padding:12px 14px;cursor:pointer;user-select:none;-webkit-user-select:none}.shop-chevron{color:var(--text-muted);display:flex;flex-shrink:0}.shop-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.shop-date{font-size:.88rem;font-weight:600;color:var(--text)}.shop-count{font-size:.72rem;color:var(--text-muted)}.shop-total{font-size:.88rem;font-weight:600;color:var(--green-500);flex-shrink:0}.shop-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;transition:color .15s;flex-shrink:0}.shop-delete:hover{color:var(--red-500)}.shop-items{border-top:1px solid var(--border);padding:8px 14px 12px}.shop-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:.82rem;color:var(--text-secondary)}.shop-item-name{flex:1;min-width:0;word-break:break-word}.shop-item-qty{color:var(--text-muted);font-size:.75rem}.shop-item-price{color:var(--green-500);font-weight:500;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-elevated);border-radius:20px 20px 0 0;width:100%;max-width:560px;padding:16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0));animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(min-width:560px){.modal-overlay{align-items:center}.modal-content{border-radius:var(--radius);max-width:420px;padding:20px}}.field{margin-bottom:12px}.field label{display:block;font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.field input{width:100%;padding:10px 12px;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:1rem;color:var(--text);outline:none;background:var(--bg-card);transition:border-color .2s,box-shadow .2s}.field input:focus{border-color:var(--green-600);box-shadow:0 0 0 3px #22875a33}.field input::placeholder{color:var(--text-muted)}.field-row{display:flex;gap:8px;margin-bottom:12px}.field-row .field{margin-bottom:0}.field-sm{flex:0 0 70px}.field-grow{flex:1;min-width:0}.modal-actions{display:flex;justify-content:space-between;align-items:center;margin-top:14px;gap:8px}.modal-actions-right{display:flex;gap:8px}.btn-save{padding:9px 20px;background:var(--green-700);color:#fff;border:none;border-radius:var(--radius-sm);font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-save:hover{background:var(--green-600)}.btn-cancel{padding:9px 16px;background:none;color:var(--text-secondary);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-cancel:hover{background:var(--bg-card)}.btn-delete{padding:9px 16px;background:none;color:var(--red-500);border:1.5px solid var(--red-500);border-radius:var(--radius-sm);font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-delete:hover{background:var(--red-50)}.add-bar{display:flex;gap:8px;margin-bottom:20px;position:relative}.add-bar input{flex:1;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:1rem;color:var(--text);outline:none;background:var(--bg-card);transition:border-color .2s,box-shadow .2s}.add-bar input::placeholder{color:var(--text-muted)}.add-bar input:focus{border-color:var(--green-600);box-shadow:0 0 0 3px #22875a33}.add-bar button{padding:12px 20px;background:var(--green-700);color:#fff;border:none;border-radius:var(--radius);font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,transform .1s}.add-bar button:hover{background:var(--green-600)}.add-bar button:active{background:var(--green-900);transform:scale(.97)}.suggestions{position:absolute;top:calc(100% + 4px);left:0;right:80px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);max-height:200px;overflow-y:auto;z-index:200;box-shadow:var(--shadow-lg)}.suggestion-item{padding:11px 14px;cursor:pointer;font-size:.88rem;display:flex;align-items:center;gap:8px;color:var(--text);transition:background .1s}.suggestion-item:hover,.suggestion-item.highlighted{background:var(--green-50)}.suggestion-item .star{color:var(--gold-500);display:flex}.section-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:20px 0 8px;font-weight:700}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.list-header h2{font-size:.9rem;font-weight:700;color:var(--text-secondary)}.list-header h2 span{font-weight:500;color:var(--text-muted)}.empty{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-icon{margin-bottom:12px;color:var(--text-muted)}.empty p{font-size:.88rem;line-height:1.5}.estimated-total{font-size:.82rem;font-weight:600;color:var(--green-500);background:var(--green-50);padding:3px 10px;border-radius:var(--radius-full)}.empty-sm{padding:24px 20px}.regulars-info{font-size:.84rem;color:var(--text-secondary);margin-bottom:16px;line-height:1.5}.regulars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.regular-chip{display:flex;align-items:center;gap:8px;background:var(--bg-card);padding:12px 14px;border-radius:var(--radius);cursor:pointer;font-size:.88rem;font-weight:500;color:var(--text);box-shadow:var(--shadow-sm);border:2px solid transparent;transition:border-color .2s,background .2s,transform .1s}.regular-chip:hover{border-color:var(--green-500);transform:translateY(-1px)}.regular-chip.in-list{background:var(--green-50);border-color:var(--green-500)}.regular-chip .remove-regular{margin-left:auto;color:var(--red-500);background:none;border:none;cursor:pointer;font-size:.85rem;padding:0 2px;line-height:1;opacity:.5;transition:opacity .15s}.regular-chip .remove-regular:hover{opacity:1}@media(max-width:400px){.regulars-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.help-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:helpFadeIn .15s ease}@keyframes helpFadeIn{0%{opacity:0}to{opacity:1}}.help-content{background:var(--bg-elevated);border-radius:20px 20px 0 0;width:100%;max-width:560px;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0));max-height:85vh;overflow-y:auto;animation:helpSlideUp .2s ease}@keyframes helpSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(min-width:560px){.help-overlay{align-items:center}.help-content{border-radius:var(--radius);max-width:420px;padding-bottom:20px;max-height:80vh}}.help-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.help-header h3{font-size:1.05rem;font-weight:700;color:var(--text)}.help-close{background:none;border:none;font-size:1.1rem;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm)}.help-close:hover{background:var(--bg-card)}.help-section{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.help-section:last-child{border-bottom:none}.help-icon{flex-shrink:0;width:32px;display:flex;align-items:center;justify-content:center;color:var(--green-500)}.help-title{font-size:.88rem;font-weight:600;color:var(--text);margin-bottom:2px}.help-section p:not(.help-title){font-size:.82rem;color:var(--text-secondary);line-height:1.45}.app-shell{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.app-main{flex:1}.app-header{background:linear-gradient(135deg,var(--green-700) 0%,var(--green-900) 100%);color:#fff;padding:14px 20px;padding-top:calc(14px + env(safe-area-inset-top,0));display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px #0000004d}.app-header img{height:32px;width:32px;object-fit:contain}.app-header h1{font-size:1.15rem;font-weight:700;letter-spacing:-.01em;flex:1}.help-btn{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.35);background:none;color:#ffffffb3;font-family:inherit;font-size:.85rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s;flex-shrink:0}.help-btn:hover{border-color:#fff9;color:#fff}.tabs{display:flex;background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:calc(60px + env(safe-area-inset-top,0));z-index:90}.tab{flex:1;padding:13px 12px;text-align:center;font-family:inherit;font-size:.85rem;font-weight:600;letter-spacing:.01em;cursor:pointer;border:none;border-bottom:2.5px solid transparent;color:var(--text-muted);background:none;transition:color .2s,border-color .2s}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--green-500);border-bottom-color:var(--green-500)}.container{max-width:560px;margin:0 auto;padding:16px 16px 32px}@media(max-width:400px){.container{padding:12px 12px 24px}}.app-footer{text-align:center;padding:24px 16px 16px;font-size:.75rem;color:var(--text-muted)}.app-footer a{color:var(--green-600);text-decoration:none}.app-footer a:hover{text-decoration:underline}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green-900: #0d3b26;--green-700: #1a6b47;--green-600: #22875a;--green-500: #2d9e6b;--green-100: #1a3a2a;--green-50: #162e23;--bg: #1a1f1c;--bg-card: #232a26;--bg-elevated: #2a332e;--border: #2e3830;--border-light: #364038;--text: #e0e4e1;--text-secondary: #8a9a8f;--text-muted: #5e6e63;--red-500: #dc3545;--red-50: #2a1a1a;--gold-500: #e6a817;--gold-400: #f0c040;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 8px rgba(0, 0, 0, .25);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .3);--radius: 16px;--radius-sm: 12px;--radius-full: 9999px}html{overflow-x:hidden;background:#1a1f1c;color-scheme:dark}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1f1c!important;color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-bottom:env(safe-area-inset-bottom,0);overscroll-behavior:none;overflow-x:hidden}#root{background:#1a1f1c;min-height:100vh}
