*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green-50: #f0fdf4;--green-100: #dcfce7;--green-500: #22c55e;--green-600: #16a34a;--green-700: #15803d;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-700: #374151;--gray-900: #111827;--red-500: #ef4444;--red-600: #dc2626;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1)}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--gray-50);color:var(--gray-900);line-height:1.5;min-height:100dvh}#root{min-height:100dvh;display:flex;flex-direction:column}.page{flex:1;display:flex;flex-direction:column;max-width:640px;width:100%;margin:0 auto}.app-bar{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;gap:8px;padding:0 16px;height:56px;box-shadow:var(--shadow-sm)}.app-bar__title{flex:1;font-size:1.125rem;font-weight:700;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-bar__title--editable{background:transparent;border:none;outline:none;border-radius:var(--radius-sm, 4px);padding:2px 4px;margin:0 -4px;min-width:0}.app-bar__title--editable:focus{background:var(--gray-100, #f3f4f6)}.app-bar__logo{font-size:1.375rem;line-height:1}.btn-back{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:none;background:transparent;color:var(--gray-700);cursor:pointer;font-size:1.5rem;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:background .15s}.btn-back:active{background:var(--gray-100)}.page-content{flex:1;overflow-y:auto;padding:16px}.list-cards{display:flex;flex-direction:column;gap:10px}.list-card{display:flex;align-items:center;gap:14px;background:#fff;border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-sm);cursor:pointer;border:1px solid var(--gray-100);-webkit-tap-highlight-color:transparent;transition:box-shadow .15s,transform .1s;text-align:left;width:100%}.list-card:active{box-shadow:none;transform:scale(.985)}.list-card__icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--green-100);color:var(--green-700);display:flex;align-items:center;justify-content:center;font-size:1.375rem;flex-shrink:0}.list-card__name{font-size:1rem;font-weight:600;color:var(--gray-900)}.list-card__chevron{margin-left:auto;color:var(--gray-400);font-size:1.125rem;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;text-align:center;color:var(--gray-400)}.empty-state__icon{font-size:3rem;line-height:1}.empty-state__text{font-size:.9375rem}.category-section{margin-bottom:8px}.category-header{display:flex;align-items:center;justify-content:space-between;padding:10px 4px 6px;position:sticky;top:0;z-index:5;background:var(--gray-50)}.category-header__name{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-500)}.category-header__add{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--green-600);font-size:1.625rem;line-height:1;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}.category-header__add:active{background:var(--green-100)}.item-list{display:flex;flex-direction:column;gap:4px}.item-row{display:flex;align-items:center;gap:10px;background:#fff;border-radius:var(--radius-md);padding:4px 8px;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100)}.item-row__checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:24px;height:24px;border-radius:50%;border:2px solid var(--gray-300, #d1d5db);background:#fff;cursor:pointer;flex-shrink:0;position:relative;transition:background .15s,border-color .15s}.item-row__checkbox:checked{background:var(--green-500);border-color:var(--green-500)}.item-row__checkbox:checked:after{content:"";position:absolute;top:4px;left:7px;width:5px;height:9px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg)}.item-row__fields{flex:1;display:flex;flex-wrap:wrap;gap:6px;min-width:0}.item-row__name-block{flex:1;min-width:120px;display:flex;flex-direction:column}.item-row__name{flex:1;min-width:120px;font-size:1rem}.item-row__french-name{font-size:.75rem;color:var(--gray-400);font-style:italic;padding:0 2px;line-height:1.4}.item-row--checked .item-row__french-name{text-decoration:line-through}.item-row__suggestion{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--gray-500);padding:0 2px;line-height:1.4}.item-row__suggestion-accept{display:inline-flex;align-items:center;padding:1px 8px;border-radius:10px;border:1px solid var(--green-500);background:transparent;color:var(--green-600);font-size:.6875rem;font-weight:600;font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s}.item-row__suggestion-accept:active{background:var(--green-100)}.item-row__category{flex:0 0 auto;width:100px;max-width:30%;text-align:right;font-size:.8125rem;color:var(--gray-500);cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239ca3af'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center;padding-right:18px}.item-row__category:focus{color:var(--gray-900)}.item-row--checked .item-row__name,.item-row--checked .item-row__category{color:var(--gray-400);text-decoration:line-through}.item-input{border:none;border-bottom:1.5px solid transparent;border-radius:0;background:transparent;padding:4px 2px;font-family:inherit;font-size:inherit;color:inherit;outline:none;transition:border-color .15s;-webkit-tap-highlight-color:transparent}.item-input:focus{border-bottom-color:var(--green-500)}.item-input::placeholder{color:var(--gray-400)}.btn-delete{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:none;background:transparent;color:var(--gray-400);cursor:pointer;font-size:1.125rem;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s}.btn-delete:active{background:#fee2e2;color:var(--red-600)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:none;background:transparent;color:var(--gray-500);cursor:pointer;font-size:1.375rem;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:background .15s}.btn-icon:active{background:var(--gray-100)}.btn-info{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--gray-400);cursor:pointer;font-size:1.25rem;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s}.btn-info:active{background:var(--gray-100);color:var(--gray-700)}.item-row__notes{font-size:.75rem;color:var(--gray-500);font-style:italic;padding:0 2px;line-height:1.4}.item-row--checked .item-row__notes{text-decoration:line-through;color:var(--gray-400)}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheet-down{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes backdrop-in{0%{background:#0000}to{background:#0006}}@keyframes backdrop-out{0%{background:#0006}to{background:#0000}}.item-modal{border:none;border-radius:var(--radius-lg);padding:0;width:min(480px,calc(100vw - 32px));box-shadow:0 8px 32px #0000002e;background:#fff;margin:auto}.item-modal::backdrop{background:#0006}@media(max-width:520px){.item-modal{position:fixed;inset:auto 0 0 0;margin:0;width:100%;max-width:100%;border-radius:20px 20px 0 0;max-height:90dvh;overflow-y:auto;animation:sheet-up .3s cubic-bezier(.32,.72,0,1)}.item-modal.item-modal--closing{animation:sheet-down .26s ease-in forwards}.item-modal::backdrop{animation:backdrop-in .3s ease forwards}.item-modal.item-modal--closing::backdrop{animation:backdrop-out .26s ease forwards}}.item-modal__content{display:flex;flex-direction:column}.item-modal__header{display:flex;align-items:center;gap:8px;padding:16px 20px 12px;border-bottom:1px solid var(--gray-100)}.item-modal__title{flex:1;font-size:1.125rem;font-weight:700;color:var(--gray-900);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-modal__close{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:none;background:transparent;color:var(--gray-400);cursor:pointer;font-size:1rem;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:background .15s}.item-modal__close:active{background:var(--gray-100)}.item-modal__body{padding:16px 20px;display:flex;flex-direction:column;gap:14px}.item-modal__row{display:flex;align-items:center;gap:12px}.item-modal__label{font-size:.8125rem;font-weight:600;color:var(--gray-500);width:80px;flex-shrink:0}.item-modal__value{font-size:.9375rem;color:var(--gray-900)}.item-modal__value--muted{color:var(--gray-500);font-style:italic}.item-modal__select{flex:1;font-size:.9375rem;color:var(--gray-900);border-bottom:1.5px solid var(--gray-200);padding:4px 2px}.item-modal__select:focus{border-bottom-color:var(--green-500)}.item-modal__notes-section{display:flex;flex-direction:column;gap:6px}.item-modal__notes{width:100%;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);padding:8px 10px;font-family:inherit;font-size:.9375rem;color:var(--gray-900);resize:vertical;outline:none;transition:border-color .15s;background:var(--gray-50)}.item-modal__notes:focus{border-color:var(--green-500);background:#fff}.item-modal__notes::placeholder{color:var(--gray-400)}.item-modal__row--spread{justify-content:space-between}.item-modal__label--normal{font-weight:400;color:var(--gray-700);font-size:.9375rem;width:auto}.toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;flex-shrink:0}.toggle input{position:absolute;opacity:0;width:0;height:0}.toggle__track{width:44px;height:26px;border-radius:13px;background:var(--gray-300, #d1d5db);transition:background .2s;position:relative}.toggle__track:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.toggle input:checked+.toggle__track{background:var(--green-500)}.toggle input:checked+.toggle__track:after{transform:translate(18px)}.item-modal__footer{padding:12px 20px 16px;border-top:1px solid var(--gray-100);display:flex;justify-content:flex-end}.item-modal__delete{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--red-500);background:transparent;color:var(--red-600);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s}.item-modal__delete:active{background:#fee2e2}.parse-name-wrapper{position:relative;flex:1;min-width:120px;display:flex}.parse-name-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;padding:4px 2px;font-family:inherit;font-size:1rem;line-height:1.5;border-bottom:1.5px solid transparent}.parse-name-backdrop__inner{display:inline-block;white-space:pre}.parse-name-input--focused{color:transparent!important;caret-color:var(--gray-900)}.hi-quantity{color:#3b82f6}.hi-unit{color:var(--green-600)}.hi-name{color:var(--gray-900)}.hi-gap{color:var(--gray-400)}.update-prompt{position:fixed;bottom:96px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;background:var(--gray-900);color:#fff;padding:10px 16px;border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:.9375rem;z-index:100;white-space:nowrap}.update-prompt button{background:var(--green-500);color:#fff;border:none;border-radius:var(--radius-sm);padding:4px 12px;font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.login-page{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:32px 28px;width:100%;max-width:360px}.login-card__header{display:flex;align-items:center;gap:10px;margin-bottom:24px;color:var(--green-700)}.login-card__title{font-size:1.375rem;font-weight:700;color:var(--gray-900)}.login-form{display:flex;flex-direction:column;gap:14px}.login-field{display:flex;flex-direction:column;gap:4px}.login-label{font-size:.8125rem;font-weight:600;color:var(--gray-700)}.login-input{border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);padding:10px 12px;font-family:inherit;font-size:1rem;color:var(--gray-900);outline:none;transition:border-color .15s;background:var(--gray-50)}.login-input:focus{border-color:var(--green-500);background:#fff}.login-error{font-size:.875rem;color:var(--red-600);background:#fee2e2;border-radius:var(--radius-sm);padding:8px 12px}.login-btn{margin-top:4px;padding:12px;background:var(--green-600);color:#fff;border:none;border-radius:var(--radius-sm);font-family:inherit;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent}.login-btn:active{background:var(--green-700)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.logout-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--gray-200);background:transparent;color:var(--gray-500);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s,border-color .15s}.logout-btn:active{background:var(--gray-100);color:var(--gray-700)}.fab{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:8px;background:var(--green-600);color:#fff;border:none;border-radius:28px;padding:0 20px 0 16px;height:56px;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:0 4px 14px #16a34a73;-webkit-tap-highlight-color:transparent;transition:background .15s,box-shadow .15s,transform .1s;z-index:20}.fab:active{background:var(--green-700);box-shadow:0 2px 8px #16a34a59;transform:scale(.97)}.fab__icon{font-size:1.5rem;line-height:1}.tab-bar{position:fixed;bottom:0;left:0;right:0;height:60px;background:#fff;border-top:1px solid var(--gray-200);display:flex;z-index:30;box-shadow:0 -1px 4px #0000000f}.tab-bar__tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:none;background:transparent;color:var(--gray-400);font-family:inherit;font-size:.6875rem;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color .15s;padding:0}.tab-bar__tab--active{color:var(--green-600)}.page--with-tabs .page-content{padding-bottom:76px}.page--with-tabs .fab{bottom:76px}.list-card__icon--recipe{background:#fef3c7;color:#d97706}.list-card__meta{font-size:.8125rem;color:var(--gray-400);margin-left:auto;margin-right:4px}.item-row__recipe-badge{display:inline-flex;align-items:center;gap:3px;font-size:.6875rem;color:var(--green-700);background:var(--green-50);border:1px solid var(--green-100);border-radius:10px;padding:1px 6px 1px 4px;line-height:1.4;align-self:flex-start}.item-row--checked .item-row__recipe-badge{color:var(--gray-400);background:transparent;border-color:var(--gray-200)}.recipe-ingredient-row__note{font-size:.8125rem;color:var(--gray-500);font-style:italic;padding:2px}.recipe-empty-hint{padding:12px 4px;font-size:.875rem;color:var(--gray-400)}.btn-icon--danger{color:var(--gray-400)}.btn-icon--danger:active{background:#fee2e2;color:var(--red-600)}.recipe-picker{display:flex;flex-direction:column;gap:6px}.recipe-picker__item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;border-radius:var(--radius-md);border:1px solid var(--gray-200);background:var(--gray-50);font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,border-color .15s;text-align:left}.recipe-picker__item:active{background:var(--green-50);border-color:var(--green-200, #bbf7d0)}.recipe-picker__name{font-size:.9375rem;font-weight:600;color:var(--gray-900)}.recipe-picker__count{font-size:.8125rem;color:var(--gray-400)}.recipe-picker__empty{font-size:.9rem;color:var(--gray-500);text-align:center;padding:8px 0}.recipe-multiplier{display:flex;align-items:center;justify-content:space-between;padding:4px 2px 12px;border-bottom:1px solid var(--gray-100);margin-bottom:12px}.recipe-multiplier__label{font-size:.9375rem;font-weight:600;color:var(--gray-700)}.recipe-multiplier__controls{display:flex;align-items:center;gap:12px}.recipe-multiplier__btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1.5px solid var(--gray-200);background:#fff;color:var(--gray-700);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,border-color .15s}.recipe-multiplier__btn:active{background:var(--green-50);border-color:var(--green-500)}.recipe-multiplier__value{font-size:1.125rem;font-weight:700;color:var(--gray-900);min-width:32px;text-align:center}.recipe-preview{display:flex;flex-direction:column;gap:4px}.recipe-preview__row{display:flex;align-items:center;justify-content:space-between;padding:6px 2px;border-bottom:1px solid var(--gray-100);font-size:.9375rem;color:var(--gray-900)}.recipe-preview__exists{color:var(--green-600);flex-shrink:0;display:flex;align-items:center}.recipe-add-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);border:none;background:var(--green-600);color:#fff;font-size:.9375rem;font-weight:600;font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s;width:100%;justify-content:center}.recipe-add-btn:active{background:var(--green-700)}
