body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{-webkit-tap-highlight-color:transparent;box-sizing:border-box;margin:0;padding:0}:root{--green:#1d9e75;--green-light:#e1f5ee;--green-dark:#0f6e56;--red:#e24b4a;--red-light:#fcebeb;--orange:#ef9f27;--orange-light:#faeeda;--blue:#378add;--blue-light:#e6f1fb;--gray-100:#f5f5f5;--gray-200:#e8e8e8;--gray-300:#d0d0d0;--gray-500:#888;--gray-700:#444;--gray-900:#111;--text-primary:#111;--text-secondary:#666;--text-tertiary:#999;--border:#e8e8e8;--bg:#f5f5f5;--white:#fff;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--bottom-nav-height:64px;--topbar-height:56px}body{background:#f5f5f5;background:var(--bg);color:#111;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5;overflow-x:hidden}.app-container{background:#fff;background:var(--white);display:flex;flex-direction:column;margin:0 auto;max-width:480px;min-height:100vh;position:relative}.screen-content{flex:1 1;overflow-y:auto;padding-bottom:64px;padding-bottom:var(--bottom-nav-height)}.loading-screen{align-items:center;background:#fff;background:var(--white);display:flex;height:100vh;justify-content:center}.spinner{animation:spin .8s linear infinite;border:3px solid #e8e8e8;border-top-color:#1d9e75;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--green);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.topbar{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);display:flex;height:56px;height:var(--topbar-height);justify-content:space-between;padding:0 16px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.topbar-title{color:#111;color:var(--text-primary);font-size:18px;font-weight:600}.topbar-subtitle{color:#666;color:var(--text-secondary);font-size:12px;margin-top:1px}.topbar-left{gap:10px}.topbar-left,.topbar-right{align-items:center;display:flex}.topbar-right{gap:8px}.icon-btn{align-items:center;background:#f5f5f5;background:var(--gray-100);border:none;border-radius:8px;border-radius:var(--radius-sm);color:#666;color:var(--text-secondary);cursor:pointer;display:flex;font-size:20px;height:40px;justify-content:center;transition:background .15s;width:40px}.icon-btn:active{background:#e8e8e8;background:var(--gray-200)}.back-btn{align-items:center;background:#f5f5f5;background:var(--gray-100);border-radius:8px;border-radius:var(--radius-sm);color:#111;color:var(--text-primary);display:flex;font-size:20px;height:40px;justify-content:center;width:40px}.back-btn,.btn-primary{border:none;cursor:pointer}.btn-primary{background:#1d9e75;background:var(--green);border-radius:12px;border-radius:var(--radius-md);color:#fff;font-size:16px;font-weight:600;padding:16px;transition:background .15s;width:100%}.btn-primary:active{background:#0f6e56;background:var(--green-dark)}.btn-primary:disabled{background:#d0d0d0;background:var(--gray-300);cursor:not-allowed}.btn-secondary{border:1.5px solid #1d9e75;border:1.5px solid var(--green);border-radius:12px;border-radius:var(--radius-md);color:#1d9e75;color:var(--green)}.btn-danger,.btn-secondary{background:#fff;background:var(--white);cursor:pointer;font-size:16px;font-weight:600;padding:16px;width:100%}.btn-danger{border:1.5px solid #e24b4a;border:1.5px solid var(--red);border-radius:12px;border-radius:var(--radius-md);color:#e24b4a;color:var(--red)}.fab{align-items:center;background:#1d9e75;background:var(--green);border:none;border-radius:18px;bottom:80px;bottom:calc(var(--bottom-nav-height) + 16px);box-shadow:0 4px 12px #1d9e7566;color:#fff;cursor:pointer;display:flex;font-size:28px;height:56px;justify-content:center;position:fixed;right:50%;transform:translateX(calc(150% - 16px - min(100vw, 480px)/2));width:56px;z-index:20}.fab:active{transform:translateX(calc(150% - 16px - min(100vw, 480px)/2)) scale(.95)}.form-container{gap:16px;padding:20px 16px}.form-container,.form-field{display:flex;flex-direction:column}.form-field{gap:6px}.form-label{color:#666;color:var(--text-secondary);font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.form-input{background:#fff;background:var(--white);border:1.5px solid #e8e8e8;border:1.5px solid var(--border);border-radius:12px;border-radius:var(--radius-md);color:#111;color:var(--text-primary);font-size:16px;outline:none;padding:14px 16px;transition:border-color .15s;width:100%}.form-input:focus{border-color:#1d9e75;border-color:var(--green)}.form-input::placeholder{color:#999;color:var(--text-tertiary)}select.form-input{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}.form-row{display:flex;gap:12px}.form-row .form-field{flex:1 1}.qty-control{border:1.5px solid #e8e8e8;border:1.5px solid var(--border);border-radius:12px;border-radius:var(--radius-md);overflow:hidden}.qty-btn,.qty-control{align-items:center;display:flex}.qty-btn{background:#f5f5f5;background:var(--gray-100);border:none;color:#1d9e75;color:var(--green);cursor:pointer;flex-shrink:0;font-size:24px;font-weight:500;height:52px;justify-content:center;width:52px}.qty-btn:active{background:#e8e8e8;background:var(--gray-200)}.qty-value{color:#111;color:var(--text-primary);flex:1 1;font-size:20px;font-weight:600;text-align:center}.toggle-row{align-items:center;background:#f5f5f5;background:var(--gray-100);border-radius:12px;border-radius:var(--radius-md);cursor:pointer;display:flex;justify-content:space-between;padding:14px 16px}.toggle-info{display:flex;flex-direction:column;gap:2px}.toggle-label{color:#111;color:var(--text-primary);font-size:15px;font-weight:500}.toggle-sublabel{color:#666;color:var(--text-secondary);font-size:12px}.toggle-switch{background:#d0d0d0;background:var(--gray-300);border-radius:13px;flex-shrink:0;height:26px;position:relative;transition:background .2s;width:44px}.toggle-switch.on{background:#1d9e75;background:var(--green)}.toggle-knob{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;height:20px;left:3px;position:absolute;top:3px;transition:transform .2s;width:20px}.toggle-switch.on .toggle-knob{transform:translateX(18px)}.badge{border-radius:6px;font-size:11px;font-weight:600;padding:3px 8px;white-space:nowrap}.badge-expired{background:#fcebeb;background:var(--red-light);color:#e24b4a;color:var(--red)}.badge-soon{background:#faeeda;background:var(--orange-light);color:#854f0b}.badge-ok{background:#e1f5ee;background:var(--green-light);color:#0f6e56;color:var(--green-dark)}.badge-staple{background:#e6f1fb;background:var(--blue-light);color:#185fa5}.badge-empty{background:#fcebeb;background:var(--red-light);color:#e24b4a;color:var(--red)}.list-section-header{background:#f5f5f5;background:var(--bg);color:#999;color:var(--text-tertiary);font-size:11px;font-weight:700;letter-spacing:.05em;padding:12px 16px 4px;text-transform:uppercase}.item-row{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);cursor:pointer;display:flex;gap:12px;padding:14px 16px;transition:background .1s}.item-row:active{background:#f5f5f5;background:var(--gray-100)}.item-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.item-name{color:#111;color:var(--text-primary);flex:1 1;font-size:15px;font-weight:400}.item-qty-badge{background:#f5f5f5;background:var(--gray-100);border:1px solid #e8e8e8;border:1px solid var(--border);border-radius:8px;color:#666;color:var(--text-secondary);font-size:13px;padding:2px 10px}.pantry-card{background:#fff;background:var(--white);border:1.5px solid #e8e8e8;border:1.5px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);cursor:pointer;padding:16px;transition:border-color .15s}.pantry-card.active{border-color:#1d9e75;border-color:var(--green)}.pantry-card-name{color:#111;color:var(--text-primary);font-size:17px;font-weight:600}.pantry-card-sub{color:#666;color:var(--text-secondary);font-size:13px;margin-top:3px}.empty-state{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;padding:60px 32px;text-align:center}.empty-state-icon{font-size:48px}.empty-state-title{color:#111;color:var(--text-primary);font-size:17px;font-weight:600}.empty-state-text{color:#666;color:var(--text-secondary);font-size:14px;line-height:1.6}.filter-bar{background:#fff;background:var(--white);border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);display:flex;gap:8px;overflow-x:auto;padding:10px 16px}.filter-bar::-webkit-scrollbar{display:none}.chip{background:#fff;background:var(--white);border:1.5px solid #e8e8e8;border:1.5px solid var(--border);border-radius:99px;color:#666;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500;padding:6px 14px;transition:all .15s;white-space:nowrap}.chip.active{background:#1d9e75;background:var(--green);border-color:#1d9e75;border-color:var(--green);color:#fff}.form-section-title{color:#999;color:var(--text-tertiary);font-size:13px;font-weight:700;letter-spacing:.04em;padding:4px 0;text-transform:uppercase}.invite-box{border:1.5px dashed #1d9e75;border:1.5px dashed var(--green);border-radius:12px;border-radius:var(--radius-md);color:#1d9e75;color:var(--green);cursor:pointer;font-size:15px;font-weight:500;padding:14px 16px}.invite-box,.member-row{align-items:center;display:flex;gap:12px}.member-row{border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);padding:12px 16px}.avatar{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:40px;justify-content:center;width:40px}.member-name{color:#111;color:var(--text-primary);font-size:15px;font-weight:500}.member-email{color:#666;color:var(--text-secondary);font-size:12px}.role-badge{border-radius:6px;font-size:11px;font-weight:600;margin-left:auto;padding:3px 10px}.role-admin{background:#e1f5ee;background:var(--green-light);color:#0f6e56;color:var(--green-dark)}.role-member{background:#f5f5f5;background:var(--gray-100);border:1px solid #e8e8e8;border:1px solid var(--border);color:#666;color:var(--text-secondary)}.alert{border-radius:12px;border-radius:var(--radius-md);font-size:14px;margin:0 16px;padding:12px 16px}.alert-error{background:#fcebeb;background:var(--red-light);color:#e24b4a;color:var(--red)}.alert-success{background:#e1f5ee;background:var(--green-light);color:#0f6e56;color:var(--green-dark)}.page-content{display:flex;flex-direction:column;gap:16px;padding:16px}
/*# sourceMappingURL=main.22e50057.css.map*/