/* ============================================================
   MASUNORI — editorial light system (cream + sumi ink)
   Brand mark: bonsai/coral silhouette. Minimal, Japanese.
   ============================================================ */

:root{
  /* token names kept from prior build, remapped to light theme */
  --ink:        #F4EFE5;   /* page background (cream) */
  --ink-2:      #ECE5D7;   /* alt band (deeper cream) */
  --ink-3:      #E4DBC9;   /* deepest cream */
  --paper:      #1A1813;   /* primary text (sumi ink) */
  --paper-dim:  #4B463D;   /* secondary text */
  --paper-mut:  #8C8576;   /* muted text */
  --line:       rgba(26,24,19,.18);
  --line-soft:  rgba(26,24,19,.10);
  --accent:     #1A1813;   /* structural marks = ink (monochrome) */
  --seal:       #A8362A;   /* sumi-red, used as a whisper only */
  --cream:      #F4EFE5;   /* light text for dark bands */
  --maxw:       1240px;

  --serif: "Shippori Mincho", "Times New Roman", serif;
  --sans:  "Manrope", system-ui, -apple-system, sans-serif;
  --ease: cubic-bezier(.22,.61,.36,1);
}

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

h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.05; margin:0; letter-spacing:-.01em; color:var(--paper); }
p{ margin:0; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 36px; }
.section{ padding:128px 0; position:relative; }
.section--tight{ padding:88px 0; }
section[id], header[id]{ scroll-margin-top:72px; }
/* section intro header for one-page sections */
.sec-intro{ text-align:center; max-width:760px; margin:0 auto 4px; }
.sec-intro h2{ font-size:clamp(38px,5.4vw,72px); margin-top:16px; }
.sec-intro p{ color:var(--paper-dim); margin-top:18px; font-size:18px; }

/* ---- kicker / labels ---- */
.kicker{
  font-family:var(--sans);
  font-size:11.5px; font-weight:700;
  letter-spacing:.30em; text-transform:uppercase;
  color:var(--paper-dim);
  display:inline-flex; align-items:center; gap:14px;
}
.kicker::before{ content:""; width:26px; height:1px; background:var(--paper); display:inline-block; }
.kicker--center::after{ content:""; width:26px; height:1px; background:var(--paper); display:inline-block; }
.jp{ font-family:var(--serif); }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 36px;
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(244,239,229,.84);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  padding:13px 36px;
  border-bottom:1px solid var(--line-soft);
}
.brand{ display:flex; align-items:center; gap:11px; }
.brand__tree{ height:34px; width:auto; }
.brand__word{ height:21px; width:auto; }
.nav.is-scrolled .brand__tree{ height:30px; }
.nav.is-scrolled .brand__word{ height:19px; }
.nav__links{ display:flex; align-items:center; gap:30px; list-style:none; margin:0; padding:0; }
.nav__links a{
  font-size:12.5px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:var(--paper-dim); position:relative; padding:4px 0;
  transition:color .25s var(--ease);
}
.nav__links a:hover{ color:var(--paper); }
.nav__links a.is-active{ color:var(--paper); }
.nav__links a.is-active::after{
  content:""; position:absolute; left:0; right:0; bottom:-3px;
  height:1.5px; background:var(--seal);
}
.nav__right{ display:flex; align-items:center; gap:18px; }

.lang{
  display:flex; align-items:center; gap:2px;
  border:1px solid var(--line); border-radius:999px; padding:3px;
  font-size:11px; font-weight:700; letter-spacing:.08em;
}
.lang button{
  background:none; border:none; color:var(--paper-mut);
  font:inherit; cursor:pointer; padding:5px 11px; border-radius:999px;
  transition:all .2s var(--ease);
}
.lang button.is-on{ background:var(--paper); color:var(--cream); }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--sans); font-size:12.5px; font-weight:700;
  letter-spacing:.10em; text-transform:uppercase;
  padding:13px 24px; border-radius:999px;
  border:1px solid transparent; cursor:pointer;
  transition:all .25s var(--ease); white-space:nowrap;
}
.btn--solid{ background:var(--paper); color:var(--cream); }
.btn--solid:hover{ background:#000; transform:translateY(-1px); }
.btn--ghost{ border-color:var(--line); color:var(--paper); background:transparent; }
.btn--ghost:hover{ border-color:var(--paper); background:var(--paper); color:var(--cream); }
.btn--paper{ background:var(--paper); color:var(--cream); }
.btn--paper:hover{ background:#000; transform:translateY(-1px); }
.btn--lg{ padding:16px 30px; font-size:13px; }
.btn--block{ width:100%; }

/* z-index:91 > el overlay del menú (.nav__links, z90): así la hamburguesa —que
   con el menú abierto se transforma en una X— queda VISIBLE y tappable arriba a
   la derecha. Tocarla cierra el menú sin navegar (deja al usuario donde estaba). */
.nav__burger{ display:none; background:none; border:none; cursor:pointer; width:30px; height:22px; position:relative; z-index:91; }
.nav__burger span{ position:absolute; left:0; right:0; height:2px; background:var(--paper); transition:all .3s var(--ease); }
.nav__burger span:nth-child(1){ top:0; }
.nav__burger span:nth-child(2){ top:10px; }
.nav__burger span:nth-child(3){ top:20px; }
body.menu-open .nav__burger span:nth-child(1){ top:10px; transform:rotate(45deg); }
body.menu-open .nav__burger span:nth-child(2){ opacity:0; }
body.menu-open .nav__burger span:nth-child(3){ top:10px; transform:rotate(-45deg); }

/* ============================================================
   HERO (cream editorial)
   ============================================================ */
.hero{ position:relative; min-height:94svh; display:flex; align-items:center; padding-top:96px; }
.hero__grid{ display:grid; grid-template-columns:1.3fr .7fr; gap:48px; align-items:center; width:100%; }
.hero__title{
  font-size:clamp(52px, 8.4vw, 124px); line-height:.96; letter-spacing:-.02em; font-weight:600; margin:24px 0 0;
}
.hero__title .em{ font-style:italic; font-weight:500; }
.hero__sub{ max-width:480px; margin:28px 0 0; color:var(--paper-dim); font-size:18px; line-height:1.55; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:38px; }
.hero__meta{
  display:flex; flex-wrap:wrap; gap:30px; margin-top:46px;
  padding-top:26px; border-top:1px solid var(--line);
  font-size:13px; color:var(--paper-dim); letter-spacing:.02em;
}
.hero__meta b{ color:var(--paper); font-weight:700; }
.hero__mark{ display:flex; justify-content:center; align-items:center; }
.hero__mark img{ width:min(100%,320px); height:auto; opacity:.96; }

/* full-bleed photo band under hero */
.photo-band{ position:relative; height:64vh; min-height:440px; overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.photo-band .shot{ width:100%; height:100%; }

/* ============================================================
   MARQUEE — ink band
   ============================================================ */
.marquee-strip{ background:var(--paper); color:var(--cream); overflow:hidden; }
.marquee-strip__track{ display:flex; gap:0; white-space:nowrap; animation:marq 34s linear infinite; }
.marquee-strip span{
  font-family:var(--serif); font-size:19px; padding:18px 30px;
  display:inline-flex; align-items:center; gap:30px; letter-spacing:.02em;
}
.marquee-strip span::after{ content:"❋"; opacity:.55; font-size:14px; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.sec-head{ max-width:780px; }
.sec-head--center{ margin:0 auto; text-align:center; }
.sec-head h2{ font-size:clamp(36px,5vw,66px); margin-top:18px; }
.sec-head p{ color:var(--paper-dim); margin-top:18px; font-size:18px; }

/* ============================================================
   SPLIT / ABOUT
   ============================================================ */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:80px; align-items:center; }
.split--rev{ grid-template-columns:.95fr 1.05fr; }
.split__media .shot{ width:100%; height:560px; }
.about-num{ display:flex; gap:50px; margin-top:42px; flex-wrap:wrap; }
.about-num__item .n{ font-family:var(--serif); font-size:46px; color:var(--paper); line-height:1; }
.about-num__item .l{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--paper-mut); margin-top:8px; }

/* ============================================================
   PILLARS
   ============================================================ */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line); }
.pillar{
  padding:40px 34px 40px 0; border-right:1px solid var(--line);
  transition:background .3s var(--ease);
}
.pillar:last-child{ border-right:none; padding-right:0; }
.pillar:not(:first-child){ padding-left:34px; }
.pillar__no{ font-family:var(--serif); font-size:14px; color:var(--seal); letter-spacing:.1em; }
.pillar h3{ font-size:27px; margin:16px 0 12px; }
.pillar p{ color:var(--paper-dim); font-size:15.5px; }

/* ============================================================
   MENU
   ============================================================ */
.menu-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:64px 76px; }
.menu-cat__head{
  display:flex; align-items:baseline; justify-content:space-between;
  border-bottom:1.5px solid var(--paper); padding-bottom:16px; margin-bottom:22px;
}
.menu-cat__head h3{ font-size:31px; }
.menu-cat__head .jp{ color:var(--paper-mut); font-size:16px; letter-spacing:.1em; }
.dish{ display:grid; grid-template-columns:1fr; gap:4px; padding:15px 0; border-bottom:1px solid var(--line-soft); }
.dish:last-child{ border-bottom:none; }
.dish__top{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; }
.dish__name{ font-family:var(--serif); font-size:20px; color:var(--paper); }
.dish__tag{
  font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--seal); border:1px solid rgba(168,54,42,.4); border-radius:999px;
  padding:3px 9px; white-space:nowrap;
}
.dish__desc{ color:var(--paper-mut); font-size:14.5px; line-height:1.5; max-width:92%; }
.dish__price{ font-family:var(--serif); font-size:17px; color:var(--paper); white-space:nowrap; }
.dish__top .dish__name{ flex:1; }

/* menu sticky subnav */
.menu-subnav{ position:sticky; top:0; z-index:60; background:rgba(244,239,229,.92); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.menu-subnav__row{ display:flex; gap:8px; overflow-x:auto; padding:14px 36px; max-width:var(--maxw); margin:0 auto; scrollbar-width:none; }
.menu-subnav__row::-webkit-scrollbar{ display:none; }
.menu-subnav a{ font-size:11.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--paper-dim); padding:7px 14px; border:1px solid var(--line); border-radius:999px; white-space:nowrap; transition:all .2s var(--ease); }
.menu-subnav a:hover{ background:var(--paper); color:var(--cream); border-color:var(--paper); }
.menu-anchor{ scroll-margin-top:96px; }

/* press / reviews */
.press{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.press__card{ border-top:2px solid var(--paper); padding-top:24px; display:flex; flex-direction:column; }
.press__quote{ font-family:var(--serif); font-size:21px; line-height:1.4; flex:1; }
.press__src{ margin-top:16px; font-size:11.5px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--paper-mut); }

.menu-note{
  margin-top:64px; border:1px solid var(--line); border-radius:4px;
  background:var(--ink-2); padding:36px 40px;
  display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap;
}
.menu-note h4{ font-size:25px; }
.menu-note p{ color:var(--paper-dim); font-size:15px; margin-top:6px; max-width:560px; }
.takeaway-tabs{ display:flex; gap:10px; flex-wrap:wrap; margin-top:18px; }

/* ---- menu PDF cards ---- */
.menu-pdf-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pdf-card{
  display:flex; flex-direction:column; min-height:300px;
  border:1px solid var(--line); border-radius:6px; padding:32px 32px 30px;
  background:var(--ink); position:relative; overflow:hidden;
  transition:border-color .3s var(--ease), transform .3s var(--ease), background .3s var(--ease);
}
.pdf-card:hover{ border-color:var(--paper); transform:translateY(-5px); background:var(--ink-2); }
.pdf-card__top{ display:flex; align-items:center; justify-content:space-between; }
.pdf-card__lang{ font-family:var(--serif); font-size:34px; color:var(--paper); line-height:1; }
.pdf-card__ext{ font-size:10px; font-weight:700; letter-spacing:.18em; color:var(--paper-mut); border:1px solid var(--line); border-radius:999px; padding:4px 10px; }
.pdf-card__title{ font-size:30px; margin-top:auto; }
.pdf-card__sub{ color:var(--paper-mut); font-size:14px; margin-top:6px; }
.pdf-card__cta{
  display:inline-flex; align-items:center; gap:9px; margin-top:22px;
  font-size:12px; font-weight:700; letter-spacing:.10em; text-transform:uppercase; color:var(--paper);
}
.pdf-card__cta svg{ width:17px; height:17px; transition:transform .3s var(--ease); }
.pdf-card:hover .pdf-card__cta svg{ transform:translateX(5px); }

/* ============================================================
   LOCATION CARDS
   ============================================================ */
.loc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.loc{
  border:1px solid var(--line); border-radius:4px; overflow:hidden;
  background:var(--ink); display:flex; flex-direction:column;
  transition:border-color .3s var(--ease), transform .3s var(--ease);
}
.loc:hover{ border-color:var(--paper); transform:translateY(-4px); }
.loc__media .shot{ width:100%; height:240px; }
.loc__body{ padding:28px 28px 30px; display:flex; flex-direction:column; flex:1; }
.loc__city{ font-size:30px; margin-bottom:6px; }
.loc__addr{ color:var(--paper-dim); font-size:15px; }
.loc__hours{ color:var(--paper-mut); font-size:13px; letter-spacing:.04em; margin-top:14px; display:flex; align-items:center; gap:8px; }
.loc__hours::before{ content:""; width:7px; height:7px; border-radius:50%; background:#2f8a4e; box-shadow:0 0 0 3px rgba(47,138,78,.16); }
.loc__actions{ display:flex; gap:10px; margin-top:24px; flex-wrap:wrap; }
.loc__actions .btn{ flex:1; padding:11px 12px; font-size:11px; }

.loc-full{ display:grid; grid-template-columns:1fr 1fr; gap:0; border:1px solid var(--line); border-radius:4px; overflow:hidden; margin-bottom:32px; background:var(--ink); }
.loc-full__media{ display:flex; flex-direction:column; }
.loc-full__media .shot{ width:100%; flex:0 0 auto; height:250px; min-height:0; }
.loc-full__map{ flex:1; width:100%; min-height:280px; border:0; display:block; filter:grayscale(.85) contrast(.97); }
.loc-full__body{ padding:58px 56px; display:flex; flex-direction:column; justify-content:center; }
.loc-full__city{ font-size:clamp(40px,5vw,62px); }
.loc-full__addr{ color:var(--paper-dim); font-size:18px; margin-top:14px; }
.loc-full__rows{ margin:30px 0; border-top:1px solid var(--line); }
.loc-full__row{ display:flex; justify-content:space-between; gap:18px; padding:15px 0; border-bottom:1px solid var(--line-soft); font-size:15px; }
.loc-full__row span:first-child{ color:var(--paper-mut); letter-spacing:.04em; }
.loc-full__row span:last-child{ color:var(--paper); font-weight:600; }
.loc-full__actions{ display:flex; gap:12px; flex-wrap:wrap; }

/* ============================================================
   STEPS / CTA CARDS
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.step{ padding-top:26px; border-top:2px solid var(--paper); }
.step__n{ font-family:var(--serif); font-size:15px; color:var(--seal); letter-spacing:.1em; }
.step h3{ font-size:25px; margin:14px 0 10px; }
.step p{ color:var(--paper-dim); font-size:15px; }

.cta-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.cta-card{
  border:1px solid var(--line); border-radius:4px; padding:40px 34px;
  background:var(--ink); display:flex; flex-direction:column; min-height:280px;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.cta-card:hover{ border-color:var(--paper); background:var(--ink-2); }
.cta-card__ic{ font-family:var(--serif); font-size:34px; color:var(--paper); }
.cta-card h3{ font-size:28px; margin:18px 0 12px; }
.cta-card p{ color:var(--paper-dim); font-size:15px; flex:1; }
.cta-card .btn{ margin-top:24px; align-self:flex-start; }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:220px; gap:14px; }
.gallery .shot{ width:100%; height:100%; }
.g-tall{ grid-row:span 2; }
.g-wide{ grid-column:span 2; }

/* ============================================================
   BANNER (photo + ink scrim — light text context)
   ============================================================ */
.banner{ position:relative; overflow:hidden; }
.banner__media{ position:absolute; inset:0; z-index:0; }
.banner__media .shot{ width:100%; height:100%; }
.banner__scrim{ position:absolute; inset:0; z-index:1; background:linear-gradient(90deg, rgba(16,15,11,.92) 0%, rgba(16,15,11,.66) 52%, rgba(16,15,11,.34) 100%); }
.banner__inner{ position:relative; z-index:2; padding:128px 0; }
.banner h2{ font-size:clamp(40px,6vw,82px); max-width:760px; color:var(--cream); }
.banner p{ color:rgba(244,239,229,.78); font-size:19px; margin:22px 0 34px; max-width:520px; }
.banner .kicker{ color:rgba(244,239,229,.72); }
.banner .kicker::before{ background:var(--cream); }
.banner .btn--solid{ background:var(--cream); color:var(--paper); }
.banner .btn--solid:hover{ background:#fff; }
.banner .btn--ghost{ border-color:rgba(244,239,229,.45); color:var(--cream); }
.banner .btn--ghost:hover{ background:var(--cream); color:var(--paper); border-color:var(--cream); }

/* ============================================================
   PAGE HEADER
   ============================================================ */
.page-head{ padding:184px 0 66px; border-bottom:1px solid var(--line); position:relative; overflow:hidden; }
.page-head h1{ font-size:clamp(48px,8vw,108px); margin-top:16px; letter-spacing:-.02em; }
.page-head p{ color:var(--paper-dim); font-size:19px; margin-top:20px; max-width:560px; }
.page-head__jp{ position:absolute; right:36px; bottom:40px; font-family:var(--serif); font-size:clamp(60px,11vw,150px); color:rgba(26,24,19,.07); z-index:0; pointer-events:none; }

/* ============================================================
   FOOTER — ink band
   ============================================================ */
.footer{ border-top:1px solid var(--line); padding:88px 0 42px; background:var(--paper); color:var(--cream); }
.footer__top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; }
.footer__brand{ display:flex; flex-direction:column; gap:18px; }
.footer__logo{ display:flex; align-items:center; gap:14px; }
.footer__tree{ height:50px; width:auto; }
.footer__word{ height:30px; width:auto; }
.footer__brand p{ color:rgba(244,239,229,.55); font-size:14px; max-width:300px; }
.footer__col h4{ font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:rgba(244,239,229,.5); margin-bottom:18px; }
.footer__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer__col a{ color:rgba(244,239,229,.78); font-size:14.5px; transition:color .2s; }
.footer__col a:hover{ color:#fff; }
.footer__bottom{ display:flex; align-items:center; justify-content:space-between; gap:20px; margin-top:66px; padding-top:28px; border-top:1px solid rgba(244,239,229,.16); flex-wrap:wrap; }
.footer__bottom p{ color:rgba(244,239,229,.5); font-size:13px; }
.footer__social{ display:flex; gap:10px; }
.footer__social a{
  width:40px; height:40px; border:1px solid rgba(244,239,229,.24); border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:rgba(244,239,229,.82);
  transition:all .25s var(--ease);
}
.footer__social a:hover{ background:var(--cream); border-color:var(--cream); color:var(--paper); }
.footer__social svg{ width:18px; height:18px; }

/* ============================================================
   REVEAL
   ============================================================ */
@media (prefers-reduced-motion:no-preference){
  .reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
  .reveal.in{ opacity:1; transform:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){ .footer__top{ grid-template-columns:1fr 1fr; } }
@media (max-width:1000px){
  .nav__links, .nav__right .btn{ display:none; }
  .nav__burger{ display:block; }
  .nav__links{
    position:fixed; top:0; right:0; bottom:0; left:0; z-index:90;
    width:100%; height:100vh; height:100dvh;
    flex-direction:column; justify-content:center; gap:28px;
    background:var(--ink); transform:translateY(-100%); transition:transform .45s var(--ease);
  }
  .nav__links a{ font-size:28px; font-family:var(--serif); text-transform:none; color:var(--paper); }
  body.menu-open .nav__links{ display:flex; transform:none; }
  /* Menú abierto = overlay cream a pantalla completa. En iOS Safari los iframes
     (mapas de Google) atraviesan los overlays position:fixed y arrastran su capa
     por encima del menú; ocultarlos mientras el menú está abierto lo evita.
     overflow:hidden bloquea el scroll del fondo. */
  body.menu-open{ overflow:hidden; }
  body.menu-open iframe{ display:none; }
  .hero__grid{ grid-template-columns:1fr; gap:30px; }
  .hero__mark{ order:-1; justify-content:center; }
  .hero__mark img{ width:150px; }
  .split, .split--rev{ grid-template-columns:1fr; gap:40px; }
  .split__media{ order:-1; }
  .split--rev .split__media{ order:-1; }
  .pillars{ grid-template-columns:1fr; }
  .pillar{ border-right:none; border-bottom:1px solid var(--line); padding:30px 0 !important; }
  .pillar:last-child{ border-bottom:none; }
  .loc-grid, .steps, .cta-cards{ grid-template-columns:1fr; }
  .menu-grid{ grid-template-columns:1fr; gap:48px; }
  .menu-pdf-grid{ grid-template-columns:1fr; }
  .press{ grid-template-columns:1fr; }
  .menu-subnav__row{ padding:12px 22px; }
  .loc-full{ grid-template-columns:1fr; }
  /* En desktop las tarjetas alternan (Belgrano viene body-primero en el HTML);
     en una sola columna eso dejaba la foto+mapa DEBAJO de la info. Forzar el
     media siempre arriba para que las tres sucursales se vean igual en mobile. */
  .loc-full__media{ order:-1; }
  .loc-full__body{ order:0; }
  .loc-full__media .shot{ height:220px; }
  .loc-full__map{ min-height:240px; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:180px; }
  .section{ padding:88px 0; }
}
@media (max-width:560px){
  .wrap{ padding:0 22px; }
  .nav{ padding:16px 22px; }
  .nav.is-scrolled{ padding:12px 22px; }
  body{ font-size:16px; }
  .gallery{ grid-template-columns:1fr; }
  .g-wide{ grid-column:span 1; }
  .footer__top{ grid-template-columns:1fr; gap:30px; }
  .lang{ display:none; }
}

/* ============================================================
   PHOTOS — real <img> replacing the old <image-slot> blocks
   ============================================================ */
.shot{ object-fit:cover; background:var(--ink-2); }
.gallery .shot{ border-radius:10px; }
.split__media .shot{ border-radius:18px; }

/* Mobile: stack the reservations card (its grid is an inline style) + tame media heights */
@media (max-width:1000px){
  .reserva-split{ grid-template-columns:1fr !important; }
  .reserva-split > div:first-child{ padding:44px 28px !important; }
  .reserva-split > div:last-child{ min-height:300px !important; }
  .split__media .shot{ height:380px; }
}

/* Language switcher inside the mobile menu (the top-bar one hides on phones) */
.nav__lang-li{ display:none; }
@media (max-width:560px){
  .nav__lang-li{ display:flex; justify-content:center; margin-top:14px; }
  .lang--menu{ display:flex; background:var(--ink-2); border-color:rgba(26,24,19,.4); }
  .lang--menu button{ font-size:15px; padding:10px 20px; }
}
