:root{color:#182019;font-synthesis:none;text-rendering:optimizelegibility;background:#f7f7f2;font-family:Inter,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}img{max-width:100%}button,input,textarea{font:inherit}button{cursor:pointer}.app-shell{grid-template-columns:minmax(0,1fr) 380px;gap:24px;min-height:100vh;padding:24px;display:grid}.storefront,.checkout-panel{min-width:0}.topbar{color:#fff;background:linear-gradient(90deg,#142d1ce0,#142d1c6b),url(https://images.unsplash.com/photo-1500937386664-56d1dfef3854?auto=format&fit=crop&w=1800&q=80) 50%/cover;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:20px;padding:28px;display:flex}.brand-block{align-items:flex-start;gap:16px;min-width:0;display:flex}.brand-block img{object-fit:contain;background:#fff;border-radius:8px;flex:none;width:64px;height:64px;padding:4px}.eyebrow{color:#e8f2d0;letter-spacing:0;text-transform:uppercase;margin:0 0 8px;font-size:.82rem;font-weight:700}h1,h2,p{margin-top:0}h1{letter-spacing:0;max-width:680px;margin-bottom:0;font-size:3.6rem;line-height:1.05}.cart-pill{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff29;border:1px solid #ffffff47;border-radius:999px;justify-content:center;align-items:center;gap:8px;min-width:72px;height:44px;font-weight:800;display:inline-flex}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.member-open-button,.guest-open-button{color:#17301f;white-space:nowrap;background:#fff;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:0 14px;font-weight:800;display:inline-flex}.guest-open-button{color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#17301f94;border:1px solid #ffffff75}.tool-row{grid-template-columns:minmax(240px,340px) minmax(0,1fr);align-items:center;gap:16px;margin:24px 0;display:grid}.search-box{background:#fff;border:1px solid #d9ddd2;border-radius:8px;align-items:center;gap:10px;height:44px;padding:0 14px;display:flex}.search-box input{border:0;outline:0;width:100%}.category-tabs{flex-wrap:wrap;gap:8px;display:flex}.category-tabs button{color:#334137;background:#fff;border:1px solid #d9ddd2;border-radius:999px;min-height:40px;padding:0 16px}.category-tabs button.active{color:#fff;background:#28643b;border-color:#28643b}.state-message{background:#fff;border:1px solid #d9ddd2;border-radius:8px;padding:16px}.state-message.error{color:#8f1f1f;border-color:#e7bbbb}.member-zone{grid-template-columns:minmax(220px,320px) minmax(0,1fr);gap:14px;margin-top:16px;display:grid}.member-card,.profile-panel{background:#fff;border:1px solid #dfe4d8;border-radius:8px;gap:10px;padding:16px;display:grid}.member-card{align-content:start}.form-title{color:#243127;align-items:center;gap:8px;display:flex}.member-card input,.profile-panel input{border:1px solid #d9ddd2;border-radius:8px;outline-color:#28643b;min-height:40px;padding:0 11px}.member-card button,.profile-panel button,.checkout-button{color:#fff;background:#28643b;border:0;border-radius:8px;justify-content:center;align-items:center;min-height:42px;padding:0 14px;font-weight:800;display:inline-flex}.member-card .guest-access-button{color:#28643b;background:#fff;border:1px solid #28643b}.profile-panel{grid-template-columns:1.1fr repeat(4,minmax(120px,1fr)) auto;align-items:center;margin-top:14px}.profile-panel strong,.profile-panel span{display:block}.profile-panel span{color:#69746c;margin-top:4px;font-size:.86rem}.modal-backdrop{z-index:30;background:#1420188c;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.member-modal{background:#f7f7f2;border-radius:8px;width:min(760px,100%);max-height:min(720px,100vh - 36px);padding:18px;overflow:auto;box-shadow:0 24px 80px #00000047}.postcode-modal{background:#f7f7f2;border-radius:8px;width:min(560px,100%);max-height:min(720px,100vh - 36px);padding:18px;overflow:hidden;box-shadow:0 24px 80px #00000047}.postcode-layer{background:#fff;border:1px solid #d9ddd2;border-radius:8px;height:min(520px,100vh - 150px);min-height:420px;overflow:hidden}.modal-heading{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;display:flex}.modal-heading h2{margin:0 0 4px;font-size:1.2rem}.modal-heading span{color:#657268;font-size:.9rem}.modal-heading button{color:#26332a;background:#fff;border:1px solid #d9ddd2;border-radius:8px;place-items:center;width:36px;height:36px;display:inline-grid}.member-modal-grid{grid-template-columns:.8fr 1.2fr;gap:14px;display:grid}.profile-card{margin-bottom:14px}.product-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;display:grid}.product-card{background:#fff;border:1px solid #dfe4d8;border-radius:8px;overflow:hidden}.product-media{aspect-ratio:4/3;background:#e7eadf;position:relative;overflow:hidden}.product-media img{object-fit:cover;width:100%;height:100%;display:block}.product-media.soldout img{filter:grayscale(.65)brightness(.55);transform:scale(1.02)}.soldout-overlay{color:#fff;text-align:center;background:linear-gradient(#23201a3d,#23201a70),repeating-linear-gradient(-45deg,#ffffff14 0 12px,#fff0 12px 24px);place-content:center;gap:10px;padding:18px;display:grid;position:absolute;inset:0}.soldout-overlay strong{color:#2e2618;background:#ffe2a8;border-radius:999px;justify-self:center;padding:7px 14px;font-size:1rem;font-weight:900}.soldout-overlay span{color:#fffaf1;text-shadow:0 1px 8px #00000073;max-width:24ch;font-size:.95rem;font-weight:900;line-height:1.45}.product-body{gap:12px;padding:16px;display:grid}.product-title-row{justify-content:space-between;align-items:flex-start;gap:10px;min-width:0;display:flex}.product-title-row h2{overflow-wrap:anywhere;margin:0;font-size:1.05rem;line-height:1.3}.product-title-row span{color:#6b3d00;background:#ffe7b3;border-radius:999px;flex:none;padding:4px 8px;font-size:.75rem;font-weight:800}.product-body p{color:#5c665e;overflow-wrap:anywhere;min-height:44px;margin:0;font-size:.9rem;line-height:1.55}.producer-info{background:#f7faf4;border:1px solid #e2e9dc;border-radius:8px;gap:3px;padding:10px;display:grid}.producer-info strong{color:#243127;font-size:.9rem}.producer-info span,.producer-info small{color:#657268;font-size:.82rem;line-height:1.45}.product-meta{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.product-meta strong{font-size:1.12rem}.product-meta small{color:#6a756d}.product-body button,.order-form button{color:#fff;background:#28643b;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:44px;font-weight:800;display:inline-flex}.product-body button:disabled{cursor:not-allowed;background:#8b948d}.product-body button.added{background:#1f7a4a}.cart-feedback-toast{z-index:40;color:#fff;background:#17301f;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:min(360px,100vw - 32px);min-height:46px;padding:0 18px;font-weight:800;display:inline-flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 14px 34px #0000003d}.checkout-panel{background:#fff;border:1px solid #dfe4d8;border-radius:8px;align-self:start;padding:20px;position:sticky;top:24px}.panel-heading,.totals div,.cart-item{justify-content:space-between;align-items:center;gap:16px;display:flex}.panel-heading h2{margin:0}.panel-heading span{color:#69746c;font-size:.9rem}.cart-list{gap:12px;margin:20px 0;display:grid}.empty-cart{color:#657268;text-align:center;background:#f4f5ef;border-radius:8px;margin:0;padding:18px}.cart-item{border-bottom:1px solid #edf0e8;align-items:flex-start;min-width:0;padding:12px 0}.cart-item strong,.cart-item span{display:block}.cart-item span{color:#69746c;margin-top:4px;font-size:.88rem}.quantity-control{grid-template-columns:32px 32px 32px 32px;align-items:center;gap:4px;display:grid}.quantity-control button{color:#2d372f;background:#f4f5ef;border:1px solid #d9ddd2;border-radius:8px;width:32px;height:32px}.quantity-control span{color:#182019;text-align:center;margin:0;font-weight:800}.totals{border-top:1px solid #edf0e8;border-bottom:1px solid #edf0e8;gap:10px;padding:16px 0;display:grid}.grand-total strong{color:#28643b;font-size:1.25rem}.order-form{gap:12px;margin-top:18px;display:grid}.order-form label{color:#4d5a50;gap:6px;font-size:.9rem;font-weight:700;display:grid}.order-form input,.order-form textarea{resize:vertical;border:1px solid #d9ddd2;border-radius:8px;outline-color:#28643b;width:100%;min-width:0;padding:11px 12px}.address-field{grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:8px;display:grid}.address-field.compact{grid-template-columns:minmax(0,1fr)}.address-field input,.address-field textarea{width:100%}.address-search-button,.order-form .address-search-button{color:#254231;white-space:nowrap;background:#eef5ec;border:1px solid #cbdcca;border-radius:8px;justify-content:center;align-items:center;gap:6px;min-height:40px;padding:0 12px;font-weight:800;display:inline-flex}.order-form button:disabled{cursor:not-allowed;opacity:.45}.checkout-button{width:100%;margin-top:16px}.checkout-button:disabled{cursor:not-allowed;opacity:.45}.history-panel{border-top:1px solid #edf0e8;margin-top:22px;padding-top:18px}.lookup-form{gap:10px;margin-top:14px;display:grid}.lookup-form label{color:#4d5a50;gap:6px;font-size:.9rem;font-weight:700;display:grid}.lookup-form input{border:1px solid #d9ddd2;border-radius:8px;outline-color:#28643b;width:100%;min-height:42px;padding:0 11px}.lookup-form button{color:#fff;background:#28643b;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;font-weight:800;display:inline-flex}.lookup-form button:disabled{cursor:not-allowed;opacity:.45}.history-list{gap:10px;margin-top:14px;display:grid}.history-list article{background:#f8faf6;border:1px solid #edf0e8;border-radius:8px;gap:4px;padding:12px;display:grid}.history-title-row{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.history-status{color:#245a35;background:#e7f3ea;border-radius:999px;flex:none;padding:3px 8px;font-size:.78rem;font-weight:800}.cancel-order-button{color:#9f1f17;background:#fff1ef;border:1px solid #f2c7c2;border-radius:8px;justify-self:start;min-height:34px;padding:0 10px;font-size:.86rem;font-weight:800}.history-list span,.history-list small{color:#657268;line-height:1.45}.history-list .order-cancel-guide{color:#8a4f16;font-weight:700}.order-message{color:#28643b;margin:14px 0 0;font-weight:800;line-height:1.45}@media (width<=1040px){.app-shell{grid-template-columns:1fr;max-width:980px;margin:0 auto}.checkout-panel{position:static}h1{font-size:2.8rem}.profile-panel{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-panel>div{grid-column:1/-1}}@media (width<=720px){.app-shell{max-width:none;padding:14px}.topbar,.tool-row,.member-zone,.profile-panel{grid-template-columns:1fr}.topbar{padding:22px;display:grid}h1{font-size:2.05rem;line-height:1.12}.topbar-actions{flex-wrap:wrap;justify-self:start}.member-modal-grid,.address-field{grid-template-columns:1fr}}@media (width<=520px){.brand-block{align-items:center}.brand-block img{width:48px;height:48px}.topbar-actions,.member-open-button,.guest-open-button,.cart-pill,.product-body button,.order-form button,.address-search-button{width:100%}.category-tabs{flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.category-tabs button{flex:none}.product-grid{grid-template-columns:1fr}.cart-item{gap:10px;display:grid}.quantity-control{justify-self:start}.member-modal,.postcode-modal{max-height:calc(100vh - 24px);padding:14px}.postcode-layer{height:calc(100vh - 140px);min-height:360px}.modal-heading{align-items:flex-start}}
