*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--gold:#C9A96E;--gold-light:#E8D5A8;--gold-dark:#A8853A;--cream:#FAF7F2;--cream-dark:#F0EBE1;--charcoal:#1A1A1A;--charcoal-light:#2A2A2A;--text:#333;--text-light:#666;--text-lighter:#999;--white:#fff;--font-display:'Playfair Display',Georgia,serif;--font-body:'Inter',system-ui,sans-serif;--font-accent:'Cormorant Garamond',Georgia,serif}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--text);background:var(--cream);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
address{font-style:normal}

.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.25rem 0;transition:all .4s ease}
.nav.scrolled{background:rgba(250,247,242,.97);backdrop-filter:blur(20px);padding:.75rem 0;box-shadow:0 1px 30px rgba(0,0,0,.06)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:.75rem}
.nav-logo-img{height:50px;width:auto;transition:filter .4s}
.nav.scrolled .nav-logo-img{filter:none}
.nav-logo-text{font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--white);letter-spacing:.02em;transition:color .4s}
.nav.scrolled .nav-logo-text{color:var(--charcoal)}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.875rem;font-weight:500;color:rgba(255,255,255,.7);transition:color .3s;letter-spacing:.03em;text-transform:uppercase}
.nav.scrolled .nav-links a{color:var(--text-light)}
.nav-links a:hover{color:var(--gold)}
.nav-cta{background:var(--gold)!important;color:var(--white)!important;padding:.6rem 1.5rem;border-radius:100px;transition:background .3s!important}
.nav-cta:hover{background:var(--gold-dark)!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem}
.nav-toggle span{width:24px;height:2px;background:var(--white);transition:all .3s}
.nav.scrolled .nav-toggle span{background:var(--charcoal)}

.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--charcoal)}
.hero-bg{position:absolute;inset:0;background:url('images/bg-hero.png') center/cover no-repeat}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.55) 0%,rgba(0,0,0,.4) 40%,rgba(0,0,0,.7) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;padding:2rem}
.hero-badge{display:inline-block;font-family:var(--font-body);font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(201,169,110,.3);padding:.5rem 1.5rem;border-radius:100px;margin-bottom:2rem}
.hero-title{font-family:var(--font-display);color:var(--white);margin-bottom:1rem}
.hero-title-line{display:block;font-size:clamp(3rem,8vw,7rem);font-weight:900;line-height:1;letter-spacing:-.02em}
.hero-title-accent{color:var(--gold);font-style:italic;font-weight:400;font-size:clamp(1.5rem,4vw,3.5rem);letter-spacing:.05em;margin-top:.25rem}
.hero-sub{font-family:var(--font-accent);font-size:clamp(1rem,2vw,1.35rem);color:rgba(255,255,255,.6);font-weight:300;letter-spacing:.05em;margin-bottom:1.5rem}
.hero-divider{margin:1.5rem auto}
.hero-tagline{font-size:.8rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:2.5rem}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(255,255,255,.3);font-size:.65rem;letter-spacing:.3em;text-transform:uppercase}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.5)}}

.btn{display:inline-block;padding:.85rem 2.25rem;border-radius:100px;font-family:var(--font-body);font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;transition:all .4s ease;cursor:pointer;border:none}
.btn-gold{background:var(--gold);color:var(--white)}
.btn-gold:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 10px 30px rgba(201,169,110,.3)}
.btn-outline{border:1px solid rgba(255,255,255,.25);color:var(--white);background:transparent}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-full{width:100%;text-align:center}

.section-label{display:inline-block;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:1rem}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.25rem);font-weight:700;color:var(--charcoal);line-height:1.15;margin-bottom:1.5rem;letter-spacing:-.01em}
.section-header{text-align:center;margin-bottom:3.5rem}

.about{padding:8rem 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-img-wrapper{position:relative}
img.about-img{width:100%;aspect-ratio:4/3;border-radius:12px;overflow:hidden;object-fit:cover;display:block}
.about-img-accent{position:absolute;top:-1rem;left:-1rem;right:1rem;bottom:1rem;border:1px solid var(--gold);border-radius:12px;z-index:-1;opacity:.4}
.about-divider{width:60px;height:2px;background:var(--gold);margin-bottom:1.5rem}
.about-text-col p{color:var(--text-light);margin-bottom:1rem;font-size:.95rem;line-height:1.8}
.about-features{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:2rem}
.about-feature{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;background:var(--cream-dark)}
.about-feature-icon{font-size:1.5rem}
.about-feature span{font-size:.85rem;font-weight:500}

.marquee-section{padding:2rem 0;background:var(--charcoal);overflow:hidden}
.marquee{overflow:hidden;white-space:nowrap}
.marquee-inner{display:inline-flex;animation:marquee 30s linear infinite;gap:2rem;align-items:center}
.marquee-inner span{font-family:var(--font-display);font-size:1.1rem;color:rgba(255,255,255,.5);letter-spacing:.05em}
.marquee-dot{color:var(--gold)!important;font-size:.6rem}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.events{padding:8rem 0;background:var(--cream-dark)}
.events-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.event-card{display:flex;gap:1.5rem;padding:2rem;background:var(--white);border-radius:12px;transition:all .4s ease;border:1px solid transparent}
.event-card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.06)}
.event-date{min-width:70px;text-align:center;padding:1rem .5rem;background:var(--charcoal);border-radius:8px;display:flex;flex-direction:column;justify-content:center;align-items:center}
.event-day{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--gold);line-height:1}
.event-month{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-top:.25rem}
.event-info{flex:1}
.event-tag{display:inline-block;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:.5rem;padding:.2rem .75rem;background:rgba(201,169,110,.1);border-radius:100px}
.event-info h3{font-family:var(--font-display);font-size:1.25rem;margin-bottom:.5rem}
.event-info p{font-size:.85rem;color:var(--text-light);line-height:1.6}
.event-meta{margin-top:.75rem;font-size:.8rem;font-weight:600;color:var(--gold)}

.menu{padding:8rem 0}
.menu-tabs{display:flex;justify-content:center;gap:.5rem;margin-bottom:3rem}
.menu-tab{padding:.7rem 2rem;border-radius:100px;border:1px solid var(--cream-dark);background:transparent;font-family:var(--font-body);font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .3s;color:var(--text-light)}
.menu-tab.active{background:var(--gold);color:var(--white);border-color:var(--gold)}
.menu-tab:hover:not(.active){border-color:var(--gold);color:var(--gold)}
.menu-content{display:none}
.menu-content.active{display:block}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.menu-item{padding:1.75rem;border-radius:12px;background:var(--cream-dark);transition:all .3s}
.menu-item:hover{background:var(--white);box-shadow:0 10px 30px rgba(0,0,0,.05)}
.menu-item-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}
.menu-item-header h3{font-family:var(--font-display);font-size:1.1rem}
.menu-price{font-family:var(--font-display);font-size:1.1rem;color:var(--gold);font-weight:700}
.menu-item p{font-size:.85rem;color:var(--text-light);line-height:1.6}
.menu-desc{text-align:center;max-width:600px;margin:0 auto 2.5rem;color:var(--text-light);font-size:.95rem;line-height:1.8}
.menu-cta{text-align:center;margin-bottom:3rem}
.menu-highlights{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.menu-highlight-card{border-radius:12px;overflow:hidden;background:var(--cream-dark);transition:all .4s}
.menu-highlight-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.08)}
.menu-highlight-card img{width:100%;height:220px;object-fit:cover}
.menu-highlight-card h3{font-family:var(--font-display);font-size:1.15rem;padding:1.25rem 1.5rem .25rem}
.menu-highlight-card p{font-size:.85rem;color:var(--text-light);padding:0 1.5rem 1.5rem;line-height:1.6}
.footer-note{margin-top:.5rem;font-size:.75rem;color:var(--gold);font-style:italic}
@media(max-width:600px){.menu-highlights{grid-template-columns:1fr}}

.functions{padding:8rem 0;background:var(--charcoal);color:var(--white)}
.functions .section-title{color:var(--white)}
.functions p{color:rgba(255,255,255,.6)}
.functions-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.functions-list{margin:2rem 0;display:flex;flex-direction:column;gap:.75rem}
.functions-list li{padding-left:1.5rem;position:relative;font-size:.9rem;color:rgba(255,255,255,.7)}
.functions-list li::before{content:'✦';position:absolute;left:0;color:var(--gold);font-size:.6rem;top:.35rem}
img.functions-img{width:100%;border-radius:12px;object-fit:contain;display:block}

.gallery{padding:8rem 0;background:var(--cream-dark)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:250px;gap:1rem}
.gallery-item{border-radius:12px;overflow:hidden;background:var(--charcoal);transition:all .4s}
.gallery-item img{width:100%;height:100%;object-fit:cover}
.gallery-item:hover{transform:scale(.98);opacity:.9}
.gallery-item-lg{grid-column:span 2}

.booking{padding:8rem 0}
.booking-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:start}
.booking-contact{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.5rem}
.booking-contact-label{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600;display:block;margin-bottom:.25rem}
.booking-contact-item a{color:var(--text);transition:color .3s}
.booking-contact-item a:hover{color:var(--gold)}
.booking-contact-item{font-size:.9rem;color:var(--text-light)}
.booking-form{background:var(--cream-dark);padding:2.5rem;border-radius:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{display:flex;flex-direction:column}
.form-group-full{margin-bottom:1.5rem}
.form-group label{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;font-weight:600;color:var(--text-light);margin-bottom:.4rem}
.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;border:1px solid #e0ddd6;border-radius:8px;font-family:var(--font-body);font-size:.9rem;background:var(--white);color:var(--text);transition:border-color .3s;outline:none;width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group textarea{resize:vertical}
.booking-success{display:none;text-align:center;padding:3rem}
.booking-success.show{display:block}
.booking-success-icon{width:60px;height:60px;border-radius:50%;background:var(--gold);color:var(--white);font-size:1.5rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}
.booking-success h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:.5rem}
.booking-success p{color:var(--text-light);font-size:.9rem}

.map-section{padding:0 0 0}
.map-wrapper{border-radius:16px;overflow:hidden;margin:0 2rem}
.map-wrapper iframe{display:block;border-radius:16px}

.footer{padding:5rem 0 2rem;background:var(--charcoal);color:rgba(255,255,255,.6)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.footer-logo-img{height:70px;width:auto;margin-bottom:.5rem}
.footer-brand p{font-size:.85rem;line-height:1.7}
.footer-col h4{font-family:var(--font-display);font-size:1rem;color:var(--white);margin-bottom:1rem}
.footer-col li{font-size:.85rem;margin-bottom:.5rem}
.footer-col a:hover{color:var(--gold)}
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:2rem;text-align:center;font-size:.75rem;color:rgba(255,255,255,.3)}

@media(max-width:968px){
.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;padding:2rem;gap:1.5rem;box-shadow:0 10px 30px rgba(0,0,0,.1)}
.nav-links.open{display:flex}
.nav-toggle{display:flex}
.about-grid,.functions-grid,.booking-grid{grid-template-columns:1fr;gap:2.5rem}
.events-grid{grid-template-columns:1fr}
.menu-grid{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
.about-img-col{order:-1}
}
@media(max-width:600px){
.container{padding:0 1.25rem}
.about,.events,.menu,.functions,.gallery,.booking{padding:5rem 0}
.hero-actions{flex-direction:column;align-items:center}
.form-row{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:1fr;grid-auto-rows:180px}
.gallery-item-lg{grid-column:span 1}
.footer-grid{grid-template-columns:1fr}
}
