:root{--bg: #f0ebe3;--bg-warm: #e8e2d8;--surface: #fffcf8;--text: #1c1b19;--text-muted: #5e5c57;--accent: #2f6f52;--accent-hover: #265a42;--accent-soft: rgba(47, 111, 82, .12);--border: rgba(28, 27, 25, .08);--shadow: 0 2px 8px rgba(28, 27, 25, .06), 0 12px 40px rgba(28, 27, 25, .08);--shadow-card-hover: 0 8px 24px rgba(28, 27, 25, .1), 0 20px 48px rgba(28, 27, 25, .08);--radius: 16px;--radius-sm: 10px;--overlay: rgba(22, 21, 19, .5);--content-max: 1080px;--gutter: clamp(1rem, 4vw, 1.75rem);font-family:DM Sans,system-ui,sans-serif;font-size:16px;line-height:1.55;color:var(--text);background-color:var(--bg);-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(ellipse 120% 80% at 50% -20%,rgba(47,111,82,.09),transparent 55%),radial-gradient(ellipse 90% 60% at 100% 50%,rgba(232,226,216,.9),transparent 45%),var(--bg)}#app{min-height:100vh}.site-header{position:sticky;top:0;z-index:10;padding:.875rem var(--gutter);background:#fffcf8d1;border-bottom:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.site-header__inner{max-width:var(--content-max);margin:0 auto;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.75rem 1rem}.site-nav{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.25rem .5rem;min-width:0}.site-nav__link{font-size:.875rem;font-weight:600;color:var(--text-muted);text-decoration:none;padding:.35rem .65rem;border-radius:var(--radius-sm);white-space:nowrap}.site-nav__link:hover{color:var(--text);background:var(--accent-soft)}.site-nav__link[aria-current=page]{color:var(--accent);background:#2f6f521a}.brand{font-weight:700;font-size:1.125rem;letter-spacing:-.03em;color:var(--text)}.brand--link{justify-self:start}@supports ((-webkit-background-clip: text) or (background-clip: text)){.brand{background:linear-gradient(135deg,var(--text) 0%,var(--accent) 160%);-webkit-background-clip:text;background-clip:text;color:transparent}}.cart-button{position:relative;display:flex;align-items:center;justify-content:center;width:46px;height:46px;padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer;box-shadow:0 1px 2px #1c1b190a;transition:background .2s,border-color .2s,box-shadow .2s,transform .2s}.cart-button:hover{background:var(--accent-soft);border-color:#2f6f5240;box-shadow:0 4px 12px #1c1b190f}.cart-button:active{transform:scale(.97)}.cart-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.cart-button svg{width:22px;height:22px}.cart-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 6px;font-size:.6875rem;font-weight:700;line-height:20px;text-align:center;color:#fff;background:var(--accent);border-radius:999px;border:2px solid var(--surface)}.cart-badge:empty,.cart-badge[data-count="0"]{display:none}.main{max-width:var(--content-max);margin:0 auto;padding:clamp(1.75rem,5vw,3rem) var(--gutter) clamp(2.5rem,6vw,4rem)}.intro{margin-bottom:clamp(1.75rem,4vw,2.5rem);text-align:center;max-width:36rem;margin-left:auto;margin-right:auto}.intro__eyebrow{margin:0 0 .5rem;font-size:.75rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}.intro h1{margin:0 0 .75rem;font-size:clamp(1.75rem,4.5vw,2.25rem);font-weight:700;letter-spacing:-.035em;line-height:1.15}.intro__lede{margin:0;color:var(--text-muted);font-size:clamp(.9375rem,2vw,1.0625rem);line-height:1.6}.controls{display:flex;align-items:center;justify-content:flex-end;gap:.65rem;margin:0 auto clamp(1.25rem,3vw,1.75rem);max-width:56rem}.controls__label{color:var(--text-muted);font-size:.95rem;font-weight:600}.controls__select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:.55rem 2.25rem .55rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;line-height:1.2;box-shadow:0 1px 2px #1c1b190a;background-image:linear-gradient(45deg,transparent 50%,var(--text-muted) 50%),linear-gradient(135deg,var(--text-muted) 50%,transparent 50%);background-position:calc(100% - 1rem) 55%,calc(100% - .75rem) 55%;background-size:6px 6px,6px 6px;background-repeat:no-repeat}.controls__select:focus-visible{outline:3px solid rgba(47,111,82,.55);outline-offset:2px}@media(max-width:540px){.controls{justify-content:center}}html[data-cart=off] #cart-toggle{display:none}html[data-cart=off] #lightbox-add{display:none!important}.static-sheet{max-width:40rem;margin:0 auto;text-align:left}.static-section+.static-section{margin-top:clamp(1.75rem,4vw,2.25rem);padding-top:clamp(1.75rem,4vw,2.25rem);border-top:1px solid var(--border)}.static-section__title{margin:0 0 .65rem;font-size:1.125rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.static-section__body{margin:0;color:var(--text-muted);font-size:clamp(.9375rem,2vw,1.0625rem);line-height:1.65;white-space:pre-line}.static-section__body:has(p,ul,ol,a,pre,code,table){white-space:normal}.static-section__body a{color:var(--accent);font-weight:600;text-underline-offset:.12em}.static-section__body a:hover{color:var(--accent-hover)}.static-section__body ul,.static-section__body ol{margin:.5rem 0 0;padding-left:1.25rem}.static-section__body li+li{margin-top:.35rem}.static-section__body p{margin:0 0 .75rem}.static-section__body p:last-child{margin-bottom:0}.product-grid{display:grid;gap:clamp(1rem,3vw,1.5rem);grid-template-columns:1fr}@media(min-width:540px){.product-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:880px){.product-grid{grid-template-columns:repeat(3,1fr)}}.product-card{display:flex;flex-direction:column;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:#2f6f5226}.product-card__media{position:relative;overflow:hidden;aspect-ratio:4 / 5;background:linear-gradient(145deg,var(--bg-warm),var(--border))}.product-card__mediaBtn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;padding:0;margin:0;width:100%;height:100%;display:block;background:transparent;cursor:zoom-in}.product-card__mediaBtn:focus-visible{outline:3px solid rgba(47,111,82,.7);outline-offset:-3px}.product-card__image{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s cubic-bezier(.33,1,.68,1)}.product-card:hover .product-card__image{transform:scale(1.05)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;display:flex;align-items:center;justify-content:center;padding:var(--gutter);background:var(--overlay);opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}.lightbox.is-open{opacity:1;visibility:visible}.lightbox__panel{position:relative;width:min(100%,960px);max-height:min(92dvh,920px);display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);box-shadow:0 24px 80px #1c1b1940;overflow:hidden;transform:translateY(10px) scale(.99);transition:transform .25s cubic-bezier(.33,1,.68,1)}.lightbox.is-open .lightbox__panel{transform:translateY(0) scale(1)}.lightbox__close{position:absolute;top:12px;right:12px;z-index:2;display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:var(--radius-sm);background:#fffcf8e6;color:var(--text);cursor:pointer;box-shadow:0 6px 18px #1c1b1924}.lightbox__close:hover{background:var(--surface)}.lightbox__close svg{width:20px;height:20px}.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:44px;height:44px;border:none;border-radius:999px;background:#fffcf8eb;color:var(--text);cursor:pointer;display:grid;place-items:center;box-shadow:0 10px 24px #1c1b1929}.lightbox__nav:hover{background:var(--surface)}.lightbox__nav svg{width:22px;height:22px}.lightbox__nav--prev{left:12px}.lightbox__nav--next{right:12px}.lightbox__content{display:grid;grid-template-columns:1fr;min-height:0;flex:1 1 auto;overflow:auto}.lightbox__media{position:relative;display:flex;align-items:center;justify-content:center;min-height:0;padding:.5rem 3rem;background:linear-gradient(145deg,var(--bg-warm),var(--border))}.lightbox__image{max-width:100%;max-height:min(68dvh,70vh);width:auto;height:auto;display:block;object-fit:contain}.lightbox__info{padding:1.25rem 1.25rem 1.35rem}.lightbox__title{margin:0 0 .25rem;font-size:1.25rem;line-height:1.2;letter-spacing:-.03em}.lightbox__price{margin:0 0 .75rem;font-weight:800;color:var(--accent);letter-spacing:-.02em}.lightbox__desc{margin:0 0 1.1rem;color:var(--text-muted);font-size:.95rem;line-height:1.65}.detail-field{display:grid;grid-template-columns:1fr;gap:.15rem;padding:.65rem .75rem;border:1px solid var(--border);border-radius:12px;background:#fffcf8a6}.detail-field+.detail-field{margin-top:.5rem}.detail-field__label{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#1c1b198c}.detail-field__value{color:var(--text-muted);font-size:.95rem;line-height:1.65}.lightbox__actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:.5rem}.lightbox__actions .btn{flex:1 1 calc(50% - .25rem);min-width:6.5rem;padding:.5rem .75rem;font-size:.8125rem}@media(min-width:840px){.lightbox__content{grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);overflow:hidden}.lightbox__media{align-self:stretch;max-height:min(85dvh,880px)}.lightbox__image{max-height:min(82dvh,860px)}.lightbox__info{padding:1.5rem 1.5rem 1.6rem;overflow-y:auto;min-height:0}}.product-card__body{display:flex;flex-direction:column;flex:1;padding:1.125rem 1.25rem 1.25rem;gap:.35rem}.product-card__title{margin:0;font-size:1.0625rem;font-weight:600;letter-spacing:-.02em}.product-card__price{margin:0 0 .25rem;font-size:1rem;font-weight:700;color:var(--accent);letter-spacing:-.02em}.product-card__actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:.5rem;margin-top:auto;padding-top:.75rem}.product-card__actions .btn{flex:1 1 calc(50% - .25rem);min-width:0;padding:.5rem .65rem;font-size:.8125rem}.btn{display:inline-flex;align-items:center;justify-content:center;width:auto;min-width:0;padding:.65rem 1rem;font-family:inherit;font-size:.875rem;font-weight:600;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s,transform .15s}.overlay-footer .btn{width:100%}.btn:active{transform:scale(.98)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn--primary{background:linear-gradient(180deg,#3a8262 0%,var(--accent) 100%);color:#fff;box-shadow:0 1px #ffffff1f inset,0 2px 8px #2f6f5240}.btn--primary:hover{background:linear-gradient(180deg,var(--accent-hover) 0%,#1f4d38 100%);box-shadow:0 1px #ffffff1a inset,0 4px 16px #2f6f524d}.btn--secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:0 1px 2px #1c1b190a}.btn--secondary:hover{background:var(--accent-soft);border-color:#2f6f5238;color:var(--accent-hover)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;justify-content:flex-end;padding:0;background:var(--overlay);opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}.overlay.is-open{opacity:1;visibility:visible}.overlay-panel{width:min(100%,420px);max-height:100vh;display:flex;flex-direction:column;background:var(--surface);border-left:1px solid var(--border);box-shadow:-12px 0 48px #1c1b191f;transform:translate(100%);transition:transform .3s cubic-bezier(.33,1,.68,1)}.overlay.is-open .overlay-panel{transform:translate(0)}.overlay-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--border)}.overlay-header h2{margin:0;font-size:1.125rem;font-weight:700}.close-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:var(--radius-sm);background:var(--bg);color:var(--text);cursor:pointer}.close-button:hover{background:var(--border)}.close-button svg{width:20px;height:20px}.overlay-body{flex:1;overflow-y:auto;padding:1rem 1.25rem 1.25rem}.cart-empty{margin:0;padding:2rem 0;text-align:center;color:var(--text-muted);font-size:.9375rem}.cart-line{display:grid;grid-template-columns:56px 1fr auto;gap:.75rem;align-items:start;padding:.75rem 0;border-bottom:1px solid var(--border)}.cart-line:first-of-type{padding-top:0}.cart-line__thumb{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:cover;background:var(--border)}.cart-line__thumb--empty{background:linear-gradient(145deg,var(--bg-warm),var(--border))}.cart-line__info{min-width:0}.cart-line__name{margin:0 0 .25rem;font-size:.875rem;font-weight:600}.cart-line__meta{margin:0;font-size:.8125rem;color:var(--text-muted)}.cart-line__qty{display:flex;align-items:center;gap:.35rem;margin-top:.5rem}.cart-line__qty button{width:28px;height:28px;padding:0;font-size:1rem;line-height:1;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer}.cart-line__qty button:hover{background:var(--bg)}.cart-line__qty span{min-width:1.5rem;text-align:center;font-size:.8125rem;font-weight:600}.cart-line__qty--fixed{margin:.5rem 0 0;font-size:.8125rem;font-weight:600;color:var(--text-muted)}.cart-line__remove{padding:.25rem;font-size:.75rem;color:var(--text-muted);background:none;border:none;cursor:pointer;text-decoration:underline}.cart-line__remove:hover{color:var(--text)}.cart-line__subtotal{font-size:.8125rem;font-weight:600;white-space:nowrap}.overlay-footer{padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--border);background:var(--surface)}.cart-total{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem;font-size:1rem}.cart-total strong{font-size:1.125rem}.terms-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:125;display:flex;align-items:center;justify-content:center;padding:var(--gutter);background:var(--overlay);opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}.terms-overlay.is-open{opacity:1;visibility:visible}.terms-panel{width:min(100%,26rem);max-height:min(85vh,560px);display:flex;flex-direction:column;padding:1.25rem 1.35rem 1.35rem;background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);box-shadow:0 24px 80px #1c1b1938}.terms-panel__title{margin:0 0 .75rem;font-size:1.125rem;font-weight:700;letter-spacing:-.02em;flex-shrink:0}.terms-panel__body{flex:1 1 auto;min-height:0;overflow-y:auto;margin:0 0 1.25rem;color:var(--text-muted);font-size:.9375rem;line-height:1.6}.terms-panel__body p{margin:0 0 .65rem}.terms-panel__body p:last-child{margin-bottom:0}.terms-panel__body ul{margin:.35rem 0 0;padding-left:1.2rem}.terms-panel__body li+li{margin-top:.35rem}.terms-panel__body a{color:var(--accent);font-weight:600}.terms-panel__actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:.5rem;flex-shrink:0}.terms-panel__actions .btn{flex:1 1 calc(50% - .25rem);min-width:0}.toast{position:fixed;bottom:1.5rem;left:50%;z-index:200;max-width:min(90vw,360px);padding:.875rem 1.125rem;font-size:.875rem;background:var(--text);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow);transform:translate(-50%) translateY(120%);opacity:0;transition:transform .25s,opacity .25s}.toast.is-visible{transform:translate(-50%) translateY(0);opacity:1}@media(prefers-reduced-motion:reduce){.overlay,.overlay-panel,.terms-overlay,.toast,.product-card,.product-card__image,.lightbox,.lightbox__panel,.cart-button,.btn{transition:none}.overlay.is-open .overlay-panel,.product-card:hover,.product-card:hover .product-card__image,.lightbox.is-open .lightbox__panel,.cart-button:active,.btn:active{transform:none}}
