*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#1a1a1a;background:#f5f5f5}.container{max-width:800px;margin:0 auto;padding:2rem 1rem}.navbar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:#fff;border-bottom:1px solid #e0e0e0}.nav-brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.25rem;color:#212121}.nav-logo{height:32px;width:auto}.nav-user{display:flex;align-items:center;gap:.75rem}.user-avatar{width:32px;height:32px;border-radius:50%}.btn{display:inline-block;padding:.5rem 1rem;border:1px solid #ccc;border-radius:6px;background:#fff;color:#333;text-decoration:none;cursor:pointer;font-size:.875rem}.btn:hover{background:#f0f0f0}.btn-primary{background:#2d6a4f;color:#fff;border-color:#2d6a4f}.btn-primary:hover{background:#245a42}.btn-lg{padding:.75rem 2rem;font-size:1rem}.btn-sm{padding:.25rem .75rem;font-size:.8rem}.login-container{text-align:center;padding:6rem 1rem}.login-logo{width:120px;height:auto;margin-bottom:1rem}.login-container h1{font-size:2.5rem;color:#212121;margin-bottom:1rem}.login-container p{color:#666;margin-bottom:2rem;max-width:500px;margin-left:auto;margin-right:auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;gap:.75rem;flex-wrap:wrap}.dashboard-header h2{margin:0}.dashboard-actions{display:flex;gap:.5rem;align-items:center}.muted{color:#888}.grocery-list{list-style:none;margin-bottom:1.5rem;border:1px solid #e0e0e0;border-radius:8px;background:#fff;overflow:hidden}.grocery-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;border-bottom:1px solid #f0f0f0}.grocery-item:last-child{border-bottom:none}.grocery-item.checked .grocery-item-text{text-decoration:line-through;color:#aaa}.grocery-item-label{display:flex;align-items:center;gap:.6rem;cursor:pointer;flex:1}.grocery-item-label input[type=checkbox]{width:1.1rem;height:1.1rem;cursor:pointer}.grocery-section-divider{padding:.3rem .75rem;background:#f8f8f8;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#999;border-bottom:1px solid #f0f0f0}.grocery-item:hover{background:#f5faf7;cursor:pointer}.btn-danger{border-color:#e0e0e0;color:#999;padding:.15rem .5rem;font-size:1rem;line-height:1}.btn-danger:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.add-item-form{display:flex;gap:.5rem;margin-bottom:1.5rem}.add-item-input{flex:1;padding:.5rem .75rem;border:1px solid #ccc;border-radius:6px;font-size:.95rem}.add-item-input:focus{outline:none;border-color:#2d6a4f;box-shadow:0 0 0 2px #2d6a4f26}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:10px;width:100%;max-width:520px;box-shadow:0 8px 32px #0000002e}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e0e0e0}.modal-header h3{margin:0;font-size:1.1rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#888;line-height:1;padding:0 .2rem}.modal-close:hover{color:#333}.modal-body{padding:1.25rem}.modal-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem;color:#888}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.paste-textarea{width:100%;padding:.6rem .75rem;border:1px solid #ccc;border-radius:6px;font-size:.9rem;font-family:inherit;resize:vertical;margin-bottom:.75rem}.paste-textarea:focus{outline:none;border-color:#2d6a4f;box-shadow:0 0 0 2px #2d6a4f26}.preview-list{list-style:none;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;margin-bottom:.5rem;max-height:280px;overflow-y:auto}.preview-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-bottom:1px solid #f0f0f0;font-size:.9rem}.preview-item:last-child{border-bottom:none}.error-text{color:#dc2626;font-size:.875rem;margin-bottom:.5rem}.source-tags{display:flex;gap:.3rem;margin-left:.5rem}.source-tag{font-size:.65rem;padding:.1rem .4rem;border-radius:999px;font-weight:600;letter-spacing:.02em}.source-tag-ai{background:#e0f0ff;color:#1d6fa4}.source-tag-keep{background:#fef9c3;color:#856404}.pantry-badge{display:inline-block;font-size:.65rem;padding:.1rem .4rem;border-radius:999px;font-weight:600;background:#fef3c7;color:#92400e;margin-right:.4rem;letter-spacing:.02em}.preview-section-label{margin-bottom:.4rem;font-size:.8rem}.preview-item-merge{font-size:.875rem}.merge-description{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.merge-old{color:#888;text-decoration:line-through}.merge-arrow{color:#2d6a4f;font-weight:700}.merge-new{color:#1a1a1a;font-weight:600}.spinner{width:2rem;height:2rem;border:3px solid #e0e0e0;border-top-color:#2d6a4f;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading{display:flex;justify-content:center;align-items:center;height:100vh;color:#888;font-size:1.1rem}
