*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:#1f1410;background:#fdfaf5;line-height:1.6}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%;display:block}

/* Navbar */
.navbar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px 40px;background:rgba(253,250,245,.92);backdrop-filter:blur(16px);border-bottom:1px solid rgba(31,20,16,.08)}
.logo{display:flex;align-items:center;gap:12px;color:#1f1410}
.logo-mark{width:38px;height:38px;border-radius:50%;background:#7f1d1d;color:#fdfaf5;display:grid;place-items:center;font-family:'Lora',serif;font-style:italic;font-weight:700;font-size:18px}
.logo span{font-family:'Lora',serif;font-size:20px;font-weight:600}
.logo em{font-style:italic;color:#7f1d1d;font-weight:500}
.navbar nav{display:flex;align-items:center;gap:32px}
.navbar nav a{font-size:14px;font-weight:500;color:#5a4030;transition:color .2s}
.navbar nav a:hover{color:#7f1d1d}
.btn-cta{padding:10px 22px;background:#7f1d1d;color:#fdfaf5 !important;font-weight:600 !important;border-radius:4px;transition:all .2s}
.btn-cta:hover{background:#991b1b}
.back{font-size:13px;color:#a18a78}
.back:hover{color:#7f1d1d}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:120px 40px 140px;color:#fdfaf5;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(31,20,16,.75) 0%,rgba(31,20,16,.5) 50%,rgba(31,20,16,.7) 100%);z-index:1}
.hero-content{position:relative;z-index:2;max-width:780px}
.ornament{display:block;font-family:'Lora',serif;font-style:italic;font-size:18px;color:#fbbf24;margin-bottom:24px;letter-spacing:.05em}
.hero h1{font-family:'Lora',serif;font-size:clamp(3rem,7vw,5.6rem);font-weight:600;line-height:1;letter-spacing:-.02em;margin-bottom:28px}
.hero h1 em{font-style:italic;color:#fbbf24;font-weight:500}
.hero-content > p{font-size:1.1rem;max-width:520px;margin-bottom:36px;opacity:.95;line-height:1.6}
.hero-cta{display:flex;align-items:center;gap:32px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:16px 32px;background:#fbbf24;color:#1f1410;font-family:'Lora',serif;font-weight:600;font-size:15px;letter-spacing:.02em;border:none;cursor:pointer;border-radius:4px;transition:all .25s}
.btn-primary:hover{background:#fcd34d;transform:translateY(-2px)}
.btn-link{font-size:14px;font-weight:500;border-bottom:1px solid #fbbf24;padding-bottom:2px;color:#fbbf24}
.btn-block{width:100%;justify-content:center}
.hero-bottom{position:absolute;bottom:30px;left:40px;right:40px;z-index:2;display:flex;align-items:center;gap:32px;flex-wrap:wrap;padding:24px 32px;background:rgba(31,20,16,.7);backdrop-filter:blur(12px);border-radius:8px;border:1px solid rgba(251,191,36,.2)}
.hero-bottom > div{display:flex;flex-direction:column}
.hero-bottom strong{font-family:'Lora',serif;font-weight:600;color:#fbbf24;font-size:1.1rem}
.hero-bottom span{font-size:12px;color:#fdfaf5;opacity:.8;margin-top:2px}
.sep{width:1px;height:36px;background:rgba(251,191,36,.2)}

/* Sections */
.section-head{text-align:center;margin-bottom:60px}
.kicker{display:inline-block;font-family:'Lora',serif;font-style:italic;font-size:18px;color:#7f1d1d;margin-bottom:14px}
.section-head h2{font-family:'Lora',serif;font-size:clamp(2.4rem,5vw,4rem);font-weight:600;color:#1f1410;line-height:1.05;letter-spacing:-.02em}
.section-head > p{color:#5a4030;font-size:1.05rem;margin-top:14px}

/* Story */
.story{padding:120px 40px;max-width:1320px;margin:0 auto}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-img img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:4px}
.story-text h2{font-family:'Lora',serif;font-size:clamp(2rem,4vw,3.4rem);font-weight:600;color:#1f1410;line-height:1.05;letter-spacing:-.02em;margin:14px 0 24px}
.story-text > p{color:#5a4030;margin-bottom:18px;font-size:1.05rem}
.story-sign{font-family:'Lora',serif;font-style:italic;color:#7f1d1d;margin-top:24px;font-size:1.1rem}

/* Menu */
.menu{padding:120px 40px;background:#1f1410;color:#fdfaf5;border-top:1px solid rgba(0,0,0,.05)}
.menu > .section-head{max-width:720px;margin:0 auto 60px}
.menu > .section-head h2{color:#fdfaf5}
.menu > .section-head .kicker{color:#fbbf24}
.menu > .section-head > p{color:#d4a574}
.menu-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:60px}
.menu-col h3{font-family:'Lora',serif;font-size:1.6rem;font-weight:600;color:#fbbf24;padding-bottom:16px;border-bottom:1px solid rgba(251,191,36,.3);margin-bottom:24px}
.menu-item{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.menu-item strong{display:block;font-family:'Lora',serif;font-size:1.05rem;color:#fdfaf5;font-weight:500;margin-bottom:4px}
.menu-item span{font-size:13px;color:#a18a78}
.menu-item .price{font-family:'Lora',serif;font-size:1.2rem;font-weight:600;color:#fbbf24;flex-shrink:0;white-space:nowrap}
.menu-set{max-width:1180px;margin:60px auto 0;padding:32px 40px;background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.2);border-radius:8px;display:flex;justify-content:space-between;align-items:center;gap:32px}
.menu-set .kicker{color:#fbbf24;margin-bottom:6px}
.menu-set h3{font-family:'Lora',serif;font-size:1.6rem;color:#fdfaf5;margin-bottom:6px}
.menu-set p{color:#d4a574;font-size:.95rem}
.set-price strong{font-family:'Lora',serif;font-size:3rem;color:#fbbf24;font-weight:600}

/* Gallery */
.gallery{padding:120px 40px;max-width:1320px;margin:0 auto}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gal-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px;transition:transform .35s}
.gal-grid img:hover{transform:scale(.98)}

/* Reviews */
.reviews{padding:120px 40px;max-width:1320px;margin:0 auto;background:#fdfaf5}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.reviews blockquote{padding:32px;background:#fff;border-radius:8px;border:1px solid #e5d8c4;text-align:center}
.stars{color:#fbbf24;letter-spacing:3px;font-size:18px;margin-bottom:14px}
.reviews p{font-family:'Lora',serif;font-size:1.15rem;font-style:italic;color:#1f1410;margin-bottom:18px;line-height:1.5}
.reviews footer{font-size:13px;color:#7f1d1d;letter-spacing:.02em;background:none;padding:0;color:#7f1d1d}

/* Reserve */
.reserve{padding:60px 40px 120px}
.reserve-card{max-width:1180px;margin:0 auto;background:#7f1d1d;color:#fdfaf5;border-radius:12px;padding:60px;display:grid;grid-template-columns:1fr 1fr;gap:80px}
.reserve-card .kicker{color:#fbbf24}
.reserve-card h2{font-family:'Lora',serif;font-size:clamp(2rem,3.5vw,3rem);font-weight:600;color:#fdfaf5;margin:14px 0 18px;line-height:1.05}
.reserve-card > div > p{color:#fde2c5;margin-bottom:32px;font-size:1.05rem}
.reserve-info{display:flex;flex-direction:column;gap:16px}
.reserve-info div{display:flex;flex-direction:column;padding:14px 0;border-top:1px solid rgba(251,191,36,.3)}
.reserve-info strong{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#fbbf24;margin-bottom:4px}
.reserve-info span{color:#fdfaf5;font-size:1rem}
.reserve form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.reserve input,.reserve select,.reserve textarea{
  width:100%;padding:14px 16px;border-radius:6px;
  border:1px solid rgba(251,191,36,.3);
  background:rgba(0,0,0,.2);color:#fdfaf5;
  font-family:inherit;font-size:14px;
}
.reserve input::placeholder,.reserve textarea::placeholder{color:rgba(253,250,245,.5)}
.reserve input:focus,.reserve select:focus,.reserve textarea:focus{outline:none;border-color:#fbbf24;background:rgba(0,0,0,.3)}
.reserve select option{background:#7f1d1d;color:#fdfaf5}
.reserve textarea{resize:vertical}
.form-success{padding:14px;background:rgba(251,191,36,.2);color:#fbbf24;border-radius:6px;font-weight:500;font-size:14px;text-align:center;display:none}
.form-success.visible{display:block}

/* Footer */
footer{background:#1f1410;color:#a18a78;padding:60px 40px 30px}
.footer-inner{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:40px}
.footer-logo{margin-bottom:14px;color:#fdfaf5}
.footer-logo em{color:#fbbf24}
footer h4{font-family:'Lora',serif;font-size:1.15rem;color:#fdfaf5;margin-bottom:16px;font-weight:600}
footer a{display:block;padding:5px 0;font-size:14px;color:#a18a78;transition:color .2s}
footer a:hover{color:#fbbf24}
footer p{font-size:14px;color:#a18a78}
.footer-bottom{max-width:1320px;margin:0 auto;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:13px;color:#7a6447;text-align:center}
.footer-bottom a{display:inline;color:#fbbf24;text-decoration:underline}

@media(max-width:960px){
  .navbar{padding:14px 20px}
  .navbar nav{display:none}
  .hero{padding:100px 20px 160px}
  .hero-bottom{position:static;margin-top:48px;flex-direction:column;align-items:flex-start;gap:18px;left:0;right:0}
  .sep{display:none}
  .story{padding:80px 20px}
  .story-grid{grid-template-columns:1fr;gap:48px}
  .menu,.gallery,.reviews{padding:80px 20px}
  .menu-grid{grid-template-columns:1fr;gap:48px}
  .menu-set{flex-direction:column;text-align:center;padding:24px;gap:18px}
  .gal-grid{grid-template-columns:1fr 1fr;gap:8px}
  .reviews-grid{grid-template-columns:1fr;gap:18px}
  .reserve{padding:40px 20px 80px}
  .reserve-card{grid-template-columns:1fr;padding:36px;gap:48px}
  .footer-inner{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:520px){
  .form-row{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
}
