/* ============================================================
   Mar de Sal · estilos públicos
   ============================================================ */
@font-face{
  font-family:'Quinn';
  src:url('/assets/fonts/Quinn.woff2') format('woff2'),
      url('/assets/fonts/Quinn.ttf') format('truetype');
  font-weight:normal;font-style:normal;font-display:swap;
}
:root{
  --sal:#E6E2D8; --vela:#FAF8F4; --abismo:#242853; --marea:#5A6070;
  --coral:#BB4142; --coral-soft:rgba(187,65,66,.82);
  --line:rgba(90,96,112,.35);
  --display:'Quinn', Georgia, serif;
  --body:'Cutive', Georgia, 'Times New Roman', serif;
  --maxw:980px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--sal);color:var(--abismo);font-family:var(--body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* Header */
.nav{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(18px,5vw,48px);background:rgba(230,226,216,.86);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav__brand{color:var(--coral);font-size:14px;letter-spacing:.14em;white-space:nowrap}
.nav__links{display:flex;align-items:center;gap:clamp(14px,2.4vw,30px)}
.nav__links>a{font-size:13px;letter-spacing:.13em;text-transform:uppercase;color:var(--abismo);transition:color .2s}
.nav__links>a:hover,.nav__links>a.is-active{color:var(--coral)}
.lang{display:flex;gap:2px;border:1px solid var(--line);border-radius:999px;padding:3px;margin-left:6px}
.lang a{font-size:11px;letter-spacing:.06em;color:var(--marea);padding:4px 9px;border-radius:999px;transition:.2s}
.lang a.is-on{background:var(--coral);color:#fff}
.btn-reservas{border:1px solid var(--coral);color:var(--coral);padding:8px 18px;border-radius:999px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;transition:.2s}
.btn-reservas:hover{background:var(--coral);color:#fff}
.burger{display:none;background:none;border:0;cursor:pointer;padding:6px}
.burger span{display:block;width:24px;height:2px;background:var(--abismo);margin:5px 0;transition:.25s}

/* Hero */
.hero{position:relative;height:min(86vh,720px);min-height:480px;overflow:hidden;display:grid;place-items:center}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__water{position:absolute;inset:0;background:
  radial-gradient(120% 80% at 50% 120%, rgba(187,65,66,.22), transparent 60%),
  linear-gradient(180deg,#10131f 0%,#1b2030 40%,#2b2230 100%)}
.hero__shimmer{position:absolute;inset:-20% -20%;opacity:.5;background:
  repeating-linear-gradient(100deg,transparent 0 28px, rgba(255,210,160,.05) 28px 30px),
  radial-gradient(60% 40% at 30% 30%, rgba(255,190,140,.10), transparent 70%);animation:drift 16s linear infinite}
@keyframes drift{0%{transform:translate3d(0,0,0)}50%{transform:translate3d(-3%,1.5%,0)}100%{transform:translate3d(0,0,0)}}
.hero__vignette{position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 40%, transparent 40%, rgba(8,10,18,.55))}
.hero__tag{position:absolute;top:14px;left:0;right:0;text-align:center;color:rgba(250,248,244,.75);font-size:11px;letter-spacing:.2em;z-index:3}
.hero__card{position:relative;z-index:4;background:var(--coral-soft);backdrop-filter:blur(3px);border-radius:20px;
  padding:clamp(32px,6vw,60px) clamp(28px,7vw,80px);text-align:center;color:var(--vela);max-width:min(86vw,640px)}
.logo{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:22px}
.logo svg{width:clamp(40px,7vw,58px);height:auto;flex:none}
.logo__word{font-family:var(--display);font-size:clamp(40px,8vw,72px);line-height:1.05;letter-spacing:.02em}
.hero__card .btn-reservas{border-color:var(--vela);color:var(--vela);font-size:13px}
.hero__card .btn-reservas:hover{background:var(--vela);color:var(--coral)}

/* FAB */
.fab{position:fixed;right:18px;bottom:18px;z-index:50;display:flex;flex-direction:column;gap:12px}
.fab a{width:52px;height:52px;border-radius:50%;background:var(--coral);display:grid;place-items:center;box-shadow:0 6px 18px rgba(36,40,83,.28);transition:transform .2s}
.fab a:hover{transform:translateY(-2px)}
.fab svg{width:24px;height:24px;fill:var(--vela)}

/* Sections */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(56px,9vw,104px) clamp(20px,5vw,32px)}
.section--alt{background:var(--vela)}
.display-title{font-family:var(--display);font-size:clamp(52px,12vw,118px);line-height:1.12;color:var(--abismo);margin:0 0 10px}
.eyebrow{color:var(--coral);font-size:12px;letter-spacing:.22em;text-transform:uppercase;margin:0 0 18px}
.intro{color:var(--marea);max-width:54ch;margin:0 0 14px;font-size:clamp(15px,2.2vw,17px)}
.langnote{color:var(--marea);font-size:12.5px;font-style:italic;opacity:.85;margin:4px 0 40px}

.cat{margin-top:54px}
.cat:first-of-type{margin-top:30px}
.cat__name{font-family:var(--display);font-size:clamp(30px,5vw,42px);line-height:1.18;color:var(--coral);margin:0 0 6px}
.cat__lead{color:var(--marea);font-style:italic;max-width:60ch;margin:0 0 26px;font-size:14.5px}
.subhead{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--abismo);margin:30px 0 14px;padding-bottom:6px;border-bottom:1px solid var(--line)}

.item{padding:13px 0;border-bottom:1px dotted var(--line)}
.item__row{display:flex;align-items:baseline;gap:8px}
.item__name{font-size:16.5px;color:var(--abismo)}
.item__lead{flex:1 1 auto;border-bottom:1px dotted var(--line);transform:translateY(-4px);min-width:18px;opacity:.7}
.item__price{color:var(--coral);white-space:nowrap;font-size:15.5px}
.item__desc{color:var(--marea);font-size:14px;margin-top:4px;max-width:70ch}
.item__meta{color:var(--abismo);opacity:.7;font-size:13px;margin-top:3px}
.note{color:var(--marea);font-size:13px;font-style:italic;margin-top:18px}

.sumiller{margin-top:54px;border-left:2px solid var(--coral);padding:6px 0 6px 22px}
.sumiller p{color:var(--marea);font-style:italic;font-size:16px;max-width:60ch;margin:0}

/* Contacto */
.contact{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,5vw,56px);align-items:center;margin-top:30px}
.map{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);min-height:300px;background:
  repeating-linear-gradient(0deg,rgba(90,96,112,.10) 0 1px,transparent 1px 34px),
  repeating-linear-gradient(90deg,rgba(90,96,112,.10) 0 1px,transparent 1px 34px),var(--vela)}
.map iframe{width:100%;height:100%;min-height:300px;border:0;display:block}
.map__pin{position:absolute;left:46%;top:52%;transform:translate(-50%,-100%)}
.map__pin svg{width:34px;height:34px;fill:var(--abismo)}
.map__note{position:absolute;left:14px;bottom:12px;right:14px;color:var(--marea);font-size:11.5px;font-style:italic}
.contact__logo{font-family:var(--display);font-size:clamp(42px,7vw,64px);color:var(--coral);line-height:1.08;margin:0 0 18px}
.contact__addr{color:var(--abismo);font-size:15.5px;line-height:1.7}
.contact__phone{color:var(--coral);font-size:18px;margin-top:8px;display:inline-block}
.social{display:flex;gap:12px;margin-top:20px}
.social a{width:42px;height:42px;border-radius:50%;background:var(--abismo);display:grid;place-items:center}
.social svg{width:20px;height:20px;fill:var(--vela)}

/* Footer */
.footer{background:var(--abismo);color:var(--sal);text-align:center;padding:46px 20px}
.footer__word{font-family:var(--display);font-size:34px;line-height:1.1;color:var(--vela)}
.footer__tag{color:rgba(230,226,216,.7);font-size:12px;letter-spacing:.16em;margin-top:6px}
.footer__small{color:rgba(230,226,216,.5);font-size:11.5px;margin-top:18px}

/* ── Índice de categorías (scroll horizontal, aparece dentro de carta/bodega) ── */
.cat-nav{
  position:sticky;top:57px;z-index:30;
  background:rgba(230,226,216,.94);backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
  overflow-x:auto;white-space:nowrap;
  scrollbar-width:none;-ms-overflow-style:none;
  padding:0 clamp(14px,4vw,32px);
}
.cat-nav::-webkit-scrollbar{display:none}
.cat-nav a{
  display:inline-block;padding:11px 14px;
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--marea);border-bottom:2px solid transparent;
  transition:color .2s,border-color .2s;white-space:nowrap;
}
.cat-nav a:hover,.cat-nav a.is-active{color:var(--coral);border-bottom-color:var(--coral)}

@media(max-width:860px){
  /* En móvil: ocultar hamburguesa y links del nav superior — la tab bar los reemplaza */
  .burger{display:none}
  .nav__links{display:none}
  /* El nav superior solo muestra el brand centrado */
  .nav{justify-content:center;padding:14px clamp(14px,4vw,32px)}

  /* Espacio para la tab bar inferior */
  body{padding-bottom:68px}

  /* ── Tab bar inferior ── */
  .tab-bar{
    display:flex;
    position:fixed;bottom:0;left:0;right:0;z-index:50;
    background:rgba(250,248,244,.96);backdrop-filter:blur(10px);
    border-top:1px solid var(--line);
    height:64px;
    box-shadow:0 -4px 20px rgba(36,40,83,.08);
  }
  .tab-bar a{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:4px;color:var(--marea);font-size:10px;letter-spacing:.08em;text-transform:uppercase;
    transition:color .2s;padding:8px 4px;
  }
  .tab-bar a.is-active,.tab-bar a:active{color:var(--coral)}
  .tab-bar svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
  .tab-bar .tab-lang{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:4px;color:var(--marea);font-size:10px;letter-spacing:.08em;
    position:relative;cursor:pointer;padding:8px 4px;
  }
  .tab-lang svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
  .tab-lang__label{font-size:10px;letter-spacing:.08em;text-transform:uppercase}
  .tab-lang__menu{
    position:absolute;bottom:68px;left:50%;transform:translateX(-50%);
    background:var(--vela);border:1px solid var(--line);border-radius:12px;
    box-shadow:0 8px 24px rgba(36,40,83,.15);
    display:none;flex-direction:column;overflow:hidden;min-width:80px;
  }
  .tab-lang__menu.open{display:flex}
  .tab-lang__menu a{
    padding:11px 18px;font-size:13px;letter-spacing:.06em;color:var(--abismo);
    border-bottom:1px solid var(--line);text-align:center;
  }
  .tab-lang__menu a:last-child{border-bottom:0}
  .tab-lang__menu a.is-on{color:var(--coral);font-weight:600}

  /* cat-nav pegado bajo el nav superior */
  .cat-nav{top:46px}

  .contact{grid-template-columns:1fr}
  .map{order:2}
}

@media(min-width:861px){
  /* En escritorio la tab bar no existe */
  .tab-bar{display:none}
}

@media(prefers-reduced-motion:reduce){.hero__shimmer{animation:none}html{scroll-behavior:auto}}
