/* =====================================================================
   CARVAN PREMIUM MARKET · v2 — Almacén premium con alma editorial
   Paleta hueso cálida + tinta carbón + rojo CARVAN. Tipografía editorial.
   ===================================================================== */
:root{
  --bone:#F3EEE4; --bone-2:#EAE3D6; --paper:#FBF9F3; --ink:#1B1714; --ink-soft:#5d5349;
  --red:#B31217;--red-bright:#DF161D; --red-deep:#8d0e12; --carbon:#16120f;
  --line:rgba(27,23,20,.13); --line-2:rgba(27,23,20,.07);
  --serif:'Cormorant',Georgia,serif;
  --sans:'Montserrat',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --ease:cubic-bezier(.16,1,.3,1); --container:1440px; --radius:16px;
  --shadow:0 30px 60px -36px rgba(27,23,20,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip;max-width:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--bone);line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:clip;font-size:16px}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}

/* ---- utilidades ---- */
.container{max-width:var(--container);margin:0 auto;padding:0 clamp(20px,4.5vw,52px)}
.kicker{font-family:var(--mono);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--red);display:inline-flex;align-items:center;gap:11px;font-weight:500}
.kicker::before{content:"";width:26px;height:1px;background:var(--red);display:inline-block}
.display{font-family:var(--serif);font-weight:600;line-height:1.0;letter-spacing:-.012em;color:var(--ink)}
.display em{font-style:italic;color:var(--red)}
.lead{font-family:var(--serif);font-weight:400;font-size:clamp(1.2rem,1.7vw,1.5rem);line-height:1.5;color:var(--ink-soft)}
.eyebrow{font-family:var(--mono);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.ico{width:24px;height:24px;flex:0 0 auto}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:50px;
  font-family:var(--sans);font-weight:600;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  transition:transform .25s var(--ease),background .25s,color .25s,box-shadow .25s;border:1px solid transparent}
.btn .ico{width:18px;height:18px}
.btn--red{background:var(--red);color:#fff}
.btn--red:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 16px 30px -14px rgba(179,18,23,.6)}
.btn--ink{background:var(--ink);color:var(--bone)}
.btn--ink:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--bone)}
.section{padding-block:clamp(70px,9vw,140px)}
.head{max-width:640px;margin-bottom:clamp(36px,5vw,64px)}
.head--center{margin-inline:auto;text-align:center}
.head .kicker{margin-bottom:20px}
.head h2{font-family:var(--serif);font-weight:600;font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1.03;letter-spacing:-.01em}
.head h2 em{font-style:italic;color:var(--red)}
.head p{margin-top:18px;color:var(--ink-soft)}

/* ---- top bar ---- */
.topbar{background:var(--carbon);color:#d8cfc2}
.topbar__in{max-width:var(--container);margin:0 auto;padding:8px clamp(20px,4.5vw,52px);
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase}
.topbar__in span{display:inline-flex;align-items:center;gap:8px}
.topbar b{color:#fff;font-weight:500}
.topbar .dot{width:5px;height:5px;background:var(--red);transform:rotate(45deg)}
@media(max-width:720px){ .topbar__in span:nth-child(2){display:none} }

/* ---- navbar ---- */
.nav{position:sticky;top:0;z-index:100;background:rgba(243,238,228,.86);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav__in{max-width:var(--container);margin:0 auto;display:flex;align-items:center;gap:24px;
  height:88px;padding:0 clamp(20px,4.5vw,52px)}
.nav__logo img{height:62px;width:auto}
.nav__links{display:flex;gap:clamp(16px,1.8vw,30px);margin-left:auto;flex-wrap:wrap}
.nav__links a{font-family:var(--sans);font-size:.74rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-soft);padding:6px 0;position:relative;transition:color .2s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--red);transition:width .28s var(--ease)}
.nav__links a:hover,.nav__links a.is-active{color:var(--ink)}
.nav__links a:hover::after,.nav__links a.is-active::after{width:100%}
.nav__icons{display:flex;align-items:center;gap:16px}
.nav__icons a{color:var(--ink);position:relative;transition:color .2s,transform .2s}
.nav__icons a:hover{color:var(--red);transform:translateY(-1px)}
.nav__icons .ico{width:21px;height:21px}
.nav__cart .ico{width:29px;height:29px}
.nav__badge{position:absolute;top:-7px;right:-9px;background:var(--red);color:#fff;font-family:var(--sans);
  font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:grid;place-items:center;padding:0 3px}
.nav__toggle{display:none;margin-left:auto;background:none;border:0;padding:8px}
.nav__toggle span{display:block;width:26px;height:2px;background:var(--ink);margin:6px 0;transition:.3s var(--ease)}
@media(max-width:1000px){
  .nav__icons{margin-left:auto}
  .nav__toggle{display:block;order:3;position:relative;z-index:160}
  .nav__links{position:fixed;inset:0 0 0 auto;z-index:150;z-index:200;width:min(86vw,340px);height:100dvh;flex-direction:column;
    align-items:flex-start;justify-content:center;gap:6px;background:var(--paper);padding:40px 34px;
    transform:translateX(100%);visibility:hidden;transition:transform .4s var(--ease),visibility .4s var(--ease);box-shadow:var(--shadow);border-left:1px solid var(--line)}
  .nav__links.open{transform:translateX(0);visibility:visible}
  .nav__links a{font-size:1rem;padding:14px 0;width:100%;border-bottom:1px solid var(--line-2)}
}

/* ---- hero ---- */
.hero{position:relative;overflow:hidden}
.hero__in{position:relative;z-index:1;padding-block:clamp(40px,4.5vw,72px)}
.hero__copy{max-width:880px;position:relative;z-index:2}
.hero::after{display:none}
@media(max-width:760px){.hero::after{display:none}}
.hero__eyebrow{margin-bottom:26px}
.hero__title{font-family:var(--serif);font-weight:700;font-size:clamp(2.9rem,6.4vw,5.6rem);
  line-height:.98;letter-spacing:-.018em;margin-bottom:26px}
.hero__title em{font-style:italic;color:var(--red)}
.hero__lead{font-family:var(--serif);font-weight:400;font-size:clamp(1.25rem,2vw,1.6rem);
  color:var(--ink-soft);max-width:44ch;line-height:1.5;margin-bottom:38px}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:42px}
.hero__meta{display:flex;flex-wrap:wrap;gap:14px 36px;font-family:var(--mono)}
.hero__meta div{font-size:.66rem;letter-spacing:.05em;color:var(--ink-soft);text-transform:uppercase;
  padding-left:16px;position:relative}
.hero__meta div::before{content:"";position:absolute;left:0;top:.45em;width:6px;height:6px;background:var(--red);transform:rotate(45deg)}
.hero__meta b{display:block;font-family:var(--serif);font-style:normal;font-weight:600;font-size:1.5rem;color:var(--ink);letter-spacing:0;margin-bottom:2px}
.hero__art{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  border:1px solid var(--line)}
.hero__art img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3.4}
.hero__tag{position:absolute;left:18px;bottom:18px;background:rgba(22,18,15,.82);color:#fff;
  font-family:var(--mono);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;padding:8px 14px;border-radius:50px}
@media(max-width:900px){
  .hero__in{grid-template-columns:1fr;gap:36px}
  .hero__art{order:-1}
  .hero__art img{aspect-ratio:16/10}
}

/* ---- beneficios ---- */
.benefits{background:var(--carbon);color:var(--bone)}
.benefits__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,48px);
  padding-block:clamp(40px,5vw,68px)}
.benefit{display:flex;flex-direction:column;gap:14px}
.benefit .ico{width:72px;height:72px;color:var(--red-bright)}
.benefit h3{font-family:var(--sans);font-weight:700;font-size:.84rem;letter-spacing:.08em;text-transform:uppercase}
.benefit p{font-size:.88rem;color:#b9af9f;line-height:1.55}
@media(max-width:780px){.benefits__grid{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:460px){.benefits__grid{grid-template-columns:1fr}}

/* ---- categorías ---- */
.cats__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.8vw,26px)}
.cat{position:relative;display:flex;flex-direction:column;justify-content:space-between;gap:40px;
  min-height:260px;padding:clamp(26px,2.4vw,38px);background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.cat::after{content:"";position:absolute;right:-30px;bottom:-30px;width:150px;height:150px;border-radius:50%;
  background:radial-gradient(circle,rgba(179,18,23,.07),transparent 70%);transition:transform .5s var(--ease)}
.cat:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(179,18,23,.4)}
.cat:hover::after{transform:scale(1.3)}
.cat__ico{width:92px;height:92px;color:var(--red)}
.cat__body h3{font-family:var(--serif);font-weight:600;font-size:1.85rem;line-height:1;margin-bottom:8px}
.cat__body h3{margin-bottom:8px}
.cat__body p{font-size:.86rem;color:var(--ink-soft);min-height:2.7em}
.cat__more{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--red);display:inline-flex;align-items:center;gap:8px;margin-top:16px}
.cat--feat{grid-column:span 1;background:var(--carbon);color:var(--bone);border-color:transparent}
.cat--feat .cat__body p{color:#b9af9f}
.cat--feat .cat__ico,.cat--feat .cat__more{color:var(--red)}
@media(max-width:900px){.cats__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cats__grid{grid-template-columns:1fr}}

/* ---- historia ---- */
.story__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:center}
.story__media{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.story__media img{width:100%;aspect-ratio:5/6;object-fit:cover}
.story__badge{position:absolute;left:20px;top:20px;background:var(--red);color:#fff;border-radius:12px;
  padding:14px 18px;text-align:center;line-height:1}
.story__badge b{font-family:var(--serif);font-size:2.1rem;font-weight:600;display:block}
.story__badge span{font-family:var(--mono);font-size:.54rem;letter-spacing:.16em;text-transform:uppercase}
.story p{margin-top:22px;color:var(--ink-soft);max-width:52ch}
.story__stats{display:flex;gap:36px;margin-top:34px;flex-wrap:wrap}
.story__stat b{font-family:var(--serif);font-size:2.6rem;font-weight:700;color:var(--ink);line-height:1;display:block}
.story__stat b em{color:var(--red);font-style:normal}
.story__stat span{font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
@media(max-width:860px){.story__grid{grid-template-columns:1fr}.story__media{max-width:420px}}

/* ---- guía de cortes ---- */
.cortes{background:var(--bone-2)}
.cortes__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.6vw,40px)}
.corte img{width:100%;height:auto;border-radius:12px;box-shadow:var(--shadow);transition:transform .35s var(--ease)}
.corte:hover img{transform:translateY(-5px)}
@media(max-width:760px){.cortes__grid{grid-template-columns:1fr}}

/* ---- proveedores ---- */
.brands__row{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(24px,4vw,64px);align-items:center}
.brands__row span{font-family:var(--serif);font-style:italic;font-size:clamp(1.2rem,2vw,1.7rem);color:var(--ink-soft);opacity:.7;transition:opacity .25s,color .25s}
.brands__row span:hover{opacity:1;color:var(--red)}

/* ---- reseñas ---- */
.reviews{background:var(--carbon);color:var(--bone)}
.reviews__in{display:grid;grid-template-columns:auto 1fr;gap:clamp(36px,6vw,90px);align-items:center}
.reviews__score{text-align:center}
.reviews__score b{font-family:var(--serif);font-size:clamp(4rem,8vw,6.5rem);font-weight:700;line-height:.9;display:block}
.reviews__stars{color:var(--red-bright);font-size:1.4rem;letter-spacing:4px;margin:8px 0}
.reviews__score span{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:#b9af9f}
.reviews__text h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,3.4vw,2.8rem);line-height:1.1}
.reviews__text h2 em{font-style:italic;color:var(--red-bright)}
.reviews__text p{color:#b9af9f;margin:18px 0 26px;max-width:48ch}
@media(max-width:720px){.reviews__in{grid-template-columns:1fr;text-align:center}.reviews__score{margin-inline:auto}}

/* ---- CTA ---- */
.cta{position:relative;background:var(--red);color:#fff;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;opacity:.14;
  background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.6) 1px,transparent 0);background-size:28px 28px}
.cta__in{position:relative;display:flex;align-items:center;justify-content:space-between;gap:40px;
  flex-wrap:wrap;padding-block:clamp(56px,7vw,92px)}
.cta__in h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.1rem,4.4vw,3.4rem);line-height:1.04;max-width:18ch}
.cta__in h2 em{font-style:italic}
.cta .btn--light{background:var(--bone);color:var(--ink)}
.cta .btn--light:hover{background:#fff;transform:translateY(-2px)}
.cta .btn--linelight{border-color:rgba(255,255,255,.6);color:#fff}
.cta .btn--linelight:hover{background:#fff;color:var(--red);border-color:#fff}

/* ---- footer ---- */
.footer{background:var(--carbon);color:#cfc8bd;padding-top:clamp(54px,6vw,84px);padding-bottom:34px;border-top:1px solid rgba(255,255,255,.16)}
.footer__grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.1fr;gap:clamp(30px,3vw,52px);padding-bottom:48px}
.footer__brand img{height:64px;margin-bottom:20px}
.footer__brand p{color:#9a9286;font-size:.92rem;max-width:42ch;line-height:1.7}
.footer h4{font-family:var(--mono);text-transform:uppercase;letter-spacing:.18em;font-size:.62rem;color:#c9c2b7;margin-bottom:20px;font-weight:500}
.footer__nav{display:flex;flex-direction:column;gap:12px}
.footer__nav a,.footer__contact a{color:#cfc8bd;font-size:.92rem;transition:color .2s}
.footer__nav a:hover,.footer__contact a:hover{color:#fff}
.footer__contact p{color:#9a9286;font-size:.92rem;margin-bottom:12px;line-height:1.6}
.footer__contact strong{color:#cfc8bd;font-weight:500}
.footer__social{display:flex;gap:12px;margin-top:20px}
.footer__social a{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  background:rgba(247,244,239,.05);border:1px solid rgba(247,244,239,.14);color:#eadfce;transition:all .25s}
.footer__social a:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-3px)}
.footer__social .ico{width:19px;height:19px}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:26px;
  border-top:1px solid rgba(247,244,239,.12);font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;
  text-transform:uppercase;color:#847c70}
.footer__bottom .accent{color:var(--red-bright)}
.footer__credit{display:flex;align-items:center;justify-content:center;gap:12px;padding-top:22px}
.footer__credit span{font-family:var(--mono);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:#847c70}
.footer__credit img{height:24px;opacity:.9}
@media(max-width:880px){.footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer__grid{grid-template-columns:1fr}}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---- pilares de compromiso ---- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,40px)}
.pillar{padding-top:30px;border-top:2px solid var(--ink);transition:border-color .35s var(--ease)}
.pillar:hover{border-top-color:var(--red)}
.pillar__ico{display:flex;align-items:center;height:88px;color:var(--red);margin-bottom:18px}.pillar__ico svg{display:block;width:auto}
.pillar h3{font-family:var(--serif);font-weight:600;font-size:1.45rem;line-height:1.14;margin-bottom:12px}
.pillar p{color:var(--ink-soft);font-size:.92rem;line-height:1.62}
@media(max-width:820px){.pillars{grid-template-columns:1fr}}

/* ---- manifiesto (cierre) ---- */
.manifesto{background:var(--carbon);color:var(--bone)}
.manifesto__in{max-width:920px;margin:0 auto;text-align:center;padding-block:clamp(74px,10vw,140px)}
.manifesto__in .kicker{justify-content:center;color:var(--red-bright);margin-bottom:8px}
.manifesto__quote{font-family:var(--serif);font-weight:500;font-size:clamp(1.55rem,3.3vw,2.7rem);line-height:1.3;margin:26px 0 26px}
.manifesto__quote em{font-style:italic;color:var(--red-bright)}
.manifesto__sign{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#b9af9f}

/* ===== PÁGINAS DE CATEGORÍA (v2) ===== */
.phero{position:relative;overflow:hidden;background:var(--bone);border-bottom:1px solid var(--line)}
.phero__in{position:relative;z-index:1;padding-block:clamp(54px,7vw,110px)}
.phero::after{display:none}
@media(max-width:760px){.phero::after{display:none}}
.phero__crumbs{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);
  margin-bottom:22px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.phero__crumbs a:hover{color:var(--red)}
.phero__crumbs .sep{width:4px;height:4px;background:var(--red);transform:rotate(45deg);display:inline-block}
.phero__title{font-family:var(--serif);font-weight:700;font-size:clamp(2.8rem,6vw,5rem);line-height:1.0;letter-spacing:-.015em;margin-bottom:22px}
.phero__title em{font-style:italic;color:var(--red)}
.phero__lead{font-family:var(--serif);font-weight:400;font-size:clamp(1.25rem,2vw,1.6rem);color:var(--ink-soft);max-width:52ch;line-height:1.5}
.subgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,22px)}
@media(max-width:900px){.subgrid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.subgrid{grid-template-columns:1fr}}
.prose{max-width:760px;margin:0 auto;text-align:center}
.prose .kicker{justify-content:center;margin-bottom:20px}
.prose h2{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,4.2vw,3.4rem);line-height:1.04;letter-spacing:-.01em}
.prose h2 em{font-style:italic;color:var(--red)}
.prose p{color:var(--ink-soft);font-size:1.05rem;line-height:1.7;margin:22px auto 30px}

/* ===== LANDING DE CATEGORÍA (rica) ===== */
/* intro 2 columnas */
.cintro{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(36px,5vw,72px);align-items:center}
.cintro__panel{background:var(--carbon);color:var(--bone);border-radius:var(--radius);padding:clamp(36px,4vw,60px);text-align:center}
.cintro__panel .big{font-family:var(--serif);font-weight:600;font-size:clamp(3.4rem,7vw,5.4rem);line-height:.9;color:#fff}
.cintro__panel .big em{font-style:normal;color:var(--red-bright)}
.cintro__panel .lbl{font-family:var(--mono);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:#b9af9f;margin-top:14px}
.cintro__panel hr{border:0;border-top:1px solid rgba(247,244,239,.14);margin:26px 0}
.cintro__panel .note{font-family:var(--serif);font-style:italic;font-size:1.25rem;color:#ece4d8}
@media(max-width:820px){.cintro{grid-template-columns:1fr}.cintro__panel{max-width:440px}}
/* tipos editoriales (filas alternadas) */
.types{margin-top:6px}
.type{display:grid;grid-template-columns:150px 1fr;gap:clamp(22px,3.4vw,48px);align-items:center;
  padding-block:clamp(22px,2.8vw,38px);border-top:1px solid var(--line)}
.type:last-child{border-bottom:1px solid var(--line)}
.type__ico{width:clamp(86px,9vw,130px);height:auto;color:var(--red);justify-self:center}
.type__n{font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris)}
.type h3{font-family:var(--serif);font-weight:600;font-size:clamp(1.7rem,3.2vw,2.7rem);line-height:1.04;margin:8px 0 12px}
.type p{color:var(--ink-soft);font-size:1.02rem;line-height:1.7;max-width:60ch}
.type:nth-child(even) .type__ico{order:2}
.type:nth-child(even) .type__txt{order:1;text-align:right}
.type:nth-child(even){grid-template-columns:1fr 170px}
.type:nth-child(even) .type__txt p{margin-left:auto}
@media(max-width:680px){.type,.type:nth-child(even){grid-template-columns:1fr;gap:14px}
  .type:nth-child(even) .type__txt{order:0;text-align:left} .type:nth-child(even) .type__ico{order:0}
  .type__ico{justify-self:start} .type:nth-child(even) .type__txt p{margin-left:0}}
/* bloques de color (calidad/efecto, listos para foto fija) */
.cblock{display:flex;flex-direction:column;justify-content:center;padding-block:clamp(64px,8vw,110px)}
.cblock .inner{max-width:1000px;margin:0 auto;width:100%;padding:0 clamp(20px,5vw,64px);text-align:center}
.cblock .kicker{justify-content:center;margin-bottom:20px}
.cblock h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.55rem,3.3vw,2.7rem);line-height:1.3;letter-spacing:-.01em}
.cblock h2 em{font-style:italic}
.cblock p{font-family:var(--serif);font-weight:300;font-size:clamp(1.05rem,1.6vw,1.3rem);margin-top:18px;max-width:52ch;margin-inline:auto}
.cblock .sign{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;margin-top:24px}
.cblock--carbon{background:var(--carbon);color:var(--bone)}.cblock--carbon .kicker,.cblock--carbon h2 em{color:var(--red-bright)}.cblock--carbon .sign{color:#cdbfae}
.cblock--red{background:var(--red);color:#fff}.cblock--red .kicker,.cblock--red h2 em{color:#ffe2e0}.cblock--red .sign{color:#ffd9d7}

/* panel de intro con ícono (categorías no-carnes) */
.cintro__panel .pico{width:clamp(80px,9vw,118px);height:auto;color:var(--red-bright);margin:0 auto 22px;display:block}

/* ===== CONTACTO ===== */
.contact{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(36px,5vw,72px);align-items:start}
.cinfo{display:flex;flex-direction:column;gap:26px}
.cinfo__item{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start}
.cinfo__ico{width:46px;height:46px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--red);flex:0 0 auto}
.cinfo__ico .ico{width:20px;height:20px}
.cinfo__item h3{font-family:var(--mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px}
.cinfo__item p{font-size:1.05rem;color:var(--ink);line-height:1.55}
.cinfo__item a{color:var(--ink)}.cinfo__item a:hover{color:var(--red)}
.cmap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.cmap iframe{width:100%;height:100%;min-height:440px;border:0;display:block}
@media(max-width:860px){.contact{grid-template-columns:1fr}.cmap iframe{min-height:340px}}

/* ===== WhatsApp flotante ===== */
.wafloat{position:fixed;right:22px;bottom:22px;z-index:90;width:58px;height:58px;
  display:grid;place-items:center;background:none;
  transition:transform .25s var(--ease)}
.wafloat:hover{transform:scale(1.08)}
.wafloat img{width:58px;height:58px;display:block;filter:drop-shadow(0 5px 14px rgba(0,0,0,.4))}
@media(prefers-reduced-motion:reduce){.wafloat{animation:none}}
@media(max-width:600px){.wafloat{right:16px;bottom:16px;width:52px;height:52px}.wafloat img{width:52px;height:52px}}

/* ===== reseñas (carrusel, fondo claro para separar del manifiesto) ===== */
.revs{background:var(--bone)}
.revs__head{text-align:center;max-width:640px;margin:0 auto clamp(28px,4vw,48px)}
.revs__head h2 em{font-style:italic;color:var(--red)}
.revs__rating{display:inline-flex;align-items:center;gap:10px;margin-top:16px;font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.revs__rating b{font-family:var(--serif);font-size:1.7rem;font-weight:700;color:var(--ink)}
.revs__stars{color:var(--red);letter-spacing:2px}
.revcar{position:relative;max-width:740px;margin:0 auto;overflow:hidden;border-radius:var(--radius)}
.revcar__track{display:flex;transition:transform .5s var(--ease)}
.revcard{flex:0 0 100%;box-sizing:border-box;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(34px,4vw,56px) clamp(26px,4vw,54px);text-align:center}
.revcard .stars{color:var(--red);letter-spacing:3px;font-size:1.1rem;margin-bottom:18px}
.revcard p{font-family:var(--serif);font-weight:400;font-size:clamp(1.3rem,2.4vw,1.9rem);line-height:1.45;color:var(--ink)}
.revcard .who{font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:20px}
.revcar__dots{display:flex;gap:2px;justify-content:center;margin-top:6px}
.revcar__dot{width:44px;height:44px;border:0;background:transparent;cursor:pointer;padding:0;position:relative;-webkit-tap-highlight-color:transparent}
.revcar__dot::before{content:"";position:absolute;top:50%;left:50%;width:8px;height:8px;border-radius:50%;background:var(--line);transform:translate(-50%,-50%);transition:background .2s,transform .2s}
.revcar__dot.is-active::before{background:var(--red);transform:translate(-50%,-50%) scale(1.3)}


/* ===== A11Y: foco visible + touch ===== */
a,button,[role="button"]{touch-action:manipulation}
:where(a,button,input,textarea,select,summary,[tabindex]):focus-visible{outline:2px solid var(--red);outline-offset:3px;border-radius:3px}
.btn:focus-visible,.nav__links a:focus-visible{outline-offset:4px}
.cblock--carbon :focus-visible,.cblock--red :focus-visible,.manifesto :focus-visible,.footer :focus-visible,.cta :focus-visible,.topbar :focus-visible{outline-color:#fff}
@media(prefers-reduced-motion:reduce){.revcar__track{transition:none}}

/* botón tienda próximamente */
.btn.is-soon{cursor:default;opacity:.72}
.btn.is-soon:hover{transform:none;box-shadow:none;background:var(--bone);color:var(--ink)}

/* menú mobile: X al abrir + fondo (scrim) para cerrar tocando afuera */
.nav__toggle.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav__toggle.is-open span:nth-child(2){opacity:0}
.nav__toggle.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.nav-scrim{position:fixed;inset:0;background:rgba(20,16,12,.45);z-index:95;opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s}
.nav-scrim.show{opacity:1;visibility:visible}
@media(min-width:1001px){.nav-scrim{display:none}}

/* botón cerrar dentro del menú mobile */
.nav__close{display:none}
@media(max-width:1000px){
  .nav__close{display:block;position:absolute;top:14px;right:20px;background:none;border:0;
    font-size:2.1rem;line-height:1;color:var(--ink);cursor:pointer;padding:2px 12px;z-index:2}
  .nav__close:hover{color:var(--red)}
  .nav__links{padding-top:64px}
}

/* ===== swashes (corte display Cormorant) — con MUCHA moderación ===== */
.swash{font-feature-settings:"swsh" 1,"salt" 1,"dlig" 1;}


/* ===== foto en hero de categoría (columna derecha del .cintro) ===== */
.phero__photo{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:3/2}
.phero__photo img{width:100%;height:100%;object-fit:cover;display:block}
.phero__badge{position:absolute;left:18px;bottom:18px;color:#fff;border-radius:12px;padding:12px 18px;line-height:1;background:rgba(22,18,15,.82);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}
.phero__badge b{font-family:var(--serif);font-weight:700;font-size:2rem;display:block}
.phero__badge b em{font-style:normal;color:var(--red-bright)}
.phero__badge span{font-family:var(--mono);font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:#cfc8bd;display:block;margin-top:4px}
@media(max-width:820px){.phero__photo{max-width:520px;margin-inline:auto}}

/* ===== hero de categoría a sangre (foto + velo) ===== */
.phero--photo{position:relative;overflow:hidden;background:var(--carbon)}
.phero--photo .phero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.phero--photo .phero__veil{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(20,16,12,.93) 0%, rgba(20,16,12,.80) 32%, rgba(20,16,12,.34) 62%, rgba(20,16,12,0) 88%),
    linear-gradient(0deg, rgba(20,16,12,.5) 0%, rgba(20,16,12,0) 42%)}
.phero--photo .phero__in{position:relative;z-index:2;display:flex;align-items:center;min-height:clamp(420px,64vh,640px)}
.phero--photo .phero__copy{max-width:600px}
.phero--photo .phero__crumbs,.phero--photo .phero__crumbs a{color:#cfc8bd}
.phero--photo .phero__crumbs a:hover{color:var(--red-bright)}
.phero--photo .phero__title{color:var(--bone);font-weight:700}
.phero--photo .phero__title em{color:var(--red-bright)}
.phero--photo .phero__lead{font-family:var(--serif);font-weight:400;font-size:clamp(1.15rem,1.8vw,1.45rem);color:#e7ded0;line-height:1.6;max-width:52ch;margin-top:20px}
.phero__stat{display:inline-flex;align-items:baseline;gap:12px;margin-top:30px;background:rgba(247,244,239,.08);border:1px solid rgba(247,244,239,.18);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-radius:50px;padding:12px 22px}
.phero__stat b{font-family:var(--serif);font-weight:700;font-size:1.8rem;color:#fff;line-height:1}
.phero__stat b em{font-style:normal;color:var(--red-bright)}
.phero__stat span{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:#cfc8bd}
@media(max-width:900px){
  .phero--photo .phero__veil{background:linear-gradient(0deg, rgba(20,16,12,.9) 0%, rgba(20,16,12,.55) 55%, rgba(20,16,12,.5) 100%)}
  .phero--photo .phero__in{min-height:clamp(380px,58vh,520px)}
}

/* ===== SCROLLYTELLING (foto fija + bloques de color) ===== */
.imgsec{position:relative;min-height:155vh;display:flex;flex-direction:column;justify-content:center;padding-block:20vh;color:#fff;background-size:cover;background-position:center;background-attachment:fixed}
.imgsec::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,11,9,.62),rgba(13,11,9,.4) 45%,rgba(13,11,9,.66))}
.imgsec .inner{position:relative;z-index:1;max-width:1080px;margin:0 auto;width:100%;padding:0 clamp(20px,5vw,60px)}
.imgsec.right .inner{text-align:right;margin-left:auto}
.imgsec .kicker{color:var(--red-bright);margin-bottom:20px}
.imgsec.right .kicker{flex-direction:row-reverse}
.imgsec h2{font-family:var(--serif);font-weight:600;font-size:clamp(2.3rem,5.6vw,4.6rem);line-height:1.0;letter-spacing:-.012em;max-width:16ch}
.imgsec.right h2{margin-left:auto}
.imgsec h2 em{font-style:italic;color:var(--red-bright)}
.imgsec p{font-family:var(--serif);font-weight:400;font-size:clamp(1.2rem,2vw,1.65rem);color:#ece4d8;max-width:46ch;margin-top:22px;line-height:1.5}
.imgsec.right p{margin-left:auto}
.block{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-block:clamp(80px,12vw,150px)}
.block .inner{max-width:1040px;margin:0 auto;width:100%;padding:0 clamp(20px,5vw,64px)}
.block.center .inner{text-align:center;margin-inline:auto}
.block .kicker{margin-bottom:22px}.block.center .kicker{justify-content:center}
.block h2{font-family:var(--serif);font-weight:600;font-size:clamp(2.5rem,6vw,5rem);line-height:1.0;letter-spacing:-.014em;max-width:18ch}
.block.center h2{margin-inline:auto}.block h2 em{font-style:italic}
.block p{font-family:var(--serif);font-weight:400;font-size:clamp(1.3rem,2.2vw,1.9rem);margin-top:24px;line-height:1.45;max-width:52ch}
.block.center p{margin-inline:auto}
.block .sign{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;margin-top:26px}
.block--bone{background:var(--bone);color:var(--ink)}.block--bone .kicker,.block--bone h2 em{color:var(--red)}
.block--carbon{background:var(--carbon);color:var(--bone)}.block--carbon .kicker,.block--carbon h2 em{color:var(--red-bright)}.block--carbon .sign{color:#cdbfae}
.block--red{background:var(--red);color:#fff}.block--red .kicker,.block--red h2 em{color:#ffe2e0}.block--red .sign{color:#ffd9d7}
.js .imgsec .inner>*,.js .block .inner>*{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.imgsec.in .inner>*,.block.in .inner>*{opacity:1;transform:none}
.in .inner>*:nth-child(2){transition-delay:.12s}.in .inner>*:nth-child(3){transition-delay:.24s}
@media(prefers-reduced-motion:reduce){.imgsec .inner>*,.block .inner>*{opacity:1;transform:none}.imgsec{background-attachment:scroll}}
@media(max-width:820px){.imgsec{background-attachment:scroll;min-height:100vh}}

/* ===== HERO a sangre: foto de fondo + velo + texto claro ===== */
.hero{position:relative;overflow:hidden;background:var(--carbon)}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center right;z-index:0}
.hero__veil{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(20,16,12,.93) 0%, rgba(20,16,12,.80) 30%, rgba(20,16,12,.35) 60%, rgba(20,16,12,0) 86%),
    linear-gradient(0deg, rgba(20,16,12,.55) 0%, rgba(20,16,12,0) 42%)}
.hero__in{position:relative;z-index:2;display:flex;align-items:center;min-height:clamp(520px,74vh,700px)}
.hero__copy .hero__title{color:var(--bone)}
.hero__copy .hero__title em{color:var(--red-bright)}
.hero__copy .hero__lead{color:#e7ded0}
.hero__copy .hero__eyebrow{color:var(--red-bright)}
.hero__copy .hero__meta div{color:#cfc8bd}
.hero__copy .hero__meta b{color:#fff}
.hero .btn--ghost{border-color:rgba(247,244,239,.7);color:var(--bone)}
.hero .btn--ghost:hover{background:var(--bone);color:var(--ink);border-color:var(--bone)}
@media(max-width:900px){
  .hero__bg{object-position:center}
  .hero__veil{background:linear-gradient(0deg, rgba(20,16,12,.90) 0%, rgba(20,16,12,.55) 55%, rgba(20,16,12,.48) 100%)}
  .hero__in{min-height:clamp(520px,78vh,720px)}
}

/* QR Data Fiscal AFIP en footer */
.footer__fiscal{display:inline-block;margin-top:22px;background:#fff;padding:5px;border-radius:6px;line-height:0}
.footer__fiscal img{width:48px;height:auto;display:block}

/* ===== Categorías con foto ===== */
.catsN{text-align:center}
.catsN__kicker{color:var(--red);font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;margin:0 0 12px}
.catsN__title{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,3.6vw,3.4rem);line-height:1.06;letter-spacing:-.01em;color:var(--ink);margin:0 0 16px}
.catsN__title em{font-style:italic;color:var(--red)}
.catsN__orn{display:flex;align-items:center;justify-content:center;gap:14px;width:200px;margin:0 auto 44px}
.catsN__orn::before,.catsN__orn::after{content:"";height:1px;flex:1;background:rgba(179,18,23,.35)}
.catsN__orn span{width:8px;height:8px;flex:none;transform:rotate(45deg);background:var(--red)}
.catsN__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.catN{display:block;overflow:hidden;border-radius:8px;background:#000;box-shadow:0 8px 30px rgba(0,0,0,.10);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.catN:hover{transform:translateY(-4px);box-shadow:0 18px 40px -12px rgba(0,0,0,.32)}
.catN__img{overflow:hidden}
.catN__img img{width:100%;aspect-ratio:4/3.2;object-fit:cover;display:block;transition:transform .5s ease}
.catN:hover .catN__img img{transform:scale(1.05)}
.catN__overlay{background:#0f0d0b;color:var(--bone);padding:18px 16px 20px;text-align:center}
.catN__overlay h3{margin:0 0 10px;font-family:var(--serif);font-weight:600;font-size:1.2rem;letter-spacing:.04em;color:#fff}
.catN__link{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:.62rem;font-weight:500;letter-spacing:.16em;color:var(--red-bright);text-transform:uppercase}
.catN__link .ico{color:var(--red-bright)}
@media(max-width:1100px){.catsN__grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.catsN__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.catsN__grid{grid-template-columns:1fr}}
