/* ===========================================================
   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 ============ */
.hero{
  position:relative; min-height:100svh; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  padding:5.5rem 1.2rem 3.2rem;
  background:
    radial-gradient(120% 70% at 50% 30%, rgba(201,164,76,.07), transparent 62%),
    var(--bg);
}
.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:1; width:100%; max-width:var(--maxw);
  display:flex; flex-direction:column; align-items:center; text-align:center;
}
.hero .eyebrow{ margin-bottom:1rem; }
.hero-stage{
  position:relative; width:100%;
  min-height:min(92vw, 460px);
  display:flex; align-items:center; justify-content:center;
}
/* arco dorado tenue */
.hero-stage::before{
  content:""; position:absolute; z-index:0; left:50%; top:50%;
  width:min(88vw, 560px); aspect-ratio:1/1; transform:translate(-50%,-50%);
  border:1px solid rgba(201,164,76,.14); border-radius:50%;
  -webkit-mask-image:linear-gradient(#000, transparent 72%);
          mask-image:linear-gradient(#000, transparent 72%);
  pointer-events:none;
}
/* brillo brasa tras el producto */
.hero-stage::after{
  content:""; position:absolute; z-index:0; left:50%; top:50%;
  width:min(62vw, 380px); aspect-ratio:1/1; transform:translate(-50%,-58%);
  background:radial-gradient(50% 50% at 50% 50%, rgba(201,164,76,.30), transparent 66%);
  mix-blend-mode:screen; filter:blur(6px); pointer-events:none;
}
/* 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 26px rgba(6,5,4,.7);
  transform:translateY(var(--part, 0));
}
/* el producto emerge POR DETRÁS del wordmark */
.hero-bud{
  position:absolute; z-index:1; left:50%; top:50%;
  translate:-50% calc(-60% + var(--par, 0px));
  width:min(58vw, 350px);
  filter:drop-shadow(0 28px 26px rgba(0,0,0,.65));
  animation:hfloat 7s ease-in-out infinite;
}
@keyframes hfloat{
  0%,100%{ transform:translateY(0); }
  50%    { transform:translateY(-10px); }
}
.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-dim); margin-top:1.1rem; max-width:36ch; }
.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; }

/* ============ Í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:contain; padding:5px;
  transform:scale(var(--img-scale,1));
  filter:drop-shadow(0 4px 6px rgba(0,0,0,.55));
  transition:transform .35s ease;
}
.ix-row a:hover .ix-thumb img{ transform:scale(calc(var(--img-scale,1) * 1.14)); }
.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;
}

/* ============ 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:center; justify-content:center;
  min-height:min(80vw, 420px); margin-bottom:1.3rem;
}
.entry-stage::before{
  content:""; position:absolute; z-index:0; left:50%; top:50%;
  width:min(86vw, 500px); aspect-ratio:1/1; transform:translate(-50%,-48%);
  border:1px solid rgba(201,164,76,.15); border-radius:50%;
  -webkit-mask-image:linear-gradient(#000, transparent 72%);
          mask-image:linear-gradient(#000, transparent 72%);
  pointer-events:none;
}
/* nombre fantasma en la tipografía de su marca */
.entry-ghost{
  position:absolute; inset:0; z-index:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  font-family:var(--brand); font-weight:400;
  font-size:clamp(2.6rem, 15vw, 6.5rem); line-height:.95; letter-spacing:.06em;
  text-align:center; text-transform:uppercase;
  color:rgba(201,164,76,.09);
  pointer-events:none; user-select:none;
}
.entry-pedestal{
  position:relative; z-index:1;
  width:min(68vw, 320px); aspect-ratio:1/1;
  display:flex; align-items:center; justify-content:center;
}
.entry-pedestal::before{
  content:""; position:absolute; z-index:0; left:50%; top:46%;
  width:82%; height:82%; transform:translate(-50%,-50%);
  background:radial-gradient(50% 50% at 50% 50%, rgba(201,164,76,.40), transparent 68%);
  mix-blend-mode:screen; filter:blur(4px); pointer-events:none;
}
.entry-pedestal::after{
  content:""; position:absolute; z-index:0; left:50%; bottom:2%;
  width:72%; height:15%; transform:translateX(-50%);
  background:
    radial-gradient(50% 60% at 50% 38%, rgba(201,164,76,.30), transparent 70%),
    radial-gradient(50% 92% at 50% 100%, rgba(0,0,0,.55), transparent 72%);
  border-radius:50%; pointer-events:none;
}
.entry-pedestal img{
  position:relative; z-index:1;
  max-width:100%; max-height:100%; object-fit:contain;
  transform:scale(var(--img-scale,1));
  filter:drop-shadow(0 26px 26px rgba(0,0,0,.6));
  animation:efloat 6s ease-in-out infinite;
}
@keyframes efloat{
  0%,100%{ transform:scale(var(--img-scale,1)) translateY(0); }
  50%    { transform:scale(var(--img-scale,1)) translateY(-8px); }
}
.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; margin-bottom:1.4rem; }
.entry-cta{
  display:inline-flex; align-items:center; gap:.6rem; cursor:pointer;
  padding:.85em 1.7em; border-radius:100px;
  font-family:var(--sans); font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--accent); background:transparent; border:1px solid rgba(201,164,76,.4);
  transition:background .3s ease, color .3s ease, gap .3s ease, transform .25s ease;
}
.entry-cta i{ font-style:normal; transition:transform .25s ease; }
.entry-cta:hover{ background:var(--accent); color:#1a1405; border-color:var(--accent); transform:translateY(-2px); gap:.9rem; }
.entry-cta:hover i{ transform:translateX(3px); }

/* ============ 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; }

/* ============ 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-bud{ width:min(32vw, 360px); }
  .hero-stage{ min-height:min(48vw, 500px); }

  .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; min-height:min(42vw, 520px); }
  .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, 7vw, 6.5rem); }
  .entry-pedestal{ width:min(34vw, 400px); }
  .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; }
}

/* 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;
  }
}
