@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#fcfcfc;--bg-secondary:#fff8f5;--bg-card:#fff;--text-primary:#2d2622;--text-secondary:#7a726e;--text-tertiary:#afa8a4;--accent-color:#ff8a5b;--accent-hover:#e77242;--accent-light:#fff0e9;--accent-pastel:#ffcca3;--border-color:#f0eae6;--border-focus:#ffb396;--danger-color:#ff6b6b;--danger-light:#ffebeb;--warning-color:#ffd166;--warning-light:#fff9eb;--success-color:#4caf50;--success-light:#edf7ed;--card-shadow:0 10px 30px #e772420a, 0 2px 8px #00000005;--header-shadow:0 4px 20px #00000005;--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--border-radius-lg:20px;--border-radius-md:12px;--border-radius-sm:8px;--transition-speed:.3s}body.dark{--bg-primary:#121214;--bg-secondary:#1c1c1e;--bg-card:#222226;--text-primary:#ebe6e4;--text-secondary:#a69e9a;--text-tertiary:#6e6865;--accent-color:#ffa577;--accent-hover:#ff8a5b;--accent-light:#332018;--accent-pastel:#b87652;--border-color:#2d2c30;--border-focus:#ff8a5b;--danger-color:#ff8b8b;--danger-light:#3b2020;--warning-color:#ffe082;--warning-light:#3b3420;--success-color:#81c784;--success-light:#1e3520;--card-shadow:0 10px 30px #0000004d, 0 2px 8px #0003;--header-shadow:0 4px 20px #0000004d}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-speed), color var(--transition-speed);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}.app-container{background-color:var(--bg-primary);max-width:480px;min-height:100vh;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));flex-direction:column;margin:0 auto;display:flex;position:relative;box-shadow:0 0 40px #00000008}.app-header{-webkit-backdrop-filter:blur(10px);z-index:100;padding:16px 20px;padding-top:calc(16px + env(safe-area-inset-top,0px));border-bottom:1px solid var(--border-color);box-shadow:var(--header-shadow);transition:background-color var(--transition-speed), border-color var(--transition-speed);background-color:#fcfcfcd9;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}body.dark .app-header{background-color:#121214d9}.app-title-group h1{color:var(--accent-color);letter-spacing:-.5px;font-size:20px;font-weight:700}.app-title-group p{color:var(--text-secondary);font-size:11px}.header-actions{align-items:center;gap:12px;display:flex}.theme-toggle-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:background-color .2s,color .2s;display:flex}.theme-toggle-btn:hover{background-color:var(--accent-light);color:var(--accent-color)}.view-content{flex:1;padding:20px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.bottom-nav{max-width:480px;height:calc(68px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-color);z-index:100;transition:background-color var(--transition-speed), border-color var(--transition-speed);background-color:#ffffffe6;justify-content:space-around;align-items:center;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #00000005}body.dark .bottom-nav{background-color:#222226e6}.nav-item{color:var(--text-tertiary);cursor:pointer;width:60px;height:100%;font-family:var(--font-sans);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;font-size:11px;font-weight:500;transition:color .2s;display:flex}.nav-item svg{stroke-width:2.2px;width:22px;height:22px;transition:transform .2s}.nav-item.active{color:var(--accent-color)}.nav-item.active svg{stroke-width:2.5px;transform:translateY(-2px)}.card{background-color:var(--bg-card);border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--card-shadow);transition:transform .2s, box-shadow .2s, background-color var(--transition-speed), border-color var(--transition-speed);margin-bottom:16px;padding:16px}.card:hover{transform:translateY(-2px)}.form-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.form-label{color:var(--text-secondary);font-size:13px;font-weight:600}.form-input,.form-select{font-family:var(--font-sans);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-primary);outline:none;padding:12px 14px;font-size:14px;transition:border-color .2s,background-color .2s}.form-input:focus,.form-select:focus{border-color:var(--border-focus);background-color:var(--bg-card)}.btn{font-family:var(--font-sans);border-radius:var(--border-radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.btn-primary{background-color:var(--accent-color);color:#fff}.btn-primary:hover{background-color:var(--accent-hover);transform:scale(.98)}.btn-secondary{background-color:var(--accent-light);color:var(--accent-color)}.btn-secondary:hover{background-color:var(--accent-pastel);color:#fff}.btn-danger{background-color:var(--danger-light);color:var(--danger-color)}.btn-danger:hover{background-color:var(--danger-color);color:#fff}.btn-icon{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:background-color .2s,color .2s;display:flex}.btn-icon:hover{background-color:var(--border-color);color:var(--text-primary)}.auth-view{flex-direction:column;justify-content:center;min-height:80vh;padding:30px 20px;display:flex}.auth-logo{text-align:center;margin-bottom:12px;font-size:42px}.auth-title{text-align:center;letter-spacing:-.5px;margin-bottom:6px;font-size:26px;font-weight:700}.auth-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:30px;font-size:13px}.auth-switch{text-align:center;color:var(--text-secondary);margin-top:20px;font-size:13px}.auth-switch-btn{color:var(--accent-color);cursor:pointer;font-weight:600;font-family:var(--font-sans);background:0 0;border:none;margin-left:4px}.auth-switch-btn:hover{text-decoration:underline}.auth-error{background-color:var(--danger-light);color:var(--danger-color);border-radius:var(--border-radius-sm);border:1px solid #ff6b6b33;margin-bottom:16px;padding:10px 14px;font-size:13px;font-weight:500}.search-filter-bar{gap:10px;margin-bottom:20px;display:flex}.search-input-wrapper{flex:1;position:relative}.search-input-wrapper input{width:100%;padding-left:36px}.search-icon{color:var(--text-tertiary);width:16px;height:16px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.categories-tabs{scrollbar-width:none;gap:8px;margin-bottom:16px;padding-bottom:8px;display:flex;overflow-x:auto}.categories-tabs::-webkit-scrollbar{display:none}.category-tab-btn{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;white-space:nowrap;border-radius:20px;padding:8px 16px;font-size:12px;font-weight:600;transition:all .2s}.category-tab-btn.active{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color)}.pantry-grid{flex-direction:column;gap:12px;display:flex}.product-row{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-md);box-shadow:var(--card-shadow);justify-content:space-between;align-items:center;padding:14px 16px;transition:all .2s;display:flex}.product-info{flex-direction:column;flex:1;gap:4px;display:flex}.product-name-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.product-name{font-size:15px;font-weight:600}.product-badge{text-transform:uppercase;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:600}.badge-low-stock{background-color:var(--warning-light);color:var(--warning-color);border:1px solid #ffd1664d}.badge-expired{background-color:var(--danger-light);color:var(--danger-color);border:1px solid #ff6b6b4d}.product-meta{color:var(--text-secondary);gap:12px;font-size:12px;display:flex}.product-expiry{align-items:center;gap:4px;display:flex}.product-qty-control{align-items:center;gap:10px;display:flex}.qty-btn{background-color:var(--bg-secondary);border:1px solid var(--border-color);width:28px;height:28px;color:var(--text-primary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:600;transition:all .15s;display:flex}.qty-btn:hover{background-color:var(--accent-light);color:var(--accent-color);border-color:var(--accent-color)}.qty-val{text-align:center;min-width:38px;font-size:15px;font-weight:700}.qty-unit{color:var(--text-secondary);font-size:11px;font-weight:400;display:block}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background-color:#00000059;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=480px){.modal-overlay{align-items:center}}.modal-content{background-color:var(--bg-card);border-top-left-radius:var(--border-radius-lg);border-top-right-radius:var(--border-radius-lg);width:100%;max-width:480px;max-height:90vh;padding:24px;animation:.3s slideUp;overflow-y:auto;box-shadow:0 -10px 40px #00000026}@media (width>=480px){.modal-content{border-radius:var(--border-radius-lg);margin:16px;animation:.25s scaleIn}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{color:var(--text-primary);font-size:18px;font-weight:700}.modal-footer{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.fab{background-color:var(--accent-color);color:#fff;cursor:pointer;z-index:99;border:none;border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;transition:all .2s;display:flex;position:fixed;bottom:84px;right:calc(50% - 220px);box-shadow:0 6px 20px #e772424d}@media (width<=480px){.fab{right:20px}}.fab:hover{background-color:var(--accent-hover);transform:translateY(-2px)rotate(90deg)}.fab svg{stroke-width:2.5px;width:24px;height:24px}.shopping-list{flex-direction:column;gap:10px;display:flex}.shopping-row{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-md);box-shadow:var(--card-shadow);align-items:center;gap:14px;padding:12px 16px;transition:all .2s;display:flex}.shopping-row.bought{opacity:.55;border-style:dashed}.shopping-checkbox-wrapper{justify-content:center;align-items:center;display:flex}.shopping-checkbox{appearance:none;border:2px solid var(--accent-color);cursor:pointer;border-radius:6px;outline:none;justify-content:center;align-items:center;width:22px;height:22px;transition:all .15s;display:flex;position:relative}.shopping-checkbox:checked{background-color:var(--accent-color)}.shopping-checkbox:checked:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:5px;height:9px;position:absolute;top:3px;transform:rotate(45deg)}.shopping-info{flex-direction:column;flex:1;display:flex}.shopping-name{font-size:14px;font-weight:600}.shopping-row.bought .shopping-name{text-decoration:line-through}.shopping-qty{color:var(--text-secondary);font-size:12px}.shopping-badge{text-transform:uppercase;border-radius:8px;padding:1px 6px;font-size:9px;font-weight:600}.badge-auto{background-color:var(--accent-light);color:var(--accent-color)}.badge-manual{background-color:var(--border-color);color:var(--text-secondary)}.settings-section{margin-bottom:24px}.settings-section h2{text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.5px;margin-bottom:12px;font-size:14px;font-weight:700}.profile-card{background-color:var(--bg-secondary);border-radius:var(--border-radius-lg);border:1px solid var(--border-color);align-items:center;gap:16px;margin-bottom:20px;padding:16px;display:flex}.profile-avatar{background-color:var(--accent-color);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:22px;font-weight:700;display:flex}.profile-info h3{font-size:16px;font-weight:600}.profile-info p{color:var(--text-secondary);font-size:12px}.pairing-box{background-color:var(--bg-card);border:2px dashed var(--accent-pastel);border-radius:var(--border-radius-lg);text-align:center;flex-direction:column;align-items:center;gap:14px;padding:20px;display:flex}.pairing-code-display{color:var(--accent-color);letter-spacing:4px;background-color:var(--accent-light);border-radius:var(--border-radius-md);border:1px solid var(--accent-pastel);margin:8px 0;padding:8px 24px;font-size:32px;font-weight:700}.pairing-expire-text{color:var(--text-secondary);font-size:11px}.divider{background-color:var(--border-color);width:100%;height:1px;margin:16px 0}.settings-row{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.settings-row:last-child{border-bottom:none}.settings-label{font-size:14px;font-weight:500}.switch{width:46px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:var(--border-color);border-radius:24px;transition:all .3s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:var(--accent-color)}input:checked+.slider:before{transform:translate(22px)}.empty-state{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;gap:12px;padding:40px 20px;display:flex}.empty-state-icon{color:var(--text-tertiary);margin-bottom:8px;font-size:48px}.empty-state h3{color:var(--text-primary);font-size:16px;font-weight:600}.empty-state p{max-width:250px;margin:0 auto;font-size:13px}.autocomplete-wrapper{width:100%;position:relative}.autocomplete-dropdown{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-md);z-index:1010;max-height:200px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #00000026}.autocomplete-item{cursor:pointer;color:var(--text-primary);justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;transition:background-color .15s;display:flex}.autocomplete-item:hover{background-color:var(--bg-secondary)}.autocomplete-item-name{font-weight:500}.autocomplete-item-meta{color:var(--text-secondary);background-color:var(--border-color);border-radius:8px;padding:1px 6px;font-size:11px}.combobox-wrapper{width:100%;position:relative}.combobox-toggle{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-md);cursor:pointer;text-align:left;width:100%;color:var(--text-primary);font-size:14px;font-family:var(--font-sans);justify-content:space-between;align-items:center;padding:10px 14px;transition:border-color .2s;display:flex}.combobox-toggle:focus{border-color:var(--accent-color);outline:none}.combobox-toggle-arrow{color:var(--text-secondary);font-size:10px}.combobox-dropdown{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-md);z-index:1020;flex-direction:column;gap:6px;margin-top:4px;padding:8px;display:flex;position:absolute;top:100%;left:0;right:0;box-shadow:0 4px 12px #00000026}.combobox-search{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background-color:var(--bg-secondary);width:100%;color:var(--text-primary);outline:none;padding:8px 10px;font-size:13px}.combobox-search:focus{border-color:var(--accent-color)}.combobox-list{flex-direction:column;max-height:150px;display:flex;overflow-y:auto}.combobox-item{cursor:pointer;border-radius:var(--border-radius-sm);color:var(--text-primary);padding:8px 10px;font-size:13px;transition:background-color .15s}.combobox-item:hover{background-color:var(--bg-secondary)}.combobox-item.selected{background-color:var(--accent-light);color:var(--accent-color);font-weight:600}.combobox-create-item{cursor:pointer;color:var(--accent-color);background-color:var(--accent-light);border-radius:var(--border-radius-sm);text-align:center;margin-top:4px;padding:8px 10px;font-size:13px;font-weight:600;transition:opacity .15s}.combobox-create-item:hover{opacity:.85}@media (display-mode:standalone){body{overscroll-behavior:none;-webkit-user-select:none;-webkit-user-select:text;user-select:text}.app-header{padding-top:calc(16px + env(safe-area-inset-top,0px))}}@supports (-webkit-touch-callout:none){body{-webkit-touch-callout:none;-webkit-overflow-scrolling:touch}*{-webkit-tap-highlight-color:transparent}.form-input,.form-select,.combobox-search{font-size:16px}.modal-content{padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}}
