@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;600;700&family=Playfair+Display:wght@700&display=swap";*{box-sizing:border-box}body{color:#29231f;background:#f4f1e8;margin:0;font-family:DM Sans,sans-serif}.app{background:var(--surface,#f4f1e8);min-height:100vh}body.modal-open{overflow:hidden}header{background:linear-gradient(135deg,var(--brand,#1f2a24),#111813);color:#fff;text-align:center;padding:46px 16px 64px;position:relative}.back-to-site{z-index:2;color:#fff;letter-spacing:.01em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;background:#ffffff10;border:1px solid #ffffff30;border-radius:999px;padding:6px 10px;font-size:.68rem;font-weight:700;line-height:1;text-decoration:none;position:absolute;top:14px;right:14px}.back-to-site:hover,.back-to-site:focus-visible{background:#ffffff20;border-color:#fff5;outline:none}.hero,main,footer{max-width:1100px;margin:auto}.hero{flex-direction:column;align-items:center;display:flex}.eyebrow{text-transform:uppercase;letter-spacing:.18em;opacity:.8;font-size:.72rem;font-weight:700}h1{margin:12px 0;font:700 clamp(2.3rem,8vw,4.6rem)/1 Playfair Display}.business-logo{object-fit:contain;width:min(180px,72vw);max-height:116px;margin:14px auto 10px;display:block}.hero p{opacity:.86;max-width:600px;margin:8px auto 0}.actions{scrollbar-width:none;flex-wrap:nowrap;justify-content:center;align-items:center;gap:8px;max-width:100%;margin-top:22px;padding:2px 2px 8px;display:flex;overflow-x:auto}.actions::-webkit-scrollbar{display:none}.actions a{color:#fff;white-space:nowrap;background:#ffffff12;border:1px solid #ffffff42;border-radius:99px;flex:none;padding:9px 14px;font-size:.9rem;font-weight:700;text-decoration:none}.controls{z-index:3;background:color-mix(in srgb,var(--surface,#f4f1e8) 94%,white);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:22px 22px 0 0;margin-top:-34px;padding:16px 12px 10px;position:sticky;top:0}input[aria-label]{width:100%;font:inherit;background:#fff;border:0;border-radius:14px;padding:15px 18px;box-shadow:0 8px 30px #38271a12}.chips,.filters{scrollbar-width:none;gap:8px;padding:12px 0;display:flex;overflow:auto}.chips button,.filters span{white-space:nowrap;background:#fff;border:1px solid #ddd3ca;border-radius:99px;padding:9px 14px;font:600 .85rem inherit}.chips .active{background:var(--brand,#1f2a24);color:#fff;border-color:var(--brand,#1f2a24)}.filters input{display:none}.filters input:checked+span{background:var(--brand,#1f2a24);color:#fff}details summary{cursor:pointer;font-size:.85rem}.grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:11px;padding:14px 10px 48px;display:grid}.product-card{text-align:left;width:100%;min-width:0;color:inherit;cursor:pointer;background:#fff;border:0;border-radius:18px;padding:0;transition:transform .18s,box-shadow .18s;display:block;overflow:hidden;box-shadow:0 10px 30px #38271a10}.product-card:hover,.product-card:focus-visible{outline:none;transform:translateY(-2px);box-shadow:0 16px 42px #38271a18}.product-card:focus-visible{box-shadow:0 0 0 3px color-mix(in srgb,var(--brand,#1f2a24) 22%,transparent),0 16px 42px #38271a18}.product-card--disabled{opacity:.62}.product-card__media{aspect-ratio:4/3;background:var(--surface,#f4f1e8);position:relative}.product-card__media img,.product-card__placeholder{object-fit:cover;width:100%;height:100%;display:block}.product-card__placeholder,.product-modal__placeholder{color:#ffffffc7;background:linear-gradient(135deg,#eee4da,#d8c7b8);place-items:center;font:700 1.35rem Playfair Display;display:grid}.product-card__badges{flex-wrap:wrap;align-items:flex-start;gap:5px;display:flex;position:absolute;top:7px;left:7px;right:7px}.badge{background:color-mix(in srgb,var(--brand,#1f2a24) 88%,black);color:#fff;border-radius:999px;padding:4px 7px;font-size:.62rem;font-weight:700;line-height:1;box-shadow:0 4px 14px #0002}.badge--featured{color:#38271a;background:#f0d9a4}.badge--disabled{color:#5b5149;background:#efe7df}.product-card__body{padding:10px}.product-card__topline{gap:5px;display:grid}.product-card h2{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font:700 .98rem/1.12 Playfair Display;display:-webkit-box;overflow:hidden}.product-card strong{white-space:nowrap;font-size:.9rem}.product-card p{color:#70665e;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:7px 0 0;font-size:.78rem;line-height:1.25;display:-webkit-box;overflow:hidden}.tags{flex-wrap:wrap;gap:5px;display:flex}.tags span{background:var(--surface,#f4f1e8);border-radius:6px;padding:5px 8px;font-size:.7rem}.tags .featured{background:#f0d9a4}.empty,.state{text-align:center;padding:80px 20px}.empty{grid-column:1/-1}.spinner{border:3px solid #ddd;border-top-color:var(--brand,#1f2a24);border-radius:50%;width:32px;height:32px;margin:auto;animation:1s linear infinite s}@keyframes s{to{transform:rotate(360deg)}}footer{color:#746960;justify-content:space-between;gap:15px;padding:20px 12px 35px;font-size:.8rem;display:flex}.modal-backdrop{z-index:20;background:#1b1410a3;justify-content:center;align-items:flex-end;padding:18px 12px 0;display:flex;position:fixed;inset:0}.product-modal{background:#fff;border-radius:28px 28px 0 0;width:min(100%,760px);max-height:90vh;position:relative;overflow:auto;box-shadow:0 -22px 70px #0004}.modal-close{z-index:2;color:var(--brand,#1f2a24);cursor:pointer;background:#fffffff0;border:0;border-radius:999px;padding:9px 12px;font:700 .78rem inherit;position:absolute;top:12px;right:12px;box-shadow:0 6px 18px #0002}.modal-close:hover,.modal-close:focus-visible{background:var(--brand,#1f2a24);color:#fff;outline:none}.product-modal__image,.product-modal__placeholder{object-fit:cover;width:100%;height:min(46vh,430px);display:block}.product-modal__body{padding:18px 18px 24px}.product-modal__heading{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.product-modal__heading h2{margin:5px 0 0;font:700 clamp(1.6rem,6vw,2.6rem)/1 Playfair Display}.product-modal__heading strong{white-space:nowrap;font-size:1.2rem}.product-modal__category{text-transform:uppercase;letter-spacing:.12em;color:#8a7869;font-size:.72rem;font-weight:700}.product-modal__body p{color:#62574f;font-size:1rem;line-height:1.6}.product-modal__tags{margin-top:16px}.product-modal__tags span{padding:7px 10px;font-size:.8rem}@media (width>=640px){.business-logo{width:min(240px,42vw);max-height:150px}.actions a{padding:10px 16px}.grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;padding-inline:12px}.product-card__body{padding:12px}.product-card h2{font-size:1.05rem}.product-card p{font-size:.83rem}.modal-backdrop{align-items:center;padding:24px}.product-modal{border-radius:28px;max-height:88vh}.product-modal__image,.product-modal__placeholder{height:380px}}@media (width>=980px){.grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.product-card__media{aspect-ratio:1.15}.product-card__topline{grid-template-columns:1fr auto;align-items:start}}@media (width<=600px){header{padding:38px 12px 56px}.back-to-site{padding:5px 8px;font-size:.62rem;top:10px;right:10px}.eyebrow{font-size:.68rem}.hero p{font-size:.93rem;line-height:1.45}.actions{justify-content:flex-start;gap:7px;width:100%;margin-top:18px;padding-inline:2px}.actions a{border-color:#ffffff38;padding:8px 11px;font-size:.8rem}.controls{margin-top:-25px}footer{flex-direction:column}.product-modal__heading{display:block}.product-modal__heading strong{margin-top:10px;display:block}.modal-backdrop{padding-inline:0}.product-modal{border-radius:26px 26px 0 0;width:100%}}
