.app-layout{display:flex;min-height:100vh;position:relative}.hamburger{position:fixed;top:1rem;left:1rem;z-index:1001;width:44px;height:44px;padding:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px}.hamburger:hover{border-color:var(--accent);background:#0969da0f}.profile-trigger{position:fixed;top:1rem;right:1rem;z-index:1001}.profile-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem;width:44px;height:44px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text);font-size:.9rem}.profile-btn:hover{border-color:var(--accent);background:#0969da0f}.profile-name{font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;min-width:180px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 12px #00000026;padding:.75rem;display:flex;flex-direction:column;gap:.25rem}.profile-dropdown-user{font-weight:600;font-size:.95rem}.profile-dropdown-email{font-size:.8rem;color:var(--muted)}.profile-dropdown-link{display:block;padding:.4rem 0;color:var(--text);font-size:.9rem;text-decoration:none}.profile-dropdown-link:hover{color:var(--accent)}.profile-dropdown-link.active{color:var(--accent);font-weight:500}.profile-dropdown-logout{margin-top:.5rem;padding:.4rem 0;background:none;border:none;color:var(--accent);font-size:.9rem;cursor:pointer;text-align:left}.profile-dropdown-logout:hover{text-decoration:underline}.hamburger span{display:block;width:18px;height:2px;background:var(--text);border-radius:1px}.sidebar{position:fixed;top:0;left:0;width:200px;height:100vh;background:var(--surface);border-right:1px solid var(--border);padding:4rem 0 0 1rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem;transform:translate(-100%);transition:transform .2s ease}.sidebar.open{transform:translate(0)}.sidebar a{color:var(--muted);text-decoration:none;font-size:1rem;font-weight:500;padding:.5rem .75rem;border-radius:var(--radius)}.sidebar a:hover{color:var(--text);background:#0000000a}.sidebar a.active{color:var(--accent);background:#0969da14}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:999}.back-to-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:1.25rem;cursor:pointer;box-shadow:0 2px 8px #0003;z-index:998;transition:opacity .2s,transform .2s}.back-to-top:hover{opacity:.9;transform:translateY(-2px)}.main-content{flex:1;min-width:0;padding-top:1rem;padding-left:4rem;padding-right:5rem;transition:margin-left .2s ease}.app-layout.nav-open .main-content{margin-left:200px}.app{max-width:1200px;margin:0 auto;padding:0 2rem 2rem;min-width:0;overflow-x:hidden}.app--full-width{max-width:none;margin-left:0;margin-right:0;padding:0 2rem 2rem}.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.page-header h1{margin:0}.page-header .toolbar{display:flex;align-items:center;gap:1rem;flex:1 1 auto;min-width:0;margin-bottom:0;justify-content:flex-end}.page-header-left{display:flex;flex-direction:column;gap:.5rem}header{margin-bottom:1rem}h1{font-size:2rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .25rem;background:linear-gradient(135deg,#0969da,#218bff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loading,.error{text-align:center;padding:4rem 2rem;color:var(--muted)}.error{color:#cf222e}.error code{background:var(--surface);padding:.2em .5em;border-radius:4px;font-family:JetBrains Mono,monospace}.error .error-hint{color:var(--muted);font-size:.9rem;margin-top:.5rem}.error .error-hint--muted{font-size:.85rem;margin-top:.75rem;opacity:.92}.error .retry-btn{margin-top:1rem;padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-size:.95rem}.error .retry-btn:hover{opacity:.9}.toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.search{flex:1;max-width:320px;padding:.6rem 1rem;font-size:.95rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit}.search::placeholder{color:var(--muted)}.search:focus{outline:none;border-color:var(--accent)}.count{font-size:.875rem;color:var(--muted)}.add-order-btn{padding:.5rem 1rem;font-size:.9rem;font-family:inherit;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer}.add-order-btn:hover{opacity:.9}.orders-page-header{align-items:center}.orders-page-title-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;min-width:0}.orders-page-title-row h1{margin:0}.orders-page .add-order-btn--inline{background:#e8f4fd;color:#0969da;border:1px solid #b6d9f7;white-space:nowrap;flex-shrink:0}.orders-page .add-order-btn--inline:hover{opacity:1;background:#d5ebfc;border-color:#91c9f2}.fetch-prices-btn{background:var(--surface);color:var(--text);border:1px solid var(--border)}.fetch-prices-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.page-header-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.scrape-btn{padding:.4rem .8rem;font-size:.875rem;font-family:inherit;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.scrape-btn:hover:not(:disabled){color:var(--text);border-color:var(--accent);background:#0969da14}.scrape-btn:disabled{opacity:.6;cursor:not-allowed}.scrape-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.scrape-btn-primary:hover:not(:disabled){opacity:.9}.scrape-result{font-size:.85rem}.scrape-result.success{color:var(--success, #1a7f37)}.scrape-result.error{color:var(--danger, #cf222e)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 32px #0003;max-width:520px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:1.15rem}.modal-close{background:none;border:none;font-size:1.5rem;line-height:1;padding:0;cursor:pointer;color:var(--muted)}.modal-close:hover{color:var(--text)}.modal-body{padding:1.25rem}.modal .modal-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.modal p{margin:0;color:var(--muted)}.add-order-modal .add-order-divider{margin:1.25rem 0 .75rem}.add-order-modal .add-order-row{margin-bottom:.5rem}.add-order-file-label{display:inline-block;padding:.5rem 1rem;font-size:.9rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.add-order-file-label:hover:not(:has(input:disabled)){border-color:var(--accent)}.add-order-file-input{display:none}.add-order-import,.add-order-import .add-order-hint{margin-top:.5rem}.add-order-hint{font-size:.9rem;color:var(--muted);margin-bottom:.75rem!important}.add-order-hint code{background:var(--surface);padding:.1em .4em;border-radius:4px;font-size:.85em}.add-order-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.add-order-url-input{min-width:320px;padding:.4rem .6rem;font-family:inherit;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.add-order-hint-url{margin-top:.25rem!important;font-size:.85rem}.add-order-row input[type=date]{padding:.4rem;font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.add-order-textarea{width:100%;max-width:600px;padding:.75rem;font-family:inherit;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);resize:vertical;margin-bottom:.75rem}.add-order-actions{display:flex;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.add-order-actions button{padding:.5rem 1rem;font-family:inherit;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer}.add-order-actions button:disabled{opacity:.5;cursor:not-allowed}.parsed-preview{font-size:.85rem;color:var(--muted);margin-top:.5rem;max-height:60px;overflow:auto}.add-order-status{margin-top:.5rem!important;font-weight:500}.add-order-sync{margin-bottom:1rem}.sync-status-section{margin-bottom:1rem;padding:.75rem;background:#00000008;border-radius:var(--radius);font-size:.9rem}.sync-status-loading{margin-left:.5rem;color:var(--muted)}.sync-status-error{margin:.5rem 0 0;color:#cf222e;font-size:.85rem}.sync-status-list{margin:.5rem 0 0;padding-left:1.25rem;list-style:none}.sync-status-list li{margin-bottom:.25rem}.sync-status-list li.imported{color:#1a7f37}.sync-status-list li.not-imported{color:var(--muted)}.add-order-sync .sync-btn{margin-bottom:.5rem}.sync-result{margin-top:.75rem;padding:.75rem 1rem;border-radius:var(--radius);font-size:.95rem}.sync-result.success{background:#1a7f371f;color:#1a7f37}.sync-result.error{background:#cf222e1a;color:#cf222e}.add-order-divider{margin:1.5rem 0 1rem;text-align:center;color:var(--muted);font-size:.85rem}.add-order-divider:before,.add-order-divider:after{content:"";display:inline-block;width:20%;height:1px;background:var(--border);vertical-align:middle;margin:0 .75rem}.add-order-divider span{vertical-align:middle}.recommended-orders-page{padding:0}.recommended-dates-list{display:flex;flex-direction:column;gap:.5rem;max-width:24rem}.recommended-date-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:.5rem}.recommended-date-card.past{opacity:.7}.recommended-date-card.next{border-color:var(--accent);background:#0969da0a}.recommended-date-row{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem 1rem;background:var(--surface);border:none;border-radius:0;cursor:pointer;font:inherit;text-align:left}.recommended-date-row:hover{background:#0000000a}.recommended-date-card.next .recommended-date-row{background:#0969da0f}.recommended-date{flex:1;font-weight:500}.recommended-date-meta{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--muted)}.recommended-badge{font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:4px;background:var(--accent);color:#fff}.recommended-badge.past{background:var(--muted);color:#fff}.recommended-items-list{margin:0;padding:.5rem 1rem 1rem;list-style:none;background:#00000005;border-top:1px solid var(--border);font-size:.9rem}.recommended-items-list li{padding:.35rem 0;display:flex;justify-content:space-between;align-items:center;gap:.5rem}.recommended-item-link{color:inherit;text-decoration:none;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.recommended-item-link:hover{color:var(--accent);text-decoration:underline}.recommended-item-qty{font-family:JetBrains Mono,monospace;color:var(--muted);flex-shrink:0}.recommended-items-empty{color:var(--muted);font-style:italic}.recommended-detail-row td{padding:.5rem 1rem!important;background:#00000008;vertical-align:top}.recommended-items-inline{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.25rem 1.5rem;font-size:.875rem}.recommended-items-inline li{padding:.2rem 0;display:flex;justify-content:space-between;gap:.5rem}.orders-page{padding:0}.orders-filters{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;margin-top:0}.orders-date-filter{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.orders-type-filter{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding-left:.5rem;border-left:1px solid var(--border)}.orders-type-label{font-size:.9rem;color:var(--muted)}.orders-type-check{display:flex;align-items:center;gap:.35rem;font-size:.9rem;color:var(--muted);cursor:pointer}.orders-type-check:hover{color:var(--text)}.orders-type-check input{cursor:pointer}.orders-date-filter label{display:flex;align-items:center;gap:.4rem;font-size:.9rem;color:var(--muted)}.orders-date-input{padding:.4rem .5rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem;font-family:inherit}.orders-date-input:focus{outline:none;border-color:var(--accent)}.orders-filter-clear{padding:.4rem .75rem;font-size:.85rem;font-family:inherit;background:transparent;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);cursor:pointer}.orders-filter-clear:hover{color:var(--text);border-color:var(--accent)}.orders-filter-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer}.orders-filter-btn:hover{color:var(--accent);border-color:#0969da59;background:#0969da0f}.orders-filter-btn--active{color:var(--accent);border-color:#0969da59;background:#0969da14}.orders-filter-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#00000059}.orders-filter-panel{position:fixed;top:0;right:0;bottom:0;z-index:1101;width:min(320px,92vw);background:var(--surface);border-left:1px solid var(--border);box-shadow:-8px 0 32px #0000001f;display:flex;flex-direction:column;animation:orders-filter-panel-in .22s ease-out;overflow:hidden;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}@keyframes orders-filter-panel-in{0%{transform:translate(100%)}to{transform:translate(0)}}.orders-filter-panel-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1rem;border-bottom:1px solid var(--border)}.orders-filter-panel-header h2{margin:0;font-size:1.05rem;font-weight:600}.orders-filter-panel-close{flex-shrink:0;width:36px;height:36px;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:1.35rem;line-height:1;cursor:pointer}.orders-filter-panel-close:hover{border-color:var(--accent);color:var(--accent)}.orders-filter-panel-body{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1.25rem}.orders-filter-panel-group{display:flex;flex-direction:column;gap:.65rem}.orders-filter-panel-label{font-size:.85rem;font-weight:600;color:var(--text)}.orders-filter-panel-field{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:var(--muted)}.orders-filter-panel-field .orders-date-input{width:100%}.orders-filter-panel-types{display:flex;flex-direction:column;gap:.5rem}.orders-type-check--symbol{gap:.5rem}.orders-type-check-label{font-size:.9rem;color:var(--text)}.orders-filter-panel-footer{padding:1rem;border-top:1px solid var(--border)}.orders-filter-panel-footer .orders-filter-clear{width:100%}.items-histogram-section{margin-bottom:1.5rem;border:1px solid var(--border);border-radius:var(--radius);background:#00000005;overflow:hidden}.items-histogram-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.65rem 1rem;font:inherit;font-size:.95rem;font-weight:600;color:var(--text);text-align:left;background:#00000008;border:none;cursor:pointer}.items-histogram-toggle:hover{background:#0000000f}.items-histogram-toggle-label{display:inline-flex;align-items:center;gap:.35rem}.items-histogram-chevron{display:inline-flex;align-items:center;color:var(--muted);flex-shrink:0}.items-histogram-wrap{background:var(--surface);border-top:1px solid var(--border);padding:.75rem 1rem .5rem;min-height:180px}.items-histogram-title{font-size:1rem;font-weight:600;margin:0 0 .5rem;color:var(--text)}.items-search-bar{margin-bottom:1rem}.items-search-bar .search{width:100%;max-width:24rem}.orders-chart-section{margin-bottom:1.5rem;border:1px solid var(--border);border-radius:var(--radius);background:#00000005;overflow:visible}.orders-chart-section-top{display:flex;align-items:stretch;background:#00000008;border-radius:var(--radius);overflow:visible}.orders-chart-section-top:has(+.orders-chart-wrap){border-radius:var(--radius) var(--radius) 0 0}.orders-chart-section-top .orders-chart-toggle{flex:1;min-width:0;border-radius:var(--radius) 0 0 0}.orders-chart-static-label{flex:1;min-width:0;display:flex;align-items:center;padding:.65rem 1rem;font-size:.95rem;font-weight:600;color:var(--text)}.recommended-info-wrap{position:relative;display:flex;align-items:center;flex-shrink:0;padding:0 .65rem;border-left:1px solid var(--border)}.recommended-info-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--muted);cursor:pointer}.recommended-info-btn:hover,.recommended-info-btn[aria-expanded=true]{color:var(--accent);border-color:#0969da59;background:#0969da0f}.recommended-info-popover{position:absolute;top:calc(100% + .5rem);right:0;z-index:50;width:min(18rem,calc(100vw - 2rem));padding:.85rem 1rem;font-size:.9rem;line-height:1.45;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000001f}.recommended-info-popover p{margin:0}.orders-chart-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.65rem 1rem;font:inherit;font-size:.95rem;font-weight:600;color:var(--text);text-align:left;background:#00000008;border:none;cursor:pointer}.orders-chart-toggle:hover{background:#0000000f}.orders-chart-toggle-label{display:inline-flex;align-items:center;gap:.35rem}.orders-chart-chevron{display:inline-flex;align-items:center;color:var(--muted);flex-shrink:0}.orders-chart-wrap{background:var(--surface);border-top:1px solid var(--border);padding:.75rem .5rem .5rem;min-height:240px}.orders-chart-scroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.orders-chart-scroll-inner{min-width:100%}.chart-metric-toggle{display:flex;align-items:center;justify-content:flex-end;gap:.25rem;margin-bottom:.75rem}.chart-metric-btns{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.chart-metric-btn{padding:.25rem .6rem;font-size:.8rem;background:transparent;border:none;color:var(--muted);cursor:pointer;transition:background .15s,color .15s}.chart-metric-btn:hover:not(:disabled){background:#0000000a;color:var(--text)}.chart-metric-btn.active{background:var(--accent);color:#fff}.chart-metric-btn:disabled{opacity:.5;cursor:not-allowed}.orders-chart-wrap .recharts-tooltip-wrapper{background-color:#fff!important;opacity:1!important}.orders-chart-tooltip{font-size:.85rem;line-height:1.6;color:var(--text);background-color:#fff;padding:1rem 1.25rem}.orders-chart-tooltip-label{font-weight:600;margin-bottom:.5rem}.orders-chart-tooltip-row{margin-bottom:.35rem}.orders-chart-tooltip-row:last-of-type{margin-bottom:0}.orders-chart-tooltip-meta{font-size:.8rem;color:var(--muted)}.orders-chart-tooltip-total{font-weight:600;margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(0,0,0,.1)}.orders-page .back-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.5rem 1rem;border-radius:var(--radius);cursor:pointer;font-family:inherit;margin-bottom:1.5rem}.orders-page .back-btn:hover{border-color:var(--accent)}.orders-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto;margin-bottom:1rem}.orders-page .orders-table-wrap--compact{width:100%;max-width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;touch-action:pan-x pan-y}.orders-page .orders-table--compact{width:max-content;min-width:100%;table-layout:auto}.orders-page .orders-table--compact.recommended-orders-table{width:100%;table-layout:fixed;min-width:0}.orders-page .orders-table--compact.recommended-orders-table .orders-col-date,.orders-page .orders-table--compact.recommended-orders-table .orders-col-type,.orders-page .orders-table--compact.recommended-orders-table .orders-col-items,.orders-page .orders-table--compact.recommended-orders-table .orders-col-total,.orders-page .orders-table--compact.recommended-orders-table .orders-col-view{width:20%}.orders-page .orders-table--compact.recommended-orders-table .view-cell{width:auto}.orders-page .orders-table--compact.recommended-orders-table .order-row .order-link{overflow:hidden;text-overflow:ellipsis}.orders-page .orders-table--compact .orders-col-date,.orders-page .orders-table--compact .orders-col-items,.orders-page .orders-table--compact .orders-col-total,.orders-page .orders-table--compact .orders-col-type{width:1%;white-space:nowrap}.orders-page .orders-table--compact .orders-col-view{width:2.75rem}.orders-page .orders-table--compact th,.orders-page .orders-table--compact td{padding:.5rem .35rem;overflow:visible;text-overflow:clip}.orders-page .orders-table--compact th{font-size:.7rem;letter-spacing:.03em}.orders-page .orders-table--compact .order-row .order-link{margin:0;padding:.15rem 0;white-space:nowrap;overflow:visible;text-overflow:clip}.orders-page .orders-table--compact .view-cell{width:2.5rem;padding-left:.2rem!important;padding-right:.2rem!important;white-space:nowrap}.orders-page .orders-table--compact .view-btn--icon{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid rgba(9,105,218,.35)}.orders-page .orders-table--compact .view-btn--icon svg{display:block}.orders-page .orders-table--compact td.num{font-variant-numeric:tabular-nums}.orders-table{width:100%;border-collapse:collapse}.orders-table th,.orders-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border)}.orders-table td:first-child{text-align:left}.orders-table td:not(:first-child){text-align:center}.orders-table th{font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:#0000000a;text-align:center}.order-row{cursor:pointer}.order-row .order-link{color:inherit;text-decoration:none;display:block;padding:inherit;margin:-.5rem -.25rem;padding:.5rem .25rem}.order-row .order-link:hover{color:var(--accent);text-decoration:underline}.order-type-cell{width:2.75rem;padding-left:.5rem!important;padding-right:.5rem!important}.order-type-symbol{display:inline-flex;align-items:center;justify-content:center;color:var(--muted)}.order-type-symbol-fallback{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;font-size:.75rem;font-weight:600;border-radius:999px;background:#0000000f}.order-row .order-link:hover .order-type-symbol{color:var(--accent)}.order-row:hover td{background:#0969da0f}.order-detail-row td{padding:0;background:#00000005;border-bottom:1px solid var(--border);vertical-align:top}.order-detail-page{max-width:44rem;padding:0}.order-detail-header{align-items:flex-start;margin-bottom:.75rem}.order-detail-header-main h1{margin:0}.order-detail-subtitle{margin:.15rem 0 0;font-size:.9rem;color:var(--muted)}.order-detail-header-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.75rem}.order-detail-nav{margin-bottom:1rem}.order-detail-back-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .85rem;font-size:.875rem;font-family:inherit;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;transition:border-color .15s ease,color .15s ease,background .15s ease}.order-detail-back-btn:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}.order-detail-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(7.5rem,1fr));gap:.75rem;margin-bottom:1.25rem}.order-detail-stat{display:flex;flex-direction:column;gap:.25rem;padding:.85rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.order-detail-stat-label{font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.order-detail-stat-value{display:inline-flex;align-items:center;gap:.4rem;font-size:1rem;font-weight:600;color:var(--text)}.order-detail-stat-total{font-family:JetBrains Mono,monospace;color:var(--accent)}.order-detail-stat--savings .order-detail-stat-value{color:var(--success)}.order-detail-items-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.order-detail-items-title{margin:0;padding:.85rem 1rem;font-size:.95rem;font-weight:600;border-bottom:1px solid var(--border);background:#0969da0a}.order-detail-items-table{display:flex;flex-direction:column}.order-detail-items-head,.order-detail-item-row,.order-detail-items-foot{display:grid;grid-template-columns:minmax(0,1fr) 4rem 5.5rem;gap:.75rem;align-items:center;padding:.65rem 1rem}.order-detail-items-head{font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);background:#00000005}.order-detail-items-body{max-height:min(28rem,60vh);overflow-y:auto}.order-detail-item-row{font-size:.9rem;border-bottom:1px solid rgba(0,0,0,.05)}.order-detail-item-row:last-child{border-bottom:none}.order-detail-item-name{min-width:0;word-break:break-word}.order-detail-item-qty,.order-detail-item-price,.order-detail-items-foot-total{font-family:JetBrains Mono,monospace}.order-detail-item-qty{color:var(--muted)}.order-detail-items-foot{border-top:1px solid var(--border);font-weight:600;background:#0969da0a}.order-detail-items-foot-total{grid-column:3;color:var(--accent)}.order-detail-page .num{text-align:right}.order-detail-page .back-link{display:inline-block;margin-bottom:0;color:var(--accent);text-decoration:none;font-size:.9rem}.order-detail-page .back-link:hover{text-decoration:underline}.order-detail-page .order-meta{display:flex;flex-wrap:wrap;gap:1rem;font-size:.9rem;color:var(--muted);align-items:flex-start;text-align:right}.order-detail-page .order-meta .order-savings-inline{color:var(--success);font-weight:500}.order-detail-page .order-items-section{margin-top:1.5rem}.order-detail-page .recommended-items-list{margin:0;padding:.5rem 0;background:transparent;border-top:none}.order-detail-page .recommended-items-list li{border-bottom:1px solid rgba(0,0,0,.05)}.order-detail-page .recommended-items-list li:last-child{border-bottom:none}.order-total-badge{font-weight:600;color:var(--accent)}.print-btn{padding:.4rem .9rem;font-size:.9rem;font-family:inherit;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.print-btn:hover{border-color:var(--accent);color:var(--accent)}@media print{.hamburger,.sidebar,.sidebar-backdrop,.profile-trigger,.print-btn,.back-link,.order-detail-back-btn,.order-detail-nav,.back-to-top,.modal-backdrop{display:none!important}}.recommended-order-table-wrap{overflow-x:hidden;max-width:100%}.recommended-order-items-table{width:100%;max-width:100%;border-collapse:collapse;table-layout:fixed}.recommended-order-items-table th,.recommended-order-items-table td{padding:.4rem .3rem;border-bottom:1px solid var(--border);vertical-align:middle}.recommended-order-items-table th{text-align:center;font-size:.65rem;letter-spacing:0;line-height:1.2;white-space:normal;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.recommended-order-items-table td{text-align:left;font-size:.8125rem}.recommended-order-items-table th.col-item,.recommended-order-items-table td.col-item{width:24%;max-width:24%;min-width:0}.recommended-order-items-table td.col-item{overflow:hidden}.recommended-order-items-table td.col-item .recommended-item-link{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recommended-order-items-table th.col-qty,.recommended-order-items-table td.col-qty{width:2.4rem;overflow:visible}.recommended-order-items-table th.col-category,.recommended-order-items-table td.col-category{width:5rem;overflow:hidden}.recommended-order-items-table th.col-price,.recommended-order-items-table td.col-price{width:3.25rem;overflow:visible}.recommended-order-items-table th.col-cost,.recommended-order-items-table td.col-cost{width:3.5rem;overflow:visible}.recommended-order-items-table th.col-tesco,.recommended-order-items-table td.col-tesco,.recommended-order-items-table .view-cell{width:2.25rem;overflow:visible}.recommended-order-items-table th.col-feedback,.recommended-order-items-table td.col-feedback{width:4.75rem;min-width:4.75rem;max-width:4.75rem;white-space:nowrap;text-align:center;overflow:visible}.recommended-order-items-table th.col-actions,.recommended-order-items-table td.col-actions{width:3.5rem;min-width:3.5rem;max-width:3.5rem;white-space:nowrap;text-align:center;overflow:visible}.recommended-order-items-table td.col-feedback .feedback-actions,.recommended-order-items-table td.col-actions .recommended-rejected-actions{overflow:visible}.recommended-order-items-table td.num{text-align:right;font-size:.75rem;font-variant-numeric:tabular-nums}.order-detail-page .recommended-order-items-table th.num,.order-detail-page .recommended-order-items-table th.col-price,.order-detail-page .recommended-order-items-table th.col-cost{text-align:center}.recommended-order-items-table .category-cell{max-width:none;color:var(--muted);font-size:.75rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recommended-order-items-table .view-cell{width:5%}.recommended-order-items-table .view-tesco-link{display:inline-flex;align-items:center;justify-content:center}.recommended-order-items-table .view-tesco-link svg{width:1rem;height:1rem}.recommended-order-items-table .substitute-label,.recommended-order-items-table .substitute-comment{font-size:.75rem}.recommended-order-items-table td.col-item .substitute-label,.recommended-order-items-table td.col-item .substitute-comment{display:inline;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;vertical-align:bottom}.recommended-feedback-intro{color:var(--muted);font-size:.875rem;margin:0 0 1rem;line-height:1.45}.recommended-order-detail-page{max-width:52rem;min-width:0;overflow-x:hidden}.recommended-order-detail-page .recommended-order-items-table th,.recommended-order-detail-page .recommended-order-items-table td{border-bottom-color:var(--border-subtle, #e8ecf0)}.recommended-order-detail-header{margin-bottom:0;align-items:center}.recommended-order-detail-header .order-detail-header-main{flex:1;min-width:0}.recommended-order-detail-title-row{display:flex;align-items:center;gap:.75rem}.recommended-order-detail-title-row h1{margin:0;min-width:0;flex:1;line-height:1}.recommended-order-print-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:auto;width:2.25rem;height:2.25rem;padding:0;border:none;border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer;line-height:0;transition:color .15s ease,background .15s ease}.recommended-order-print-btn:hover{color:var(--accent);background:#0969da14}.recommended-order-print-btn svg{display:block}.recommended-order-header-actions{display:inline-flex;align-items:center;gap:.35rem;flex-shrink:0}.recommended-order-header-actions .recommended-order-print-btn{margin:0}.recommended-order-filter-range{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.recommended-order-filter-input,.recommended-order-filter-select,.recommended-order-item-filter-panel .recommended-order-filter-input,.recommended-order-item-filter-panel .recommended-order-filter-select{width:100%;padding:.5rem .75rem;font:inherit;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg)}.recommended-order-filter-input:focus,.recommended-order-filter-select:focus{outline:none;border-color:var(--accent)}.recommended-order-detail-summary{margin-bottom:1rem;grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem}.recommended-order-detail-summary .order-detail-stat{padding:.6rem .5rem;min-width:0;text-align:center;align-items:center;background:var(--surface-elevated, #ffffff);border-color:var(--border-subtle, #e8ecf0)}.recommended-order-detail-summary .order-detail-stat-label{font-size:.65rem;letter-spacing:.03em}.recommended-order-detail-summary .order-detail-stat-value{font-size:.9rem}.recommended-order-toolbar{margin-bottom:1rem}.recommended-order-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;border-bottom:1px solid var(--border);margin-bottom:1rem}.recommended-order-tab{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;padding:.55rem .35rem .65rem;font-size:.8rem;font-weight:500;font-family:inherit;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--muted);cursor:pointer;border-radius:var(--radius) var(--radius) 0 0;white-space:nowrap;min-width:0}.recommended-order-tab:hover{color:var(--text);background:#00000004}.recommended-order-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.recommended-order-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.1rem;padding:.05rem .3rem;font-size:.68rem;font-weight:600;line-height:1.2;border-radius:999px;background:#00000008;color:var(--muted);flex-shrink:0}.recommended-order-tab.active .recommended-order-tab-count{background:#0969da0f;color:var(--accent)}.recommended-order-bulk-bar{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;padding:.45rem .75rem;margin-bottom:1rem;background:#0969da08;border:1px solid rgba(9,105,218,.22);border-radius:var(--radius);font-size:.875rem}.recommended-order-bulk-count{font-weight:600;color:var(--text);margin-right:auto;min-width:0}.recommended-order-bulk-actions{gap:.25rem}.recommended-order-bulk-actions button{min-width:1.75rem;min-height:1.75rem;font-size:.95rem}.recommended-order-items-table th.col-select,.recommended-order-items-table td.col-select{width:1.4rem;min-width:0;max-width:1.4rem;text-align:center;vertical-align:middle;padding:.3rem .05rem!important}.recommended-order-group-card .recommended-order-items-table th.col-select,.recommended-order-group-card .recommended-order-items-table td.col-select{padding:.35rem .1rem!important}.recommended-order-row-checkbox{width:.9rem;height:.9rem;cursor:pointer;accent-color:var(--accent);margin:0 auto;display:block}.recommended-order-row--selected td{background:#0969da0a}.recommended-order-subsection-title{margin:0;padding:.65rem 1rem;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid var(--border-subtle, #e8ecf0);background:#0969da05;color:var(--accent)}.recommended-order-toolbar .recommended-order-search{max-width:none;background:var(--surface-elevated, #ffffff);border-color:var(--border-subtle, #e8ecf0)}.recommended-order-items-section{margin-top:0}.recommended-order-group-card{background:var(--surface-elevated, #ffffff);border:1px solid var(--border-subtle, #e8ecf0);border-radius:var(--radius);overflow:hidden;margin-bottom:1rem}.recommended-order-group-card h3{margin:0;padding:.75rem 1rem;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid var(--border-subtle, #e8ecf0);background:#00000003}.recommended-order-group-card.accepted-group h3{color:var(--success, #1a7f37);background:#1a7f3708}.recommended-order-group-card.substituted-group h3{color:var(--accent);background:#0969da08}.recommended-order-group-card.recommended-pending-group h3{color:var(--text);background:#0969da05}.recommended-order-group-card.rejected-group h3{color:var(--danger, #cf222e);background:#cf222e08}.recommended-order-group-card .recommended-order-table-wrap{margin:0}.recommended-order-group-card .recommended-order-items-table th{font-size:.65rem;font-weight:600;letter-spacing:0;text-transform:none;color:var(--muted);background:#00000003}.recommended-order-group-card .recommended-order-items-table th,.recommended-order-group-card .recommended-order-items-table td{padding:.45rem .3rem}.recommended-order-group-card .recommended-order-items-table tr:last-child td{border-bottom:none}.recommended-order-search-wrap{margin-bottom:1rem}.recommended-order-search{width:100%;max-width:20rem;padding:.5rem .75rem;font-size:.9rem;font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.recommended-order-search:focus{outline:none;border-color:var(--accent)}.recommended-group{margin-bottom:1.5rem}.recommended-group h3{font-size:1rem;margin:0 0 .5rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.recommended-group.accepted-group h3{color:var(--success, #1a7f37)}.recommended-group.substituted-group h3{color:var(--accent)}.recommended-group.rejected-group h3{color:var(--danger, #cf222e)}.feedback-actions{display:inline-flex;align-items:center;justify-content:center;gap:.1rem;white-space:nowrap;line-height:1}.feedback-actions button{padding:0;margin:0;border:none;background:transparent;cursor:pointer;font-size:.75rem;min-width:1.25rem;min-height:1.25rem;line-height:1;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;transition:background .15s ease,opacity .15s ease}.feedback-actions .btn-accept{color:var(--success, #1a7f37)}.feedback-actions .btn-accept:hover{background:#1a7f371f}.feedback-actions .btn-unaccept{color:var(--muted);font-size:.95rem}.feedback-actions .btn-unaccept:hover{color:var(--text);background:#00000014}.feedback-actions .btn-reject{color:var(--danger, #cf222e)}.feedback-actions .btn-reject:hover{background:#cf222e1f}.feedback-actions .btn-substitute{color:var(--accent)}.feedback-actions .btn-substitute:hover{background:#0969da1f}.substitute-label{color:var(--muted);margin-right:.25rem}.substitute-comment{color:var(--muted);font-size:.9rem}.rejected-item-name{color:var(--text)}.recommended-rejected-actions{display:inline-flex;align-items:center;justify-content:center;gap:.1rem;white-space:nowrap;line-height:1}.recommended-rejected-view-btn,.recommended-rejected-actions .btn-unreject{display:inline-flex;align-items:center;justify-content:center;padding:0;margin:0;border:none;background:transparent;cursor:pointer;min-width:1.25rem;min-height:1.25rem;border-radius:4px;transition:background .15s ease,color .15s ease}.recommended-rejected-view-btn{color:var(--muted);line-height:0}.recommended-rejected-view-btn:hover,.recommended-rejected-view-btn[aria-pressed=true]{color:var(--accent);background:#0969da1a}.recommended-rejected-actions .btn-unreject{color:var(--muted);font-size:.95rem}.recommended-rejected-actions .btn-unreject:hover{color:var(--text);background:#00000014}.recommended-rejected-row--active{background:#0969da0a}.recommended-rejected-detail-panel .recommended-rejected-detail-comment{white-space:pre-wrap;line-height:1.45}.recommended-rejected-detail-actions{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border-subtle, #e8ecf0)}.reject-comment{color:var(--muted);font-size:.9rem;max-width:200px}.feedback-modal .modal-body label{display:block;margin-bottom:.75rem}.substitute-picker-label,.substitute-comment-label,.reject-reason-label{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.substitute-picker-label span,.substitute-comment-label span,.reject-reason-label span{font-size:.875rem;font-weight:500;color:var(--text)}.substitute-search-input{width:100%;padding:.5rem .75rem;font-size:.9rem;font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.substitute-search-input:focus{outline:none;border-color:var(--accent)}.substitute-picker-list{list-style:none;margin:0 0 .75rem;padding:0;max-height:min(16rem,40vh);overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.substitute-picker-list li{margin:0;border-bottom:1px solid rgba(0,0,0,.05)}.substitute-picker-list li:last-child{border-bottom:none}.substitute-picker-option{display:block;width:100%;padding:.55rem .75rem;border:none;background:transparent;text-align:left;font:inherit;font-size:.9rem;color:var(--text);cursor:pointer}.substitute-picker-option:hover{background:#0969da0f}.substitute-picker-option.selected{background:#0969da1f;color:var(--accent);font-weight:600}.substitute-picker-empty,.substitute-picker-hint{margin:0 0 .75rem;font-size:.85rem;color:var(--muted)}.feedback-modal .substitute-select,.feedback-modal .reject-reason-select{min-width:280px;padding:.4rem .5rem}.feedback-modal .reject-reason-select{width:100%;max-width:none;font:inherit;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.feedback-modal .substitute-comment-input{width:100%;max-width:none;padding:.5rem .75rem;font-size:.9rem;font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.feedback-modal .modal-actions{display:flex;gap:.5rem;margin-top:1rem}.order-detail-page .order-items-section h2{font-size:1rem;font-weight:600;margin-bottom:.75rem;color:var(--muted)}.order-detail-page .order-items-list{max-height:none;padding:0}.settings-page{max-width:42rem}.settings-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border)}.settings-tab{padding:.5rem 1rem;font-size:.95rem;font-family:inherit;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--muted);cursor:pointer}.settings-tab:hover{color:var(--text)}.settings-tab.active{color:var(--accent);font-weight:500;border-bottom-color:var(--accent)}.settings-status{font-size:.9rem;color:var(--success, #2da44e);margin-bottom:.75rem}.settings-cred-form{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.settings-cred-form label{display:flex;flex-direction:column;gap:.35rem}.settings-label{font-size:.9rem;font-weight:500}.settings-hint{font-size:.8rem;color:var(--muted)}.cooking-tips-page{padding:1.5rem 0}.cooking-tips-header-row{margin-bottom:.5rem}.cooking-tips-tab-bar{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:.75rem 1rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem}.cooking-tips-tabs-strip{display:flex;gap:0}.cooking-tips-tab{padding:.65rem 1.1rem .75rem;font-size:.95rem;font-weight:500;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--muted);cursor:pointer;border-radius:var(--radius) var(--radius) 0 0}.cooking-tips-tab:hover{color:var(--text);background:#00000008}.cooking-tips-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.cooking-tips-tab-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-bottom:.35rem}.cooking-tips-qty-section-label{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--muted)}.cooking-tips-qty-section-select{padding:.35rem .5rem;font-size:.85rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);max-width:min(280px,70vw)}.cooking-tips-modal-form select.cooking-tips-qty-section-select--modal{width:100%;max-width:none;padding:.5rem .75rem;font-size:.9rem;font-family:inherit;cursor:pointer;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text)}.cooking-tips-page .btn-primary,.cooking-tips-modal .btn-primary{padding:.45rem 1rem;font-size:.9rem;font-weight:600;color:#fff;background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer}.cooking-tips-page .btn-primary:hover:not(:disabled),.cooking-tips-modal .btn-primary:hover:not(:disabled){filter:brightness(1.06)}.cooking-tips-page .btn-primary:disabled,.cooking-tips-modal .btn-primary:disabled{opacity:.45;cursor:not-allowed}.cooking-tips-qty-loading{color:var(--muted);margin:0 0 1rem}.cooking-tips-qty-filters{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.5rem 1rem;margin-bottom:1rem}.cooking-tips-tips-filters{justify-content:flex-end;align-items:center}.cooking-tips-qty-no-match{margin:0 0 1rem;padding:.75rem 1rem;color:var(--muted);font-style:italic;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.cooking-tips-modal-form .cooking-tips-modal-label{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem;font-size:.85rem;font-weight:500;color:var(--text)}.cooking-tips-modal .modal-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.quantity-table-wrap{overflow-x:auto;max-width:100%}.quantity-table-actions-col{width:7rem;text-align:right}.quantity-table-actions{text-align:right;white-space:nowrap}.quantity-table-actions .recipe-actions-btns{justify-content:flex-end}.quantity-table-empty{color:var(--muted);font-style:italic;padding:.75rem!important}.cooking-tips-item-actions{margin-left:auto;display:flex;align-items:center;gap:.35rem}.cooking-tips-page .link-btn{padding:.2rem .45rem;font-size:.85rem;background:transparent;border:none;color:var(--accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.cooking-tips-page .link-btn:hover{filter:brightness(.95)}.cooking-tips-page .link-btn.danger{color:#b42318}.cooking-tips-item-meta{justify-content:flex-start}.cooking-tips-item-meta .cooking-tips-item-actions{margin-left:auto}.cooking-tips-quantities{display:flex;flex-direction:column;gap:2rem}.quantity-section h3{font-size:1rem;font-weight:600;margin:0 0 .75rem;color:var(--text)}.quantity-table{width:100%;max-width:420px;border-collapse:collapse;font-size:.9rem}.quantity-table th,.quantity-table td{padding:.4rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.quantity-table th{font-weight:600;color:var(--muted)}.quantity-table tbody tr:hover{background:var(--bg)}.cooking-tips-page.loading{padding:3rem;text-align:center;color:var(--muted)}.cooking-tips-filters{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-bottom:1rem}.cooking-tips-search{min-width:160px;padding:.5rem .75rem;font-size:.95rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.cooking-tips-search.cooking-tips-search--compact{flex:0 1 280px;max-width:min(280px,100%)}.cooking-tips-tag-filter{padding:.5rem .75rem;font-size:.9rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.cooking-tips-add-form{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.cooking-tips-text-input{padding:.5rem .75rem;font-size:.95rem;font-family:inherit;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);resize:vertical}.cooking-tips-tags-input{padding:.5rem .75rem;font-size:.9rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.cooking-tips-list{list-style:none;margin:0;padding:0}.cooking-tips-item{padding:1rem;margin-bottom:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.cooking-tips-item-text{margin:0 0 .5rem;line-height:1.5;color:var(--text)}.cooking-tips-item-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.cooking-tips-item-meta .recipe-tag{margin-right:0}.cooking-tips-empty{padding:2rem;text-align:center;color:var(--muted);font-style:italic}.settings-page.loading{padding:3rem;text-align:center;color:var(--muted)}.settings-error{color:#cf222e;margin-bottom:1rem}.settings-section{margin-bottom:2rem}.settings-section h2{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.settings-desc{font-size:.9rem;color:var(--muted);margin-bottom:1rem}.settings-alias-form{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-bottom:1rem}.settings-input{flex:1;min-width:140px;padding:.5rem .75rem;font-size:.9rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.settings-arrow{color:var(--muted);font-size:.85rem}.settings-alias-list{list-style:none;margin:0;padding:0}.settings-alias-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.settings-alias-item:last-child{border-bottom:none}.settings-alias-orig{font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--muted);max-width:200px;overflow:hidden;text-overflow:ellipsis}.settings-alias-disp{flex:1;min-width:0}.settings-delete{flex-shrink:0}.settings-alias-empty{color:var(--muted);font-style:italic;padding:.5rem 0}.settings-textarea{min-height:8em;resize:vertical}.settings-input-narrow{max-width:6rem}.settings-rules-row{display:flex;gap:1.5rem;margin-bottom:1rem}.settings-rules-row .settings-hint{display:block;margin-top:.35rem}.settings-mappings-block{margin-bottom:1rem}.settings-mappings-block .settings-label{display:block;margin-bottom:.5rem}.settings-mappings-add{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-bottom:.75rem}.settings-ingredient-rules-form label{display:block;margin-bottom:1rem}.settings-ingredient-rules-form textarea{width:100%;max-width:100%;box-sizing:border-box}.settings-ingredient-rules-form .settings-label{display:block;margin-bottom:.35rem}.expand-cell{width:2rem;color:var(--muted);font-size:.75rem}.orders-table .view-cell{white-space:nowrap;text-align:right}.orders-table .view-btn{display:inline-block;padding:.35rem .6rem;font-size:.85rem;font-family:inherit;font-weight:500;color:var(--accent);background:transparent;border:1px solid rgba(9,105,218,.4);border-radius:var(--radius);text-decoration:none;cursor:pointer;transition:background .15s,border-color .15s}.orders-table .view-btn:hover{background:#0969da14;border-color:var(--accent)}.orders-table a.view-btn:hover{color:var(--accent)}.order-items-list{padding:1rem 1.5rem;max-height:300px;overflow-y:auto}.order-item-line{display:flex;gap:1rem;padding:.25rem 0;font-size:.9rem;border-bottom:1px solid rgba(0,0,0,.05)}.order-item-line:last-child{border-bottom:none}.order-item-line .item-name{flex:1}.order-item-line .item-qty{font-family:JetBrains Mono,monospace;color:var(--muted)}.order-item-line .item-price{font-family:JetBrains Mono,monospace;min-width:4rem}.order-savings{margin-top:.5rem;padding-top:.5rem;font-weight:500;color:var(--success)}.orders-count{font-size:.9rem;color:var(--muted);margin:0}.items-chart-toggle-btn{padding:.5rem 1rem;font-size:.9rem;font-family:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.items-chart-toggle-btn:hover{border-color:var(--accent);color:var(--accent)}.items-chart-toggle-btn--active{color:var(--accent);border-color:#0969da59;background:#0969da14}.items-page-toolbar .items-toolbar-icon-btn{width:44px;height:44px;border:none;background:transparent;box-shadow:none;outline:none;color:var(--text)}.items-page-toolbar .items-toolbar-icon-btn svg{width:28px;height:28px}.items-page-toolbar .items-toolbar-icon-btn:hover:not(:disabled){background:#0969da14;color:var(--accent);filter:none}.items-page-toolbar .items-toolbar-icon-btn.items-chart-toggle-btn--active{color:var(--accent);background:#0969da14;border:none}.items-page-toolbar .items-bulk-toolbar .items-toolbar-icon-btn.items-filter-btn,.items-page-toolbar .items-toolbar-icon-btn.items-filter-btn,.items-page-toolbar .items-toolbar-icon-btn.items-refresh-btn,.items-page-toolbar .items-toolbar-icon-btn.items-scrape-missing-btn,.items-page-toolbar .items-toolbar-icon-btn.items-scrape-stop-btn,.items-page-toolbar .items-toolbar-icon-btn.items-scrape-restart-btn,.items-page-toolbar .items-toolbar-icon-btn.items-chart-toggle-btn,.items-page-toolbar .items-toolbar-icon-btn.items-bulk-clear-btn,.items-page-toolbar .items-toolbar-icon-btn.open-in-tabs-btn{border:none;background:transparent;color:var(--text)}.items-toolbar-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;flex-shrink:0;line-height:0;-webkit-tap-highlight-color:transparent}.items-toolbar-icon-btn svg{display:block}.items-toolbar-icon-spin{animation:items-toolbar-spin .8s linear infinite}@keyframes items-toolbar-spin{to{transform:rotate(360deg)}}.items-page .page-header{flex-wrap:nowrap;align-items:center;gap:.75rem}.items-page .page-header h1{flex-shrink:0}.items-page-toolbar{flex-wrap:nowrap;gap:.125rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;justify-content:flex-end}.items-page-toolbar::-webkit-scrollbar{display:none}.items-page .page-header .toolbar{flex-wrap:nowrap}.items-filter-btn{padding:.5rem 1rem;font-size:.9rem;font-family:inherit;background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer}.items-filter-btn:hover{filter:brightness(1.08)}.items-scrape-missing-btn{padding:.5rem 1rem;font-size:.9rem;font-family:inherit;font-weight:600;background:#1a7f371f;color:var(--text, #1f2328);border:1px solid rgba(26,127,55,.5);border-radius:var(--radius);cursor:pointer}.items-scrape-missing-btn:hover:not(:disabled){filter:brightness(1.05);border-color:#1a7f37bf}.items-scrape-missing-btn:disabled{opacity:.55;cursor:not-allowed}.items-scrape-stop-btn,.items-scrape-restart-btn{padding:.5rem .85rem;font-size:.875rem;font-family:inherit;background:var(--bg, #fff);color:var(--text, #1f2328);border:1px solid var(--border, #d1d9e0);border-radius:var(--radius);cursor:pointer}.items-scrape-stop-btn:hover:not(:disabled),.items-scrape-restart-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.items-scrape-stop-btn:disabled,.items-scrape-restart-btn:disabled{opacity:.5;cursor:not-allowed}.items-refresh-btn{padding:.5rem 1rem;font-size:.9rem;font-family:inherit;background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer}.items-refresh-btn:hover:not(:disabled){filter:brightness(1.08)}.items-refresh-btn:disabled{opacity:.6;cursor:not-allowed}.items-bulk-toolbar{display:flex;flex-wrap:nowrap;align-items:center;gap:.25rem .35rem;padding:.25rem .35rem;margin-right:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;flex-shrink:0}.items-bulk-count{font-weight:600;color:var(--text)}.items-bulk-label{display:inline-flex;align-items:center;gap:.35rem;font-size:.875rem}.items-bulk-status-select{font:inherit;font-size:.85rem;padding:.25rem .4rem;border-radius:6px;border:1px solid var(--border);background:var(--bg)}.items-bulk-clear-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer}.items-bulk-clear-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.items-quick-picks{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.items-filters-modal .items-quick-picks{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.quick-pick-btn{padding:.35rem .75rem;font-size:.8rem;font-family:inherit;color:#fff;background:var(--accent);border:1px solid var(--accent);border-radius:999px;cursor:pointer}.quick-pick-btn:hover{filter:brightness(1.08)}.items-filter-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.filter-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .5rem;font-size:.8rem;background:var(--surface);border:1px solid var(--border);border-radius:999px}.filter-chip-clear{display:inline-flex;align-items:center;justify-content:center;width:1.1rem;height:1.1rem;padding:0;font-size:1rem;line-height:1;color:var(--muted);background:none;border:none;border-radius:50%;cursor:pointer}.filter-chip-clear:hover{color:var(--text);background:#0000000f}.items-filters-modal-body.items-filters{flex-direction:column;align-items:stretch;gap:1rem;padding:0;border:none}.items-filters-modal-body .filter-group{flex-direction:column;align-items:flex-start;gap:.25rem}.items-filters-modal-body .filter-inputs-row{display:flex;flex-direction:row;gap:.5rem}.items-filters{display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.5rem;padding:.75rem 0;margin-bottom:.25rem;border-bottom:1px solid var(--border)}.items-filters .filter-group{display:flex;align-items:center;gap:.5rem}.items-filters .filter-label{font-size:.875rem;color:var(--muted);white-space:nowrap}.items-filters .filter-input,.items-filters .filter-select{padding:.4rem .6rem;font-size:.875rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.items-filters .filter-input:focus,.items-filters .filter-select:focus{outline:none;border-color:var(--accent)}.items-filters .filter-number{width:5rem}.items-filters .filter-date{width:9rem}.pagination-bar{display:flex;align-items:center;flex-wrap:nowrap;gap:.5rem .75rem;padding:.5rem 0;margin-bottom:.5rem;font-size:.9rem;color:var(--muted);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.pagination-bar::-webkit-scrollbar{display:none}.pagination-info{flex:0 1 auto;min-width:0;white-space:nowrap}.pagination-controls{display:flex;align-items:center;flex-shrink:0;gap:.5rem;margin-left:auto}.pagination-rows-label{display:flex;align-items:center;flex-shrink:0;gap:.35rem;font-size:.875rem;color:var(--muted);white-space:nowrap}.items-page .pagination-btn{padding:.35rem .75rem;font-size:.875rem;font-family:inherit;background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer}.items-page .pagination-btn:hover:not(:disabled){filter:brightness(1.08);color:#fff;border-color:var(--accent);background:var(--accent)}.items-page .pagination-btn--icon{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;line-height:0}.items-page .pagination-btn--icon svg{display:block}.pagination-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-page{font-weight:500;white-space:nowrap}.pagination-rows-select{padding:.35rem .5rem;font-size:.875rem;font-family:inherit;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text)}.pagination-bar--bottom{margin-top:.5rem;margin-bottom:0}.items-not-relevant-section{margin-top:1.25rem;border:1px solid var(--border);border-radius:var(--radius);background:#00000005;overflow:hidden}.items-not-relevant-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.65rem 1rem;font:inherit;font-size:.9rem;font-weight:600;color:var(--muted);text-align:left;background:#00000008;border:none;cursor:pointer}.items-not-relevant-toggle:hover{background:#0000000f;color:var(--text)}.items-not-relevant-toggle-label{display:inline-flex;align-items:baseline;gap:.25rem}.items-not-relevant-count{font-weight:500;color:var(--muted)}.items-not-relevant-chevron{flex-shrink:0;font-size:.7rem;opacity:.75}.items-not-relevant-table-wrap{margin:0;border:none;border-radius:0;border-top:1px solid var(--border)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;min-width:640px;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}th{font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:#0000000a;text-align:center}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{color:var(--text)}.sort-arrow{margin-left:.25em;color:var(--accent)}.items-table-wrap th.sortable .items-table-sortable-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.25em;max-width:7.25rem;margin:0 auto;vertical-align:middle;line-height:1.25;white-space:normal}.items-table-wrap th.sortable .items-table-th-label{text-align:center;white-space:normal;overflow-wrap:break-word;word-break:normal;-webkit-hyphens:manual;hyphens:manual}.items-table-wrap .items-th-label-stack{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.06em;line-height:1.15;word-break:normal;overflow-wrap:normal}.items-table-wrap .items-th-label-stack>span{display:block;white-space:nowrap}.items-table-wrap th.col-avg-qty .items-table-sortable-inner,.items-table-wrap th.col-min-qty .items-table-sortable-inner,.items-table-wrap th.col-max-qty .items-table-sortable-inner{max-width:none}.items-table-wrap th.col-avg-qty{min-width:4.25rem}.items-table-wrap th.col-min-qty,.items-table-wrap th.col-max-qty{min-width:3.35rem}.items-table-wrap th.sortable .items-table-sort-arrow-slot{display:inline-block;width:1em;min-width:1em;flex-shrink:0;text-align:center;font-size:.72rem;line-height:1;font-weight:700;color:var(--accent)}tr:last-child td{border-bottom:none}tr:hover td{background:#0969da0f}td:not(:first-child){text-align:center}td.name{font-weight:500}.items-page .items-table-wrap td.name{text-align:left}.items-list-item-text{display:flex;flex-direction:column;gap:.12rem;min-width:0}.items-list-item-category{font-size:.75rem;color:var(--muted);line-height:1.2}.items-page .items-table-wrap td.name .product-link{font-weight:500;line-height:1.3;word-break:break-word}td.num{font-family:JetBrains Mono,monospace;font-size:.9rem}.link{color:var(--accent);text-decoration:none;font-weight:500}.link:hover{text-decoration:underline}.items-table-wrap th{white-space:normal;overflow-wrap:break-word;word-break:normal;vertical-align:middle;-webkit-hyphens:manual;hyphens:manual;line-height:1.25;padding-top:.5rem;padding-bottom:.5rem}.items-page .items-table-wrap th,.items-page .items-table-wrap td{padding:.35rem .2rem}.items-page .items-table-wrap td.name,.items-page .items-table-wrap th.name,.items-page .items-table-wrap td.items-name-cell{padding-right:.1rem}.items-page .items-table-wrap .items-col-detail{padding-left:.12rem;padding-right:.12rem}.items-name-actions-row{display:flex;align-items:center;gap:.25rem;min-width:0}.items-name-actions-slot{display:none;flex-shrink:0}.items-page .items-table-wrap .items-list-item-text{flex:1;min-width:0}.items-table-wrap .items-table{min-width:1060px}.items-table-wrap .category-cell{min-width:95px;overflow:visible}.items-table-wrap th.col-times-ordered{min-width:7.5rem}.items-table-wrap th.col-avg-days{min-width:10rem}.items-table-wrap th.col-avg-price{min-width:6.5rem}.items-table-wrap .items-thumb-col{width:3.75rem;min-width:3.75rem;text-align:center;font-size:.75rem;font-weight:600;color:var(--muted);white-space:nowrap}.items-page .items-table-wrap .items-thumb-col{width:3.75rem;min-width:3.75rem}.items-page .items-table-wrap th.items-select-col,.items-page .items-table-wrap td.items-select-cell{width:2.15rem;min-width:2.15rem;max-width:2.25rem;text-align:center;vertical-align:middle;padding-left:.08rem!important;padding-right:.08rem!important}.items-row-checkbox{width:1rem;height:1rem;cursor:pointer;accent-color:var(--accent)}.items-table-wrap th.col-item-status,.items-table-wrap td.items-status-cell{min-width:7.5rem;text-align:center;vertical-align:middle}.items-status-select{font:inherit;font-size:.8125rem;max-width:10rem;padding:.2rem .35rem;border-radius:6px;border:1px solid var(--border);background:var(--bg)}.items-page .items-table-wrap .items-thumb-cell{vertical-align:middle;text-align:center;padding:.12rem .1rem .12rem .06rem!important}.items-table-wrap .items-thumb-cell .product-hover-trigger{display:inline-block;vertical-align:middle;line-height:0}.items-table-wrap .scraped-cell{text-align:center;min-width:2.5rem}.items-table-wrap th.scraped-cell{min-width:9rem;max-width:10rem}.items-table-wrap .scraped-icon{font-size:1.1rem;font-weight:600}.items-table-wrap .scraped-icon.scraped-ok{color:#1a7f37}.items-table-wrap .scraped-icon.scraped-pending{color:#cf222e}.items-table-wrap .scraped-icon.scraped-failed{color:#9a6700}.items-table-wrap .scraped-icon.scraped-no-id{color:#6e7681}.items-scrape-progress-banner{display:flex;align-items:center;flex-wrap:wrap;gap:.65rem 1rem;margin:0 0 1rem;padding:.65rem 1rem;border-radius:8px;border:1px solid rgba(154,103,0,.35);background:linear-gradient(135deg,#fff8dcf2,#ffebc8e6);color:var(--fg, #1f2328);font-size:.9375rem;box-shadow:0 1px 3px #0000000f}.items-scrape-progress-banner--stale{border-color:#6e768159;background:linear-gradient(135deg,#f6f8fafa,#e6e8ebf2)}.items-scrape-progress-banner--error{border-color:#cf222e59;background:#ffebe9f2;font-size:.875rem}.items-scrape-progress-banner--warn{border-color:#9a670066;background:#fffbe6f2;font-size:.875rem}.items-scrape-progress-errdetail{opacity:.9;font-weight:500}.items-scrape-progress-pulse{width:10px;height:10px;border-radius:50%;background:#9a6700;flex-shrink:0;animation:items-scrape-progress-blink 1.1s ease-in-out infinite}@keyframes items-scrape-progress-blink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.92)}}.items-scrape-progress-body{display:flex;flex-direction:column;gap:.15rem;min-width:0}.items-scrape-progress-label{font-weight:700;font-size:.8rem;letter-spacing:.02em;text-transform:uppercase;color:var(--muted, #656d76)}.items-scrape-progress-name{font-weight:600;line-height:1.25;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.items-scrape-progress-meta{margin-left:auto;font-size:.8125rem;color:var(--muted, #656d76);display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;text-align:right;white-space:nowrap}.items-scrape-progress-meta-line{display:block}@media (max-width: 640px){.items-scrape-progress-meta{margin-left:0;width:100%;align-items:flex-start;text-align:left;white-space:normal}}.items-table-wrap td.category-cell{white-space:normal;overflow-wrap:break-word;word-break:break-word;max-width:200px;overflow:visible;text-overflow:clip}.items-table-wrap td.col-first-ordered,.items-table-wrap td.col-last-ordered{white-space:nowrap}.items-page .items-table-wrap th.actions-cell{position:static;right:auto;z-index:auto;width:1%;min-width:0;padding-left:0;padding-right:0;box-shadow:none}.items-page .items-table-wrap td.actions-cell{width:1%;min-width:0;padding-left:0;padding-right:0;text-align:center;vertical-align:middle}.items-page .items-table-wrap th.items-more-col,.items-page .items-table-wrap td.items-more-cell{width:1.75rem;min-width:1.75rem;max-width:1.75rem;text-align:center;vertical-align:middle;padding-left:.05rem;padding-right:.1rem}.items-table-wrap th.actions-cell{position:static;right:auto;z-index:auto;width:1%;min-width:0;padding-left:.15rem;padding-right:.1rem;box-shadow:none}.items-table-wrap td.actions-cell{width:1%;min-width:0;padding-left:.15rem;padding-right:.1rem;text-align:center;vertical-align:middle}.items-table-wrap th.items-more-col,.items-table-wrap td.items-more-cell{width:1.75rem;min-width:1.75rem;max-width:1.75rem;text-align:center;vertical-align:middle;padding-left:.1rem;padding-right:.15rem}.items-more-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;-webkit-tap-highlight-color:transparent}.items-more-btn:hover{color:var(--accent);background:#0969da14}.items-detail-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#00000059}.items-detail-panel{position:fixed;top:0;right:0;bottom:0;z-index:1101;width:min(360px,92vw);background:var(--surface);border-left:1px solid var(--border);box-shadow:-8px 0 32px #0000001f;display:flex;flex-direction:column;animation:items-detail-panel-in .22s ease-out;overflow:hidden;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}@keyframes items-detail-panel-in{0%{transform:translate(100%)}to{transform:translate(0)}}.items-detail-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:1rem;border-bottom:1px solid var(--border);background:var(--surface)}.items-detail-panel-header h2{margin:0;font-size:1.05rem;line-height:1.35;font-weight:600}.items-detail-panel-close{flex-shrink:0;width:36px;height:36px;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:1.35rem;line-height:1;cursor:pointer}.items-detail-panel-close:hover{border-color:var(--accent);color:var(--accent)}.items-detail-panel-body{overflow-y:auto;padding:1rem;flex:1}.items-detail-panel-fields{display:grid;gap:.85rem;margin:0}.items-detail-panel-fields>div{margin:0}.items-detail-panel-fields dt{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0}.items-detail-panel-fields dd{margin:.15rem 0 0;font-size:.95rem}.items-detail-panel-fields .items-status-select{width:100%;max-width:16rem}.actions-buttons{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap}.items-table-wrap .actions-buttons{gap:0;margin-left:0}.items-page .items-table-wrap .actions-buttons{margin-left:0}.items-table-wrap .actions-buttons a,.items-table-wrap .actions-buttons button{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:4px;background:transparent;line-height:0;-webkit-tap-highlight-color:transparent}.items-table-wrap .actions-buttons a:hover,.items-table-wrap .actions-buttons button:hover{background:#0969da14;color:var(--accent);text-decoration:none}.items-table-wrap .actions-buttons .items-more-btn:hover{color:var(--accent);background:#0969da14}.items-table-wrap .actions-buttons .delete-btn:hover{background:#cf222e14;color:#cf222e}.view-tesco-link{display:inline-flex;align-items:center;gap:.35rem}.items-table-wrap th.category-cell,.items-table-wrap th.col-item-status,.items-table-wrap th.scraped-cell,.items-table-wrap th.actions-cell{background:#0000000a;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);overflow:visible;text-overflow:clip}.items-table-wrap th.category-cell{max-width:5.5rem}.items-table-wrap th.actions-cell{max-width:none}.view-in-app-btn{display:inline-block;padding:.35rem .6rem;font-size:.8rem;color:var(--accent);text-decoration:none;border:1px solid rgba(9,105,218,.4);border-radius:var(--radius)}.view-in-app-btn:hover{background:#0969da14}.view-in-app-btn--icon{display:inline-flex;align-items:center;justify-content:center;padding:.35rem;line-height:0}.items-row-clickable{cursor:pointer}.delete-btn{padding:.35rem .6rem;font-size:.8rem;font-family:inherit;color:#cf222e;background:transparent;border:1px solid rgba(207,34,46,.5);border-radius:var(--radius);cursor:pointer}.delete-btn:hover{background:#cf222e14}.delete-btn-icon{padding:.35rem;display:inline-flex;align-items:center;justify-content:center;border:none}.delete-btn-icon svg{display:block}.detail-row td{padding:.5rem 1rem;background:#00000008;border-top:none;font-size:.875rem;color:var(--muted)}.product-detail section{margin-bottom:.5rem}.product-detail section:last-child{margin-bottom:0}.product-link{color:inherit;text-decoration:none}.product-link:hover{color:var(--accent);text-decoration:underline}.product-page{padding:0}.product-page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.product-page-header-right{display:flex;align-items:center;gap:.75rem}.product-page .back-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.5rem 1rem;border-radius:var(--radius);cursor:pointer;font-family:inherit;margin-bottom:0}.product-header{display:flex;gap:2rem;margin-bottom:1rem}.product-top-panels{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.product-top-panels .product-panel{flex:1;min-width:180px;margin-bottom:0}.product-image{width:150px;height:150px;object-fit:contain;background:var(--surface);border-radius:var(--radius)}.product-page .back-btn:hover{border-color:var(--accent)}.product-meta{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;color:var(--muted);font-size:.9rem}.product-meta-row{display:flex;flex-wrap:wrap;gap:1rem}.product-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.5rem;margin-bottom:1rem}.product-section h3{margin:0 0 .5rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.product-section p{margin:0;line-height:1.5}.dietary-badges{display:flex;flex-wrap:wrap;gap:.5rem}.dietary-badge{display:inline-block;padding:.25rem .6rem;font-size:.85rem;font-weight:500;background:#1a7f3726;color:#1a7f37;border-radius:4px}.nutrition-summary{margin-bottom:1rem!important}.product-section .nutrition-serving-label{font-weight:600;margin:2rem 0 .5rem;font-size:.95rem}.nutrition-summary-table{width:100%;margin-bottom:1.5rem;border-collapse:collapse}.nutrition-summary-table th,.nutrition-summary-table td{padding:.5rem 1rem;text-align:left;border-bottom:1px solid var(--border);font-size:.9rem}.nutrition-summary-table th{font-weight:600;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.product-section .nutrition-table{width:auto;min-width:240px;margin-top:.5rem}.product-section .nutrition-table td{padding:.35rem 1rem .35rem 0;border-bottom:none;font-size:.9rem}.product-section .nutrition-table th{font-size:.75rem;text-transform:none;padding:.5rem 1rem .5rem 0}.product-section .nutrition-table td:first-child{color:var(--muted)}.nutrition-ref{font-size:.8rem;color:var(--muted);margin-top:.5rem!important}.category-hierarchy{margin:0;padding-left:1.25rem;list-style:none}.category-hierarchy li{position:relative;padding:.2rem 0;line-height:1.4}.category-hierarchy li:before{content:"›";position:absolute;left:-1rem;color:var(--accent)}.category-hierarchy li+li{margin-top:.15rem}.brand-details p{margin:0 0 .25rem;line-height:1.5}.brand-details p:last-child{margin-bottom:0}.raw-data-btn{display:block;width:100%;text-align:left;padding:.6rem 1rem;margin-top:.5rem;font-family:inherit;font-size:.9rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text);transition:border-color .15s,background .15s}.raw-data-btn:hover{border-color:var(--accent);background:#0969da0f}.raw-section .raw-json .raw-data-btn:first-child{margin-top:0}.raw-data-modal{max-width:min(90vw,800px);width:100%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.raw-data-modal .modal-body-scroll{overflow-y:auto;overflow-x:auto;flex:1;min-height:0;padding:0}.raw-data-modal .raw-data-pre{margin:0;padding:1rem 1.25rem;font-family:JetBrains Mono,monospace;font-size:.8rem;line-height:1.5;background:#00000008;white-space:pre-wrap;word-break:break-word;-moz-tab-size:2;tab-size:2}td.breadcrumbs{font-size:.8rem;max-width:200px;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.app{padding:1rem}header h1{font-size:1.5rem}.toolbar{flex-wrap:wrap;gap:.75rem}.page-header{flex-direction:column;align-items:stretch}.items-page .page-header{flex-direction:row;align-items:center}.items-page .page-header h1{font-size:1.35rem}.page-header .toolbar{justify-content:stretch}.items-page .pagination-bar{gap:.35rem .5rem;font-size:.8rem}.items-page .pagination-rows-label,.items-page .pagination-rows-select,.items-page .pagination-btn,.items-page .pagination-page{font-size:.8rem}.items-page .pagination-btn{padding:.3rem .5rem}.items-page .pagination-btn--icon{width:1.75rem;height:1.75rem;padding:0}.items-page .pagination-rows-select{padding:.25rem .35rem}.search{max-width:none;flex:1 1 100%;min-width:0}.add-order-url-input{min-width:100%}.add-order-row{flex-direction:column;align-items:stretch}.add-order-row label{display:block}.product-top-panels{flex-direction:column}.product-top-panels .product-panel{min-width:100%}.product-header{flex-direction:column;gap:1rem}.product-image{width:120px;height:120px}th,td{padding:.5rem .75rem;font-size:.875rem}.nutrition-summary-table,.product-section .nutrition-table{display:block;overflow-x:auto}}@media (max-width: 768px){.recommended-order-items-table .col-price,.recommended-order-items-table .col-tesco{display:none}}@media (max-width: 640px){.order-detail-page{max-width:none}.order-detail-header{flex-direction:column;align-items:stretch;gap:.75rem}.order-detail-header-actions{justify-content:flex-start}.order-detail-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.order-detail-items-head,.order-detail-item-row,.order-detail-items-foot{grid-template-columns:minmax(0,1fr) 3.25rem 4.75rem;gap:.5rem;padding-left:.75rem;padding-right:.75rem}.order-detail-page .page-header{flex-direction:column;align-items:stretch;gap:.75rem}.order-detail-page .page-header-left{gap:.25rem}.order-detail-page .order-meta{flex-direction:column;align-items:flex-start;gap:.5rem;text-align:left}.order-detail-page .order-meta .print-btn{align-self:flex-start}.recommended-feedback-intro{font-size:.85rem;margin:0 0 .85rem}.recommended-order-tab{flex-direction:column;gap:.15rem;padding:.45rem .2rem .5rem;font-size:.68rem;white-space:normal;text-align:center;line-height:1.15}.recommended-order-tab-count{font-size:.62rem;min-width:1rem;padding:.05rem .25rem}.recommended-order-bulk-bar{gap:.35rem;padding:.4rem .55rem;font-size:.8rem}.recommended-order-bulk-count{flex:1 1 100%;margin-right:0;font-size:.78rem}.recommended-order-detail-summary{grid-template-columns:repeat(4,minmax(0,1fr));gap:.4rem}.recommended-order-detail-summary .order-detail-stat{padding:.5rem .35rem}.recommended-order-detail-summary .order-detail-stat-label{font-size:.6rem}.recommended-order-detail-summary .order-detail-stat-value{font-size:.85rem}.recommended-order-group-card h3{padding:.65rem .85rem}.recommended-order-group-card .recommended-order-items-table th,.recommended-order-group-card .recommended-order-items-table td{padding:.35rem .2rem}.recommended-order-table-wrap{overflow-x:hidden;margin-left:0;margin-right:0;padding-left:0;padding-right:0}.recommended-order-items-table{min-width:0;width:100%}.recommended-order-items-table th,.recommended-order-items-table td{padding:.35rem .2rem;font-size:.75rem}.recommended-order-items-table th{font-size:.6rem}.recommended-item-link{word-break:break-word}.order-detail-page .recommended-group{margin-bottom:1.25rem}.feedback-modal .substitute-select,.feedback-modal .reject-reason-select{min-width:0;width:100%}.feedback-modal .substitute-comment-input{max-width:none}.feedback-modal .modal-actions{flex-direction:column}.feedback-modal .modal-actions button{width:100%;padding:.6rem 1rem}}.upcoming-orders-page{padding:0 .5rem 2rem;max-width:1100px;margin:0 auto}.upcoming-toolbar-icons{display:flex;align-items:center;gap:.5rem;flex-direction:row}.upcoming-toolbar-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--accent);cursor:pointer}.upcoming-toolbar-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.upcoming-orders-page .btn,.upcoming-orders-page .btn-primary,.upcoming-orders-page .btn-secondary{padding:.5rem 1rem;font-size:.9rem;font-family:inherit;background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer}.upcoming-orders-page .btn:hover:not(:disabled),.upcoming-orders-page .btn-primary:hover:not(:disabled),.upcoming-orders-page .btn-secondary:hover:not(:disabled){filter:brightness(1.08)}.upcoming-orders-page .modal .btn:hover:not(:disabled){filter:brightness(1.08)}.upcoming-orders-page.loading,.upcoming-orders-page.error{padding:2rem}.upcoming-page-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.upcoming-page-header-main h1{margin:0 0 .25rem;font-size:1.5rem;font-weight:600}.upcoming-page-subtitle{margin:0;font-size:.95rem;color:var(--muted)}.upcoming-page-header-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.upcoming-page-header-actions .btn-execute{font-weight:600}.upcoming-orders-layout{display:flex;flex-direction:column;gap:1.5rem}.upcoming-orders-sidebar{flex:0 0 220px;border-right:1px solid var(--border);padding-right:1rem}.upcoming-orders-sidebar h3{font-size:.95rem;margin:0 0 .75rem;color:var(--muted)}.upcoming-orders-list{list-style:none;margin:0;padding:0}.upcoming-orders-list li{margin:.25rem 0}.upcoming-orders-list a{display:block;padding:.5rem .75rem;border-radius:var(--radius);color:var(--text);text-decoration:none}.upcoming-orders-list a:hover{background:#0000000a}.upcoming-orders-list a.active{color:var(--accent);background:#0969da14}.upcoming-orders-list .item-count{color:var(--muted);font-size:.85rem}.upcoming-orders-sidebar .btn{margin-top:.75rem;display:block;width:100%}.upcoming-orders-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1rem}.upcoming-empty-state{padding:3rem 2rem;text-align:center;color:var(--muted)}.upcoming-add-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.upcoming-add-modal{max-width:900px;display:flex;flex-direction:column;overflow:hidden}.upcoming-add-modal .modal-header{flex-shrink:0}.upcoming-add-modal .modal-body{min-width:560px;max-width:860px;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.upcoming-add-panels{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;min-height:0;flex:1;overflow:hidden}.upcoming-add-panel-items,.upcoming-add-panel-categories{min-width:0;display:flex;flex-direction:column}.upcoming-add-panel-items{border-top:1px solid var(--border);padding-top:1rem;flex:1;min-height:0;overflow:hidden}.upcoming-add-panel-categories{padding-bottom:.15rem;flex-shrink:0}.upcoming-add-panel-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.upcoming-add-panel-title{margin:0;font-size:.9rem;font-weight:600;color:var(--muted)}.upcoming-add-panel-dismiss,.upcoming-add-active-filter-clear{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;padding:0;border:none;border-radius:var(--radius);background:transparent;color:var(--muted);font-size:1.25rem;line-height:1;cursor:pointer}.upcoming-add-panel-dismiss:hover,.upcoming-add-active-filter-clear:hover{background:#0969da14;color:var(--accent)}.upcoming-add-show-categories-btn{padding:.2rem .5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--accent);font-size:.8rem;font-weight:600;cursor:pointer}.upcoming-add-show-categories-btn:hover{background:#0969da14}.upcoming-add-active-filter{display:inline-flex;align-items:center;gap:.35rem;max-width:100%;margin:0 0 .5rem;padding:.3rem .35rem .3rem .6rem;border:1px solid var(--accent);border-radius:999px;background:#0969da14;color:var(--accent);font-size:.82rem;font-weight:600}.upcoming-add-active-filter-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upcoming-categories-picker{list-style:none;margin:0;padding:0;max-height:180px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.upcoming-categories-picker li{margin:.2rem 0}.upcoming-category-picker-btn{display:block;width:100%;padding:.4rem .5rem;background:none;border:none;border-radius:var(--radius);cursor:pointer;text-align:left;font-size:.9rem;color:var(--text)}.upcoming-category-picker-btn:hover{background:#0969da14;color:var(--accent)}.upcoming-category-picker-btn--selected{background:#0969da1f;color:var(--accent);font-weight:600;box-shadow:inset 0 0 0 1px #0969da40}.upcoming-add-panel-empty{margin:.5rem 0 0;font-size:.85rem;color:var(--muted)}.upcoming-add-modal .upcoming-add-input-row{margin-bottom:.75rem;flex-shrink:0}.upcoming-add-modal .upcoming-add-custom-btn,.upcoming-add-modal .upcoming-add-feedback,.upcoming-add-modal .upcoming-add-panel-header{flex-shrink:0}.upcoming-add-feedback{display:flex;align-items:center;gap:.55rem;margin-bottom:.85rem;padding:.65rem .75rem;border:1px solid #8fd19e;border-radius:var(--radius);background:#edf9f0;color:#14532d;animation:upcoming-toast-in .22s ease-out}.upcoming-add-feedback-icon{flex-shrink:0;color:#15803d}.upcoming-add-feedback-text{flex:1 1 auto;min-width:0;font-size:.9rem;line-height:1.35}.upcoming-add-feedback-text strong{font-weight:700}.upcoming-add-feedback-view{flex-shrink:0;padding:.3rem .55rem;border:1px solid #8fd19e;border-radius:var(--radius);background:#fff;color:#15803d;font-size:.8rem;font-weight:600;cursor:pointer}.upcoming-add-feedback-view:hover{background:#f6fffa}.upcoming-items-picker button.upcoming-item-picker-btn--added{color:#15803d;font-weight:600;text-decoration:none}.upcoming-item-picker-added-badge{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:4px;background:#edf9f0;color:#15803d;border:1px solid #8fd19e}.upcoming-order-items-table tr.item-row--just-added{animation:upcoming-list-item-added 2.4s ease-out}@keyframes upcoming-list-item-added{0%{background:#22c55e38;box-shadow:inset 0 0 0 2px #22c55e73}70%{background:#22c55e1f;box-shadow:inset 0 0 0 2px #22c55e40}to{background:transparent;box-shadow:none}}.upcoming-add-trigger{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:transparent;border:2px dashed var(--border);border-radius:var(--radius);color:var(--muted);font-size:1rem;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.upcoming-add-trigger:hover{border-color:var(--accent);color:var(--accent);background:#0969da0a}.upcoming-add-trigger.active{border-color:var(--accent);color:var(--accent);background:#0969da0f;border-style:solid}.upcoming-add-trigger-icon{font-size:1.25rem;font-weight:300;line-height:1}.upcoming-filter-inline{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.upcoming-order-items-section .upcoming-filter-inline{margin-left:0}.upcoming-list-toolbar-bar{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:.5rem .75rem;width:100%;min-width:0;overflow:visible}.upcoming-list-toolbar-bar .upcoming-added-by-wrap{flex:0 0 auto;min-width:0}.upcoming-added-by-wrap{position:relative;flex-shrink:0}.upcoming-added-by-pill{display:inline-flex;align-items:stretch;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden}.upcoming-added-by-label{display:flex;align-items:center;padding:.5rem .65rem;font-size:.95rem;font-weight:500;color:var(--text);white-space:nowrap;background:var(--bg);border-right:1px solid var(--border)}.upcoming-added-by-trigger{display:flex;align-items:center;gap:.35rem;padding:.5rem 2rem .5rem .65rem;min-height:2.75rem;min-width:5.5rem;font-size:.95rem;font-weight:500;font-family:inherit;color:var(--text);background:var(--surface);border:none;cursor:pointer;text-align:left;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .55rem center;background-size:1rem}.upcoming-added-by-pill:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 18%,transparent)}.upcoming-added-by-trigger:focus{outline:none}.upcoming-added-by-dropdown{position:absolute;top:calc(100% + .25rem);left:0;z-index:120;min-width:100%;margin:0;padding:.35rem 0;list-style:none;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #0000001f}.upcoming-added-by-dropdown li{margin:0}.upcoming-added-by-dropdown li button{display:block;width:100%;padding:.65rem .85rem;font-size:.95rem;font-family:inherit;font-weight:500;color:var(--text);text-align:left;background:transparent;border:none;cursor:pointer}.upcoming-added-by-dropdown li button:hover,.upcoming-added-by-dropdown li button.upcoming-added-by-option--selected{background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--accent)}.upcoming-list-toolbar-bar .upcoming-list-action-btns{flex:0 0 auto;flex-wrap:nowrap;margin-left:0}.upcoming-filter-inline .filter-label{color:var(--muted)}.upcoming-filter-inline select{padding:.35rem .6rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem}.upcoming-empty-list{padding:3rem 2rem;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.upcoming-empty-list p{margin:0 0 1rem;color:var(--muted);font-size:.95rem}.auth-user-badge{display:inline-flex;align-items:center;gap:.5rem;font-weight:500}.auth-user-badge .btn-logout{background:none;border:none;color:var(--muted);font-size:.85rem;cursor:pointer}.auth-user-badge .btn-logout:hover{color:var(--text);text-decoration:underline}.auth-gate-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg, #f6f8fa)}.auth-gate-card{width:100%;max-width:24rem;padding:1.75rem;background:var(--surface, #fff);border:1px solid var(--border, #d0d7de);border-radius:12px;box-shadow:0 8px 24px #00000014}.auth-gate-card h1{margin:0 0 .5rem;font-size:1.5rem}.auth-gate-card.loading{text-align:center;color:var(--muted)}.auth-modal .auth-modal-intro{color:var(--muted);font-size:.9rem;margin:0 0 1rem}.auth-modal .auth-error{color:var(--danger, #cf222e);font-size:.9rem;margin:0 0 .5rem}.auth-modal .auth-success{color:var(--success, #2da44e);font-size:.9rem;margin:0 0 .5rem}.auth-modal .auth-forgot{margin:.75rem 0 0}.auth-modal .link-btn{background:none;border:none;padding:0;font-size:.9rem;color:var(--primary);cursor:pointer;text-decoration:underline}.auth-modal .link-btn:hover{opacity:.85}.auth-modal .form-label{display:block;font-size:.85rem;margin-bottom:.25rem}.auth-modal label{display:block;margin-bottom:.75rem}.auth-modal input{width:100%;padding:.5rem;border:1px solid var(--border);border-radius:var(--radius)}.auth-modal button[type=submit]{margin-top:.5rem}.upcoming-add-panel{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.upcoming-items-header{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem 1rem;margin-bottom:.75rem}.upcoming-items-header h3{margin:0;font-size:1.1rem;font-weight:600}.upcoming-items-count{font-size:.9rem;color:var(--muted)}.upcoming-add-input-row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-bottom:.5rem}.upcoming-add-input-row input[type=text]{flex:1;min-width:200px;margin:0}.upcoming-add-search-wrap{position:relative;flex:1;min-width:200px;display:flex;align-items:center}.upcoming-add-search-wrap input[type=text]{width:100%;min-width:0;padding-right:2.35rem}.upcoming-add-search-clear{position:absolute;right:.3rem;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer;-webkit-tap-highlight-color:transparent}.upcoming-add-search-clear:hover{color:var(--text);background:#0969da14}.upcoming-add-input-row .qty-input{width:60px}.upcoming-add-custom-btn{margin-bottom:.75rem}.upcoming-items-picker{list-style:none;margin:.5rem 0 0;padding:0;flex:1;min-height:0;max-height:min(42vh,320px);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.upcoming-add-picker-sentinel{height:1px;margin:0;padding:0;list-style:none;pointer-events:none}.upcoming-items-picker li{margin:.25rem 0}.upcoming-items-picker button.upcoming-item-picker-btn{display:flex;align-items:center;gap:.5rem;width:100%;background:none;border:none;padding:.35rem 0;cursor:pointer;text-align:left;color:var(--accent);font-size:.95rem}.upcoming-items-picker button.upcoming-item-picker-btn:hover{text-decoration:underline}.upcoming-item-picker-img{width:40px;height:40px;object-fit:contain;flex-shrink:0;border-radius:4px;background:var(--surface)}.upcoming-item-picker-img-placeholder{width:40px;height:40px;flex-shrink:0;border-radius:4px;background:var(--surface);border:1px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:.5rem;line-height:1.1;color:var(--muted);text-align:center;padding:2px;box-sizing:border-box;overflow:hidden;word-break:break-word}.upcoming-recommendations-inline{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.upcoming-recommendations-inline h4{margin:0 0 .75rem;font-size:.95rem}.upcoming-recommendations-list{list-style:none;margin:0;padding:0}.upcoming-recommendations-list li{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(0,0,0,.06)}.upcoming-recommendations-list li:last-child{border-bottom:none}.upcoming-recommendations-list .btn-accept,.upcoming-recommendations-list .btn-reject{margin-left:.5rem;padding:.25rem .5rem;font-size:.85rem;background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer}.upcoming-recommendations-list .btn-accept:hover,.upcoming-recommendations-list .btn-reject:hover{filter:brightness(1.08)}.upcoming-order-items-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem}.upcoming-list-section{background:color-mix(in srgb,var(--accent) 4%,var(--surface))}.upcoming-items-header-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem;margin-bottom:.75rem;overflow:visible}.upcoming-order-items-section--collapsed .upcoming-items-header-row{margin-bottom:0}.upcoming-items-header-toggle{display:flex;align-items:center;gap:.5rem;flex:1 1 auto;min-width:0;padding:.25rem 0;margin:0;background:none;border:none;font:inherit;color:inherit;cursor:pointer;text-align:left}.upcoming-items-header-toggle:hover{color:var(--accent)}.upcoming-items-header-filter{flex-shrink:0;display:flex;align-items:center;gap:.75rem;overflow:visible}.upcoming-list-action-btns{display:flex;flex-wrap:nowrap;align-items:center;gap:.45rem;flex-shrink:0}.open-pending-product-tabs-btn{padding:.35rem .6rem;font-size:.9rem;font-family:inherit;border:1px solid color-mix(in srgb,var(--accent) 55%,var(--border));border-radius:var(--radius);background:transparent;color:var(--accent);cursor:pointer;white-space:nowrap}.open-pending-product-tabs-btn:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 10%,transparent);border-color:var(--accent)}.open-pending-product-tabs-btn:disabled{opacity:.5;cursor:not-allowed}.open-in-tabs-btn{padding:.35rem .6rem;font-size:.9rem;border:1px solid var(--accent);border-radius:var(--radius);background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap}.open-in-tabs-btn:hover:not(:disabled){filter:brightness(1.08)}.open-in-tabs-btn:disabled{opacity:.5;cursor:not-allowed}.upcoming-page-toast{position:fixed;top:1rem;right:1rem;z-index:2100;display:flex;align-items:flex-start;gap:.65rem;max-width:min(520px,calc(100vw - 2rem));padding:.75rem .85rem;border-radius:var(--radius);box-shadow:0 10px 28px #0000002e;animation:upcoming-toast-in .22s ease-out}@keyframes upcoming-toast-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.upcoming-page-toast-text{margin:0;font-size:.88rem;line-height:1.45;flex:1 1 auto}.upcoming-page-toast-close{flex-shrink:0;border:none;background:transparent;color:inherit;font-size:1.25rem;line-height:1;cursor:pointer;padding:0 .1rem;opacity:.75}.upcoming-page-toast-close:hover{opacity:1}.upcoming-page-toast--info{border:1px solid color-mix(in srgb,var(--accent) 45%,var(--border));background:color-mix(in srgb,var(--accent) 10%,var(--surface, #fff));color:var(--text, inherit)}.upcoming-page-toast--success{border:1px solid #8fd19e;background:#edf9f0;color:#14532d}.upcoming-page-toast--error{border:1px solid #f0b3b3;background:#fff1f1;color:#7a1f1f}.upcoming-subtable-heading{font-size:1rem;font-weight:600;margin:1rem 0 .5rem;color:var(--text, inherit)}.upcoming-subtable-heading--pending{margin-top:0}.upcoming-tesco-basket-block{margin-top:1.25rem;padding-top:.75rem;border-top:1px solid var(--border)}.upcoming-tesco-basket-toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:.75rem 1rem;margin-bottom:.65rem}.upcoming-tesco-basket-toolbar-text{flex:1 1 12rem;min-width:0}.upcoming-subtable-heading--basket{margin:0 0 .2rem;font-size:1rem}.upcoming-tesco-basket-sub{margin:0;font-size:.82rem;line-height:1.4;color:var(--muted)}.btn-move-all-to-pending{flex-shrink:0;padding:.45rem .85rem;font-size:.85rem;font-weight:600;font-family:inherit;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--accent) 45%,var(--border));border-radius:var(--radius);cursor:pointer;white-space:nowrap}.btn-move-all-to-pending:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 16%,transparent);border-color:var(--accent)}.btn-move-all-to-pending:disabled{opacity:.5;cursor:not-allowed}.upcoming-tesco-basket-table-wrap{border-radius:var(--radius);border:1px solid color-mix(in srgb,var(--border) 80%,var(--accent, #0a7) 15%);overflow:hidden}.upcoming-order-items-table--basket tbody tr{background:color-mix(in srgb,var(--accent, #0a7) 5%,transparent)}.upcoming-order-items-table--basket tbody tr:nth-child(2n){background:color-mix(in srgb,var(--accent, #0a7) 8%,transparent)}.upcoming-pending-all-in-basket{margin:0 0 1rem;padding:.65rem .75rem;font-size:.9rem;color:var(--muted);background:color-mix(in srgb,var(--border) 35%,transparent);border-radius:var(--radius)}.upcoming-order-items-table--basket .upcoming-basket-actions-col{width:8.5rem;min-width:7.5rem}.upcoming-order-items-table--basket .actions-buttons--basket-row{gap:.35rem;flex-wrap:nowrap;justify-content:flex-end}.basket-revert-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;flex-shrink:0;color:var(--accent);background:transparent;border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);border-radius:var(--radius);cursor:pointer}.basket-revert-btn:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);border-color:var(--accent)}.upcoming-items-header-title{font-weight:600;font-size:1.1rem}.upcoming-items-header-summary{font-size:.95rem;color:var(--muted)}.upcoming-items-header-total{font-weight:600;color:inherit}.upcoming-items-header-chevron{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent)}.upcoming-items-header-chevron svg{display:block}.upcoming-order-items-section .upcoming-items-header-filter .upcoming-filter-inline{margin-left:0}.upcoming-suggestions-section .upcoming-items-header-filter{flex:1 1 16rem;min-width:0;max-width:100%}.upcoming-suggestions-filter-bar{display:flex;flex-direction:row;align-items:center;gap:.5rem;width:100%;min-width:0}.upcoming-suggestions-filter-bar .upcoming-suggestions-category-wrap{flex:1 1 10rem;min-width:0}.upcoming-suggestions-filter-bar .upcoming-suggestions-category-pill{width:100%;min-width:0}.upcoming-suggestions-category-wrap{position:relative;display:flex;align-items:center;gap:.25rem}.upcoming-suggestions-category-pill{display:inline-flex;align-items:center;gap:0;min-width:10rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.upcoming-suggestions-category-pill--active .upcoming-suggestions-category-select{padding-right:.25rem}.upcoming-suggestions-category-select{padding:.4rem .6rem;font-size:.9rem;font-family:inherit;border:none;border-radius:0;background:transparent;min-width:0;flex:1;text-align:left;cursor:pointer}.upcoming-suggestions-category-pill:focus-within{outline:none;border-color:var(--accent)}.upcoming-suggestions-category-clear{flex-shrink:0;width:1.75rem;height:1.75rem;margin:.15rem;padding:0;font-size:1.2rem;line-height:1;font-family:inherit;border:none;border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center}.upcoming-suggestions-category-clear:hover{color:var(--accent);background:#0969da14}.upcoming-suggestions-category-dropdown{position:absolute;top:100%;left:0;margin-top:.25rem;min-width:14rem;max-width:20rem;max-height:20rem;overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 12px #00000026;z-index:100}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.upcoming-suggestions-category-dropdown-search-wrap{position:sticky;top:0;z-index:2;padding:.5rem .6rem;background:var(--surface);border-bottom:1px solid var(--border)}.upcoming-suggestions-category-dropdown-search{width:100%;box-sizing:border-box;padding:.4rem .5rem;font-size:.88rem;font-family:inherit;color:inherit;background:var(--bg, #fff);border:1px solid var(--border);border-radius:6px}.upcoming-suggestions-category-dropdown-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #0969da33}.upcoming-suggestions-category-empty{list-style:none}.upcoming-suggestions-category-empty-text{display:block;padding:.5rem .5rem .25rem;font-size:.85rem;color:var(--muted)}.upcoming-suggestions-category-breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;padding:.5rem .6rem;border-bottom:1px solid var(--border);font-size:.85rem;color:var(--muted)}.upcoming-suggestions-category-breadcrumb button{background:none;border:none;padding:.2rem 0;font-size:inherit;font-family:inherit;color:inherit;cursor:pointer}.upcoming-suggestions-category-breadcrumb button:hover{color:var(--accent)}.upcoming-suggestions-category-bc-sep:before{content:" › ";color:var(--muted)}.upcoming-suggestions-category-list{list-style:none;margin:0;padding:.75rem}.upcoming-suggestions-category-list li{margin:0}.upcoming-suggestions-category-list li button{display:block;width:100%;padding:.4rem .5rem;text-align:left;font-size:.9rem;font-family:inherit;background:none;border:none;border-radius:4px;cursor:pointer;color:inherit}.upcoming-suggestions-category-list li button:hover{background:var(--accent);color:#fff}.upcoming-suggestions-category-select-level{font-style:italic}.upcoming-suggestions-category-arrow{opacity:.7;margin-left:.2rem}.upcoming-suggestions-search{flex:1 1 8rem;min-width:0;width:auto;max-width:none;padding:.4rem .6rem;font-size:.9rem;font-family:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.upcoming-suggestions-search:focus{outline:none;border-color:var(--accent)}.upcoming-suggestions-empty{margin:0;padding:1rem 0;color:var(--muted);font-size:.9rem}.upcoming-suggestions-sentinel{height:1px;visibility:hidden;pointer-events:none}.upcoming-suggestions-end{margin:1rem 0 0;padding:0;text-align:center;color:var(--muted);font-size:.9rem}.upcoming-suggestions-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:auto;column-gap:1rem;gap:1rem;list-style:none;margin:0;padding:0;overflow:hidden}.upcoming-suggestions-list li,.upcoming-suggestion-li{display:flex;min-width:0;height:auto;grid-column:var(--suggestion-col, auto);grid-row:var(--suggestion-row, auto)}@media (max-width: 980px){.upcoming-suggestions-list{display:flex;flex-direction:column;gap:.75rem}.upcoming-suggestions-list li,.upcoming-suggestion-li{grid-column:unset;grid-row:unset;width:100%}}.upcoming-suggestion-item{display:flex;flex-direction:row;align-items:flex-start;gap:.5rem;padding:.5rem .5rem .25rem;min-width:0;font-size:.9rem;font-family:inherit;background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer;transition:filter .15s;-webkit-tap-highlight-color:rgba(0,0,0,.1);width:100%;height:100%;min-height:0;box-sizing:border-box;overflow:hidden;isolation:isolate}.upcoming-suggestion-item:hover{filter:brightness(1.08)}.upcoming-suggestion-item:active{filter:brightness(.95)}@media (hover: none){.upcoming-suggestion-item:hover{filter:none}.upcoming-suggestion-item:active{filter:brightness(1.08)}}.product-hover-thumb-wrap{position:relative;display:inline-block;line-height:0;vertical-align:middle;overflow:hidden;flex-shrink:0}.product-hover-thumb{object-fit:contain;display:block;border-radius:6px}.product-hover-thumb--items{width:51px;height:51px;border:1px solid var(--border);background:var(--bg)}.product-hover-thumb--lg{width:96px;height:96px;flex-shrink:0;background:#fff3}.upcoming-suggestion-item .product-hover-trigger{position:relative;flex-shrink:0;align-self:flex-start;cursor:zoom-in}.product-hover-placeholder--inline{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;font-size:.75rem;color:var(--muted);border:1px solid var(--border);border-radius:6px;background:var(--bg);vertical-align:middle}.product-hover-placeholder--lg{width:96px;min-height:96px;background:var(--surface)!important;border:1px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:.55rem;line-height:1.1;color:var(--muted);text-align:center;padding:4px;box-sizing:border-box;overflow:hidden;word-break:break-word}.product-hover-thumb-badge{position:absolute;top:2px;right:2px;min-width:1.6rem;padding:2px 4px;background:var(--surface);border:1px solid var(--border);border-radius:4px;font-size:.5rem;line-height:1.05;text-align:center;color:var(--text);pointer-events:none;box-shadow:0 1px 2px #0000000f}.product-hover-thumb-badge-line1{display:block;font-weight:700}.product-hover-thumb-badge-line2{display:block;font-weight:500;opacity:.85}.product-hover-popover--anchored{display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-.5rem);z-index:200;width:280px;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #00000040;pointer-events:none;flex-direction:column;gap:.5rem}.product-hover-wide:hover .product-hover-popover--anchored,.product-hover-trigger:hover .product-hover-popover--anchored{display:flex}.product-hover-popover--portal{position:fixed;z-index:10050;width:280px;max-width:min(280px,calc(100vw - 24px));max-height:min(360px,calc(100vh - 24px));overflow-y:auto;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #00000040;pointer-events:none;display:flex;flex-direction:column;gap:.5rem}.product-hover-breadcrumbs{display:block;font-size:.85rem;font-weight:500;line-height:1.3;color:var(--muted);overflow-wrap:break-word;word-break:break-word;white-space:normal}.product-hover-name{font-size:1.05rem;font-weight:600;line-height:1.35;color:var(--text);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.product-hover-popover--anchored .product-hover-breadcrumbs{font-size:.95rem}.product-hover-popover--anchored .product-hover-name{font-size:1.1rem}.product-hover-popover--portal img,.product-hover-popover--anchored img{width:100%;height:200px;object-fit:contain;border-radius:6px;background:#00000008}.product-hover-popover--text-only.product-hover-popover--anchored{width:260px}@media (hover: none){.product-hover-popover--anchored{display:none!important}}.upcoming-suggestion-item{flex-wrap:nowrap}.upcoming-suggestion-content{display:flex;flex-direction:column;min-width:0;flex:1;justify-content:flex-start;align-self:flex-start;gap:.15rem;overflow:hidden}.upcoming-suggestion-breadcrumbs{font-size:.8rem;opacity:.85;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word}.upcoming-suggestion-price-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.35rem .5rem;margin-top:.1rem;margin-bottom:.15rem;flex-shrink:0;min-width:0;width:100%}.upcoming-suggestion-actions{display:inline-flex;align-items:center;flex-shrink:0;margin-left:auto}.upcoming-suggestion-actions .qty-controls{display:inline-flex;align-items:center;gap:0;height:2rem;min-height:2rem;padding:0 .08rem;border:2px solid rgba(255,255,255,.9);border-right:none;border-radius:var(--radius) 0 0 var(--radius);background:#ffffff1a;line-height:1;box-sizing:border-box}.upcoming-suggestion-actions .qty-minus-btn,.upcoming-suggestion-actions .qty-plus-btn{width:26px;height:26px;min-width:26px;padding:0;border:none;border-radius:var(--radius);background:transparent;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent}.upcoming-suggestion-actions .qty-minus-btn:hover:not(:disabled),.upcoming-suggestion-actions .qty-plus-btn:hover:not(:disabled){background:#ffffff26}.upcoming-suggestion-actions .qty-minus-btn:disabled{opacity:.5;cursor:not-allowed}.upcoming-suggestion-actions .qty-value-btn{min-width:1.55rem;padding:.05rem .1rem;font-weight:600;font-size:.95rem;line-height:1;border:none;background:transparent;color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent}.upcoming-suggestion-actions .qty-input-inline{width:2rem;margin:0;padding:.1rem;text-align:center;font-size:.95rem;font-weight:600;line-height:1;border:none;background:transparent;color:#fff;-moz-appearance:textfield}.upcoming-suggestion-actions .qty-input-inline::-webkit-outer-spin-button,.upcoming-suggestion-actions .qty-input-inline::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.upcoming-suggestion-name{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.3;font-size:1rem;font-weight:600;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word}.upcoming-suggestion-price{font-family:Plus Jakarta Sans,DM Sans,sans-serif;font-size:.95rem;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums;flex-shrink:0;white-space:nowrap}.upcoming-suggestion-price.upcoming-suggestion-price--has-subtotal{font-weight:400}.upcoming-suggestion-price.upcoming-suggestion-price--has-subtotal .upcoming-suggestion-subtotal{font-weight:600}.upcoming-suggestion-subtotal{font-weight:600;opacity:1}.upcoming-suggestion-add{font-weight:600;font-size:.95rem;line-height:1;height:2.35rem;min-height:2.35rem;padding:0 .65rem;background:transparent;color:#fff;border:2px solid rgba(255,255,255,.9);border-radius:0 var(--radius) var(--radius) 0;cursor:pointer;transition:background .15s,border-color .15s;-webkit-tap-highlight-color:transparent;margin-left:0;align-self:center;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box}.upcoming-suggestion-add:hover{background:#fff3;border-color:#fff}.upcoming-order-items-table{width:100%;border-collapse:collapse}.upcoming-order-items-table th,.upcoming-order-items-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid #b8c0cc}.upcoming-order-items-table th{text-align:center}.upcoming-order-items-table thead th{text-align:center!important}.upcoming-order-items-table .col-qty{width:108px}.upcoming-order-items-table .col-each,.upcoming-order-items-table .col-total{font-family:Plus Jakarta Sans,DM Sans,sans-serif;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.upcoming-order-items-table .col-each{font-weight:500}.upcoming-order-items-table .col-total{font-weight:600}.upcoming-list-item-head{display:flex;align-items:flex-start;gap:.6rem;min-width:0;width:100%}.upcoming-list-item-head-text{display:flex;flex-direction:column;gap:.12rem;min-width:0;flex:1}.upcoming-list-item-name{font-weight:600;line-height:1.3;word-break:break-word}.upcoming-list-item-category{font-size:.75rem;color:var(--muted);line-height:1.2}.product-hover-thumb--list{width:53px;height:53px;flex-shrink:0;border-radius:6px;border:1px solid var(--border);background:var(--bg);object-fit:contain}.upcoming-list-item-head .product-hover-placeholder--lg{width:53px;min-height:53px;font-size:.5rem}.upcoming-order-items-table td.name .product-hover-trigger{flex-shrink:0;align-self:flex-start}.upcoming-order-items-table .qty-controls{display:inline-flex;align-items:center;gap:.1rem}.upcoming-order-items-table .qty-minus-btn,.upcoming-order-items-table .qty-plus-btn{width:28px;height:28px;min-width:28px;padding:0;border:1px solid var(--accent);border-radius:var(--radius);background:var(--accent);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.upcoming-order-items-table .qty-minus-btn:hover:not(:disabled),.upcoming-order-items-table .qty-plus-btn:hover:not(:disabled){filter:brightness(1.08)}.upcoming-order-items-table .qty-minus-btn:disabled{opacity:.5;cursor:not-allowed}.upcoming-order-items-table .qty-value{min-width:2.5rem;text-align:center;cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius);border:1px solid transparent}.upcoming-order-items-table .qty-value:hover{background:#0969da0f;border-color:var(--border)}.upcoming-order-items-table .qty-value-btn{min-width:1.65rem;padding:.1rem .15rem;font-weight:600;font-size:1rem;line-height:1;border:none;background:transparent;color:var(--text);cursor:pointer}.upcoming-order-items-table .qty-controls input.qty-input-edit{width:2.35rem;margin:0;padding:.15rem .2rem;text-align:center;font-size:1rem}.upcoming-order-items-table .qty-btn{background:none;border:none;cursor:pointer;padding:.25rem;color:var(--accent)}.upcoming-order-items-table .qty-btn:hover{text-decoration:underline}.upcoming-order-items-table .move-btn{padding:.35rem .6rem;font-size:.8rem;background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer;color:#fff;display:inline-flex;align-items:center;justify-content:center}.upcoming-order-items-table .move-btn:hover{filter:brightness(1.08)}.upcoming-order-items-table td.actions-cell{text-align:center}.upcoming-order-items-table .actions-buttons{display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.upcoming-order-items-table .actions-buttons a,.upcoming-order-items-table .actions-buttons button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;flex-shrink:0}.upcoming-order-items-table .view-tesco-link{background:transparent;border:none}.upcoming-order-items-table .view-in-app-btn{display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--accent);border:none}.upcoming-order-items-table .view-in-app-btn:hover{opacity:.8}.upcoming-order-items-table .view-in-app-btn-text{display:none}.upcoming-order-items-table tr.item-row--unknown{background:#ffc10714;border-left:3px solid rgba(255,152,0,.6)}.upcoming-order-items-table tr.item-row--unknown td{border-left-color:transparent}.upcoming-order-items-table .items-table-totals-row td{border-top:2px solid var(--border);font-weight:600;padding-top:.6rem}.upcoming-order-items-table .items-table-totals-row .col-qty{text-align:center}.upcoming-order-items-table .items-table-totals-row .col-total{text-align:right}.upcoming-order-items-table .delete-btn.delete-btn-icon{background:transparent;border:none}.comment-btn.comment-btn-icon{padding:.35rem;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--accent);cursor:pointer;border-radius:var(--radius)}.comment-btn.comment-btn-icon:hover{background:#0969da14;opacity:.9}.item-comment-text{margin:0;white-space:pre-wrap;word-break:break-word}@media (max-width: 768px){.app-layout .app:has(.upcoming-orders-page){padding-left:max(.35rem,env(safe-area-inset-left));padding-right:max(.35rem,env(safe-area-inset-right))}.upcoming-orders-page{padding:0 0 max(1.5rem,env(safe-area-inset-bottom))}.upcoming-page-header{flex-direction:column;gap:1rem}.upcoming-page-header-actions{width:100%;flex-wrap:wrap}.upcoming-page-header-actions .btn{flex:1;min-width:120px}.upcoming-orders-page .page-header .toolbar.upcoming-toolbar-icons{flex-direction:row;align-items:center;gap:.5rem}.upcoming-orders-page .page-header .toolbar .btn{min-height:44px;padding:.6rem 1rem}.upcoming-orders-page .page-header h1{font-size:1.35rem}.upcoming-empty-list .btn{min-height:48px;padding:.75rem 1.25rem}.upcoming-order-items-section{padding:.55rem .4rem;min-width:0}.upcoming-order-items-section .upcoming-items-header-row,.upcoming-order-items-section .upcoming-items-header-filter,.upcoming-order-items-section .upcoming-list-toolbar-bar,.upcoming-order-items-section .upcoming-added-by-wrap{overflow:visible}.upcoming-order-items-section .table-wrap,.upcoming-order-items-section .upcoming-tesco-basket-table-wrap{overflow-x:hidden}.upcoming-items-header-row{flex-direction:column;align-items:stretch;gap:.65rem;margin-bottom:.5rem}.upcoming-items-header-toggle{width:100%}.upcoming-order-items-section:not(.upcoming-suggestions-section) .upcoming-items-header-row{flex-direction:row;flex-wrap:wrap;align-items:center}.upcoming-order-items-section:not(.upcoming-suggestions-section) .upcoming-items-header-toggle{flex:1 1 100%;width:100%}.upcoming-order-items-section:not(.upcoming-suggestions-section) .upcoming-items-header-filter{flex:1 1 100%;width:100%;flex-direction:row}.upcoming-list-toolbar-bar{flex-wrap:nowrap;align-items:center;gap:.45rem .5rem}.upcoming-list-toolbar-bar .upcoming-list-action-btns{flex:0 0 auto;margin-left:0;flex-direction:row;flex-wrap:nowrap;width:auto}.upcoming-list-toolbar-bar .open-in-tabs-btn,.upcoming-list-toolbar-bar .open-pending-product-tabs-btn{width:auto;min-height:36px;flex:0 0 auto;padding:.3rem .5rem;font-size:.82rem}.upcoming-order-items-section .upcoming-items-header-filter .upcoming-filter-inline{width:auto;justify-content:flex-start}.upcoming-added-by-label,.upcoming-added-by-trigger,.upcoming-added-by-dropdown li button{font-size:1rem}.upcoming-added-by-trigger{min-height:2.85rem}.upcoming-list-action-btns{width:auto;flex-direction:row;flex-wrap:nowrap;align-items:center}.upcoming-list-action-btns .open-in-tabs-btn,.upcoming-list-action-btns .open-pending-product-tabs-btn{width:auto;min-height:36px}.upcoming-tesco-basket-toolbar{flex-direction:column;align-items:stretch;gap:.65rem}.upcoming-tesco-basket-toolbar .btn-move-all-to-pending{width:100%;min-height:44px}.upcoming-order-items-section .table-wrap,.upcoming-tesco-basket-table-wrap{overflow:visible;min-width:0;border:none;background:transparent;border-radius:0}.upcoming-order-items-table{display:block;min-width:0;width:100%}.upcoming-order-items-table thead{display:none}.upcoming-order-items-table tbody,.upcoming-order-items-table tfoot{display:block}.upcoming-order-items-table{--list-line: #b8c0cc;--list-thumb-size: 62px;--list-thumb-gap: .6rem;--list-text-inset: calc(var(--list-thumb-size) + var(--list-thumb-gap))}.upcoming-order-items-table tbody tr{display:grid;grid-template-columns:var(--list-text-inset) auto auto 1fr auto;grid-template-rows:auto auto auto auto;align-items:start;row-gap:.1rem;column-gap:0;padding:.75rem .85rem .4rem;margin-bottom:.5rem;background:var(--card-bg, var(--surface));border:1px solid var(--list-line, var(--border));border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);min-width:0}.upcoming-order-items-table tbody tr:after{content:"";grid-column:1 / -1;grid-row:3;display:block;width:100%;height:1px;background:var(--list-line, var(--border));margin-top:.25rem;align-self:stretch}.upcoming-order-items-table td[data-label="Added by"]{grid-column:1 / 5;grid-row:4;min-width:0;font-size:.75rem;color:var(--muted);padding:.15rem 0 0;margin-top:0;border-top:none;align-self:end;align-items:center;min-height:0}.upcoming-order-items-table td[data-label="Added by"]:before{content:"Added by ";font-size:.7rem}.upcoming-order-items-table tbody tr:hover td{background:transparent}.upcoming-order-items-table tbody tr:last-child{margin-bottom:.5rem}.upcoming-orders-page .items-table-wrap td.actions-cell{position:static;right:auto;box-shadow:none;min-width:0;background:transparent}.upcoming-order-items-table tr.item-row--unknown{border-left:none}.upcoming-order-items-table tr.item-row--unknown td.name{border-left:none;padding-left:0}.upcoming-order-items-table tr.item-row--unknown .upcoming-list-item-head{border-left:3px solid rgba(255,152,0,.65);padding-left:.45rem;margin-left:-.1rem}.upcoming-order-items-table tfoot tr.items-table-totals-row{display:flex;flex-wrap:wrap;gap:.5rem 1rem;padding:.65rem .85rem;background:#00000008;border:1px solid var(--border);border-radius:var(--radius-lg);font-weight:600;margin-top:.25rem}.upcoming-order-items-table tfoot tr.items-table-totals-row td{display:inline;padding:0;border:none}.upcoming-order-items-table tfoot tr.items-table-totals-row td:last-child{display:none}.upcoming-order-items-table tfoot tr.items-table-totals-row td:before{display:none}.upcoming-order-items-table tfoot tr.items-table-totals-row td.name{margin-right:.5rem;flex:1 1 100%;font-size:.9rem}.upcoming-order-items-table td{display:flex;align-items:center;justify-content:flex-start;padding:0;border:none;min-width:0}.upcoming-order-items-table td:before{content:attr(data-label);font-size:.75rem;color:var(--muted);margin-right:.5rem;flex-shrink:0}.upcoming-order-items-table td.name{grid-column:1 / -1;grid-row:1;min-width:0;padding:0;align-items:flex-start}.upcoming-order-items-table td.name .upcoming-list-item-head{position:relative;padding-left:var(--list-text-inset);min-height:0;gap:0}.upcoming-order-items-table td.name .product-hover-trigger{position:absolute;left:0;top:0}.upcoming-order-items-table td.name .upcoming-list-item-head-text{gap:.06rem}.upcoming-order-items-table td.name .upcoming-list-item-name{line-height:1.25}.upcoming-order-items-table td.name:before{display:none}.upcoming-order-items-table td.col-each{grid-column:2;grid-row:2;display:flex;align-items:flex-end;align-self:end;margin-left:0;padding-left:0;font-family:Plus Jakarta Sans,DM Sans,sans-serif;font-size:.85rem;font-weight:500;letter-spacing:-.02em;font-variant-numeric:tabular-nums;color:var(--text);line-height:1}.upcoming-order-items-table td.col-each:before{display:none}.upcoming-order-items-table td.col-each:after{content:" ea";font-size:.72rem;color:var(--muted);font-weight:400;line-height:1}.upcoming-order-items-table td.col-total{grid-column:3;grid-row:2;display:flex;align-items:flex-end;align-self:end;font-family:Plus Jakarta Sans,DM Sans,sans-serif;font-weight:600;font-size:.85rem;letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1}.upcoming-order-items-table td.col-total:before{content:"·";margin:0 .35rem;color:var(--muted);font-weight:400;font-size:.85rem;line-height:1}.upcoming-order-items-table td.col-qty{grid-column:5;grid-row:2;justify-self:end;align-self:center;display:flex;align-items:center;justify-content:flex-end;margin-left:0}.upcoming-order-items-table td.col-qty:before{display:none}.upcoming-order-items-table td.actions-cell{grid-column:5;grid-row:4;justify-self:end;align-self:end;justify-content:flex-end;padding:.15rem 0 0;margin-top:0;border-top:none;min-width:auto;min-height:0;align-items:center}.upcoming-order-items-table td.actions-cell:before{display:none}.upcoming-order-items-table .qty-controls{margin-left:0;border:1px solid var(--list-line, var(--border));border-radius:var(--radius);padding:.05rem .08rem;gap:0;background:var(--bg)}.upcoming-order-items-table .qty-minus-btn,.upcoming-order-items-table .qty-plus-btn{min-width:28px;min-height:28px;width:28px;height:28px;font-size:1rem;border:none;background:transparent;color:var(--accent)}.upcoming-order-items-table .qty-minus-btn:hover:not(:disabled),.upcoming-order-items-table .qty-plus-btn:hover:not(:disabled){filter:none;background:#0969da14}.upcoming-order-items-table .qty-value-btn{min-width:1.55rem;padding:.05rem .1rem;font-weight:600;font-size:.95rem;border:none;background:transparent;color:var(--text);cursor:pointer}.upcoming-order-items-table .qty-controls input.qty-input-inline{width:2rem;margin:0;padding:.1rem;text-align:center;font-size:.95rem;font-weight:600;border:none;background:transparent;-moz-appearance:textfield}.upcoming-order-items-table .qty-controls input.qty-input-inline::-webkit-outer-spin-button,.upcoming-order-items-table .qty-controls input.qty-input-inline::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.upcoming-order-items-table .actions-buttons{gap:.25rem;flex-shrink:0}.upcoming-order-items-table .actions-buttons a,.upcoming-order-items-table .actions-buttons button{min-width:30px;min-height:30px;width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius);background:var(--bg);border:1px solid var(--list-line, var(--border))}.upcoming-order-items-table .view-in-app-btn-text{display:none}.upcoming-order-items-table .upcoming-list-item-head{gap:var(--list-thumb-gap, .6rem)}.product-hover-thumb--list{width:var(--list-thumb-size, 62px);height:var(--list-thumb-size, 62px)}.upcoming-list-item-head .product-hover-placeholder--lg{width:var(--list-thumb-size, 62px);min-height:var(--list-thumb-size, 62px)}.upcoming-suggestions-section .upcoming-items-header-row{flex-direction:row;flex-wrap:wrap;align-items:center}.upcoming-suggestions-section .upcoming-items-header-toggle{flex:1 1 auto;width:auto}.upcoming-suggestions-section .upcoming-items-header-filter{flex:1 1 14rem;width:auto;flex-direction:row}.upcoming-suggestions-list{gap:.5rem;grid-auto-rows:minmax(100px,auto)}}@media (max-width: 480px){.upcoming-orders-page{padding-left:0;padding-right:0}.upcoming-order-items-section{padding:.5rem .3rem}.upcoming-order-items-table tbody tr{padding:.65rem .75rem .35rem;margin-bottom:.4rem}.upcoming-subtable-heading{font-size:.95rem;margin-bottom:.4rem}.upcoming-suggestions-section .upcoming-items-header-row{flex-direction:row;flex-wrap:wrap;align-items:center}.upcoming-suggestions-section .upcoming-items-header-toggle{flex:1 1 100%;width:100%}.upcoming-suggestions-section .upcoming-items-header-filter{flex:1 1 100%;width:100%;flex-direction:row}.upcoming-suggestions-filter-bar .upcoming-suggestions-category-pill,.upcoming-suggestions-filter-bar .upcoming-suggestions-category-select{min-width:0}.upcoming-suggestions-list{grid-template-columns:1fr;gap:.75rem;grid-auto-rows:minmax(100px,auto)}.upcoming-suggestion-item{padding:.4rem .4rem .2rem}.product-hover-thumb--lg{width:77px;height:77px;min-height:77px;max-height:77px}.upcoming-suggestion-item .product-hover-placeholder--lg{width:77px;min-height:77px}.upcoming-suggestion-price-row{flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.3rem .45rem}.upcoming-suggestion-actions{margin-left:auto}.upcoming-suggestion-actions .qty-controls{height:2rem;min-height:2rem;padding:0 .05rem}.upcoming-suggestion-actions .qty-minus-btn,.upcoming-suggestion-actions .qty-plus-btn{width:26px;height:26px;min-width:26px;font-size:1rem}.upcoming-suggestion-add{height:2rem;min-height:2rem;padding:0 .5rem;font-size:.9rem}.upcoming-add-modal{max-width:calc(100vw - 2rem);margin:0 1rem}.upcoming-add-modal .modal-body{min-width:0;max-width:none}.upcoming-add-panels{gap:.85rem}.upcoming-add-panel-items{padding-top:.85rem}.upcoming-add-input-row{flex-direction:column;align-items:stretch}.upcoming-add-search-wrap{min-width:0;width:100%}.upcoming-add-input-row input[type=text]{min-width:0}.upcoming-add-input-row .qty-input{width:100%;max-width:80px}.upcoming-items-picker button.upcoming-item-picker-btn{min-height:48px;padding:.5rem 0}.upcoming-item-picker-img,.upcoming-item-picker-img-placeholder{width:36px;height:36px}}.print-only-title{display:none}@media print{.upcoming-orders-page .page-header,.upcoming-orders-page .upcoming-add-card,.upcoming-orders-page .upcoming-add-panel,.upcoming-orders-page .upcoming-recommendations-inline,.upcoming-orders-page .upcoming-filter-inline,.upcoming-orders-page .upcoming-empty-list,.upcoming-orders-page .upcoming-items-header,.upcoming-orders-page .upcoming-items-header-row,.upcoming-orders-page .upcoming-items-header-toggle,.upcoming-orders-page .upcoming-items-header-filter,.upcoming-orders-page .actions-cell,.upcoming-orders-page .move-btn,.upcoming-orders-page .delete-btn{display:none!important}.print-only-title{display:block!important;margin:0 0 .75rem;font-size:1.25rem}.upcoming-orders-page .upcoming-order-items-section{margin:0;padding:0}.upcoming-suggestions-section{display:none!important}.upcoming-orders-main{width:100%;max-width:none}.app-layout .main-content{margin-left:0!important;padding-left:0!important}.upcoming-orders-page .upcoming-order-items-table thead{display:table-header-group!important}.upcoming-orders-page .upcoming-order-items-table tbody tr{display:table-row!important;padding:0!important;margin:0!important;background:transparent!important;border:none!important}.upcoming-orders-page .upcoming-order-items-table td{display:table-cell!important;padding:.5rem .75rem!important;border-bottom:1px solid var(--border)!important}.upcoming-orders-page .upcoming-order-items-table td:before{display:none!important}.upcoming-orders-page .upcoming-order-items-table th:nth-child(5),.upcoming-orders-page .upcoming-order-items-table th:nth-child(6),.upcoming-orders-page .upcoming-order-items-table td:nth-child(5),.upcoming-orders-page .upcoming-order-items-table td:nth-child(6){display:none!important}.upcoming-orders-page .upcoming-order-items-table tfoot tr{display:table-row!important}.upcoming-orders-page .upcoming-order-items-table tfoot td{display:table-cell!important}.upcoming-orders-page .qty-minus-btn,.upcoming-orders-page .qty-plus-btn{display:none!important}.upcoming-orders-page .qty-value-btn{border:none!important;background:transparent!important;cursor:default!important}.upcoming-orders-page .qty-controls{justify-content:flex-start}}@media (max-width: 480px){.recommended-order-items-table .col-category{display:none}.recommended-order-items-table th,.recommended-order-items-table td{padding:.3rem .15rem;font-size:.7rem}.recommended-order-items-table th{font-size:.58rem}.recommended-order-items-table td.num{font-size:.68rem}.recommended-order-items-table .category-cell{font-size:.65rem}.feedback-actions button{min-width:1.2rem;min-height:1.2rem;font-size:.72rem}}@media (max-width: 1200px){.items-table-wrap .items-col-detail{display:none}.items-table-wrap .items-table{min-width:0;width:100%}.items-page .items-table-wrap .items-actions-col--detached,.items-page .items-table-wrap .items-actions-cell--detached{display:none}.items-page .items-name-actions-slot{display:block}.items-page .items-table-wrap td.actions-cell{position:static;right:auto;background:transparent;z-index:auto;box-shadow:none}.items-page .items-table-wrap tbody tr:hover td.actions-cell{background:transparent}.items-table-wrap td.actions-cell{position:sticky;right:0;background:var(--surface);z-index:1;box-shadow:-4px 0 8px -2px #00000014}.items-table-wrap tbody tr:hover td.actions-cell{background:#0969da0f}}.alternatives-page{padding:1rem 0}.alternatives-page.loading,.alternatives-page.error{padding:2rem;text-align:center}.alternatives-intro{margin:.5rem 0 0;color:var(--muted);font-size:.95rem;max-width:560px}.alternatives-page .page-header{flex-wrap:wrap;gap:.75rem}.alternatives-table-wrap{overflow-x:auto;margin-top:1rem}.alternatives-table{width:100%;border-collapse:collapse}.alternatives-table th,.alternatives-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.alternatives-table th{background:#0000000a;font-weight:600;font-size:.85rem}.alternatives-table .col-item{font-weight:500}.alternatives-table .col-alternative .link{color:var(--accent)}.alternatives-table .col-alternative .btn-link{background:none;border:none;color:var(--accent);cursor:pointer;padding:0;font-size:inherit;text-decoration:underline}.alternatives-table .col-alternative .btn-link:hover{color:var(--accent);opacity:.9}.alternatives-table .col-status .status-accepted{color:var(--success, #1a7f37)}.alternatives-table .col-status .status-rejected{color:var(--danger, #cf222e)}.alternatives-table .col-status .status-pending{color:var(--muted)}.alternatives-table .actions-cell{white-space:nowrap}.alternatives-table .actions-cell .btn{margin-right:.25rem;padding:.3rem .5rem;font-size:.85rem}.alternatives-table .btn-accept{color:var(--success, #1a7f37);background:transparent;border:1px solid var(--success, #1a7f37)}.alternatives-table .btn-accept:hover{background:#1a7f371a}.alternatives-table .btn-reject{color:var(--danger, #cf222e);background:transparent;border:1px solid var(--danger, #cf222e)}.alternatives-table .btn-reject:hover{background:#cf222e1a}.alternatives-table .manual-url-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.alternatives-table .manual-url-input{min-width:200px;flex:1;padding:.35rem .5rem;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius)}.alternatives-empty{margin-top:2rem;color:var(--muted);text-align:center}.recipes-page{padding:1rem 0}.recipes-page.loading,.recipes-page.error{padding:2rem;text-align:center}.recipes-page .page-header{flex-wrap:nowrap;align-items:center;gap:.75rem}.recipes-page .page-header h1{flex-shrink:0;margin:0;text-align:left}.recipes-page .page-header-actions{flex-shrink:0;margin-left:auto}.recipes-rescrape-btn{padding:.4rem .8rem;font-size:.9rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.recipes-rescrape-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.recipes-rescrape-btn:disabled{opacity:.6;cursor:not-allowed}.recipes-add-btn{padding:.5rem 1rem;font-size:.9rem;font-family:inherit;background:#e8f4fd;color:#0969da;border:1px solid #b6d9f7;border-radius:var(--radius);cursor:pointer;white-space:nowrap;flex-shrink:0}.recipes-add-btn:hover{background:#d5ebfc;border-color:#91c9f2}.recipes-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:1rem}.recipes-filter-search{flex:1;min-width:12rem;padding:.4rem .6rem;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius)}.recipes-filter-tag,.recipes-filter-star{padding:.4rem .6rem;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.recipes-filter-date{padding:.4rem .6rem;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius)}.recipes-table-wrap{overflow-x:auto;margin-top:1rem;border:1px solid var(--border);border-radius:var(--radius)}.recipes-table{width:100%;border-collapse:collapse;font-size:.9rem}.recipes-table th,.recipes-table td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.recipes-table th{background:var(--surface);font-weight:600;text-align:center}.recipe-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.recipe-sortable:hover{background:#0969da14}.recipes-table tbody tr:last-child td{border-bottom:none}.recipe-row{cursor:pointer}.recipe-row:hover{background:#0969da0a}.recipe-name{font-weight:500}.recipe-tags-cell{white-space:nowrap}.recipe-tag{display:inline-block;padding:.15rem .4rem;margin-right:.25rem;margin-bottom:.15rem;font-size:.75rem;background:#0969da1a;border-radius:var(--radius);color:var(--accent)}.recipe-ingredients-preview{max-width:200px;color:var(--muted);font-size:.85rem}.recipe-time-col{min-width:8rem;font-weight:500}.recipe-time-cell{font-size:.85rem;color:var(--muted)}.recipe-time-parts{display:flex;flex-direction:column;gap:.15rem}.recipe-time-part{display:block;white-space:nowrap}.recipe-date-cell,.recipe-rating-cell{white-space:nowrap}.recipe-source-rating-col{text-align:center;min-width:4rem;font-weight:500}.recipe-source-rating-cell{text-align:center;font-size:.9rem;color:var(--muted)}.recipe-avg-rating-col{text-align:center;min-width:2.5rem;font-weight:500}.recipe-avg-rating-cell{text-align:center;font-size:.9rem;color:var(--muted)}.recipe-family-rating-col{white-space:nowrap;font-size:.85rem;font-weight:500;min-width:2rem;text-align:center}.recipe-family-rating-cell{text-align:center;color:var(--muted);font-size:.9rem}.recipe-family-ratings{display:inline-flex;flex-wrap:wrap;gap:.5rem;align-items:center}.recipe-family-rating-badge{font-size:.85rem;color:var(--muted);padding:.15rem .4rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.recipe-actions-col{white-space:nowrap;width:1%}.recipe-actions-cell{white-space:nowrap;vertical-align:middle}.recipe-actions-btns{display:flex;align-items:center;gap:.15rem;justify-content:center}.recipe-actions-btns .recipe-action-btn{padding:.35rem;border:none;background:transparent}.recipe-action-btn:hover{color:var(--accent)}.recipe-actions-btns .recipe-action-btn:hover{background:#0969da14}.recipe-action-btn.recipe-action-delete:hover{color:#c00}.recipe-actions-btns .recipe-action-btn.recipe-action-delete:hover{background:#cc000014}.recipes-empty-cell{text-align:center;color:var(--muted);padding:2rem!important}.recipes-list{display:flex;flex-direction:column;gap:1.5rem;margin-top:1.5rem}.recipes-empty{margin-top:2rem;color:var(--muted);text-align:center}.recipe-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.recipe-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.5rem}.recipe-title{margin:0;font-size:1.1rem}.recipe-card-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.recipe-source-link{color:var(--muted);text-decoration:none;font-size:1.1rem}.recipe-source-link:hover{color:var(--accent)}.recipe-edit-btn,.recipe-delete-btn{padding:.25rem .5rem;font-size:.85rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer}.recipe-edit-btn:hover,.recipe-delete-btn:hover{border-color:var(--accent);color:var(--accent)}.recipe-delete-btn:hover{border-color:#c00;color:#c00}.recipe-source-url{display:block;font-size:.8rem;color:var(--muted);margin-bottom:1rem;word-break:break-all}.recipe-body{display:grid;gap:1rem}.recipe-section h4{margin:0 0 .5rem;font-size:.95rem;color:var(--muted)}.recipe-text{margin:0;font-family:inherit;font-size:.9rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.recipe-form-mode-toggle{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.recipe-form-mode-label{font-size:.9rem;font-weight:500}.recipe-form-mode-option{display:inline-flex;align-items:center;gap:.35rem;cursor:pointer;font-size:.9rem}.recipe-modal .modal-body label{display:block;margin-bottom:1rem}.recipe-modal .modal-body label span{display:block;font-size:.9rem;font-weight:500;margin-bottom:.35rem}.recipe-modal .modal-body input,.recipe-modal .modal-body textarea{width:100%;padding:.5rem;font-size:.95rem;border:1px solid var(--border);border-radius:var(--radius)}.recipe-modal .modal-body textarea{resize:vertical;min-height:6rem}.recipe-form-metadata{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.recipe-form-metadata-title{margin:0 0 .75rem;font-size:.95rem;font-weight:600;color:var(--muted)}.recipe-form-metadata-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem 1rem}.recipe-form-metadata-full{grid-column:1 / -1}.recipe-modal .modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.recipe-modal .modal-actions .primary{background:var(--accent);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius);cursor:pointer}.recipe-modal .modal-actions .primary:disabled{opacity:.5;cursor:not-allowed}.recipe-detail{padding:0 0 2rem;max-width:900px;margin:0 auto}.recipe-detail--loading{padding:3rem;text-align:center;color:var(--muted)}.recipe-back-btn{flex-shrink:0;align-self:center;color:var(--muted);text-decoration:none;font-size:.85rem;padding:.35rem .5rem;margin-right:.5rem}.recipe-back-btn:hover{color:var(--accent)}.recipe-detail-hero{display:flex;flex-direction:column;gap:0;margin-bottom:1rem}.recipe-detail-hero-top{position:relative;display:flex;flex-direction:row;flex-wrap:nowrap}.recipe-detail-hero-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:0}.recipe-detail-hero-top:has(.recipe-detail-image-wrap) .recipe-detail-hero-left{margin-right:136px}.recipe-detail-back-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-bottom:.35rem}.recipe-detail-top-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem}.recipe-detail-title-block{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.25rem;flex:0 1 auto}.recipe-detail-title-block .recipe-detail-title{flex:0 1 auto;margin:0}.recipe-detail-actions-row{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.recipe-detail-title-block .recipe-detail-actions{flex-shrink:0}.recipe-detail-date-inline{font-size:.8rem;color:var(--muted);white-space:nowrap}.recipe-detail-image-wrap{position:absolute;top:0;right:0;width:120px;height:120px;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #00000014;background:var(--surface);flex-shrink:0}.recipe-detail-image{display:block;width:100%;height:100%;object-fit:cover;border-radius:12px}.recipe-detail-image-btn{cursor:pointer;border:none;padding:0;font:inherit}.recipe-detail-image-btn:hover{opacity:.9}.image-hover-wrap{display:inline-block;position:relative}.recipe-detail-image-wrap .image-hover-wrap{display:block;width:100%;height:100%}.image-hover-popup{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#000000bf;padding:2rem;pointer-events:none}.image-hover-popup img{max-width:90vw;max-height:90vh;width:auto;height:auto;object-fit:contain;border-radius:12px;box-shadow:0 12px 40px #0000004d}.recipe-image-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#000000d9;cursor:pointer;padding:2rem}.recipe-image-popup-overlay .recipe-image-popup-img{max-width:90vw;max-height:90vh;width:auto;height:auto;object-fit:contain;border-radius:12px;box-shadow:0 12px 40px #0000004d;cursor:default}.recipe-video-panel{margin-bottom:1.5rem}.recipe-video-content.recipe-accordion-content{padding:0}.recipe-video-content .recipe-video-embed{border-radius:0;box-shadow:none}.recipe-video-title{margin:0 0 .75rem;font-size:1.1rem;font-weight:600;color:var(--text)}.recipe-video-embed{position:relative;width:100%;padding-bottom:56.25%;border-radius:12px;overflow:hidden;background:var(--surface);box-shadow:0 4px 20px #00000014}.recipe-video-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.recipe-detail-title{margin:0;font-size:1.5rem;font-weight:700;line-height:1.25;letter-spacing:-.02em;flex:1;min-width:150px}.recipe-detail-actions{display:flex;flex-wrap:wrap;gap:.5rem}.recipe-detail-actions.recipe-detail-actions-icons .recipe-action-btn{padding:.4rem;min-width:36px;min-height:36px;justify-content:center;border:none;background:none}.recipe-detail-actions.recipe-detail-actions-icons .recipe-action-btn:hover{background:#0969da14}.recipe-detail-actions.recipe-detail-actions-icons .recipe-action-btn.recipe-action-delete:hover{background:#cc000014}.recipe-detail-key-ingredients{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.35rem}.recipe-detail-tags-unified{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem 1rem;margin-top:.5rem;width:100%}.recipe-tag-category{display:inline-flex;flex-wrap:wrap;align-items:center;gap:.3rem .5rem}.recipe-tag-category-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-right:.15rem}.recipe-tag-dietary{background:#228b2226;color:#1a6b1a}.recipe-tag-ingredient,.recipe-tag-ingredient[data-tooltip]{position:relative;cursor:default}.recipe-tag-ingredient[data-tooltip]:hover:after,.recipe-tag[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:.4rem .65rem;background:#000000e6;color:#fff;font-size:.8rem;white-space:normal;max-width:220px;border-radius:6px;z-index:10002;margin-bottom:6px;pointer-events:none;box-shadow:0 4px 12px #0003}.recipe-tag-ingredient{background:#0969da1f;color:var(--accent)}.recipe-tag-meta{background:#64748b26;color:#475569}.recipe-detail-ratings-inline{display:flex;flex-wrap:nowrap;align-items:center;gap:.5rem;min-width:0;flex:1 1 auto;justify-content:flex-end;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.recipe-detail-ratings-inline::-webkit-scrollbar{display:none}.recipe-ratings-panel{display:inline-flex;flex-wrap:nowrap;align-items:center;gap:.35rem .45rem;padding:.3rem .5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);white-space:nowrap;flex-shrink:0}.recipe-family-rating-inline{display:inline-flex;align-items:center;gap:.25rem}.recipe-rating-num{font-size:.8rem;color:var(--muted);white-space:nowrap;flex-shrink:0}.recipe-rating-num.recipe-rating-avg{font-weight:700}.recipe-rating-num.recipe-source-rating{white-space:nowrap;flex-shrink:0}.recipe-ratings-edit-btn{display:inline-flex;align-items:center;padding:.2rem;margin-left:.15rem;background:none;border:none;color:var(--muted);cursor:pointer;border-radius:var(--radius);flex-shrink:0}.recipe-ratings-edit-btn:hover{color:var(--accent)}.recipe-ratings-modal-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.recipe-ratings-modal-row:last-child{border-bottom:none}.recipe-ratings-modal-label{font-size:.95rem;font-weight:500}.recipe-meta-rate-label{font-size:.8rem;color:var(--muted);margin-right:.15rem}.recipe-detail-meta-tags-row{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .75rem;margin-top:.5rem}.recipe-tag-meta{background:#0969da14;color:var(--accent);border:1px solid rgba(9,105,218,.2)}.recipe-action-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.85rem;font-weight:500;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;text-decoration:none;font-family:inherit}.recipe-action-btn:hover{border-color:var(--accent);color:var(--accent);background:#0969da0f}.recipe-action-btn.recipe-action-source{color:var(--accent)}.recipe-action-btn.recipe-action-delete:hover{border-color:#c00;color:#c00;background:#cc00000f}.recipe-action-btn.recipe-action-rescrape{font-size:.85rem}.recipe-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:1.25rem;padding:1rem 1.25rem;margin-bottom:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:12px}.recipe-detail-meta-inline{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.recipe-meta-tags{display:flex;flex-wrap:wrap;gap:.35rem}.recipe-meta-ratings{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.recipe-meta-rate-section{display:flex;align-items:center;gap:.5rem}.recipe-meta-rate-label{font-size:.85rem;font-weight:500;color:var(--muted)}.recipe-meta-family{display:flex;flex-wrap:wrap;gap:.35rem}.recipe-meta-date{margin-left:auto;font-size:.85rem;color:var(--muted)}.recipe-detail-description{margin-bottom:1rem;padding:.875rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:12px}.recipe-strapline,.recipe-description-text{margin:0 0 .5rem;font-size:.9rem;line-height:1.55;color:var(--text);font-weight:400}.recipe-time-bar-chart{margin-top:.75rem}.recipe-time-bar{display:flex;height:36px;border-radius:8px;overflow:hidden;background:var(--border)}.recipe-time-bar-segment{min-width:52px;transition:width .2s ease;display:flex;align-items:center;justify-content:center;padding:0 .35rem}.recipe-time-bar-segment.time-freeze{background:#3a6d82}.recipe-time-bar-segment.time-prep{background:#4d8499}.recipe-time-bar-segment.time-cook{background:#629bb0}.recipe-time-bar-segment.time-other{background:#76b0c4}.recipe-time-bar-label{display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.7rem;font-weight:500;color:#fffffffa;line-height:1.2;text-align:center}.recipe-time-bar-type{font-size:.65rem;text-transform:uppercase;letter-spacing:.02em;opacity:.9}.recipe-time-bar-duration{font-size:.75rem}.recipe-detail-meta-grid{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;font-size:.85rem;color:var(--muted)}.recipe-meta-item strong{color:var(--text);font-weight:500;margin-right:.25rem}.recipe-stars{color:#e6a800}.recipe-rating-stars{display:inline-flex;align-items:center;gap:.1rem}.recipe-rating-stars.compact .recipe-star-btn{padding:.1rem;font-size:.9rem}.recipe-star-btn{background:none;border:none;padding:.2rem;font-size:1rem;color:var(--muted);cursor:default}.recipe-star-btn.filled{color:#e6a800}.recipe-star-btn.clickable{cursor:pointer}.recipe-star-btn.clickable:hover{color:#e6a800}.recipe-date{color:var(--muted);font-size:.9rem}.recipe-detail-tabs{display:flex;gap:.25rem;margin-bottom:1rem;border-bottom:1px solid var(--border)}.recipe-tab{padding:.6rem 1rem;font-size:.95rem;font-weight:500;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;background:none;color:var(--muted);cursor:pointer;font-family:inherit;border-radius:var(--radius) var(--radius) 0 0}.recipe-tab:hover{color:var(--text)}.recipe-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.recipe-detail-body{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}.recipe-detail-body--ingredients,.recipe-detail-body--method{grid-template-columns:1fr}@media (max-width: 768px){.recipe-detail-body{grid-template-columns:1fr}}.recipe-detail-ingredients,.recipe-detail-method{min-width:0}.recipe-section-card{padding:1.25rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:12px}.recipe-section-header-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.recipe-section-header-row .recipe-section-title{margin:0}.recipe-add-missing-btn{font-size:.85rem;padding:.4rem .75rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-weight:500;font-family:inherit}.recipe-add-missing-btn:hover{opacity:.9}.recipe-clear-all-btn{margin-top:.75rem;font-size:.85rem;padding:.35rem .65rem;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.recipe-clear-all-btn:hover{color:var(--text);border-color:var(--muted)}.recipe-add-missing-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:10000;display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:var(--radius);font-size:.9rem;box-shadow:0 4px 20px #00000026;animation:recipe-toast-in .2s ease-out}@keyframes recipe-toast-in{0%{opacity:0;transform:translate(-50%) translateY(.5rem)}to{opacity:1;transform:translate(-50%) translateY(0)}}.recipe-add-missing-toast.success{background:#008000f2;color:#fff}.recipe-add-missing-toast.error{background:#b40000f2;color:#fff}.recipe-add-missing-toast a{color:inherit;font-weight:500;margin-left:.5rem;text-decoration:underline}.recipe-section-title{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:var(--text);letter-spacing:-.01em}.recipe-ingredients-plain,.recipe-text{margin:0;font-size:.95rem;line-height:1.6;white-space:pre-wrap;word-break:break-word}.recipe-method-steps{margin:0}.recipe-method-header{margin:0 0 .75rem;font-size:1.1rem;font-weight:600;color:var(--text)}.recipe-method-header:not(:first-child){margin-top:1.5rem}.recipe-method-step{position:relative;margin-bottom:1rem;line-height:1.55}.recipe-method-step.has-num{padding-left:1.5rem}.recipe-method-step:last-child{margin-bottom:0}.recipe-step-num{position:absolute;left:-1.5rem;font-weight:600;color:var(--accent);font-size:.9rem}.recipe-step-text{display:block}.recipe-method-with-images .recipe-method-step-block{margin-bottom:1.5rem}.recipe-method-with-images .recipe-method-step-block:last-child{margin-bottom:0}.recipe-method-with-images .recipe-method-step-text{margin:0 0 .75rem;line-height:1.6}.recipe-method-step-images{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.recipe-method-step-img{max-width:100%;height:auto;border-radius:var(--radius);object-fit:cover;max-height:280px}.recipe-ingredients-structured{margin-bottom:0}.recipe-servings-display{font-size:.9rem;color:var(--text);margin-bottom:.75rem}.recipe-servings-note{font-size:.8rem;color:var(--muted);font-weight:400}.recipe-ingredients-controls{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.recipe-unit-buttons{display:flex;gap:.25rem}.recipe-unit-btn{padding:.35rem .65rem;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer}.recipe-unit-btn:hover{border-color:var(--accent)}.recipe-unit-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.recipe-units-label{font-size:.9rem;font-weight:500;color:var(--muted)}.recipe-quantity-buttons{display:flex;gap:.25rem}.recipe-qty-btn{padding:.35rem .65rem;font-size:.9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer}.recipe-qty-btn:hover{border-color:var(--accent)}.recipe-qty-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.recipe-ingredients-list{list-style:none;margin:0;padding:0}.recipe-ingredients-plain .recipe-ingredient-text{font-size:.95rem;line-height:1.5;white-space:pre-wrap}.recipe-ingredient-section{margin-bottom:1rem}.recipe-ingredient-section-title{margin:0 0 .5rem;font-size:.95rem;font-weight:600;color:var(--muted)}.recipe-ingredient-section ul{list-style:none;margin:0;padding:0}.recipe-ingredient-item{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.35rem}.recipe-ingredient-checkbox{flex-shrink:0;margin-top:.25rem}.recipe-ingredient-item .recipe-ingredient-text{flex:1;min-width:0;font-size:.95rem;line-height:1.5}.recipe-thumb-col{width:60px}.recipe-thumb-cell{padding:.35rem!important;vertical-align:middle}.recipe-thumb{width:48px;height:48px;object-fit:cover;border-radius:var(--radius);display:block}.recipe-thumb-placeholder{display:inline-block;width:48px;height:48px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);color:var(--muted);font-size:.8rem;line-height:48px;text-align:center}.recipe-accordion-standalone{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.recipe-accordion{display:flex;flex-direction:column;gap:.25rem}.recipe-accordion-panel{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.recipe-accordion-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.65rem 1rem;background:var(--surface);border:none;cursor:pointer;font-size:.95rem;font-weight:600;color:inherit;text-align:left}.recipe-accordion-trigger:hover{background:var(--bg)}.recipe-accordion-icon{font-size:1.1rem;color:var(--muted)}.recipe-accordion-content{padding:1rem;background:var(--bg);border-top:1px solid var(--border);font-size:.9rem;line-height:1.5}.recipe-accordion-content p{margin:0 0 .5rem}.recipe-accordion-content p:last-child{margin-bottom:0}.recipe-nutrition-row{display:flex;justify-content:space-between;padding:.25rem 0;border-bottom:1px solid var(--border)}.recipe-nutrition-row:last-child{border-bottom:none}.recipe-nutrition-label{color:var(--muted)}.recipe-faq-item{margin-bottom:.75rem}.recipe-faq-item strong{display:block;margin-bottom:.25rem}.meal-planner-page{padding:1rem}.meal-planner-toast{position:fixed;top:1rem;right:1rem;z-index:1200;display:flex;align-items:center;gap:.75rem;max-width:min(560px,calc(100vw - 2rem));padding:.7rem .9rem;border-radius:var(--radius);border:1px solid #f0b3b3;background:#fff1f1;color:#7a1f1f;box-shadow:0 8px 24px #00000029}.meal-planner-toast-close{border:none;background:transparent;color:inherit;font-size:1.1rem;line-height:1;cursor:pointer;padding:0}.meal-planner-page .btn,.meal-planner-page .btn-primary,.meal-planner-page .btn-secondary{padding:.5rem 1rem;font-size:.9rem;font-family:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-weight:700;line-height:1}.meal-planner-page .btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.meal-planner-page .btn-secondary{background:var(--bg);color:var(--accent);border-color:var(--accent)}.meal-planner-page .btn:hover:not(:disabled),.meal-planner-page .btn-primary:hover:not(:disabled),.meal-planner-page .btn-secondary:hover:not(:disabled){filter:brightness(1.08)}.meal-planner-page .btn:disabled,.meal-planner-page .btn-primary:disabled,.meal-planner-page .btn-secondary:disabled{opacity:.6;cursor:not-allowed}.meal-planner-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:1rem;align-items:start}.meal-planner-grid--single{grid-template-columns:1fr}.meal-planner-weeks-col{display:flex;flex-direction:column;gap:1rem}.meal-planner-week{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:.9rem}.meal-planner-week-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.5rem}.meal-planner-week-title{margin:0;font-size:1.1rem}.meal-planner-week-delete-btn{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:999px;padding:.35rem .65rem;cursor:pointer;font-size:.9rem;font-weight:700}.meal-planner-week-delete-btn:hover{border-color:var(--accent);background:#0969da0f}.meal-planner-week-subtab-bar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.5rem;border-bottom:1px solid var(--border);padding-bottom:.25rem;margin-bottom:1rem}.meal-planner-week-subtab-btn{padding:.45rem .9rem .6rem;cursor:pointer;font-size:.95rem;font-weight:500;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--muted);border-radius:var(--radius) var(--radius) 0 0}.meal-planner-week-subtab-btn:hover{color:var(--text);background:#00000008}.meal-planner-week-subtab-btn.active{color:var(--accent);background:transparent;border-bottom-color:var(--accent);font-weight:600}.meal-planner-days-grid{display:flex;flex-direction:column;gap:.75rem;padding-bottom:.25rem}.meal-planner-week{display:grid;grid-template-columns:1fr .55fr;gap:1rem}.meal-planner-week-header{grid-column:1 / -1}.meal-planner-weekly-snacks{border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:var(--bg);padding:.75rem;align-self:start;position:sticky;top:1rem}.meal-planner-weekly-snacks-title{font-weight:800;color:var(--text);margin-bottom:.25rem}.meal-planner-weekly-snacks-hint{color:var(--muted);font-size:.85rem;margin-bottom:.75rem;line-height:1.3}.meal-planner-weekly-snacks-actions{display:flex;gap:.5rem;margin-bottom:.75rem}.meal-planner-day-col{display:flex;flex-direction:column;gap:.5rem;width:100%;padding:.75rem;border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:var(--bg)}.meal-planner-day-name{color:var(--muted);font-weight:700;font-size:.95rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}.meal-planner-day-body{display:grid;grid-template-columns:1fr;gap:.75rem;align-items:start}.meal-planner-day-section--snacks{border-left:1px solid var(--border);padding-left:.75rem}.meal-planner-day-section-title{font-size:.8rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.35rem}.meal-planner-day-section-empty{color:var(--muted);font-size:.9rem;font-style:italic;padding:.25rem 0}.meal-planner-slot-list{display:flex;flex-direction:column;gap:.4rem}.meal-planner-slot-row{display:grid;grid-template-columns:60px 1fr 54px;gap:.3rem;align-items:center}.meal-planner-slot-label{color:var(--muted);font-size:.85rem;font-weight:700;line-height:1.2}.meal-planner-recipe-select,.meal-planner-multiplier-select,.meal-planner-unit-select{width:100%;padding:.45rem .65rem;font-size:.95rem;min-height:36px;border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px}.meal-planner-slot-row--saving{background:#0969da0f;border-radius:10px;outline:1px solid rgba(9,105,218,.25);outline-offset:-2px}.meal-planner-unit-toggle{display:inline-flex;align-items:center;gap:.5rem;font-size:.95rem}.meal-planner-ingredients-col{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:.9rem;position:sticky;top:1rem}.meal-planner-tabs{display:flex;gap:0;align-items:flex-end;border-bottom:1px solid var(--border);padding-bottom:0;margin-right:auto}.meal-planner-tab-btn{padding:.65rem 1.1rem .75rem;cursor:pointer;font-size:.95rem;font-weight:500;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--muted);border-radius:var(--radius) var(--radius) 0 0}.meal-planner-tab-btn.active{color:var(--accent);background:transparent;border-bottom-color:var(--accent);font-weight:600}.meal-planner-tab-btn:hover{color:var(--text);background:#00000008}.meal-planner-ingredients-title{margin:0 0 .75rem;font-size:1.1rem}.meal-planner-ingredient-row{padding:.55rem 0;border-bottom:1px solid var(--border)}.meal-planner-ingredient-row:last-child{border-bottom:none}.meal-planner-ingredient-name{font-weight:700;margin-bottom:.25rem}.meal-planner-ingredient-comment{color:var(--muted);font-size:.9rem;line-height:1.35;white-space:pre-wrap}.meal-planner-empty p{margin:0 0 .75rem;color:var(--muted)}.meal-planner-ingredients-loading,.meal-planner-skipped p{color:var(--muted)}@media (max-width: 980px){.meal-planner-grid{grid-template-columns:1fr}.meal-planner-ingredients-col{position:static}.meal-planner-days-grid{flex-direction:column}.meal-planner-day-body{grid-template-columns:1fr}.meal-planner-day-section--snacks{border-left:none;padding-left:0;border-top:1px solid var(--border);padding-top:.75rem;margin-top:.25rem}.meal-planner-week{grid-template-columns:1fr}.meal-planner-weekly-snacks{position:static}}:root{--bg: #ffffff;--surface: #f6f8fa;--surface-raised: #eef1f5;--surface-elevated: #ffffff;--card-bg: #ffffff;--border: #d0d7de;--border-subtle: #e8ecf0;--text: #1f2328;--muted: #656d76;--accent: #0969da;--accent-hover: #0550ae;--accent-ring: rgba(9, 105, 218, .2);--success: #1a7f37;--warn: #9a6700;--danger: #cf222e;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);color-scheme:light}*{box-sizing:border-box}body{margin:0;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}#root{min-height:100vh;min-height:100dvh}:root{--mobile-header-h: 3.25rem;--mobile-nav-h: 4rem;--mobile-shell-top: var(--mobile-header-h);--mobile-shell-bottom: var(--mobile-nav-h)}@media (max-width: 768px){.app-layout{flex-direction:column;min-height:100dvh;padding-top:calc(var(--mobile-shell-top) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--mobile-shell-bottom) + env(safe-area-inset-bottom,0px))}.app-layout .hamburger,.app-layout .sidebar,.app-layout .sidebar-backdrop{display:none!important}.app-layout .profile-trigger{display:none}.app-layout .main-content{margin-left:0!important;padding:0!important;flex:1;min-height:0}.app-layout .app,.app-layout .app--full-width{padding:.75rem max(.75rem,env(safe-area-inset-left)) max(1rem,env(safe-area-inset-bottom)) max(.75rem,env(safe-area-inset-right))}.app-layout .page-header{padding-top:.25rem}.app-layout .page-header h1{font-size:1.35rem}.app-layout .back-to-top{bottom:calc(var(--mobile-shell-bottom) + env(safe-area-inset-bottom,0px) + .75rem);right:max(.75rem,env(safe-area-inset-right))}}.mobile-header,.mobile-page-title-bar{display:none}@media (max-width: 768px){.mobile-header{display:grid;grid-template-columns:40px 1fr 40px;align-items:center;gap:.5rem;position:fixed;top:0;left:0;right:0;z-index:1002;height:var(--mobile-header-h);padding:env(safe-area-inset-top,0px) max(.75rem,env(safe-area-inset-right)) 0 max(.75rem,env(safe-area-inset-left));background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);overflow:visible}.mobile-header-menu{display:inline-flex;justify-self:start;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:40px;height:40px;padding:0;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);color:var(--text);cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;text-decoration:none}.mobile-header-menu span{display:block;width:16px;height:2px;background:currentColor;border-radius:1px}.mobile-header-menu.active{color:var(--accent);border-color:#0969da59;background:#0969da14}.mobile-header-logo-wrap{display:flex;align-items:center;justify-content:flex-start;justify-self:start;gap:.5rem;min-width:0;-webkit-tap-highlight-color:transparent;text-decoration:none}.mobile-header-logo{flex-shrink:0;border-radius:8px}.mobile-header-brand-text{font-size:1.05rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:linear-gradient(135deg,#0969da,#218bff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mobile-page-title-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem max(.75rem,env(safe-area-inset-right)) .75rem max(.75rem,env(safe-area-inset-left));margin:0 0 .25rem}.mobile-page-back{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);color:var(--text);text-decoration:none;-webkit-tap-highlight-color:transparent}.mobile-page-back svg{width:20px;height:20px}.mobile-page-back:active{background:#0969da14;border-color:#0969da59}.mobile-page-title-row{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.mobile-page-title{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;min-width:0;background:linear-gradient(135deg,#0969da,#218bff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mobile-page-title-actions{flex-shrink:0;display:inline-flex;align-items:center}.mobile-page-title-actions .recommended-order-print-btn{width:2rem;height:2rem}.mobile-page-title-actions .add-order-btn--inline{padding:.35rem .65rem;font-size:.8rem}.mobile-header-profile-wrap{position:relative;flex-shrink:0;justify-self:end}.mobile-header-profile{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer}.mobile-header-profile svg{width:20px;height:20px}.mobile-profile-menu{position:absolute;top:calc(100% + .35rem);right:0;z-index:1005;min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000001f;padding:.75rem;display:flex;flex-direction:column;gap:.25rem}}.mobile-bottom-nav{display:none}@media (max-width: 768px){.mobile-bottom-nav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;bottom:0;left:0;right:0;z-index:1002;height:calc(var(--mobile-nav-h) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:#fffffff5;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);box-shadow:0 -4px 20px #0000000f}.mobile-nav-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;padding:.35rem .15rem;border:none;background:transparent;color:var(--muted);text-decoration:none;font:inherit;font-size:.65rem;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;min-height:44px;position:relative;transition:color .15s}.mobile-nav-tab.active{color:var(--accent)}.mobile-nav-tab.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:3px;background:var(--accent);border-radius:0 0 3px 3px}.mobile-nav-tab:active{opacity:.7}.mobile-nav-icon{display:inline-flex;width:24px;height:24px}.mobile-nav-icon svg{width:100%;height:100%}.mobile-nav-label{line-height:1.1}}.mobile-nav-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1003;background:#00000059}.mobile-nav-drawer{position:fixed;top:0;left:0;bottom:0;z-index:1004;width:min(280px,85vw);padding:calc(var(--mobile-header-h) + env(safe-area-inset-top,0px) + .5rem) 1rem 1.5rem max(1rem,env(safe-area-inset-left));background:var(--surface);border-right:1px solid var(--border);box-shadow:8px 0 32px #0000001f;animation:mobile-drawer-in .22s ease-out;overflow-y:auto}.mobile-nav-drawer-close{position:absolute;top:calc(env(safe-area-inset-top,0px) + .5rem);right:.75rem;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:0;background:none;color:var(--muted);font-size:1.75rem;line-height:1;cursor:pointer;outline:none;-webkit-tap-highlight-color:transparent}.mobile-nav-drawer-close:hover{color:var(--text)}.mobile-nav-drawer-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius)}@keyframes mobile-drawer-in{0%{transform:translate(-100%)}to{transform:translate(0)}}.mobile-nav-drawer-links{display:flex;flex-direction:column;gap:.25rem}.mobile-nav-drawer-links a{display:flex;align-items:center;gap:.75rem;padding:.85rem .75rem;border-radius:var(--radius-lg);color:var(--text);text-decoration:none;font-weight:500;font-size:1rem;transition:background .15s}.mobile-drawer-link-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius);background:var(--surface);color:var(--muted);flex-shrink:0}.mobile-drawer-link-icon svg{width:18px;height:18px}.mobile-nav-drawer-links a.active .mobile-drawer-link-icon{color:var(--accent);background:#0969da1a}.mobile-nav-drawer-links a.active{color:var(--accent);background:#0969da14}.pwa-install-banner{position:fixed;left:max(.75rem,env(safe-area-inset-left));right:max(.75rem,env(safe-area-inset-right));bottom:calc(var(--mobile-nav-h) + env(safe-area-inset-bottom,0px) + .5rem);z-index:1001;display:flex;flex-direction:column;gap:.75rem;padding:.85rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px #0000001f}.pwa-install-text{display:flex;flex-direction:column;gap:.2rem;font-size:.85rem}.pwa-install-text strong{font-size:.95rem}.pwa-install-text span{color:var(--muted)}.pwa-install-actions{display:flex;gap:.5rem}.btn-sm{padding:.45rem .85rem;font-size:.85rem}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text);border-radius:var(--radius);cursor:pointer;font-family:inherit;font-weight:500}@media (max-width: 768px){.orders-page .page-header-actions{flex-wrap:nowrap;overflow-x:auto;max-width:100%;scrollbar-width:none}.orders-page .page-header-actions::-webkit-scrollbar{display:none}.orders-page .orders-table--compact th,.orders-page .orders-table--compact td{padding:.45rem .25rem}.orders-page .orders-table--compact th{font-size:.65rem}}@media (min-width: 769px){.pwa-install-banner{left:auto;right:1.5rem;bottom:1.5rem;max-width:320px}}@media (min-width: 769px){.mobile-page-title-bar{display:none}}@media print{.mobile-header,.mobile-page-title-bar,.mobile-bottom-nav,.mobile-nav-drawer-backdrop,.mobile-nav-drawer,.pwa-install-banner{display:none!important}}.page-content{animation:page-enter .28s ease-out}@keyframes page-enter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.page-content,.mobile-nav-drawer,.modal,.items-detail-panel,.toast{animation:none!important;transition:none!important}}.loading-spinner{display:inline-block;width:1.75rem;height:1.75rem;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;padding:3rem 1.5rem;color:var(--muted);min-height:40vh}.loading-state .loading-spinner{width:2rem;height:2rem}.skeleton{background:linear-gradient(90deg,var(--surface) 0%,var(--surface-raised) 50%,var(--surface) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.4s ease-in-out infinite;border-radius:var(--radius)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{height:4.5rem;margin-bottom:.5rem}.skeleton-card--tall{height:6rem}.toast-stack{position:fixed;top:calc(var(--mobile-header-h, 3.25rem) + env(safe-area-inset-top,0px) + .5rem);left:max(.75rem,env(safe-area-inset-left));right:max(.75rem,env(safe-area-inset-right));z-index:3000;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{display:flex;align-items:center;gap:.5rem;padding:.75rem .85rem;background:var(--surface-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);font-size:.9rem;pointer-events:auto;animation:toast-in .25s ease-out}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.toast--success{border-color:#1a7f374d;background:#f0fdf4}.toast--error{border-color:#cf222e4d;background:#fff5f5}.toast--warn{border-color:#9a67004d;background:#fffbeb}.toast-message{flex:1;min-width:0}.toast-dismiss{flex-shrink:0;width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--muted);font-size:1.2rem;line-height:1;cursor:pointer;border-radius:var(--radius)}@media (min-width: 769px){.toast-stack{top:auto;bottom:1.5rem;left:auto;right:1.5rem;max-width:360px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.55rem 1rem;font-size:.9rem;font-family:inherit;font-weight:600;border-radius:var(--radius-lg);border:1px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;-webkit-tap-highlight-color:transparent;min-height:44px}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn:disabled{opacity:.55;cursor:not-allowed}.search,.recipes-filter-search,.items-search-input{border-radius:var(--radius-full)!important;padding-left:1rem!important;padding-right:1rem!important;background:var(--surface)!important;transition:border-color .15s,box-shadow .15s}.search:focus,.recipes-filter-search:focus,.items-search-input:focus{box-shadow:0 0 0 3px var(--accent-ring)}.app-card{background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1rem}@media (max-width: 768px){.app-layout .orders-page-title-row{display:none}.app-layout .page-header-left h1,.app-layout .page-header>h1,.app-layout .orders-page-title-row h1,.app-layout .order-detail-header h1,.app-layout .product-header h1,.app-layout .recipe-detail-title{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-layout .page-header .back-link,.app-layout .page-header-left .back-link,.app-layout .order-detail-nav,.app-layout .recipe-detail-back-row,.app-layout .product-page-header .back-btn{display:none}.app-layout .page-header{margin-bottom:.75rem;gap:.5rem}.app-layout .page-header .toolbar,.app-layout .page-header-actions{width:100%}.app-layout .recommended-order-detail-header{display:none}.modal-backdrop{align-items:flex-end;padding:0;overscroll-behavior:none}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:92dvh;max-width:none;width:100%;animation:sheet-up .3s cubic-bezier(.32,.72,0,1);padding-bottom:env(safe-area-inset-bottom,0px);overflow:hidden}.upcoming-add-modal .modal-body{min-width:0;max-width:none}.upcoming-add-modal .upcoming-items-picker{max-height:none}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{padding:1.25rem 1.25rem .75rem;position:relative}.modal-header:before{content:"";display:block;width:36px;height:4px;background:var(--border);border-radius:2px;position:absolute;top:.5rem;left:50%;transform:translate(-50%);margin:0}.modal-header h3{text-align:left}.orders-page .orders-table-wrap--compact{overflow-x:auto!important;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.orders-table-wrap--compact .orders-table{display:table;width:max-content;min-width:100%}.orders-table-wrap--compact .orders-table thead{display:table-header-group}.orders-table-wrap--compact .orders-table tbody{display:table-row-group}.orders-table-wrap--compact .orders-table tr.order-row{display:table-row;padding:0;background:transparent;border:none;border-radius:0;box-shadow:none;position:static}.orders-table-wrap--compact .orders-table tr.order-row:active{box-shadow:none;border-color:transparent}.orders-table-wrap--compact .orders-table tr.order-row td{display:table-cell;padding:.45rem .35rem;border-bottom:1px solid var(--border);font-size:inherit;color:inherit}.orders-table-wrap--compact .orders-table tr.order-row td:first-child{font-size:inherit;font-weight:inherit}.orders-table-wrap--compact .orders-table tr.order-row td.num{display:table-cell}.orders-table-wrap--compact .orders-table tr.order-row td.num:before{content:none!important}.orders-table-wrap--compact .orders-table tr.order-row td.view-cell{position:static;transform:none}.orders-table-wrap--compact .orders-table tr.order-row .order-link{pointer-events:auto}.orders-table-wrap--compact .orders-table tr.order-row .view-btn--icon{width:2rem;height:2rem;border-radius:var(--radius)}.recipes-page .recipes-table tbody tr.recipe-row{display:grid;grid-template-columns:1fr auto;gap:.35rem .5rem;padding:.85rem 1rem;margin-bottom:.5rem;background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.recipes-page .recipes-table thead{display:none}.recipes-page .recipes-table tbody{display:flex;flex-direction:column}.recipes-page .recipes-table{display:block}.recipes-page .recipes-table-wrap{overflow:visible}.recipes-page .recipes-table tr.recipe-row td{display:block;padding:0;border:none}.recipes-page .recipes-table tr.recipe-row td.recipe-name{grid-column:1 / -1;font-size:1rem;font-weight:600}.recipes-page .recipes-table tr.recipe-row .recipe-actions-col,.recipes-page .recipes-table tr.recipe-row .recipe-date-col,.recipes-page .recipes-table tr.recipe-row .recipe-avg-rating-col,.recipes-page .recipes-table tr.recipe-row .recipe-time-col{display:none}.recipes-page .recipes-table tr.recipe-row .recipe-tags-cell{grid-column:1;font-size:.8rem}.recipes-page .recipes-table tr.recipe-row .recipe-ingredients-preview{grid-column:1 / -1;font-size:.8rem;color:var(--muted);-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.toolbar .btn,.page-header-actions .btn,.scrape-btn,.recipes-add-btn,.recipes-rescrape-btn,.add-order-btn{min-height:44px}.orders-chart-section{margin-bottom:.75rem}.orders-chart-wrap{height:200px!important}.product-page .product-header{background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-sm)}.settings-page .settings-section{background:var(--card-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1rem;margin-bottom:.75rem;box-shadow:var(--shadow-sm)}.recipes-filters,.orders-filters-row{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:.25rem}.recipes-filters::-webkit-scrollbar,.orders-filters-row::-webkit-scrollbar{display:none}.recipes-filters>*,.orders-filters-row>*{flex-shrink:0}}
