/* ===== RESET & BASE ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0a1a2e;--teal:#2a9d8f;--warm:#f5f0eb;--gold:#d4a574;
  --teal-dark:#238578;--navy-light:#122640;
}
html{scroll-behavior:smooth;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--teal) var(--navy)}
body{background:var(--navy);color:var(--warm);font-family:'DM Sans',sans-serif;font-weight:300;line-height:1.7;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:600;line-height:1.2}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--teal);color:var(--navy)}

/* ===== PARTICLES ===== */
.particles{position:fixed;inset:0;pointer-events:none;z-index:9999;overflow:hidden}
.particle{position:absolute;width:3px;height:3px;background:rgba(245,240,235,0.15);border-radius:50%;animation:floatUp linear infinite}
@keyframes floatUp{
  0%{transform:translateY(100vh) translateX(0) scale(1);opacity:0}
  10%{opacity:1}
  90%{opacity:1}
  100%{transform:translateY(-10vh) translateX(var(--drift)) scale(0.3);opacity:0}
}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:1.5rem 3rem;transition:all 0.5s ease}
.site-header.scrolled{background:rgba(10,26,46,0.95);backdrop-filter:blur(20px);padding:1rem 3rem;box-shadow:0 1px 30px rgba(0,0,0,0.3)}
.logo{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:600;letter-spacing:0.05em}
.main-nav{display:flex;gap:2.5rem}
.main-nav a{font-size:0.85rem;letter-spacing:0.12em;text-transform:uppercase;font-weight:400;opacity:0.7;transition:opacity 0.3s}
.main-nav a:hover{opacity:1;color:var(--teal)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:28px;height:20px;position:relative;z-index:1001}
.nav-toggle span{display:block;width:100%;height:1.5px;background:var(--warm);position:absolute;left:0;transition:all 0.3s}
.nav-toggle span:nth-child(1){top:0}.nav-toggle span:nth-child(2){top:50%;transform:translateY(-50%)}.nav-toggle span:nth-child(3){bottom:0}
.nav-toggle.open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}

.mobile-nav{position:fixed;inset:0;background:rgba(10,26,46,0.98);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity 0.4s}
.mobile-nav.open{opacity:1;pointer-events:all}
.mobile-nav a{font-family:'Playfair Display',serif;font-size:1.8rem;opacity:0.8;transition:opacity 0.3s}
.mobile-nav a:hover{opacity:1;color:var(--teal)}

/* ===== HERO ===== */
.hero{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
#waveCanvas{position:absolute;inset:0;width:100%;height:100%}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,26,46,0.3) 0%,rgba(10,26,46,0.5) 60%,rgba(10,26,46,0.8) 100%)}
.hero-content{position:relative;z-index:2}
.hero-pre{font-size:clamp(0.7rem,1vw,0.9rem);letter-spacing:0.3em;text-transform:uppercase;margin-bottom:1.5rem;color:var(--gold);font-weight:400}
.hero h1{font-size:clamp(3.5rem,9vw,8rem);letter-spacing:0.03em;margin-bottom:0.5rem}
.hero-tagline{font-size:clamp(1rem,2vw,1.4rem);letter-spacing:0.2em;text-transform:uppercase;font-weight:300;opacity:0.8;margin-bottom:2.5rem}
.hero-cta{display:inline-block;padding:1rem 2.5rem;border:1px solid rgba(245,240,235,0.4);font-size:0.85rem;letter-spacing:0.15em;text-transform:uppercase;transition:all 0.4s;font-weight:400}
.hero-cta:hover{background:var(--teal);border-color:var(--teal);color:var(--navy)}

.scroll-indicator{position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);z-index:2}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,transparent,var(--warm));animation:scrollPulse 2s ease infinite}
@keyframes scrollPulse{0%,100%{opacity:0.2;transform:scaleY(0.6)}50%{opacity:0.8;transform:scaleY(1)}}

/* ===== SECTIONS ===== */
.section{padding:10rem 6vw;position:relative}
.section-label{display:block;font-size:0.75rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--teal);margin-bottom:1.5rem;font-weight:500}

/* ===== ABOUT ===== */
.about-inner{display:grid;grid-template-columns:1.1fr 1fr;gap:6rem;align-items:center;max-width:1400px;margin:0 auto}
.about-images{position:relative}
.about-img-wrap{border-radius:4px;overflow:hidden;position:relative;z-index:1}
.about-img-wrap img{width:100%;height:auto;display:block}
.about-img-accent{position:absolute;bottom:-3rem;right:-3rem;width:55%;border-radius:4px;overflow:hidden;z-index:2;box-shadow:0 20px 60px rgba(0,0,0,0.4)}
.about-img-accent img{width:100%;height:auto}
.about-text h2{font-size:clamp(2rem,3.5vw,3.2rem);color:var(--warm);margin-bottom:2rem}
.about-text p{font-size:clamp(0.95rem,1.1vw,1.1rem);color:rgba(245,240,235,0.75);margin-bottom:1.2rem}
.about-quote{color:var(--gold);font-size:clamp(1.1rem,1.3vw,1.3rem);margin-top:1rem}

/* ===== MENU ===== */
.menu-section{background:var(--navy-light)}
.menu-inner{max-width:900px;margin:0 auto;text-align:center}
.menu-inner h2{font-size:clamp(2rem,3.5vw,3.2rem);margin-bottom:1.5rem}
.menu-intro{color:rgba(245,240,235,0.65);max-width:600px;margin:0 auto 3rem;font-size:1rem}

.menu-categories{display:flex;justify-content:center;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}
.menu-cat{background:none;border:1px solid rgba(245,240,235,0.15);color:var(--warm);font-family:'DM Sans',sans-serif;font-size:0.8rem;letter-spacing:0.12em;text-transform:uppercase;padding:0.7rem 1.8rem;border-radius:2px;cursor:pointer;transition:all 0.3s;font-weight:400}
.menu-cat.active,.menu-cat:hover{border-color:var(--teal);color:var(--teal)}

.menu-panel{display:none;text-align:left}
.menu-panel.active{display:block}
.menu-item{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 0;border-bottom:1px solid rgba(245,240,235,0.06)}
.menu-item:last-child{border-bottom:none}
.menu-item h3{font-size:1.15rem;font-weight:600;margin-bottom:0.3rem}
.menu-item p{font-size:0.9rem;color:rgba(245,240,235,0.5);font-weight:300}
.menu-price{font-size:1.1rem;color:var(--teal);font-weight:500;white-space:nowrap;padding-left:2rem}
.menu-price::before{content:"\00A3"}

/* Tidal animation */
.tidal-item{opacity:0;transform:translateX(-30px);transition:opacity 0.6s ease,transform 0.6s ease}
.tidal-item.tidal-visible{opacity:1;transform:translateX(0)}

/* ===== PARALLAX INTERLUDE ===== */
.parallax-interlude{position:relative;height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.parallax-bg{position:absolute;inset:-20%;width:140%;height:140%;background-size:cover;background-position:center;will-change:transform}
.parallax-overlay{position:absolute;inset:0;background:rgba(10,26,46,0.7)}
.parallax-content{position:relative;z-index:2;max-width:700px;padding:0 2rem}
.parallax-content h2{font-size:clamp(2rem,3.5vw,3rem);margin-top:1rem}

/* ===== SOURCING MAP ===== */
.sourcing-inner{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;max-width:1400px;margin:0 auto}
.map-container{position:relative}
.sourcing-map{width:100%;height:auto}
.source-point{cursor:pointer;transition:transform 0.3s}
.source-point:hover{transform:scale(1.3)}
.pulse-ring{animation:pulse 2.5s ease-out infinite}
@keyframes pulse{0%{r:6;opacity:0.8}100%{r:22;opacity:0}}
.map-tooltip{position:absolute;background:rgba(10,26,46,0.95);border:1px solid var(--teal);border-radius:4px;padding:1rem 1.2rem;pointer-events:none;opacity:0;transition:opacity 0.3s;max-width:250px;z-index:10}
.tooltip-name{display:block;color:var(--teal);font-size:0.9rem;margin-bottom:0.3rem;font-family:'Playfair Display',serif}
.tooltip-info{font-size:0.8rem;color:rgba(245,240,235,0.7);line-height:1.5}
.sourcing-text h3{font-size:clamp(1.8rem,2.5vw,2.5rem);margin-bottom:1.5rem}
.sourcing-text p{color:rgba(245,240,235,0.7);font-size:1rem;margin-bottom:2.5rem}
.sourcing-stats{display:flex;gap:3rem}
.stat{text-align:center}
.stat-num{display:block;font-family:'Playfair Display',serif;font-size:2.5rem;color:var(--teal);font-weight:700}
.stat-label{font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(245,240,235,0.5)}

/* ===== GALLERY ===== */
.gallery-section{text-align:center}
.gallery-section h2{font-size:clamp(2rem,3.5vw,3.2rem);margin-bottom:3rem}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:250px;gap:1rem;max-width:1200px;margin:0 auto}
.gallery-item{border-radius:4px;overflow:hidden;position:relative}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s ease}
.gallery-item:hover img{transform:scale(1.06)}
.gi-tall{grid-row:span 2}
.gi-wide{grid-column:span 2}

/* ===== RESERVATIONS ===== */
.reservations-section{background:var(--navy-light);overflow:hidden;position:relative}
.wave-wash{position:absolute;inset:0;background:var(--teal);transform:translateX(-100%);z-index:3;pointer-events:none;opacity:0}
.wave-wash.active{animation:waveWash 1.2s cubic-bezier(0.4,0,0.2,1) forwards}
@keyframes waveWash{
  0%{transform:translateX(-100%);opacity:0.3}
  40%{transform:translateX(0);opacity:0.15}
  100%{transform:translateX(100%);opacity:0}
}
.res-inner{display:grid;grid-template-columns:1fr 1fr;gap:6rem;max-width:1200px;margin:0 auto;position:relative;z-index:2}
.res-form-side h2{font-size:clamp(2rem,3vw,2.8rem);margin-bottom:2rem}
.res-form{display:flex;flex-direction:column;gap:1.2rem}
.form-group{display:flex;flex-direction:column;gap:0.4rem}
.form-group label{font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(245,240,235,0.5)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
input,select{background:rgba(245,240,235,0.05);border:1px solid rgba(245,240,235,0.12);border-radius:3px;padding:0.9rem 1rem;color:var(--warm);font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:300;outline:none;transition:border-color 0.3s,background 0.3s}
input:focus,select:focus{border-color:var(--teal);background:rgba(42,157,143,0.05)}
input::placeholder{color:rgba(245,240,235,0.3)}
select{cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232a9d8f' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
select option{background:var(--navy);color:var(--warm)}
.btn-reserve{background:var(--teal);color:var(--navy);border:none;border-radius:3px;padding:1.1rem;font-family:'DM Sans',sans-serif;font-size:0.9rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;transition:all 0.3s;margin-top:0.5rem}
.btn-reserve:hover{background:var(--teal-dark);transform:translateY(-1px)}
.btn-reserve.success{background:var(--gold);color:var(--navy)}

.res-info-side{display:flex;flex-direction:column;justify-content:center;gap:2.5rem}
.info-block h3{font-size:1.1rem;color:var(--teal);margin-bottom:0.6rem}
.info-block p{font-size:0.95rem;color:rgba(245,240,235,0.7);font-weight:300;line-height:1.8}

/* ===== FOOTER ===== */
.site-footer{border-top:1px solid rgba(245,240,235,0.06);padding:3rem 6vw}
.footer-inner{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;flex-wrap:wrap;gap:2rem}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:600;display:block;margin-bottom:0.4rem}
.footer-brand p{font-size:0.8rem;color:rgba(245,240,235,0.4)}
.footer-links{display:flex;gap:2rem}
.footer-links a{font-size:0.8rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(245,240,235,0.5);transition:color 0.3s}
.footer-links a:hover{color:var(--teal)}
.footer-credit{font-size:0.8rem;color:rgba(245,240,235,0.4)}
.footer-credit a{color:var(--teal);transition:opacity 0.3s}
.footer-credit a:hover{opacity:0.7}

/* ===== REVEAL ANIMATIONS ===== */
.reveal-text{opacity:0;transform:translateY(25px);transition:opacity 0.8s ease,transform 0.8s ease}
.reveal-text.visible{opacity:1;transform:translateY(0)}
.reveal-words{opacity:1}
.reveal-words .word{display:inline-block;opacity:0;transform:translateY(20px);transition:opacity 0.5s ease,transform 0.5s ease}
.reveal-words .word.visible{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .about-inner{grid-template-columns:1fr;gap:3rem}
  .about-img-accent{position:relative;bottom:auto;right:auto;width:60%;margin-top:-2rem;margin-left:auto}
  .sourcing-inner{grid-template-columns:1fr;gap:3rem}
  .res-inner{grid-template-columns:1fr;gap:3rem}
  .section{padding:6rem 5vw}
}
@media(max-width:768px){
  .main-nav{display:none}
  .nav-toggle{display:block}
  .site-header{padding:1.2rem 1.5rem}
  .site-header.scrolled{padding:0.8rem 1.5rem}
  .hero h1{font-size:clamp(2.8rem,12vw,4.5rem)}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .gi-tall{grid-row:span 1}.gi-wide{grid-column:span 1}
  .sourcing-stats{gap:1.5rem}
  .form-row{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;text-align:center}
  .footer-links{flex-wrap:wrap;justify-content:center}
  .menu-categories{gap:0.5rem}
  .menu-cat{padding:0.5rem 1.2rem;font-size:0.7rem}
}
@media(max-width:480px){
  .section{padding:5rem 4vw}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:220px}
  .sourcing-stats{flex-direction:column;gap:1.5rem}
  .about-img-accent{display:none}
}
