:root{--bg: #0b1828;--bg-card: #111f33;--bg-dark: #0c1a2c;--brand: #2f86d6;--brand-dark: #0F2744;--brand-muted: rgba(47, 134, 214, .15);--gold: #34c4e3;--gold-muted: rgba(52, 196, 227, .12);--heading: #eaf1fb;--text: #dce7f3;--text-mid: #9fb6d0;--text-muted: #7089a6;--text-inverse: #eaf1fb;--border: rgba(255, 255, 255, .08);--border-dark: #284866;--danger: #f0707a;--warning: #f2b450;--warning-bg: rgba(242, 180, 80, .13);--success: #56d08a;--success-bg: rgba(86, 208, 138, .13);--radius-sm: 4px;--radius-md: 10px;--radius-lg: 18px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .5)}body{background-color:var(--bg);background-image:radial-gradient(circle at 30% 0%,#15263d,#0b1828 55%,#081320);background-attachment:fixed;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.5}h1,h2,h3,h4{font-family:Playfair Display,Georgia,serif;color:var(--heading)}.app{display:flex;flex-direction:row;min-height:100vh}.sidebar{width:224px;min-width:224px;background:var(--bg-dark);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:2rem 0 1.5rem;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;gap:.6rem;font-family:Inter,sans-serif;font-style:normal;font-size:1.1rem;font-weight:600;color:var(--text-inverse);padding:0 1.25rem 2rem;letter-spacing:.01em}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:0 .5rem}.sidebar-nav-item{background:none;border:none;border-left:3px solid transparent;color:#eef4fba6;padding:.65rem .85rem;font-size:.78rem;font-weight:500;text-transform:uppercase;letter-spacing:.07em;display:flex;align-items:center;gap:.6rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0;transition:all .15s;text-align:left;width:100%}.sidebar-nav-item:hover{color:var(--text-inverse);background:#eef4fb14}.sidebar-nav-item.active{border-left-color:var(--accent, var(--gold));color:var(--accent, var(--gold));background:color-mix(in srgb,var(--accent, var(--gold)) 14%,transparent)}.sidebar-nav-icon{display:inline-flex;align-items:center;flex-shrink:0}.main-content{flex:1;overflow-y:auto;background:transparent;padding:40px;min-width:0}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:.85rem;border-bottom:1px solid color-mix(in srgb,var(--accent, var(--gold)) 30%,transparent)}.section-header .section-title{color:var(--accent, var(--gold))}.section-title{font-family:Playfair Display,Georgia,serif;font-size:1.6rem;font-weight:400;color:var(--heading)}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:1.5rem;margin-bottom:1.25rem}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.card-title{font-family:Playfair Display,Georgia,serif;font-size:1.1rem;color:var(--heading)}table{width:100%;border-collapse:collapse;font-size:.9rem}th{background:var(--bg-dark);color:var(--text-inverse);padding:.65rem .85rem;text-align:left;font-weight:500;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}th:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}th:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}td{padding:.6rem .85rem;border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr:nth-child(2n) td{background:var(--gold-muted)}tbody tr:hover td{background:var(--brand-muted)}.row-missing td{background:var(--warning-bg)!important}.row-total td{background:var(--bg-card);font-weight:600}.row-stocked td{font-style:italic;color:var(--text-muted)}.row-stocked-divider td{border-top:2px dashed var(--border)!important}.row-bought td{text-decoration:line-through;color:var(--text-muted)}.col-check{width:1%;white-space:nowrap;text-align:center;padding-left:.6rem;padding-right:.25rem}.col-check input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent, var(--brand));vertical-align:middle}.row-stocked-toggle td{background:transparent!important;padding:.35rem .85rem}.btn-link-toggle{background:none;border:none;padding:.2rem 0;cursor:pointer;color:var(--text-muted);font-family:inherit;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.btn-link-toggle:hover{color:var(--accent, var(--brand))}.badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.73rem;padding:.2rem .55rem;border-radius:var(--radius-full);font-weight:600;letter-spacing:.03em}.badge-warn{background:var(--warning-bg);color:var(--warning)}.badge-ok,.badge-green{background:var(--success-bg);color:var(--success)}.badge-yellow{background:var(--warning-bg);color:var(--warning)}.badge-red{background:#f0707a26;color:var(--danger)}.badge-stocked{background:var(--brand-muted);color:var(--gold);font-size:.68rem;margin-left:.5rem;padding:.1rem .5rem;text-transform:uppercase;letter-spacing:.04em}.cost-green{color:var(--success);font-weight:600}.cost-yellow{color:var(--warning);font-weight:600}.cost-red{color:var(--danger);font-weight:600}.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem 1rem;border-radius:var(--radius-sm);border:none;font-size:.85rem;font-weight:500;font-family:inherit;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{filter:brightness(1.12)}.btn-secondary{background:transparent;color:var(--brand);border:1.5px solid var(--brand)}.btn-secondary:hover{background:var(--brand);color:#fff}.btn-danger{background:transparent;color:var(--danger);border:1.5px solid var(--danger)}.btn-danger:hover{background:var(--danger);color:var(--bg)}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-mid)}.btn-ghost:hover{background:var(--brand-muted)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{filter:brightness(1.08)}.btn:disabled,.btn:disabled:hover{opacity:.45;cursor:not-allowed;filter:none}.btn-sm{padding:.25rem .65rem;font-size:.8rem}.btn-icon{padding:.3rem;justify-content:center;line-height:0}.btn-icon svg{display:block}.litres-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .6rem;border-radius:var(--radius-full);font-weight:600;font-size:.9rem;color:var(--text)}.litres-chip.below-min{background:#f0707a2e;color:var(--danger)}.flavour-online-bar{position:relative;height:5px;border-radius:var(--radius-full);background:var(--border-dark);overflow:hidden}.flavour-online-bar>span{position:absolute;inset:0 auto 0 0;background:var(--brand);border-radius:var(--radius-full)}.form-row{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:.3rem}.form-label{font-size:.78rem;font-weight:600;color:var(--text-mid);text-transform:uppercase;letter-spacing:.05em}input[type=text],input[type=number],input[type=password],input[type=email],input[type=date],input[type=search],select,textarea{padding:.45rem .75rem;border:1px solid var(--border-dark);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;outline:none;background:var(--bg-dark);color:var(--text);transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-muted)}input[type=number]{width:100px}.search-input{padding:.5rem .75rem;border:1px solid var(--border-dark);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;width:100%;max-width:300px;outline:none;background:var(--bg-dark);color:var(--text)}.search-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-muted)}.recipe-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);margin-bottom:.5rem}.recipe-card-header{border-radius:var(--radius-md)}.recipe-card.expanded>.recipe-card-header{border-radius:var(--radius-md) var(--radius-md) 0 0}.recipe-card-header{padding:.85rem 1rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:background .1s}.recipe-card-header:hover{background:var(--gold-muted)}.recipe-name{font-weight:600;flex:1}.recipe-costs{display:flex;gap:.75rem;font-size:.82rem;color:var(--text-muted)}.recipe-body{border-top:1px solid var(--border);padding:1rem}.editable{cursor:pointer}.editable:hover{text-decoration:underline dotted;color:var(--brand)}.inline-edit-input{width:100%;padding:.3rem .5rem;border:1px solid var(--brand);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit}.autocomplete-wrapper{position:relative}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);z-index:100;max-height:200px;overflow-y:auto;box-shadow:var(--shadow-md)}.autocomplete-item{padding:.4rem .75rem;cursor:pointer;font-size:.9rem}.autocomplete-item:hover,.autocomplete-item.is-active{background:var(--brand-muted)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.75rem;max-width:420px;width:90%;box-shadow:var(--shadow-lg)}.dialog h3{margin-bottom:.75rem;font-size:1.15rem}.dialog p{color:var(--text-mid);font-size:.9rem;margin-bottom:1.25rem}.dialog-actions{display:flex;gap:.5rem;justify-content:flex-end}.plan-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.plan-item-name{flex:1;font-weight:500}.plan-item-liters{color:var(--text-muted);font-size:.9rem}.empty{text-align:center;padding:2.5rem;color:var(--text-muted)}.empty-icon{font-size:2.5rem;margin-bottom:.5rem}.plans-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1.5rem;align-items:start}.plan-detail-grid{display:grid;grid-template-columns:1fr 2fr;gap:1.5rem;align-items:start}#plans-grid input[type=number]::-webkit-outer-spin-button,#plans-grid input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}#plans-grid input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.toast-saved{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--success);color:#fff;padding:.5rem 1rem;border-radius:var(--radius-full);font-size:.85rem;font-weight:500;box-shadow:var(--shadow-md);z-index:9999;animation:toast-in .15s ease;pointer-events:none}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mobile-nav,.mobile-header,.mobile-more-overlay,.mobile-more-menu,.print-only{display:none}@media print{@page{margin:1.5cm 2cm;size:A4 portrait}html,body,.app,.main-content,#plans-grid{display:block!important;padding:0!important;margin:0!important;background:#fff!important}.sidebar,.section-header,#plans-left,.mobile-header,.mobile-nav{display:none!important}#plans-grid~*{display:none!important}#shopping-list-panel{display:block!important;width:100%!important;border:none!important;border-radius:0!important;box-shadow:none!important;padding:0!important;margin:0!important;position:static!important;background:#fff!important}.print-hide{display:none!important}.print-only{display:block!important;visibility:visible!important}table{border-collapse:collapse;width:100%;font-size:10pt;font-family:sans-serif}th{text-align:left;font-size:9pt;font-weight:600;padding:8px 10px;border-bottom:2px solid #333;background:none!important;color:#000!important}th:first-child{border-radius:0!important}th:last-child{border-radius:0!important}td{padding:6px 10px;border-bottom:1px solid #ddd}.row-total td{border-top:2px solid #333;border-bottom:none;font-weight:700}.row-missing td{font-style:italic}}.lab-panel-recipe{flex:1 1 380px;min-width:300px}.lab-panel-balance{flex:1.5 1 460px;min-width:320px}@media (max-width: 768px){.sidebar{display:none}.mobile-header{display:flex;align-items:center;justify-content:space-between;background:var(--bg-dark);padding:.6rem 1rem;position:sticky;top:0;z-index:100}.mobile-header .sidebar-logo{font-size:1.1rem;padding:0;color:var(--text-inverse)}.app{flex-direction:column}.main-content{padding:12px 12px 72px;overflow-x:hidden}.mobile-nav{display:flex;flex-wrap:wrap;position:fixed;bottom:0;left:0;right:0;background:var(--bg-dark);border-top:1px solid rgba(255,255,255,.1);z-index:200;justify-content:center;align-items:stretch;padding-bottom:env(safe-area-inset-bottom,0px)}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1 1 0;min-width:0;background:none;border:none;color:#eef4fb73;font-size:.65rem;font-weight:500;font-family:inherit;text-transform:uppercase;letter-spacing:.04em;padding:5px 2px;min-height:44px;cursor:pointer;transition:color .15s}.mobile-nav-item.active{color:var(--accent, var(--gold));position:relative}.mobile-nav-item.active:after{content:"";position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:4px;height:4px;background:var(--accent, var(--gold));border-radius:50%}.mobile-more-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:199;background:transparent}.mobile-more-menu{position:fixed;right:8px;bottom:calc(64px + env(safe-area-inset-bottom,0px));z-index:201;min-width:190px;max-width:calc(100vw - 16px);display:flex;flex-direction:column;gap:2px;padding:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}.mobile-more-item{display:flex;align-items:center;gap:.6rem;min-height:44px;padding:0 .75rem;background:none;border:none;border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:.9rem;font-weight:500;text-align:left;cursor:pointer;transition:background .15s,color .15s}.mobile-more-item:hover{background:var(--brand-muted)}.mobile-more-item.active{color:var(--accent, var(--gold));background:var(--brand-muted)}.card{padding:1rem;margin-bottom:.75rem}.table-wrap{overflow-x:auto}.btn{min-height:40px}.btn-sm{min-height:36px}.btn-icon{min-width:36px}.dialog{width:94%;max-width:94%;padding:1.25rem}.form-row{flex-direction:column}.recipe-costs{flex-direction:column;gap:.25rem}.plans-grid,.plan-detail-grid{grid-template-columns:1fr}#shopping-list-panel{position:static!important}.lab-panel{flex-basis:100%;min-width:0}.toast-saved{bottom:80px}.section-header{flex-wrap:wrap;gap:.5rem}.search-input{max-width:100%}input[type=text],input[type=number],select,textarea{font-size:16px}.section-title{font-size:1.3rem}.card-title{font-size:1rem}}.allergen-chips{display:inline-flex;flex-wrap:wrap;gap:.25rem;align-items:center}.allergen-chip{display:inline-flex;align-items:center;justify-content:center;min-width:1.4rem;padding:.05rem .4rem;font-size:.8rem;font-weight:600;background:var(--brand-muted);color:var(--text);border-radius:var(--radius-full);border:1px solid var(--border)}.allergen-chip-detailed{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;font-size:.85rem;background:var(--brand-muted);color:var(--text);border-radius:var(--radius-md);border:1px solid var(--border)}.allergen-chip-detailed .allergen-chip-num{font-weight:700}.no-allergens-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .7rem;font-size:.85rem;font-weight:600;background:var(--success-bg);color:var(--success);border-radius:var(--radius-md);border:1px solid var(--success)}.allergen-cell{position:relative;display:inline-block}.allergen-picker{position:absolute;top:100%;left:0;margin-top:.25rem;z-index:100;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:.6rem .75rem;min-width:320px;max-width:90vw}.allergen-picker-grid{display:grid;grid-template-columns:1fr 1fr;gap:.25rem .75rem}.allergen-picker-row{display:grid;grid-template-columns:auto auto 1fr;gap:.4rem;align-items:baseline;font-size:.85rem;cursor:pointer}.allergen-picker-num{font-weight:600;color:var(--text-mid)}.allergen-picker-detail{color:var(--text-muted);font-size:.8rem}.allergen-picker-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.6rem;padding-top:.5rem;border-top:1px solid var(--border)}@media (max-width: 768px){.allergen-picker-grid{grid-template-columns:1fr}}.stockpile-adjust-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:stretch}.stockpile-adjust-divider{width:1px;background:var(--border)}.stockpile-adjust-col{display:flex;flex-direction:column}.stockpile-sign-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.stockpile-sign-toggle button{padding:.4rem .75rem;background:var(--bg-card);border:none;font-size:1rem;font-weight:700;color:var(--text-mid);cursor:pointer;min-width:2.4rem}.stockpile-sign-toggle button.active{background:var(--brand);color:#fff}.stockpile-range-picker{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.stockpile-range-picker button{padding:.35rem .7rem;background:var(--bg-card);border:none;font-size:.8rem;color:var(--text-mid);cursor:pointer;border-right:1px solid var(--border)}.stockpile-range-picker button:last-child{border-right:none}.stockpile-range-picker button.active{background:var(--brand);color:#fff}.stockpile-sparkline-cell{width:110px;min-width:110px;text-align:center;vertical-align:middle}.stockpile-sparkline-cell .recharts-wrapper{display:inline-block;vertical-align:middle}.stockpile-burn-rate{font-size:.72rem;font-weight:600;margin-top:.1rem;line-height:1}.stockpile-overview-table td,.stockpile-overview-table th{padding-top:.35rem;padding-bottom:.35rem;vertical-align:middle}.stockpile-overview-table .stockpile-sparkline-cell{padding-top:.15rem;padding-bottom:.15rem}@media (max-width: 768px){.stockpile-sparkline-cell{display:none}}.stockpile-date-row{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.82rem;color:var(--text-mid)}.stockpile-date-row input[type=date]{padding:.25rem .4rem;font-size:.85rem}.btn-link{background:none;border:none;padding:0;color:var(--brand);cursor:pointer;font-size:.8rem;text-decoration:underline}.hidden-pill-row{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin:0 0 .85rem;padding:.5rem .6rem;background:var(--brand-muted);border-radius:var(--radius-sm);font-size:.82rem}.hidden-pill-row-label{color:var(--text-mid);font-weight:600;margin-right:.15rem}.hidden-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.18rem .55rem;font-size:.78rem;background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;font-family:inherit}.hidden-pill:hover{background:var(--brand);color:#fff;border-color:var(--brand)}.hidden-pill-restore{font-size:.85rem;line-height:1}@media (max-width: 768px){.stockpile-adjust-grid{grid-template-columns:1fr}.stockpile-adjust-divider{width:100%;height:1px}}.main-content .btn-primary{background:var(--accent, var(--brand));color:var(--bg)}.main-content .btn-secondary{color:var(--accent, var(--brand));border-color:var(--accent, var(--brand))}.main-content .btn-secondary:hover{background:var(--accent, var(--brand));color:var(--bg)}.main-content .btn-link,.main-content .editable:hover{color:var(--accent, var(--brand))}.main-content .inline-edit-input{border-color:var(--accent, var(--brand))}.main-content input:focus,.main-content select:focus,.main-content textarea:focus,.main-content .search-input:focus{border-color:var(--accent, var(--brand));box-shadow:0 0 0 3px color-mix(in srgb,var(--accent, var(--brand)) 25%,transparent)}.main-content .stockpile-sign-toggle button.active,.main-content .stockpile-range-picker button.active{background:var(--accent, var(--brand));color:var(--bg)}.main-content .hidden-pill:hover{background:var(--accent, var(--brand));color:var(--bg);border-color:var(--accent, var(--brand))}.main-content tbody tr:hover td{background:color-mix(in srgb,var(--accent, var(--brand)) 10%,transparent)}
