/* =====================================================================
   CUCHILLO Y JAMÓN — Josué Veloz · Cortador de jamón
   Sistema de diseño: Editorial oscuro de lujo
   Granate #9F1239 · Oro #C9A24B · Crema #FFF9F2 sobre carbón
   ===================================================================== */

:root{
  /* Paleta */
  --carbon:        #0c0a0b;
  --carbon-2:      #14100f;
  --carbon-3:      #1c1715;
  --surface:       #1a1513;
  --surface-2:     #221b18;
  --line:          rgba(201,162,75,.18);
  --line-soft:     rgba(237,230,221,.10);

  --granate:       #9F1239;
  --granate-2:     #c01a48;
  --granate-deep:  #7a0e2c;

  --gold:          #c9a24b;
  --gold-2:        #ddc07e;
  --gold-soft:     rgba(201,162,75,.12);

  --cream:         #fff9f2;
  --text:          #ece4da;
  --muted:         #b3a89c;
  --muted-2:       #8a8076;

  /* Tipografia */
  --serif: "Cormorant Garamond", "Times New Roman", Georgia, serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* Escala / ritmo */
  --container: 1240px;
  --container-narrow: 860px;
  --space: clamp(3.5rem, 6vw, 6.5rem);
  --radius: 2px;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--sans);
  background:var(--carbon);
  color:var(--text);
  font-size:clamp(1rem,.96rem + .2vw,1.08rem);
  line-height:1.75;
  font-weight:400;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
ul{ margin:0; padding:0; list-style:none; }

/* ---------- Tipografia ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.06; margin:0; letter-spacing:.01em; }
h1{ font-size:clamp(2.7rem,1.8rem + 4.4vw,5.6rem); }
h2{ font-size:clamp(2rem,1.4rem + 2.6vw,3.4rem); }
h3{ font-size:clamp(1.4rem,1.1rem + 1.1vw,2rem); }
p{ margin:0 0 1.1em; color:var(--muted); }
strong{ color:var(--text); font-weight:600; }
em{ font-style:italic; }

.kicker{
  font-family:var(--sans);
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:.85rem;
}
.kicker::before{
  content:""; width:34px; height:1px; background:linear-gradient(90deg,transparent,var(--gold));
}
.kicker.centered{ justify-content:center; }
.kicker.centered::after{
  content:""; width:34px; height:1px; background:linear-gradient(90deg,var(--gold),transparent);
}

.serif-accent{ font-family:var(--serif); font-style:italic; color:var(--gold-2); font-weight:500; }
.lead{ font-size:clamp(1.12rem,1rem + .5vw,1.4rem); color:var(--text); line-height:1.7; }

/* ---------- Layout ---------- */
.container{ width:min(100% - 2.6rem, var(--container)); margin-inline:auto; }
.narrow{ width:min(100% - 2.6rem, var(--container-narrow)); margin-inline:auto; }
section{ position:relative; }
.section-pad{ padding-block:var(--space); }
.bg-carbon-2{ background:var(--carbon-2); }
.bg-surface{ background:var(--surface); }
.center{ text-align:center; }
.divider{ height:1px; background:linear-gradient(90deg,transparent,var(--line),transparent); border:0; margin:0; }

/* ---------- Botones ---------- */
.btn{
  --bg:var(--granate); --fg:var(--cream);
  display:inline-flex; align-items:center; gap:.7rem;
  padding:1.05rem 2.1rem;
  background:var(--bg); color:var(--fg);
  font-family:var(--sans); font-size:.82rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase;
  border:1px solid transparent; border-radius:var(--radius);
  position:relative; overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s;
}
.btn svg{ width:18px; height:18px; }
.btn::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.18),transparent 70%);
  transform:translateX(-120%); transition:transform .7s var(--ease);
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 16px 38px -14px rgba(159,18,57,.7); }
.btn:hover::after{ transform:translateX(120%); }
.btn--gold{ --bg:var(--gold); --fg:#1a1208; }
.btn--gold:hover{ box-shadow:0 16px 38px -14px rgba(201,162,75,.6); }
.btn--ghost{
  background:transparent; color:var(--text);
  border-color:var(--line);
}
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold-2); box-shadow:none; }
.btn--wa{ --bg:#1f7a4d; }
.btn--wa:hover{ box-shadow:0 16px 38px -14px rgba(31,122,77,.6); }
.btn--lg{ padding:1.2rem 2.6rem; }

.text-link{
  display:inline-flex; align-items:center; gap:.5rem;
  color:var(--gold-2); font-weight:600; font-size:.82rem;
  letter-spacing:.12em; text-transform:uppercase;
  border-bottom:1px solid var(--line); padding-bottom:.25rem;
  transition:gap .3s var(--ease), color .3s, border-color .3s;
}
.text-link:hover{ gap:.9rem; color:var(--gold); border-color:var(--gold); }

/* ---------- Header / Nav ---------- */
.site-top{ position:fixed; top:0; left:0; right:0; z-index:100; }
.site-top .topbar{ transition:max-height .4s var(--ease), padding .4s var(--ease), opacity .3s; max-height:60px; overflow:hidden; }
.site-top.scrolled .topbar{ max-height:0; padding-top:0; padding-bottom:0; opacity:0; }
.site-header{
  padding-block:1.05rem;
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
  background:linear-gradient(180deg,rgba(12,10,11,.6),transparent);
}
.site-top.scrolled .site-header{
  background:rgba(12,10,11,.9);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom-color:var(--line);
  padding-block:.7rem;
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.brand{ display:flex; align-items:center; gap:.85rem; }
.brand__logo{ width:42px; height:42px; object-fit:contain; }
.brand__txt{ display:flex; flex-direction:column; line-height:1; }
.brand__name{ font-family:var(--serif); font-size:1.3rem; color:var(--cream); letter-spacing:.02em; }
.brand__sub{ font-size:.6rem; letter-spacing:.32em; text-transform:uppercase; color:var(--gold); margin-top:.3rem; }
.nav__menu{ display:flex; align-items:center; gap:2.1rem; }
.nav__link{
  font-size:.82rem; font-weight:500; letter-spacing:.04em; color:var(--muted);
  position:relative; padding-block:.3rem; transition:color .3s;
}
.nav__link::after{
  content:""; position:absolute; left:0; bottom:0; width:0; height:1px;
  background:var(--gold); transition:width .3s var(--ease);
}
.nav__link:hover, .nav__link.active{ color:var(--cream); }
.nav__link:hover::after, .nav__link.active::after{ width:100%; }
.nav__cta{ display:flex; align-items:center; gap:1rem; }
.nav__phone{ display:inline-flex; align-items:center; gap:.5rem; font-size:.85rem; color:var(--text); font-weight:600; }
.nav__phone svg{ width:16px; height:16px; color:var(--gold); }

/* Dropdown servicios */
.nav__dd{ position:relative; }
.nav__dd-menu{
  position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(10px);
  min-width:240px; background:rgba(16,12,11,.97); backdrop-filter:blur(14px);
  border:1px solid var(--line); padding:.7rem; margin-top:1rem;
  opacity:0; visibility:hidden; transition:opacity .3s var(--ease), transform .3s var(--ease);
}
.nav__dd:hover .nav__dd-menu{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.nav__dd-menu::before{ content:""; position:absolute; top:-1rem; left:0; right:0; height:1rem; }
.nav__dd-menu a{ display:block; padding:.7rem .9rem; font-size:.85rem; color:var(--muted); transition:color .25s, background .25s; }
.nav__dd-menu a:hover, .nav__dd-menu a.active{ color:var(--gold-2); background:var(--gold-soft); }

.nav__toggle{ display:none; background:none; border:0; color:var(--cream); width:42px; height:42px; }
.nav__toggle svg{ width:26px; height:26px; }

/* Mobile drawer */
.nav__drawer{
  position:fixed; inset:0; z-index:99;
  background:rgba(10,8,9,.97); backdrop-filter:blur(8px);
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:.4rem;
  opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s;
}
.nav__drawer.open{ opacity:1; visibility:visible; }
.nav__drawer a{ font-family:var(--serif); font-size:2rem; color:var(--text); padding:.5rem 1rem; transition:color .3s; }
.nav__drawer a:hover{ color:var(--gold-2); }
.nav__drawer .btn{ margin-top:1.5rem; font-family:var(--sans); font-size:.82rem; }
.nav__close{ position:absolute; top:1.5rem; right:1.5rem; background:none; border:0; color:var(--cream); }
.nav__close svg{ width:30px; height:30px; }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  padding-top:7rem; overflow:hidden;
}
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; }
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(12,10,11,.55) 0%, rgba(12,10,11,.35) 35%, rgba(12,10,11,.8) 78%, var(--carbon) 100%),
    linear-gradient(90deg, rgba(12,10,11,.85) 0%, rgba(12,10,11,.3) 55%, transparent 100%);
}
.hero__inner{ position:relative; z-index:2; max-width:760px; }
.hero h1{ color:var(--cream); margin:1.6rem 0 0; }
.hero h1 .serif-accent{ display:block; }
.hero__sub{ margin-top:1.8rem; max-width:560px; color:var(--text); }
.hero__actions{ margin-top:2.6rem; display:flex; flex-wrap:wrap; gap:1rem; }
.hero__scroll{
  position:absolute; bottom:2.2rem; left:50%; transform:translateX(-50%); z-index:2;
  font-size:.68rem; letter-spacing:.3em; text-transform:uppercase; color:var(--muted-2);
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
}
.hero__scroll span{ width:1px; height:42px; background:linear-gradient(var(--gold),transparent); animation:scrollpulse 2.4s var(--ease) infinite; }
@keyframes scrollpulse{ 0%,100%{ opacity:.3; transform:scaleY(.6);} 50%{ opacity:1; transform:scaleY(1);} transform-origin:top; }

/* ---------- Authority strip (logos / hitos) ---------- */
.authority{ border-block:1px solid var(--line); background:var(--carbon-2); }
.authority__inner{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:1rem 3rem; padding-block:2.2rem; }
.authority__item{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:.2rem; }
.authority__num{ font-family:var(--serif); font-size:2rem; color:var(--gold-2); line-height:1; }
.authority__label{ font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.authority__sep{ width:1px; height:38px; background:var(--line); }

/* ---------- Section heading ---------- */
.sec-head{ max-width:680px; margin-bottom:3.4rem; }
.sec-head.centered{ margin-inline:auto; text-align:center; }
.sec-head h2{ color:var(--cream); margin:1.2rem 0 0; }
.sec-head p{ margin-top:1.3rem; }

/* ---------- Intro split (sobre/Las Vegas) ---------- */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2.5rem,5vw,5.5rem); align-items:center; }
.split--rev .split__media{ order:-1; }
.split__media{ position:relative; }
.split__media img{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:var(--radius); }
.split__media .frame{ position:absolute; inset:14px; border:1px solid var(--gold-soft); pointer-events:none; }
.split__media .tag{
  position:absolute; bottom:-1px; left:-1px; background:var(--granate); color:var(--cream);
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; padding:.7rem 1.4rem; font-weight:600;
}
.split__body h2{ color:var(--cream); margin:1.2rem 0 1.4rem; }

/* ---------- Servicios ---------- */
.services{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.6rem; }
.svc{
  position:relative; min-height:420px; display:flex; flex-direction:column; justify-content:flex-end;
  padding:2.4rem; overflow:hidden; border:1px solid var(--line-soft);
  isolation:isolate;
}
.svc__media{ position:absolute; inset:0; z-index:-2; }
.svc__media img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.svc::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(12,10,11,.15) 0%, rgba(12,10,11,.55) 50%, rgba(10,7,8,.94) 100%); }
.svc:hover .svc__media img{ transform:scale(1.06); }
.svc__num{ font-family:var(--serif); font-size:.9rem; color:var(--gold); letter-spacing:.2em; }
.svc h3{ color:var(--cream); margin:.7rem 0 .7rem; }
.svc p{ color:var(--muted); margin-bottom:1.2rem; font-size:.98rem; }
.svc .text-link{ align-self:flex-start; }
.svc--wide{ grid-column:span 2; min-height:320px; }

/* ---------- Lista de valor ---------- */
.values{ display:grid; grid-template-columns:repeat(2,1fr); gap:0; border:1px solid var(--line); }
.value{ padding:2.2rem 2.4rem; border-right:1px solid var(--line); border-bottom:1px solid var(--line); }
.value:nth-child(2n){ border-right:0; }
.value__ico{ width:40px; height:40px; color:var(--gold); margin-bottom:1.1rem; }
.value__ico svg{ width:100%; height:100%; stroke-width:1.2; }
.value h3{ font-size:1.3rem; color:var(--cream); margin-bottom:.6rem; }
.value p{ font-size:.96rem; margin:0; }

/* ---------- Proceso (Antes/Durante/Después) ---------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; counter-reset:step; }
.step{ padding:2.2rem; border:1px solid var(--line-soft); background:var(--carbon-2); position:relative; }
.step__n{ font-family:var(--serif); font-size:3.4rem; color:var(--gold-soft); line-height:1; }
.step h3{ color:var(--cream); margin:.4rem 0 1rem; font-size:1.5rem; }
.step p{ font-size:.95rem; margin:0; }

/* ---------- Galeria ---------- */
.gallery{ columns:3; column-gap:14px; }
.gallery figure{ margin:0 0 14px; break-inside:avoid; position:relative; overflow:hidden; border-radius:var(--radius); }
.gallery img{ width:100%; transition:transform .9s var(--ease), filter .6s; filter:saturate(.92) brightness(.92); }
.gallery figure::after{ content:""; position:absolute; inset:0; border:1px solid transparent; transition:border-color .4s; }
.gallery figure:hover img{ transform:scale(1.05); filter:saturate(1.05) brightness(1); }
.gallery figure:hover::after{ border-color:var(--gold-soft); }

/* ---------- Timeline ---------- */
.timeline{ position:relative; margin-left:1rem; }
.timeline::before{ content:""; position:absolute; left:0; top:.5rem; bottom:.5rem; width:1px; background:linear-gradient(var(--gold-soft),var(--line),transparent); }
.tl-item{ position:relative; padding:0 0 2.6rem 2.6rem; }
.tl-item::before{ content:""; position:absolute; left:-5px; top:.35rem; width:11px; height:11px; border-radius:50%; background:var(--granate); box-shadow:0 0 0 4px rgba(159,18,57,.15); }
.tl-year{ font-family:var(--sans); font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.tl-item h3{ color:var(--cream); margin:.4rem 0 .6rem; font-size:1.5rem; }
.tl-item p{ margin:0; font-size:.98rem; }

/* about stats */
.about-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.about-stat{ border:1px solid var(--line); padding:2rem 1.6rem; text-align:center; }
.about-stat .n{ font-family:var(--serif); font-size:2.6rem; color:var(--gold-2); line-height:1; }
.about-stat .l{ font-size:.82rem; color:var(--muted); margin-top:.6rem; }
@media (max-width:560px){ .about-grid{ grid-template-columns:1fr; } }

/* ---------- Galería avanzada: filtros + lightbox ---------- */
.gal-filter{ display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; margin-bottom:2.8rem; }
.gal-filter button{
  background:transparent; border:1px solid var(--line); color:var(--muted);
  padding:.6rem 1.3rem; font-family:var(--sans); font-size:.78rem; letter-spacing:.1em;
  text-transform:uppercase; border-radius:100px; transition:all .3s var(--ease);
}
.gal-filter button:hover{ color:var(--cream); border-color:var(--gold); }
.gal-filter button.active{ background:var(--granate); border-color:var(--granate); color:var(--cream); }
.gal-filter button .count{ opacity:.55; margin-left:.4rem; font-size:.72em; }

.gallery figure{ cursor:zoom-in; }
.gallery figure.is-hidden{ display:none; }
.gallery figure .view-ico{
  position:absolute; inset:0; display:grid; place-items:center; z-index:2;
  opacity:0; transition:opacity .35s var(--ease); pointer-events:none;
}
.gallery figure .view-ico span{
  width:52px; height:52px; border:1px solid var(--gold-2); border-radius:50%;
  display:grid; place-items:center; color:var(--gold-2); background:rgba(12,10,11,.45); backdrop-filter:blur(2px);
}
.gallery figure .view-ico svg{ width:22px; height:22px; }
.gallery figure:hover .view-ico{ opacity:1; }

/* Lightbox */
.lightbox{
  position:fixed; inset:0; z-index:200; background:rgba(7,5,6,.97);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .35s var(--ease), visibility .35s;
}
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox__stage{ position:relative; max-width:92vw; max-height:86vh; display:flex; align-items:center; justify-content:center; }
.lightbox__img{ max-width:92vw; max-height:82vh; width:auto; height:auto; object-fit:contain; border:1px solid var(--line); box-shadow:0 40px 100px -25px #000; opacity:0; transition:opacity .3s var(--ease); }
.lightbox__img.loaded{ opacity:1; }
.lightbox__cap{ position:absolute; bottom:1.6rem; left:0; right:0; text-align:center; color:var(--muted); font-size:.86rem; letter-spacing:.04em; padding:0 1rem; }
.lightbox__counter{ position:absolute; top:1.5rem; left:1.8rem; color:var(--gold-2); font-size:.78rem; letter-spacing:.18em; font-family:var(--serif); }
.lb-btn{
  position:absolute; z-index:2; background:rgba(20,16,15,.6); border:1px solid var(--line);
  color:var(--cream); width:52px; height:52px; border-radius:50%; display:grid; place-items:center;
  transition:background .3s, border-color .3s, transform .3s var(--ease);
}
.lb-btn:hover{ background:var(--granate); border-color:var(--granate); }
.lb-btn svg{ width:22px; height:22px; }
.lb-close{ top:1.3rem; right:1.6rem; }
.lb-prev{ left:1.6rem; top:50%; transform:translateY(-50%); }
.lb-next{ right:1.6rem; top:50%; transform:translateY(-50%); }
.lb-prev:hover{ transform:translateY(-50%) scale(1.08); }
.lb-next:hover{ transform:translateY(-50%) scale(1.08); }
@media (max-width:640px){
  .lb-prev{ left:.6rem; } .lb-next{ right:.6rem; } .lb-btn{ width:44px; height:44px; }
  .lightbox__counter{ left:1rem; top:1rem; }
}

/* ---------- FAQ ---------- */
.faq{ border-top:1px solid var(--line); }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__q{
  width:100%; text-align:left; background:none; border:0; color:var(--cream);
  font-family:var(--serif); font-size:clamp(1.2rem,1.05rem + .6vw,1.6rem);
  padding:1.7rem 3rem 1.7rem 0; position:relative; display:flex; justify-content:space-between; align-items:center; gap:1rem;
}
.faq__q::after{ content:"+"; font-family:var(--sans); font-weight:300; font-size:1.6rem; color:var(--gold); transition:transform .3s; }
.faq__item.open .faq__q::after{ transform:rotate(45deg); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .5s var(--ease); }
.faq__a p{ padding:0 0 1.7rem; margin:0; max-width:760px; }

/* ---------- Testimonio / cita ---------- */
.quote{ text-align:center; }
.quote__mark{ font-family:var(--serif); font-size:5rem; color:var(--gold-soft); line-height:.4; }
.quote blockquote{ margin:1.5rem auto 0; max-width:820px; font-family:var(--serif); font-style:italic;
  font-size:clamp(1.5rem,1.2rem + 1.4vw,2.4rem); color:var(--cream); line-height:1.35; }
.quote cite{ display:block; margin-top:1.8rem; font-style:normal; font-size:.8rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--gold); }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; overflow:hidden; text-align:center; padding-block:clamp(5rem,9vw,8rem); }
.cta-band__media{ position:absolute; inset:0; z-index:-2; }
.cta-band__media img{ width:100%; height:100%; object-fit:cover; }
.cta-band::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(10,7,8,.86), rgba(122,14,44,.5), rgba(10,7,8,.9)); }
.cta-band h2{ color:var(--cream); max-width:760px; margin:1.2rem auto 1.6rem; }
.cta-band .lead{ max-width:600px; margin:0 auto 2.4rem; }
.cta-band__actions{ display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; }

/* ---------- Page hero (interiores) ---------- */
.page-hero{ position:relative; padding:12rem 0 5rem; overflow:hidden; }
.page-hero__media{ position:absolute; inset:0; z-index:-2; }
.page-hero__media img{ width:100%; height:100%; object-fit:cover; object-position:center 35%; }
.page-hero::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(12,10,11,.78), rgba(12,10,11,.6) 40%, rgba(12,10,11,.95)); }
.page-hero h1{ color:var(--cream); margin:1.4rem 0 0; max-width:14ch; }
.page-hero p{ margin-top:1.4rem; max-width:560px; }
.breadcrumb{ display:flex; gap:.6rem; font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-2); margin-bottom:.4rem; }
.breadcrumb a:hover{ color:var(--gold); }
.breadcrumb span{ color:var(--gold); }

/* ---------- Includes list (que incluye) ---------- */
.checklist{ display:grid; gap:1rem; }
.checklist li{ display:flex; gap:1rem; align-items:flex-start; color:var(--muted); }
.checklist li::before{
  content:""; flex:0 0 auto; width:22px; height:22px; margin-top:.25rem;
  background:var(--gold-soft); border:1px solid var(--line); border-radius:50%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c9a24b' stroke-width='2.5'%3E%3Cpath d='M5 12l4 4 10-10'/%3E%3C/svg%3E");
  background-size:13px; background-repeat:no-repeat; background-position:center;
}
.checklist li strong{ color:var(--text); }

/* ---------- Blog ---------- */
.posts{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.post-card{ display:flex; flex-direction:column; border:1px solid var(--line-soft); background:var(--carbon-2); transition:border-color .4s, transform .4s var(--ease); }
.post-card:hover{ border-color:var(--line); transform:translateY(-5px); }
.post-card__media{ aspect-ratio:16/10; overflow:hidden; }
.post-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
.post-card:hover .post-card__media img{ transform:scale(1.06); }
.post-card__body{ padding:1.8rem; display:flex; flex-direction:column; flex:1; }
.post-card__cat{ font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:.9rem; }
.post-card h3{ font-size:1.35rem; color:var(--cream); line-height:1.2; margin-bottom:.8rem; }
.post-card p{ font-size:.92rem; flex:1; }
.post-card .text-link{ margin-top:1rem; }

/* Articulo */
.article{ max-width:760px; margin-inline:auto; }
.article p{ color:var(--text); font-size:1.12rem; line-height:1.8; }
.article h2{ color:var(--cream); margin:2.4rem 0 1rem; }
.article h3{ color:var(--cream); margin:2rem 0 .8rem; }
.article ul{ list-style:none; margin:0 0 1.4rem; }
.article ul li{ position:relative; padding-left:1.6rem; margin-bottom:.6rem; color:var(--muted); }
.article ul li::before{ content:""; position:absolute; left:0; top:.7em; width:7px; height:7px; background:var(--granate); border-radius:50%; }

/* ---------- Formulario ---------- */
.form-wrap{ background:var(--carbon-2); border:1px solid var(--line); padding:clamp(2rem,4vw,3.2rem); }
.field{ margin-bottom:1.4rem; }
.field label{ display:block; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:.6rem; }
.field input, .field textarea, .field select{
  width:100%; padding:.95rem 1.1rem; background:var(--carbon); border:1px solid var(--line-soft);
  color:var(--text); font-family:var(--sans); font-size:1rem; border-radius:var(--radius);
  transition:border-color .3s, background .3s;
}
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--gold); background:var(--carbon-3); }
.field textarea{ resize:vertical; min-height:130px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; }
.form-note{ font-size:.82rem; color:var(--muted-2); margin-top:.5rem; }
.honeypot{ position:absolute; left:-9999px; opacity:0; }
.alert{ padding:1rem 1.3rem; border-radius:var(--radius); margin-bottom:1.6rem; font-size:.94rem; }
.alert--ok{ background:rgba(31,122,77,.15); border:1px solid rgba(31,122,77,.5); color:#9fe3bf; }
.alert--err{ background:rgba(192,26,72,.12); border:1px solid rgba(192,26,72,.5); color:#f0a9bd; }

/* contact aside */
.contact-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(2.5rem,5vw,4.5rem); align-items:start; }
.contact-info .ci-item{ display:flex; gap:1.1rem; padding:1.5rem 0; border-bottom:1px solid var(--line-soft); align-items:flex-start; }
.contact-info .ci-item:first-child{ padding-top:0; }
.ci-ico{ width:40px; height:40px; flex:0 0 auto; border:1px solid var(--line); display:grid; place-items:center; color:var(--gold); }
.ci-ico svg{ width:19px; height:19px; }
.ci-item h4{ font-family:var(--sans); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin:0 0 .35rem; }
.ci-item a, .ci-item p{ color:var(--cream); font-size:1.05rem; margin:0; }
.ci-item a:hover{ color:var(--gold-2); }

/* ---------- Consentimiento (checkbox) ---------- */
.field-check{ margin:1.5rem 0 1.2rem; }
.check{ display:flex; gap:.8rem; align-items:flex-start; cursor:pointer; font-size:.9rem; color:var(--muted); line-height:1.55; }
.check input{ flex:0 0 auto; width:20px; height:20px; margin-top:.12rem; accent-color:var(--granate); cursor:pointer; }
.check a{ color:var(--gold-2); border-bottom:1px solid var(--line); }
.check a:hover{ color:var(--gold); border-color:var(--gold); }

/* ---------- Mapa carga al pulsar ---------- */
.map-box{ position:relative; min-height:420px; overflow:hidden; }
.map-box iframe{ display:block; width:100%; height:420px; border:0; filter:grayscale(.3) contrast(1.05); }
.map-placeholder{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1rem; text-align:center; padding:2rem; background:linear-gradient(160deg,var(--carbon-2),var(--surface)); color:var(--muted); }
.map-placeholder svg{ color:var(--gold); }
.map-placeholder p{ margin:0; color:var(--text); font-size:1.05rem; }
.map-note{ font-size:.76rem; color:var(--muted-2); max-width:34ch; }

/* ---------- Footer ---------- */
.site-footer{ background:#08060700; border-top:1px solid var(--line); padding-block:4.5rem 2rem; background:var(--carbon-2); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2.5rem; }
.footer-brand .brand__name{ font-size:1.5rem; }
.footer-brand p{ margin-top:1.2rem; font-size:.94rem; max-width:30ch; }
.footer-col h4{ font-family:var(--sans); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin:0 0 1.3rem; }
.footer-col a{ display:block; color:var(--muted); font-size:.95rem; padding:.4rem 0; transition:color .3s, padding-left .3s; }
.footer-col a:hover{ color:var(--cream); padding-left:.4rem; }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; margin-top:3.5rem; padding-top:1.8rem; border-top:1px solid var(--line-soft); font-size:.8rem; color:var(--muted-2); }
.footer-bottom a:hover{ color:var(--gold); }

/* ---------- Boton flotante WhatsApp + arriba ---------- */
.fab{ position:fixed; right:1.4rem; bottom:1.4rem; z-index:90; display:flex; flex-direction:column; gap:.8rem; }
.fab a, .fab button{
  width:54px; height:54px; border-radius:50%; display:grid; place-items:center;
  border:1px solid var(--line); background:var(--carbon-3); color:var(--cream);
  box-shadow:0 10px 30px -8px rgba(0,0,0,.6); transition:transform .3s var(--ease), background .3s;
}
.fab svg{ width:24px; height:24px; }
.fab .fab--wa{ background:#1f7a4d; border-color:#1f7a4d; }
.fab a:hover, .fab button:hover{ transform:translateY(-4px) scale(1.05); }
.fab .to-top{ opacity:0; visibility:hidden; transition:opacity .3s, visibility .3s, transform .3s; }
.fab .to-top.show{ opacity:1; visibility:visible; }

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; }

/* ====================================================================
   COMPONENTES DE CONVERSIÓN Y AUTORIDAD
   ==================================================================== */

/* Barra superior de anuncio/autoridad */
.topbar{
  background:linear-gradient(90deg,var(--granate-deep),var(--granate));
  color:var(--cream); font-size:.76rem; letter-spacing:.04em;
  text-align:center; padding:.5rem 1rem; position:relative; z-index:101;
}
.topbar a{ color:var(--cream); font-weight:600; text-decoration:underline; text-underline-offset:2px; }
.topbar strong{ color:#fff; }
.topbar .sep{ opacity:.5; margin:0 .6rem; }
@media (max-width:620px){ .topbar .hide-sm{ display:none; } }

/* Badges de autoridad en hero */
.hero__badges{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:2rem; }
.badge{
  display:inline-flex; align-items:center; gap:.5rem;
  border:1px solid var(--line); background:rgba(12,10,11,.4); backdrop-filter:blur(4px);
  padding:.5rem .9rem; font-size:.72rem; letter-spacing:.08em; color:var(--text);
  border-radius:100px;
}
.badge svg{ width:15px; height:15px; color:var(--gold); }
.hero__trust{ margin-top:2rem; display:flex; align-items:center; gap:1rem; flex-wrap:wrap; font-size:.8rem; color:var(--muted); }
.hero__trust .stars{ color:var(--gold-2); letter-spacing:2px; }

/* Tira de logos/escenarios de autoridad */
.logos-strip{ border-block:1px solid var(--line); background:var(--carbon-2); }
.logos-strip__inner{ display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:1rem 2.6rem; padding:2rem 0; }
.logos-strip__label{ width:100%; text-align:center; font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; color:var(--muted-2); margin-bottom:.4rem; }
.logo-item{ font-family:var(--serif); font-size:1.45rem; font-style:italic; color:var(--gold-2); white-space:nowrap; opacity:.92; transition:opacity .3s, transform .3s; }
.logo-item:hover{ opacity:1; transform:translateY(-2px); }
.logo-item .small{ font-family:var(--sans); font-style:normal; font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted-2); display:block; text-align:center; margin-top:2px; }

/* Sellos de confianza / garantías */
.guarantees{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.guarantee{ text-align:center; padding:1.6rem 1rem; border:1px solid var(--line-soft); }
.guarantee svg{ width:30px; height:30px; color:var(--gold); margin-bottom:.7rem; stroke-width:1.2; }
.guarantee h4{ font-family:var(--sans); font-size:.92rem; color:var(--cream); margin:0 0 .3rem; letter-spacing:.02em; }
.guarantee p{ font-size:.82rem; margin:0; color:var(--muted-2); }
@media (max-width:720px){ .guarantees{ grid-template-columns:repeat(2,1fr); } }

/* Las Vegas / autoridad — collage */
.vegas{ display:grid; grid-template-columns:1.2fr 1fr; gap:1.4rem; }
.vegas__main{ position:relative; overflow:hidden; }
.vegas__main img{ width:100%; height:100%; object-fit:cover; min-height:330px; max-height:430px; }
.vegas__col{ display:grid; grid-template-rows:1fr 1fr; gap:1.2rem; }
.vegas__cell{ position:relative; overflow:hidden; }
.vegas__cell img{ width:100%; height:100%; object-fit:cover; min-height:155px; max-height:210px; transition:transform 1s var(--ease); }
.vegas__cell:hover img, .vegas__main:hover img{ transform:scale(1.05); }
.vegas__cell .cap, .vegas__main .cap{ position:absolute; left:0; bottom:0; right:0; padding:1.2rem; background:linear-gradient(transparent,rgba(10,7,8,.9)); font-size:.78rem; letter-spacing:.06em; color:var(--cream); }
.vegas__cell .cap strong, .vegas__main .cap strong{ color:var(--gold-2); }
@media (max-width:820px){ .vegas{ grid-template-columns:1fr; } .vegas__col{ grid-template-columns:1fr 1fr; grid-template-rows:none; } }

/* Calculadora de jamón */
.calc{ background:linear-gradient(160deg,var(--surface-2),var(--carbon-2)); border:1px solid var(--line); padding:clamp(2rem,4vw,3.4rem); }
.calc__top{ display:grid; grid-template-columns:1fr auto; gap:1.5rem; align-items:end; }
.calc__field label{ display:block; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:.7rem; }
.calc__field input{ width:100%; padding:1rem 1.2rem; background:var(--carbon); border:1px solid var(--line); color:var(--cream); font-size:1.4rem; font-family:var(--serif); border-radius:var(--radius); }
.calc__field input:focus{ outline:none; border-color:var(--gold); }
.calc__btn{ white-space:nowrap; }
.calc__out{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:2rem; }
.calc__res{ text-align:center; padding:1.6rem 1rem; background:var(--carbon); border:1px solid var(--line-soft); }
.calc__res .n{ font-family:var(--serif); font-size:2.6rem; color:var(--gold-2); line-height:1; }
.calc__res .l{ font-size:.8rem; color:var(--muted); margin-top:.5rem; }
.calc__note{ margin-top:1.6rem; font-size:.86rem; color:var(--muted-2); }
.calc__cta{ margin-top:1.6rem; }
@media (max-width:620px){ .calc__top{ grid-template-columns:1fr; } .calc__out{ grid-template-columns:1fr; } .calc__btn{ width:100%; } }

/* Testimonios (cita real de invitado) */
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.testi{ background:var(--carbon-2); border:1px solid var(--line-soft); padding:2rem; position:relative; }
.testi .stars{ color:var(--gold-2); letter-spacing:2px; font-size:.9rem; margin-bottom:1rem; }
.testi p{ font-family:var(--serif); font-style:italic; font-size:1.18rem; color:var(--text); line-height:1.5; margin:0 0 1.2rem; }
.testi cite{ font-style:normal; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); }
@media (max-width:820px){ .testi-grid{ grid-template-columns:1fr; } }

/* Zonas de servicio (SEO local) */
.zonas{ display:flex; flex-wrap:wrap; gap:.7rem; justify-content:center; margin-top:2rem; }
.zona{ border:1px solid var(--line); padding:.6rem 1.2rem; font-size:.86rem; color:var(--text); border-radius:100px; transition:border-color .3s, color .3s, background .3s; }
.zona:hover{ border-color:var(--gold); color:var(--gold-2); }
.zona--lleida{ background:var(--granate); border-color:var(--granate); color:var(--cream); font-weight:600; }

/* Sticky CTA móvil */
.sticky-cta{
  position:fixed; left:0; right:0; bottom:0; z-index:95;
  display:none; grid-template-columns:1fr 1fr 1fr;
  background:rgba(10,8,9,.96); backdrop-filter:blur(12px); border-top:1px solid var(--line);
}
.sticky-cta a{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.2rem;
  padding:.7rem; font-size:.68rem; letter-spacing:.06em; text-transform:uppercase; color:var(--text);
  border-right:1px solid var(--line-soft);
}
.sticky-cta a:last-child{ border-right:0; }
.sticky-cta a svg{ width:20px; height:20px; }
.sticky-cta a.call{ color:var(--gold-2); }
.sticky-cta a.wa{ color:#4ad07f; }
.sticky-cta a.book{ background:var(--granate); color:var(--cream); }
@media (max-width:860px){
  .sticky-cta{ display:grid; }
  .fab{ bottom:5.4rem; }
  .fab .fab--wa{ display:none; }
  body{ padding-bottom:62px; }
  .site-footer{ padding-bottom:3rem; }
}

/* CTA inline reutilizable */
.cta-inline{ display:flex; flex-wrap:wrap; gap:1rem; align-items:center; }

/* Mini-FAQ precio destacado */
.price-hint{ display:inline-flex; align-items:center; gap:.6rem; background:var(--gold-soft); border:1px solid var(--line); padding:.6rem 1.1rem; border-radius:100px; font-size:.84rem; color:var(--gold-2); }

/* ---------- Responsive ---------- */
@media (max-width:980px){
  :root{ --space:clamp(3.5rem,8vw,5.5rem); }
  .split{ grid-template-columns:1fr; gap:2.5rem; }
  .split--rev .split__media{ order:0; }
  .services{ grid-template-columns:1fr; }
  .svc--wide{ grid-column:span 1; }
  .steps{ grid-template-columns:1fr; }
  .posts{ grid-template-columns:repeat(2,1fr); }
  .gallery{ columns:2; }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:2rem; }
  .nav__menu, .nav__phone{ display:none; }
  .nav__toggle{ display:inline-grid; place-items:center; }
}
@media (max-width:560px){
  :root{ --space:clamp(3rem,9vw,4.5rem); }
  .container, .narrow{ width:min(100% - 1.8rem, var(--container)); }
  .values{ grid-template-columns:1fr; }
  .value{ border-right:0; }
  .posts{ grid-template-columns:1fr; }
  .gallery{ columns:1; }
  .field-row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero{ min-height:90svh; }
  .btn{ width:100%; justify-content:center; }
  .hero__actions .btn, .cta-band__actions .btn{ width:auto; }
}

/* reduce motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.01ms !important; }
  html{ scroll-behavior:auto; }
}
