/* ===========================================================
   CARTA · DONOSTI (Tarragona) — menú digital QR
   Catálogo editorial nocturno: wordmark geométrico gigante,
   plato flotando sobre pedestal de luz, índice degustación,
   una pieza editorial por plato firma. 4 idiomas.
   Piel: carbón cálido + oro (el oro ES la brasa).
   Mobile-first (sagrado). Desktop a partir de 760px.
   Contrato: ../DESIGN.md
   =========================================================== */

:root{
  --bg:        #0c0b09;   /* carbón cálido casi negro */
  --surface:   #16140f;
  --surface-2: #1d1a13;
  --text:      #f4efe6;
  --text-dim:  #a9a294;
  --accent:    #c9a44c;   /* oro */
  --accent-h:  #d8b663;
  --line:      rgba(244,239,230,.10);
  --line-2:    rgba(244,239,230,.18);
  --maxw:      1180px;
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --brand: "Questrial", "Century Gothic", var(--sans); /* wordmark geométrico */
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.05; }
section, .entry{ scroll-margin-top:70px; }

/* cifras "modernas" en los precios */
.ix-price, .entry-stats b, .ficha-precio-v, .stat-v{ font-variant-numeric:lining-nums; }

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--accent);
}

/* ============ NAV ============ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1rem 1.2rem;
  transition:background .35s ease, padding .35s ease, border-color .35s ease;
  border-bottom:1px solid transparent;
}
.nav.is-solid{
  background:rgba(12,11,9,.84);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-bottom-color:var(--line);
  padding:.7rem 1.2rem;
}
.nav-mark{
  font-family:var(--brand); font-size:1.05rem; letter-spacing:.34em;
  text-transform:uppercase; color:var(--accent); line-height:1;
}
/* selector de idioma (pills minimal) */
.lang{ display:flex; gap:.25rem; }
.lang button{
  cursor:pointer; background:transparent; border:1px solid transparent;
  color:var(--text-dim); font-family:var(--sans);
  font-size:.72rem; font-weight:700; letter-spacing:.12em;
  padding:.42em .7em; border-radius:100px;
  transition:color .25s ease, border-color .25s ease, background .25s ease;
}
.lang button:hover{ color:var(--text); }
.lang button.is-active{
  color:var(--accent); border-color:rgba(201,164,76,.4);
  background:rgba(201,164,76,.07);
}

/* ============ HERO (foto full-bleed tras el wordmark) ============ */
.hero{
  position:relative; min-height:100svh; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  padding:5.5rem 1.2rem 3.2rem;
  background:var(--bg);
}
.hero-photo{ position:absolute; inset:0; z-index:0; }
.hero-photo img{
  width:100%; height:112%; object-fit:cover; object-position:50% 32%;
  transform:translateY(calc(-3% + var(--par, 0px)));
}
/* veladura: viñeta + fundido al carbón para que la foto SE FUNDA con la página */
.hero-veil{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(130% 95% at 50% 32%, transparent 26%, rgba(12,11,9,.42) 62%, rgba(12,11,9,.86) 100%),
    linear-gradient(180deg, rgba(12,11,9,.42) 0%, rgba(12,11,9,.05) 30%, rgba(12,11,9,.12) 55%, rgba(12,11,9,.94) 90%, var(--bg) 100%);
}
.hero-vlabel{
  position:absolute; z-index:2; top:50%; transform:translateY(-50%);
  writing-mode:vertical-rl;
  font-size:.6rem; font-weight:600; letter-spacing:.3em; text-transform:uppercase;
  color:var(--text-dim); opacity:.55; display:none;
}
.hero-vlabel--l{ left:1.1rem; rotate:180deg; }
.hero-vlabel--r{ right:1.1rem; }
.hero-inner{
  position:relative; z-index:2; width:100%; max-width:var(--maxw);
  display:flex; flex-direction:column; align-items:center; text-align:center;
}
.hero .eyebrow{ margin-bottom:1rem; text-shadow:0 2px 14px rgba(6,5,4,.8); }
.hero-stage{
  position:relative; width:100%;
  min-height:min(60vw, 340px);
  display:flex; align-items:center; justify-content:center;
}
/* wordmark SIEMPRE legible, por delante (su identidad geométrica) */
.hero-title{
  position:relative; z-index:2;
  font-family:var(--brand); font-weight:400;
  font-size:clamp(3rem, 14.5vw, 9.5rem);
  line-height:.9; letter-spacing:.12em; text-transform:uppercase;
  color:var(--text); white-space:nowrap;
  text-shadow:0 4px 34px rgba(6,5,4,.85), 0 1px 10px rgba(6,5,4,.6);
  transform:translateY(var(--part, 0));
}
.hero-flank{
  position:absolute; z-index:3; top:4%;
  font-size:.6rem; font-weight:600; letter-spacing:.26em; text-transform:uppercase;
  color:var(--text-dim); line-height:1.8; display:none;
}
.hero-flank--l{ left:2%; text-align:left; }
.hero-flank--r{ right:2%; text-align:right; }
.hero-rule{
  display:flex; align-items:center; gap:.7rem;
  width:min(62vw, 320px); margin-top:1.2rem;
  color:rgba(201,164,76,.55); font-size:.55rem;
}
.hero-rule::before, .hero-rule::after{
  content:""; flex:1; border-top:1px dotted rgba(244,239,230,.25);
}
.hero-sub{ font-size:1.05rem; color:var(--text); opacity:.85; margin-top:1.1rem; max-width:36ch; text-shadow:0 2px 12px rgba(6,5,4,.8); }
.hero-cue{
  display:inline-flex; align-items:center; gap:.6rem; margin-top:1.6rem;
  font-size:.82rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--text);
}
.cue-arrow{ display:inline-block; animation:bob 1.8s ease-in-out infinite; }
@keyframes bob{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(5px);} }

/* ============ SECCIONES DE LA CARTA ============ */
.section{ position:relative; overflow:hidden; padding:4.5rem 1.4rem; }
.section + .section{ border-top:1px solid var(--line); }
.section{
  background:
    radial-gradient(110% 50% at 50% -8%, rgba(201,164,76,.05), transparent 60%),
    var(--bg);
}
.section-head{ max-width:var(--maxw); margin:0 auto 2.2rem; position:relative; z-index:1; }
.section-head h2{ font-size:clamp(2.4rem, 8.5vw, 3.6rem); margin:.4rem 0 .5rem; }
.section-lead{ color:var(--text-dim); font-size:1.02rem; max-width:46ch; }

/* ============ SUMARIO (índice degustación de secciones) ============ */
.sumario{ padding:5rem 1.4rem 3.5rem; }
.sumario .section-head{ text-align:center; margin-bottom:2rem; }
.sumario .section-lead{ margin-left:auto; margin-right:auto; }
.sum{ list-style:none; max-width:560px; margin:0 auto; }
.sum-row a{
  display:flex; align-items:baseline; gap:.8rem;
  padding:.62rem .3rem; cursor:pointer; border-radius:10px;
  transition:background .3s ease, padding .25s ease;
}
.sum-row a:hover{ background:rgba(29,26,19,.55); padding-left:.7rem; }
.sum-num{ font-size:.66rem; font-weight:600; letter-spacing:.18em; color:var(--accent); opacity:.85; }
.sum-name{
  font-family:var(--serif); font-weight:600; font-size:clamp(1.15rem, 3.8vw, 1.4rem);
  line-height:1.1; transition:color .25s ease;
}
.sum-row a:hover .sum-name{ color:var(--accent); }
.sum-leader{
  flex:1; min-width:1.4rem; align-self:center;
  border-bottom:1px dotted rgba(244,239,230,.22); transform:translateY(.15em);
}
.sum-count{ font-size:.78rem; color:var(--text-dim); letter-spacing:.08em; }

/* ============ BANDA FOTOGRÁFICA (interludio full-bleed) ============ */
.banda{
  position:relative; overflow:hidden;
  height:52svh; min-height:340px; max-height:560px;
}
.banda img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover;
  transform:scale(1.08);
  transition:transform 1.6s ease;
}
.banda.is-in img{ transform:scale(1); }
.banda-veil{
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(120% 100% at 50% 50%, transparent 38%, rgba(12,11,9,.5) 82%),
    linear-gradient(180deg, var(--bg) 0%, rgba(12,11,9,.18) 22%, rgba(12,11,9,.14) 72%, var(--bg) 100%);
}
.banda-inner{
  position:absolute; inset:0; z-index:1;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:1.4rem;
  opacity:0; transform:translateY(18px);
  transition:opacity .9s ease .2s, transform .9s ease .2s;
}
.banda.is-in .banda-inner{ opacity:1; transform:none; }
.banda-title{
  font-size:clamp(2.2rem, 8vw, 3.6rem); color:var(--text);
  text-shadow:0 4px 30px rgba(6,5,4,.9), 0 1px 8px rgba(6,5,4,.7);
}
.banda-sub{
  font-family:var(--serif); font-style:italic; font-size:1.1rem;
  color:var(--text); opacity:.9; margin-top:.4rem;
  text-shadow:0 2px 14px rgba(6,5,4,.9);
}
/* la banda no anima con .reveal genérico (usa su propia coreografía) */
.banda.reveal{ opacity:1; transform:none; }

/* ============ ÍNDICE (la carta, con puntilleo como la suya) ============ */
.index{ list-style:none; max-width:860px; margin:0 auto; position:relative; z-index:1; }
.ix-row{ border-bottom:1px solid var(--line); }
.ix-row:first-child{ border-top:1px solid var(--line); }
.ix-row a{
  display:flex; align-items:baseline; gap:.85rem;
  padding:.8rem .4rem; border-radius:14px; cursor:pointer;
  transition:padding .25s ease, background .3s ease;
}
.ix-row a:hover{ padding-left:.95rem; background:rgba(29,26,19,.55); }
/* vitrina circular retroiluminada (◆ si aún no hay foto) */
.ix-thumb{
  flex:none; align-self:center; position:relative; overflow:hidden;
  width:48px; height:48px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(60% 60% at 50% 44%, rgba(201,164,76,.28), transparent 72%),
    radial-gradient(130% 130% at 50% 0%, #1a1710 0%, #070605 78%);
  border:1px solid rgba(201,164,76,.28);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  color:rgba(201,164,76,.5); font-size:.5rem;
}
.ix-thumb img{
  width:100%; height:100%; object-fit:cover; border-radius:50%;
  transition:transform .35s ease;
}
.ix-row a:hover .ix-thumb img{ transform:scale(1.12); }
.ix-num{ font-size:.68rem; font-weight:600; letter-spacing:.18em; color:var(--accent); opacity:.85; }
.ix-name{
  font-family:var(--serif); font-weight:600;
  font-size:clamp(1.25rem, 4.2vw, 1.6rem); line-height:1.1;
  transition:color .25s ease;
}
.ix-row a:hover .ix-name{ color:var(--accent); }
.ix-type{ display:none; color:var(--text-dim); font-size:.76rem; }
.ix-leader{
  flex:1; min-width:1.6rem; align-self:center;
  border-bottom:1px dotted rgba(244,239,230,.22);
  transform:translateY(.15em);
}
.ix-price{
  font-family:var(--serif); font-weight:600; font-size:1.35rem;
  color:var(--accent); line-height:1; white-space:nowrap;
}
.iva-note{
  text-align:center; color:var(--text-dim); opacity:.75;
  font-size:.78rem; letter-spacing:.06em; padding:1.6rem 1.4rem 3rem;
}

/* ============ ACOMPAÑAMIENTOS (panes / salsas, lista compacta) ============ */
.acomp{ list-style:none; max-width:720px; margin:0 auto; position:relative; z-index:1; }
.ac-row{
  display:flex; align-items:baseline; gap:.7rem;
  padding:.72rem .2rem; border-bottom:1px solid var(--line);
}
.ac-row:first-child{ border-top:1px solid var(--line); }
.ac-name{
  font-family:var(--serif); font-weight:600;
  font-size:clamp(1.05rem, 3.4vw, 1.28rem); line-height:1.15; flex:none;
}
.ac-alg{ display:inline-flex; flex-wrap:wrap; gap:.3rem; align-self:center; }
.ac-alg-chip{
  font-family:var(--sans); font-size:.6rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--text-dim); border:1px solid var(--line-2);
  border-radius:100px; padding:.18em .6em; white-space:nowrap;
}
.ac-leader{
  flex:1; min-width:1.2rem; align-self:center;
  border-bottom:1px dotted rgba(244,239,230,.22); transform:translateY(.15em);
}
.ac-price{
  font-family:var(--serif); font-weight:600; font-size:1.2rem;
  color:var(--accent); line-height:1; white-space:nowrap;
}

/* ============ PIEZA EDITORIAL (plato firma) ============ */
.entries{ max-width:var(--maxw); margin:2.8rem auto 0; position:relative; z-index:1; }
.entry{ position:relative; }
.entry + .entry{ margin-top:3.2rem; padding-top:4rem; }
.entry + .entry::before{
  content:"\25C6"; /* ◆ */
  position:absolute; left:50%; top:0; transform:translateX(-50%);
  color:rgba(201,164,76,.45); font-size:.7rem; line-height:1;
}
.entry-stage{
  position:relative; display:flex; align-items:flex-end; justify-content:center;
  margin-bottom:1.3rem; padding-top:2.2rem;
}
/* nombre fantasma en la tipografía de su marca: asoma POR DETRÁS del marco */
.entry-ghost{
  position:absolute; top:-.18em; left:50%; transform:translateX(-50%);
  z-index:0; white-space:nowrap;
  font-family:var(--brand); font-weight:400;
  font-size:clamp(3.4rem, 17vw, 7.5rem); line-height:1; letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(201,164,76,.12);
  pointer-events:none; user-select:none;
}
/* marco fotográfico full-bleed sobre fondo de luz */
.entry-frame{
  position:relative; z-index:1; margin:0;
  width:min(88vw, 440px); aspect-ratio:3/4;
  border-radius:16px; overflow:hidden;
  border:1px solid rgba(201,164,76,.24);
  box-shadow:0 34px 70px -24px rgba(0,0,0,.75), inset 0 1px 0 rgba(255,255,255,.06);
}
/* fondo de luz: brillo brasa detrás del marco */
.entry-stage::after{
  content:""; position:absolute; z-index:0; left:50%; bottom:-6%;
  width:110%; height:60%; transform:translateX(-50%);
  background:radial-gradient(50% 55% at 50% 50%, rgba(201,164,76,.20), transparent 68%);
  mix-blend-mode:screen; filter:blur(10px); pointer-events:none;
}
.entry-frame img{
  width:100%; height:100%; object-fit:cover;
  transform:scale(1.08);
  transition:transform 1.4s ease;
}
.entry.is-in .entry-frame img{ transform:scale(1); }
/* veladura: la foto se funde con el carbón por abajo */
.entry-frame::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(12,11,9,.14) 0%, transparent 22%, transparent 62%, rgba(12,11,9,.5) 100%);
}
.entry-body{ position:relative; z-index:1; text-align:center; max-width:36rem; margin:0 auto; }
.entry-kicker{
  font-size:.66rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase;
  color:var(--accent); opacity:.9; margin-bottom:.4rem;
}
.entry-name{ font-size:clamp(1.9rem, 6.6vw, 2.6rem); line-height:1.05; }
.entry-tagline{ font-family:var(--serif); font-style:italic; font-size:1.12rem; color:var(--accent); margin-top:.25rem; }
.entry-desc{ color:var(--text-dim); font-size:.98rem; margin-top:.7rem; max-width:44ch; margin-left:auto; margin-right:auto; }
.entry-stats{
  list-style:none; display:flex; justify-content:center; flex-wrap:wrap; gap:1.5rem;
  margin:1.2rem 0 1.1rem;
}
.entry-stats li{ display:flex; flex-direction:column; gap:.22rem; }
.entry-stats span{ font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
.entry-stats b{ font-family:var(--serif); font-size:1.28rem; font-weight:600; }
.entry-stats b.gold{ color:var(--accent); }
.entry-chips{ justify-content:center; }

/* ============ MODAL (ficha de plato) ============ */
.modal{ position:fixed; inset:0; z-index:300; display:none; }
.modal.is-open{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(6,5,4,.78); backdrop-filter:blur(6px); }
.modal-card{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:min(640px, 94vw); max-height:92svh; overflow-y:auto;
  background:var(--surface); border:1px solid var(--line-2); border-radius:18px;
  -webkit-overflow-scrolling:touch;
}
.modal-x{
  position:absolute; top:.7rem; right:.7rem; z-index:5;
  width:40px; height:40px; border-radius:50%; cursor:pointer;
  background:rgba(10,9,7,.6); border:1px solid var(--line-2); color:var(--text);
  font-size:1.5rem; line-height:1; display:flex; align-items:center; justify-content:center;
}
.modal-x:hover{ background:rgba(10,9,7,.9); }
/* ficha con recorte: el plato flota sobre brillo de brasa */
.modal-hero{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.modal-hero--cutout{
  display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(55% 60% at 50% 46%, rgba(201,164,76,.22), transparent 68%),
    radial-gradient(130% 100% at 50% 0%, #1a1710 0%, #0a0908 80%);
}
.modal-hero--cutout img{
  max-height:82%; max-width:78%; object-fit:contain;
  filter:drop-shadow(0 20px 22px rgba(0,0,0,.6));
}
.modal-hero--photo img{ width:100%; height:100%; object-fit:cover; }
.modal-hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(22,20,15,0) 55%, rgba(22,20,15,1) 100%); pointer-events:none; }
.modal-title{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.2rem 1.5rem; }
.modal-title h2{ font-size:2.1rem; }
.modal-tagline{ font-family:var(--serif); font-style:italic; font-size:1.1rem; color:var(--accent); margin-top:.2rem; }
.modal-content{ padding:1.4rem 1.5rem 2rem; }

.stats{ display:flex; gap:.7rem; flex-wrap:wrap; margin-bottom:1.4rem; }
.stat{ flex:1 1 90px; background:var(--surface-2); border:1px solid var(--line); border-radius:10px; padding:.7rem .8rem; }
.stat-k{ font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); }
.stat-v{ font-size:1.05rem; font-weight:700; margin-top:.15rem; }
.stat-v.gold{ color:var(--accent); }

.ficha-row{ padding:.95rem 0; border-top:1px solid var(--line); }
.ficha-row:first-of-type{ border-top:none; }
.ficha-k{ font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); margin-bottom:.3rem; }
.ficha-v{ color:var(--text); font-size:1rem; }

.chips{ display:flex; flex-wrap:wrap; gap:.45rem; }
.chip{ font-size:.82rem; padding:.32em .8em; border-radius:100px; background:var(--surface-2); border:1px solid var(--line-2); color:var(--text); }
.chip--alergeno{ border-color:rgba(201,164,76,.35); color:var(--accent); }

.modal-foot{
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  margin-top:1.5rem; padding-top:1.3rem; border-top:1px solid var(--line-2);
}
.ficha-precio{ display:flex; flex-direction:column; gap:.15rem; }
.ficha-precio-k{ font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
.ficha-precio-v{ font-family:var(--serif); font-size:1.9rem; font-weight:600; color:var(--accent); line-height:1; }
.ficha-seccion{ font-size:.8rem; color:var(--text-dim); letter-spacing:.08em; text-transform:uppercase; }

/* ============ VINOS (sección preparada; índice cuando llegue su carta) ============ */
.section--vinos{ padding-top:2.2rem; padding-bottom:3.2rem; }
.vinos-nota{
  text-align:center; font-family:var(--serif); font-style:italic;
  font-size:1.15rem; color:var(--text-dim); max-width:44ch; margin:0 auto;
}

/* ============ FOOTER ============ */
.footer{ background:#090807; padding:3rem 1.4rem 3.4rem; text-align:center; border-top:1px solid var(--line); }
.footer-mark{ color:var(--accent); font-size:.8rem; margin-bottom:.9rem; }
.footer-line{
  font-family:var(--brand); font-size:.85rem; letter-spacing:.3em;
  text-transform:uppercase; color:var(--accent);
}
.footer-small{ color:var(--text-dim); font-size:.85rem; max-width:56ch; margin:1rem auto 0; }
.footer-credits{ color:var(--text-dim); opacity:.6; font-size:.76rem; margin-top:1rem; }

/* ============ REVEAL (rearmable — se reproduce en cada pasada) ============ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.is-in{ opacity:1; transform:none; }
.entry.reveal{ opacity:1; transform:none; transition:none; }
.entry .entry-stage,
.entry .entry-body{
  opacity:0; transform:translateY(28px);
  transition:opacity .85s ease, transform .85s ease;
}
.entry .entry-body{ transition-delay:.18s; }
.entry.is-in .entry-stage,
.entry.is-in .entry-body{ opacity:1; transform:none; }
.entry .entry-ghost{ opacity:0; scale:.94; transition:opacity 1.1s ease .3s, scale 1.1s ease .3s; }
.entry.is-in .entry-ghost{ opacity:1; scale:1; }

/* ============ TABLET / DESKTOP ============ */
@media (min-width:560px){
  .ix-type{ display:inline; }
}
@media (min-width:760px){
  .section{ padding:6.5rem 2rem; }
  .hero-vlabel{ display:block; }
  .hero-flank{ display:block; }
  .hero-stage{ min-height:min(34vw, 380px); }
  .banda{ height:62svh; max-height:640px; }

  .entry{ display:grid; grid-template-columns:1fr 1.15fr; column-gap:2.6rem; align-items:center; }
  .entry-body{ grid-row:1; grid-column:1; text-align:left; margin:0; }
  .entry-stage{ grid-row:1; grid-column:2; margin:0; }
  .entry:nth-child(even) .entry-body{ grid-column:2; }
  .entry:nth-child(even) .entry-stage{ grid-column:1; }
  .entry-desc{ margin-left:0; margin-right:0; }
  .entry-stats{ justify-content:flex-start; }
  .entry-chips{ justify-content:flex-start; }
  .entry-ghost{ font-size:clamp(3.6rem, 7.5vw, 7rem); }
  .entry-frame{ width:min(36vw, 460px); }
  .entry + .entry{ margin-top:4rem; padding-top:5rem; }

  .entry .entry-stage{ transform:translateX(46px); }
  .entry .entry-body{ transform:translateX(-36px); }
  .entry:nth-child(even) .entry-stage{ transform:translateX(-46px); }
  .entry:nth-child(even) .entry-body{ transform:translateX(36px); }
  .entry.is-in .entry-stage,
  .entry.is-in .entry-body{ transform:none; }
}
@media (min-width:1080px){
  .entry{ column-gap:3.4rem; }
}

/* ===========================================================
   HOME (Fase 2 · web completa) — portada del restaurante.
   Mismo lenguaje: carbón+oro, serif editorial, marcos fotográficos.
   =========================================================== */

/* --- Nav con enlaces (home y vuelta desde la carta) --- */
.nav-right{ display:flex; align-items:center; gap:1rem; }
/* En móvil los enlaces se ocultan (los CTAs del hero cumplen ese papel);
   la marca DONOSTI siempre vuelve al inicio. */
.nav-links{ display:none; align-items:center; gap:1.1rem; }
.nav-links a{
  font-size:.72rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  color:var(--text-dim); transition:color .25s ease; white-space:nowrap;
}
.nav-links a:hover{ color:var(--accent); }

/* --- Botones (pills editoriales) --- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.85em 1.9em; border-radius:100px; cursor:pointer;
  font-family:var(--sans); font-size:.78rem; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--text); border:1px solid rgba(201,164,76,.45);
  background:rgba(201,164,76,.06);
  transition:background .3s ease, color .3s ease, border-color .3s ease, transform .3s ease;
}
.btn:hover{ border-color:var(--accent-h); background:rgba(201,164,76,.14); transform:translateY(-1px); }
.btn--solid{ background:var(--accent); border-color:var(--accent); color:#0c0b09; }
.btn--solid:hover{ background:var(--accent-h); border-color:var(--accent-h); }
.hero-ctas{
  display:flex; flex-wrap:wrap; justify-content:center; gap:.8rem;
  margin-top:1.7rem;
}
.hero-ctas + .hero-cue{ margin-top:2.2rem; }

/* --- Marco fotográfico genérico (mismo trato que .entry-frame) --- */
.photo-frame{
  position:relative; margin:0; overflow:hidden; border-radius:16px;
  border:1px solid rgba(201,164,76,.24);
  box-shadow:0 34px 70px -24px rgba(0,0,0,.75), inset 0 1px 0 rgba(255,255,255,.06);
}
.photo-frame img{
  width:100%; height:100%; object-fit:cover;
  transform:scale(1.08); transition:transform 1.4s ease;
}
.reveal.is-in .photo-frame img, .photo-frame.is-in img{ transform:scale(1); }
.photo-frame::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(12,11,9,.14) 0%, transparent 22%, transparent 62%, rgba(12,11,9,.5) 100%);
}

/* --- Sobre nosaltres --- */
.about-grid{ max-width:var(--maxw); margin:0 auto; display:grid; gap:2.2rem; }
.about-body h2{ font-size:clamp(2.4rem, 8.5vw, 3.6rem); margin:.4rem 0 1rem; }
.about-p{ color:var(--text-dim); font-size:1.02rem; max-width:52ch; }
.about-p + .about-p{ margin-top:.9rem; }
.about-frame{ aspect-ratio:4/5; width:min(88vw, 440px); justify-self:center; }

/* --- Els moments (3 piezas) --- */
.moms{ max-width:var(--maxw); margin:0 auto; display:grid; gap:2.6rem; }
.mom{ text-align:center; }
.mom-frame{ aspect-ratio:4/5; width:min(88vw, 400px); margin:0 auto 1.1rem; }
.mom-title{ font-size:clamp(1.7rem, 6vw, 2.1rem); }
.mom-text{ color:var(--text-dim); font-size:.96rem; max-width:38ch; margin:.45rem auto 0; }

/* --- Banda CTA de la carta --- */
.banda--cta{ height:64svh; min-height:400px; }
.banda-btn{ margin-top:1.4rem; }

/* --- Horari --- */
.horari{ list-style:none; max-width:560px; margin:0 auto; position:relative; z-index:1; }
.h-row{
  display:flex; align-items:baseline; gap:.8rem;
  padding:.72rem .3rem; border-bottom:1px solid var(--line);
}
.h-row:first-child{ border-top:1px solid var(--line); }
.h-day{
  font-family:var(--serif); font-weight:600;
  font-size:clamp(1.15rem, 3.8vw, 1.4rem); line-height:1.1;
}
.h-today{
  align-self:center; font-size:.6rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--accent);
  border:1px solid rgba(201,164,76,.4); border-radius:100px; padding:.2em .7em;
  background:rgba(201,164,76,.07);
}
.h-leader{
  flex:1; min-width:1.4rem; align-self:center;
  border-bottom:1px dotted rgba(244,239,230,.22); transform:translateY(.15em);
}
.h-hours{
  font-family:var(--serif); font-weight:600; font-size:1.15rem;
  color:var(--text); text-align:right;
  display:flex; flex-wrap:wrap; justify-content:flex-end;
  column-gap:.55rem; row-gap:.05rem;
}
.h-shift{ white-space:nowrap; }
.h-shift + .h-shift::before{ content:"· "; color:var(--text-dim); margin-right:.3rem; }
.h-row.is-today .h-day, .h-row.is-today .h-hours{ color:var(--accent); }
.h-row.is-closed .h-hours{ color:var(--text-dim); font-style:italic; font-weight:500; }

/* --- Contacte: com arribar + reserves --- */
.c-grid{ max-width:var(--maxw); margin:0 auto; display:grid; gap:3rem; }
.c-block h2{ font-size:clamp(2rem, 7vw, 2.8rem); margin:.4rem 0 .6rem; }
.c-text{ color:var(--text-dim); font-size:1.02rem; max-width:44ch; margin-bottom:1.2rem; }
.c-tels{ display:flex; flex-direction:column; gap:.15rem; margin-bottom:1.3rem; }
.c-tels a{
  font-family:var(--serif); font-weight:600; font-size:clamp(1.6rem, 6vw, 2.1rem);
  color:var(--text); line-height:1.25; transition:color .25s ease;
  font-variant-numeric:lining-nums;
}
.c-tels a:hover{ color:var(--accent); }
.footer-credits a{ color:var(--accent); opacity:.9; }

/* --- Home · tablet / desktop --- */
@media (min-width:560px){
  .nav-links{ display:flex; }
}
@media (min-width:760px){
  .about-grid{ grid-template-columns:1.15fr 1fr; align-items:center; column-gap:3rem; }
  .about-frame{ width:min(36vw, 440px); }
  .moms{ grid-template-columns:repeat(3, 1fr); column-gap:2.2rem; align-items:start; }
  .mom-frame{ width:100%; }
  .c-grid{ grid-template-columns:1fr 1fr; column-gap:3rem; align-items:start; }
}

/* Respeta reduce-motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .reveal, .entry .entry-stage, .entry .entry-body, .entry .entry-ghost{
    opacity:1 !important; transform:none !important; scale:1 !important;
  }
  .photo-frame img{ transform:none !important; }
}
