  /* ───── Hero ───── */
  .hero{
    padding:clamp(48px,8vh,90px) 0;
    position:relative;background:var(--paper-2);overflow:hidden;
    height:calc(85dvh - var(--header-h, 103px));
    min-height:520px;
    display:flex;align-items:center;
    box-sizing:border-box;
  }

  /* imagen arranca donde termina el bloque de texto, en cualquier pantalla */
  .hero-img{
    position:absolute;
    right:0; top:0; bottom:0; width:auto; height:100%;
    object-fit:cover; object-position:right center;
    display:block; pointer-events:none;
    filter:saturate(0.72);
  }
  .hero-grain{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    opacity:.22;mix-blend-mode:multiply;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.78' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size:140px 140px;
    animation:hero-grain .45s steps(1) infinite;
  }
  /* viñeta 35mm */
  .hero-vignette{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    background:radial-gradient(ellipse 80% 90% at 60% 50%, transparent 45%, rgba(20,16,10,.45) 100%);
  }
  @keyframes hero-grain{
    0%   {background-position:  0%   0%}
    11%  {background-position: -5%  -10%}
    22%  {background-position:-15%   5%}
    33%  {background-position:  7% -25%}
    44%  {background-position: 20%  25%}
    55%  {background-position:-25%  10%}
    66%  {background-position: 15%   5%}
    77%  {background-position:  0%  15%}
    88%  {background-position: 25%  35%}
  }
  .hero-fade{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    background:linear-gradient(
      to right,
      var(--paper-2) calc(max(32px, (100vw - 1240px) / 2) + 390px),
      rgba(232,225,212,.88) calc(max(32px, (100vw - 1240px) / 2) + 520px),
      transparent calc(max(32px, (100vw - 1240px) / 2) + 680px)
    );
  }
  .hero .wrap{position:relative;z-index:2;width:100%}
  .hero-inner{max-width:480px}

  @media (max-width:880px){
    .hero-img{left:0;right:0;top:auto;bottom:0;width:100%;height:52%;object-position:center top}
    .hero-fade{background:linear-gradient(to bottom, var(--paper-2) 48%, rgba(232,225,212,.75) 72%, transparent 100%)}
    .hero{padding:clamp(36px,6vh,60px) 0;align-items:flex-start}
    .hero-inner{max-width:100%}
  }
  @media (max-width:600px){
    .hero{padding:clamp(40px,6vh,56px) 0;height:70dvh}
    .hero-img{height:58%}
    .hero .eyebrow{font-size:10px;letter-spacing:.16em;gap:10px}
    .hero .eyebrow .line{width:24px}
  }

  .hero h1{
    font-family:var(--display);
    font-weight:300;
    font-size:clamp(28px, 3.8vw, 52px);
    line-height:1.1;
    letter-spacing:-.028em;
    max-width:18ch;
    color:var(--ink);
    margin-bottom:24px;
  }
  .hero h1 em{font-style:normal;font-weight:600;letter-spacing:-.032em;color:var(--ink)}

  .hero .lede{
    font-family:var(--display);
    font-weight:300;
    font-size:clamp(17px, 1.5vw, 21px);
    line-height:1.6;
    letter-spacing:-.005em;
    color:var(--ink-soft);
    max-width:54ch;
  }
  .hero .lede b{font-weight:500;color:var(--ink)}
  .hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
  .hero .eyebrow{
    display:flex;align-items:center;gap:14px;
    font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-mute);
    margin-bottom:20px;
  }
  .hero .eyebrow .line{width:36px;height:1px;background:var(--ink);opacity:.5;display:inline-block}
  .hero .rule{
    width:48px;height:1px;background:var(--ink);opacity:.5;
    margin-bottom:32px;
  }
  /* ───── Marquee bodegas ───── */
  .marquee{
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    padding:18px 0;overflow:hidden;background:var(--paper);
    margin-top:30px;position:relative;
    -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
    mask-image:linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
  }
  .marquee-track{
    display:flex;gap:0;white-space:nowrap;
    animation:marquee 24s linear infinite;
    will-change:transform;
  }
  .marquee-track:hover{animation-play-state:paused}
  .marquee-item{
    font-family:var(--display);font-weight:300;
    font-size:clamp(16px,1.6vw,22px);
    padding:0 26px;color:var(--ink);letter-spacing:-.005em;
    display:inline-flex;align-items:center;gap:26px;
  }
  .marquee-item::after{content:"❋";font-size:.6em;color:var(--ink-mute);transform:translateY(-1px)}
  @keyframes marquee{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

  /* ───── Sección genérica ───── */
  section{padding:110px 0;border-top:1px solid var(--line-soft);scroll-margin-top:80px}
  @media (max-width:720px){ section{padding:72px 0;scroll-margin-top:60px} }
  .label{
    font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-mute);
    display:inline-flex;align-items:center;gap:12px;margin-bottom:28px;
  }
  .label::before{content:"";width:24px;height:1px;background:var(--ink);opacity:.5}

  h2{
    font-family:var(--display);font-weight:200;
    font-size:clamp(32px,4.2vw,56px);line-height:1.08;letter-spacing:-.025em;
    max-width:18ch;
  }
  h2 em{font-style:normal;font-weight:500;letter-spacing:-.03em}

  /* ───── "Lo que vas a encontrar" ───── */
  .offer-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:54px}
  .offer-head p{max-width:38ch;color:var(--ink-soft)}

  .offer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
  .offer-card{
    padding:38px 30px 34px;border-right:1px solid var(--line);
    display:flex;flex-direction:column;gap:18px;min-height:280px;
    transition:background .3s ease, transform .35s ease;
  }
  .offer-card:last-child{border-right:none}
  .offer-card:hover{background:var(--paper-2);transform:translateY(-3px)}
  .offer-card .ico{transition:transform .4s ease}
  .offer-card:hover .ico{transform:translateY(-2px) rotate(-2deg)}
  .offer-card .num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--ink-mute)}
  .offer-card .ico{width:34px;height:34px;color:var(--ink)}
  .offer-card h3{font-family:var(--display);font-weight:500;font-size:20px;line-height:1.25;letter-spacing:-.015em}
  .offer-card p{font-size:14px;line-height:1.6;color:var(--ink-soft);margin-top:auto}
  @media (max-width:880px){ .offer-grid{grid-template-columns:1fr} .offer-card{border-right:none!important;border-bottom:1px solid var(--line)} .offer-card:last-child{border-bottom:none} }

  /* ───── Filosofía · 100vh ───── */
  .creed{
    background:var(--paper-2);padding:48px 0;position:relative;overflow:hidden;
    height:calc(100svh - 80px);box-sizing:border-box;
    display:flex;flex-direction:column;justify-content:center;
  }
  .creed .wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  @media (max-width:880px){ .creed .wrap{grid-template-columns:1fr;gap:36px} .creed{height:auto;padding:72px 0} }

  .creed .label{margin-bottom:20px}
  .creed blockquote{
    font-family:var(--display);font-weight:200;
    font-size:clamp(24px,2.8vw,38px);line-height:1.18;letter-spacing:-.025em;
    max-width:18ch;margin:0;color:var(--ink);
  }
  .creed blockquote em{font-style:normal;font-weight:500}
  .creed blockquote::before{content:"\201C";display:block;font-size:1.4em;line-height:.4;margin-bottom:.25em;opacity:.35;font-weight:300}
  .creed cite{display:block;font-style:normal;margin-top:22px;font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mute)}

  .creed-body{display:flex;flex-direction:column;gap:16px;padding-top:10px}
  .creed-body p{
    font-family:var(--display);font-weight:300;
    font-size:clamp(14px,1.1vw,16px);line-height:1.65;color:var(--ink-soft);
    letter-spacing:-.005em;max-width:46ch;
  }
  .creed-body p b{font-weight:500;color:var(--ink)}

  .creed-pillars{
    display:grid;grid-template-columns:repeat(3,1fr);gap:0;
    margin-top:24px;border-top:1px solid var(--line);
  }
  .creed-pillars > div{padding:22px 18px 22px 0;border-right:1px solid var(--line)}
  .creed-pillars > div + div{padding-left:20px}
  .creed-pillars > div:last-child{border-right:none;padding-right:0}
  .creed-pillars dt{
    font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
    color:var(--ink-mute);margin-bottom:8px;
  }
  .creed-pillars dd{
    font-family:var(--display);font-weight:400;font-size:14px;line-height:1.4;color:var(--ink);
    letter-spacing:-.005em;margin:0;
  }
  @media (max-width:560px){
    .creed-pillars{grid-template-columns:1fr}
    .creed-pillars > div{border-right:none;border-bottom:1px solid var(--line);padding:16px 0}
    .creed-pillars > div + div{padding-left:0}
    .creed-pillars > div:last-child{border-bottom:none}
  }

  /* ───── Galería bodegas ───── */
  .gal-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:54px}
  .gal-head p{max-width:38ch;color:var(--ink-soft)}

  .gal{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}

  /* ───── Bodegas elegidas · grid cuadrada ───── */
  #bodegas{ padding:110px 0 }

  .elegidas-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
  }
  .elegida-item{
    display:flex;flex-direction:column;gap:0;
  }
  .elegida-img{
    width:100%;aspect-ratio:1/1;
    overflow:hidden;border:1px solid var(--line);
    position:relative;
  }
  .elegida-img img{
    width:100%;height:100%;object-fit:cover;display:block;
    transition:transform .7s ease;
  }
  .elegida-item:hover .elegida-img img{transform:scale(1.04)}
  .elegida-text{
    padding:16px 0 0;
    display:flex;flex-direction:column;gap:6px;
  }
  .elegida-proc{
    font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
    color:var(--ink-mute);opacity:.65;
  }
  .elegida-nombre{
    font-family:var(--display);font-weight:500;
    font-size:clamp(16px,1.5vw,19px);line-height:1.25;letter-spacing:-.015em;
    color:var(--ink);
  }
  .elegida-copy{
    font-family:var(--sans);font-weight:300;font-size:13px;line-height:1.6;
    color:var(--ink-soft);margin-top:2px;
  }
  /* stagger */
  .js .elegidas-grid > [data-reveal]:nth-child(1){transition-delay:0ms}
  .js .elegidas-grid > [data-reveal]:nth-child(2){transition-delay:90ms}
  .js .elegidas-grid > [data-reveal]:nth-child(3){transition-delay:180ms}
  .js .elegidas-grid > [data-reveal]:nth-child(4){transition-delay:270ms}
  /* mobile: slider horizontal */
  /* tablet: 2 columnas */
  @media(max-width:880px){
    .elegidas-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  }
  @media(max-width:600px){
    .elegidas-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
  }

  .gal .ph{
    background:var(--paper-2);
    border:1px solid var(--line);
    position:relative;
    overflow:hidden;
    display:flex;align-items:center;justify-content:center;
  }
  .gal .ph::before{
    content:"";position:absolute;inset:0;
    background-image:repeating-linear-gradient(
      135deg,
      transparent 0 14px,
      rgba(41,41,37,.045) 14px 15px
    );
  }
  .gal .ph .cap{
    position:relative;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    color:var(--ink-mute);text-align:center;padding:14px 18px;line-height:1.6;
    background:var(--paper);border:1px solid var(--line);
  }
  .gal .ph .cap b{display:block;color:var(--ink);font-weight:400;letter-spacing:.22em;margin-bottom:6px}

  /* layout explícito: Apotema arriba izq · Yuyos 1 portrait columna derecha · La Inc + Yuyos 2 abajo izq */
  .gal .a{grid-column:1/9;grid-row:1;aspect-ratio:4/3}
  .gal .b{grid-column:9/13;grid-row:1/3;aspect-ratio:2/3}
  .gal .c{grid-column:1/5;grid-row:2;aspect-ratio:1/1}
  .gal .d{grid-column:5/9;grid-row:2;aspect-ratio:16/9}
  .gal-img{overflow:hidden;position:relative;border:1px solid var(--line)}
  .gal-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s ease}
  .gal-img:hover img{transform:scale(1.04)}
  @media (max-width:780px){
    .gal{gap:14px}
    .gal .a,.gal .b,.gal .c,.gal .d{grid-column:1/13;grid-row:auto;aspect-ratio:4/3}
  }

  /* ───── Visitanos ───── */
  #visitanos{
    padding:48px 0;
    height:calc(100svh - 80px);
    box-sizing:border-box;
    display:flex;flex-direction:column;
  }
  #visitanos .wrap{flex:1;min-height:0;display:flex;flex-direction:column}
  #visitanos .label{flex-shrink:0;margin-bottom:20px}
  #visitanos .visit{flex:1;min-height:0}
  #visitanos .visit-map{min-height:0}
  #visitanos .visit-info{padding:40px 40px}
  @media(max-width:880px){
    #visitanos{height:auto;display:block;padding:72px 0}
    #visitanos .wrap{display:block}
    #visitanos .visit{flex:none}
    #visitanos .visit-map{min-height:340px}
  }
  .visit{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line)}
  .visit-info{padding:60px 50px}
  .visit-info h2{margin-bottom:38px}
  .visit-info dl{display:grid;grid-template-columns:auto 1fr;column-gap:32px;row-gap:18px;margin-bottom:36px}
  .visit-info dt{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);padding-top:5px}
  .visit-info dd{font-family:var(--display);font-weight:400;font-size:18px;line-height:1.4;color:var(--ink);letter-spacing:-.005em}
  .visit-info dd small{display:block;font-family:var(--sans);font-weight:300;font-size:13px;color:var(--ink-soft);margin-top:4px;letter-spacing:0}

  .visit-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}

  .visit-map{
    background:var(--paper-2);
    position:relative;
    border-left:1px solid var(--line);
    min-height:520px;
    overflow:hidden;
    display:block;
    text-decoration:none;
    cursor:pointer;
    transition:filter .35s ease;
  }
  .visit-map:hover{filter:brightness(.97)}
  .visit-map .map-hint{
    position:absolute;left:24px;top:24px;z-index:3;
    font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);
    background:var(--paper);border:1px solid var(--ink);padding:8px 12px;
    display:inline-flex;align-items:center;gap:8px;
    transition:background .25s, color .25s;
  }
  .visit-map:hover .map-hint{background:var(--ink);color:var(--paper)}
  .visit-map .map-hint svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:1.6}
  .visit-map .addr-stamp{
    position:absolute;right:24px;bottom:24px;z-index:3;
    font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);
    background:var(--paper);border:1px solid var(--ink);padding:10px 14px;
  }
  .visit-map svg{position:absolute;inset:0;width:100%;height:100%;display:block}
  .pin{
    position:absolute;left:50%;top:48%;transform:translate(-50%,-100%);
    display:flex;flex-direction:column;align-items:center;gap:6px;
  }
  .pin .label{
    font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
    background:var(--paper);border:1px solid var(--ink);padding:6px 10px;color:var(--ink);white-space:nowrap;
  }
  .pin .dotwrap{position:relative;width:14px;height:14px}
  .pin .dotwrap::before,.pin .dotwrap::after{content:"";position:absolute;border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%)}
  .pin .dotwrap::before{width:14px;height:14px;background:var(--ink)}
  .pin .dotwrap::after{width:30px;height:30px;border:1px solid var(--ink);opacity:.45;animation:pulse 2.4s ease-in-out infinite}

  @media (max-width:880px){
    .visit{grid-template-columns:1fr}
    .visit-map{border-left:none;border-top:1px solid var(--line);min-height:340px}
    .visit-info{padding:42px 28px}
  }
  @media (max-width:600px){
    .visit-info dd{font-size:14px}
    .visit-info dt{font-size:10px}
  }

  /* ───── FAQ pequeño ───── */
  .faq{display:grid;grid-template-columns:.6fr 1fr;gap:60px}
  .faq h2{margin-bottom:0}
  .faq-list{border-top:1px solid var(--line)}
  .faq-list details{border-bottom:1px solid var(--line);padding:24px 0}
  .faq-list summary{
    list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;
    font-family:var(--display);font-weight:400;font-size:18px;line-height:1.35;color:var(--ink);letter-spacing:-.01em;
  }
  .faq-list summary::-webkit-details-marker{display:none}
  .faq-list summary::after{content:"+";font-family:var(--sans);font-weight:300;font-size:24px;color:var(--ink-mute);transition:transform .25s}
  .faq-list details[open] summary::after{transform:rotate(45deg)}
  .faq-list details p{margin-top:14px;color:var(--ink-soft);font-size:15px;line-height:1.65;max-width:60ch}
  @media (max-width:780px){ .faq{grid-template-columns:1fr;gap:24px} }
