*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#301011;--primary-light:#4a1a1c;--primary-dark:#1e0a0b;--accent:#d3bd7d;--accent-light:#e8d49a;--accent-dark:#b8a05e;--cream:#f5edd6;--cream-muted:#c4b38f;--font-serif:"Cormorant Garamond", Georgia, serif;--font-sans:"Jost", system-ui, sans-serif}html{scroll-behavior:smooth}body{background-color:var(--primary);color:var(--cream);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;font-weight:300;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-sans)}#root{width:100%;min-height:100svh}.nav{z-index:100;justify-content:space-between;align-items:center;padding:1.5rem 4rem;transition:background .35s,padding .35s,box-shadow .35s;display:flex;position:fixed;top:0;left:0;right:0}.nav--scrolled{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1e0a0beb;padding:1rem 4rem;box-shadow:0 1px #d3bd7d26}.nav__logo{flex-shrink:0;line-height:0}.nav__logo-img{mix-blend-mode:multiply;filter:brightness(1.05);width:auto;height:52px}.nav__links{align-items:center;gap:2.5rem;list-style:none;display:flex}.nav__links a{letter-spacing:.12em;text-transform:uppercase;color:var(--cream-muted);font-size:.85rem;font-weight:400;transition:color .2s}.nav__links a:hover{color:var(--cream)}.nav__cta{background:var(--accent);border-radius:2px;padding:.55rem 1.4rem;color:var(--primary)!important;font-weight:500!important;transition:background .2s!important}.nav__cta:hover{background:var(--accent-light)!important}.nav__burger{background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:none}.nav__burger span{background:var(--accent);width:24px;height:2px;transition:transform .3s,opacity .3s;display:block}.nav__burger--open span:first-child{transform:translateY(7px)rotate(45deg)}.nav__burger--open span:nth-child(2){opacity:0}.nav__burger--open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}@media (width<=768px){.nav{padding:1.25rem 1.5rem}.nav--scrolled{padding:1rem 1.5rem}.nav__burger{display:flex}.nav__links{background:var(--primary-dark);border-top:1px solid #d3bd7d33;flex-direction:column;gap:0;padding:.75rem 0 1.25rem;display:none;position:absolute;top:100%;left:0;right:0;box-shadow:0 12px 32px #0006}.nav__links--open{display:flex}.nav__links li{width:100%}.nav__links a{align-items:center;min-height:44px;padding:1rem 1.75rem;font-size:.9rem;display:flex}.nav__cta{text-align:center;border-radius:2px;justify-content:center;margin:.5rem 1.75rem 0}}.hero{text-align:center;justify-content:center;align-items:center;min-height:100svh;padding:0 1.5rem;display:flex;position:relative;overflow:hidden}.hero__bg{pointer-events:none;position:absolute;inset:0}.hero__grain{opacity:.4;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");position:absolute;inset:0}.hero__glow{filter:blur(120px);pointer-events:none;border-radius:50%;position:absolute}.hero__glow--1{background:radial-gradient(circle,#d3bd7d1f 0%,#0000 70%);width:600px;height:600px;top:-100px;right:-100px}.hero__glow--2{background:radial-gradient(circle,#4a1a1ccc 0%,#0000 70%);width:500px;height:500px;bottom:-80px;left:-80px}.hero__content{z-index:1;max-width:780px;position:relative}.hero__logo{mix-blend-mode:multiply;filter:brightness(1.05);opacity:0;width:auto;height:160px;margin:0 auto 1.5rem;animation:.8s forwards heroFade}.hero__eyebrow{letter-spacing:.22em;text-transform:uppercase;color:var(--accent);opacity:0;margin-bottom:1.5rem;font-size:.78rem;animation:.6s .15s forwards heroFade}.hero__title{font-family:var(--font-serif);letter-spacing:-.01em;color:var(--cream);margin-bottom:1.75rem;font-size:clamp(3.2rem,8vw,7rem);font-weight:300;line-height:1.05}.hero__title em{color:var(--accent);font-style:italic}.hero__subtitle{color:var(--cream-muted);opacity:0;max-width:520px;margin:0 auto 2.5rem;font-size:1.05rem;line-height:1.75;animation:.7s cubic-bezier(.16,1,.3,1) 1.1s forwards heroRise}.hero__actions{opacity:0;flex-wrap:wrap;justify-content:center;gap:1rem;animation:.7s cubic-bezier(.16,1,.3,1) 1.3s forwards heroRise;display:flex}.hero__scroll{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.hero__scroll span{background:linear-gradient(to bottom, var(--accent), transparent);width:1px;height:60px;margin:0 auto;animation:2s ease-in-out infinite scrollLine;display:block}@keyframes scrollLine{0%{opacity:0;transform-origin:top;transform:scaleY(0)}50%{opacity:1;transform:scaleY(1)}to{opacity:0;transform-origin:bottom;transform:scaleY(1)}}@keyframes pourIn{0%{clip-path:inset(105% 0 0);opacity:0;transform:translateY(10px)}12%{opacity:1}to{clip-path:inset(0% 0 0);opacity:1;transform:translateY(0)}}@keyframes heroFade{0%{opacity:0}to{opacity:1}}@keyframes heroRise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.pour-word{clip-path:inset(0 0 105%);animation:pourIn var(--pour-duration,.65s) cubic-bezier(.16, 1, .3, 1) var(--d,0s) forwards;display:inline-block}.btn{font-family:var(--font-sans);letter-spacing:.12em;text-transform:uppercase;border-radius:2px;padding:.85rem 2.2rem;font-size:.85rem;font-weight:400;transition:all .2s;display:inline-block}.btn--accent{background:var(--accent);color:var(--primary)}.btn--accent:hover{background:var(--accent-light)}.btn--ghost{color:var(--cream-muted);border:1px solid #d3bd7d66}.btn--ghost:hover{border-color:var(--accent);color:var(--cream)}.divider{letter-spacing:.2em;text-transform:uppercase;color:var(--cream-muted);border-top:1px solid #d3bd7d26;border-bottom:1px solid #d3bd7d26;justify-content:center;align-items:center;gap:1.5rem;padding:2rem;font-size:.75rem;display:flex}.divider span:first-child,.divider span:last-child{color:var(--accent);font-size:.65rem}#menu,#specialties,#about,#visit{scroll-margin-top:72px}.section{width:100%;max-width:1200px;margin:0 auto;padding:7rem 2rem}.section__header{text-align:center;margin-bottom:4rem}.section__eyebrow{letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;font-size:.78rem}.section__title{font-family:var(--font-serif);color:var(--cream);margin-bottom:1rem;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;line-height:1.1}.section__subtitle{color:var(--cream-muted);max-width:480px;margin:0 auto;font-size:1rem;line-height:1.7}.menu__layout{grid-template-columns:1fr 1fr;align-items:start;gap:4rem;display:grid}.menu__sections{flex-direction:column;gap:2.5rem;display:flex}.menu__category-heading{font-family:var(--font-serif);color:var(--accent);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid #d3bd7d40;margin-bottom:.75rem;padding-bottom:.6rem;font-size:1.3rem;font-style:italic;font-weight:400}.menu__list{flex-direction:column;gap:.85rem;list-style:none;display:flex}.menu__item{justify-content:space-between;align-items:baseline;gap:1rem;display:flex}.menu__item-info{flex-direction:column;gap:.2rem;display:flex}.menu__item-name{color:var(--cream);font-size:.975rem;font-weight:400}.menu__item-desc{color:var(--cream-muted);max-width:340px;font-size:.8rem;line-height:1.5}.menu__item-price{font-family:var(--font-serif);color:var(--accent);white-space:nowrap;flex-shrink:0;font-size:1rem}.menu__category--addons .menu__item-name,.menu__category--addons .menu__item-price{color:var(--cream-muted);font-size:.875rem}.menu__image-wrap{position:sticky;top:6rem}.menu__image{border-radius:4px;width:100%;box-shadow:0 20px 60px #00000080}@media (width<=860px){.menu__layout{grid-template-columns:1fr;gap:3rem}.menu__image-wrap{max-width:480px;margin:0 auto;position:static}}.about{padding-top:0}.about__inner{grid-template-columns:1fr 1fr;align-items:center;gap:5rem;display:grid}.about__visual{justify-content:center;align-items:center;min-height:400px;display:flex;position:relative}.about__orb{background:radial-gradient(circle,#d3bd7d14,#0000 70%);border-radius:50%;position:absolute;inset:0}.about__frame{z-index:1;text-align:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#4a1a1c4d;border:1px solid #d3bd7d40;padding:3rem 2.5rem;position:relative}.about__beans{color:var(--accent);opacity:.7;justify-content:center;gap:1rem;margin-bottom:2rem;font-size:1.2rem;display:flex}.about__quote{font-family:var(--font-serif);color:var(--cream);font-size:1.3rem;font-style:italic;font-weight:300;line-height:1.6}.about__text{flex-direction:column;gap:1.25rem;display:flex}.about__text .section__eyebrow{display:block}.about__text p{color:var(--cream-muted);font-size:.975rem;line-height:1.8}.about__text .btn{align-self:flex-start;margin-top:.5rem}@media (width<=900px){.about__inner{grid-template-columns:1fr;gap:3rem}.about__visual{min-height:280px}}.visit{border-top:1px solid #d3bd7d1f}.visit__grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.visit-card{background:#4a1a1c40;border:1px solid #d3bd7d26;border-radius:2px;flex-direction:column;gap:1rem;padding:2.5rem 2rem;display:flex}.visit-card__icon{color:var(--accent);font-size:1.8rem;line-height:1}.visit-card h3{font-family:var(--font-serif);color:var(--cream);font-size:1.4rem;font-weight:400}.visit-card ul{flex-direction:column;gap:.5rem;list-style:none;display:flex}.visit-card li{color:var(--cream-muted);border-bottom:1px solid #d3bd7d1a;justify-content:space-between;padding-bottom:.5rem;font-size:.9rem;display:flex}.visit-card p{color:var(--cream-muted);font-size:.9rem;line-height:1.7}.visit-card__social{gap:.75rem;margin-top:auto;display:flex}.visit-card__social a{letter-spacing:.1em;text-transform:uppercase;width:36px;height:36px;color:var(--cream-muted);border:1px solid #d3bd7d4d;border-radius:2px;justify-content:center;align-items:center;font-size:.7rem;transition:all .2s;display:inline-flex}.visit-card__social a:hover{border-color:var(--accent);color:var(--accent)}@media (width<=860px){.visit__grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}}.footer{background:var(--primary-dark);text-align:center;border-top:1px solid #d3bd7d26;padding:4rem 2rem}.footer__inner{flex-direction:column;align-items:center;gap:1.25rem;max-width:800px;margin:0 auto;display:flex}.footer__logo-img{mix-blend-mode:multiply;filter:brightness(1.05);width:auto;height:90px}.footer__tagline{color:var(--cream-muted);font-size:.85rem;font-style:italic}.footer__links{flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:.5rem;display:flex}.footer__links a{letter-spacing:.15em;text-transform:uppercase;color:var(--cream-muted);font-size:.78rem;transition:color .2s}.footer__links a:hover{color:var(--accent)}.footer__copy{color:#c4b38f73;margin-top:.5rem;font-size:.78rem}.showcase{height:100svh;position:relative;overflow:hidden}.showcase__track{scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;height:100%;display:flex;overflow-x:scroll}.showcase__track::-webkit-scrollbar{display:none}.showcase__slide{scroll-snap-align:start;text-align:center;flex:0 0 100%;justify-content:center;align-items:center;height:100%;padding:2rem;display:flex;position:relative;overflow:hidden}.showcase__glow{background:radial-gradient(ellipse at 50% 60%, var(--glow), transparent 65%);pointer-events:none;position:absolute;inset:0}.showcase__ring{pointer-events:none;border:1px solid #ffffff0f;border-radius:50%;position:absolute;top:50%;left:50%}.showcase__ring--outer{width:min(700px,120vw);height:min(700px,120vw);animation:25s linear infinite spin;transform:translate(-50%,-50%)}.showcase__ring--inner{border-color:#ffffff0a;width:min(450px,80vw);height:min(450px,80vw);animation:18s linear infinite reverse spin;transform:translate(-50%,-50%)}@keyframes spin{0%{transform:translate(-50%,-50%)rotate(0)}to{transform:translate(-50%,-50%)rotate(360deg)}}.showcase__content{z-index:1;flex-direction:column;align-items:center;gap:1rem;max-width:620px;display:flex;position:relative}.showcase__eyebrow{letter-spacing:.25em;text-transform:uppercase;color:var(--accent-slide);opacity:.8;font-size:.72rem}.showcase__symbol{color:var(--accent-slide);opacity:.6;margin:.25rem 0;font-size:2.5rem;line-height:1}.showcase__name{font-family:var(--font-serif);color:#fff;letter-spacing:-.01em;font-size:clamp(2.4rem,6vw,5rem);font-weight:300;line-height:1.05}.showcase__desc{color:#ffffff8c;max-width:420px;font-size:.9rem;line-height:1.7}.showcase__ingredients{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:.25rem;list-style:none;display:flex}.showcase__ingredients li{letter-spacing:.1em;text-transform:uppercase;color:var(--accent-slide);opacity:.75;border:1px solid;border-radius:999px;padding:.3rem .85rem;font-size:.72rem}.showcase__price{font-family:var(--font-serif);color:var(--accent-slide);margin-top:.25rem;font-size:1.8rem;font-weight:300}.showcase__dots{z-index:10;gap:.6rem;display:flex;position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}.showcase__dot{cursor:pointer;background:#ffffff40;border:none;border-radius:50%;width:6px;height:6px;padding:0;transition:all .3s}.showcase__dot--active{background:var(--accent-slide);border-radius:999px;width:24px}.showcase__hint{letter-spacing:.15em;text-transform:uppercase;color:#ffffff40;z-index:10;align-items:center;gap:.5rem;font-size:.7rem;display:flex;position:absolute;bottom:2rem;right:2rem}@media (hover:hover){.showcase__hint{display:none}}@media (width<=860px){.section{padding:5rem 1.5rem}}@media (width<=640px){.nav__logo-img{height:44px}.hero{align-items:flex-start;padding:30svh 1.25rem 5rem}.hero__logo{height:110px}.hero__eyebrow{margin-bottom:1rem;font-size:.7rem}.hero__title{margin-bottom:1.25rem;font-size:2.6rem}.hero__subtitle{margin-bottom:2rem;font-size:.95rem}.hero__actions{flex-direction:column;align-items:stretch;gap:.75rem}.hero__actions .btn{text-align:center;padding:1rem}.hero__scroll{display:none}.divider{text-align:center;flex-direction:column;gap:.4rem;padding:1.25rem}.divider span:first-child,.divider span:last-child{display:none}.section{padding:4rem 1.25rem}.section__header{margin-bottom:2.5rem}.menu__layout{gap:2.5rem}.menu__image-wrap{order:-1}.menu__sections{gap:2rem}.menu__item-desc{max-width:100%}.showcase__name{font-size:2.2rem}.showcase__desc{font-size:.85rem}.showcase__content{gap:.75rem}.showcase__dots{bottom:1.5rem}.showcase__hint{bottom:1.5rem;right:1.25rem}.about__visual{min-height:200px}.about__frame{padding:2rem 1.5rem}.about__quote{font-size:1.1rem}.about__text .btn{text-align:center;align-self:stretch}.visit__grid{gap:1rem;max-width:100%}.visit-card{padding:1.75rem 1.25rem}.visit-card__social a{width:44px;height:44px}.footer{padding:3rem 1.25rem}.footer__logo-img{height:70px}.footer__links{gap:1rem}.footer__copy{font-size:.72rem}}@media (width<=380px){.hero__title{font-size:2.2rem}.nav{padding:1rem 1.25rem}.nav--scrolled{padding:.75rem 1.25rem}}
