@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Inter:wght@300;400;500;600&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#fdf6ec;--dark:#1a0a0a;--brand:#5a0e0e;--gold:#c9923d;--muted:#7a5c3e;--card:#fff9f0;--border:rgba(90,14,14,0.12)}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--dark);line-height:1.6}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;object-fit:cover}

/* NAV */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 5vw;background:rgba(20,5,5,0.96);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(201,146,61,0.12)}
.nav-brand{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--gold);letter-spacing:0.12em}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{color:rgba(253,246,236,0.65);font-size:0.88rem;letter-spacing:0.05em;transition:color 0.2s}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-reserve{background:var(--brand) !important;color:#fdf6ec !important;padding:0.48rem 1.1rem;border-radius:6px}
.nav-reserve:hover{background:#7a1515 !important}
.nav-back{font-size:0.78rem;color:rgba(253,246,236,0.35) !important;margin-left:1rem}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:flex-end;background:linear-gradient(to top,rgba(10,3,3,0.88) 0%,rgba(10,3,3,0.25) 55%,transparent 100%),url('https://images.unsplash.com/photo-1414235077428-338989a2e8c0?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;padding:5rem 5vw 6rem;color:#fff}
.hero-inner{max-width:680px}
.eyebrow{font-size:0.73rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:1rem}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(3rem,6vw,5.5rem);line-height:1.08;margin-bottom:1.2rem}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-desc{font-size:1.1rem;color:rgba(255,255,255,0.75);max-width:500px;margin-bottom:2.2rem;line-height:1.75}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}

/* BUTTONS */
.btn{display:inline-block;padding:0.82rem 1.9rem;border-radius:6px;font-weight:500;font-size:0.9rem;transition:all 0.22s;cursor:pointer;border:none;font-family:'Inter',sans-serif}
.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:#7a1515;transform:translateY(-1px)}
.btn-gold{background:var(--gold);color:#fff}.btn-gold:hover{background:#b07d2a;transform:translateY(-1px)}
.btn-outline{border:1.5px solid rgba(255,255,255,0.45);color:#fff;background:transparent}.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-dark{background:var(--dark);color:#fff}.btn-dark:hover{background:#3a1308}

/* SECTIONS */
.section{padding:6rem 5vw}
.section-alt{background:#fff9f0}
.section-dark{background:var(--dark);color:#fff}
.section-header{text-align:center;margin-bottom:3.5rem}
.section-header .section-sub{margin:0 auto;max-width:520px;color:var(--muted);line-height:1.75;font-size:1rem}
h2.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.9rem,4vw,3rem);line-height:1.15;margin-bottom:0.8rem}

/* GRIDS */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}

/* CARDS */
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:transform 0.3s ease,box-shadow 0.3s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(90,14,14,0.12)}
.card-img{height:220px;background-size:cover;background-position:center}
.card-body{padding:1.5rem}
.card-body h3{font-family:'Playfair Display',serif;font-size:1.15rem;margin-bottom:0.5rem}
.card-body p{color:var(--muted);font-size:0.9rem;line-height:1.6}
.card-price{color:var(--gold);font-weight:600;margin-top:0.7rem;font-size:0.95rem}

/* STATS STRIP */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);background:var(--brand);padding:4rem 5vw;text-align:center;gap:1rem}
.stat-num{font-family:'Playfair Display',serif;font-size:2.8rem;color:var(--gold);display:block}
.stat-label{font-size:0.82rem;color:rgba(253,246,236,0.65);letter-spacing:0.08em}

/* SPLIT LAYOUT */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:center}
.split-img{border-radius:14px;overflow:hidden;height:480px;background-size:cover;background-position:center}
.split-text .eyebrow{margin-bottom:0.8rem}
.split-text h2{margin-bottom:1rem}
.split-text p{color:var(--muted);line-height:1.75;margin-bottom:1.2rem;font-size:1rem}

/* DINING GALLERY */
.dining-gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:280px 280px;gap:0.8rem}
.dining-gallery>div{background-size:cover;background-position:center;border-radius:12px;overflow:hidden}
.dining-gallery>div:first-child{grid-row:span 2}

/* TESTIMONIALS */
.testimonial-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:2rem}
.testimonial-stars{color:var(--gold);font-size:1rem;margin-bottom:1rem;letter-spacing:0.12em}
.testimonial-card blockquote{font-family:'Playfair Display',serif;font-style:italic;font-size:1rem;line-height:1.65;margin-bottom:1.2rem;color:var(--dark)}
.testimonial-card cite{font-size:0.83rem;color:var(--muted);font-style:normal}

/* MENU */
.menu-cat{margin-bottom:4rem}
.menu-cat-title{font-family:'Playfair Display',serif;font-size:1.9rem;color:var(--brand);border-bottom:2px solid var(--gold);padding-bottom:0.75rem;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:baseline}
.menu-cat-title span{font-family:'Inter',sans-serif;font-size:0.73rem;color:var(--muted);letter-spacing:0.12em;text-transform:uppercase}
.menu-item{display:flex;justify-content:space-between;align-items:flex-start;padding:1.1rem 0;border-bottom:1px solid rgba(90,14,14,0.07);gap:2rem}
.menu-item:last-child{border-bottom:none}
.menu-item h4{font-size:1rem;margin-bottom:0.3rem}
.menu-item p{font-size:0.85rem;color:var(--muted);line-height:1.5}
.menu-price{font-weight:600;color:var(--brand);white-space:nowrap;font-size:0.95rem}
.menu-tag{display:inline-block;font-size:0.66rem;text-transform:uppercase;letter-spacing:0.1em;background:rgba(201,146,61,0.12);color:var(--gold);border-radius:4px;padding:0.15rem 0.45rem;margin-left:0.4rem}

/* FORM */
.form-wrap{max-width:680px;margin:0 auto}
.form-field{margin-bottom:1.2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
label{font-size:0.83rem;color:var(--muted);display:block;margin-bottom:0.4rem;font-weight:500}
input,select,textarea{width:100%;padding:0.85rem 1rem;border:1px solid rgba(90,14,14,0.18);border-radius:8px;background:#fff;color:var(--dark);font-family:'Inter',sans-serif;font-size:0.95rem;outline:none;transition:border-color 0.2s;-webkit-appearance:none}
input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(90,14,14,0.07)}
textarea{min-height:130px;resize:vertical}

/* STORY PAGE */
.story-lead{font-family:'Playfair Display',serif;font-size:1.35rem;font-style:italic;line-height:1.65;color:var(--brand);max-width:700px;margin:0 auto 3rem;border-left:3px solid var(--gold);padding-left:1.5rem}
.team-card{text-align:center}
.team-photo{width:120px;height:120px;border-radius:50%;background-size:cover;background-position:center;margin:0 auto 1rem;border:3px solid var(--gold)}
.team-card h4{font-family:'Playfair Display',serif;font-size:1.1rem;margin-bottom:0.25rem}
.team-card span{font-size:0.8rem;color:var(--muted);letter-spacing:0.06em;text-transform:uppercase}

/* HOURS */
.hours-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0.8rem;max-width:560px;margin:0 auto}
.hour-item{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1rem 1.4rem;display:flex;justify-content:space-between;align-items:center}
.hour-item .day{font-weight:500;font-size:0.9rem}
.hour-item .time{color:var(--muted);font-size:0.85rem}

/* CTA BAND */
.cta-band{position:relative;padding:7rem 5vw;text-align:center;color:#fff;background:url('https://images.unsplash.com/photo-1424847651672-bf20a4b0982b?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat}
.cta-band::before{content:'';position:absolute;inset:0;background:rgba(22,5,5,0.78)}
.cta-band>*{position:relative}
.cta-band h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1rem}
.cta-band p{color:rgba(255,255,255,0.75);max-width:440px;margin:0 auto 2.2rem}

/* PAGE HERO */
.page-hero{padding:10rem 5vw 5rem;text-align:center}
.page-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,5vw,4rem);margin-bottom:1rem}
.page-hero p{color:var(--muted);max-width:520px;margin:0 auto;font-size:1.05rem;line-height:1.75}

/* FOOTER */
.site-footer{background:#0f0505;color:rgba(253,246,236,0.5);padding:4rem 5vw 2rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand-name{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--gold);margin-bottom:0.8rem}
.footer-tagline{font-size:0.88rem;line-height:1.7;max-width:260px}
.footer-col h5{color:rgba(253,246,236,0.75);font-size:0.75rem;letter-spacing:0.14em;text-transform:uppercase;margin-bottom:1.1rem}
.footer-col a{display:block;margin-bottom:0.55rem;font-size:0.88rem;transition:color 0.2s}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(253,246,236,0.08);padding-top:1.5rem;display:flex;justify-content:space-between;font-size:0.78rem;flex-wrap:wrap;gap:0.5rem}
.footer-credit a{color:var(--gold)}

/* INFO BOX */
.info-box{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:2.5rem;text-align:center}
.info-box h3{font-family:'Playfair Display',serif;font-size:1.2rem;margin-bottom:0.5rem}
.info-box p{color:var(--muted);font-size:0.9rem;line-height:1.6}

/* RESPONSIVE */
@media(max-width:940px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .stats-strip{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:2.5rem}
  .footer-grid{grid-template-columns:1fr 1fr}
  .dining-gallery{grid-template-columns:1fr 1fr;grid-template-rows:240px 240px}
  .dining-gallery>div:first-child{grid-row:span 1}
  .hours-grid{grid-template-columns:1fr}
}
@media(max-width:620px){
  .nav-links{gap:1rem}
  .nav-links a{font-size:0.82rem}
  .grid-3,.grid-2,.grid-4,.stats-strip,.footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .section{padding:4rem 5vw}
  .hero{padding:5rem 5vw 4.5rem}
  .dining-gallery{grid-template-columns:1fr}
  .page-hero{padding:8rem 5vw 3.5rem}
}
