:root{--font-sans: "DM Sans", system-ui, "Segoe UI", Roboto, sans-serif;--font-display: "Fraunces", Georgia, "Times New Roman", serif;--text: #3d3a36;--text-strong: #1c1917;--text-muted: #6b6560;--surface: #faf8f5;--surface-elevated: #ffffff;--surface-muted: #f0ebe4;--border: #e4ddd4;--border-strong: #c9bfb2;--accent: #2d7a4f;--accent-dark: #1f5a38;--hero-a: #e8f5ec;--hero-b: #f5f0e6;--radius-sm: 10px;--radius: 14px;--shadow-sm: 0 1px 3px rgba(28, 25, 23, .06);--shadow-lg: 0 20px 40px -12px rgba(28, 25, 23, .18), 0 8px 16px -8px rgba(28, 25, 23, .1);--max-width: 1200px;font-family:var(--font-sans);font-size:16px;line-height:1.5;color:var(--text);background:var(--surface);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100svh}#root{min-height:100svh}h1,h2,h3{font-weight:600}a{color:inherit}.app{min-height:100svh;display:flex;flex-direction:column}.skip-link{position:absolute;left:-9999px;z-index:200;padding:.75rem 1rem;background:var(--surface-elevated);color:var(--text);border-radius:var(--radius-sm)}.skip-link:focus{left:1rem;top:1rem}.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--surface) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.site-header__inner{max-width:var(--max-width);margin:0 auto;padding:.75rem clamp(1rem,3vw,1.5rem);display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;justify-content:space-between}.brand{display:flex;align-items:center;gap:.65rem;min-width:0}.brand__mark{font-size:clamp(1.5rem,4vw,1.75rem);line-height:1}.brand__title{margin:0;font-family:var(--font-display);font-weight:700;font-size:clamp(1rem,2.5vw,1.15rem);color:var(--text-strong);line-height:1.2}.brand__tag{margin:.15rem 0 0;font-size:clamp(.75rem,2vw,.85rem);color:var(--text-muted)}.site-nav{display:flex;gap:1rem;flex:1;justify-content:center}@media (max-width: 639px){.site-nav{order:3;width:100%;justify-content:flex-start;border-top:1px solid var(--border);padding-top:.5rem}}.site-nav a{color:var(--text);text-decoration:none;font-weight:500;font-size:.95rem}.site-nav a:hover{color:var(--accent)}.cart-toggle{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-elevated);color:var(--text-strong);font-weight:600;font-size:.95rem;cursor:pointer;position:relative}.cart-toggle:hover{border-color:var(--accent)}.lang-switch{display:inline-flex;border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden;background:var(--surface-elevated)}.lang-switch__btn{padding:.45rem .65rem;border:none;background:transparent;color:var(--text-muted);font-size:.82rem;font-weight:600;cursor:pointer;line-height:1.2}.lang-switch__btn:hover{color:var(--text-strong);background:var(--surface-muted)}.lang-switch__btn--active{background:color-mix(in srgb,var(--accent) 22%,var(--surface));color:var(--accent-dark)}.site-header__actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.cart-toggle__badge{position:absolute;top:-6px;right:-6px;min-width:1.25rem;height:1.25rem;padding:0 .25rem;border-radius:999px;background:var(--accent);color:#fff;font-size:.7rem;line-height:1.25rem;text-align:center}.hero{background:linear-gradient(145deg,var(--hero-a) 0%,var(--hero-b) 45%,var(--surface) 100%);border-bottom:1px solid var(--border)}.hero__content{max-width:var(--max-width);margin:0 auto;padding:clamp(2rem,6vw,3.5rem) clamp(1rem,3vw,1.5rem)}.hero__eyebrow{margin:0 0 .5rem;font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-dark)}.hero h1{margin:0 0 .75rem;font-family:var(--font-display);font-size:clamp(1.65rem,5vw,2.35rem);font-weight:800;line-height:1.15;color:var(--text-strong);max-width:18ch}.hero__lead{margin:0 0 1.5rem;max-width:42ch;font-size:clamp(1rem,2.2vw,1.1rem);color:var(--text);line-height:1.55}.hero__actions{display:flex;flex-wrap:wrap;gap:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.65rem 1.15rem;border-radius:var(--radius-sm);font-weight:600;font-size:.95rem;text-decoration:none;border:2px solid transparent;cursor:pointer;transition:background .2s,border-color .2s,transform .15s}.btn:active{transform:scale(.98)}.btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn--primary:hover{background:var(--accent-dark);border-color:var(--accent-dark)}.btn--outline{background:transparent;color:var(--text-strong);border-color:var(--border-strong)}.btn--outline:hover{border-color:var(--accent);color:var(--accent-dark)}.btn--cart{width:100%;margin-top:auto;background:var(--surface-elevated);color:var(--text-strong);border-color:var(--border)}.btn--cart:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--surface-elevated))}.btn--block{width:100%}.btn-text{background:none;border:none;color:var(--text-muted);text-decoration:underline;cursor:pointer;font-size:.9rem;padding:.5rem}.btn-text:hover{color:var(--accent-dark)}main{flex:1;max-width:var(--max-width);margin:0 auto;width:100%;padding:0 clamp(1rem,3vw,1.5rem);box-sizing:border-box}.section-head{padding:clamp(1.75rem,4vw,2.5rem) 0 1rem}.section-head h2{margin:0 0 .35rem;font-family:var(--font-display);font-size:clamp(1.35rem,3.5vw,1.65rem);color:var(--text-strong)}.section-head__sub{margin:0;color:var(--text-muted);font-size:.95rem}.category-bar{display:flex;flex-wrap:wrap;gap:.5rem;padding-bottom:1.25rem}.chip{padding:.45rem .9rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-elevated);color:var(--text);font-size:.88rem;font-weight:500;cursor:pointer}.chip:hover{border-color:var(--accent)}.chip--active{background:color-mix(in srgb,var(--accent) 18%,var(--surface));border-color:var(--accent);color:var(--accent-dark);font-weight:600}.product-grid{list-style:none;margin:0;padding:0 0 2.5rem;display:grid;gap:1rem;grid-template-columns:1fr}@media (min-width: 640px){.product-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.product-grid{grid-template-columns:repeat(3,1fr);gap:1.15rem}}@media (min-width: 1280px){.product-grid{grid-template-columns:repeat(4,1fr)}}.product-card{height:100%;display:flex;flex-direction:column;padding:1.15rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-elevated);box-shadow:var(--shadow-sm)}.product-card__visual{margin-bottom:.65rem;min-height:2.25rem}.product-card__emoji{display:block;font-size:2.25rem;line-height:1}.product-card__thumb{display:block;width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-muted)}.product-card__title{margin:0 0 .4rem;font-size:1.05rem;font-weight:700;color:var(--text-strong)}.product-card__price{margin:0 0 .5rem;font-size:.95rem;font-weight:700;color:var(--accent-dark)}.product-card__desc{margin:0 0 1rem;font-size:.9rem;color:var(--text-muted);line-height:1.45;flex:1}.visit-section{padding:2rem 0 3rem;border-top:1px solid var(--border)}.visit-section h2{margin:0 0 .75rem;font-family:var(--font-display);font-size:1.25rem;color:var(--text-strong)}.address-block{font-style:normal;line-height:1.65;color:var(--text);margin-bottom:.75rem}.visit-note{margin:0;font-size:.95rem}.visit-note a{color:var(--accent-dark);font-weight:600;text-decoration:none}.visit-note a:hover{text-decoration:underline}.site-footer{margin-top:auto;padding:1.25rem clamp(1rem,3vw,1.5rem);border-top:1px solid var(--border);background:var(--surface-muted);text-align:center}.site-footer p{margin:0;font-size:.88rem;color:var(--text-muted)}.site-footer a{color:var(--accent-dark);font-weight:600;text-decoration:none}.cart-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f141973;opacity:0;pointer-events:none;transition:opacity .25s;z-index:90}.cart-backdrop--open{opacity:1;pointer-events:auto}.cart-panel{position:fixed;top:0;right:0;width:min(100%,400px);height:100svh;background:var(--surface-elevated);border-left:1px solid var(--border);z-index:100;display:flex;flex-direction:column;padding:1rem 1.15rem 1.5rem;box-sizing:border-box;transform:translate(100%);transition:transform .28s ease;box-shadow:var(--shadow-lg)}.cart-panel--open{transform:translate(0)}.cart-panel__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.cart-panel__head h2{margin:0;font-size:1.15rem;font-family:var(--font-display);color:var(--text-strong)}.cart-panel__close{width:2.25rem;height:2.25rem;border:none;background:var(--surface-muted);border-radius:var(--radius-sm);font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-strong)}.cart-panel__close:hover{background:var(--border)}.cart-empty{color:var(--text-muted);margin:1rem 0}.cart-list{list-style:none;margin:0;padding:0;flex:1;overflow:auto}.cart-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem 0;border-bottom:1px solid var(--border);font-size:.92rem}.cart-row__left{display:flex;align-items:center;gap:.65rem;min-width:0;flex:1}.cart-row__thumb{width:48px;height:48px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);flex-shrink:0;background:var(--surface-muted)}.cart-row__name{color:var(--text-strong);font-weight:500;min-width:0}.cart-row__qty{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.cart-row__qty button{width:1.85rem;height:1.85rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:1rem;line-height:1}.cart-row__qty button:hover{border-color:var(--accent)}.cart-panel__actions{display:flex;flex-direction:column;gap:.6rem;margin-top:1rem}.cart-hint{margin:1rem 0 0;font-size:.82rem;color:var(--text-muted);line-height:1.45}.toast{position:fixed;bottom:1.25rem;left:50%;transform:translate(-50%);width:min(calc(100% - 2rem),420px);padding:1rem 1.1rem;background:var(--text-strong);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:120;animation:toast-in .35s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast__title{margin:0 0 .35rem;font-weight:700;font-size:1rem}.toast__body{margin:0 0 .65rem;font-size:.9rem;line-height:1.45;opacity:.95}.toast__dismiss{background:color-mix(in srgb,#fff 18%,transparent);border:none;color:#fff;padding:.35rem .65rem;border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer}.toast__dismiss:hover{background:color-mix(in srgb,#fff 28%,transparent)}@media (min-width: 640px){.toast{left:auto;right:1.25rem;transform:none;animation-name:toast-in-right}@keyframes toast-in-right{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}}
