﻿:root{
    --paper:#efe7d8;
    --paper2:#e6dccb;
    --espresso:#1b1612;
    --espresso2:#231c17;
    --ink:#2a2521;
    --ink-soft:#6a5f54;
    --burgundy:#6b2230;
    --navy:#1f2c4c;
    --forest:#2c3d33;
    --cork:#b9854a;
    --line:rgba(42,37,33,.16);
    --line-light:rgba(239,231,216,.16);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    background:var(--paper);
    color:var(--ink);
    font-family:'Spectral',serif;
    font-weight:400;
    line-height:1.7;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }
  .wrap{max-width:1240px;margin:0 auto;padding:0 36px}
  @media(max-width:680px){.wrap{padding:0 22px}}

  .display{font-family:'Bodoni Moda',serif;font-weight:500;letter-spacing:.01em;line-height:1.02}
  .eyebrow{font-family:'Spectral',serif;font-size:.74rem;letter-spacing:.34em;text-transform:uppercase}
  h2.sec{font-family:'Bodoni Moda',serif;font-weight:500;font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1.06;letter-spacing:.01em}
  .sec em{font-style:italic}

  .moon{display:inline-block;vertical-align:middle}
  .moon .lhalf{fill:currentColor}
  .moon .rhalf{stroke:currentColor;stroke-width:1.1}

  .mark{font-family:'Bodoni Moda',serif;font-weight:500;letter-spacing:.04em;position:relative;white-space:nowrap}
  .mark .star{font-size:.5em;vertical-align:.55em;margin:0 .02em}

  /* official logo */
  .brand-logo{display:block;height:30px;line-height:0}
  .brand-logo img{height:100%;width:auto;display:block}
  .brand-logo .lg-dark{display:none}
  nav.scrolled .brand-logo .lg-light{display:none}
  nav.scrolled .brand-logo .lg-dark{display:block}
  .hero-logo{width:min(560px,84vw);height:auto;display:block;opacity:0;transform:translateY(28px);
    animation:rise 1.1s .25s forwards;filter:drop-shadow(0 10px 34px rgba(0,0,0,.45))}
  .foot-logo{height:46px;width:auto;display:block}
  @media(max-width:680px){.foot-logo{height:38px}}

  nav{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;justify-content:space-between;align-items:center;
    padding:22px 40px;transition:all .4s ease;color:var(--paper)}
  nav.scrolled{background:var(--paper);color:var(--ink);padding:14px 40px;box-shadow:0 1px 0 var(--line)}
  nav .mark{font-size:1.45rem}
  .nav-links{display:flex;gap:32px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-family:'Spectral',serif}
  .nav-links a{color:inherit;text-decoration:none;opacity:.82;transition:opacity .3s}
  .nav-links a:hover{opacity:1}
  @media(max-width:820px){.nav-links{display:none}nav{padding:18px 22px}}

  header{position:relative;height:100vh;min-height:640px;display:flex;align-items:flex-end;color:var(--paper);overflow:hidden}
  .hero-bg{position:absolute;inset:0;background-position:center 38%;background-size:cover;transform:scale(1.06);will-change:transform}
  video.hero-bg{width:100%;height:100%;object-fit:cover;object-position:center 38%;background:#11100c}
  .hero-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,16,12,.55) 0%,rgba(20,16,12,.15) 38%,rgba(20,16,12,.78) 100%)}
  .hero-inner{position:relative;z-index:2;width:100%;padding-bottom:9vh}
  .hero-inner .eyebrow{opacity:0;animation:rise 1s .2s forwards;margin-bottom:24px}
  .hero-mark{font-family:'Bodoni Moda',serif;font-weight:500;font-size:clamp(3.4rem,13vw,11rem);line-height:.9;letter-spacing:.02em;overflow:hidden}
  .hero-mark span{display:inline-block;transform:translateY(115%);animation:slideUp 1.2s cubic-bezier(.22,1,.36,1) .15s forwards}
  .hero-mark .star{font-size:.34em;vertical-align:.7em}
  .hero-sub{font-style:italic;font-size:clamp(1.05rem,2.2vw,1.5rem);max-width:30ch;margin-top:22px;color:#efe7d8cc;opacity:0;animation:rise 1s .8s forwards}
  .hero-cta{display:inline-block;margin-top:30px;opacity:0;animation:rise 1s 1s forwards}
  .scroll-hint{position:absolute;bottom:30px;right:40px;z-index:3;font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;display:flex;align-items:center;gap:12px;opacity:0;animation:rise 1s 1.1s forwards}
  .scroll-hint::after{content:"";width:44px;height:1px;background:var(--paper);transform-origin:right;animation:lineGrow 2.4s 1.3s infinite ease-in-out}
  @media(max-width:820px){.scroll-hint{right:22px}}

  .manifesto{padding-top:120px;padding-bottom:110px;text-align:center}
  .manifesto .moon{color:var(--burgundy);margin-bottom:30px}
  .manifesto .lead{font-family:'Bodoni Moda',serif;font-weight:400;font-style:italic;font-size:clamp(1.5rem,3.4vw,2.5rem);line-height:1.32;max-width:20ch;margin:0 auto;color:var(--ink)}
  .manifesto p.body{max-width:60ch;margin:32px auto 0;color:var(--ink-soft);font-size:1.08rem}

  .story{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;border-top:1px solid var(--line)}
  @media(max-width:860px){.story{grid-template-columns:1fr}}
  .story .txt{padding:90px 64px;display:flex;flex-direction:column;justify-content:center}
  @media(max-width:860px){.story .txt{padding:64px 26px}}
  .story .img{min-height:540px;background-size:cover;background-position:center}
  .story .label{color:var(--burgundy);margin-bottom:22px}
  .story p{color:var(--ink-soft);margin-top:18px;max-width:46ch}

  .label{font-family:'Spectral',serif;font-size:.74rem;letter-spacing:.3em;text-transform:uppercase;display:flex;align-items:center;gap:13px}
  .label::before{content:"";width:26px;height:1px;background:currentColor;opacity:.6}

  .expr{padding-top:110px;padding-bottom:110px}
  .expr-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:44px}
  .expr-head .label{color:var(--burgundy)}
  .lineup-band{width:100%;border-radius:4px;overflow:hidden;margin-bottom:60px;border:1px solid var(--line)}
  .lineup-band img{width:100%;display:block}
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch}
  .buy{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
  .buy .price{font-family:'Bodoni Moda',serif;font-size:1.5rem;color:var(--ink)}
  .buy-btn{display:inline-block;font-family:'Spectral',serif;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--paper);background:var(--ink);padding:13px 26px;border-radius:2px;text-decoration:none;transition:transform .3s ease,background .3s ease}
  .buy-btn:hover{transform:translateY(-2px);background:var(--burgundy)}
  .medals{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
  .medals .row{display:flex;gap:12px;align-items:flex-start}
  .medals .m{width:54px;height:auto;flex:0 0 auto}
  .medals .ttl{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--navy);margin-bottom:12px}
  .medals .cap{font-size:.74rem;color:var(--ink-soft);margin-top:12px;line-height:1.5;font-style:italic}
  .award-flag{position:absolute;top:14px;right:14px;background:rgba(27,22,18,.62);color:var(--paper);
    font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;padding:7px 12px;border-radius:30px;backdrop-filter:blur(5px)}
  @media(max-width:860px){.cards{grid-template-columns:1fr;max-width:420px;margin:0 auto}}
  .card{background:var(--paper2);border-radius:5px;overflow:hidden;border:1px solid var(--line);transition:transform .5s cubic-bezier(.22,1,.36,1),box-shadow .5s;display:flex;flex-direction:column;height:100%}
  .card:hover{transform:translateY(-7px);box-shadow:0 28px 50px rgba(27,22,18,.22)}
  .card .ph{height:330px;background-size:cover;background-position:center;position:relative}
  .card .topbar{height:5px}
  .card .meta{padding:26px 24px 30px;display:flex;flex-direction:column;flex:1}
  .card .deg{font-family:'Bodoni Moda',serif;font-weight:500;font-size:2.6rem;line-height:1}
  .card h3{font-family:'Spectral',serif;font-weight:500;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;margin:14px 0 8px;color:var(--ink-soft)}
  .card p{font-size:.95rem;color:var(--ink-soft);margin-bottom:24px}
  .c37 .topbar{background:var(--forest)} .c37 .deg{color:var(--forest)}
  .c40 .topbar{background:var(--navy)} .c40 .deg{color:var(--navy)}
  .c55 .topbar{background:var(--burgundy)} .c55 .deg{color:var(--burgundy)}

  .proceso{background:var(--espresso);color:var(--paper)}
  .proceso .grid{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
  @media(max-width:860px){.proceso .grid{grid-template-columns:1fr}}
  .proceso .img{min-height:600px;background-size:cover;background-position:center}
  .proceso .txt{padding:96px 64px}
  @media(max-width:860px){.proceso .txt{padding:64px 26px}.proceso .img{min-height:420px}}
  .proceso .label{color:var(--cork)}
  .proceso h2.sec{margin:22px 0 10px}
  .proceso .credit{font-style:italic;color:#efe7d899;margin-bottom:34px}
  .steps{border-top:1px solid var(--line-light)}
  .step{display:grid;grid-template-columns:46px 1fr;gap:20px;padding:24px 0;border-bottom:1px solid var(--line-light);transition:padding-left .5s cubic-bezier(.22,1,.36,1)}
  .step:hover{padding-left:10px}
  .step .n{font-family:'Bodoni Moda',serif;font-style:italic;font-size:1.3rem;color:var(--cork)}
  .step h4{font-family:'Bodoni Moda',serif;font-weight:500;font-size:1.35rem;margin-bottom:4px}
  .step p{font-size:.94rem;color:#efe7d8aa}

  .galeria{padding-top:110px;padding-bottom:110px}
  .galeria .label{color:var(--burgundy);margin-bottom:40px}
  .grid-gal{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;grid-auto-rows:230px;grid-auto-flow:dense}
  .grid-gal figure{margin:0;overflow:hidden;border-radius:4px;cursor:zoom-in;position:relative;background:var(--paper2)}
  .grid-gal img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s cubic-bezier(.22,1,.36,1)}
  .grid-gal figure:hover img{transform:scale(1.05)}
  .gp1{grid-column:span 2;grid-row:span 2}
  .gp2{grid-column:span 2}
  .gp3{grid-column:span 2}
  .gp4{grid-column:span 2}
  .gp5{grid-column:span 3}
  .gp6{grid-column:span 3}
  .gp7{grid-column:span 6}
  @media(max-width:860px){.grid-gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}.gp1,.gp2,.gp3,.gp4,.gp5,.gp6,.gp7{grid-column:span 2;grid-row:span 1}}

  .ediciones{background:var(--espresso2);color:var(--paper);padding-top:110px;padding-bottom:110px}
  @media(max-width:860px){.ediciones{padding-top:80px;padding-bottom:80px}}
  .ed-head{max-width:62ch;margin:0 auto 56px;text-align:center}
  .ediciones .label{color:var(--cork);margin-bottom:22px;justify-content:center}
  .ediciones h2.sec{margin-bottom:20px}
  .ediciones p{color:#efe7d8b0;margin:0 auto}
  .bead-grid{display:flex;flex-wrap:wrap;gap:22px;justify-content:center}
  .bead-grid figure{margin:0;flex:0 1 calc(33.333% - 22px);max-width:300px;min-width:190px}
  @media(max-width:760px){.bead-grid figure{flex:0 1 calc(50% - 22px)}}
  .bead-grid .ph{aspect-ratio:2/3;border-radius:6px;overflow:hidden;background:#f4f1ea;cursor:zoom-in;box-shadow:0 22px 46px rgba(0,0,0,.42)}
  .bead-grid img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s cubic-bezier(.22,1,.36,1)}
  .bead-grid figure:hover img{transform:scale(1.05)}
  .bead-note{text-align:center;font-style:italic;color:#efe7d877;margin-top:40px;font-size:.95rem}

  .ficha{padding-top:96px;padding-bottom:96px;text-align:center}
  .ficha .moon{color:var(--burgundy);margin-bottom:26px}
  .ficha .row{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:46px;text-align:left}
  @media(max-width:680px){.ficha .row{grid-template-columns:repeat(2,1fr)}}
  .ficha .row div{border-top:1px solid var(--line);padding-top:16px}
  .ficha .v{font-family:'Bodoni Moda',serif;font-size:1.5rem}
  .ficha .k{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-top:4px}

  .cta{background:var(--burgundy);color:var(--paper);text-align:center;padding-top:130px;padding-bottom:130px}
  .cta h2{font-family:'Bodoni Moda',serif;font-weight:500;font-size:clamp(2.2rem,5vw,3.8rem);line-height:1.1;max-width:20ch;margin:0 auto 16px}
  .cta p{font-style:italic;color:#efe7d8cc;margin-bottom:38px}
  .btn{display:inline-block;font-family:'Spectral',serif;font-size:.76rem;letter-spacing:.26em;text-transform:uppercase;color:var(--burgundy);background:var(--paper);padding:19px 46px;text-decoration:none;border-radius:2px;transition:transform .35s cubic-bezier(.22,1,.36,1)}
  .btn:hover{transform:translateY(-3px)}

  footer{background:var(--espresso);color:var(--paper);padding:56px 0 40px}
  .foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
  .foot .mark{font-size:1.5rem}
  .foot .meta{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#efe7d899;text-align:right;line-height:1.9}
  .legal{margin-top:34px;padding-top:22px;border-top:1px solid var(--line-light);font-size:.72rem;color:#efe7d877;line-height:1.7}

  .reveal{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.22,1,.36,1),transform 1s cubic-bezier(.22,1,.36,1)}
  .reveal.in{opacity:1;transform:none}

  .lb{position:fixed;inset:0;z-index:120;background:rgba(15,11,8,.94);display:none;align-items:center;justify-content:center;padding:34px;cursor:zoom-out}
  .lb.open{display:flex}
  .lb img{max-width:92vw;max-height:90vh;object-fit:contain;border-radius:4px}

  /* age gate */
  body.gate-open{overflow:hidden}
  #agegate{position:fixed;inset:0;z-index:200;background:var(--espresso);color:var(--paper);display:flex;align-items:center;justify-content:center;text-align:center;padding:30px;overflow:hidden}
  #agegate .ag-bg{position:absolute;inset:0;background:url(../assets/images/image_001.jpg) center/cover no-repeat;filter:blur(7px) brightness(.4);transform:scale(1.1);z-index:0}
  #agegate .ag-inner{max-width:540px;position:relative;z-index:1}
  #agegate .ag-kicker{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--cork);margin-bottom:22px}
  #agegate .ag-mark{font-family:'Bodoni Moda',serif;font-weight:500;font-size:clamp(2.6rem,9vw,4.6rem);letter-spacing:.04em;line-height:1}
  #agegate .ag-logo{width:min(460px,82vw);height:auto;display:block;margin:0 auto}
  #agegate .ag-mark .star{font-size:.4em;vertical-align:.62em;margin:0 .02em}
  #agegate .ag-q{font-family:'Bodoni Moda',serif;font-style:italic;font-size:1.6rem;margin:34px 0 8px}
  #agegate .ag-sub{color:#efe7d8aa;font-size:.98rem;margin-bottom:32px}
  #agegate .ag-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
  #agegate button{font-family:'Spectral',serif;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;padding:16px 34px;border:1px solid var(--paper);border-radius:2px;cursor:pointer;transition:transform .3s ease,background .3s ease,color .3s ease;background:transparent;color:var(--paper)}
  #agegate button.yes{background:var(--paper);color:var(--espresso)}
  #agegate button:hover{transform:translateY(-2px)}
  #agegate .ag-legal{margin-top:36px;font-size:.7rem;color:#efe7d877;letter-spacing:.04em;line-height:1.6}
  #agegate .ag-denied{display:none}
  #agegate.denied .ag-form{display:none}
  #agegate.denied .ag-denied{display:block}

  @keyframes slideUp{to{transform:translateY(0)}}
  @keyframes rise{to{opacity:1;transform:translateY(0)}}
  @keyframes lineGrow{0%,100%{transform:scaleX(.25)}50%{transform:scaleX(1)}}
/* ============================================
   RESPONSIVE DESIGN - Mobile First Enhancements
   ============================================ */

/* --- Hamburger Menu Button --- */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:12px;z-index:70}
.nav-toggle span{display:block;width:28px;height:3px;background:currentColor;margin:6px 0;transition:transform .3s ease,opacity .3s ease;border-radius:2px;box-shadow:0 1px 2px rgba(0,0,0,0.3)}
.nav-toggle span:nth-child(1){transform-origin:top left}
.nav-toggle span:nth-child(3){transform-origin:bottom left}
.nav-open .nav-toggle span:nth-child(1){transform:rotate(45deg) translate(1px,-1px)}
.nav-open .nav-toggle span:nth-child(2){opacity:0}
.nav-open .nav-toggle span:nth-child(3){transform:rotate(-45deg) translate(1px,1px)}

/* --- Tablet Landscape (max-width: 1024px) --- */
@media(max-width:1024px){
  .wrap{max-width:100%;padding:0 28px}
  .manifesto{padding-top:90px;padding-bottom:80px}
  .expr{padding-top:80px;padding-bottom:80px}
  .galeria{padding-top:80px;padding-bottom:80px}
  .ficha{padding-top:72px;padding-bottom:72px}
  .cta{padding-top:90px;padding-bottom:90px}
  .proceso .txt{padding:72px 40px}
  .story .txt{padding:72px 40px}
}

/* --- Tablet Portrait (max-width: 860px) --- */
@media(max-width:860px){
  .story .img{min-height:380px}
  .grid-gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gp1,.gp2,.gp3,.gp4,.gp5,.gp6,.gp7{grid-column:span 1;grid-row:span 1}
  .gp1{grid-column:span 2;grid-row:span 2}
  .gp7{grid-column:span 2}
}

/* --- Mobile Navigation (max-width: 820px) --- */
@media(max-width:820px){
  .nav-toggle{display:block;color:inherit}
  .nav-links{
    display:flex;
    flex-direction:column;
    position:fixed;
    top:0;right:-100%;
    width:min(320px,85vw);
    height:100vh;height:100dvh;
    background:var(--espresso);
    color:var(--paper);
    padding:90px 36px 40px;
    gap:0;
    transition:right .4s cubic-bezier(.22,1,.36,1);
    box-shadow:-10px 0 40px rgba(0,0,0,.4);
    z-index:65;
    overflow-y:auto;
  }
  .nav-links a{
    font-size:.88rem;
    letter-spacing:.18em;
    opacity:1;
    padding:18px 0;
    border-bottom:1px solid var(--line-light);
    display:block;
  }
  .nav-open .nav-links{right:0}
  .nav-overlay{
    display:none;
    position:fixed;inset:0;
    background:rgba(0,0,0,.5);
    z-index:62;
  }
  .nav-open .nav-overlay{display:block}
}

/* --- Small Tablets & Large Phones (max-width: 680px) --- */
@media(max-width:680px){
  .wrap{padding:0 24px}
  nav{padding:16px 18px}
  nav.scrolled{padding:12px 18px}
  header{min-height:100vh;min-height:100dvh}
  .hero-inner{padding-bottom:7vh}
  .hero-logo{width:min(420px,80vw)}
  .hero-sub{font-size:1rem;max-width:26ch}
  .scroll-hint{right:18px;bottom:22px;font-size:.58rem}
  .manifesto{padding-top:64px;padding-bottom:56px}
  .manifesto .lead{font-size:clamp(1.3rem,5vw,1.8rem);max-width:18ch}
  .manifesto p.body{font-size:1.08rem;margin-top:24px}
  .story .txt{padding:56px 24px;text-align:center;align-items:center}
  .story .img{min-height:300px}
  .expr{padding-top:56px;padding-bottom:56px}
  .expr-head{margin-bottom:28px;flex-direction:column;align-items:flex-start}
  .expr-head p{max-width:100%!important}
  .lineup-band{margin-bottom:36px}
  .card .ph{height:280px}
  .card .meta{padding:22px 20px 26px}
  .card .deg{font-size:2.2rem}
  .buy{flex-direction:column;align-items:flex-start;gap:14px}
  .buy-btn{width:100%;text-align:center;padding:14px 20px}
  .medals .row{flex-wrap:wrap}
  .medals .m{width:44px}
  .proceso .img{min-height:320px}
  .proceso .txt{padding:56px 24px;text-align:center;align-items:center}
  .proceso h2.sec{font-size:clamp(1.8rem,6vw,2.6rem)}
  .step{grid-template-columns:36px 1fr;gap:14px;padding:18px 0}
  .galeria{padding-top:56px;padding-bottom:56px}
  .galeria .label{margin-bottom:24px}
  .grid-gal{gap:10px;grid-auto-rows:160px}
  .ediciones{padding-top:56px;padding-bottom:56px}
  .ed-head{margin-bottom:36px}
  .bead-grid{gap:14px}
  .bead-grid figure{flex:0 1 calc(50% - 14px);min-width:140px}
  .bead-note{margin-top:46px;font-size:.88rem}
  .ficha{padding-top:56px;padding-bottom:56px}
  .ficha .row{gap:20px;margin-top:32px}
  .ficha .v{font-size:1.3rem}
  .cta{padding-top:72px;padding-bottom:72px}
  .cta h2{font-size:clamp(1.8rem,6vw,2.8rem)}
  .cta p{font-size:.95rem}
  .btn{padding:16px 36px;font-size:.72rem;width:100%;text-align:center}
  footer{padding:40px 0 30px}
  .foot{flex-direction:column;align-items:center;text-align:center;gap:22px}
  .foot .meta{text-align:center}
  .legal{text-align:center}
  #agegate{padding:20px}
  #agegate .ag-q{font-size:1.3rem;margin:26px 0 6px}
  #agegate button{padding:14px 28px;font-size:.72rem}
}

/* --- Small Phones (max-width: 420px) --- */
@media(max-width:420px){
  .wrap{padding:0 20px}
  nav{padding:14px 14px}
  .hero-logo{width:min(300px,78vw)}
  .hero-sub{font-size:.92rem}
  .hero-inner{padding-bottom:5vh}
  h2.sec{font-size:clamp(1.6rem,6vw,2.2rem)}
  .manifesto .lead{font-size:clamp(1.2rem,5vw,1.5rem)}
  .manifesto p.body{font-size:1rem}
  .card .ph{height:240px}
  .card .deg{font-size:1.9rem}
  .card h3{font-size:.72rem}
  .card p{font-size:.95rem}
  .buy .price{font-size:1.3rem}
  .step h4{font-size:1.15rem}
  .step p{font-size:.92rem}
  .grid-gal{grid-template-columns:1fr;grid-auto-rows:200px}
  .gp1,.gp2,.gp3,.gp4,.gp5,.gp6,.gp7{grid-column:span 1}
  .ficha .row{grid-template-columns:1fr 1fr}
  .bead-grid figure{flex:0 1 100%;max-width:280px}
  .ediciones h2.sec{font-size:clamp(1.6rem,6vw,2.2rem)}
  .cta h2{font-size:clamp(1.5rem,7vw,2.2rem)}
  .btn{padding:14px 24px;letter-spacing:.18em}
  footer .foot-logo{height:32px}
  .foot .meta{font-size:.66rem}
  .legal{font-size:.66rem}
}

/* --- Extra Safe: Ensure images never overflow --- */
img{max-width:100%;height:auto}
video{max-width:100%}

/* --- Touch-friendly tap targets --- */
@media(hover:none){
  .card:hover{transform:none;box-shadow:none}
  .grid-gal figure:hover img{transform:none}
  .bead-grid figure:hover img{transform:none}
  .step:hover{padding-left:0}
  .buy-btn{padding:15px 26px}
  #agegate button{padding:16px 36px}
}

