/* ============================================================
   1. BRAND TOKENS  —  change these to rebrand the whole site
   ============================================================ */
:root{
  /* Colors (dark & bold) */
  --bg:            #14110E;
  --bg-soft:       #1D1916;
  --bg-softer:     #272019;
  --ink:           #F3EDE4;
  --ink-dim:       #B5A793;
  --accent:        #E0633A;
  --accent-2:      #D9A441;
  --line:          rgba(243,237,228,0.10);

  /* Type */
  --display: 'Fraunces', Georgia, serif;
  --body:    'Outfit', system-ui, sans-serif;

  /* Spacing */
  --maxw: 1180px;
  --pad:  clamp(20px, 5vw, 64px);
}

/* ============================================================
   2. RESET + BASE
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
section{padding:clamp(48px,7vw,100px) var(--pad)}
.wrap{max-width:var(--maxw);margin:0 auto}

h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.05;letter-spacing:-0.02em}
.eyebrow{
  font-family:var(--body);
  font-size:.74rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent);margin-bottom:18px;display:inline-block;
}
.lead{color:var(--ink-dim);font-size:1.05rem;max-width:60ch}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);font-weight:500;font-size:.95rem;
  padding:15px 32px;border-radius:100px;cursor:pointer;border:none;
  position:relative;letter-spacing:.01em;
  transition:transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease, background .3s ease, color .3s ease, border-color .3s ease;
}
.btn-primary{
  background:linear-gradient(135deg, #e87a4d, var(--accent));
  color:#fff;box-shadow:0 6px 20px rgba(224,99,58,.32);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(224,99,58,.45)}
.btn-primary:active{transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.03);color:var(--ink);border:1px solid var(--line);backdrop-filter:blur(4px)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-3px);background:rgba(224,99,58,.06)}
.btn-lg{padding:17px 38px;font-size:1rem}

/* Reveal-on-scroll
   Content is VISIBLE by default. JS adds .reveal-on to enable the
   hidden->animate behavior, so if JS fails nothing is ever invisible. */
.reveal-on .reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal-on .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal-on .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* Page header offset (for inner pages with fixed nav) */
.page-top{padding-top:clamp(120px,16vh,180px)}

/* ============================================================
   3. NAV
   ============================================================ */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  transition:background .35s ease, padding .35s ease, border-color .35s ease;
  border-bottom:1px solid transparent;
}
.logo{position:relative;z-index:2}
.nav-links{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
}
.nav-resv{position:relative;z-index:2;padding:10px 22px;font-size:.88rem;color:#fff !important}
.nav-mobile-resv{display:none}
header.nav.scrolled{
  background:rgba(20,17,14,.85);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  padding:12px var(--pad);
}
.logo{font-family:var(--display);font-weight:700;font-size:1.4rem;letter-spacing:-.02em}
.logo span{color:var(--accent)}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:.92rem;color:var(--ink-dim);transition:color .2s}
.nav-links a:hover,.nav-links a.current{color:var(--ink)}
.nav-cta{padding:10px 22px;font-size:.88rem;color:#fff !important}
.nav-toggle{display:none;background:none;border:none;color:var(--ink);cursor:pointer;flex-direction:column;gap:5px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:.3s;transform-origin:center}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   4. HERO  (home page)
   ============================================================ */
.hero{
  min-height:100vh;display:flex;align-items:center;position:relative;
  padding-top:120px;
  background:
    linear-gradient(180deg, rgba(20,17,14,.55) 0%, rgba(20,17,14,.80) 60%, var(--bg) 100%),
    url('../images/hero.jpg') center/cover;
}
.hero-inner{max-width:720px}
.hero h1{font-size:clamp(2.8rem,7vw,5.4rem);margin:14px 0 22px}
.hero h1 em{font-style:italic;color:var(--accent-2)}
.hero .lead{font-size:clamp(1.05rem,2vw,1.25rem);margin-bottom:36px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-marquee{
  position:absolute;bottom:0;left:0;right:0;
  border-top:1px solid var(--line);background:rgba(20,17,14,.6);
  overflow:hidden;white-space:nowrap;padding:14px 0;
}
.hero-marquee div{display:inline-block;animation:scroll 28s linear infinite}
.hero-marquee span{font-family:var(--display);font-style:italic;font-size:1.1rem;color:var(--ink-dim);margin:0 28px}
.hero-marquee span::after{content:'·';margin-left:28px;color:var(--accent)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Page hero (inner pages) */
.page-hero{text-align:center;max-width:680px;margin:0 auto}
.page-hero h1{font-size:clamp(2.4rem,6vw,4.2rem);margin:14px 0 18px}
.page-hero h1 em{font-style:italic;color:var(--accent-2)}

/* ============================================================
   5. ABOUT
   ============================================================ */
.about{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center}
.about-img{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:4/5}
.about-img img{width:100%;height:100%;object-fit:cover}
.about h2{font-size:clamp(2rem,4.5vw,3.2rem);margin:10px 0 22px}
.about p+p{margin-top:16px}
.about-stats{display:flex;gap:40px;margin-top:34px;flex-wrap:wrap}
.about-stats div b{font-family:var(--display);font-size:2.2rem;color:var(--accent-2);display:block;line-height:1}
.about-stats div small{color:var(--ink-dim);font-size:.85rem;letter-spacing:.04em}

/* ============================================================
   6. MENU
   ============================================================ */
.menu{background:var(--bg-soft)}
.menu-head{text-align:center;margin-bottom:54px}
.menu-head h2{font-size:clamp(2rem,4.5vw,3.4rem);margin:8px 0}
.menu-tabs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.menu-tab{
  font-family:var(--body);font-size:.9rem;font-weight:500;letter-spacing:.02em;
  padding:10px 24px;border-radius:100px;border:1px solid var(--line);
  background:transparent;color:var(--ink-dim);cursor:pointer;transition:.25s;
}
.menu-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 48px;max-width:920px;margin:0 auto}
.menu-cat{display:none}
.menu-cat.active{display:contents}
.dish{
  display:flex;gap:18px;align-items:baseline;
  padding:20px 0;border-bottom:1px solid var(--line);
}
.dish-info{flex:1}
.dish-name{font-family:var(--display);font-size:1.18rem;font-weight:600}
.dish-name .tag{
  font-family:var(--body);font-size:.62rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);
  padding:2px 7px;border-radius:4px;margin-left:8px;vertical-align:middle;
}
.dish-desc{color:var(--ink-dim);font-size:.9rem;margin-top:4px}
.dish-price{font-family:var(--display);font-size:1.15rem;color:var(--accent-2);white-space:nowrap}
.dish-dots{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-5px)}
.menu-more{text-align:center;margin-top:48px}

/* Menu cards (image + info) */
.menu-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:26px;
  max-width:1100px;margin:0 auto;
}
.dish-card{
  background:var(--bg);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.dish-card:hover{transform:translateY(-6px);border-color:var(--accent);box-shadow:0 16px 40px rgba(0,0,0,.4)}
.dish-card-img{aspect-ratio:4/3;overflow:hidden}
.dish-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.dish-card:hover .dish-card-img img{transform:scale(1.07)}
.dish-card-body{padding:22px 22px 26px;display:flex;flex-direction:column;flex:1}
.dish-card-top{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.dish-card-name{font-family:var(--display);font-size:1.28rem;font-weight:600;line-height:1.15}
.dish-card-price{font-family:var(--display);font-size:1.25rem;color:var(--accent-2);white-space:nowrap}
.dish-card-tag{
  display:inline-block;margin-top:8px;width:fit-content;
  font-family:var(--body);font-size:.6rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);border:1px solid var(--accent);padding:3px 9px;border-radius:5px;
}
.dish-card-desc{color:var(--ink-dim);font-size:.92rem;margin-top:12px;line-height:1.55}

/* ============================================================
   7. GALLERY
   ============================================================ */
.gallery-head{text-align:center;margin-bottom:48px}
.gallery-head h2{font-size:clamp(2rem,4.5vw,3.4rem);margin:8px 0}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;grid-auto-rows:200px}
.gallery-grid figure{overflow:hidden;border-radius:6px;position:relative}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-grid figure:hover img{transform:scale(1.08)}
.gallery-grid .tall{grid-row:span 2}
.gallery-grid .wide{grid-column:span 2}

/* Home gallery preview (simpler 3-up strip) */
.gallery-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;grid-auto-rows:260px}
.gallery-preview figure{overflow:hidden;border-radius:6px}
.gallery-preview img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-preview figure:hover img{transform:scale(1.08)}

/* Full menu image (on menu page, below favorites) */
.menu-image{margin-top:18px;text-align:center}
.menu-image img{
  width:100%;max-width:760px;margin:0 auto;border-radius:12px;
  border:1px solid var(--line);box-shadow:0 18px 50px rgba(0,0,0,.45);
}
.menu-image .menu-dl{margin-top:26px}

/* ============================================================
   8. ORDER / RESERVE
   ============================================================ */
.order{background:var(--bg-soft);display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.order-copy h2{font-size:clamp(2rem,4.5vw,3.2rem);margin:10px 0 18px}
.order-meta{margin-top:34px;display:flex;flex-direction:column;gap:16px}
.order-meta div{display:flex;gap:14px;align-items:center;color:var(--ink-dim)}
.order-meta b{color:var(--ink);font-weight:500}
.order-meta .ic{width:38px;height:38px;flex-shrink:0;border-radius:8px;background:var(--bg-softer);display:grid;place-items:center;color:var(--accent)}
.order-form{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:clamp(26px,4vw,40px)}
.order-form h3{font-size:1.5rem;margin-bottom:6px}
.order-form p.sub{color:var(--ink-dim);font-size:.9rem;margin-bottom:24px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.82rem;color:var(--ink-dim);margin-bottom:7px;letter-spacing:.02em}
.field input,.field textarea{
  width:100%;background:var(--bg-soft);border:1px solid var(--line);border-radius:9px;
  padding:13px 15px;color:var(--ink);font-family:var(--body);font-size:.95rem;transition:border .2s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{resize:vertical;min-height:96px}
.form-msg{font-size:.9rem;margin-top:14px;min-height:20px}
.form-msg.ok{color:var(--accent-2)}
.form-msg.err{color:#ff7a6b}
.order-form .btn-primary{width:100%;justify-content:center;margin-top:6px}
.order-form .btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* ============================================================
   8a. RESERVATIONS
   ============================================================ */
.resv{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(28px,4vw,40px);align-items:start}
.resv-single{grid-template-columns:1fr;max-width:680px;margin:0 auto}
.resv-head{margin-bottom:46px;text-align:center}
.resv-head h2{font-size:clamp(2.4rem,6vw,4rem);margin:10px 0 18px}
.resv-head .lead{font-size:clamp(1rem,2vw,1.15rem);margin-left:auto;margin-right:auto}
.resv-card{
  background:var(--bg-soft);border:1px solid var(--line);
  border-radius:16px;padding:clamp(26px,4vw,42px);
}
.resv-card h3{font-size:1.7rem;margin-bottom:24px}
.resv-card h3.sub-tight{margin-bottom:4px}
.resv-card .muted{color:var(--ink-dim);font-size:.92rem;margin-bottom:26px}
.resv-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.resv .field label{color:var(--accent);font-weight:500}
.resv select{
  width:100%;background:var(--bg-soft);border:1px solid var(--line);border-radius:9px;
  padding:13px 15px;color:var(--ink);font-family:var(--body);font-size:.95rem;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23B5A793' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 15px center;cursor:pointer;
}
.resv input[type="date"],.resv input[type="time"]{color-scheme:dark;font-family:var(--body);letter-spacing:0;word-spacing:0}
.resv input[type="date"]::-webkit-datetime-edit,
.resv input[type="time"]::-webkit-datetime-edit{padding:0;letter-spacing:0;word-spacing:normal}
.resv input[type="date"]::-webkit-datetime-edit-text{padding:0 1px;color:var(--ink-dim)}
.resv input[type="date"]::-webkit-datetime-edit-month-field,
.resv input[type="date"]::-webkit-datetime-edit-day-field,
.resv input[type="date"]::-webkit-datetime-edit-year-field{padding:0 1px;color:var(--ink-dim)}
/* when a real value is entered, show it in full ink */
.resv input[type="date"]:valid::-webkit-datetime-edit-month-field,
.resv input[type="date"]:valid::-webkit-datetime-edit-day-field,
.resv input[type="date"]:valid::-webkit-datetime-edit-year-field{color:var(--ink)}
.resv input[type="date"]::-webkit-calendar-picker-indicator,
.resv input[type="time"]::-webkit-calendar-picker-indicator{
  filter:invert(.7) sepia(1) saturate(3) hue-rotate(330deg);
  cursor:pointer;opacity:.9;
}
.resv .btn-primary{width:auto;min-width:170px;justify-content:center;margin:14px auto 0;display:flex;padding:14px 42px}
.resv-note{color:var(--ink-dim);font-size:.85rem;margin-top:16px;line-height:1.5}

/* phone-reserve side card */
.resv-phone .btn-call{
  display:flex;justify-content:center;width:100%;font-size:1.15rem;font-weight:600;
  padding:20px;margin-bottom:30px;
}
.resv-info{display:flex;flex-direction:column}
.resv-info-row{
  display:grid;grid-template-columns:110px 1fr;gap:16px;
  padding:18px 0;border-top:1px solid var(--line);
}
.resv-info-row:first-child{border-top:none}
.resv-info-row b{color:var(--accent);font-weight:600;font-size:.95rem}
.resv-info-row span{color:var(--ink);font-size:.98rem;line-height:1.45}

/* ============================================================
   8b. REVIEWS (Google)
   ============================================================ */
.reviews{background:var(--bg)}
.reviews-head{margin-bottom:48px}
.reviews-head h2{font-size:clamp(2rem,4.5vw,3.4rem);margin:8px 0;max-width:16ch}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review-card{
  position:relative;background:var(--bg-soft);border:1px solid var(--line);
  border-radius:14px;padding:30px 28px;display:flex;flex-direction:column;
  text-decoration:none;color:inherit;transition:transform .3s ease,border-color .3s ease;
}
a.review-card:hover{transform:translateY(-5px);border-color:var(--accent)}
.review-card .quote-mark{
  position:absolute;top:18px;right:22px;font-family:var(--display);
  font-size:2.6rem;line-height:1;color:var(--accent);opacity:.35;
}
.review-stars{color:var(--accent);font-size:1rem;letter-spacing:2px;margin-bottom:18px}
.review-text{font-family:var(--display);font-style:italic;font-size:1.05rem;line-height:1.5;color:var(--ink)}
.review-author{margin-top:20px;color:var(--ink-dim);font-size:.88rem}
.review-hidden{display:none}
.review-hidden.show{display:flex}
.reviews-more{text-align:center;margin-top:40px}

/* ============================================================
   8c. MAP EMBED
   ============================================================ */
.map-embed{margin-top:14px;border-radius:14px;overflow:hidden;border:1px solid var(--line);line-height:0}
.map-embed iframe{width:100%;height:360px;border:0;display:block;filter:grayscale(.2) contrast(1.05)}

/* Find Us — intro + why-visit list */
.findus-intro{text-align:center;max-width:680px;margin:0 auto 56px}
.findus-intro h2{font-size:clamp(2.2rem,5vw,3.6rem);margin:10px 0 18px}
.why-list{list-style:none;display:grid;gap:14px;max-width:620px;margin:24px auto 0;text-align:left}
.why-list li{
  display:flex;gap:14px;align-items:flex-start;
  color:var(--ink);font-size:1.02rem;line-height:1.5;
}
.why-list li::before{
  content:"";flex-shrink:0;width:22px;height:22px;margin-top:2px;border-radius:50%;
  background:var(--accent);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E") center/16px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E") center/16px no-repeat;
}

/* Find Us — premium layout */
.findus-hero{
  position:relative;border-radius:18px;overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--line);background:var(--bg-soft);
  max-width:1000px;margin:0 auto;
}
.findus-info{padding:clamp(26px,3.5vw,44px);display:flex;flex-direction:column;justify-content:center}
.findus-info h3{font-size:clamp(1.7rem,3.6vw,2.4rem);margin-bottom:8px}
.findus-info .sub{color:var(--ink-dim);margin-bottom:24px;font-size:.96rem}
.findus-rows{display:flex;flex-direction:column;gap:2px;margin-bottom:26px}
.findus-row{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-top:1px solid var(--line)}
.findus-row:first-child{border-top:none}
.findus-row .ic{
  width:38px;height:38px;flex-shrink:0;border-radius:9px;background:var(--bg);
  display:grid;place-items:center;font-size:1rem;border:1px solid var(--line);
}
.findus-row .rt b{display:block;color:var(--accent);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px}
.findus-row .rt span{color:var(--ink);font-size:.94rem;line-height:1.4}
.findus-actions{display:flex;gap:12px;flex-wrap:wrap}
.findus-map{position:relative;min-height:100%}
.findus-map iframe{width:100%;height:100%;min-height:360px;border:0;display:block;filter:grayscale(.25) contrast(1.05)}

/* ============================================================
   8d. CTA BANNER
   ============================================================ */
.cta{
  background:linear-gradient(180deg, var(--bg-soft), var(--bg));
  border-top:1px solid var(--line);
}
.cta-inner{max-width:var(--maxw);margin:0 auto}
.cta h2{font-size:clamp(2.2rem,5.5vw,4rem);margin:14px 0 20px;max-width:18ch}
.cta .lead{font-size:clamp(1rem,2vw,1.15rem);margin-bottom:0}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}

/* Legal pages (privacy / policy) */
.legal{max-width:760px;margin:0 auto;text-align:center}
.legal h1{font-size:clamp(2.2rem,5vw,3.4rem);margin-bottom:10px}
.legal .updated{color:var(--ink-dim);font-size:.9rem;margin-bottom:40px}
.legal h2{font-size:1.4rem;margin:36px 0 12px;color:var(--ink)}
.legal p{color:var(--ink-dim);margin-bottom:14px;line-height:1.7}
.legal ul{color:var(--ink-dim);margin:0 0 14px;line-height:1.7;list-style:none;padding:0}
.legal a{color:var(--accent)}

/* ============================================================
   9. FOOTER
   ============================================================ */
footer{background:var(--bg);border-top:1px solid var(--line);padding:64px var(--pad) 30px}
.foot-grid{display:grid;grid-template-columns:1.8fr 1fr 1.3fr;gap:48px;max-width:var(--maxw);margin:0 auto}
.foot-brand .foot-social{margin-top:22px}
.foot-visit{display:flex;flex-direction:column;gap:4px}
.foot-visit .v-name{color:var(--ink-dim);font-weight:500;font-size:.98rem;margin-bottom:2px}
.foot-visit a,.foot-visit span{color:var(--ink-dim);font-size:.94rem;margin-bottom:4px;transition:color .2s}
.foot-visit a:hover{color:var(--accent)}
.foot-brand .logo{font-size:1.6rem;margin-bottom:14px}
.foot-brand p{color:var(--ink-dim);max-width:34ch;font-size:.92rem}
.foot-col h4{font-family:var(--body);font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.foot-col a{display:block;color:var(--ink-dim);font-size:.94rem;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:var(--accent)}
.foot-social{display:flex;gap:12px}
.foot-social a{
  width:42px;height:42px;border-radius:50%;
  background:var(--bg-soft);border:1px solid var(--line);
  display:grid;place-items:center;margin-bottom:0;
  transition:transform .25s ease, background .25s ease, border-color .25s ease;
}
.foot-social a:hover{transform:translateY(-3px);background:var(--accent);border-color:var(--accent)}
.foot-social svg{width:19px;height:19px;fill:var(--ink-dim);transition:fill .25s ease}
.foot-social a:hover svg{fill:#fff}
.foot-bottom{max-width:var(--maxw);margin:48px auto 0;padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:14px;color:var(--ink-dim);font-size:.85rem}
.foot-legal{display:flex;gap:18px}
.foot-legal a{color:var(--ink-dim);transition:color .2s}
.foot-legal a:hover{color:var(--accent)}

/* ============================================================
   10. FLOATING WHATSAPP
   ============================================================ */
.fab{
  position:fixed;right:20px;bottom:20px;z-index:60;
  width:56px;height:56px;border-radius:50%;background:#25D366;
  display:grid;place-items:center;box-shadow:0 8px 24px rgba(0,0,0,.4);
  transition:transform .25s;
}
.fab:hover{transform:scale(1.08)}
.fab svg{width:28px;height:28px;fill:#fff}

/* ============================================================
   11. RESPONSIVE
   ============================================================ */
@media (max-width:880px){
  .nav-links{
    position:fixed;inset:0;left:0;top:0;right:0;bottom:0;
    width:100%;height:100vh;height:100dvh;
    background:linear-gradient(165deg, var(--bg-soft), var(--bg));
    flex-direction:column;justify-content:center;align-items:center;
    gap:30px;padding:80px 44px;
    transform:translateX(-100%);transition:transform .45s cubic-bezier(.4,0,.2,1);
    border:none;
    z-index:55;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.6rem;font-family:var(--display);color:var(--ink);opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease,color .25s ease;position:relative}
  .nav-links a:hover,.nav-links a:active{color:var(--accent)}
  .nav-links a::after{
    content:"";position:absolute;left:50%;bottom:-6px;width:0;height:2px;
    background:var(--accent);transform:translateX(-50%);transition:width .3s ease;
  }
  .nav-links a:hover::after,.nav-links a:active::after{width:60%}
  .nav-links a.nav-mobile-resv::after{display:none}
  .nav-links.open a{opacity:1;transform:none}
  .nav-links.open a:nth-child(1){transition-delay:.08s}
  .nav-links.open a:nth-child(2){transition-delay:.14s}
  .nav-links.open a:nth-child(3){transition-delay:.20s}
  .nav-links.open a:nth-child(4){transition-delay:.26s}
  .nav-links.open a:nth-child(5){transition-delay:.32s}
  .nav-links.open a:nth-child(6){transition-delay:.38s}
  .nav-links a.current{color:var(--accent)}
  .nav-mobile-resv{
    display:inline-flex !important;background:var(--accent);color:#fff !important;
    padding:14px 34px;border-radius:100px;font-size:1.15rem !important;margin-top:10px;
    font-family:var(--body) !important;box-shadow:0 8px 24px rgba(224,99,58,.4);
  }
  .nav-resv{display:none}
  .nav-toggle{display:flex;z-index:56}
  .nav-overlay{display:none}
  .about,.order{grid-template-columns:1fr}
  .resv{grid-template-columns:1fr}
  .findus-hero{grid-template-columns:1fr}
  .findus-map iframe{min-height:300px}
  .about-img{aspect-ratio:16/11;max-height:420px}
  .menu-grid{grid-template-columns:1fr;gap:0}
  .menu-cards{grid-template-columns:repeat(2,1fr);gap:18px}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .gallery-grid .wide{grid-column:span 1}
  .gallery-preview{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gallery-preview figure:last-child{grid-column:1/-1}
  .reviews-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px 24px}
  .foot-brand{grid-column:1/-1}
}
@media (max-width:520px){
  .menu-cards{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px 20px}
  .foot-brand{grid-column:1/-1}
  .foot-social{flex-wrap:wrap;gap:10px}
  .foot-social a{width:38px;height:38px}
  .gallery-grid{grid-auto-rows:130px}
  .foot-bottom{font-size:.78rem;gap:10px}
}
