*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;background:#f5f5f7;color:#1d1d1f;min-height:100vh;-webkit-font-smoothing:antialiased}.app-shell{display:flex;flex-direction:column;min-height:100vh;background:#e5e7eb}.app-shell-inner{width:100%;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;flex:1;background:#fff;min-height:100vh;box-shadow:0 0 0 1px #d1d5db}.app-body{display:flex;flex:1}.app-nav{width:200px;flex-shrink:0;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;padding:1rem .75rem;gap:.25rem}.app-nav-link{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;border-radius:7px;font-size:.9rem;color:#374151;text-decoration:none;background:none;border:none;cursor:pointer;width:100%;text-align:left;font-family:inherit;transition:background .12s,color .12s}.app-nav-link:hover{background:#f3f4f6;color:#111827}.app-nav-link--active{background:#eef2ff;color:#4f46e5;font-weight:500}.app-nav-link--active svg{stroke:#4f46e5}.app-nav-link--action{color:#6b7280}.app-nav-link--action:hover{background:#fef2f2;color:#dc2626}.app-nav-spacer{flex:1}.app-main{flex:1;overflow:auto}.app-header-right{display:flex;align-items:center;gap:.65rem}.app-hamburger{display:none;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:.3rem;color:#374151;border-radius:6px;flex-shrink:0}.app-hamburger:hover{background:#f3f4f6}.app-nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:199}@media (max-width: 640px){.app-hamburger{display:flex}.app-header-username{display:none}.app-nav{position:fixed;top:0;right:0;bottom:0;width:220px;z-index:200;border-right:none;border-left:1px solid #e5e7eb;padding-top:4.5rem;transform:translate(100%);transition:transform .25s ease;box-shadow:-4px 0 20px #0000001f}.app-nav--open{transform:translate(0)}}.journal-page{padding:2rem}.journal-header{text-align:center;margin-bottom:2rem}.journal-header .home-title{margin-bottom:.4rem}.journal-date-nav{display:flex;align-items:center;gap:.75rem;justify-content:center}.journal-date-label{font-size:.95rem;color:#6b7280}.journal-date-arrow{background:none;border:none;cursor:pointer;font-size:1rem;color:#6b7280;padding:.25rem .4rem;border-radius:5px;line-height:1;transition:background .12s,color .12s}.journal-date-arrow:hover{background:#f3f4f6;color:#111827}.journal-meals{display:flex;flex-direction:column;gap:.75rem}.journal-meal-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:1rem 1.25rem}.journal-meal-header{display:flex;align-items:center;justify-content:space-between}.journal-meal-name{font-size:.95rem;font-weight:600;color:#111827}.journal-meal-calories{font-size:.88rem;color:#6b7280}.journal-meal-add-btn{background:none;border:1.5px solid #d1d5db;border-radius:50%;width:1.75rem;height:1.75rem;display:flex;align-items:center;justify-content:center;font-size:1.1rem;line-height:1;color:#6b7280;cursor:pointer;padding:0;transition:background .12s,border-color .12s,color .12s;flex-shrink:0}.journal-meal-add-btn:hover{background:#f3f4f6;border-color:#9ca3af;color:#111827}.journal-food-added-banner{text-align:center;font-size:.85rem;font-weight:500;color:#16a34a;margin:.5rem 0 0}.journal-meal-entries{margin-top:.75rem;display:flex;flex-direction:column;gap:0;border-top:1px solid #f3f4f6}.journal-entry{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f3f4f6;border-radius:4px;padding:.45rem .25rem}.journal-entry:last-child{border-bottom:none}.journal-entry-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}.journal-entry-name{font-size:.88rem;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.journal-entry-serving{font-size:.78rem;color:#9ca3af}.journal-entry-cals{font-size:.85rem;color:#6b7280;white-space:nowrap;margin-left:.75rem;flex-shrink:0}@keyframes entry-highlight-fade{0%{background-color:#d1fae5}75%{background-color:#d1fae5}to{background-color:transparent}}.journal-entry--highlighted{animation:entry-highlight-fade 10s ease forwards}.journal-add-page{padding:1rem 2rem 2rem}.journal-add-back{background:none;border:none;cursor:pointer;color:#6b7280;font-size:.9rem;padding:0;margin-bottom:.75rem;display:inline-flex;align-items:center;gap:.25rem}.journal-add-back:hover{color:#111827}.journal-add-header{margin-bottom:1.5rem}.journal-add-meal{font-size:1.5rem;font-weight:700;color:#111827;margin-bottom:.25rem}.journal-add-date{font-size:.95rem;color:#6b7280}.journal-add-search-again-row{margin-bottom:1.25rem}.journal-add-search-again-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.1rem;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:.9375rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .12s,border-color .12s}.journal-add-search-again-btn:hover{background:#e5e7eb;border-color:#9ca3af}.journal-add-candidate{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;margin-bottom:1.5rem}.journal-add-candidate-header{padding:1rem 1.5rem .875rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.journal-add-candidate-name{font-size:1.375rem;font-weight:700;color:#111827;margin:0 0 .2rem;line-height:1.25}.journal-add-candidate-brand{font-size:1rem;color:#6b7280;margin:0}.journal-add-servings-row{display:flex;align-items:center;gap:.6rem;margin-top:.875rem}.journal-add-servings-label{font-size:.9375rem;font-weight:500;color:#374151;white-space:nowrap}.journal-add-servings-input{width:5rem;padding:.4rem .6rem;border:1px solid #d1d5db;border-radius:7px;font-size:.9375rem;font-family:inherit;text-align:center;outline:none}.journal-add-servings-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.journal-add-servings-add-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .9rem;background:#4f46e5;color:#fff;border:none;border-radius:7px;font-size:.9375rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .12s}.journal-add-servings-add-btn:hover:not(:disabled){background:#4338ca}.journal-add-servings-add-btn:disabled{opacity:.65;cursor:default}.journal-add-servings-add-btn--success{background:#16a34a}.journal-add-servings-add-btn--success:hover:not(:disabled){background:#16a34a}.journal-add-servings-error{font-size:.8125rem;color:#dc2626;margin:.35rem 0 0}.journal-add-results{border-top:1px solid #e5e7eb;padding-top:1.25rem;margin-top:.5rem}.journal-add-search-row{display:grid;grid-template-columns:2fr 1fr;gap:1rem;align-items:start;margin-bottom:1.5rem}@media (max-width: 540px){.journal-add-search-row{grid-template-columns:1fr}}.journal-add-search-form,.journal-add-inputs{display:flex;flex-direction:column;gap:.5rem}.journal-add-search-actions{display:flex;justify-content:center;padding-top:.25rem}.journal-add-search-btn{padding:.6rem 2.5rem;background:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background .12s}.journal-add-search-btn:hover:not(:disabled){background:#4338ca}.journal-add-search-btn:disabled{opacity:.4;cursor:default}.journal-add-barcode-col{display:flex;flex-direction:column;gap:.5rem}.journal-add-barcode-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:#007aff;color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:opacity .15s}.journal-add-barcode-btn:hover:not(:disabled){opacity:.85}.journal-add-barcode-btn:disabled{opacity:.45;cursor:default}.journal-add-barcode-btn--upload{background:#3a3a3c}.journal-add-barcode-error{font-size:.85rem;color:#dc2626;margin:0}.journal-add-use-barcode-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;width:100%;height:100%;min-height:7rem;padding:1.25rem 1rem;background:#007aff;color:#fff;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:opacity .15s}.journal-add-use-barcode-btn:hover{opacity:.85}.barcode-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.barcode-modal{position:relative;background:#fff;border-radius:16px;padding:2rem 1.5rem 1.5rem;width:100%;max-width:22rem;display:flex;flex-direction:column;gap:.75rem}.barcode-modal-title{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 .25rem;text-align:center}.barcode-modal-close{position:absolute;top:.75rem;right:.875rem;background:none;border:none;font-size:1.5rem;line-height:1;color:#6b7280;cursor:pointer;padding:.25rem}.barcode-modal-close:hover{color:#111827}.barcode-modal-manual-btn{width:100%;padding:.75rem 1rem;background:#f3f4f6;color:#374151;border:none;border-radius:10px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background .12s}.barcode-modal-manual-btn:hover{background:#e5e7eb}.barcode-modal-manual-form{display:flex;flex-direction:column;gap:.75rem}.barcode-modal-input{width:100%;padding:.65rem .875rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;font-family:inherit;outline:none;box-sizing:border-box}.barcode-modal-input:focus{border-color:#007aff;box-shadow:0 0 0 3px #007aff26}.home-page{padding:3rem 2.5rem}.home-title{font-size:2rem;font-weight:700;color:#111827;margin-bottom:.5rem}.home-subtitle{font-size:1.1rem;color:#6b7280;margin-bottom:1.5rem}.home-cta{font-size:.95rem;color:#374151}.home-cta a{color:#4f46e5;text-decoration:none;font-weight:500}.home-cta a:hover{text-decoration:underline}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:56px;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0}.app-header-wordmark{font-size:1.2rem;font-weight:700;color:#111827;text-decoration:none;letter-spacing:-.02em}.app-header-wordmark:hover{color:#4f46e5}.app-header-user{display:flex;align-items:center;gap:.65rem}.app-header-username{font-size:.88rem;color:#374151}.app-header-avatar{width:32px;height:32px;border-radius:50%;background:#e0e7ff;color:#4f46e5;font-size:.82rem;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1.5rem}.card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014;padding:2.5rem 2rem;width:100%;max-width:400px;text-align:center}.logo{font-size:2.5rem;margin-bottom:.75rem}h1{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;margin-bottom:.4rem}.subtitle{color:#6e6e73;font-size:.95rem;margin-bottom:1.75rem}.auth-state{display:flex;flex-direction:column;align-items:center;gap:.75rem}.status-badge{display:inline-flex;align-items:center;gap:.4rem;background:#e8f5e9;color:#2e7d32;font-size:.8rem;font-weight:600;padding:.3rem .75rem;border-radius:999px;letter-spacing:.3px}.dot{width:7px;height:7px;background:#43a047;border-radius:50%}.welcome{font-size:1.05rem;color:#1d1d1f}.email{font-size:.85rem;color:#6e6e73}.prompt{font-size:.9rem;color:#6e6e73}.form{display:flex;flex-direction:column;gap:1rem;text-align:left;margin-bottom:1.5rem}.field{display:flex;flex-direction:column;gap:.35rem}label{font-size:.85rem;font-weight:600;color:#3a3a3c}input{border:1.5px solid #d1d1d6;border-radius:10px;padding:.65rem .9rem;font-size:.95rem;outline:none;transition:border-color .15s;background:#fafafa;width:100%}input:focus{border-color:#007aff;background:#fff}input:disabled{opacity:.6;cursor:not-allowed}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap input{padding-right:2.75rem}.input-reveal{position:absolute;right:.65rem;background:none;border:none;cursor:pointer;color:#6e6e73;padding:.25rem;display:flex;align-items:center;transition:color .15s}.input-reveal:hover{color:#1d1d1f}.alert{background:#fff0f0;border:1px solid #ffcdd2;color:#c62828;border-radius:8px;padding:.6rem .85rem;font-size:.875rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.7rem 1.5rem;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;border:none;text-decoration:none;transition:opacity .15s,background .15s;width:100%}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:#007aff;color:#fff}.btn-primary:hover:not(:disabled){background:#0066d6}.btn-secondary{background:#f2f2f7;color:#1d1d1f}.btn-secondary:hover:not(:disabled){background:#e5e5ea}.back-link{display:inline-block;font-size:.875rem;color:#007aff;text-decoration:none;margin-top:.25rem}.back-link:hover{text-decoration:underline}.admin-shell{display:flex;min-height:100vh}.admin-sidebar{width:220px;flex-shrink:0;background:#1c1c1e;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.admin-sidebar-header{display:flex;align-items:center;gap:.6rem;padding:1.5rem 1.25rem 1.25rem;border-bottom:1px solid #2c2c2e}.admin-sidebar-icon{font-size:1.25rem}.admin-sidebar-title{font-size:1rem;font-weight:700;color:#fff;letter-spacing:-.3px}.admin-nav{display:flex;flex-direction:column;gap:2px;padding:1rem .75rem;flex:1}.admin-nav-link{display:block;padding:.55rem .75rem;border-radius:8px;font-size:.9rem;font-weight:500;color:#aeaeb2;text-decoration:none;transition:background .12s,color .12s}.admin-nav-link:hover{background:#2c2c2e;color:#fff}.admin-nav-link.active{background:#007aff;color:#fff}.admin-sidebar-footer{padding:1rem 1.25rem 1.5rem;border-top:1px solid #2c2c2e;display:flex;flex-direction:column;gap:.6rem}.admin-footer-user{margin-bottom:.25rem}.admin-footer-name{font-size:.85rem;font-weight:600;color:#e5e5e7}.admin-footer-email{font-size:.75rem;color:#6e6e73;margin-top:1px;word-break:break-all}.admin-footer-back,.admin-footer-logout{display:block;font-size:.8rem;color:#6e6e73;text-decoration:none;background:none;border:none;padding:0;cursor:pointer;text-align:left;transition:color .12s}.admin-footer-back:hover,.admin-footer-logout:hover{color:#aeaeb2}.admin-main{flex:1;min-width:0;background:#f5f5f7}.admin-content{padding:2rem 2.5rem;max-width:960px}.admin-page-header{margin-bottom:2rem}.admin-page-header h2{font-size:1.6rem;font-weight:700;letter-spacing:-.4px;color:#1d1d1f}.admin-page-subtitle{color:#6e6e73;font-size:.9rem;margin-top:.25rem}.admin-section{margin-bottom:2.5rem}.admin-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#6e6e73;margin-bottom:.875rem}.admin-alert{background:#fff0f0;border:1px solid #ffcdd2;color:#c62828;border-radius:10px;padding:.75rem 1rem;font-size:.875rem}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.stat-card{background:#fff;border-radius:12px;padding:1.25rem 1rem 1rem;box-shadow:0 1px 4px #0000000f;border-left:3px solid transparent;position:relative}.stat-card--blue{border-left-color:#007aff}.stat-card--green{border-left-color:#34c759}.stat-card--purple{border-left-color:#af52de}.stat-card--orange{border-left-color:#ff9500}.stat-card--red{border-left-color:#ff3b30}.stat-card--default{border-left-color:#d1d1d6}.stat-value{font-size:2rem;font-weight:700;letter-spacing:-1px;color:#1d1d1f;line-height:1;margin-bottom:.4rem;min-height:2rem}.stat-label{font-size:.8rem;font-weight:600;color:#3a3a3c}.stat-tag{font-size:.7rem;font-weight:600;color:#aeaeb2;margin-top:.2rem;text-transform:uppercase;letter-spacing:.4px}.stat-skeleton{display:inline-block;width:3rem;height:1.75rem;background:#e5e5ea;border-radius:6px;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.admin-placeholder{background:#fff;border-radius:12px;padding:3rem;text-align:center;color:#6e6e73;font-size:.95rem;box-shadow:0 1px 4px #0000000f}.admin-placeholder-icon{font-size:2.5rem;margin-bottom:.75rem}.rndb-content{max-width:1100px}.rndb-restaurants{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.rndb-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:999px;border:1.5px solid #d1d1d6;background:#fff;font-size:.85rem;font-weight:500;color:#3a3a3c;cursor:pointer;transition:border-color .12s,background .12s,color .12s;white-space:nowrap}.rndb-pill:hover{border-color:#007aff;color:#007aff}.rndb-pill.active{background:#007aff;border-color:#007aff;color:#fff}.rndb-pill-count{font-size:.75rem;font-weight:600;opacity:.7}.rndb-toolbar{display:flex;gap:.75rem;margin-bottom:.875rem}.rndb-search{flex:1;border:1.5px solid #d1d1d6;border-radius:10px;padding:.6rem .9rem;font-size:.95rem;outline:none;background:#fff;transition:border-color .15s}.rndb-search:focus{border-color:#007aff}.rndb-select{border:1.5px solid #d1d1d6;border-radius:10px;padding:.6rem .9rem;font-size:.9rem;outline:none;background:#fff;color:#1d1d1f;cursor:pointer;transition:border-color .15s;min-width:160px}.rndb-select:focus{border-color:#007aff}.rndb-meta{font-size:.8rem;color:#6e6e73;margin-bottom:.6rem}.rndb-meta-loading{opacity:.5}.admin-table-wrap{background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000000f;overflow-x:auto;transition:opacity .15s}.admin-table-wrap.loading{opacity:.5}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table thead tr{border-bottom:1.5px solid #f2f2f7}.admin-table th{padding:.75rem 1rem;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#6e6e73;white-space:nowrap}.admin-table td{padding:.7rem 1rem;border-bottom:1px solid #f2f2f7;vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:#fafafa}.item-name{font-weight:500;color:#1d1d1f}.item-brand{font-size:.78rem;color:#6e6e73;margin-top:1px}.item-category{color:#3a3a3c}.item-restaurant{color:#6e6e73;white-space:nowrap}.table-empty{text-align:center;color:#6e6e73;padding:2.5rem!important}.rndb-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.25rem}.page-btn{padding:.45rem 1rem;border-radius:8px;border:1.5px solid #d1d1d6;background:#fff;font-size:.85rem;font-weight:600;color:#1d1d1f;cursor:pointer;transition:border-color .12s,color .12s}.page-btn:hover:not(:disabled){border-color:#007aff;color:#007aff}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{font-size:.85rem;color:#6e6e73;min-width:5rem;text-align:center}.db-table{max-width:640px}.db-table-name{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.825rem;color:#1d1d1f;white-space:nowrap}.db-bar-cell{padding-top:0!important;padding-bottom:0!important;vertical-align:middle}.db-bar{height:8px;background:#007aff;border-radius:4px;opacity:.7;min-width:2px;transition:width .3s ease}.db-count{text-align:right;font-variant-numeric:tabular-nums;font-size:.875rem;color:#3a3a3c;white-space:nowrap}.admin-table tfoot tr td{border-top:1.5px solid #e5e5ea;border-bottom:none;padding-top:.75rem;padding-bottom:.75rem}.db-total-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#6e6e73}.db-total-count{text-align:right;font-weight:700;font-variant-numeric:tabular-nums;color:#1d1d1f}.off-search-form{display:flex;gap:.625rem;margin-bottom:1.5rem}.off-search-form .rndb-search{flex:1}.off-search-submit{padding:.6rem 1.25rem;background:#007aff;color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s}.off-search-submit:hover:not(:disabled){background:#0062cc}.off-search-submit:disabled{opacity:.45;cursor:default}.off-search-toggle{display:inline-flex;background:#f5f5f7;border-radius:10px;padding:3px;margin-bottom:1.25rem}.off-toggle-btn{padding:.35rem .9rem;border:none;border-radius:8px;font-size:.875rem;cursor:pointer;background:transparent;color:#666;transition:all .15s;font-weight:400;white-space:nowrap}.off-toggle-btn.active{background:#fff;color:#1d1d1f;font-weight:500;box-shadow:0 1px 3px #0000001f}.off-toggle-btn:not(.active):hover{color:#1d1d1f}.off-table td{vertical-align:middle}.off-product-cell{display:flex;align-items:center;gap:.625rem}.off-thumb{width:40px;height:40px;object-fit:contain;border-radius:4px;flex-shrink:0;background:#f5f5f7}.off-product-name{font-size:.875rem;font-weight:500;color:#1d1d1f}.off-barcode{font-size:.75rem;color:#6e6e73;font-variant-numeric:tabular-nums}.off-brand{font-size:.8125rem;color:#6e6e73}.off-nutriscore{display:inline-block;padding:.125rem .5rem;border-radius:4px;color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.5px}.off-cache-btn{padding:.25rem .625rem;font-size:.75rem;border-radius:6px;border:1px solid #d1d1d6;background:#fff;color:#1d1d1f;cursor:pointer;transition:background .15s,border-color .15s}.off-cache-btn:hover:not(:disabled){background:#f0f0f5;border-color:#b0b0b8}.off-cache-btn:disabled{cursor:default}.off-cache-btn.cached{background:#e8f5e9;border-color:#81c784;color:#1b5e20}.off-cache-btn.error{background:#fdecea;border-color:#e57373;color:#b71c1c}.off-row{cursor:pointer;transition:background .1s}.off-row:hover{background:#f5f5f7}.off-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.off-modal{background:#fff;border-radius:14px;box-shadow:0 8px 40px #0000002e;width:100%;max-width:680px;max-height:88vh;overflow-y:auto;position:relative}.off-modal-close{position:sticky;top:.75rem;float:right;margin:.75rem .75rem 0 0;width:2rem;height:2rem;border-radius:50%;border:none;background:#f0f0f5;color:#1d1d1f;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1;transition:background .15s}.off-modal-close:hover{background:#e0e0e8}.off-modal-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 2rem;color:#6e6e73}.off-modal-spinner{width:2rem;height:2rem;border:3px solid #e0e0e8;border-top-color:#1d1d1f;border-radius:50%;animation:off-spin .7s linear infinite}@keyframes off-spin{to{transform:rotate(360deg)}}.off-modal-error{padding:2rem;color:#cc2d2d;text-align:center}.off-modal-body{padding:1.5rem;clear:both}.off-modal-hero{display:flex;gap:1.5rem;align-items:flex-start;margin-bottom:1.5rem}.off-modal-image{width:160px;height:160px;object-fit:contain;border-radius:8px;background:#f5f5f7;flex-shrink:0;border:1px solid #e5e5ea}.off-modal-image-placeholder{width:160px;height:160px;border-radius:8px;background:#f5f5f7;border:1px solid #e5e5ea;display:flex;align-items:center;justify-content:center;color:#aeaeb2;font-size:.8125rem;flex-shrink:0}.off-modal-identity{flex:1;min-width:0}.off-modal-name{font-size:1.125rem;font-weight:600;color:#1d1d1f;margin-bottom:.25rem;line-height:1.3}.off-modal-brand{font-size:.9375rem;color:#6e6e73;margin-bottom:.5rem}.off-modal-meta{font-size:.8125rem;color:#6e6e73;margin-top:.25rem}.off-modal-barcode{font-variant-numeric:tabular-nums}.off-modal-score{display:inline-block;margin-top:.625rem;font-size:.8125rem}.off-modal-section{border-top:1px solid #e5e5ea;padding-top:1rem;margin-top:1rem}.off-modal-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#6e6e73;margin-bottom:.625rem}.off-modal-nutrients{width:100%;border-collapse:collapse;font-size:.875rem}.off-modal-nutrients tr{border-bottom:1px solid #f0f0f5}.off-modal-nutrients tr:last-child{border-bottom:none}.off-modal-nutrients th{padding:.3rem 0 .5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#86868b;border-bottom:1px solid #d1d1d6}.off-modal-nutrients td{padding:.3rem 0;color:#1d1d1f}.off-modal-nutrient-value{text-align:right;font-variant-numeric:tabular-nums;color:#3a3a3c}.off-modal-ingredients{font-size:.8125rem;color:#3a3a3c;line-height:1.6}.off-modal-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.625rem}.off-nova-badge{display:inline-block;padding:.2rem .55rem;border-radius:5px;font-size:.75rem;font-weight:700;background:#3a3a3c;color:#fff;letter-spacing:.02em}.off-modal-counts{display:flex;gap:1rem;margin-top:.5rem;font-size:.75rem;color:#86868b}.off-modal-aux-images{display:flex;gap:1.5rem;flex-wrap:wrap}.off-modal-aux-img{max-width:200px;max-height:200px;object-fit:contain;border-radius:6px;border:1px solid #e5e5ea;background:#f5f5f7}.off-barcode-main{display:flex;gap:1.25rem;align-items:flex-start;flex-wrap:wrap}.off-barcode-label-col{flex-shrink:0}.off-barcode-label-col .fda-label{margin:0}.off-barcode-info-col{flex:1;min-width:160px;display:flex;flex-direction:column;gap:.75rem}.off-barcode-details{margin-top:1rem;border-top:1px solid #e5e5ea}.off-barcode-details-summary{padding:.6rem 0;font-size:.875rem;font-weight:500;color:#4f46e5;cursor:pointer;list-style:none;display:flex;align-items:center;gap:.4rem;-webkit-user-select:none;user-select:none}.off-modal-image--clickable{cursor:zoom-in}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem}.lightbox-img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:6px;box-shadow:0 8px 48px #0009}.lightbox-close{position:fixed;top:1rem;right:1.25rem;background:none;border:none;color:#fff;font-size:2rem;line-height:1;cursor:pointer;padding:.25rem .5rem;opacity:.8}.lightbox-close:hover{opacity:1}.off-barcode-details-summary::-webkit-details-marker{display:none}.off-barcode-details-summary:before{content:"▶";font-size:.55rem;display:inline-block;transition:transform .15s}.off-barcode-details[open] .off-barcode-details-summary:before{transform:rotate(90deg)}.fda-label{border:2px solid #000;padding:4px 6px 6px;max-width:290px;width:100%;font-family:Arial,Helvetica,sans-serif;font-size:.875rem;color:#000;background:#fff;margin:1.25rem auto;box-sizing:border-box}.fda-label-title{font-size:2rem;font-weight:900;line-height:1;margin-bottom:1px}.fda-label-serving-size{display:flex;justify-content:space-between;align-items:baseline;font-size:.8125rem;font-weight:700;margin-bottom:2px}.fda-rule{border:none;margin:0}.fda-rule--thick{border-top:8px solid #000;margin:3px 0}.fda-rule--medium{border-top:4px solid #000;margin:2px 0}.fda-rule--thin{border-top:1px solid #000}.fda-label-amount-header{font-size:.6875rem;margin-top:2px}.fda-label-calories-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1px}.fda-label-calories-label{font-size:1.1rem;font-weight:700}.fda-label-calories-value{font-size:2.75rem;font-weight:900;line-height:1}.fda-dv-header{text-align:right;font-size:.6875rem;font-weight:700;padding-bottom:1px}.fda-row{display:flex;justify-content:space-between;align-items:baseline;padding:1px 0;font-size:.8125rem;line-height:1.3}.fda-row--indent1 .fda-row-left{padding-left:1rem}.fda-row--indent2 .fda-row-left{padding-left:2rem;font-size:.75rem}.fda-row--vitamin{font-size:.8rem}.fda-row-left{flex:1}.fda-row-right{flex-shrink:0;margin-left:.5rem}.fda-row-amount{font-weight:400}.fda-footnote{font-size:.6rem;line-height:1.35;margin:3px 0 0}.app-settings-list{display:flex;flex-direction:column;gap:0}.app-setting-row{display:flex;align-items:center;gap:1.5rem;padding:1rem 0;border-bottom:1px solid #f0f0f5}.app-setting-row:last-child{border-bottom:none}.app-setting-meta{flex:1;min-width:0}.app-setting-label{font-size:.9375rem;font-weight:500;color:#1d1d1f}.app-setting-key{font-size:.75rem;color:#888;font-family:SF Mono,Menlo,monospace;margin-top:.125rem}.app-setting-control{display:flex;align-items:center;gap:.625rem;flex-shrink:0}.app-setting-save{padding:.5rem 1rem;background:#007aff;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s}.app-setting-save:hover:not(:disabled){background:#0062cc}.app-setting-save:disabled{opacity:.45;cursor:default}.app-setting-save.saved{background:#1d8a1d}.app-setting-error{width:100%;font-size:.8125rem;color:#cc2d2d;margin-top:.25rem}.logs-toolbar{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem}.logs-toolbar .rndb-search{flex:1}.logs-refresh-btn{padding:.6rem 1rem;border:1.5px solid #d1d1d6;border-radius:10px;font-size:.875rem;background:#fff;cursor:pointer;white-space:nowrap;transition:border-color .15s}.logs-refresh-btn:hover:not(:disabled){border-color:#007aff;color:#007aff}.logs-refresh-btn:disabled{opacity:.5;cursor:default}.logs-meta{font-size:.8125rem;color:#888;margin-bottom:.5rem}.logs-output{background:#1c1c1e;border-radius:10px;padding:.875rem 1rem;overflow-x:auto;overflow-y:auto;max-height:70vh;font-family:SF Mono,Menlo,Monaco,monospace;font-size:.75rem;line-height:1.55}.logs-placeholder{color:#888}.logs-line{color:#e5e5ea;white-space:pre-wrap;word-break:break-all}.logs-line--error{color:#ff6b6b}.logs-line--warn{color:#ffd166}.logs-line--debug{color:#a0c4ff}.barcode-scan-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;border:none;border-radius:10px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:opacity .15s}.barcode-scan-btn:hover{opacity:.85}.barcode-scan-btn--camera{background:#007aff;color:#fff}.barcode-scan-btn--upload{background:#3a3a3c;color:#fff}.barcode-scan-btn--manual{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.barcode-scan-btn--manual:hover{background:#e5e7eb;opacity:1}.barcode-viewfinder{display:none;position:relative;width:100%;max-width:480px;aspect-ratio:4 / 3;background:#000;border-radius:12px;overflow:hidden}.barcode-viewfinder--active{display:block}.barcode-video{width:100%;height:100%;object-fit:cover;display:block}.barcode-reticle{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;width:65%;height:40%;border:2px solid rgba(255,255,255,.85);border-radius:8px;box-shadow:0 0 0 9999px #0006}.barcode-cancel-btn{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#0000008c;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:.45rem 1.25rem;font-size:.875rem;font-weight:500;cursor:pointer;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.barcode-upload-preview{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.barcode-scan-image{max-width:100%;max-height:50vh;border-radius:10px;border:1px solid #e5e5ea;display:block;object-fit:contain}.barcode-scan-hits{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:480px}.barcode-hit{background:#fff;border-radius:10px;padding:1rem 1.25rem;box-shadow:0 1px 4px #0000000f}.barcode-hit-value{font-size:1.6rem;font-weight:700;letter-spacing:.06em;font-variant-numeric:tabular-nums;color:#1d1d1f}.barcode-hit-format{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#6e6e73;margin-top:.2rem}.barcode-product-detail{margin-top:1.25rem;background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000000f;overflow:hidden;width:100%}.nf-label{font-family:Arial,Helvetica,sans-serif;background:#fff;color:#000;border:2px solid #000;padding:.375rem .5rem .5rem;max-width:320px;width:100%;margin-top:1.5rem}.nf-title{font-size:2.25rem;font-weight:900;line-height:1;letter-spacing:-.5px}.nf-rule--medium{height:5px;background:#000;margin:.2rem 0 .15rem}.nf-rule--heavy{height:10px;background:#000;margin:.2rem 0}.nf-rule--thick{height:5px;background:#000;margin:.1rem 0}.nf-rule--thin{height:1px;background:#000;margin:.25rem 0 .2rem}.nf-serving-row{display:flex;justify-content:space-between;align-items:baseline;font-size:.8rem;margin:.1rem 0}.nf-serving-size{font-weight:700}.nf-calories-section{margin:.15rem 0 0}.nf-amount-label{font-size:.8rem;display:block}.nf-calories-row{display:flex;justify-content:space-between;align-items:baseline;line-height:1}.nf-calories-label{font-size:1.75rem;font-weight:700}.nf-calories-value{font-size:3.25rem;font-weight:900;line-height:1}.nf-dv-header{text-align:right;font-size:.72rem;font-weight:700;padding-bottom:.1rem}.nf-row{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid #000;padding:2px 0;font-size:.82rem;gap:.5rem}.nf-row--sub{padding-left:1rem}.nf-row--sub2{padding-left:2rem}.nf-row-left{flex:1;min-width:0}.nf-row-amount{font-weight:400}.nf-row-pct{font-weight:700;white-space:nowrap;flex-shrink:0;min-width:2.5rem;text-align:right}.nf-mineral{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid #000;font-size:.82rem;padding:2px 0;gap:.5rem}.nf-mineral-pct{font-weight:700;white-space:nowrap}.nf-footnote{font-size:.62rem;line-height:1.35;margin-top:.25rem;color:#000}.admin-topbar{display:none}.admin-hamburger{background:none;border:none;color:#fff;cursor:pointer;padding:.375rem;display:flex;flex-direction:column;gap:5px;flex-shrink:0}.admin-hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px}.admin-topbar-title{font-size:1rem;font-weight:700;color:#fff;letter-spacing:-.3px}.admin-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200}@media (max-width: 768px){.admin-shell{flex-direction:column}.admin-topbar{display:flex;align-items:center;gap:1rem;position:sticky;top:0;z-index:100;height:52px;background:#1c1c1e;padding:0 1rem;flex-shrink:0}.admin-sidebar{position:fixed;top:0;left:0;height:100vh;width:260px;z-index:300;transform:translate(-100%);transition:transform .25s ease}.admin-sidebar--open{transform:translate(0)}.admin-content{padding:1.25rem 1rem}}.comp-search-form{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.comp-search-inputs{display:flex;gap:.625rem}.comp-search-inputs .rndb-search{flex:1}.comp-search-actions{display:flex;align-items:center;justify-content:center;gap:1.25rem}.comp-search-or{font-size:.8125rem;font-weight:600;color:var(--text-muted, #888);letter-spacing:.05em}.comp-search-barcode{background:#555!important}.comp-tab-count{display:inline-block;margin-left:.4rem;padding:.05rem .45rem;background:#0000001f;border-radius:20px;font-size:.75rem;font-weight:600}.comp-search-results{border-top:1px solid var(--border, #e0e0e0);padding-top:1.5rem}.comp-search-empty{text-align:center;color:var(--text-muted, #888);font-size:.9375rem;padding:2rem 0}.foods-badge{display:inline-block;padding:.15rem .55rem;border-radius:20px;font-size:.75rem;font-weight:600}.foods-badge--shared{background:#d4edda;color:#1d6a2e}.foods-badge--private{background:#f0f0f0;color:#666}.add-food-form{max-width:640px;display:flex;flex-direction:column;gap:1.5rem}.add-food-section{border:1px solid var(--border, #e0e0e0);border-radius:12px;padding:1.25rem;background:var(--bg-card, #f5f5f7)}.add-food-section-title{font-size:1rem;font-weight:600;margin:0 0 1rem}.add-food-section-sub{font-size:.8125rem;font-weight:400;color:var(--text-muted, #888);margin-left:.4rem}.add-food-required{color:#cc2d2d}.add-food-fields{display:grid;grid-template-columns:1fr 1fr;gap:.875rem}.add-food-field{display:flex;flex-direction:column;gap:.35rem}.add-food-field--wide{grid-column:1 / -1}.add-food-label{font-size:.8125rem;font-weight:500;color:var(--text-muted, #666)}.add-food-input{width:100%}.add-food-input-unit{display:flex;align-items:center;gap:.4rem}.add-food-unit{font-size:.8125rem;color:var(--text-muted, #888);white-space:nowrap}.add-food-nutrient-list{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border, #e0e0e0);border-radius:8px;overflow:hidden}.add-food-nutrient-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem .875rem;border-bottom:1px solid var(--border, #e0e0e0)}.add-food-nutrient-row:last-child{border-bottom:none}.add-food-nutrient-row--bold .add-food-nutrient-label{font-weight:600}.add-food-nutrient-row--indent{padding-left:1.75rem}.add-food-nutrient-row--indent2{padding-left:3rem}.add-food-nutrient-label{font-size:.9rem;flex:1}.add-food-nutrient-input{width:5rem;padding:.3rem .5rem;border:1px solid var(--border, #ddd);border-radius:6px;font-size:.875rem;text-align:right;background:var(--bg-card, #f5f5f7)}.add-food-nutrient-input:focus{outline:none;border-color:#007aff;background:#fff}.add-food-nutrient-divider{height:4px;background:var(--text, #1c1c1e)}.add-food-nutrient-divider--thick{height:8px}.add-food-actions{display:flex;align-items:center;justify-content:space-between;padding-bottom:2rem}.add-food-add-serving-btn{padding:.6rem 1.25rem;background:#1d8a1d;color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:500;cursor:pointer;white-space:nowrap}.add-food-add-serving-btn:hover{background:#176b17}.add-food-save-btn{margin-left:auto}.add-food-alt-nutrients-btn{padding:.55rem 1rem;background:none;border:1px dashed var(--border, #ccc);border-radius:8px;font-size:.875rem;color:#007aff;cursor:pointer;width:100%;text-align:center}.add-food-alt-nutrients-btn:hover{background:#f0f7ff;border-color:#007aff}.add-food-status{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;background:#e8f4fd;border:1px solid #b3d9f5;border-radius:8px;font-size:.9rem;color:#06c}.add-food-status-spinner{display:inline-block;width:1rem;height:1rem;border:2px solid #b3d9f5;border-top-color:#06c;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.docs-toc{display:flex;gap:1rem;margin-bottom:2rem;padding:.75rem 1rem;background:var(--bg-card, #f5f5f7);border-radius:10px;font-size:.9rem}.docs-toc a{color:#007aff;text-decoration:none}.docs-toc a:hover{text-decoration:underline}.docs-section{margin-bottom:3rem}.docs-section-title{font-size:1.25rem;font-weight:600;margin:0 0 .5rem;padding-bottom:.5rem;border-bottom:2px solid var(--border, #e0e0e0)}.docs-body{font-size:.9375rem;line-height:1.6;color:var(--text, #1c1c1e);margin:.75rem 0}.docs-tab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;margin:1.25rem 0}.docs-tab-card{border:1px solid var(--border, #e0e0e0);border-radius:12px;padding:1.25rem;background:var(--bg-card, #f5f5f7)}.docs-tab-header{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;margin-bottom:.875rem}.docs-tab-name{font-size:1rem;font-weight:600}.docs-tab-api{font-size:.75rem;font-weight:500;color:#fff;background:#555;padding:.15rem .5rem;border-radius:20px;white-space:nowrap}.docs-dl{margin:0 0 .875rem;display:grid;grid-template-columns:auto 1fr;gap:.25rem .75rem;font-size:.8125rem}.docs-dl dt{font-weight:600;color:var(--text-muted, #666);white-space:nowrap}.docs-dl dd{margin:0}.docs-dl code{font-size:.775rem;background:var(--bg, #fff);padding:.1rem .35rem;border-radius:4px;border:1px solid var(--border, #e0e0e0);word-break:break-all}.docs-note{margin-top:1.5rem;padding:1rem 1.25rem;background:#fff8e1;border-left:4px solid #f5c518;border-radius:0 8px 8px 0;font-size:.9rem}.docs-note strong{display:block;margin-bottom:.5rem}.docs-note ul{margin:0;padding-left:1.25rem;line-height:1.7}.wiz-steps{display:flex;align-items:flex-start;gap:0;margin-bottom:2rem;overflow-x:auto;padding-bottom:.25rem}.wiz-steps-item{display:flex;align-items:center;flex-shrink:0}.wiz-step-pip{width:2rem;height:2rem;border-radius:50%;border:2px solid #d1d5db;background:#fff;color:#9ca3af;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s,border-color .2s,color .2s}.wiz-step-pip--active{border-color:#2563eb;background:#2563eb;color:#fff}.wiz-step-pip--done{border-color:#16a34a;background:#16a34a;color:#fff}.wiz-step-label{font-size:.78rem;color:#9ca3af;margin-left:.5rem;white-space:nowrap}.wiz-step-label--active{color:#111827;font-weight:600}.wiz-step-connector{height:2px;width:2.5rem;background:#e5e7eb;margin:0 .5rem;flex-shrink:0;transition:background .2s}.wiz-step-connector--done{background:#16a34a}.wiz-body{min-height:18rem}.wiz-step-body{max-width:640px}.wiz-step-intro{font-size:.9rem;color:#6b7280;margin-bottom:1.5rem}.wiz-nav{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding-top:1.25rem;border-top:1px solid #e5e7eb}.wiz-nav-left,.wiz-nav-right{display:flex;gap:.75rem}.wiz-btn{padding:.6rem 1.4rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:background .15s,opacity .15s}.wiz-btn:disabled{opacity:.45;cursor:not-allowed}.wiz-btn--back{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.wiz-btn--back:hover:not(:disabled){background:#e5e7eb}.wiz-btn--next{background:#2563eb;color:#fff}.wiz-btn--next:hover:not(:disabled){background:#1d4ed8}.wiz-btn--save{background:#16a34a;color:#fff}.wiz-btn--save:hover:not(:disabled){background:#15803d}.wiz-review{display:flex;gap:2.5rem;align-items:flex-start;flex-wrap:wrap}.wiz-review-info{flex:1;min-width:220px}.wiz-review-title{font-size:1rem;font-weight:700;color:#111827;margin-bottom:.75rem}.wiz-review-dl{display:grid;grid-template-columns:auto 1fr;gap:.35rem 1rem;font-size:.88rem}.wiz-review-dl dt{color:#6b7280;font-weight:600;white-space:nowrap}.wiz-review-dl dd{color:#111827;margin:0;word-break:break-word}.wiz-review-label{flex-shrink:0}.wiz-review-label .nf-label{margin-top:0}.wiz-review-empty{font-size:.88rem;color:#9ca3af;font-style:italic}.v3-confirm-product-header{margin-bottom:1rem}.v3-confirm-product-name{font-size:1.15rem;font-weight:600;color:#111827;margin:0 0 .2rem}.v3-confirm-product-brand{font-size:.9rem;color:#6b7280;margin:0 0 .25rem}.v3-confirm-barcode{font-family:monospace;font-size:.82rem;color:#9ca3af;margin:0}.v3-confirm-not-found{background:#fef3c7;border:1px solid #fde68a;border-radius:8px;padding:.75rem 1rem;font-size:.9rem;color:#92400e;margin-bottom:1.25rem}.v3-confirm-label-prompt{font-size:1rem;color:#374151;margin-bottom:1rem}.v3-confirm-label-actions{display:flex;flex-direction:column;gap:.65rem;max-width:280px}.fda-scan-stage{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem}.fda-scan-icon{color:#9ca3af}.fda-scan-prompt{font-size:1rem;color:#6b7280;margin:0;text-align:center}.fda-scan-preview{width:100%;max-width:480px;max-height:60vh;object-fit:contain;border-radius:12px;border:1px solid #e5e7eb;display:block}.fda-scan-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}.fda-scan-btn{font-size:1rem;padding:.75rem 1.75rem}.fda-scan-btn--process{background:#16a34a;color:#fff}.fda-scan-status{font-size:.88rem;color:#6b7280;margin:.5rem 0 0;display:flex;align-items:center;gap:.25rem}.fda-json-result{margin-top:1.5rem;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;max-width:600px}.fda-json-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.fda-json-title{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#6b7280}.fda-json-count{font-size:.78rem;color:#9ca3af}.fda-json-body{margin:0;padding:1rem;font-family:SF Mono,Menlo,Consolas,monospace;font-size:.82rem;line-height:1.65;color:#111827;background:#fff;overflow-x:auto;white-space:pre}.v3-barcode-question{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem}.v3-question-text{font-size:1.3rem;font-weight:700;color:#111827;margin:0 0 2rem;text-align:center}.v3-question-buttons{display:flex;gap:1.25rem;justify-content:center}.v3-question-btn{min-width:120px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.v3-question-btn--no{background:#f3f4f6;color:#374151;border-color:#d1d5db}.v3-question-btn--no:hover{background:#e5e7eb}.v3-question-btn--yes{background:#2563eb;color:#fff;border-color:#2563eb}.v3-question-btn--yes:hover{background:#1d4ed8;border-color:#1d4ed8}.v3-scan-container{max-width:480px}.v3-scan-detecting{color:#9ca3af;font-size:.9rem}.v3-scan-options{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem}.v3-scan-heading{font-size:1.15rem;font-weight:700;color:#111827;margin:0}.v3-scan-subtext{font-size:.9rem;color:#6b7280;margin:0 0 .5rem;line-height:1.5}.v3-scan-primary-btn{font-size:1rem;padding:.75rem 1.5rem}.v3-scan-or{display:flex;align-items:center;gap:.75rem;width:100%;color:#9ca3af;font-size:.82rem;margin:.25rem 0}.v3-scan-or:before,.v3-scan-or:after{content:"";flex:1;height:1px;background:#e5e7eb}.v3-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:200px;border:2px dashed #d1d5db;border-radius:12px;background:#f9fafb;cursor:pointer;padding:2rem 1.5rem;gap:.5rem;transition:border-color .15s,background .15s;text-align:center;font:inherit}.v3-upload-zone:hover{border-color:#2563eb;background:#eff6ff}.v3-upload-zone-icon{color:#9ca3af;margin-bottom:.25rem}.v3-upload-zone:hover .v3-upload-zone-icon{color:#2563eb}.v3-upload-zone-label{font-size:.95rem;font-weight:600;color:#374151}.v3-upload-zone-hint{font-size:.78rem;color:#9ca3af}.v3-status-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem 1.5rem;margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.v3-status-barcode{display:flex;flex-direction:column;gap:.2rem}.v3-status-barcode-value{font-size:1.5rem;font-weight:700;letter-spacing:.06em;font-variant-numeric:tabular-nums;color:#111827}.v3-status-barcode-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#16a34a}.v3-status-lookup{font-size:.9rem;color:#6b7280}.v3-status-not-found{font-size:.88rem;color:#374151}.v3-status-not-found p{margin:0;line-height:1.5}.v3-manual-modal{max-width:400px!important;padding:1.75rem}.v3-manual-modal-header{display:flex;align-items:center;gap:.625rem;margin-bottom:.5rem;color:#111827}.v3-manual-modal-title{font-size:1.05rem;font-weight:700;margin:0}.v3-manual-modal-desc{font-size:.88rem;color:#6b7280;margin:0 0 1.25rem;line-height:1.5}.v3-manual-modal-input{width:100%;padding:.65rem .875rem;font-size:1.1rem;font-family:SF Mono,Menlo,Consolas,monospace;letter-spacing:.08em;border:2px solid #d1d5db;border-radius:8px;outline:none;box-sizing:border-box;transition:border-color .15s}.v3-manual-modal-input:focus{border-color:#2563eb}.v3-manual-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem}
