.app-layout{width:100%;max-width:100vw;height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--color-neutral-900);color:#fff;flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--color-neutral-700);align-items:center;gap:10px;padding:20px 16px;display:flex}.sidebar-brand h1{font-size:var(--font-size-lg);letter-spacing:-.01em;color:#fff;font-weight:600}.sidebar-nav{flex-direction:column;gap:2px;padding:8px;display:flex}.nav-item{font-size:var(--font-size-sm);color:var(--color-neutral-400);transition:all var(--transition-fast);border-radius:6px;align-items:center;gap:10px;padding:10px 12px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{color:#fff;background:var(--color-neutral-800);text-decoration:none}.nav-item--active{color:#fff;background:var(--color-primary-700)}.nav-item--active:hover{background:var(--color-primary-600)}.sidebar-footer{border-top:1px solid var(--color-neutral-700);flex-direction:column;gap:4px;margin-top:auto;padding:12px 8px;display:flex}.sidebar-support-link{font-size:var(--font-size-xs);color:var(--color-neutral-400);transition:all var(--transition-fast);border-radius:6px;align-items:center;gap:8px;margin-bottom:4px;padding:6px 8px;text-decoration:none;display:flex}.sidebar-support-link:hover{color:var(--color-primary-400);background:var(--color-neutral-800);text-decoration:none}.sidebar-user-email{font-size:var(--font-size-xs);color:var(--color-neutral-400);text-overflow:ellipsis;white-space:nowrap;padding:0 8px;overflow:hidden}.sidebar-signout{color:var(--color-neutral-400);justify-content:flex-start;gap:8px;width:100%}.sidebar-signout:hover{color:#fff;background:var(--color-neutral-800)}.mobile-header{display:none}.main-content{flex-direction:column;flex:1;max-width:1200px;min-height:0;padding:24px 32px;display:flex;overflow:hidden auto}.mobile-tab-bar{display:none}.page-header{margin-bottom:24px}.page-header h2{font-size:var(--font-size-2xl);color:var(--color-neutral-900);letter-spacing:-.02em;font-weight:600}.page-header p{color:var(--color-neutral-500);font-size:var(--font-size-sm);margin-top:4px}.page-title{font-size:var(--font-size-2xl);color:var(--color-neutral-900);letter-spacing:-.02em;font-weight:600}.page-subtitle{color:var(--color-neutral-500);font-size:var(--font-size-sm);margin-top:4px;line-height:1.5}.card{border:1px solid var(--color-neutral-200);box-shadow:var(--shadow-sm);background:#fff;border-radius:8px}.card-header{border-bottom:1px solid var(--color-neutral-100);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-header h3{font-size:var(--font-size-lg);color:var(--color-neutral-900);font-weight:600}.card-body{padding:0}.item-row{border-bottom:1px solid var(--color-neutral-100);transition:background var(--transition-fast);align-items:center;gap:12px;padding:12px 20px;display:flex}.item-row:hover{background:var(--color-neutral-50)}.item-row--selected{background:var(--color-primary-50)}.item-row--selected:hover{background:var(--color-primary-100)}.item-row:last-child{border-bottom:none}.item-name{color:var(--color-neutral-800);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;overflow:hidden}.item-quantity{color:var(--color-neutral-500);font-size:var(--font-size-sm);white-space:nowrap}.item-category-badge{font-size:var(--font-size-xs);background:var(--color-primary-50);color:var(--color-primary-700);white-space:nowrap;border-radius:12px;padding:2px 8px;font-weight:500}.item-expiring-badge{font-size:var(--font-size-xs);background:var(--color-danger-50);color:var(--color-danger-600);white-space:nowrap;border-radius:12px;padding:2px 8px;font-weight:500}.item-warning-badge{font-size:var(--font-size-xs);background:var(--color-warning-50);color:var(--color-warning-600);white-space:nowrap;border-radius:12px;padding:2px 8px;font-weight:500}.item-fresh-badge{font-size:var(--font-size-xs);background:var(--color-success-50);color:var(--color-success-700);white-space:nowrap;border-radius:12px;padding:2px 8px;font-weight:500}.item-actions{opacity:0;transition:opacity var(--transition-fast);gap:4px;display:flex}.item-row:hover .item-actions{opacity:1}.btn{font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);font-weight:500;font-family:var(--font-family);border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;line-height:1.25;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary-600);color:#fff;border-color:var(--color-primary-600)}.btn-primary:hover:not(:disabled){background:var(--color-primary-700);border-color:var(--color-primary-700)}.btn-secondary{color:var(--color-neutral-700);border-color:var(--color-neutral-300);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--color-neutral-50);border-color:var(--color-neutral-400)}.btn-danger{color:var(--color-danger-600);border-color:var(--color-danger-600);background:#fff}.btn-danger:hover:not(:disabled){background:var(--color-danger-50)}.btn-ghost{color:var(--color-neutral-500);background:0 0;border:none;padding:6px 8px}.btn-ghost:hover:not(:disabled){background:var(--color-neutral-100);color:var(--color-neutral-700)}.btn-sm{font-size:var(--font-size-xs);padding:4px 10px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{font-size:var(--font-size-sm);color:var(--color-neutral-700);font-weight:500}.form-input,.form-select,.form-textarea{border:1px solid var(--color-neutral-300);font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-neutral-800);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#fff;border-radius:6px;padding:8px 12px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100);outline:none}.form-textarea{resize:vertical;min-height:60px}.modal-overlay{z-index:50;background:#0006;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{box-shadow:var(--shadow-lg);background:#fff;border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--color-neutral-100);z-index:1;background:#fff;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.modal-header h3{font-size:var(--font-size-lg);font-weight:600}.modal-body{flex-direction:column;gap:16px;padding:20px;display:flex}.modal-footer{border-top:1px solid var(--color-neutral-100);background:#fff;justify-content:flex-end;gap:8px;padding:12px 20px;display:flex;position:sticky;bottom:0}.empty-state{text-align:center;color:var(--color-neutral-400);padding:48px 24px}.empty-state p{font-size:var(--font-size-sm);margin-top:8px}.tabs{border-bottom:2px solid var(--color-neutral-200);gap:0;margin-bottom:0;display:flex}.tab{font-size:var(--font-size-sm);color:var(--color-neutral-500);cursor:pointer;transition:all var(--transition-fast);font-weight:500;font-family:var(--font-family);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px}.tab:hover{color:var(--color-neutral-700)}.tab--active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-600)}.manage-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.manage-list-item{border-bottom:1px solid var(--color-neutral-100);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.manage-list-item:last-child{border-bottom:none}.manage-list-item span{font-size:var(--font-size-sm);color:var(--color-neutral-700)}.add-inline-form{border-top:1px solid var(--color-neutral-100);gap:8px;padding:12px 16px;display:flex}.add-inline-form input{flex:1}.bulk-cell:focus{border-color:var(--color-primary-400);box-shadow:0 0 0 2px var(--color-primary-100);background:#fff;outline:none}.bulk-cell:hover:not(:focus){border-color:var(--color-neutral-300);background:#fff}.bulk-cell[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.bulk-cell[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.bulk-cell[type=number]{-moz-appearance:textfield}.bulk-suggestion-item{cursor:pointer;font-size:var(--font-size-sm);color:var(--color-neutral-700);transition:background var(--transition-fast);align-items:center;padding:7px 12px;display:flex}.bulk-suggestion-item:hover{background:var(--color-neutral-50)}.group-header-btn{background:var(--color-neutral-50);border:none;border-bottom:1px solid var(--color-neutral-100);cursor:pointer;width:100%;font-family:var(--font-family);text-align:left;transition:background var(--transition-fast);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:11px 20px;display:flex}.group-header-btn:hover{background:var(--color-neutral-100)}.group-header-chevron{color:var(--color-neutral-400);transition:transform .2s ease, color var(--transition-fast);flex-shrink:0;align-items:center;display:inline-flex}.group-header-btn:hover .group-header-chevron{color:var(--color-neutral-600)}.group-header-label{font-size:var(--font-size-sm);color:var(--color-neutral-700);letter-spacing:-.01em;font-weight:600}.group-header-count{font-size:var(--font-size-xs);color:var(--color-neutral-400);background:var(--color-neutral-200);transition:background var(--transition-fast), color var(--transition-fast);border-radius:20px;padding:2px 8px;font-weight:500}.group-header-btn:hover .group-header-count{background:var(--color-neutral-300);color:var(--color-neutral-600)}.inventory-scroll-well{border-radius:8px;flex:1;min-height:0;overflow-y:auto}.expiring-section{margin-bottom:24px}.expiring-section h3{font-size:var(--font-size-base);color:var(--color-neutral-700);margin-bottom:8px;font-weight:600}.auth-page{background:var(--color-neutral-100);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{border:1px solid var(--color-neutral-200);background:#fff;border-radius:12px;width:100%;max-width:400px;padding:40px;box-shadow:0 4px 24px #0000000f}.auth-brand{color:var(--color-primary-600);flex-direction:column;align-items:center;gap:8px;margin-bottom:32px;display:flex}.auth-brand h1{font-size:var(--font-size-xl);color:var(--color-neutral-900);margin:0;font-weight:700}.auth-brand p{font-size:var(--font-size-sm);color:var(--color-neutral-500);margin:0}.auth-title{font-size:var(--font-size-lg);color:var(--color-neutral-900);margin:0 0 20px;font-weight:600}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-submit{justify-content:center;width:100%;margin-top:4px}.auth-error{background:var(--color-danger-50);border:1px solid var(--color-danger-200);color:var(--color-danger-700);font-size:var(--font-size-sm);border-radius:6px;padding:10px 14px}.auth-message{background:var(--color-success-50);border:1px solid var(--color-success-200);color:var(--color-success-700);font-size:var(--font-size-sm);border-radius:6px;padding:10px 14px}.auth-footer{flex-direction:column;align-items:center;gap:8px;margin-top:20px;display:flex}.auth-link{color:var(--color-primary-600);font-size:var(--font-size-sm);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:4px;text-decoration:underline}.auth-link:hover{color:var(--color-primary-700)}.auth-loading{justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-loading-spinner{border:3px solid var(--color-neutral-200);border-top-color:var(--color-primary-500);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.app-layout{flex-direction:column;height:100dvh}.sidebar{display:none}.mobile-header{background:var(--color-neutral-900);color:#fff;border-bottom:1px solid var(--color-neutral-700);flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 16px;display:flex}.mobile-header-brand{font-size:var(--font-size-base);color:#fff;align-items:center;gap:8px;font-weight:600;display:flex}.mobile-signout-btn{width:36px;height:36px;color:var(--color-neutral-400);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.mobile-signout-btn:hover{background:var(--color-neutral-800);color:#fff}.mobile-tab-bar{background:var(--color-neutral-900);border-top:1px solid var(--color-neutral-700);padding-bottom:env(safe-area-inset-bottom,0px);flex-shrink:0;align-items:stretch;display:flex}.mobile-tab{color:var(--color-neutral-400);transition:color var(--transition-fast), background var(--transition-fast);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-height:56px;padding:10px 8px;font-size:10px;font-weight:500;text-decoration:none;display:flex}.mobile-tab:hover{color:var(--color-neutral-200);background:var(--color-neutral-800);text-decoration:none}.mobile-tab--active{color:var(--color-primary-400)}.mobile-tab--active:hover{color:var(--color-primary-300)}.main-content{flex:1;min-height:0;padding:16px;overflow-y:auto}.page-header{margin-bottom:16px}.page-header h2{font-size:var(--font-size-xl)}.manage-grid{grid-template-columns:1fr}.manage-cleanup-grid{grid-template-columns:1fr!important}.item-actions{opacity:1}.item-row{min-height:52px;padding:14px 16px}.group-header-btn{min-height:48px;padding:14px 16px}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:20px 20px 0 0;width:100%;max-width:100%;max-height:92dvh}.tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{white-space:nowrap;flex-shrink:0;padding:10px 16px}.auth-card{padding:28px 24px}}.inventory-desktop-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.inventory-mobile-header,.inventory-mobile-controls,.inventory-mobile-chips{display:none}.btn-split{align-items:stretch;display:flex}.btn-split__main{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0}.btn-split__caret{min-width:unset;border-top-left-radius:0;border-bottom-left-radius:0;padding:0 8px}.inventory-bulk-menu--desktop{min-width:220px}.inventory-bulk-menu{border:1px solid var(--color-neutral-200);box-shadow:var(--shadow-md);z-index:20;background:#fff;border-radius:8px;min-width:160px;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden}.inventory-bulk-menu-item{width:100%;font-size:var(--font-size-sm);color:var(--color-neutral-700);cursor:pointer;font-weight:500;font-family:var(--font-family);text-align:left;transition:background var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;padding:10px 14px;display:flex}.inventory-bulk-menu-item:hover{background:var(--color-neutral-50)}.inventory-fab{display:none}.item-actions--desktop{display:flex}.item-actions--mobile{display:none}.item-action-btn{width:36px;height:36px;color:var(--color-neutral-400);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family);background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.item-action-btn:hover{background:var(--color-neutral-100);color:var(--color-neutral-700)}.item-action-btn--consume{color:var(--color-primary-500)}.item-action-btn--consume:hover{background:var(--color-primary-50);color:var(--color-primary-700)}.item-action-btn--primary{color:var(--color-success-600)}.item-action-btn--primary:hover{background:var(--color-success-50);color:var(--color-success-700)}.item-overflow-menu{border:1px solid var(--color-neutral-200);box-shadow:var(--shadow-md);z-index:100;background:#fff;border-radius:10px;min-width:150px;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden}.item-overflow-menu--up{top:auto;bottom:calc(100% + 4px)}.item-overflow-item{width:100%;font-size:var(--font-size-sm);color:var(--color-neutral-700);cursor:pointer;font-weight:500;font-family:var(--font-family);text-align:left;transition:background var(--transition-fast);background:0 0;border:none;align-items:center;gap:10px;padding:12px 16px;display:flex}.item-overflow-item:hover{background:var(--color-neutral-50)}.item-overflow-item--danger{color:var(--color-danger-600)}.item-overflow-item--danger:hover{background:var(--color-danger-50)}.inventory-view-pills{scrollbar-width:none;-webkit-overflow-scrolling:touch;flex:1;gap:6px;display:flex;overflow-x:auto}.inventory-view-pills::-webkit-scrollbar{display:none}.view-pill{font-size:var(--font-size-sm);white-space:nowrap;border:1px solid var(--color-neutral-300);color:var(--color-neutral-600);cursor:pointer;transition:all var(--transition-fast);font-weight:500;font-family:var(--font-family);background:#fff;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:6px 14px;display:inline-flex}.view-pill:hover{border-color:var(--color-neutral-400);color:var(--color-neutral-800)}.view-pill--active{background:var(--color-primary-600);border-color:var(--color-primary-600);color:#fff}.view-pill--active:hover{background:var(--color-primary-700);border-color:var(--color-primary-700)}.inventory-filter-btn{border:1px solid var(--color-neutral-300);width:38px;height:38px;color:var(--color-neutral-600);cursor:pointer;transition:all var(--transition-fast);background:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.inventory-filter-btn:hover{border-color:var(--color-neutral-400);color:var(--color-neutral-800)}.inventory-filter-btn--active{border-color:var(--color-primary-600);color:var(--color-primary-600);background:var(--color-primary-50)}.inventory-filter-badge{background:var(--color-primary-600);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-5px;right:-5px}.inventory-filter-sheet{max-width:480px}.bulk-table-view{flex-direction:column;display:flex}.bulk-card-view{display:none}.bulk-row-card{border:1px solid var(--color-neutral-200);box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast);background:#fff;border-radius:10px;margin-bottom:10px;padding:12px 14px}.bulk-row-card--prefilled{border-color:var(--color-primary-200);background:var(--color-primary-50)}.bulk-row-card--dirty{border-left:3px solid var(--color-primary-400)}.bulk-row-card--inactive{background:var(--color-warning-50);border-color:var(--color-warning-200)}.bulk-row-card-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.bulk-row-card-num{font-size:var(--font-size-xs);color:var(--color-neutral-400);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.bulk-row-card-name{font-size:var(--font-size-sm);color:var(--color-neutral-700);flex:1;font-weight:600}.bulk-row-card-field{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.bulk-row-card-field--full{flex:none;width:100%;margin-bottom:8px}.bulk-row-card-row{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;display:grid}.bulk-row-card-row:last-child{margin-bottom:0}.bulk-field-label{font-size:var(--font-size-xs);color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.04em;font-weight:600}@media (width<=768px){.bulk-table-view{display:none!important}.bulk-card-view{flex-direction:column;flex:1;padding-bottom:16px;display:flex;overflow-y:auto}}.bulk-page-header{flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.bulk-page-title h2{font-size:var(--font-size-2xl);color:var(--color-neutral-900);letter-spacing:-.02em;white-space:nowrap;font-weight:600}.bulk-page-title p{color:var(--color-neutral-500);font-size:var(--font-size-sm);white-space:nowrap;text-overflow:ellipsis;margin-top:4px;overflow:hidden}.bulk-page-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.bulk-hint-bar{font-size:var(--font-size-xs);color:var(--color-neutral-400);align-items:center;gap:16px;margin-bottom:8px;display:flex}.bulk-edit-mobile-warning{display:none}@media (width<=768px){.bulk-page-header{flex-wrap:wrap;gap:10px;margin-bottom:12px}.bulk-page-title h2{font-size:var(--font-size-lg);white-space:normal}.bulk-page-title p{white-space:normal;font-size:var(--font-size-xs);max-width:100%}.bulk-page-actions{justify-content:flex-end;width:100%}.bulk-hint-extra,.bulk-hint-bar{display:none}.bulk-edit-mobile-warning{background:var(--color-warning-50);border:1px solid var(--color-warning-400);font-size:var(--font-size-sm);color:var(--color-warning-700);border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;display:flex}.inventory-desktop-header,.inventory-desktop-controls{display:none}.inventory-mobile-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.inventory-mobile-controls{align-items:center;gap:8px;margin-bottom:8px;display:flex}.inventory-mobile-chips{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.inventory-fab{bottom:calc(72px + env(safe-area-inset-bottom,0px));background:var(--color-primary-600);color:#fff;cursor:pointer;width:56px;height:56px;transition:all var(--transition-fast);z-index:30;border:none;border-radius:28px;justify-content:center;align-items:center;display:flex;position:fixed;right:20px;box-shadow:0 4px 16px #0003}.inventory-fab:hover{background:var(--color-primary-700);transform:scale(1.05)}.inventory-fab:active{transform:scale(.97)}.item-actions--desktop{display:none}.item-actions--mobile{flex-shrink:0;align-items:center;gap:2px;display:flex}.item-row-tags{display:none}}.shopping-more-btn{border:1px solid var(--color-neutral-300);width:36px;height:36px;color:var(--color-neutral-500);cursor:pointer;transition:all var(--transition-fast);background:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.shopping-more-btn:hover{border-color:var(--color-neutral-400);color:var(--color-neutral-700)}.shopping-more-btn--active{border-color:var(--color-primary-400);background:var(--color-primary-50);color:var(--color-primary-600)}.shopping-row{border-bottom:1px solid var(--color-neutral-100);transition:background var(--transition-fast);align-items:center;gap:12px;padding:12px 16px;display:flex}.shopping-row:last-child{border-bottom:none}.shopping-row:hover{background:var(--color-neutral-50)}.shopping-row--purchased{opacity:.55}.shopping-row--purchased .shopping-row-name{color:var(--color-neutral-400);text-decoration:line-through}.shopping-check-btn{border:2px solid var(--color-neutral-300);cursor:pointer;width:24px;min-width:24px;height:24px;transition:all var(--transition-fast);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.shopping-check-btn:hover{border-color:var(--color-primary-400);background:var(--color-primary-50)}.shopping-row--purchased .shopping-check-btn{background:var(--color-success-500);border-color:var(--color-success-500)}.shopping-row-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.shopping-row-name{font-size:var(--font-size-base);color:var(--color-neutral-800);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.shopping-row-meta{font-size:var(--font-size-xs);color:var(--color-neutral-400)}.shopping-remove-btn{width:32px;height:32px;color:var(--color-neutral-300);cursor:pointer;transition:all var(--transition-fast);opacity:0;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.shopping-row:hover .shopping-remove-btn{opacity:1}.shopping-remove-btn:hover{background:var(--color-danger-50);color:var(--color-danger-500)}.shopping-favorite-btn{width:32px;height:32px;color:var(--color-neutral-400);cursor:pointer;transition:all var(--transition-fast);opacity:0;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.shopping-row:hover .shopping-favorite-btn{opacity:1}.shopping-favorite-btn:hover{background:var(--color-warning-50);color:var(--color-warning-500)}.shopping-favorite-btn--active{color:var(--color-warning-500);opacity:1}@media (width<=768px){.shopping-favorite-btn{opacity:1;width:28px;height:28px}.shopping-check-btn{width:28px;min-width:28px;height:28px}.shopping-remove-btn{opacity:1}}.manage-section{border:1px solid var(--color-neutral-200);box-shadow:var(--shadow-sm);background:#fff;border-radius:10px;overflow:hidden}.manage-section+.manage-section{margin-top:12px}.manage-section-header{cursor:pointer;width:100%;font-family:var(--font-family);transition:background var(--transition-fast);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.manage-section-header:hover{background:var(--color-neutral-50)}.manage-section-title{font-size:var(--font-size-base);color:var(--color-neutral-800);align-items:center;gap:10px;font-weight:600;display:flex}.manage-badge{background:var(--color-neutral-100);min-width:20px;height:20px;color:var(--color-neutral-500);border-radius:10px;justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:600;display:inline-flex}.manage-badge--warning{background:var(--color-warning-100);color:var(--color-warning-700)}.onboarding-welcome{background:var(--color-neutral-50);justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.onboarding-welcome-inner{text-align:center;width:100%;max-width:520px}.onboarding-welcome-icon{background:var(--color-primary-50);border-radius:24px;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 24px;display:flex}.onboarding-welcome-title{font-size:var(--font-size-2xl);color:var(--color-neutral-900);letter-spacing:-.02em;margin:0 0 8px;font-weight:800}.onboarding-welcome-tagline{font-size:var(--font-size-lg);color:var(--color-primary-600);margin:0 0 16px;font-weight:600}.onboarding-welcome-body{font-size:var(--font-size-sm);color:var(--color-neutral-500);margin:0 0 32px;line-height:1.7}.onboarding-welcome-steps{text-align:left;flex-direction:column;gap:16px;margin-bottom:36px;display:flex}.onboarding-welcome-step{border:1px solid var(--color-neutral-150);background:#fff;border-radius:12px;align-items:flex-start;gap:14px;padding:16px;display:flex}.onboarding-welcome-step-icon{background:var(--color-primary-50);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.onboarding-welcome-step-title{font-size:var(--font-size-sm);color:var(--color-neutral-800);margin-bottom:3px;font-weight:700}.onboarding-welcome-step-body{font-size:var(--font-size-xs);color:var(--color-neutral-500);line-height:1.5}.onboarding-welcome-actions{flex-direction:column;align-items:center;gap:12px;display:flex}@media (width<=768px){.onboarding-welcome{align-items:flex-start;padding:32px 20px}.onboarding-welcome-title{font-size:var(--font-size-xl)}}.manage-toggle{background:var(--color-neutral-200);cursor:pointer;border:none;border-radius:11px;flex-shrink:0;width:40px;height:22px;transition:background .2s;position:relative}.manage-toggle:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.manage-toggle--on{background:var(--color-primary-500)}.manage-toggle--on:after{transform:translate(18px)}.onboarding-page{background:var(--color-neutral-50);flex-direction:column;min-height:100vh;display:flex}.onboarding-header{border-bottom:1px solid var(--color-neutral-150);z-index:100;box-shadow:var(--shadow-sm);background:#fff;padding:20px 24px 0;position:sticky;top:0}.onboarding-header-inner{justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:16px;display:flex}.onboarding-brand{align-items:flex-start;gap:12px;display:flex}.onboarding-title{font-size:var(--font-size-xl);color:var(--color-neutral-900);margin:0 0 4px;font-weight:700}.onboarding-subtitle{font-size:var(--font-size-sm);color:var(--color-neutral-500);max-width:380px;margin:0;line-height:1.5}.onboarding-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.onboarding-selection-bar{border-top:1px solid var(--color-neutral-100);font-size:var(--font-size-sm);color:var(--color-neutral-600);justify-content:space-between;align-items:center;padding:8px 0 12px;display:flex}.onboarding-category-pills{scrollbar-width:none;gap:8px;padding:16px 24px;display:flex;overflow-x:auto}.onboarding-category-pills::-webkit-scrollbar{display:none}.onboarding-pill{font-size:var(--font-size-sm);white-space:nowrap;border:1.5px solid var(--color-neutral-200);color:var(--color-neutral-600);cursor:pointer;transition:all var(--transition-fast);background:#fff;border-radius:20px;flex-shrink:0;align-items:center;gap:5px;padding:6px 14px;font-weight:500;display:inline-flex}.onboarding-pill:hover{border-color:var(--color-primary-300);color:var(--color-primary-700)}.onboarding-pill--active{border-color:var(--color-primary-500);background:var(--color-primary-50);color:var(--color-primary-700)}.onboarding-pill-badge{background:var(--color-primary-500);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:11px;font-weight:700;display:inline-flex}.onboarding-body{flex:1;padding:0 24px 100px}.onboarding-sections{flex-direction:column;gap:28px;display:flex}.onboarding-section-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.onboarding-section-emoji{font-size:20px;line-height:1}.onboarding-section-title{font-size:var(--font-size-base);color:var(--color-neutral-800);flex:1;margin:0;font-weight:700}.onboarding-section-count{font-size:var(--font-size-xs);color:var(--color-neutral-400);font-weight:500}.onboarding-item-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;display:grid}.onboarding-item{border:1.5px solid var(--color-neutral-200);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:#fff;border-radius:8px;align-items:center;gap:8px;min-height:44px;padding:10px 12px;display:flex}.onboarding-item:hover{border-color:var(--color-primary-300);background:var(--color-primary-50)}.onboarding-item--selected{border-color:var(--color-primary-500);background:var(--color-primary-50)}.onboarding-item-check{border:1.5px solid var(--color-neutral-300);width:20px;height:20px;color:var(--color-neutral-300);transition:all var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.onboarding-item--selected .onboarding-item-check{background:var(--color-primary-500);border-color:var(--color-primary-500);color:#fff}.onboarding-item-name{font-size:var(--font-size-sm);color:var(--color-neutral-700);flex:1;font-weight:500;line-height:1.3}.onboarding-item--selected .onboarding-item-name{color:var(--color-primary-700)}.onboarding-item-unit{color:var(--color-neutral-400);white-space:nowrap;border-left:1px solid var(--color-neutral-200);margin-left:5px;padding-left:5px;font-size:11px}.onboarding-sticky-bar{bottom:0;left:var(--sidebar-width);border-top:1px solid var(--color-neutral-200);z-index:200;background:#fff;justify-content:space-between;align-items:center;gap:12px;padding:12px 20px;display:flex;position:fixed;right:0;box-shadow:0 -4px 16px #00000014}@media (width<=768px){.onboarding-sticky-bar{left:0;bottom:calc(56px + env(safe-area-inset-bottom,0px))}}.onboarding-sticky-count{font-size:var(--font-size-sm);color:var(--color-neutral-700);font-weight:600}@media (width<=768px){.onboarding-header-inner{flex-direction:column;gap:12px}.onboarding-brand{flex-direction:column;gap:8px}.onboarding-header-actions{justify-content:space-between;width:100%}.onboarding-body{padding:0 16px 120px}.onboarding-item-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px}.onboarding-category-pills{padding:12px 16px}}.help-btn{background:var(--color-neutral-100);border:1px solid var(--color-neutral-200);width:28px;height:28px;color:var(--color-neutral-500);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;line-height:1;transition:background .15s,color .15s,border-color .15s;display:flex}.help-btn:hover{background:var(--color-primary-50);border-color:var(--color-primary-200);color:var(--color-primary-600)}.help-modal{width:100%;max-width:480px}.help-modal-body{flex-direction:column;gap:16px;max-height:60vh;padding:20px 24px;display:flex;overflow-y:auto}.help-section{flex-direction:column;gap:4px;display:flex}.help-section-heading{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-neutral-700);font-weight:700}.help-section-body{font-size:var(--font-size-sm);color:var(--color-neutral-600);line-height:1.65}.quick-add-page{flex-direction:column;height:100%;display:flex;overflow:hidden}.quick-add-header{border-bottom:1px solid var(--color-neutral-200);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.quick-add-title{font-size:var(--font-size-lg);color:var(--color-neutral-800);font-weight:600}.quick-add-tabs{border-bottom:1px solid var(--color-neutral-200);flex-shrink:0;gap:0;padding:0 20px;display:flex}.quick-add-tab{font-size:var(--font-size-sm);color:var(--color-neutral-500);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 16px;font-weight:500;transition:color .15s,border-color .15s;display:flex}.quick-add-tab:hover{color:var(--color-neutral-700)}.quick-add-tab--active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-500)}.quick-add-body{flex:1;padding:16px 20px 100px;overflow-y:auto}.quick-add-filter-row{align-items:center;gap:8px;margin-bottom:10px;display:flex}.quick-add-fav-btn{border:1.5px solid var(--color-neutral-200);width:36px;height:36px;color:var(--color-neutral-400);cursor:pointer;transition:all var(--transition-fast);background:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.quick-add-fav-btn:hover{border-color:var(--color-warning-400);color:var(--color-warning-500);background:var(--color-warning-50)}.quick-add-fav-btn--active{border-color:var(--color-warning-400);background:var(--color-warning-50);color:var(--color-warning-500)}.quick-add-filters-toggle{flex-shrink:0;align-items:center;gap:5px;display:flex;position:relative}.quick-add-filters-toggle--active{background:var(--color-primary-50);border-color:var(--color-primary-300);color:var(--color-primary-700)}.quick-add-filter-badge{background:var(--color-primary-500);color:#fff;text-align:center;border-radius:8px;min-width:16px;padding:1px 5px;font-size:10px;font-weight:700}.quick-add-filters-panel{background:var(--color-neutral-50);border:1px solid var(--color-neutral-200);border-radius:8px;flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:12px;padding:14px 16px;display:flex}.quick-add-filter-group{flex-direction:column;gap:4px;min-width:140px;display:flex}.quick-add-filter-label{font-size:var(--font-size-xs);color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.form-select--sm{font-size:var(--font-size-sm);padding:6px 10px}.quick-add-card-wrap{align-items:stretch;display:flex;position:relative}.quick-add-card-wrap .onboarding-item{flex:1;min-width:0;padding-right:22px}.quick-add-star-btn{width:20px;height:20px;color:var(--color-neutral-300);cursor:pointer;transition:all var(--transition-fast);z-index:1;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.quick-add-star-btn:hover{color:var(--color-warning-500);background:var(--color-warning-50)}.quick-add-star-btn--active{color:var(--color-warning-500)}.onboarding-item--inactive{opacity:.7}.quick-add-catalog-prompt{color:var(--color-neutral-500);font-size:var(--font-size-sm);border-top:1px solid var(--color-neutral-100);align-items:center;gap:8px;margin-top:8px;padding:16px 0;display:flex}.quick-add-search-wrap{background:var(--color-neutral-50);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);align-items:center;gap:8px;margin-bottom:0;padding:8px 12px;display:flex}.quick-add-search{font-size:var(--font-size-sm);color:var(--color-neutral-800);background:0 0;border:none;outline:none;flex:1}.quick-add-search::placeholder{color:var(--color-neutral-400)}.quick-add-sections{flex-direction:column;gap:20px;display:flex}.quick-add-section{flex-direction:column;gap:8px;display:flex}.quick-add-section-header{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-neutral-500);border-bottom:1px solid var(--color-neutral-100);align-items:center;gap:6px;padding-bottom:4px;font-weight:600;display:flex}.favorite-toggle-btn{border:1.5px solid var(--color-neutral-200);color:var(--color-neutral-600);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);background:#fff;border-radius:6px;align-items:center;gap:7px;padding:7px 14px;font-weight:500;display:inline-flex}.favorite-toggle-btn:hover{border-color:var(--color-warning-400);color:var(--color-warning-600);background:var(--color-warning-50)}.favorite-toggle-btn--active{border-color:var(--color-warning-400);background:var(--color-warning-50);color:var(--color-warning-600)}.favorites-controls{margin-bottom:16px}.view-mode-tabs{background:var(--color-neutral-100);border-radius:8px;flex-wrap:wrap;gap:4px;width:fit-content;padding:4px;display:flex}.view-mode-tab{font-size:var(--font-size-sm);color:var(--color-neutral-600);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-weight:500;display:flex}.view-mode-tab:hover{background:var(--color-neutral-200);color:var(--color-neutral-800)}.view-mode-tab--active{color:var(--color-neutral-900);box-shadow:var(--shadow-sm);background:#fff}.view-mode-tab-badge{background:var(--color-warning-500);color:#fff;text-align:center;border-radius:10px;min-width:18px;padding:1px 6px;font-size:11px;font-weight:700}.favorites-sections{flex-direction:column;gap:8px;display:flex}.favorites-section{border:1px solid var(--color-neutral-200);background:#fff;border-radius:10px;overflow:hidden}.favorites-section-header-row{background:var(--color-neutral-50);border-bottom:1px solid var(--color-neutral-100);align-items:center;display:flex}.favorites-select-all{font-size:var(--font-size-xs);color:var(--color-neutral-500);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:center;gap:5px;padding:0 14px;display:flex}.favorites-section-header{cursor:pointer;text-align:left;transition:background var(--transition-fast);color:var(--color-neutral-700);background:0 0;border:none;flex:1;align-items:center;gap:8px;padding:12px 16px;display:flex}.favorites-section-header:hover{background:var(--color-neutral-100)}.favorites-section-title{font-size:var(--font-size-sm);color:var(--color-neutral-700);flex:1;font-weight:600}.favorites-section-count{font-size:var(--font-size-xs);color:var(--color-neutral-500);background:var(--color-neutral-200);border-radius:10px;padding:2px 8px;font-weight:600}.favorites-section-empty{font-size:var(--font-size-sm);color:var(--color-neutral-500);text-align:center;padding:16px;font-style:italic}.favorites-items,.favorites-list{flex-direction:column;display:flex}.favorite-item-row{border-bottom:1px solid var(--color-neutral-100);transition:background var(--transition-fast);align-items:center;gap:12px;padding:12px 16px;display:flex}.favorite-item-row:last-child{border-bottom:none}.favorite-item-row:hover{background:var(--color-neutral-50)}.favorite-item-row--selected{background:var(--color-primary-50)}.favorite-item-row--selected:hover{background:var(--color-primary-100)}.favorite-checkbox{border:2px solid var(--color-neutral-300);cursor:pointer;width:20px;height:20px;transition:all var(--transition-fast);color:#fff;background:#fff;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.favorite-checkbox:hover{border-color:var(--color-primary-500)}.favorite-checkbox--checked{background:var(--color-primary-500);border-color:var(--color-primary-500)}.favorite-item-info{flex:1;min-width:0}.favorite-item-name{font-size:var(--font-size-sm);color:var(--color-neutral-800);white-space:nowrap;text-overflow:ellipsis;font-weight:500;display:block;overflow:hidden}.favorite-item-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-top:3px;display:flex}.favorite-meta-chip{font-size:var(--font-size-xs);color:var(--color-neutral-500);background:var(--color-neutral-100);border-radius:4px;padding:1px 6px}.favorite-meta-chip--category{background:var(--color-primary-50);color:var(--color-primary-700)}.favorite-status-badge{font-size:var(--font-size-xs);border-radius:4px;padding:1px 7px;font-weight:600}.favorite-status-badge--in-stock{background:var(--color-success-50);color:var(--color-success-700)}.favorite-status-badge--out-of-stock{background:var(--color-warning-50);color:var(--color-warning-700)}.favorite-item-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.favorite-unfavorite-btn{color:var(--color-warning-500);padding:4px 6px}.favorite-unfavorite-btn:hover{color:var(--color-warning-600);background:var(--color-warning-50)}.favorite-action-label{display:inline}.btn-success{background:var(--color-success-500);color:#fff;border:1px solid var(--color-success-600);font-size:var(--font-size-sm);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-weight:500;display:inline-flex}.bulk-action-bar{bottom:calc(env(safe-area-inset-bottom) + 64px);left:calc(var(--sidebar-width) + 16px);background:var(--color-neutral-900);color:#fff;box-shadow:var(--shadow-lg);z-index:200;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;display:flex;position:fixed;right:16px}.bulk-action-count{font-size:var(--font-size-sm);flex:1;font-weight:600}@media (width<=768px){.bulk-action-bar{left:8px;right:8px;bottom:calc(env(safe-area-inset-bottom) + 72px)}.favorite-action-label{display:none}}@media (width<=375px){.main-content{padding:12px}.item-row{gap:8px}.item-category-badge{display:none}}.landing{min-height:100vh;font-family:var(--font-family);color:var(--color-neutral-800);background:var(--color-neutral-50)}.landing-nav{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-neutral-200);background:#ffffffeb;position:fixed;top:0;left:0;right:0}.landing-nav-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:14px 24px;display:flex}.landing-nav-brand{font-weight:700;font-size:var(--font-size-lg);color:var(--color-neutral-900);align-items:center;gap:8px;display:flex}.landing-nav-brand svg{color:var(--color-primary-600)}.landing-nav-actions{align-items:center;gap:8px;display:flex}.landing-hero{background:linear-gradient(180deg, var(--color-neutral-50) 0%, white 100%);padding:120px 24px 80px}.landing-hero-inner{grid-template-columns:1fr 1fr;align-items:center;gap:64px;max-width:1200px;margin:0 auto;display:grid}.landing-hero-title{color:var(--color-neutral-900);letter-spacing:-.02em;font-size:3rem;font-weight:800;line-height:1.15}.landing-hero-subtitle{font-size:var(--font-size-lg);color:var(--color-neutral-600);max-width:520px;margin-top:20px;line-height:1.65}.landing-hero-cta{flex-wrap:wrap;align-items:center;gap:16px;margin-top:32px;display:flex}.landing-hero-cta .btn-lg{font-size:var(--font-size-base);align-items:center;gap:8px;padding:14px 28px;display:inline-flex}.landing-hero-note{font-size:var(--font-size-sm);color:var(--color-neutral-400)}.landing-section-inner{max-width:1200px;margin:0 auto;padding:0 24px}.landing-section-title{text-align:center;color:var(--color-neutral-900);letter-spacing:-.01em;font-size:2rem;font-weight:700}.landing-section-subtitle{text-align:center;font-size:var(--font-size-lg);color:var(--color-neutral-500);max-width:600px;margin-top:12px;margin-left:auto;margin-right:auto}.landing-features{background:#fff;padding:96px 0}.landing-features-grid{grid-template-columns:repeat(3,1fr);gap:32px;margin-top:56px;display:grid}.landing-feature-card{background:var(--color-neutral-50);border:1px solid var(--color-neutral-200);transition:transform var(--transition-base), box-shadow var(--transition-base);border-radius:12px;padding:32px}.landing-feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.landing-feature-icon{background:var(--color-primary-100);width:48px;height:48px;color:var(--color-primary-700);border-radius:10px;justify-content:center;align-items:center;margin-bottom:20px;display:flex}.landing-feature-card h3{font-size:var(--font-size-lg);color:var(--color-neutral-900);margin-bottom:8px;font-weight:600}.landing-feature-card p{font-size:var(--font-size-sm);color:var(--color-neutral-500);line-height:1.65}.landing-how{background:var(--color-neutral-50);padding:96px 0}.landing-how-steps{grid-template-columns:repeat(3,1fr);gap:40px;margin-top:56px;display:grid}.landing-how-step{text-align:center}.landing-how-number{background:var(--color-primary-600);color:#fff;width:40px;height:40px;font-weight:700;font-size:var(--font-size-lg);border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;display:inline-flex}.landing-how-step h3{font-size:var(--font-size-base);color:var(--color-neutral-900);margin-bottom:8px;font-weight:600}.landing-how-step p{font-size:var(--font-size-sm);color:var(--color-neutral-500);max-width:280px;margin:0 auto;line-height:1.65}.landing-insurance{background:var(--color-neutral-900);color:#fff;padding:80px 0}.landing-insurance-content{text-align:center;max-width:640px;margin:0 auto}.landing-insurance-icon{color:var(--color-primary-400);margin-bottom:20px}.landing-insurance-content h2{margin-bottom:16px;font-size:1.75rem;font-weight:700}.landing-insurance-content p{font-size:var(--font-size-base);color:var(--color-neutral-300);line-height:1.7}.landing-insurance-coming{font-size:var(--font-size-sm);color:var(--color-neutral-400);margin-top:16px;font-style:italic}.landing-benefits{background:#fff;padding:96px 0}.landing-benefits-grid{grid-template-columns:repeat(2,1fr);gap:20px 48px;max-width:720px;margin-top:48px;margin-left:auto;margin-right:auto;display:grid}.landing-benefit-item{font-size:var(--font-size-base);color:var(--color-neutral-700);align-items:center;gap:12px;display:flex}.landing-benefit-check{color:var(--color-primary-600);flex-shrink:0}.landing-roadmap{background:#fff;padding:96px 0}.landing-roadmap-grid{grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;display:grid}.landing-roadmap-card{background:var(--color-neutral-50);border:1px dashed var(--color-neutral-300);text-align:center;border-radius:12px;padding:28px}.landing-roadmap-icon{color:var(--color-primary-600);margin-bottom:16px}.landing-roadmap-card h3{font-size:var(--font-size-base);color:var(--color-neutral-800);margin-bottom:8px;font-weight:600}.landing-roadmap-card p{font-size:var(--font-size-sm);color:var(--color-neutral-500);line-height:1.6}@media (width<=768px){.landing-roadmap-grid{grid-template-columns:1fr}}.landing-faq{background:var(--color-neutral-50);padding:96px 0}.landing-faq-list{max-width:640px;margin-top:48px;margin-left:auto;margin-right:auto}.landing-faq-item{border-bottom:1px solid var(--color-neutral-200)}.landing-faq-question{cursor:pointer;width:100%;font-size:var(--font-size-base);color:var(--color-neutral-800);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:16px;padding:20px 0;font-weight:500;display:flex}.landing-faq-chevron{color:var(--color-neutral-400);transition:transform var(--transition-base);flex-shrink:0}.landing-faq-item--open .landing-faq-chevron{transform:rotate(180deg)}.landing-faq-answer{max-height:0;transition:max-height .3s,padding .3s;overflow:hidden}.landing-faq-item--open .landing-faq-answer{max-height:200px;padding-bottom:20px}.landing-faq-answer p{font-size:var(--font-size-sm);color:var(--color-neutral-500);line-height:1.7}.landing-final-cta{text-align:center;background:#fff;padding:96px 0}.landing-final-cta h2{color:var(--color-neutral-900);margin-bottom:12px;font-size:1.75rem;font-weight:700}.landing-final-cta p{font-size:var(--font-size-base);color:var(--color-neutral-500);margin-bottom:32px}.landing-final-cta .btn-lg{font-size:var(--font-size-base);align-items:center;gap:8px;padding:14px 28px;display:inline-flex}.landing-footer{background:var(--color-neutral-100);border-top:1px solid var(--color-neutral-200);padding:32px 0}.landing-footer-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 24px;display:flex}.landing-footer-brand{color:var(--color-neutral-700);align-items:center;gap:8px;font-weight:600;display:flex}.landing-footer-brand svg{color:var(--color-primary-600)}.landing-footer-copy{font-size:var(--font-size-xs);color:var(--color-neutral-400)}.auth-back-link{font-size:var(--font-size-sm);color:var(--color-neutral-400);transition:color var(--transition-fast);align-items:center;gap:4px;margin-bottom:20px;text-decoration:none;display:inline-flex}.auth-back-link:hover{color:var(--color-primary-600)}@media (width<=768px){.landing-hero{padding:100px 20px 60px}.landing-hero-inner{grid-template-columns:1fr;gap:48px}.landing-hero-title{font-size:2rem}.landing-hero-subtitle{font-size:var(--font-size-base)}.landing-features-grid{grid-template-columns:1fr;gap:20px}.landing-how-steps{grid-template-columns:1fr;gap:32px}.landing-benefits-grid{grid-template-columns:1fr}.landing-section-title{font-size:1.5rem}.landing-footer-inner{text-align:center;flex-direction:column;gap:12px}}.demo-window{border:1px solid var(--color-neutral-200);background:#fff;border-radius:12px;width:100%;max-width:480px;position:relative;overflow:hidden;box-shadow:0 20px 60px #0000001f,0 8px 20px #0000000f}.demo-titlebar{background:var(--color-neutral-100);border-bottom:1px solid var(--color-neutral-200);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.demo-titlebar-dots{gap:6px;display:flex}.demo-dot{background:var(--color-neutral-300);border-radius:50%;width:10px;height:10px}.demo-dot--red{background:#ff5f57}.demo-dot--yellow{background:#febc2e}.demo-dot--green{background:#28c840}.demo-titlebar-text{font-size:var(--font-size-xs);color:var(--color-neutral-500);font-weight:500}.demo-toolbar{background:var(--color-neutral-50);border-bottom:1px solid var(--color-neutral-200);gap:2px;padding:8px 12px;display:flex}.demo-tab{color:var(--color-neutral-500);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-size:11px;font-weight:500;display:inline-flex}.demo-tab:hover{background:var(--color-neutral-200);color:var(--color-neutral-700)}.demo-tab--active{background:var(--color-primary-100);color:var(--color-primary-700)}.demo-content{max-height:360px;padding:12px;overflow-y:auto}.demo-header{justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 4px;display:flex}.demo-header h3{font-size:var(--font-size-sm);color:var(--color-neutral-900);font-weight:600}.demo-count{color:var(--color-neutral-400);font-size:11px}.demo-list{flex-direction:column;gap:2px;display:flex}.demo-group{margin-bottom:4px}.demo-group-header{cursor:pointer;width:100%;color:var(--color-neutral-700);transition:background var(--transition-fast);background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 8px;font-size:12px;font-weight:600;display:flex}.demo-group-header:hover{background:var(--color-neutral-100)}.demo-group-name{text-align:left;flex:1}.demo-group-badge{background:var(--color-neutral-200);color:var(--color-neutral-500);border-radius:8px;padding:1px 6px;font-size:10px;font-weight:500}.demo-group-items{margin-top:2px;padding-left:8px}.demo-item{transition:background var(--transition-fast);border-radius:4px;align-items:center;gap:6px;padding:5px 8px;font-size:11px;display:flex}.demo-item:hover{background:var(--color-neutral-50)}.demo-star{color:var(--color-neutral-300);flex-shrink:0}.demo-star--active{color:var(--color-warning-400)}.demo-item-name{color:var(--color-neutral-800);flex:1;font-weight:500}.demo-item-qty{color:var(--color-neutral-400);font-size:10px}.demo-item-expiry{background:var(--color-warning-100);color:var(--color-warning-700);white-space:nowrap;border-radius:4px;padding:1px 5px;font-size:9px}.demo-shopping-item{transition:background var(--transition-fast);border-radius:6px;align-items:center;gap:8px;padding:8px;display:flex}.demo-shopping-item:hover{background:var(--color-neutral-50)}.demo-shopping-check{border:2px solid var(--color-neutral-300);cursor:pointer;width:18px;height:18px;transition:all var(--transition-fast);color:#fff;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.demo-shopping-item--done .demo-shopping-check{background:var(--color-primary-500);border-color:var(--color-primary-500)}.demo-shopping-name{color:var(--color-neutral-700);font-size:12px;font-weight:500}.demo-shopping-name--done{color:var(--color-neutral-400);text-decoration:line-through}.demo-restock-bar{border-top:1px solid var(--color-neutral-100);justify-content:center;margin-top:12px;padding-top:12px;display:flex}.demo-restock-btn{background:var(--color-primary-600);color:#fff;cursor:pointer;transition:background var(--transition-fast);border:none;border-radius:6px;padding:6px 16px;font-size:11px;font-weight:600}.demo-restock-btn:hover{background:var(--color-primary-700)}.demo-label{text-align:center;color:var(--color-neutral-400);background:var(--color-neutral-50);border-top:1px solid var(--color-neutral-100);padding:8px;font-size:10px}@media (width<=768px){.demo-window{max-width:100%}.demo-content{max-height:280px}.landing-hero-demo{justify-content:center;display:flex}}:root{--color-primary-50:#f0fdfa;--color-primary-100:#ccfbf1;--color-primary-200:#99f6e4;--color-primary-300:#5eead4;--color-primary-400:#2dd4bf;--color-primary-500:#14b8a6;--color-primary-600:#0d9488;--color-primary-700:#0f766e;--color-primary-800:#115e59;--color-primary-900:#134e4a;--color-neutral-50:#fafafa;--color-neutral-100:#f5f5f5;--color-neutral-200:#e5e5e5;--color-neutral-300:#d4d4d4;--color-neutral-400:#a3a3a3;--color-neutral-500:#737373;--color-neutral-600:#525252;--color-neutral-700:#404040;--color-neutral-800:#262626;--color-neutral-900:#171717;--color-danger-50:#fef2f2;--color-danger-500:#ef4444;--color-danger-600:#dc2626;--color-warning-50:#fffbeb;--color-warning-400:#fbbf24;--color-warning-500:#f59e0b;--color-warning-600:#d97706;--color-warning-700:#b45309;--color-success-50:#f0fdf4;--color-success-200:#bbf7d0;--color-success-500:#22c55e;--color-success-600:#16a34a;--color-success-700:#15803d;--color-danger-200:#fecaca;--color-danger-700:#b91c1c;--sidebar-width:240px;--header-height:56px;--font-family:"Inter", system-ui, -apple-system, sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--transition-fast:.15s ease;--transition-base:.2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-neutral-800);background:var(--color-neutral-50);line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--color-primary-600);text-decoration:none}a:hover{text-decoration:underline}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
