/* Piccolo di Mare */
:root {
  --sand:#f5f0e8;--warm:#ede6d8;--linen:#e0d8c8;--navy:#0e1528;--navy2:#162040;
  --ink:#1a1a2e;--ink2:#3d3a4a;--ink3:#7a7590;--ink4:#b0aab8;
  --gold:#c9a84c;--gold-l:#ddc06a;--gold-d:#a88a30;--grape:#1a0f28;--white:#fff;
  --e:cubic-bezier(.4,0,.2,1);--eo:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Manrope',sans-serif;background:var(--sand);color:var(--ink);overflow-x:hidden}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}
button{border:none;background:none;cursor:pointer;font-family:inherit}
h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,5vw,3.6rem);font-weight:300;line-height:1.1;letter-spacing:-.5px}
h2 em{font-style:italic;color:var(--gold-d);font-weight:400}
.eyebrow{font-size:.6rem;font-weight:700;letter-spacing:4.5px;text-transform:uppercase;color:var(--gold-d);margin-bottom:14px}

/* SCROLL ANIM */
.slide-left{opacity:0;transform:translateX(-60px);transition:opacity .9s var(--e),transform .9s var(--e)}
.slide-right{opacity:0;transform:translateX(60px);transition:opacity .9s var(--e),transform .9s var(--e)}
.slide-up{opacity:0;transform:translateY(50px);transition:opacity .8s var(--e),transform .8s var(--e)}
.scroll-text{opacity:0;transform:translateY(30px) scale(.97);transition:opacity 1s var(--e),transform 1s var(--e)}
.slide-left.vis,.slide-right.vis,.slide-up.vis,.scroll-text.vis{opacity:1;transform:none}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .5s var(--e)}
.nav-inner{max-width:1400px;margin:0 auto;padding:20px 40px;display:flex;align-items:center;justify-content:space-between}
.nav.scrolled{background:rgba(245,240,232,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.nav.scrolled .nav-inner{padding:14px 40px}
.nav-brand{height:32px;position:relative;min-width:180px}
.logo-w,.logo-b{height:32px;width:auto;position:absolute;top:0;left:0;transition:opacity .4s}
.logo-w{opacity:1}.logo-b{opacity:0}
.nav.scrolled .logo-w{opacity:0}.nav.scrolled .logo-b{opacity:1}
.nav-right{display:flex;align-items:center;gap:24px}
.nav-link{font-size:.78rem;font-weight:500;color:rgba(255,255,255,.55);transition:color .3s}
.nav-link:hover{color:var(--gold-l)}
.nav.scrolled .nav-link{color:var(--ink3)}.nav.scrolled .nav-link:hover{color:var(--gold-d)}
.nav-btn{padding:9px 22px;border-radius:60px;font-size:.72rem;font-weight:700;background:var(--gold);color:var(--navy);transition:all .3s}
.nav-btn:hover{background:var(--gold-l);transform:translateY(-2px);box-shadow:0 6px 16px rgba(201,168,76,.25)}
.burger{display:none;width:24px;height:16px;flex-direction:column;justify-content:space-between;z-index:101}
.burger span{height:2px;background:#fff;border-radius:2px;transition:all .3s}
.nav.scrolled .burger span{background:var(--ink)}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mob-overlay{position:fixed;inset:0;background:rgba(14,21,40,.97);backdrop-filter:blur(20px);z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;opacity:0;pointer-events:none;transition:opacity .4s}
.mob-overlay.open{opacity:1;pointer-events:auto}
.mob-overlay a{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:rgba(255,255,255,.7);transition:color .3s}
.mob-overlay a:hover{color:var(--gold-l)}

/* HERO */
.hero{position:relative;height:100vh;height:100dvh;min-height:600px;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:-10% 0;z-index:1;will-change:transform}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-frame{position:absolute;inset:0}
.hf-1{z-index:1}
.hf-2,.hf-3,.hf-4,.hf-5{z-index:2;opacity:0}
.hf-2{animation:ff 2.5s ease-in-out infinite 0s}
.hf-3{animation:ff 2.5s ease-in-out infinite .625s}
.hf-4{animation:ff 2.5s ease-in-out infinite 1.25s}
.hf-5{animation:ff 2.5s ease-in-out infinite 1.875s}
@keyframes ff{0%,18%{opacity:0}25%,43%{opacity:1}50%,100%{opacity:0}}
.hero-fade{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(14,21,40,.25) 0%,rgba(14,21,40,.1) 30%,rgba(14,21,40,.4) 70%,rgba(14,21,40,.88) 100%)}
.hero-content{position:relative;z-index:3;padding:0 48px 80px;max-width:900px}
.hero-loc{font-size:.58rem;font-weight:600;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;opacity:0;animation:fi .7s var(--e) .2s forwards}
h1{font-family:'Cormorant Garamond',serif;font-weight:300;line-height:.9;margin-bottom:12px}
.hw{display:inline-block;font-size:clamp(3.5rem,9vw,7.5rem);color:#fff;opacity:0;transform:translateY(100%);animation:su .8s var(--eo) forwards;animation-delay:var(--d)}.hw.gold{color:var(--gold-l)}.hw i{font-weight:400}
.hero-tag{font-size:clamp(.8rem,1.3vw,.95rem);font-weight:300;color:rgba(255,255,255,.35);margin-bottom:32px;opacity:0;animation:fi 1s var(--e) .7s forwards}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;opacity:0;animation:fi 1s var(--e) .9s forwards}
@keyframes su{to{opacity:1;transform:translateY(0)}}
@keyframes fi{to{opacity:1}}

/* BUTTONS */
.btn-fill{display:inline-flex;align-items:center;padding:14px 30px;border-radius:60px;font-size:.8rem;font-weight:600;background:var(--gold);color:var(--navy);transition:all .3s var(--e)}
.btn-fill:hover{background:var(--gold-l);transform:translateY(-2px);box-shadow:0 8px 20px rgba(201,168,76,.3)}
.btn-line{display:inline-flex;align-items:center;padding:14px 30px;border-radius:60px;font-size:.8rem;font-weight:600;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.6);transition:all .3s var(--e)}
.btn-line:hover{border-color:rgba(255,255,255,.5);color:#fff;transform:translateY(-2px)}

/* STRIP */
.strip{padding:100px 40px;text-align:center;background:var(--sand)}
.strip-text{font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,3.5vw,2.4rem);font-weight:300;font-style:italic;color:var(--ink2);max-width:700px;margin:0 auto;line-height:1.4}

/* DUO */
.duo{display:grid;grid-template-columns:1fr 1fr;min-height:500px;overflow:hidden}
.duo-rev{direction:rtl}.duo-rev>*{direction:ltr}
.duo-img{position:relative;overflow:hidden;min-height:400px}
.duo-img>*{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.duo-text{padding:72px 56px;display:flex;flex-direction:column;justify-content:center;max-width:560px}
.duo-text h2{margin:12px 0 20px}
.duo-text p:not(.eyebrow){font-size:.88rem;font-weight:300;color:var(--ink3);line-height:1.85}

/* ═══ MOSAIC — FLIP ANIMATED ═══ */
.food{padding:100px 40px;background:var(--warm)}
.food-inner{max-width:1200px;margin:0 auto}
.food-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:44px;flex-wrap:wrap;gap:20px}
.filters{display:flex;gap:6px;flex-wrap:wrap}
.pill{padding:8px 18px;border-radius:60px;font-size:.72rem;font-weight:600;color:var(--ink3);border:1.5px solid var(--linen);transition:all .3s;letter-spacing:.3px}
.pill:hover{border-color:var(--gold);color:var(--gold-d)}
.pill.active{background:var(--navy);color:var(--sand);border-color:var(--navy)}

.mosaic{position:relative;width:100%;transition:height .6s var(--e)}

.tile{position:absolute;border-radius:12px;overflow:hidden;cursor:pointer;
  transition:transform .6s var(--e),width .6s var(--e),height .6s var(--e),left .6s var(--e),top .6s var(--e),opacity .4s var(--e)}
.tile.gone{opacity:0;pointer-events:none;transform:scale(.9)}
.tile:hover .tile-img>*{transform:scale(1.06)}
.tile-img{position:absolute;inset:0;overflow:hidden}
.tile-img>*{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--e)}
.ds-img img{width:100%;height:100%;object-fit:cover;border-radius:14px}
.find-bg img{width:100%;height:100%;object-fit:cover}
.tile-cap{position:absolute;bottom:0;left:0;right:0;padding:16px 18px;background:linear-gradient(transparent,rgba(14,21,40,.8) 60%);color:#fff;z-index:2}
.tile-cap strong{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:600;display:block;margin-bottom:1px}
.tile-cap span{font-size:.68rem;font-weight:300;color:rgba(255,255,255,.5)}

/* ═══ DRINKS ═══ */
.drinks{background:var(--navy);position:relative}
.drinks-layout{display:grid;grid-template-columns:1fr 1fr;max-width:1400px;margin:0 auto}
.drinks-sticky{position:relative}
.drinks-stack{position:sticky;top:0;height:100vh;display:flex;align-items:center;justify-content:center;padding:40px;overflow:hidden}
.ds-img{position:absolute;border-radius:14px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.4);transition:transform .6s var(--eo),opacity .6s var(--e)}
.ds-1{width:45%;aspect-ratio:1;z-index:1;transform:rotate(-3deg) translate(-20%,5%);opacity:0}
.ds-2{width:45%;aspect-ratio:1;z-index:2;transform:rotate(4deg) translate(25%,-15%);opacity:0}
.ds-3{width:45%;aspect-ratio:1;z-index:3;transform:rotate(-2deg) translate(5%,20%);opacity:0}
.ds-img.vis{opacity:1}
.drinks-text{padding:120px 56px 120px 40px}
.drinks-block{margin-bottom:80px;min-height:60vh;display:flex;flex-direction:column;justify-content:center}
.drinks-block:last-child{margin-bottom:0}
.drinks-block h2{color:#fff;margin:10px 0 18px}
.drinks-block h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:500;color:var(--gold-l);margin-bottom:10px}
.drinks-block p:not(.eyebrow){font-size:.88rem;font-weight:300;color:rgba(255,255,255,.45);line-height:1.8}

/* REVIEWS */
.voices{padding:100px 40px;background:var(--sand)}
.voices-inner{max-width:900px;margin:0 auto}
.voices-inner>h2{text-align:center;margin-bottom:48px}
.voice-stack{display:flex;flex-direction:column;gap:24px}
.voice{background:var(--white);border-radius:16px;padding:36px 40px;box-shadow:0 2px 12px rgba(0,0,0,.02);border:1px solid rgba(0,0,0,.03)}
.voice p{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:400;font-style:italic;color:var(--ink2);line-height:1.65;margin-bottom:12px}
.voice cite{font-style:normal;font-size:.72rem;font-weight:600;color:var(--ink3)}

/* CONTACT */
.find{position:relative;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.find-bg{position:absolute;inset:-10% 0;z-index:1;will-change:transform}
.find-overlay{position:absolute;inset:0;z-index:2;background:rgba(14,21,40,.82)}
.find-content{position:relative;z-index:3;padding:80px 40px;max-width:960px;width:100%}
.find-content h2{color:#fff;margin-bottom:36px;font-size:clamp(2.2rem,5vw,3.5rem);text-align:center}

.find-two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-bottom:32px}
.find-info{display:flex;flex-direction:column;gap:20px}
.fi strong{display:block;font-size:.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.fi span{font-size:.85rem;font-weight:300;color:rgba(255,255,255,.6);line-height:1.6}
.fi a{color:var(--gold-l);transition:color .3s}.fi a:hover{color:#fff}

.find-form h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:500;color:var(--gold-l);margin-bottom:16px}
.find-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* RESERVATION FORM */
.res-form{display:flex;flex-direction:column;gap:10px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.res-form input,.res-form select{width:100%;padding:13px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#fff;font-family:'Manrope',sans-serif;font-size:.82rem;font-weight:400;outline:none;transition:border-color .3s}
.res-form input::placeholder{color:rgba(255,255,255,.3)}
.res-form select{color:rgba(255,255,255,.3);-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.3)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.res-form select option{background:var(--navy);color:#fff}
.res-form select:valid{color:#fff}
.res-form input:focus,.res-form select:focus{border-color:var(--gold)}
.res-form input[type="date"],.res-form input[type="time"]{color-scheme:dark}
.form-note{font-size:.68rem;font-weight:300;color:rgba(255,255,255,.6);text-align:left;margin-top:10px;line-height:1.5}

/* FOOTER */
.foot{background:var(--navy);padding:28px 0;border-top:1px solid rgba(255,255,255,.04)}
.foot-inner{max-width:1400px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between}
.foot-inner span{font-size:.68rem;color:rgba(255,255,255,.3)}
.foot-ig{color:rgba(255,255,255,.3);transition:color .3s}.foot-ig:hover{color:var(--gold-l)}

/* PLACEHOLDERS */
.ph-full{width:100%;height:100%;min-height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(170deg,#0e1528,#1a1040 40%,#162040 70%,#0e1528);color:rgba(255,255,255,.08);font-size:.55rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;text-align:center;padding:20px}
.ph-full::after{content:attr(data-label)}
.ph-sq{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#2e1a3d);color:rgba(255,255,255,.08);font-size:.5rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;text-align:center;padding:12px}
.ph-sq::after{content:attr(data-label)}

/* INLINE COCKTAIL IMAGES (mobile only) */
.db-img{display:none}

/* RESPONSIVE */
@media(max-width:960px){
  .duo,.duo-rev{grid-template-columns:1fr;direction:ltr}
  .duo-img{min-height:300px}.duo-text{padding:48px 32px}
  .drinks-layout{grid-template-columns:1fr}
  .drinks-sticky{display:none}
  .db-img{display:block;border-radius:14px;overflow:hidden;margin-bottom:24px;box-shadow:0 12px 36px rgba(0,0,0,.35)}
  .db-img img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
  .drinks-text{padding:80px 32px}
  .drinks-block{min-height:auto;margin-bottom:48px}
  .find-two-col{grid-template-columns:1fr;gap:32px}
  .find-content{padding:60px 32px}
  .nav-inner{padding:16px 24px}
}
@media(max-width:640px){
  .nav-right{display:none}.burger{display:flex}
  .hero-content{padding:0 24px 40px}
  .hero-bg img{object-position:80% center}
  .hw{font-size:clamp(2.6rem,13vw,4rem)!important}
  .strip{padding:64px 24px}.duo-text{padding:40px 24px}
  .food{padding:64px 20px}
  .food-head{flex-direction:column;align-items:flex-start}
  .filters{width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  .pill{white-space:nowrap;flex-shrink:0}
  .voices{padding:64px 20px}.voice{padding:28px 24px}
  .find-content{padding:60px 24px}
  .find-btns{flex-direction:column;align-items:center}
  .find-btns .btn-fill,.find-btns .btn-line{width:100%;justify-content:center}
  .form-row{grid-template-columns:1fr}
  .foot-inner{flex-direction:column;gap:12px;text-align:center;padding:0 20px}
}
