:root{
  --cream:#F6EEE1;--cream-2:#EFE4D2;--char:#241C16;--char-2:#4A3D32;
  --ember:#C2562F;--ember-2:#E0743F;--gold:#A9802F;--line:rgba(36,28,22,.14);
  --maxw:1160px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--char);font-family:"Jost",system-ui,sans-serif;font-weight:300;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.section{max-width:var(--maxw);margin:0 auto;padding:7rem 1.6rem}
h1,h2,h3,.logo{font-family:"Fraunces",Georgia,serif;font-weight:400}
.kicker{font-family:"Jost",sans-serif;text-transform:uppercase;letter-spacing:.28em;font-size:.72rem;color:var(--ember);font-weight:500;margin-bottom:1.1rem}
em{font-style:italic}

/* builtby */
.builtby{position:fixed;left:1rem;bottom:1rem;z-index:1000;font-size:.74rem;letter-spacing:.04em;color:var(--char-2);background:rgba(246,238,225,.85);border:1px solid var(--line);padding:.5rem .9rem;border-radius:999px;backdrop-filter:blur(6px);transition:.25s}
.builtby strong{color:var(--ember);font-weight:500}
.builtby:hover{border-color:var(--ember);transform:translateY(-2px)}

/* embers */
.embers{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.embers .e{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:var(--ember-2);box-shadow:0 0 8px var(--ember-2);opacity:0;animation:rise linear infinite}
@keyframes rise{0%{transform:translateY(0) translateX(0);opacity:0}10%{opacity:.9}90%{opacity:.5}100%{transform:translateY(-105vh) translateX(40px);opacity:0}}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;display:flex;justify-content:space-between;align-items:center;padding:1.4rem clamp(1.2rem,4vw,3rem);transition:.4s}
.nav.scrolled{background:rgba(246,238,225,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding-top:1rem;padding-bottom:1rem}
.logo{font-size:1.5rem;letter-spacing:.01em}
.logo span{color:var(--ember);font-style:italic}
.nav-links{display:flex;align-items:center;gap:2.2rem;font-size:.95rem;letter-spacing:.02em}
.nav-links a{transition:color .2s}
.nav-links a:hover{color:var(--ember)}
.btn-line{border:1px solid var(--char);padding:.5rem 1.3rem;border-radius:999px;transition:.25s}
.btn-line:hover{background:var(--char);color:var(--cream)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;background:var(--char);color:var(--cream);padding:1rem 2rem;border-radius:999px;font-family:"Jost",sans-serif;font-weight:400;letter-spacing:.04em;font-size:.95rem;cursor:pointer;border:0;transition:.3s}
.btn:hover{background:var(--ember);transform:translateY(-2px)}
.btn-block{width:100%}
.btn-text{font-family:"Jost",sans-serif;letter-spacing:.04em;border-bottom:1px solid var(--ember);padding-bottom:2px;transition:.25s}
.btn-text:hover{color:var(--ember)}

/* hero */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:8rem 1.6rem 4rem;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:
  radial-gradient(60% 50% at 50% 78%,rgba(224,116,63,.55),transparent 70%),
  radial-gradient(50% 40% at 70% 20%,rgba(169,128,47,.3),transparent 70%),
  linear-gradient(180deg,var(--cream),var(--cream-2));
  will-change:transform}
.hero-inner{position:relative;z-index:3;max-width:880px}
.hero h1{font-size:clamp(3.2rem,10vw,7rem);line-height:.98;letter-spacing:-.01em;margin:.6rem 0 1.5rem}
.hero h1 em{color:var(--ember)}
.hero-sub{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--char-2);max-width:46ch;margin:0 auto 2.4rem}
.hero-actions{display:flex;gap:1.8rem;align-items:center;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:3;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--char-2)}
.hero-scroll::after{content:"";display:block;width:1px;height:30px;margin:.7rem auto 0;background:var(--ember);animation:drop 2s infinite}
@keyframes drop{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}

/* strip */
.strip{position:relative;z-index:2;background:var(--char);color:var(--cream);padding:1.1rem 0;overflow:hidden}
.strip-track{display:flex;width:max-content;animation:marq 72s linear infinite;font-family:"Fraunces",serif;font-style:italic;font-size:1.4rem;align-items:center;white-space:nowrap}
.strip-track .mq-group{display:flex;align-items:center;gap:2rem;padding-right:2rem;flex:none}
.strip-track i{color:var(--ember-2);font-style:normal;font-size:.8rem}
@keyframes marq{to{transform:translateX(-50%)}}

/* story */
.story{position:relative;z-index:2}
.story-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:4rem;align-items:center}
.story-art{display:flex;justify-content:center;color:var(--ember)}
.flame-art{width:min(300px,70%);filter:drop-shadow(0 10px 30px rgba(194,86,47,.4))}
.story-text h2{font-size:clamp(2rem,4.5vw,3.2rem);line-height:1.05;margin-bottom:1.3rem;letter-spacing:-.01em}
.story-text p{color:var(--char-2);margin-bottom:1.1rem;max-width:50ch;font-size:1.05rem}

/* menu */
.menu{position:relative;z-index:2}
.menu-head{text-align:center;margin-bottom:3.6rem}
.menu-head h2{font-size:clamp(2.2rem,5vw,3.4rem);letter-spacing:-.01em}
.menu-note{color:var(--char-2);font-style:italic;font-family:"Fraunces",serif;margin-top:.6rem}
.menu-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem}
.course{font-size:1.5rem;font-style:italic;color:var(--ember);margin-bottom:1.4rem;padding-bottom:.7rem;border-bottom:1px solid var(--line)}
.dish{margin-bottom:1.5rem}
.dish-top{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.dish-top span{font-family:"Fraunces",serif;font-size:1.15rem}
.dish-top b{font-family:"Fraunces",serif;font-weight:400;color:var(--char-2)}
.dish p{font-size:.86rem;color:var(--char-2);letter-spacing:.03em;margin-top:.2rem}
.dish .v{color:var(--gold);font-style:italic;font-family:"Fraunces",serif}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;position:relative;z-index:2}
.g-tile{aspect-ratio:3/4;display:flex;align-items:flex-end;padding:1.4rem;position:relative;overflow:hidden}
.g-tile span{font-family:"Fraunces",serif;font-style:italic;color:var(--cream);font-size:1.3rem;position:relative;z-index:2}
.g-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent,rgba(0,0,0,.5))}
.g-tile.t1{background:radial-gradient(120% 100% at 30% 20%,#e0743f,#5a2414)}
.g-tile.t2{background:radial-gradient(120% 100% at 70% 30%,#a9802f,#3a2c14)}
.g-tile.t3{background:radial-gradient(120% 100% at 40% 60%,#7a3a22,#1f120c)}
.g-tile.t4{background:radial-gradient(120% 100% at 60% 40%,#c2562f,#46180c)}
.g-tile{transition:transform .5s}
.g-tile:hover{transform:scale(.98)}

/* reserve */
.reserve{position:relative;z-index:2}
.reserve-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;background:var(--cream-2);border-radius:24px;padding:clamp(2rem,5vw,4rem)}
.reserve-text h2{font-size:clamp(2rem,4.5vw,3rem);line-height:1.05;margin-bottom:1.2rem}
.reserve-text p{color:var(--char-2);margin-bottom:1rem;max-width:42ch}
.reserve-contact{font-family:"Fraunces",serif;font-style:italic;color:var(--char)!important;font-size:1.1rem}
.reserve-form{display:grid;gap:1rem}
.rf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.reserve-form label{display:flex;flex-direction:column;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--char-2);gap:.4rem}
.reserve-form input,.reserve-form select{font-family:"Jost",sans-serif;font-size:1rem;padding:.8rem .9rem;border:1px solid var(--line);border-radius:10px;background:var(--cream);color:var(--char)}
.reserve-form input:focus,.reserve-form select:focus{outline:none;border-color:var(--ember)}
.rf-note{font-size:.78rem;text-align:center;color:var(--char-2);letter-spacing:.02em;text-transform:none}
.rf-note.sent{color:var(--ember)}

/* visit */
.visit{background:var(--char);color:var(--cream);position:relative;z-index:2}
.visit-grid{max-width:var(--maxw);margin:0 auto;padding:4rem 1.6rem;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center}
.visit h4{font-family:"Fraunces",serif;font-style:italic;color:var(--ember-2);font-size:1.3rem;margin-bottom:.6rem;font-weight:400}
.visit p{color:#d9cab6;font-size:.98rem}

/* footer */
.footer{position:relative;z-index:2;text-align:center;padding:3rem 1.6rem;display:flex;flex-direction:column;align-items:center;gap:.7rem}
.footer .logo{font-size:1.8rem}
.footer p{font-size:.82rem;color:var(--char-2)}
.builtby-foot{font-size:.8rem;color:var(--ember);border-bottom:1px solid transparent;transition:.2s}
.builtby-foot:hover{border-color:var(--ember)}

/* fade */
.fade{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.fade.in{opacity:1;transform:none}

@media(max-width:880px){
  .story-grid,.reserve-grid,.menu-cols{grid-template-columns:1fr;gap:2.5rem}
  .gallery{grid-template-columns:1fr 1fr}
  .visit-grid{grid-template-columns:1fr}
  .nav-links{gap:1.3rem;font-size:.85rem}
  .nav-links a:not(.btn-line){display:none}
  .section{padding:5rem 1.4rem}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important}.fade{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}.hero-bg{transform:none!important}}
