/* =========================================================
   La V — Vietnamese Fusion
   Design language inspired by mayabayrestaurant.com,
   branded with La V's identity (Arapey / Lato / Karla,
   Ink / Porcelain / Clay Rose).
   ========================================================= */
@import url("../fonts/fonts.css");

:root{
  --ink:#191919; --ink-card:#201d1d; --charcoal:#141212;
  --porcelain:#ffffff; --paper:#f6f2ee; --paper-2:#efe8e2;
  --clay:#dea193; --clay-2:#e9bab0; --rose:#b0575c;
  --line-dark:rgba(25,25,25,.14);
  --line-light:rgba(255,255,255,.16);
  --ink-soft:rgba(25,25,25,.66);
  --por-soft:rgba(255,255,255,.64);
  --serif:'Arapey','Times New Roman',Georgia,serif;
  --sans:'Lato','Segoe UI',system-ui,-apple-system,Arial,sans-serif;
  --util:'Karla',system-ui,-apple-system,Arial,sans-serif;
  --ease:cubic-bezier(.2,.7,.2,1);
  --container:1280px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.9;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
::selection{background:var(--clay);color:var(--ink)}

/* ---------- shared ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 48px}
.section{padding:130px 0}
.section--dark{background:var(--ink);color:var(--porcelain)}
.section--light{background:var(--paper);color:var(--ink)}

.eyebrow{font-family:var(--util);font-weight:600;font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--clay)}
.h-serif{font-family:var(--serif);font-weight:400;text-transform:uppercase;line-height:.95;letter-spacing:.045em}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;font-family:var(--util);font-weight:600;
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:17px 36px;border:1px solid transparent;
  transition:all .45s var(--ease);white-space:nowrap}
.btn--solid{background:var(--clay);color:var(--ink);border-color:var(--clay)}
.btn--solid:hover{background:transparent;color:var(--clay)}
.btn--light{border-color:rgba(255,255,255,.55);color:#fff}
.btn--light:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn--ink{border-color:var(--ink);color:var(--ink)}
.btn--ink:hover{background:var(--ink);color:#fff}
.btn--clay-line{border-color:var(--clay);color:var(--clay)}
.btn--clay-line:hover{background:var(--clay);color:var(--ink)}

/* section heading with brush flourishes */
.sec-head{text-align:center;margin-bottom:66px}
.sec-head .eyebrow{display:block;margin-bottom:18px}
.sec-title-row{display:flex;align-items:center;justify-content:center;gap:34px}
.sec-title{font-family:var(--serif);font-weight:400;text-transform:uppercase;letter-spacing:.05em;line-height:.9;
  font-size:clamp(48px,7.5vw,104px)}
.sec-shape{width:104px;height:auto;flex:none;opacity:.92;pointer-events:none}
.sec-shape--r{transform:scaleX(-1)}

/* reveal on scroll */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1!important;transform:none!important;transition:none}
  .hero__img{animation:none!important}
}

/* =========================================================
   HEADER
   ========================================================= */
.header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease)}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:96px;padding:0 48px;transition:height .5s var(--ease)}
.header.scrolled{background:rgba(20,18,18,.9);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(255,255,255,.08)}
.header.scrolled .header__inner{height:70px}
.brand{display:flex;align-items:center;gap:16px}
.brand__mark{height:46px;width:auto;transition:height .5s var(--ease)}
.header.scrolled .brand__mark{height:38px}
.brand__loc{font-family:var(--util);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--por-soft);
  padding-left:16px;border-left:1px solid var(--line-light)}
.nav{display:flex;align-items:center;gap:34px}
.nav a{font-family:var(--util);font-weight:500;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.85);position:relative;padding:6px 0}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--clay);transition:width .4s var(--ease)}
.nav a:hover{color:#fff}
.nav a:hover::after{width:100%}
.header__actions{display:flex;align-items:center;gap:18px}
.header .btn{padding:13px 26px;font-size:11px}
.burger{display:none;flex-direction:column;gap:6px;width:34px;height:34px;align-items:center;justify-content:center}
.burger span{display:block;width:26px;height:1.5px;background:#fff;transition:transform .4s var(--ease),opacity .3s}

/* mobile menu overlay */
.mobile-menu{position:fixed;inset:0;z-index:99;background:rgba(20,18,18,.98);backdrop-filter:blur(6px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{font-family:var(--serif);text-transform:uppercase;font-size:30px;letter-spacing:.06em;color:#fff;padding:12px}
.mobile-menu a:hover{color:var(--clay)}
.mobile-menu .btn{margin-top:22px}
.mm-close{position:absolute;top:26px;right:30px;color:#fff;font-family:var(--util);font-size:12px;letter-spacing:.2em;text-transform:uppercase}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;height:100vh;min-height:620px;background:var(--ink);overflow:hidden;display:flex}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__img{width:100%;height:100%;object-fit:cover;animation:kenburns 24s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.18)}}
.hero__overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(15,14,14,.55),rgba(15,14,14,.32) 42%,rgba(18,16,16,.82))}
.hero__inner{position:relative;z-index:2;margin:auto;text-align:center;color:#fff;padding:120px 24px 0;max-width:920px;display:flex;flex-direction:column;align-items:center}
.hero__eyebrow{font-family:var(--util);font-weight:600;font-size:12px;letter-spacing:.42em;text-transform:uppercase;color:var(--clay);margin-bottom:34px}
.hero__logo{width:min(620px,88vw);height:auto;margin-bottom:30px}
.hero__tag{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.6vw,30px);line-height:1.35;color:rgba(255,255,255,.9);max-width:620px;margin-bottom:42px}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}
.hero__scroll{position:absolute;left:50%;bottom:34px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:12px;
  font-family:var(--util);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.hero__scroll i{display:block;width:1px;height:52px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:scrolldot 2.4s var(--ease) infinite}
@keyframes scrolldot{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* =========================================================
   ABOUT
   ========================================================= */
.about__grid{display:grid;grid-template-columns:1fr 0.92fr;gap:84px;align-items:center}
.about__text .eyebrow{margin-bottom:22px}
.about__title{font-family:var(--serif);font-weight:400;text-transform:none;font-size:clamp(34px,4.4vw,58px);line-height:1.08;letter-spacing:.005em;margin-bottom:30px}
.about__title em{font-style:italic;color:var(--rose)}
.about__text p{color:var(--ink-soft);font-size:15.5px;line-height:2;margin-bottom:20px;max-width:52ch}
.about__text p.lead{color:var(--ink);font-size:18px;line-height:1.85}
.about__actions{margin-top:38px}
.about__media{position:relative}
.about__media img:not(.about__mark){width:100%;aspect-ratio:3/4;object-fit:cover;position:relative;z-index:1}
.about__media::before{content:"";position:absolute;inset:22px -22px -22px 22px;border:1px solid var(--clay);z-index:0}
.about__mark{position:absolute;right:-20px;bottom:-30px;width:116px;height:auto;aspect-ratio:auto;object-fit:contain;background:var(--paper);padding:16px 18px;z-index:2;box-shadow:0 10px 30px rgba(25,25,25,.14)}

/* =========================================================
   MENU
   ========================================================= */
.menu__intro{max-width:840px;margin:0 auto 66px;text-align:center;color:var(--por-soft);font-size:16px;line-height:1.95}
.menu__intro em{color:var(--clay);font-style:italic}
.menu__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.mcard{display:flex;flex-direction:column;background:var(--ink-card);border:1px solid var(--line-light);overflow:hidden}
.mcard__media{aspect-ratio:4/5;overflow:hidden}
.mcard__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.mcard:hover .mcard__media img{transform:scale(1.07)}
.mcard__body{padding:26px 24px 26px;display:flex;flex-direction:column;flex:1}
.mcard__cat{font-family:var(--util);font-weight:600;font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--clay);margin-bottom:13px}
.mcard__title{font-family:var(--serif);text-transform:uppercase;font-weight:400;font-size:25px;letter-spacing:.04em;line-height:1;margin-bottom:14px}
.mcard__desc{font-size:13px;line-height:1.75;color:var(--por-soft);flex:1}
.mcard__hours{margin-top:12px;font-family:var(--util);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.mcard__link{margin-top:22px;padding-top:18px;border-top:1px solid var(--line-light);display:inline-flex;align-items:center;gap:11px;
  font-family:var(--util);font-weight:600;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);transition:gap .4s var(--ease),color .3s}
.mcard__link svg{width:20px;height:8px;transition:transform .4s var(--ease)}
.mcard__link:hover{color:var(--clay-2)}
.mcard__link:hover svg{transform:translateX(6px)}

/* =========================================================
   GALLERY (Swiper)
   ========================================================= */
.gallery__slider{overflow:hidden;padding-bottom:8px}
.gallery__slider .swiper-slide{width:clamp(280px,30vw,400px)}
.g-item{aspect-ratio:3/4;overflow:hidden;position:relative}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.g-item:hover img{transform:scale(1.06)}
.gallery__nav{display:flex;justify-content:center;gap:18px;margin-top:44px}
.gnav{width:56px;height:56px;border:1px solid var(--line-light);display:flex;align-items:center;justify-content:center;color:#fff;transition:all .4s var(--ease)}
.gnav:hover{background:var(--clay);border-color:var(--clay);color:var(--ink)}
.gnav svg{width:22px;height:12px}

/* =========================================================
   CONTACT
   ========================================================= */
.contact__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:70px;align-items:stretch}
.contact__block{margin-bottom:34px;padding-bottom:34px;border-bottom:1px solid var(--line-dark)}
.contact__block:last-of-type{border-bottom:0}
.contact__label{font-family:var(--util);font-weight:600;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--rose);margin-bottom:14px}
.contact__value{font-family:var(--serif);font-size:24px;line-height:1.4;letter-spacing:.01em}
.contact__value.small{font-size:19px}
.contact__value a:hover{color:var(--rose)}
.contact__actions{display:flex;gap:14px;flex-wrap:wrap;margin:34px 0 26px}
.social{display:flex;gap:14px}
.social a{width:46px;height:46px;border:1px solid var(--line-dark);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:all .4s var(--ease)}
.social a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.social svg{width:18px;height:18px}
.contact__map{min-height:480px;border:1px solid var(--line-dark);overflow:hidden}
.contact__map iframe{width:100%;height:100%;min-height:480px;border:0;filter:grayscale(.35) contrast(1.02)}

/* =========================================================
   ORDER ONLINE band
   ========================================================= */
.order{position:relative;overflow:hidden;text-align:center;color:#fff;padding:150px 0}
.order__media{position:absolute;inset:0;z-index:0}
.order__media img{width:100%;height:100%;object-fit:cover}
.order__media::after{content:"";position:absolute;inset:0;background:rgba(16,14,14,.72)}
.order__inner{position:relative;z-index:1;max-width:720px;margin:0 auto;padding:0 24px}
.order .sec-title{font-size:clamp(46px,6.5vw,88px)}
.order__text{color:rgba(255,255,255,.82);font-size:16.5px;line-height:1.9;margin:24px auto 40px;max-width:560px}
.order__cta{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--charcoal);color:var(--por-soft);padding:96px 0 40px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:56px;padding-bottom:64px;border-bottom:1px solid var(--line-light)}
.footer__logo{width:230px;height:auto;margin-bottom:26px}
.footer__addr{font-family:var(--serif);font-size:20px;line-height:1.5;color:#fff;margin-bottom:26px}
.footer__col h4{font-family:var(--util);font-weight:600;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--clay);margin-bottom:22px}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.footer__col a,.footer__col p{font-family:var(--util);font-size:13px;letter-spacing:.06em;color:var(--por-soft);transition:color .3s}
.footer__col a:hover{color:#fff}
.footer__phone{font-family:var(--serif);font-size:26px;color:#fff!important;letter-spacing:.02em}
.footer .social{margin-top:22px}
.footer .social a{border-color:var(--line-light);color:#fff}
.footer .social a:hover{background:var(--clay);border-color:var(--clay);color:var(--ink)}
.footer__bottom{padding-top:32px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  font-family:var(--util);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4)}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1080px){
  .menu__grid{grid-template-columns:repeat(2,1fr)}
  .about__grid{gap:56px}
}
@media(max-width:980px){
  .nav,.header__actions .btn{display:none}
  .burger{display:flex}
  .header__inner{padding:0 24px}
  .brand__loc{display:none}
}
@media(max-width:820px){
  .section{padding:82px 0}
  .container{padding:0 24px}
  .sec-shape{width:60px}
  .sec-title-row{gap:18px}
  .about__grid{grid-template-columns:1fr;gap:64px}
  .about__media{order:-1}
  .about__media::before{inset:14px -14px -14px 14px}
  .contact__grid{grid-template-columns:1fr;gap:44px}
  .footer__grid{grid-template-columns:1fr;gap:44px}
  .footer__bottom{flex-direction:column;gap:10px}
  .order{padding:104px 0}
}
@media(max-width:520px){
  .menu__grid{grid-template-columns:1fr}
  .hero__cta{flex-direction:column;width:100%}
  .hero__cta .btn{width:100%}
}
