:root{
  --bg:#faf8f5;
  --paper:#ffffff;
  --ink:#111111;
  --muted:#5b5b5b;
  --line:rgba(17,17,17,.12);
  --line2:rgba(17,17,17,.20);
  --shadow: 0 12px 30px rgba(0,0,0,.10);
  --radius:18px;
  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  line-height:1.55;
  overflow-x:hidden;
}

body.no-scroll{overflow:hidden;}

a{color:inherit}
.container{max-width:1040px;margin:0 auto;padding:0 18px}

.topbar{
  position:sticky; top:0; z-index:50;
  background: rgba(250,248,245,.86);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--line);
}
.topbar .row{
  display:flex; align-items:center; gap:14px;
  padding:14px 0;
}
.brand{
  display:flex; align-items:center; gap:10px;
  text-decoration:none;
  min-width: 120px;
}
.brand img{height:40px;width:auto;display:block}
.brand .wordmark{
  font-weight:800; letter-spacing:.14em;
  text-transform:uppercase; font-size:.88rem;
  opacity:.9;
  display:none;
}
@media (min-width:860px){ .brand .wordmark{display:inline} }

.navlinks{margin-left:auto; display:flex; gap:14px; align-items:center}

/* Mobile menu */
.navtoggle{
  margin-left:auto;
  display:none;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.6);
  cursor:pointer;
}
.navtoggle:hover{border-color:var(--line2)}
.navtoggle svg{width:20px;height:20px}

.navpanel{
  position:fixed;
  inset:0;
  z-index:80;
  background:rgba(0,0,0,.32);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  padding:16px;
}
.navpanel[hidden]{display:none;}
.navpanel__sheet{
  margin-left:auto;
  width:min(380px, 100%);
  background:rgba(250,248,245,.98);
  border:1px solid var(--line);
  border-radius:24px;
  padding:14px;
  box-shadow: var(--shadow);
}
.navpanel__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:4px 4px 10px;
  border-bottom:1px solid var(--line);
}
.navpanel__title{
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:.82rem;
  color:var(--muted);
}
.navpanel__close{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.7);
  cursor:pointer;
}
.navpanel__close:hover{border-color:var(--line2)}

.navlinks.navlinks--panel{
  margin:12px 0 0;
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:stretch;
}
.navlinks.navlinks--panel a{
  padding:12px 12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.7);
  opacity:1;
}
.navlinks.navlinks--panel .langswitch a{
  text-align:center;
  padding:10px 10px;
}

/* Dedicated language block inside mobile drawer */

@media (max-width:859px){
  .brand{min-width:0;}
  .navlinks{display:none;}
  .navtoggle{display:inline-flex;}
}
.navlinks a{
  text-decoration:none;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.78rem;
  opacity:.78;
  position:relative;
  padding:10px 8px;
  border-radius:999px;
}
.navlinks a:hover{opacity:1; background:rgba(17,17,17,.06)}
.navlinks a.active{opacity:1}

.langswitch a{
  text-decoration:none;
  font-weight:800;
  letter-spacing:.08em;
  font-size:.74rem;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  opacity:.9;
}
.hero h1{
  margin:0;
  font-family:var(--serif);
  font-weight:800;
  letter-spacing:.02em;
  font-size: clamp(2rem, 4vw, 3.1rem);
  line-height:1.05;
}
.hero p{
  margin:10px 0 0;
  color:var(--muted);
  max-width: 64ch;
  font-size:1.05rem;
}

.utility{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  margin:18px 0 22px;
}
.search{
  flex:1 1 320px;
  display:flex; align-items:center; gap:10px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 14px;
}
.search input{
  border:0; outline:0;
  width:100%;
  font:inherit;
  background:transparent;
}
.badges{
  display:flex; gap:8px; flex-wrap:wrap; align-items:center;
}
.badge{
  font-size:.78rem;
  letter-spacing:.04em;
  color:var(--muted);
  border:1px solid var(--line);
  background:rgba(255,255,255,.6);
  padding:8px 12px;
  border-radius:999px;
}

.section-nav{
  position:sticky; top:74px; z-index:40;
  background: linear-gradient(to bottom, rgba(250,248,245,.96), rgba(250,248,245,.72));
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--line);
}
.section-nav .pills{
  display:flex; gap:8px; flex-wrap:wrap;
  padding:10px 0;
}
.pill{
  text-decoration:none;
  font-weight:800;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-size:.72rem;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.55);
  opacity:.86;
}
.pill:hover{opacity:1; border-color:var(--line2)}
.pill.active{opacity:1; background:rgba(17,17,17,.08); border-color:var(--line2)}

.menu-section{
  padding:26px 0 8px;
  scroll-margin-top: 140px;
}
.menu-section .capitulo{
  margin:0 0 16px;
  padding:14px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  text-align:center;
  font-weight:900;
  letter-spacing:.34em;
  text-transform:uppercase;
  font-size:.95rem;
}

.menu-section h2.seccion{
  margin:22px 0 10px;
  padding:12px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  font-weight:900;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-size:.86rem;
}

.menu-section ul.carta-lista{
  list-style:none;
  padding:0; margin:0;
}
.menu-section ul.carta-lista li{
  padding:14px 0;
  border-bottom:1px solid var(--line);
  display:grid;
  grid-template-columns: 1fr auto;
  column-gap: 16px;
  row-gap: 6px;
  align-items:baseline;
  position:relative;
}
.menu-section ul.carta-lista li:last-child{border-bottom:none}
.menu-section ul.carta-lista li br{display:none}
.menu-section ul.carta-lista li::after{
  content:"";
  position:absolute;
  left:0; right:0;
  top:22px;
  border-bottom:1px dotted var(--line2);
  pointer-events:none;
  z-index:0;
}
.nombre,.precio{
  position:relative;
  z-index:1;
  background:var(--bg);
  padding:0 6px;
}
.nombre{font-weight:650;font-size:1.02rem}
.precio{font-weight:900;letter-spacing:.08em;font-size:.95rem; justify-self:end}
.desc{
  grid-column:1 / -1;
  margin-top:4px;
  color:var(--muted);
  font-family:var(--serif);
  font-style:italic;
  font-size:.98rem;
}

.panel-link{
  border:1px solid var(--line);
  background:rgba(255,255,255,.7);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}
.panel-link .panel-text{
  margin:0 0 12px;
  color:var(--muted);
  font-family:var(--serif);
  font-style:italic;
}
.panel-link .panel-btn{
  display:inline-block;
  text-decoration:none;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:.74rem;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line2);
  background: var(--paper);
}
.panel-link .panel-btn:hover{transform:translateY(-1px)}

.footer{
  margin-top:32px;
  padding:26px 0 40px;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:.95rem;
}
.footer .cols{
  display:flex; gap:18px; flex-wrap:wrap; justify-content:space-between;
}
.footer a{color:inherit}
.small{font-size:.86rem}

.lang-landing{
  min-height: calc(100vh - 74px);
  display:flex;
  align-items:center;
  padding: 26px 0 52px;
}
.lang-card{
  background: rgba(255,255,255,.78);
  border:1px solid var(--line);
  border-radius: 24px;
  padding: 22px;
  box-shadow: var(--shadow);
}
.lang-card .kicker{
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:900;
  font-size:.78rem;
  color:var(--muted);
}
.lang-card h1{
  margin:10px 0 6px;
  font-family:var(--serif);
  font-weight:800;
  font-size: clamp(2rem, 4vw, 2.9rem);
}
.lang-card p{margin:0;color:var(--muted)}
.lang-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:10px;
}
.lang-tile{
  border:1px solid var(--line);
  background: var(--paper);
  border-radius: 18px;
  padding:14px;
  text-decoration:none;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.lang-tile .code{
  font-weight:900;
  letter-spacing:.20em;
  font-size:.82rem;
  color:var(--muted);
}
.lang-tile .label{
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size:.95rem;
}
.lang-tile:hover{border-color:var(--line2); transform:translateY(-1px)}
@media (max-width:760px){
  .lang-grid{grid-template-columns:1fr}
  .section-nav{top:64px}
}


/* Mobile polish */
@media (max-width:560px){
  .container{padding:0 14px}
  .topbar .row{padding:10px 0}
  .brand img{height:34px}
  .hero{padding:22px 0 10px}
  .hero p{font-size:1rem}
  .utility{margin:14px 0 16px; gap:10px}
  .search{flex:1 1 100%; padding:9px 12px}
  .badges{flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch; padding-bottom:4px}
  .badge{flex:0 0 auto; padding:7px 10px; font-size:.75rem}
  .section-nav{top:58px}
  .section-nav .pills{
    flex-wrap:nowrap;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding:10px 0 12px;
    scroll-snap-type:x proximity;
  }
  .pill{flex:0 0 auto; white-space:nowrap; scroll-snap-align:start; padding:9px 11px}
  .menu-section{padding:18px 0 6px; scroll-margin-top:120px}
  .menu-section .capitulo{font-size:.85rem; letter-spacing:.26em; padding:12px 0}
  .menu-section h2.seccion{font-size:.78rem; letter-spacing:.22em}
  .menu-section ul.carta-lista li{padding:12px 0; grid-template-columns:1fr}
  .menu-section ul.carta-lista li::after{display:none}
  .nombre{padding:0; font-size:1rem}
  .precio{justify-self:start; padding:0; font-size:.92rem; margin-top:2px}
  .desc{font-size:.95rem}
  .footer{padding:20px 0 32px}
}

@media (max-width:380px){
  .hero h1{font-size:1.85rem}
  .pill{font-size:.70rem}
  .nombre{font-size:.98rem}
}

/* v3 mobile polish */
@media (max-width:560px){
  .container{padding:0 14px}
  .topbar .row{gap:10px}
  .brand img{height:36px}
  .hero{padding:26px 0 14px}
  .hero p{font-size:1rem}
  .pills{gap:8px; padding:10px 0}
  .pill{padding:10px 12px; font-size:.78rem}
  .carta-lista li{padding:12px 12px}
  .nombre{font-size:1.02rem}
  .precio{font-size:.98rem}
}
