/* ============================================================
   La Mélange — Vajilla para eventos
   Estética alineada a lamelange.com.ar:
   blanco minimal · Playfair Display + Montserrat · acento slate
   ============================================================ */

:root {
  --bg:        #FFFFFF;  /* fondo principal (blanco) */
  --bg-2:      #F6F4F1;  /* off-white cálido (secciones alternas) */
  --bg-3:      #ECE6DE;  /* neutro cálido (slots de foto) */
  --ink:       #1A1A1A;  /* negro del logo */
  --muted:     #6F6A64;  /* gris cálido (texto secundario) */
  --line:      #E5E1DB;  /* hairline */
  --accent:    #2C3E50;  /* slate (acento de la tienda) */
  --dark:      #2A2622;  /* banda oscura (negro cálido) */
  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:  "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --maxw:  1200px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  font-weight: 300;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }

/* ---------- Tipografía ---------- */
h1, h2, h3 { font-family: var(--serif); font-weight: 400; line-height: 1.15; }
h1 { font-size: clamp(2.4rem, 5.2vw, 4rem); letter-spacing: 0.5px; }
h2 { font-size: clamp(1.8rem, 3.6vw, 2.7rem); }
h3 { font-size: 1.4rem; }

.eyebrow {
  font-family: var(--sans);
  font-size: 0.7rem; font-weight: 400;
  letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--accent); display: inline-block;
}
.lead { font-size: 1.08rem; color: var(--muted); font-weight: 300; max-width: 48ch; }

/* ---------- Botones ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 0.5em;
  font-family: var(--sans); font-size: 0.74rem; letter-spacing: 0.2em;
  text-transform: uppercase; font-weight: 400;
  padding: 1.05em 2.1em; border: 1px solid var(--ink);
  transition: all .25s ease; cursor: pointer; border-radius: 0;
}
.btn--solid { background: var(--ink); color: #fff; }
.btn--solid:hover { background: transparent; color: var(--ink); }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: #fff; }
.btn--light { border-color: #fff; color: #fff; }
.btn--light:hover { background: #fff; color: var(--ink); }

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--line);
}
.nav__inner { display: flex; align-items: center; justify-content: space-between; height: 80px; }
.brand { display: inline-block; text-align: center; line-height: 1; }
.brand b { font-family: var(--serif); font-weight: 400; font-size: 1.55rem; letter-spacing: 0.22em; text-transform: uppercase; display: block; }
.brand small { font-family: var(--sans); font-weight: 300; font-size: 0.56rem; letter-spacing: 0.42em; text-transform: uppercase; color: var(--muted); display: block; margin-top: 6px; text-align: center; }
.brand__logo { display: block; height: 26px; width: auto; margin: 0 auto; }
.footer .brand { text-align: left; }
.footer .brand__logo { margin: 0; }
.footer .brand small { text-align: left; }
.nav__links { display: flex; align-items: center; gap: 34px; }
.nav__links a { font-family: var(--sans); font-size: 0.82rem; font-weight: 400; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); transition: color .2s; }
.nav__links a:hover { color: var(--ink); }
.nav__cta { color: var(--ink) !important; border: 1px solid var(--ink); padding: 0.85em 1.4em; }
.nav__cta:hover { background: var(--ink); color: #fff !important; }
.nav__toggle { display: none; background: none; border: 0; font-size: 1.5rem; color: var(--ink); cursor: pointer; }

/* ---------- Hero (split: texto en panel limpio + foto nítida) ---------- */
.hero { position: relative; }
.hero--split { display: grid; grid-template-columns: 1.05fr 1fr; min-height: 76vh; }
.hero__panel { display: flex; align-items: center; padding: 56px 5vw; background: var(--bg); }
.hero__photo { background-size: cover; background-position: center; background-color: var(--bg-3); min-height: 40vh; }
.hero__content { text-align: left; max-width: 540px; }
.hero__content h1 { margin: 20px 0 22px; }
.hero__content .lead { margin: 0; }
.hero__actions { display: flex; gap: 14px; margin-top: 36px; justify-content: flex-start; flex-wrap: wrap; }
@media (max-width: 860px) {
  .hero--split { grid-template-columns: 1fr; }
  .hero__photo { min-height: 42vh; order: -1; }
  .hero__panel { padding: 44px 28px; }
  .hero__content { text-align: center; max-width: none; margin: 0 auto; }
  .hero__actions { justify-content: center; }
}

/* ---------- Slots de foto ---------- */
.photo {
  position: relative; background: var(--bg-3); overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  background-size: cover; background-position: center;
}
.photo::after {
  content: attr(data-label);
  position: absolute; bottom: 14px; left: 0; right: 0; text-align: center;
  font-family: var(--sans); font-size: 0.6rem; letter-spacing: 0.26em;
  text-transform: uppercase; color: var(--accent); opacity: .6;
}
.photo svg { width: 48px; height: 48px; stroke: var(--accent); opacity: .45; }
.photo--full { width: 100%; height: 100%; }

/* ---------- Secciones ---------- */
.section { padding: 110px 0; }
.section--sand { background: var(--bg-2); }
.section__head { text-align: center; max-width: 660px; margin: 0 auto 60px; }
.section__head h2 { margin: 16px 0 16px; }
.section__head p { color: var(--muted); }

/* ---------- Valores ---------- */
.values { display: grid; grid-template-columns: repeat(3, 1fr); gap: 56px; }
.value { text-align: center; }
.value svg { width: 38px; height: 38px; stroke: var(--accent); margin: 0 auto 20px; }
.value h3 { font-size: 1.3rem; margin-bottom: 12px; }
.value p { color: var(--muted); font-size: 0.96rem; }

/* ---------- Colecciones ---------- */
.collections { display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px; }
.col-card { display: block; background: var(--bg); border: 1px solid var(--line); overflow: hidden; transition: transform .3s ease, box-shadow .3s ease; }
.col-card:hover { transform: translateY(-4px); box-shadow: 0 22px 50px -30px rgba(0,0,0,.4); }
.col-card .photo { aspect-ratio: 4/3; }
.col-card__body { padding: 24px 26px 28px; text-align: center; }
.col-card__body h3 { font-size: 1.3rem; margin-bottom: 6px; }
.col-card__count { font-family: var(--sans); font-size: 0.66rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }

/* ---------- Stock destacado ---------- */
.stock-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.product { background: var(--bg); border: 1px solid var(--line); overflow: hidden; }
.product .photo { aspect-ratio: 1/1; }
.product__body { padding: 18px 20px 22px; text-align: center; }
.product__name { font-family: var(--serif); font-size: 1.12rem; margin-bottom: 4px; }
.product__meta { font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.badge { display: inline-flex; align-items: center; gap: 0.5em; font-family: var(--sans); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); border: 1px solid var(--line); padding: 0.5em 0.9em; }
.badge i { width: 5px; height: 5px; border-radius: 50%; background: var(--accent); display: inline-block; }

/* ---------- Lookbook ---------- */
.lookbook { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 240px 240px; gap: 16px; }
.lookbook .photo:nth-child(1) { grid-row: span 2; }

/* ---------- Banda profesionales ---------- */
.pro { background: var(--bg-2); color: var(--ink); }
.pro__grid { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 64px; padding-top: 100px; padding-bottom: 100px; }
.pro .eyebrow { color: var(--accent); }
.pro h2 { margin: 18px 0 20px; color: var(--ink); }
.pro p { color: var(--muted); margin-bottom: 22px; }
.pro__list { list-style: none; display: grid; gap: 16px; }
.pro__list li { display: flex; gap: 13px; align-items: flex-start; font-size: 0.96rem; color: var(--ink); font-weight: 300; }
.pro__list svg { width: 19px; height: 19px; stroke: var(--accent); flex: 0 0 auto; margin-top: 4px; }

/* ---------- CTA ---------- */
.cta-band { text-align: center; padding: 110px 0; }
.cta-band h2 { margin: 16px auto 18px; max-width: 18ch; }
.cta-band p { color: var(--muted); max-width: 50ch; margin: 0 auto 32px; }

/* ---------- Footer ---------- */
.footer { background: var(--bg-2); border-top: 1px solid var(--line); padding: 70px 0 44px; }
.footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 44px; margin-bottom: 48px; }
.footer h4 { font-family: var(--sans); font-size: 0.66rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--accent); margin-bottom: 18px; }
.footer a, .footer p { color: var(--muted); font-size: 0.9rem; display: block; margin-bottom: 9px; }
.footer a:hover { color: var(--ink); }
.footer__bottom { border-top: 1px solid var(--line); padding-top: 26px; display: flex; justify-content: space-between; font-size: 0.74rem; letter-spacing: 0.06em; color: var(--muted); flex-wrap: wrap; gap: 8px; }

/* ---------- Catálogo ---------- */
.catalog-head { padding: 80px 0 24px; text-align: center; }
.filters { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin: 36px 0 8px; }
.filter { font-family: var(--sans); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; padding: 0.7em 1.3em; border: 1px solid var(--line); background: var(--bg); cursor: pointer; color: var(--muted); transition: all .2s; }
.filter:hover { border-color: var(--ink); color: var(--ink); }
.filter.is-active { background: var(--ink); color: #fff; border-color: var(--ink); }
.catalog-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; padding: 32px 0 110px; }

/* ---------- WhatsApp flotante ---------- */
.wa { position: fixed; right: 24px; bottom: 24px; z-index: 60; width: 54px; height: 54px; border-radius: 50%; background: #25D366; display: flex; align-items: center; justify-content: center; box-shadow: 0 10px 26px -8px rgba(0,0,0,.45); }
.wa svg { width: 28px; height: 28px; fill: #fff; }

/* ---------- Modalidades (sección 3) ---------- */
.mods { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.mod { display: block; text-align: center; border: 1px solid var(--line); padding: 40px 28px; background: var(--bg); transition: transform .25s ease, background .25s ease; }
.mod:hover { background: var(--bg-2); transform: translateY(-3px); }
.mod svg { width: 40px; height: 40px; stroke: var(--accent); margin: 0 auto 20px; }
.mod h3 { font-size: 1.4rem; margin-bottom: 10px; }
.mod p { color: var(--muted); font-size: 0.95rem; margin-bottom: 20px; }
.mod .go { font-family: var(--sans); font-size: 0.68rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); }

/* ---------- Mesas curadas (galería por modelo, photo-first) ---------- */
.mesa-band { padding: 60px 0; }
.mesa-band:nth-child(odd) { background: var(--bg-2); }
.mesa-feat { display: grid; grid-template-columns: 1.25fr 1fr; gap: 56px; align-items: center; }
.mesa-band:nth-child(even) .mesa-feat { grid-template-columns: 1fr 1.25fr; }
.mesa-band:nth-child(even) .mesa-gallery { order: 2; }
.mesa-band:nth-child(even) .mesa-info { order: 1; }
.mesa-gallery .main { aspect-ratio: 3/2; }
.mesa-info .eyebrow { margin-bottom: 14px; }
.mesa__name { font-family: var(--serif); font-size: clamp(2rem, 3vw, 2.6rem); margin: 0 0 18px; line-height: 1.1; }
.cap { display: inline-flex; align-items: center; gap: 0.45em; font-family: var(--sans); font-size: 0.74rem; letter-spacing: 0.04em; padding: 0.5em 0.95em; margin-bottom: 22px; }
.cap--lim { background: #F4EADB; color: #8A5A1A; }
.cap--amp { background: #E7EFE2; color: #3B6D2E; }
.comp-line { color: var(--muted); font-size: 0.98rem; line-height: 1.7; margin-bottom: 28px; max-width: 42ch; }
.mesa-info .btn { padding: 1em 2.1em; }

/* ---------- Constructor "Armá tu mesa" ---------- */
.builder { display: grid; grid-template-columns: 320px 1fr; gap: 40px; align-items: start; max-width: 940px; margin: 0 auto; }
.builder__preview { position: relative; height: 360px; background: var(--bg-2); border: 1px solid var(--line); overflow: hidden; }
.builder__preview .plate { position: absolute; top: 48%; left: 50%; transform: translate(-50%, -50%); border-radius: 50%; border-style: solid; }
.builder__preview .util { position: absolute; background: #D8CFBF; border-radius: 6px; }
.builder__preview .glass { position: absolute; border: 1px solid #D8CFBF; border-radius: 50%; }
.bgroup { margin-bottom: 24px; }
.bgroup__label { font-family: var(--serif); font-size: 1.25rem; margin-bottom: 2px; }
.bgroup__hint { font-size: 0.78rem; color: var(--muted); margin-bottom: 14px; }
.bsw-row { display: flex; flex-wrap: wrap; gap: 12px; }
.bsw { display: flex; flex-direction: column; align-items: center; width: 72px; cursor: pointer; background: none; border: 0; padding: 4px; }
.bsw .chip { width: 34px; height: 34px; border-radius: 50%; border-width: 2px; border-style: solid; }
.bsw.sel .chip { box-shadow: 0 0 0 2px var(--bg), 0 0 0 4px var(--ink); }
.bsw .nm { font-size: 0.72rem; color: var(--muted); text-align: center; line-height: 1.25; margin-top: 7px; }
.bsw .st { font-size: 0.7rem; margin-top: 2px; }
.builder__summary { max-width: 940px; margin: 30px auto 0; border-top: 1px solid var(--line); padding-top: 22px; display: flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap; }
.bsum-name { font-family: var(--serif); font-size: 1.3rem; }
.bsum-meta { font-size: 0.86rem; color: var(--muted); margin-top: 5px; }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .mods { grid-template-columns: 1fr; }
  .mesa-band { padding: 40px 0; }
  .mesa-feat, .mesa-band:nth-child(even) .mesa-feat { grid-template-columns: 1fr; gap: 22px; }
  .mesa-band:nth-child(even) .mesa-gallery, .mesa-band:nth-child(even) .mesa-info { order: 0; }
  .builder { grid-template-columns: 1fr; gap: 26px; }
  .builder__preview { height: 320px; }
}

/* ---------- Responsive (base) ---------- */
@media (max-width: 900px) {
  .values { grid-template-columns: 1fr; gap: 44px; }
  .collections { grid-template-columns: repeat(2, 1fr); }
  .stock-row, .catalog-grid { grid-template-columns: repeat(2, 1fr); }
  .lookbook { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .lookbook .photo:nth-child(1) { grid-row: auto; aspect-ratio: 16/10; }
  .lookbook .photo { aspect-ratio: 4/3; }
  .pro__grid { grid-template-columns: 1fr; gap: 38px; padding-top: 70px; padding-bottom: 70px; }
  .pro__grid > div:last-child { order: -1; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .nav__links { display: none; }
  .nav__links.open { display: flex; position: absolute; top: 80px; left: 0; right: 0; flex-direction: column; align-items: flex-start; background: var(--bg); border-bottom: 1px solid var(--line); padding: 22px 32px; gap: 18px; }
  .nav__toggle { display: block; }
  .section { padding: 76px 0; }
  .hero__media { min-height: 70vh; }
}
@media (max-width: 920px) { .collections { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) {
  .stock-row, .catalog-grid { grid-template-columns: 1fr; }
  .collections { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
}

/* ---------- Catálogo: galería, visor, piezas, badge, filtro tipo ---------- */
.filters--tipo { margin-top: 8px; }
.mix-badge { position: absolute; top: 8px; left: 8px; background: rgba(44,62,80,.85); color: #fff; font-size: 10px; letter-spacing: .05em; text-transform: uppercase; padding: 3px 8px; border-radius: 20px; z-index: 2; }
.piezas { display: flex; flex-wrap: wrap; gap: 4px 14px; margin-top: 9px; }
.pieza { font-size: 12.5px; color: #6a6256; white-space: nowrap; }
.pieza b { color: #2c3e50; font-weight: 600; }
.gnav { position: absolute; top: 50%; transform: translateY(-50%); width: 34px; height: 46px; border: 0; background: none; color: #fff; font-size: 30px; line-height: 1; padding: 0; cursor: pointer; opacity: .7; text-shadow: 0 1px 5px rgba(0,0,0,.45); transition: opacity .15s; outline: none; -webkit-tap-highlight-color: transparent; }
.gnav:hover { opacity: 1; }
.gnav:focus, .gnav:focus-visible { outline: none; }
.gprev { left: 4px; } .gnext { right: 4px; }
.gdots { position: absolute; bottom: 9px; left: 0; right: 0; display: flex; gap: 5px; justify-content: center; pointer-events: none; }
.gdots i { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,.55); box-shadow: 0 0 2px rgba(0,0,0,.35); }
.gdots i.on { background: #fff; }
.lb { position: fixed; inset: 0; background: rgba(22,20,17,.93); z-index: 200; display: flex; align-items: center; justify-content: center; }
.lb[hidden] { display: none; }
.lb__img { max-width: 88vw; max-height: 82vh; object-fit: contain; border-radius: 4px; box-shadow: 0 12px 50px rgba(0,0,0,.5); }
.lb__close { position: absolute; top: 16px; right: 24px; font-size: 34px; line-height: 1; color: #fff; background: none; border: 0; cursor: pointer; }
.lb__nav { position: absolute; top: 50%; transform: translateY(-50%); font-size: 46px; line-height: 1; color: #fff; background: none; border: 0; cursor: pointer; padding: 10px 18px; opacity: .75; }
.lb__nav:hover { opacity: 1; }
.lb__prev { left: 6px; } .lb__next { right: 6px; }
.lb__cap { position: absolute; bottom: 22px; left: 0; right: 0; text-align: center; color: #fff; font-size: 13px; letter-spacing: .05em; }

/* ---------- Animaciones sutiles ---------- */
html { scroll-behavior: smooth; }
section[id], #mesasGrid { scroll-margin-top: 92px; }
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1); }
.reveal.in { opacity: 1; transform: none; }
.nav { transition: box-shadow .35s ease, background .35s ease; }
.nav.scrolled { box-shadow: 0 8px 28px -16px rgba(0,0,0,.22); }
.col-card .photo { transition: transform .6s cubic-bezier(.22,.61,.36,1); }
.col-card:hover .photo { transform: scale(1.05); }
.product { transition: transform .25s ease, box-shadow .25s ease; }
.product:hover { transform: translateY(-3px); box-shadow: 0 18px 44px -28px rgba(0,0,0,.45); }
.btn { transition: background .25s ease, color .25s ease, transform .2s ease; }
.btn:hover { transform: translateY(-1px); }
.mesa-main { transition: opacity .45s ease; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .col-card:hover .photo, .product:hover, .btn:hover { transform: none; }
}

/* ============================================================
   Página de producto (PDP) + tags + "Combiná con"
   ============================================================ */
.pdp { padding: 40px 20px 80px; }
.pdp-crumbs { font-family: var(--sans); font-size: .72rem; letter-spacing: .04em; color: var(--muted); margin-bottom: 26px; }
.pdp-crumbs a { color: var(--muted); text-decoration: none; }
.pdp-crumbs a:hover { color: var(--ink); }
.pdp-crumbs span { color: var(--ink); }

.pdp-top { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(0,.95fr); gap: 54px; align-items: start; }

/* galería */
.pdp-gallery { position: sticky; top: 90px; }
.pdp-main { position: relative; aspect-ratio: 1/1; background: var(--bg-3) center/cover no-repeat; border: 1px solid var(--line); }
.pdp-main--empty { display: flex; align-items: center; justify-content: center; }
.pdp-main--empty svg { width: 86px; height: 86px; stroke: var(--muted); opacity: .5; }
.pdp-main .gnav { position: absolute; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; border: 0; background: rgba(255,255,255,.82); color: var(--ink); font-size: 1.5rem; cursor: pointer; border-radius: 50%; box-shadow: 0 4px 16px rgba(0,0,0,.12); }
.pdp-main .gprev { left: 14px; } .pdp-main .gnext { right: 14px; }
.pdp-thumbs { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.pdp-thumb { width: 70px; height: 70px; border: 1px solid var(--line); background: var(--bg-3) center/cover no-repeat; cursor: pointer; padding: 0; opacity: .65; transition: opacity .2s; }
.pdp-thumb.on, .pdp-thumb:hover { opacity: 1; outline: 2px solid var(--accent); outline-offset: -2px; }

/* info */
.pdp-info .eyebrow { display: block; }
.pdp-name { font-family: var(--serif); font-size: 2.4rem; line-height: 1.1; margin: 6px 0 16px; }
.pdp-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.tag-chip { font-family: var(--sans); font-size: .68rem; letter-spacing: .06em; text-transform: lowercase; color: var(--muted); background: var(--bg-2); border: 1px solid var(--line); padding: 5px 12px; border-radius: 100px; text-decoration: none; transition: all .2s; }
.tag-chip:hover { color: #fff; background: var(--accent); border-color: var(--accent); }

.pdp-spec { border-top: 1px solid var(--line); margin: 0 0 24px; }
.pdp-spec > div { display: flex; justify-content: space-between; gap: 20px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.pdp-spec dt { font-family: var(--sans); font-size: .74rem; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin: 0; }
.pdp-spec dd { margin: 0; text-align: right; color: var(--ink); font-size: .95rem; }

.pdp-stock-wrap { margin-bottom: 26px; }
.pdp-stock__label { font-family: var(--sans); font-size: .74rem; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.pdp-stock { margin-top: 10px; }
.pdp-stock__row { display: flex; justify-content: space-between; align-items: baseline; padding: 9px 0; border-bottom: 1px dotted var(--line); }
.pdp-stock__row span { color: var(--ink); }
.pdp-stock__row b { font-family: var(--serif); font-size: 1.3rem; color: var(--accent); }

.pdp-desc { color: var(--muted); line-height: 1.7; margin: 0 0 28px; }
.pdp-cta { display: inline-block; }

/* combiná con */
.pdp-combina { margin-top: 52px; padding: 32px 32px 36px; background: var(--sand, #faf8f4); border: 1px solid var(--line); border-radius: 16px; }
.pdp-combina__title { font-family: var(--serif); font-size: 1.2rem; margin-bottom: 6px; }
.pdp-combina__sub { font-family: var(--sans); font-size: .82rem; color: var(--muted); margin: 0 0 20px; }
.combo-row { display: flex; gap: 16px; overflow-x: auto; padding-bottom: 8px; scroll-snap-type: x mandatory; }
.combo-card { flex: 0 0 148px; scroll-snap-align: start; text-decoration: none; color: inherit; }
.combo-card__img { aspect-ratio: 1/1; background: #fff center/cover no-repeat; border: 1px solid var(--line); border-radius: 12px; display: flex; align-items: center; justify-content: center; transition: transform .3s, box-shadow .3s; box-shadow: 0 2px 12px -7px rgba(0,0,0,.25); }
.combo-card__img svg { width: 50px; height: 50px; stroke: var(--muted); opacity: .5; }
.combo-card:hover .combo-card__img { transform: translateY(-4px); box-shadow: 0 16px 38px -22px rgba(0,0,0,.45); }
.combo-card__name { font-family: var(--sans); font-size: .82rem; margin-top: 10px; text-align: center; color: var(--ink); }

.pdp-empty { text-align: center; padding: 80px 20px; }
.pdp-empty h2 { font-family: var(--serif); font-size: 1.8rem; margin-bottom: 10px; }
.pdp-empty p { color: var(--muted); margin-bottom: 22px; }

/* filtro por tag (catálogo) */
.tag-active { display: flex; align-items: center; justify-content: center; gap: 10px; font-family: var(--sans); font-size: .8rem; color: var(--muted); margin: 0 auto 22px; }
.tag-active b { color: var(--accent); }
.tag-active a { color: var(--muted); text-decoration: underline; }

@media (max-width: 820px){
  .pdp-top { grid-template-columns: 1fr; gap: 30px; }
  .pdp-gallery { position: static; }
  .pdp-name { font-size: 2rem; }
}

.product--link { cursor: pointer; }
.product--link:hover { transform: translateY(-3px); box-shadow: 0 20px 44px -30px rgba(0,0,0,.4); transition: transform .3s, box-shadow .3s; }

/* ---- Filtros por tag (facetas) en el catálogo ---- */
.filters-tags { display: flex; flex-direction: column; gap: 10px; max-width: 760px; margin: 18px auto 0; }
.tagfacet { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.tagfacet__label { font-family: var(--sans); font-size: .64rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); width: 74px; text-align: right; flex: 0 0 74px; }
.tagchip { font-family: var(--sans); font-size: .72rem; letter-spacing: .04em; text-transform: lowercase; color: var(--muted); background: var(--bg); border: 1px solid var(--line); padding: 5px 13px; border-radius: 100px; cursor: pointer; transition: all .2s; }
.tagchip:hover { border-color: var(--accent); color: var(--ink); }
.tagchip.is-on { background: var(--accent); border-color: var(--accent); color: #fff; }
.tagclear { align-self: center; margin-top: 4px; font-family: var(--sans); font-size: .7rem; letter-spacing: .04em; color: var(--muted); background: transparent; border: 0; cursor: pointer; text-decoration: underline; }
.tagclear:hover { color: var(--ink); }
@media (max-width: 560px){
  .tagfacet__label { width: 100%; text-align: left; flex-basis: 100%; }
}

/* ---- Toolbar + botón Filtros + panel lateral (drawer) ---- */
.cat-toolbar { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 14px; margin-top: 4px; }
.filters-btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--sans); font-size: .78rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink); background: var(--bg); border: 1px solid var(--ink); padding: 9px 18px; border-radius: 100px; cursor: pointer; transition: all .2s; }
.filters-btn:hover { background: var(--ink); color: #fff; }
.filters-btn svg { display: block; }
.filters-btn__count { display: inline-flex; align-items: center; justify-content: center; min-width: 19px; height: 19px; padding: 0 5px; border-radius: 100px; background: var(--accent); color: #fff; font-size: .68rem; letter-spacing: 0; }
.filters-btn:hover .filters-btn__count { background: #fff; color: var(--ink); }

.drawer { position: fixed; inset: 0; z-index: 1000; }
.drawer[hidden] { display: none; }
.drawer__backdrop { position: absolute; inset: 0; background: rgba(20,18,16,.42); opacity: 0; transition: opacity .28s ease; }
.drawer__panel { position: absolute; top: 0; right: 0; height: 100%; width: 340px; max-width: 86vw; background: var(--bg); box-shadow: -20px 0 60px -30px rgba(0,0,0,.5); transform: translateX(100%); transition: transform .28s cubic-bezier(.22,.61,.36,1); display: flex; flex-direction: column; }
.drawer.is-open .drawer__backdrop { opacity: 1; }
.drawer.is-open .drawer__panel { transform: translateX(0); }
.drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 22px 24px; border-bottom: 1px solid var(--line); }
.drawer__head h3 { font-family: var(--serif); font-size: 1.4rem; }
.drawer__close { background: none; border: 0; font-size: 1.9rem; line-height: 1; color: var(--muted); cursor: pointer; }
.drawer__close:hover { color: var(--ink); }
.drawer__body { flex: 1; overflow-y: auto; padding: 26px 24px; }
.drawer__foot { display: flex; gap: 12px; padding: 16px 24px; border-top: 1px solid var(--line); }
.drawer__foot .btn { flex: 1; text-align: center; padding: 12px; }
.drawer .filters-tags { max-width: none; margin: 0; gap: 24px; }
.drawer .tagfacet { flex-direction: column; align-items: flex-start; gap: 10px; }
.drawer .tagfacet__label { width: auto; flex: none; text-align: left; }

.filters-btn__count[hidden] { display: none; }

/* ============================================================
   Carrito "Solicitud de presupuesto"
   ============================================================ */
/* enlace + badge en el nav */
.nav__cart { position: relative; display: inline-flex; align-items: center; gap: 7px; }
.nav__cart-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 18px; height: 18px; padding: 0 5px; border-radius: 100px; background: var(--accent); color: #fff; font-size: .66rem; font-family: var(--sans); }

/* botón "+ Agregar a solicitud" en tarjetas del catálogo */
.card-add { width: 100%; margin-top: 14px; padding: 9px 10px; font-family: var(--sans); font-size: .72rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink); background: var(--bg); border: 1px solid var(--line); cursor: pointer; transition: all .2s; }
.card-add:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.card-add.is-added { background: #3B6D2E; border-color: #3B6D2E; color: #fff; }

/* acciones en la página de producto */
.pdp-actions { display: flex; gap: 12px; align-items: stretch; margin-bottom: 12px; }
.pdp-qty { display: inline-flex; align-items: center; border: 1px solid var(--line); }
.pdp-qty button { width: 38px; border: 0; background: var(--bg); font-size: 1.1rem; cursor: pointer; color: var(--ink); }
.pdp-qty button:hover { background: var(--bg-2); }
.pdp-qty input { width: 46px; text-align: center; border: 0; border-left: 1px solid var(--line); border-right: 1px solid var(--line); font-family: var(--sans); font-size: .95rem; -moz-appearance: textfield; }
.pdp-qty input::-webkit-outer-spin-button, .pdp-qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.pdp-cta { flex: 1; }
.pdp-cta.is-added { background: #3B6D2E; border-color: #3B6D2E; }
.pdp-wa { display: inline-block; font-family: var(--sans); font-size: .8rem; color: var(--muted); text-decoration: none; }
.pdp-wa:hover { color: var(--ink); text-decoration: underline; }

/* página Mi solicitud */
.sol { padding: 44px 20px 80px; }
.sol__title { font-family: var(--serif); font-size: 2.4rem; }
.sol__grid { display: grid; grid-template-columns: 1fr 340px; gap: 40px; align-items: start; }
.sol__item { display: grid; grid-template-columns: 84px 1fr auto auto; gap: 16px; align-items: center; padding: 16px 0; border-bottom: 1px solid var(--line); }
.sol__thumb { width: 84px; height: 84px; background: var(--bg-3) center/cover no-repeat; border: 1px solid var(--line); }
.sol__name { font-family: var(--serif); font-size: 1.15rem; color: var(--ink); text-decoration: none; }
.sol__name:hover { text-decoration: underline; }
.sol__meta { font-family: var(--sans); font-size: .72rem; letter-spacing: .04em; color: var(--muted); margin: 3px 0; }
.sol__pieces { font-family: var(--sans); font-size: .76rem; color: var(--muted); }
.sol__qty { display: flex; flex-direction: column; align-items: center; gap: 3px; }
.sol__qty label { font-family: var(--sans); font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.sol__qty input { width: 58px; text-align: center; padding: 7px; border: 1px solid var(--line); font-family: var(--sans); }
.sol__remove { width: 34px; height: 34px; border: 0; background: none; font-size: 1.5rem; color: var(--muted); cursor: pointer; line-height: 1; }
.sol__remove:hover { color: #b5483f; }
.sol__empty { text-align: center; padding: 60px 20px; }
.sol__empty p { color: var(--muted); margin-bottom: 20px; }

.sol__form-wrap { position: sticky; top: 90px; }
.sol__form { background: var(--bg-2); border: 1px solid var(--line); padding: 26px 24px; display: flex; flex-direction: column; gap: 14px; }
.sol__form h3 { font-family: var(--serif); font-size: 1.3rem; margin-bottom: 4px; }
.sol__form label { display: flex; flex-direction: column; gap: 5px; font-family: var(--sans); font-size: .74rem; letter-spacing: .04em; color: var(--muted); }
.sol__form input, .sol__form textarea { font-family: var(--sans); font-size: .95rem; color: var(--ink); padding: 10px 12px; border: 1px solid var(--line); background: var(--bg); }
.sol__form input:focus, .sol__form textarea:focus { outline: none; border-color: var(--accent); }
.sol__form .btn { margin-top: 6px; text-align: center; padding: 13px; }
.sol__hint { font-family: var(--sans); font-size: .72rem; color: var(--muted); text-align: center; line-height: 1.5; }

@media (max-width: 820px){
  .sol__grid { grid-template-columns: 1fr; gap: 28px; }
  .sol__form-wrap { position: static; }
  .sol__item { grid-template-columns: 64px 1fr auto; grid-template-areas: "t i r" "t q q"; }
  .sol__thumb { grid-area: t; width: 64px; height: 64px; }
  .sol__remove { grid-area: r; }
  .sol__qty { grid-area: q; flex-direction: row; justify-content: flex-start; margin-top: 6px; }
}

/* ============================================================
   v10 — Carrito por pieza · ícono nav · vista rápida (modal)
   ============================================================ */
/* nav: un poco menos de gap para que entre el carrito */
.nav__links { gap: 26px; }
.nav__cart { position: relative; display: inline-flex; align-items: center; color: var(--muted); }
.nav__cart:hover { color: var(--ink); }
.nav__cart-badge { position: absolute; top: -7px; right: -10px; min-width: 17px; height: 17px; padding: 0 4px; display: inline-flex; align-items: center; justify-content: center; border-radius: 100px; background: var(--accent); color: #fff; font-size: .62rem; font-family: var(--sans); }

/* selector "Agregar a mi solicitud" por pieza */
.qadd { border: 1px solid var(--line); padding: 18px 18px 20px; margin: 6px 0 14px; background: var(--bg-2); }
.qadd-title { font-family: var(--sans); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; }
.qadd-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 7px 0; }
.qadd-lbl { font-family: var(--sans); font-size: .9rem; color: var(--ink); }
.qadd-lbl small { color: var(--muted); font-size: .72rem; margin-left: 4px; }
.qadd-qty { width: 72px; text-align: center; padding: 8px; border: 1px solid var(--line); background: var(--bg); font-family: var(--sans); font-size: .95rem; }
.qadd-btn { width: 100%; margin-top: 12px; text-align: center; padding: 12px; }
.qadd-btn.is-added { background: #3B6D2E; border-color: #3B6D2E; }

/* vista rápida (modal) */
.qv { position: fixed; inset: 0; z-index: 1100; }
.qv[hidden] { display: none; }
.qv__backdrop { position: absolute; inset: 0; background: rgba(20,18,16,.5); opacity: 0; transition: opacity .26s ease; }
.qv.is-open .qv__backdrop { opacity: 1; }
.qv__panel { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -46%); width: 960px; max-width: 94vw; max-height: 90vh; overflow: hidden; background: var(--bg); box-shadow: 0 30px 90px -30px rgba(0,0,0,.6); opacity: 0; transition: opacity .26s ease, transform .26s cubic-bezier(.22,.61,.36,1); display: flex; flex-direction: column; }
.qv.is-open .qv__panel { opacity: 1; transform: translate(-50%, -50%); }
.qv__close { position: absolute; top: 14px; right: 16px; z-index: 2; width: 38px; height: 38px; border: 0; border-radius: 50%; background: rgba(255,255,255,.85); font-size: 1.6rem; line-height: 1; color: var(--ink); cursor: pointer; box-shadow: 0 4px 16px rgba(0,0,0,.12); }
.qv__close:hover { background: #fff; }
.qv__body { overflow-y: auto; padding: 34px 36px 40px; }
.qv__body .pdp-gallery { position: static; }
.qv__body .pdp-top { gap: 36px; }
.qv__body .pdp-name { font-size: 2rem; }
.qv__body .pdp-combina { margin-top: 40px; padding-top: 30px; }

/* solicitud: líneas por pieza dentro de cada item */
.sol__item { grid-template-columns: 84px 1fr auto; }
.sol__lineas { margin-top: 8px; display: flex; flex-direction: column; gap: 6px; }
.sol__linea { display: flex; align-items: center; justify-content: space-between; gap: 12px; max-width: 280px; }
.sol__linea span { font-family: var(--sans); font-size: .82rem; color: var(--ink); }
.sol__linea input { width: 66px; text-align: center; padding: 6px; border: 1px solid var(--line); font-family: var(--sans); }

@media (max-width: 600px){
  .qv__body { padding: 26px 18px 30px; }
  .qv__body .pdp-name { font-size: 1.7rem; }
}

/* aviso "elegí una cantidad" */
.qadd--error { border-color: #c0564d; box-shadow: 0 0 0 3px rgba(192,86,77,.12); transition: box-shadow .2s, border-color .2s; }
.qadd--error .qadd-qty { border-color: #c0564d; }

/* ============================================================
   v13 — Galería al hover + productos en Mesas curadas
   ============================================================ */
/* fade suave de la galería de tarjetas al pasar el mouse */
.product .photo.has-gal { transition: opacity .16s ease, transform .6s cubic-bezier(.22,.61,.36,1); }

/* "En esta mesa" — productos relacionados */
.mesa-prods { margin-top: 44px; padding-top: 30px; border-top: 1px solid var(--line); }
.mesa-prods__t { display: block; font-family: var(--sans); font-size: .66rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin-bottom: 16px; }
.mesa-prods__row { display: flex; gap: 14px; overflow-x: auto; padding-bottom: 6px; scroll-snap-type: x mandatory; }
.mesa-prods__row::-webkit-scrollbar { height: 5px; }
.mesa-prods__row::-webkit-scrollbar-thumb { background: var(--line); border-radius: 100px; }
.mprod { flex: 0 0 96px; scroll-snap-align: start; text-decoration: none; color: inherit; }
.mprod__img { display: block; width: 96px; height: 96px; background: var(--bg-3) center/cover no-repeat; border: 1px solid var(--line); transition: transform .3s, box-shadow .3s; }
.mprod:hover .mprod__img { transform: translateY(-3px); box-shadow: 0 14px 30px -18px rgba(0,0,0,.5); }
.mprod__n { display: block; font-family: var(--sans); font-size: .68rem; line-height: 1.3; color: var(--ink); margin-top: 7px; text-align: center; }

/* solicitud: particular/profesional + nota de stock */
.sol__tipo { border: 1px solid var(--line); padding: 12px 14px; display: flex; flex-direction: column; gap: 9px; margin: 2px 0; }
.sol__tipo legend { font-family: var(--sans); font-size: .74rem; letter-spacing: .04em; color: var(--muted); padding: 0 4px; }
.sol__radio { display: flex; align-items: center; gap: 8px; font-family: var(--sans); font-size: .92rem; color: var(--ink); cursor: pointer; }
.sol__radio input { width: auto; margin: 0; }
.sol__radio small { color: var(--muted); }
.sol__linea small { color: var(--muted); font-size: .68rem; }

/* ===== Carrito en la barra superior (siempre visible, también en mobile) ===== */
.nav__inner > .brand { margin-right: auto; }
.nav__inner { gap: 22px; }
.nav__cart { color: var(--muted); }
.nav__cart:hover { color: var(--ink); }

/* ===== Solicitud: quitar una pieza (×) y resumen con subtotales ===== */
.sol__linea-ctrl { display: inline-flex; align-items: center; gap: 8px; }
.sol__linea-rm { background: none; border: 0; color: var(--muted); font-size: 1.05rem; line-height: 1; cursor: pointer; padding: 2px 6px; border-radius: 6px; transition: color .15s, background .15s; }
.sol__linea-rm:hover { color: var(--accent); background: rgba(0,0,0,.05); }
.sol__resumen { margin-top: 22px; padding: 18px 20px; background: var(--sand, #faf8f4); border: 1px solid var(--line); border-radius: 12px; }
.sol__resumen h3 { margin: 0 0 12px; font-family: var(--serif, 'Playfair Display', serif); font-size: 1rem; }
.sol__sub-row { display: flex; justify-content: space-between; align-items: center; padding: 6px 0; font-size: .9rem; }
.sol__sub-row b { font-weight: 600; }
.sol__sub-total { border-top: 1px solid var(--line); margin-top: 6px; padding-top: 12px; font-size: .98rem; }

/* ===== Compartir: modelo, foto y búsqueda ===== */
.pdp-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 14px; }
.pdp-share { font-family: var(--sans); font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink); background: none; border: 1px solid var(--line); border-radius: 100px; padding: 9px 16px; cursor: pointer; transition: border-color .2s, color .2s, background .2s; }
.pdp-share:hover { border-color: var(--ink); background: var(--ink); color: #fff; }
.pdp-main { position: relative; }
.pdp-share-img { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; border-radius: 50%; border: 0; background: rgba(255,255,255,.92); color: var(--ink); font-size: 1.05rem; line-height: 1; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; box-shadow: 0 2px 8px rgba(0,0,0,.12); transition: background .2s, transform .15s; }
.pdp-share-img:hover { background: #fff; transform: translateY(-1px); }
#catShare { white-space: nowrap; }

/* ===== Vista rápida: "Ver completo" (expandir a página) ===== */
.qv__panel { position: relative; }
.qv__expand { position: absolute; top: 14px; left: 18px; z-index: 4; font-family: var(--sans); font-size: .74rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: #fff; background: var(--ink); text-decoration: none; display: inline-flex; align-items: center; gap: 6px; padding: 11px 20px; border-radius: 100px; box-shadow: 0 6px 18px -8px rgba(0,0,0,.5); transition: background .2s, transform .2s; }
.qv__expand:hover { background: var(--accent); transform: translateY(-1px); }
@media (max-width: 620px){ .qv__expand { font-size: .68rem; padding: 9px 15px; } }

/* ===== Segunda galería: Inspiración / en la mesa ===== */
/* 2 · EN LA MESA: momento grande, editorial (clima del evento) */
.pdp-insp { margin-top: 70px; }
.pdp-insp__title { font-family: var(--serif, 'Playfair Display', serif); font-size: 1.7rem; margin: 0 0 20px; }
.pdp-insp__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px; }
.pdp-insp__item { display: block; aspect-ratio: 4/3; background-size: cover; background-position: center; border-radius: 12px; transition: transform .2s, box-shadow .2s; }
.pdp-insp__item:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(0,0,0,.14); }
@media (max-width: 560px){ .pdp-insp__grid { grid-template-columns: repeat(2, 1fr); } }

/* ===== Galería principal MÁS GRANDE y nítida (ver todas las combinaciones de un vistazo) ===== */
/* 1 · PRODUCTO: la galería domina (es lo primero que mira el ojo) */
.pdp-top { grid-template-columns: minmax(0,1.95fr) minmax(0,.72fr); gap: 44px; }
.pdp-thumbs { gap: 12px; margin-top: 16px; }
.pdp-thumb { width: 104px; height: 104px; opacity: .8; }
.qv__body .pdp-top { grid-template-columns: minmax(0,1.7fr) minmax(0,.8fr); }
@media (max-width: 880px){ .pdp-top { grid-template-columns: 1fr; } .pdp-thumb { width: 92px; height: 92px; } }

/* eyebrow de cada sección (propuesta de recorrido) */
.pdp-insp .eyebrow, .pdp-combina .eyebrow { display: block; margin-bottom: 8px; }

/* la sección Inspiración ahora es botón (visor), no enlace */
.pdp-insp__item { border: 0; padding: 0; cursor: pointer; }

/* ===== Visor (lightbox) de la galería de Inspiración ===== */
.pdplb { position: fixed; inset: 0; z-index: 1000; background: rgba(20,18,16,.92); display: flex; align-items: center; justify-content: center; }
.pdplb[hidden] { display: none; }
.pdplb__img { max-width: 88vw; max-height: 86vh; object-fit: contain; border-radius: 6px; box-shadow: 0 12px 50px rgba(0,0,0,.5); }
.pdplb__close { position: absolute; top: 22px; right: 26px; width: 46px; height: 46px; border: 0; border-radius: 50%; background: rgba(255,255,255,.14); color: #fff; font-size: 1.7rem; line-height: 1; cursor: pointer; }
.pdplb__close:hover { background: rgba(255,255,255,.26); }
.pdplb__nav { position: absolute; top: 50%; transform: translateY(-50%); width: 54px; height: 54px; border: 0; border-radius: 50%; background: rgba(255,255,255,.14); color: #fff; font-size: 2rem; line-height: 1; cursor: pointer; }
.pdplb__nav:hover { background: rgba(255,255,255,.26); }
.pdplb__prev { left: 24px; } .pdplb__next { right: 24px; }
.pdplb__count { position: absolute; bottom: 24px; left: 0; right: 0; text-align: center; color: rgba(255,255,255,.85); font-family: var(--sans); font-size: .8rem; letter-spacing: .08em; }
@media (max-width: 560px){ .pdplb__nav { width: 44px; height: 44px; font-size: 1.6rem; } .pdplb__prev { left: 10px; } .pdplb__next { right: 10px; } .pdplb__img { max-width: 94vw; } }

/* ===== Tea Party (landing para anuncios) ===== */
.tp-hero { position: relative; min-height: 62vh; display: flex; align-items: flex-end; overflow: hidden; }
.tp-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.tp-hero__bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(30,20,25,.12), rgba(30,20,25,.6)); }
.tp-hero__inner { position: relative; z-index: 2; padding: 64px 0; max-width: 640px; color: #fff; }
.tp-hero__inner .eyebrow { color: rgba(255,255,255,.85); }
.tp-hero__inner h1 { font-family: var(--serif, 'Playfair Display', serif); font-size: clamp(2.6rem, 6vw, 4.4rem); line-height: 1.02; margin: 10px 0 14px; color: #fff; }
.tp-hero__inner .lead { color: rgba(255,255,255,.94); }
.tp-hero__inner .btn { margin-top: 24px; }
.tp-gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 16px; }
.tp-gallery__item { aspect-ratio: 4/3; background-size: cover; background-position: center; border-radius: 12px; }
@media (max-width: 560px){ .tp-hero { min-height: 52vh; } .tp-hero__inner { padding: 40px 0; } }

/* ===== Tope de stock (ficha): aviso claro + botón "Agregar" bloqueado ===== */
.qadd-row--over .qadd-qty { border-color: #c0564d; box-shadow: 0 0 0 2px rgba(192,86,77,.20); outline: none; }
.qadd-row--over .qadd-lbl small { color: #c0564d; font-weight: 600; font-size: .82rem; }
.qadd-btn--block { opacity: .5; cursor: not-allowed; }
.qadd-btn--block:hover { background: var(--ink); color: #fff; }

/* ===== Botón "Volver" (página de producto) ===== */
.pdp-back { display: inline-flex; align-items: center; gap: 6px; background: none; border: 1px solid var(--line); border-radius: 100px; padding: 8px 16px; font-family: var(--sans); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); cursor: pointer; margin-bottom: 18px; transition: color .2s, border-color .2s; }
.pdp-back:hover { color: var(--ink); border-color: var(--ink); }

/* ===== Chips de la ficha flotante (avisan y llevan a las secciones de abajo) ===== */
.pdp-jump { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 18px; }
.pdp-jump button { background: var(--sand, #faf8f4); border: 1px solid var(--line); border-radius: 100px; padding: 9px 15px; font-family: var(--sans); font-size: .72rem; letter-spacing: .05em; color: var(--ink); cursor: pointer; transition: background .2s, border-color .2s; }
.pdp-jump button:hover { background: var(--bg-3); border-color: var(--muted); }

/* ===== Vista rápida: CTA a la ficha completa (mesas + combinaciones) ===== */
.pdp-more { display: flex; flex-direction: column; align-items: center; gap: 3px; margin-top: 18px; padding: 14px 18px; border: 1px solid var(--ink); border-radius: 12px; text-align: center; transition: background .2s, color .2s; }
.pdp-more b { font-family: var(--sans); font-weight: 500; font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; }
.pdp-more small { font-family: var(--sans); font-size: .72rem; color: var(--muted); }
.pdp-more:hover { background: var(--ink); color: #fff; }
.pdp-more:hover small { color: rgba(255,255,255,.82); }

/* ===== Botón "Vista rápida" sobre la foto (aparece al pasar el mouse) ===== */
.qv-btn { position: absolute; left: 50%; bottom: 16px; transform: translateX(-50%) translateY(6px); background: rgba(255,255,255,.95); color: var(--ink); border: 0; border-radius: 100px; padding: 10px 20px; font-family: var(--sans); font-size: .66rem; letter-spacing: .16em; text-transform: uppercase; cursor: pointer; opacity: 0; box-shadow: 0 6px 18px rgba(0,0,0,.16); transition: opacity .2s, transform .2s, background .2s; z-index: 3; }
.photo:hover .qv-btn { opacity: 1; transform: translateX(-50%) translateY(0); }
.qv-btn:hover { background: #fff; }
@media (hover: none) { .qv-btn { opacity: 1; transform: translateX(-50%); bottom: 12px; padding: 8px 16px; } }

/* ===== "En la mesa" + "Combiná con" ahora en la columna derecha (visibles sin scroll largo) ===== */
.pdp-info .pdp-insp { margin-top: 30px; }
.pdp-info .pdp-insp__title { font-size: 1.12rem; margin: 0 0 12px; }
.pdp-info .pdp-insp__grid { grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: 10px; }
.pdp-info .pdp-insp__item { aspect-ratio: 1/1; border-radius: 10px; }
.pdp-info .pdp-combina { margin-top: 26px; padding: 22px 22px 24px; }
.pdp-info .pdp-combina__title { font-size: 1.08rem; }
.pdp-info .combo-card { flex: 0 0 124px; }
@media (max-width: 880px){ .pdp-info .pdp-insp__grid { grid-template-columns: repeat(3, 1fr); } }

/* ===== Galería: foto PRINCIPAL más chica + MINIATURAS (combinaciones) MÁS GRANDES ===== */
.pdp-top { grid-template-columns: minmax(0,1.15fr) minmax(0,.95fr); gap: 40px; }
.pdp-thumbs { gap: 14px; margin-top: 16px; }
.pdp-thumb { width: 158px; height: 158px; opacity: .82; }
.pdp-thumb.on, .pdp-thumb:hover { opacity: 1; }
.qv__body .pdp-top { grid-template-columns: minmax(0,1.2fr) minmax(0,.95fr); }
@media (max-width: 880px){ .pdp-top { grid-template-columns: 1fr; } .pdp-thumb { width: 120px; height: 120px; } }

/* "En la mesa" full-width y protagonista (ya no en la columna) */
.pdp-insp { margin-top: 64px; }
.pdp-insp__title { font-size: 1.7rem; margin: 0 0 20px; }
.pdp-insp__grid { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }
.pdp-insp__item { aspect-ratio: 4/3; border-radius: 12px; }

/* ===== Tea Party header: panel con los neutros cálidos del sitio para que integre con la foto ===== */
.hero--tp .hero__panel { background: linear-gradient(135deg, var(--bg-2) 0%, var(--bg-3) 100%); }
.hero--tp .hero__photo { box-shadow: -18px 0 40px -30px rgba(0,0,0,.28); }
@media (max-width: 860px){ .hero--tp .hero__panel { background: linear-gradient(180deg, var(--bg-2), var(--bg-3)); } }
