.groceries-page{padding:20px;max-width:1400px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px}.header h1{margin:0;font-size:28px}.header-subtitle{margin:4px 0 0;color:var(--placeholder-text);font-size:14px}.header-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:16px;border:1px solid #fcc}.controls{gap:20px;margin-bottom:24px;padding:16px;background-color:var(--card-background);border-radius:8px;align-items:flex-start}.controls,.filters{display:flex;flex-wrap:wrap}.filters{gap:16px;align-items:center;flex:1 1 100%}.filters label{display:flex;align-items:center;gap:8px;font-size:14px}.chipFilters{display:flex;flex-wrap:wrap;gap:16px 20px;flex:1 1 100%}.chipLabel{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--placeholder-text);margin-bottom:4px}.chipRow{display:flex;flex-wrap:wrap;gap:8px}.chipGroup{display:flex;flex-direction:column;gap:4px;min-width:min(320px,100%)}.chip{border:1px solid var(--border-color);background-color:var(--background);color:var(--foreground);padding:6px 12px;border-radius:999px;font-size:13px;cursor:pointer;transition:background-color .2s,border-color .2s}.chipActive{background-color:var(--button-secondary);border-color:var(--button-secondary)}.entry-tabs,.quick-actions{display:flex;gap:8px}.entry-tabs{flex-wrap:wrap;margin-bottom:16px}.entry-tab{border:1px solid var(--border-color);background-color:var(--background);color:var(--foreground);padding:8px 16px;border-radius:999px;font-size:14px;cursor:pointer;transition:background-color .2s,border-color .2s}.entry-tab-active{background-color:var(--button-secondary);border-color:var(--button-secondary)}.single-entry{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:center}.single-entry h2{margin:0;font-size:20px}.single-subtitle{margin:6px 0 0;color:var(--placeholder-text);font-size:13px}.batch-entry{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:24px;display:flex;flex-direction:column;gap:16px}.batch-header{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:flex-start}.batch-header h2{margin:0;font-size:20px}.batch-subtitle{margin:6px 0 0;color:var(--placeholder-text);font-size:13px;max-width:520px}.batch-actions{display:flex;gap:10px;flex-wrap:wrap}.batch-template-status{margin:0;font-size:13px;color:var(--placeholder-text)}.batch-grid{height:320px;width:100%}.batch-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;font-size:13px;color:var(--foreground)}.batch-label{text-transform:uppercase;letter-spacing:.08em;font-size:11px;color:var(--placeholder-text)}.records-entry{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:24px;display:flex;flex-direction:column;gap:16px}.records-header{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:flex-start}.records-grid{height:360px;width:100%}.changed-cell{background-color:rgba(245,158,11,.2)}.items-container{gap:32px}.item-group,.items-container{display:flex;flex-direction:column}.item-group{gap:16px}.group-header{font-size:20px;margin:0;padding-bottom:8px;border-bottom:2px solid var(--border-color);color:var(--foreground)}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.grocery-item-card{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .2s}.grocery-item-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1)}.item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.item-header h3{margin:0;font-size:18px;color:var(--foreground);flex:1}.badges{display:flex;gap:6px;flex-wrap:wrap}.recurring-badge{background-color:var(--button-primary)}.needed-badge,.recurring-badge{color:white;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap}.needed-badge{background-color:#f59e0b}.item-detail{font-size:14px;color:var(--foreground);display:flex;flex-direction:column;gap:4px}.item-detail strong{font-weight:600;color:var(--foreground)}.stores-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.store-tag{background-color:var(--background);border:1px solid var(--border-color);padding:4px 8px;border-radius:4px;font-size:12px}.item-actions{display:flex;gap:6px;margin-top:8px;padding-top:12px;border-top:1px solid var(--border-color);flex-wrap:wrap}.empty-state{text-align:center;padding:60px 20px;color:var(--foreground);opacity:.6}.btn-primary{background-color:var(--button-primary);color:white;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-primary:hover:not(:disabled){opacity:.9}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:var(--button-secondary);color:var(--foreground);border:1px solid var(--border-color);padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:var(--background)}.btn-mark-needed{background-color:#f59e0b;color:white;border:none;padding:8px 12px;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:opacity .2s}.btn-mark-needed:hover{opacity:.9}.btn-unmark-needed{background-color:#10b981;color:white;border:none;padding:8px 12px;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:opacity .2s}.btn-unmark-needed:hover{opacity:.9}.btn-purchase{background-color:var(--button-success);color:white;border:none;padding:8px 12px;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:opacity .2s}.btn-purchase:hover{opacity:.9}.btn-delete{background-color:#dc3545;color:white;border:none;padding:8px 12px;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;transition:opacity .2s}.btn-delete:hover{opacity:.9}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{padding:28px;max-width:600px;max-height:90vh;overflow-y:auto}.modal,.modal-small{background-color:var(--background);color:var(--foreground);border-radius:12px;width:100%;box-shadow:0 10px 40px rgba(0,0,0,.3)}.modal-small{padding:24px;max-width:400px}.modal h2,.modal-small h2{margin-top:0;margin-bottom:20px;font-size:22px}.modal label,.modal-small label{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;font-size:14px;font-weight:500}.modal .checkboxLabel,.modal-small .checkboxLabel{flex-direction:row;align-items:center;gap:8px;font-weight:500}.modal input[type=number],.modal input[type=text],.modal select,.modal textarea,.modal-small input[type=number],.modal-small input[type=text],.modal-small select,.modal-small textarea{padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--background);color:var(--foreground);font-size:14px;font-family:inherit}.modal input[type=checkbox],.modal-small input[type=checkbox]{width:auto;margin:0}.modal textarea,.modal-small textarea{resize:vertical;min-height:80px}.stores-selection{margin-bottom:16px;padding:12px;background-color:var(--card-background);border-radius:6px;border:1px solid var(--border-color)}.stores-selection strong{display:block;margin-bottom:10px;font-size:14px}.stores-selection label{display:flex;flex-direction:row;align-items:center;gap:8px;margin-bottom:8px;font-weight:400;cursor:pointer}.modal-actions,.modal-small .modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}@media (max-width:768px){.controls,.filters{flex-direction:column;align-items:stretch}.items-grid{grid-template-columns:1fr}.header{flex-direction:column;align-items:stretch;gap:12px}.header-actions{width:100%;justify-content:flex-start}.batch-header,.records-header{flex-direction:column}.single-entry{align-items:flex-start}}