:root{
  --cream: #F6EBD2;
  --cream-2: #FBF3DD;
  --espresso: #1B0F07;
  --espresso-2: #2D1A0E;
  --mustard: #F2B705;
  --mustard-deep:#D89A00;
  --brown: #6B3A1A;
  --brown-deep: #4A2510;
  --amber: #F2B705;
  --matcha: #8FA86A;
  --pink: #F4B6A0;
  --line: rgba(27,15,7,0.12);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;padding:0;
  background:var(--cream);color:var(--espresso);
  font-family:"Manrope",system-ui,sans-serif;font-size:17px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

::selection{background:var(--mustard);color:var(--espresso)}

h1,h2,h3,h4{font-family:"Bricolage Grotesque",serif;font-weight:800;letter-spacing:-0.02em;line-height:0.95;margin:0}
.script{font-family:"Caveat",cursive;font-weight:700;letter-spacing:0;line-height:1}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- grain overlay ---------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;mix-blend-mode:multiply;opacity:.06;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .35s ease, backdrop-filter .35s ease, padding .25s ease, color .25s ease, box-shadow .25s ease;
  color:var(--brown-deep);
  background:transparent;
  backdrop-filter:none;-webkit-backdrop-filter:none;
}
.nav-inner{
  max-width:1352px;margin:0 auto;padding:18px 36px;
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;
  transition:padding .25s ease;
}
.nav.scrolled{
  background:rgba(246,235,210,0.94);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  color:var(--espresso);
  box-shadow:0 1px 0 rgba(74,37,16,0.08);
}
.nav.scrolled .nav-inner{padding:16px 36px}
.nav.scrolled .brand-logo{transform:translateY(-4px)}
.nav.nav--dark.scrolled{
  background:rgba(27,15,7,0.88);
  color:var(--cream-2);
  box-shadow:0 1px 0 rgba(246,235,210,0.07);
}
.nav.nav--dark .links a:hover{background:rgba(246,235,210,0.1)}
.nav.nav--dark .links a.active{background:rgba(242,183,5,0.2);color:var(--mustard)}
.nav .brand{display:flex;align-items:center;gap:10px;justify-self:start}
.nav .brand-logo{display:block;height:32px;width:auto;}
.nav .brand-logo svg{display:block;height:100%;width:auto}
.nav .links{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  display:flex;gap:4px;align-items:center;flex-wrap:nowrap;
}
.nav .links a{
  padding:10px 18px;border-radius:999px;font-size:15px;font-weight:600;
  transition:background .2s, color .2s;white-space:nowrap;
  letter-spacing:-0.01em;
  font-family:"Bricolage Grotesque",serif;
  display:inline-flex;align-items:center;gap:7px;
}
.nav-icon{
  width:14px;height:14px;flex-shrink:0;
  opacity:.55;transition:opacity .2s,transform .2s;
}
.nav .links a:hover .nav-icon{opacity:1;transform:scale(1.15)}
.nav .links a:hover{background:rgba(107,58,26,0.1)}
.nav.scrolled .links a:hover{background:rgba(107,58,26,0.1)}
.nav .links a.active{background:rgba(242,183,5,0.18);color:var(--espresso)}
.nav-social{display:flex;gap:6px;align-items:center}
.nav-social-btn{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--mustard);color:var(--espresso);
  transition:background .2s, transform .15s;flex-shrink:0;
}
.nav-social-btn:hover{background:#FFD24D;transform:translateY(-2px)}
.nav .menu-btn{display:none;background:none;border:0;color:inherit;font-size:28px;cursor:pointer;padding:10px 12px;justify-self:end}

/* ---------- hero ---------- */
.hero{
  position:relative;min-height:100vh;
  background:var(--cream);
  color:var(--espresso);
  overflow:hidden;
  isolation:isolate;
  padding:180px 36px 120px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(60% 50% at 50% 35%, rgba(242,183,5,0.10), transparent 65%),
    radial-gradient(40% 40% at 20% 80%, rgba(107,58,26,0.05), transparent 60%),
    radial-gradient(40% 40% at 80% 80%, rgba(232,115,44,0.05), transparent 60%);
}
.hero-decor{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero-decor .deco{position:absolute;display:block}
.hero-decor .deco svg{width:100%;height:100%;display:block}
.hero-content{position:relative;z-index:2;max-width:780px;display:flex;flex-direction:column;align-items:center}

/* deco positions and animations */
.deco-bean1{top:14%;left:8%;width:64px;height:64px;animation:floatA 7s ease-in-out infinite}
.deco-cup{top:18%;right:9%;width:78px;height:78px;animation:floatB 9s ease-in-out infinite}
.deco-hotdog{top:34%;left:6%;width:120px;height:60px;animation:floatA 8s ease-in-out infinite .3s}
.deco-steam{top:42%;right:7%;width:54px;height:54px;animation:floatB 6s ease-in-out infinite .5s}
.deco-leaf{bottom:18%;left:10%;width:74px;height:74px;animation:floatA 10s ease-in-out infinite .8s}
.deco-drip{bottom:14%;right:14%;width:38px;height:50px;animation:floatB 7s ease-in-out infinite}
.deco-bean2{bottom:30%;right:5%;width:46px;height:46px;animation:floatA 8s ease-in-out infinite}
.deco-spark1{top:30%;left:18%;width:30px;height:30px;animation:twinkle 3s ease-in-out infinite}
.deco-spark2{top:62%;right:20%;width:24px;height:24px;animation:twinkle 4s ease-in-out infinite 1s}
.deco-spark3{bottom:38%;left:22%;width:18px;height:18px;animation:twinkle 5s ease-in-out infinite .5s}
.deco-tea{bottom:24%;right:24%;width:46px;height:70px;animation:floatA 9s ease-in-out infinite 1s}
.deco-bean3{top:60%;left:10%;width:48px;height:48px;animation:floatB 7s ease-in-out infinite .4s}

@keyframes floatA{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-14px) rotate(2deg)}}
@keyframes floatB{0%,100%{transform:translateY(0) rotate(4deg)}50%{transform:translateY(10px) rotate(-3deg)}}
@keyframes twinkle{0%,100%{transform:scale(.7);opacity:.5}50%{transform:scale(1);opacity:1}}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;letter-spacing:0.18em;text-transform:uppercase;font-weight:700;
  color:var(--brown);margin-bottom:24px;
}
.hero-eyebrow::before{content:"";width:32px;height:1px;background:var(--brown);display:inline-block}

.hero-logo{width:min(720px, 92vw);margin:0 auto 8px}
.hero-logo svg{width:100%;height:auto;display:block;filter:drop-shadow(0 6px 18px rgba(74,37,16,0.12))}

.hero-logo-mini{display:none}
.hero-eyebrow-line{display:none}

.hero-cafe{
  font-family:"Caveat",cursive;font-weight:700;
  color:var(--mustard);font-size:clamp(64px, 10vw, 140px);
  line-height:0.85;margin-top:-30px;margin-left:30%;
  transform:rotate(-4deg);
  text-shadow:0 4px 30px rgba(0,0,0,0.4);
}

.hero-tag{
  max-width:560px;font-size:clamp(17px, 1.3vw, 20px);font-weight:500;color:var(--brown-deep);
  margin:36px 0 32px;line-height:1.5;
}
.hero-tag b{color:var(--espresso);font-weight:700}

.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;border-radius:999px;
  font-family:"Manrope",sans-serif;font-weight:700;font-size:15px;
  cursor:pointer;border:1.5px solid transparent;transition:transform .15s, background .15s, border-color .15s;
}
.btn-primary{background:var(--mustard);color:var(--espresso)}
.btn-primary:hover{background:#FFD24D;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--brown-deep);border-color:rgba(75,37,16,0.3)}
.btn-ghost:hover{border-color:var(--brown);background:rgba(107,58,26,0.06)}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(3px)}

.hero-meta{display:none}
.float-chip{display:none}
.hero-stamp{display:none}

@media (max-width:900px){.hero{grid-template-columns:1fr}}

.scroll-cue{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  color:rgba(75,37,16,0.6);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;font-weight:700;
  display:flex;flex-direction:column;align-items:center;gap:8px;z-index:3;
}
.scroll-cue .line{width:1px;height:32px;background:linear-gradient(180deg,rgba(75,37,16,0.6),transparent);animation:drop 2s linear infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- feature strip ---------- */
.feat-strip{
  background:var(--cream);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:28px 36px;
  position:relative;
}
.feat-strip::before, .feat-strip::after{
  content:"★";position:absolute;top:50%;transform:translateY(-50%);
  color:var(--mustard);font-size:14px;
}
.feat-strip::before{left:36px}
.feat-strip::after{right:36px}
.feat{
  display:flex;justify-content:center;gap:36px;flex-wrap:wrap;align-items:center;
  max-width:1180px;margin:0 auto;
  font-family:"Bricolage Grotesque",serif;font-weight:600;font-size:15px;
  color:var(--brown-deep);letter-spacing:-0.005em;
}
.feat span{display:inline-flex;align-items:center;gap:10px;white-space:nowrap}
.feat .dot{
  width:8px;height:8px;border-radius:50%;
  display:inline-block;flex-shrink:0;
}
@media (max-width:760px){
  .feat-strip{padding:20px 20px}
  .feat-strip::before,.feat-strip::after{display:none}
  .feat{gap:18px;font-size:14px}
}

/* ---------- marquee (legacy, unused) ---------- */
.marquee{
  background:var(--mustard);color:var(--espresso);
  padding:18px 0;overflow:hidden;border-top:2px solid var(--espresso);border-bottom:2px solid var(--espresso);
}
.marquee-track{display:flex;gap:48px;animation:scroll 35s linear infinite;white-space:nowrap;width:max-content}
.marquee span{font-family:"Bricolage Grotesque",serif;font-weight:800;font-size:28px;letter-spacing:-0.01em;display:inline-flex;align-items:center;gap:48px}
.marquee span::after{content:"✦";color:var(--brown);font-size:20px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- section base ---------- */
section{padding:120px 36px;position:relative}
.container{max-width:1280px;margin:0 auto}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:0.2em;text-transform:uppercase;font-weight:700;
  color:var(--brown);margin-bottom:18px;
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--brown);display:inline-block}

.h-display{font-size:clamp(32px, 4vw, 60px);letter-spacing:-0.035em;line-height:0.92}
.h-display em{font-family:"Caveat",cursive;font-weight:700;font-style:normal;color:var(--amber);letter-spacing:0;font-size:1.15em}

/* ---------- categories ---------- */
.cats-head{display:flex;align-items:end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:60px}
.cats-head p{max-width:380px;color:var(--brown-deep);margin:0;font-size:17px}

.catgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.catitem{
  position:relative;border-radius:18px;overflow:hidden;
  height:220px;isolation:isolate;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px;color:var(--cream);
}
.catitem-bg{
  position:absolute;inset:0;z-index:-2;
  background-size:cover;background-position:center;
  transition:transform .6s ease;
}
.catitem:hover .catitem-bg{transform:scale(1.06)}
.catitem::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,transparent 20%,rgba(27,15,7,0.82) 100%);
}
.catitem-name{font-family:"Bricolage Grotesque",serif;font-weight:800;font-size:22px;letter-spacing:-0.02em;line-height:1}
.catitem-desc{font-size:13px;color:rgba(246,235,210,0.75);margin-top:4px;line-height:1.4}

/* ---------- menu ---------- */
.menu-section{background:var(--espresso);color:var(--cream);border-radius:48px 48px 0 0;margin-top:-60px;padding-top:160px}
.menu-section .eyebrow{color:var(--mustard)}
.menu-section .eyebrow::before{background:var(--mustard)}
.menu-section .h-display em{color:var(--mustard)}

.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:60px}
.menu-col h3{font-size:24px;letter-spacing:-0.01em;margin-bottom:6px}
.menu-col .col-tag{font-family:"Caveat",cursive;font-size:22px;color:var(--mustard);margin-bottom:24px;display:inline-block}
.menu-list{list-style:none;padding:0;margin:0}
.menu-list li{
  display:grid;grid-template-columns:1fr auto;gap:12px;align-items:baseline;
  padding:18px 0;border-bottom:1px solid rgba(246,235,210,0.1);
}
.menu-list .nm{font-family:"Bricolage Grotesque",serif;font-weight:700;font-size:20px;letter-spacing:-0.01em}
.menu-list .nm small{display:block;font-family:"Manrope",sans-serif;font-weight:400;font-size:13px;color:rgba(246,235,210,0.55);margin-top:4px;letter-spacing:0}
.menu-list .pr{font-family:"Bricolage Grotesque",serif;font-weight:800;font-size:20px;color:var(--mustard);white-space:nowrap}
.menu-list .tag{
  display:inline-block;font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  background:var(--matcha);color:var(--espresso);padding:2px 8px;border-radius:999px;margin-left:10px;vertical-align:2px;
}
.menu-list .tag.hot{background:var(--amber);color:var(--espresso)}
.menu-list .tag.new{background:var(--mustard);color:var(--espresso)}

/* ---------- gallery ---------- */
.gallery-section{background:var(--espresso);padding:0 0 0;margin-top:0}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:24px}
.gallery .g{aspect-ratio:1;overflow:hidden;border-radius:18px;position:relative}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;display:block}
.gallery .g:hover img{transform:scale(1.06)}

/* ---------- about ---------- */
.about{background:var(--cream-2);border-radius:0 0 48px 48px;padding-top:120px;padding-bottom:120px}
.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:center}
.about-text p{font-size:18px;line-height:1.65;color:var(--brown-deep);margin:0 0 18px}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px;padding-top:30px;border-top:1px solid var(--line)}
.stat .n{font-family:"Bricolage Grotesque",serif;font-weight:800;font-size:42px;color:var(--brown);letter-spacing:-0.02em;line-height:1}
.stat .l{font-size:13px;color:var(--brown-deep);margin-top:4px}
.about-img{
  border-radius:32px;overflow:hidden;aspect-ratio:0.95;
  position:relative;
  box-shadow:0 30px 60px -20px rgba(75,37,16,0.4);
}
.about-img img{width:100%;height:100%;object-fit:cover}

/* ---------- visit ---------- */
.visit{padding:140px 36px}
.visit-head{text-align:center;margin-bottom:72px}
.visit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.v-card{
  background:#fff;border-radius:28px;padding:36px;border:1px solid var(--line);
  display:flex;flex-direction:column;gap:16px;
  transition:transform .25s, box-shadow .25s;
}
.v-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px -25px rgba(75,37,16,0.4)}
.v-card .ico{
  width:48px;height:48px;border-radius:14px;background:var(--mustard);
  display:flex;align-items:center;justify-content:center;color:var(--espresso);
}
.v-card h4{font-size:24px;letter-spacing:-0.01em}
.v-card p{margin:0;color:var(--brown-deep)}
.v-card .strong{font-family:"Bricolage Grotesque",serif;font-weight:700;font-size:20px;color:var(--espresso);letter-spacing:-0.01em}
.v-card a{color:var(--brown);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.hours{display:grid;grid-template-columns:1fr auto;gap:6px 14px;margin:0;padding:0;list-style:none;font-size:15px}
.hours dt{color:var(--brown-deep)}
.hours dd{margin:0;font-family:"Bricolage Grotesque",serif;font-weight:700;color:var(--espresso)}

/* ---------- footer ---------- */
footer{
  background:var(--espresso);color:var(--cream);
  padding:80px 36px 40px;
  border-radius:48px 48px 0 0;
}
.ft-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;margin-bottom:60px;align-items:start}
.ft-brand h2{font-size:64px;letter-spacing:-0.03em}
.ft-brand h2 em{font-family:"Caveat",cursive;font-style:normal;color:var(--mustard);font-weight:700}
.ft-brand p{color:rgba(246,235,210,0.6);max-width:340px;margin:18px 0 24px}
.ft-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;border:1px solid rgba(246,235,210,0.25);
  font-weight:700;font-size:14px;
  transition:background .2s, border-color .2s;
}
.ft-cta:hover{background:rgba(246,235,210,0.08);border-color:var(--cream)}
.ft-col h5{font-family:"Bricolage Grotesque",serif;font-weight:700;font-size:14px;letter-spacing:0.16em;text-transform:uppercase;color:var(--mustard);margin:0 0 18px}
.ft-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;color:rgba(246,235,210,0.75);font-size:15px}
.ft-col a:hover{color:var(--cream)}
.ft-bottom{display:flex;justify-content:center;align-items:center;padding-top:30px;border-top:1px solid rgba(246,235,210,0.12);font-size:13px;color:rgba(246,235,210,0.5);flex-wrap:wrap;gap:6px}

/* ---------- preloader ---------- */
#preloader{
  position:fixed;inset:0;z-index:9999;
  background:var(--cream);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s ease, visibility .5s ease;
}
#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{display:flex;flex-direction:column;align-items:center;gap:52px}
.preloader-logo{width:clamp(200px, 50vw, 320px)}
.preloader-logo svg{width:100%;height:auto;display:block}
.preloader-cup svg{overflow:visible}
.cup-fill{
  transform-box:fill-box;
  transform-origin:bottom;
  transform:scaleY(0);
  animation:cupFill 1.6s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes cupFill{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.steam{
  opacity:0;
  animation:steamRise 1.3s ease-in-out infinite;
}
.steam.s1{animation-delay:1.4s}
.steam.s2{animation-delay:1.8s}
.steam.s3{animation-delay:2.2s}
@keyframes steamRise{
  0%{opacity:0;transform:translateY(4px)}
  40%{opacity:0.55}
  100%{opacity:0;transform:translateY(-12px)}
}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width: 900px){
  .hero{grid-template-columns:1fr;gap:30px}
  .hero-visual{height:60vh;min-height:380px;order:2}
  .hero-content{order:1}
  .hero-stamp{width:100px;height:100px;font-size:18px;left:-4%}
}
@media (max-width: 760px){
  .nav-inner{padding:12px 18px;grid-template-columns:1fr auto}
  .nav-social{display:none}
  .nav.nav--dark .links a{color:var(--espresso)}
  .hero-decor .deco{display:none}
  .hero-decor .deco-cup{display:block;top:18%;right:8%;left:auto;width:55px;height:55px;}
  .hero-decor .deco-leaf{display:block;top:20%;left:6%;bottom:auto;width:52px;height:52px;}
  .hero-decor .deco-hotdog{display:block;bottom:16%;top:auto;left:58%;transform:translateX(-50%);width:90px;height:45px;}
  .hero-decor .deco-bean2{display:block;bottom:14%;top:auto;left:18%;width:40px;height:40px;}
  .nav .links{
    left:0 !important;right:0;top:100%;bottom:auto;
    transform:translateY(-6px) !important;
    flex-direction:column;gap:2px;
    background:rgba(251,243,221,0.98);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    padding:10px 12px 18px;
    box-shadow:0 12px 40px rgba(27,15,7,0.1);
    opacity:0;pointer-events:none;
    transition:opacity .25s ease, transform .25s ease;
  }
  .nav.open .links{opacity:1 !important;transform:translateY(0) !important;pointer-events:auto}
  .nav .links a{
    width:100%;padding:14px 18px;font-size:16px;
    border-radius:10px;box-sizing:border-box;
    justify-content:flex-start;
  }
  .nav .menu-btn{display:block}
  .nav .cta{display:none}
  .hero{padding:130px 20px 80px}
  .deco-tea,.deco-bean3{display:none}
  .chip-1,.chip-2{display:none}
  section{padding:80px 20px}
  .catgrid{grid-template-columns:1fr 1fr;gap:10px}
  .menu-grid,.about-grid{grid-template-columns:1fr;gap:50px}
  .visit-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .ft-top{grid-template-columns:1fr;gap:40px}
  .hero-cafe{margin-left:0;font-size:18vw;margin-top:-10px}
}
@media (max-width: 480px){
  .catgrid{grid-template-columns:1fr 1fr}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{justify-content:center}
}
