/* ALGARETE theme · main.css — sistema de diseño (identidad corporativa) */
/* ===== Fuentes ===== */
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/poppins-latin-ext-400-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/poppins-latin-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/poppins-latin-ext-500-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/poppins-latin-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/poppins-latin-ext-600-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/poppins-latin-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/poppins-latin-ext-700-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/poppins-latin-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/fraunces-latin-ext-400-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/fraunces-latin-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400;font-display:swap;src:url('../fonts/fraunces-latin-ext-400-italic.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400;font-display:swap;src:url('../fonts/fraunces-latin-400-italic.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/fraunces-latin-ext-500-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/fraunces-latin-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:500;font-display:swap;src:url('../fonts/fraunces-latin-ext-500-italic.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:500;font-display:swap;src:url('../fonts/fraunces-latin-500-italic.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/fraunces-latin-ext-600-normal.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/fraunces-latin-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:600;font-display:swap;src:url('../fonts/fraunces-latin-ext-600-italic.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:600;font-display:swap;src:url('../fonts/fraunces-latin-600-italic.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
/* ===== Base / sistema ===== */

  /* ===========================================================
     ALGARETE — Identidad corporativa (Guía de estilo v.01)
     Color: algarete red #e94e59 · algarete black · white
     Tipo:  Poppins (principal 70%) · Zodiak (secundaria 30%)
            -> Fraunces embebida como sustituta de Zodiak.
            Para usar la Zodiak real, añade su @font-face
            con font-family:'Zodiak' y tendrá prioridad.
     =========================================================== */
  :root{
    --red:#e94e59;
    --red-deep:#d23b46;
    --black:#161514;
    --black-2:#201e1d;
    --white:#ffffff;
    --font:'Poppins',sans-serif;
    --accent:'Zodiak','Fraunces',Georgia,serif;
    --maxw:1240px;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--font);
    background:var(--red);
    color:var(--black);
    overflow-x:hidden;
    letter-spacing:-.01em;
    -webkit-font-smoothing:antialiased;
  }
  a{color:inherit;text-decoration:none}

  /* grain */
  .grain{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.10;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='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

  /* helpers */
  .accent{font-family:var(--accent);font-style:italic}
  .eyebrow{font-family:var(--font);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:13px}
  .logo-mark{display:block}
  .logo-white{filter:brightness(0) invert(1)}
  .logo-black{filter:brightness(0)}

  /* ===================== NAV ===================== */
  header.nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;
    padding:16px clamp(18px,4vw,48px);transition:background .35s,padding .35s,box-shadow .35s}
  header.nav.scrolled{background:rgba(233,78,89,.95);backdrop-filter:blur(8px);padding-top:11px;padding-bottom:11px;box-shadow:0 1px 0 rgba(22,21,20,.15)}
  .nav-logo img{height:clamp(20px,2.4vw,26px);width:auto}
  .nav-links{display:flex;align-items:center;gap:clamp(14px,2vw,30px)}
  .nav-links a.txt{font-weight:600;text-transform:uppercase;font-size:12.5px;letter-spacing:.08em;color:var(--white);position:relative}
  .nav-links a.txt::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--black);transition:width .3s}
  .nav-links a.txt:hover::after{width:100%}
  .btn{display:inline-block;background:var(--black);color:var(--white);font-weight:600;text-transform:uppercase;font-size:12.5px;
    letter-spacing:.06em;padding:11px 20px;border:2px solid var(--black);transition:transform .18s,background .25s,color .25s}
  .btn:hover{background:transparent;color:var(--white);transform:translateY(-2px)}
  header.nav .btn:hover{color:var(--black);background:var(--white);border-color:var(--white)}
  .nav-links .txt{display:none}
  @media(min-width:780px){.nav-links .txt{display:inline-block}}

  /* ===================== HERO ===================== */
  .hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;
    padding:120px clamp(18px,4vw,48px) 56px;overflow:hidden}
  .hero .ring{position:absolute;border:2px solid rgba(22,21,20,.10);border-radius:50%}
  .hero .ring-1{width:60vw;height:42vw;top:-16vw;right:-12vw}
  .hero .ring-2{width:30vw;height:30vw;bottom:-12vw;left:-10vw;border-color:rgba(255,255,255,.18)}

  .hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
  .hero-bg img{width:100%;height:100%;object-fit:cover;object-position:60% 40%;filter:grayscale(1) contrast(1.12) brightness(.95)}
  .hero-bg::before{content:"";position:absolute;inset:0;background:var(--red);mix-blend-mode:multiply;opacity:.70}
  .hero-bg::after{content:"";position:absolute;inset:0;background:
    linear-gradient(95deg, var(--red) 0%, var(--red) 16%, rgba(233,78,89,.82) 42%, rgba(233,78,89,.28) 72%, rgba(233,78,89,0) 100%),
    linear-gradient(0deg, rgba(22,18,16,.5) 0%, rgba(22,18,16,0) 38%);}
  .hero .ring{z-index:1}

  .hero-inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;width:100%}
  .hero .eyebrow{display:flex;align-items:center;gap:14px;color:var(--white);margin-bottom:26px}
  .hero .eyebrow .dot{width:8px;height:8px;background:var(--black);border-radius:50%}
  .hero .eyebrow .line{flex:0 0 90px;height:2px;background:var(--white)}
  .hero-logo{width:min(92vw,1000px)}
  .hero-logo img{width:100%;height:auto;display:block;filter:drop-shadow(3px 5px 0 rgba(22,18,16,.35))}
  .hero .tagline{font-family:var(--accent);font-style:italic;font-weight:500;color:var(--black);
    font-size:clamp(26px,5vw,58px);line-height:1;margin-top:6px;margin-left:.06em}

  .hero-meta{margin-top:clamp(30px,5vw,52px);display:flex;flex-wrap:wrap;align-items:flex-end;gap:clamp(22px,4vw,56px)}
  .hero-meta .when{color:var(--black);margin-bottom:6px}
  .hero-meta .date{font-family:var(--accent);font-style:normal;font-weight:600;color:var(--white);
    font-size:clamp(46px,8.5vw,86px);line-height:.82;letter-spacing:-.02em;text-shadow:3px 4px 0 rgba(22,21,20,.18)}
  .hero-meta .where{font-weight:600;text-transform:uppercase;font-size:clamp(12.5px,1.4vw,15px);letter-spacing:.02em;
    color:var(--black);line-height:1.4;border-left:3px solid var(--black);padding-left:14px;max-width:240px}

  .countdown{display:flex;gap:9px;margin-top:clamp(26px,4vw,38px);flex-wrap:wrap}
  .cd{background:var(--black);color:var(--white);min-width:74px;padding:11px 10px 8px;text-align:center}
  .cd .n{font-family:var(--accent);font-style:normal;font-weight:600;font-size:clamp(28px,4vw,40px);line-height:1;letter-spacing:.01em}
  .cd .l{font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.16em;margin-top:5px;opacity:.7}

  /* ===================== MARQUEE ===================== */
  .marquee{background:var(--black);overflow:hidden;white-space:nowrap;padding:13px 0}
  .marquee .track{display:inline-block;animation:scroll 26s linear infinite}
  .marquee span{font-family:var(--accent);font-style:italic;font-weight:500;color:var(--red);font-size:clamp(20px,2.6vw,34px);padding:0 22px}
  .marquee span b{color:var(--white);font-style:normal;font-family:var(--font);font-weight:600;text-transform:uppercase;font-size:.8em;letter-spacing:.04em}
  @keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* ===================== EVENTS (LISTADO) ===================== */
  .events{background:var(--black);color:var(--white);padding:clamp(64px,9vw,120px) clamp(18px,4vw,48px)}
  .events-inner{max-width:var(--maxw);margin:0 auto;position:relative}
  .sec-head{margin-bottom:clamp(30px,4vw,52px)}
  .sec-head .eyebrow{color:var(--red);display:block;margin-bottom:10px}
  .sec-head h2{font-family:var(--font);font-weight:700;text-transform:uppercase;font-size:clamp(38px,6.5vw,84px);
    line-height:.92;letter-spacing:-.03em}
  .sec-head h2 em{font-family:var(--accent);font-style:italic;font-weight:500;text-transform:none;color:var(--red);letter-spacing:-.01em}

  .ev-list{border-top:1px solid rgba(255,255,255,.16)}
  .ev-row{position:relative;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:18px;
    padding:clamp(22px,3vw,34px) clamp(8px,2vw,24px);border-bottom:1px solid rgba(255,255,255,.16);
    cursor:pointer;transition:color .3s;overflow:hidden}
  .ev-row .fill{position:absolute;inset:0;background:var(--red);transform:translateY(101%);transition:transform .45s cubic-bezier(.16,1,.3,1);z-index:0}
  .ev-row:hover .fill{transform:translateY(0)}
  .ev-row>*{position:relative;z-index:1}
  .ev-row:hover{color:var(--black)}
  .ev-main{display:flex;align-items:baseline;gap:clamp(14px,2.4vw,34px);flex-wrap:wrap}
  .ev-date{font-family:var(--accent);font-style:normal;font-weight:600;font-size:clamp(30px,4.4vw,56px);line-height:.9;letter-spacing:-.02em;flex:0 0 auto}
  .ev-date small{display:block;font-family:var(--font);font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.55;margin-top:4px}
  .ev-text .ev-title{font-weight:700;text-transform:uppercase;font-size:clamp(20px,2.6vw,34px);line-height:1;letter-spacing:-.02em}
  .ev-text .ev-lineup{font-family:var(--accent);font-style:italic;font-weight:500;color:var(--red);font-size:clamp(16px,1.9vw,23px);margin-top:6px;line-height:1.05}
  .ev-row:hover .ev-text .ev-lineup{color:var(--black)}
  .ev-text .ev-venue{font-weight:500;font-size:13px;letter-spacing:.02em;opacity:.7;margin-top:7px;text-transform:uppercase}
  .ev-cta{display:flex;align-items:center;gap:10px;font-weight:600;text-transform:uppercase;font-size:13px;letter-spacing:.06em;white-space:nowrap}
  .ev-cta .circle{width:44px;height:44px;border:2px solid currentColor;border-radius:50%;display:grid;place-items:center;font-size:18px;transition:transform .3s}
  .ev-row:hover .ev-cta .circle{transform:translateX(6px) rotate(-45deg)}
  .ev-cta .lbl{display:none}
  @media(min-width:620px){.ev-cta .lbl{display:inline}}

  /* floating preview image (desktop hover) */
  .ev-preview{position:fixed;width:230px;height:300px;pointer-events:none;z-index:50;opacity:0;
    transform:translate(-50%,-50%) scale(.92) rotate(-3deg);transition:opacity .25s ease,transform .25s ease;
    border-radius:6px;overflow:hidden;box-shadow:0 24px 60px -16px rgba(0,0,0,.6);filter:grayscale(1) contrast(1.05)}
  .ev-preview.show{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(-3deg)}
  .ev-preview img{width:100%;height:100%;object-fit:cover}
  @media(hover:none){.ev-preview{display:none}}

  /* ===================== ABOUT ===================== */
  .about{background:var(--red);color:var(--black);padding:clamp(64px,10vw,128px) clamp(18px,4vw,48px);position:relative;overflow:hidden}
  .about .ring{position:absolute;border:2px solid rgba(22,21,20,.12);border-radius:50%;width:40vw;height:40vw;top:-12vw;right:-12vw}
  .about-inner{max-width:1000px;margin:0 auto;position:relative;z-index:2}
  .about .eyebrow{display:block;color:var(--white);margin-bottom:14px}
  .about h2{font-weight:700;text-transform:uppercase;font-size:clamp(36px,6.5vw,88px);line-height:.92;letter-spacing:-.03em;margin-bottom:26px}
  .about h2 em{font-family:var(--accent);font-style:italic;font-weight:500;text-transform:none;color:var(--white);letter-spacing:-.01em}
  .about p{font-size:clamp(15px,1.6vw,19px);line-height:1.7;margin-bottom:18px;font-weight:400;max-width:68ch}
  .about p b{font-weight:600}
  .artists{display:flex;flex-wrap:wrap;gap:9px;margin-top:30px}
  .artists span{border:1.5px solid var(--black);padding:8px 15px;font-weight:600;text-transform:uppercase;font-size:12.5px;letter-spacing:.04em;transition:background .25s,color .25s}
  .artists span:hover{background:var(--black);color:var(--white)}

  /* ===================== GALLERY ===================== */
  .gallery{background:var(--black);color:var(--white);padding:clamp(64px,9vw,120px) clamp(18px,4vw,48px)}
  .gallery-inner{max-width:var(--maxw);margin:0 auto}
  .gallery .sec-head .eyebrow{color:var(--red)}
  .gal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:clamp(28px,4vw,44px)}
  .gal-card{position:relative;overflow:hidden;aspect-ratio:3/2;display:block;background:var(--black-2)}
  .gal-card img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);transition:transform .7s,filter .5s}
  .gal-card:hover img{transform:scale(1.07);filter:grayscale(0)}
  .gal-card .cap{position:absolute;left:0;bottom:0;background:var(--red);color:var(--black);font-weight:700;text-transform:uppercase;
    font-size:14px;letter-spacing:.02em;padding:8px 15px;transform:translateY(110%);transition:transform .35s}
  .gal-card:hover .cap{transform:translateY(0)}
  .gal-more{text-align:center;margin-top:clamp(32px,5vw,52px)}
  .btn-line{display:inline-flex;align-items:center;gap:10px;border:2px solid var(--white);color:var(--white);
    font-weight:600;text-transform:uppercase;font-size:13px;letter-spacing:.06em;padding:14px 26px;transition:background .25s,color .25s,transform .18s}
  .btn-line:hover{background:var(--red);border-color:var(--red);color:var(--black);transform:translate(-2px,-2px)}

  /* ===================== FOOTER ===================== */
  footer{background:var(--black);color:var(--white);padding:clamp(54px,7vw,90px) clamp(18px,4vw,48px) 38px}
  .foot-inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;align-items:flex-start}
  .foot-brand img{width:min(70vw,300px);height:auto}
  .foot-brand .accent{display:block;color:var(--red);font-size:clamp(20px,2.4vw,28px);margin-top:10px;margin-left:.1em}
  .foot-col h4{font-weight:700;text-transform:uppercase;font-size:14px;color:var(--red);margin-bottom:14px;letter-spacing:.06em}
  .foot-col a{display:block;font-weight:400;font-size:14px;margin-bottom:9px;opacity:.82;transition:opacity .2s,transform .2s}
  .foot-col a:hover{opacity:1;transform:translateX(4px)}
  .foot-bottom{max-width:var(--maxw);margin:46px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.18);
    display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:12px;font-weight:500;opacity:.65;text-transform:uppercase;letter-spacing:.05em}

  /* reveal */
  .reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
  .reveal.in{opacity:1;transform:none}
  @keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
  .hero .eyebrow{animation:fadeUp .8s ease .05s both}
  .hero-logo{animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .15s both}
  .hero .tagline{animation:fadeUp .9s ease .45s both}
  .hero-meta{animation:fadeUp .9s ease .65s both}
  .countdown{animation:fadeUp .9s ease .8s both}

/* ===== Subpáginas / eventos ===== */


  /* ---------- SUBPAGE / EVENT detail ---------- */
  .where-btn{display:inline-flex;align-items:center;gap:9px;border:2px solid var(--black);color:var(--black);
    font-weight:600;text-transform:uppercase;font-size:13px;letter-spacing:.06em;padding:12px 20px;transition:background .25s,color .25s,transform .18s}
  .where-btn:hover{background:var(--black);color:var(--white);transform:translateY(-2px)}

  .btn-cta{display:inline-flex;align-items:center;gap:11px;background:var(--black);color:var(--white);
    font-weight:600;text-transform:uppercase;font-size:14px;letter-spacing:.06em;padding:16px 30px;border:2px solid var(--black);
    transition:background .25s,color .25s,transform .18s,box-shadow .25s}
  .btn-cta:hover{background:var(--white);color:var(--black);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--black)}
  .btn-cta .a{transition:transform .25s}.btn-cta:hover .a{transform:translateX(4px)}

  .breadcrumb{font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:11.5px;margin-bottom:24px;color:var(--black)}
  .breadcrumb a{opacity:.65}.breadcrumb a:hover{opacity:1}
  .breadcrumb i{opacity:.5;font-style:normal;margin:0 9px}

  /* event hero */
  .ev-hero{position:relative;background:var(--red);color:var(--black);overflow:hidden;padding:130px clamp(18px,4vw,48px) clamp(50px,7vw,90px)}
  .ev-hero .ring{position:absolute;border:2px solid rgba(22,18,16,.12);border-radius:50%;width:40vw;height:40vw;top:-12vw;right:-12vw}
  .ev-hero .ring-2{width:26vw;height:26vw;top:auto;bottom:-12vw;left:-8vw;border-color:rgba(255,255,255,.20)}
  .ev-hero-grid{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:clamp(30px,4vw,60px);align-items:center}
  @media(min-width:880px){.ev-hero-grid{grid-template-columns:1.05fr .95fr}}
  .ev-hero-text .eyebrow{display:block;color:var(--white);margin-bottom:14px}
  .ev-hero-text h1{font-weight:700;text-transform:uppercase;font-size:clamp(40px,7.2vw,96px);line-height:.88;letter-spacing:-.03em}
  .ev-hero-text .lineup{font-family:var(--accent);font-style:italic;font-weight:500;font-size:clamp(22px,3.2vw,40px);line-height:1.02;margin-top:16px;color:var(--black)}
  .ev-hero-poster{justify-self:center}
  .ev-hero-poster img{width:min(84vw,400px);height:auto;border-radius:6px;display:block;
    box-shadow:0 34px 80px -24px rgba(22,18,16,.6);transform:rotate(-2.5deg);transition:transform .5s}
  .ev-hero-poster img:hover{transform:rotate(0) scale(1.02)}
  .ev-cd{margin-top:clamp(24px,4vw,34px)}

  /* event body (info + desc) */
  .ev-body{background:var(--black);color:var(--white);padding:clamp(56px,8vw,112px) clamp(18px,4vw,48px)}
  .ev-body-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:clamp(40px,5vw,72px)}
  @media(min-width:880px){.ev-body-inner{grid-template-columns:.95fr 1.05fr}}
  .ev-info .info-row{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:17px 0;border-bottom:1px solid rgba(255,255,255,.16)}
  .ev-info .info-row:first-child{border-top:1px solid rgba(255,255,255,.16)}
  .ev-info .k{font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:11.5px;opacity:.55;flex:0 0 auto}
  .ev-info .v{font-weight:600;text-align:right}
  .ev-info .v.acc{font-family:var(--accent);font-style:italic;font-weight:500;color:var(--red);text-transform:none;font-size:clamp(17px,2vw,21px)}
  .ev-info .btn-cta{margin-top:30px}
  .ev-info .btn-cta:hover{background:var(--red);border-color:var(--red);color:var(--black);box-shadow:6px 6px 0 rgba(255,255,255,.25)}
  .ev-desc .eyebrow{display:block;color:var(--red);margin-bottom:12px}
  .ev-desc h2{font-weight:700;text-transform:uppercase;font-size:clamp(26px,3.4vw,46px);line-height:.95;letter-spacing:-.02em;margin-bottom:20px}
  .ev-desc h2 em{font-family:var(--accent);font-style:italic;font-weight:500;text-transform:none;color:var(--red)}
  .ev-desc p{font-size:clamp(15px,1.6vw,18px);line-height:1.75;margin-bottom:16px;opacity:.9}
  .ev-desc .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
  .ev-desc .tags span{border:1.5px solid rgba(255,255,255,.4);padding:7px 14px;font-weight:600;text-transform:uppercase;font-size:12px;letter-spacing:.04em}

  .back-strip{background:var(--red);padding:clamp(34px,5vw,56px) clamp(18px,4vw,48px);text-align:center}
  .back-strip a{display:inline-flex;align-items:center;gap:10px;font-weight:700;text-transform:uppercase;font-size:14px;letter-spacing:.06em;color:var(--black)}
  .back-strip a:hover{text-decoration:underline}

  /* ---------- SUBPAGE header (gallery) ---------- */
  .subhero{position:relative;background:var(--red);color:var(--black);overflow:hidden;padding:140px clamp(18px,4vw,48px) clamp(46px,7vw,84px)}
  .subhero .ring{position:absolute;border:2px solid rgba(22,18,16,.12);border-radius:50%;width:40vw;height:40vw;top:-12vw;right:-12vw}
  .subhero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto}
  .subhero .eyebrow{display:block;color:var(--white);margin-bottom:12px}
  .subhero h1{font-weight:700;text-transform:uppercase;font-size:clamp(46px,9.5vw,128px);line-height:.9;letter-spacing:-.03em}
  .subhero h1 em{font-family:var(--accent);font-style:italic;font-weight:500;text-transform:none;color:var(--white);letter-spacing:-.01em}
  .subhero .lead{font-size:clamp(15px,1.7vw,19px);max-width:62ch;margin-top:18px;line-height:1.6}

/* ===== Componentes inyectados (tarjetas, slideshow, hero) ===== */
.where-btn{display:inline-flex;align-items:center;gap:9px;border:2px solid var(--black);color:var(--black);font-weight:600;text-transform:uppercase;font-size:13px;letter-spacing:.06em;padding:12px 20px;transition:background .25s,color .25s,transform .18s}.where-btn:hover{background:var(--black);color:var(--white);transform:translateY(-2px)}
.hero-meta{align-items:flex-start}.hero-next-info{display:flex;flex-direction:column;align-items:flex-start;gap:13px}.next-name{font-family:var(--accent);font-style:italic;font-weight:600;font-size:clamp(20px,2.4vw,30px);color:var(--black);line-height:1}.hero-meta .where{margin-bottom:2px}@media(max-width:620px){.hero-meta{gap:20px}}
/* En dispositivos tactiles el :hover se queda pegado: mantenemos el listado en negro */@media (hover: none){.ev-row .fill{transform:translateY(101%)}.ev-row,.ev-row:hover{color:var(--white)}.ev-row:hover .ev-text .ev-lineup{color:var(--red)}.ev-row:hover .ev-cta .circle{transform:none}}
.hero-bg .hero-slides{position:absolute;inset:0}.hero-bg .slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:60% 40%;filter:grayscale(1) contrast(1.12) brightness(.95);opacity:0;transition:opacity 1.3s ease;z-index:0}.hero-bg .slide.active{opacity:1}.hero-bg::before{z-index:1}.hero-bg::after{z-index:2}
/* Tarjetas de galeria - diseno alternativo (bloque editorial) */.gal-grid.gcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:clamp(20px,2.4vw,30px)}.gcard{display:block;text-decoration:none;color:inherit}.gcard-media{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--black-2)}.gcard-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.06);transition:transform .7s ease,filter .5s ease}.gcard:hover .gcard-media img{transform:scale(1.06);filter:grayscale(0)}.gcard-index{position:absolute;top:12px;left:16px;z-index:2;font-family:var(--accent);font-style:italic;font-weight:600;font-size:34px;line-height:1;color:#fff;mix-blend-mode:difference;pointer-events:none}.gcard-foot{position:relative;z-index:3;margin:-32px 14px 0;background:var(--black);color:#fff;padding:15px 18px;display:flex;align-items:center;gap:14px;transition:background .3s ease}.gcard:hover .gcard-foot{background:var(--red)}.gcard-titles{flex:1;min-width:0}.gcard-title{font-weight:700;text-transform:uppercase;font-size:clamp(17px,1.8vw,21px);letter-spacing:-.01em;line-height:1;transition:color .3s ease}.gcard-sub{font-family:var(--accent);font-style:italic;font-weight:500;color:var(--red);font-size:15px;margin-top:4px;line-height:1;transition:color .3s ease}.gcard:hover .gcard-title{color:var(--black)}.gcard:hover .gcard-sub{color:var(--black)}.gcard-arrow{flex:0 0 auto;width:34px;height:34px;border:2px solid currentColor;border-radius:50%;display:grid;place-items:center;font-size:15px;color:#fff;transition:transform .3s ease,color .3s ease}.gcard:hover .gcard-arrow{transform:rotate(-45deg);color:var(--black)}
/* ===== Galería single ===== */



  /* ---------- GALLERY SINGLE ---------- */
  .gs-meta{display:flex;flex-wrap:wrap;gap:24px;margin-top:22px}
  .gs-meta .item{border-left:3px solid var(--black);padding-left:12px}
  .gs-meta .k{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;opacity:.6}
  .gs-meta .v{font-weight:600;text-transform:uppercase;font-size:14px}
  .photo-section{background:var(--black);padding:clamp(46px,7vw,92px) clamp(18px,4vw,48px)}
  .photo-wall{max-width:var(--maxw);margin:0 auto;column-count:3;column-gap:14px}
  @media(max-width:900px){.photo-wall{column-count:2}}
  @media(max-width:560px){.photo-wall{column-count:1}}
  .photo-wall figure{margin:0 0 14px;break-inside:avoid;overflow:hidden;cursor:pointer;position:relative;background:var(--black-2)}
  .photo-wall img{width:100%;display:block;filter:grayscale(1) contrast(1.05);transition:transform .6s ease,filter .5s ease}
  .photo-wall figure:hover img{transform:scale(1.05);filter:grayscale(0)}
  .photo-wall figure::after{content:"+";position:absolute;top:8px;right:14px;color:#fff;font-size:24px;font-weight:300;opacity:0;transition:opacity .3s;text-shadow:0 2px 8px rgba(0,0,0,.5)}
  .photo-wall figure:hover::after{opacity:.95}
  /* lightbox */
  .lightbox{position:fixed;inset:0;background:rgba(12,11,10,.95);z-index:2000;display:none;align-items:center;justify-content:center;padding:30px}
  .lightbox.open{display:flex}
  .lightbox img{max-width:92vw;max-height:84vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6)}
  .lb-btn{position:absolute;background:rgba(0,0,0,.25);border:2px solid #fff;color:#fff;width:52px;height:52px;border-radius:50%;font-size:22px;line-height:0;cursor:pointer;display:grid;place-items:center;transition:background .2s,color .2s,border-color .2s}
  .lb-btn:hover{background:var(--red);border-color:var(--red);color:var(--black)}
  .lb-close{top:24px;right:24px}
  .lb-prev{left:24px;top:50%;transform:translateY(-50%)}
  .lb-next{right:24px;top:50%;transform:translateY(-50%)}
  .lb-count{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:#fff;font-weight:600;letter-spacing:.12em;font-size:13px;opacity:.8}
  @media(max-width:560px){.lb-prev{left:8px}.lb-next{right:8px}.lb-btn{width:44px;height:44px;font-size:18px}}

/* ===== Tienda / WooCommerce ===== */



  /* ===== SHOP shared ===== */
  .shop{background:var(--black);color:var(--white);padding:clamp(44px,6vw,86px) clamp(18px,4vw,48px)}
  .shop-inner{max-width:var(--maxw);margin:0 auto}
  .btn-red{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--red);color:var(--black);
    font-weight:700;text-transform:uppercase;font-size:15px;letter-spacing:.05em;padding:16px 28px;border:2px solid var(--red);
    cursor:pointer;transition:background .2s,color .2s,transform .18s}
  .btn-red:hover{background:transparent;color:var(--red);transform:translateY(-2px)}
  .btn-ghost{display:inline-flex;align-items:center;gap:9px;border:2px solid rgba(255,255,255,.4);color:#fff;font-weight:600;
    text-transform:uppercase;font-size:13px;letter-spacing:.05em;padding:13px 22px;transition:border-color .2s,color .2s}
  .btn-ghost:hover{border-color:var(--red);color:var(--red)}
  .field{margin-bottom:15px}
  .field label{display:block;font-weight:600;text-transform:uppercase;font-size:11.5px;letter-spacing:.1em;opacity:.65;margin-bottom:7px}
  .field select,.field input,.field textarea{width:100%;background:var(--black-2);border:2px solid rgba(255,255,255,.18);color:#fff;
    font-family:var(--font);font-size:15px;padding:13px 14px;transition:border-color .2s}
  .field select:focus,.field input:focus,.field textarea:focus{outline:none;border-color:var(--red)}
  .qty{display:inline-flex;align-items:center;border:2px solid rgba(255,255,255,.2)}
  .qty button{background:none;border:none;color:#fff;width:42px;height:46px;font-size:20px;line-height:0;cursor:pointer;transition:background .2s,color .2s}
  .qty button:hover{background:var(--red);color:var(--black)}
  .qty input{width:48px;height:46px;text-align:center;background:none;border:none;color:#fff;font-weight:700;font-size:16px;-moz-appearance:textfield}
  .qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none}

  /* ===== PRODUCT ===== */
  .product{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,56px);align-items:start}
  @media(min-width:880px){.product{grid-template-columns:1.02fr .98fr}}
  .product-media{position:relative;overflow:hidden;background:var(--black-2);aspect-ratio:4/5;border-radius:4px}
  .product-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.25) contrast(1.06)}
  .product-tag{position:absolute;top:16px;left:16px;background:var(--red);color:var(--black);font-weight:700;text-transform:uppercase;font-size:12px;letter-spacing:.06em;padding:7px 13px}
  .product-info .eyebrow{display:block;color:var(--red);margin-bottom:12px}
  .product-info h1{font-weight:700;text-transform:uppercase;font-size:clamp(30px,4.4vw,54px);line-height:.92;letter-spacing:-.02em}
  .price{font-family:var(--accent);font-style:italic;font-weight:600;color:#fff;font-size:clamp(30px,4vw,46px);margin:16px 0 4px}
  .price small{font-family:var(--font);font-style:normal;font-weight:600;font-size:13px;opacity:.55;text-transform:uppercase;letter-spacing:.06em;margin-left:6px}
  .product-info p.lead{opacity:.85;line-height:1.7;margin:14px 0 22px;max-width:54ch}
  .qty-row{display:flex;align-items:center;gap:14px;margin:18px 0 8px}
  .add-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}
  .includes{margin-top:28px;border-top:1px solid rgba(255,255,255,.16);padding-top:22px}
  .includes h3{font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.08em;margin-bottom:14px;color:var(--red)}
  .includes ul{list-style:none}
  .includes li{display:flex;gap:11px;padding:7px 0;font-size:15px;opacity:.9}
  .includes li::before{content:"✦";color:var(--red)}

  /* ===== CART ===== */
  .cart-grid{display:grid;grid-template-columns:1fr;gap:clamp(26px,4vw,48px);align-items:start}
  @media(min-width:920px){.cart-grid{grid-template-columns:1.6fr .9fr}}
  .cart-item{display:grid;grid-template-columns:84px 1fr auto;gap:18px;align-items:center;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.16)}
  .cart-item:first-child{border-top:1px solid rgba(255,255,255,.16)}
  .cart-item .thumb{width:84px;height:84px;object-fit:cover;background:var(--black-2);filter:grayscale(.3)}
  .cart-item .ci-name{font-weight:700;text-transform:uppercase;font-size:16px;line-height:1.1}
  .cart-item .ci-meta{font-family:var(--accent);font-style:italic;color:var(--red);font-size:14px;margin-top:4px}
  .cart-item .ci-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px;text-align:right}
  .cart-item .ci-price{font-weight:700;font-size:16px;white-space:nowrap}
  .ci-remove{background:none;border:none;color:rgba(255,255,255,.5);cursor:pointer;font-size:12px;text-transform:uppercase;letter-spacing:.06em}
  .ci-remove:hover{color:var(--red)}
  .summary{background:var(--black-2);padding:clamp(22px,3vw,30px);border:1px solid rgba(255,255,255,.14)}
  .summary h3{font-weight:700;text-transform:uppercase;font-size:16px;letter-spacing:.04em;margin-bottom:16px}
  .summary .row{display:flex;justify-content:space-between;gap:12px;padding:9px 0;font-size:15px;opacity:.85}
  .summary .row.total{border-top:1px solid rgba(255,255,255,.2);margin-top:8px;padding-top:15px;font-size:20px;font-weight:700;opacity:1}
  .summary .row.total b{font-family:var(--accent);font-style:italic;color:var(--red);font-size:24px}
  .summary .btn-red{width:100%;margin-top:18px}
  .cart-actions{display:flex;justify-content:space-between;align-items:center;margin-top:22px;flex-wrap:wrap;gap:14px}
  .coupon{display:flex;gap:10px;margin-top:16px}
  .coupon input{flex:1;margin:0}
  .cart-empty{text-align:center;padding:60px 0}
  .cart-empty p{opacity:.7;margin-bottom:20px}

  /* ===== CHECKOUT ===== */
  .checkout-grid{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,52px);align-items:start}
  @media(min-width:920px){.checkout-grid{grid-template-columns:1.2fr .8fr}}
  .form-block{margin-bottom:28px}
  .form-block h3{font-weight:700;text-transform:uppercase;font-size:14px;letter-spacing:.06em;margin-bottom:16px;color:var(--red)}
  .grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  @media(max-width:560px){.grid2{grid-template-columns:1fr}}
  .pay-methods{display:flex;flex-direction:column;gap:10px}
  .pay-opt{display:flex;align-items:center;gap:12px;border:2px solid rgba(255,255,255,.18);padding:14px 16px;cursor:pointer;transition:border-color .2s,background .2s}
  .pay-opt.sel{border-color:var(--red);background:rgba(233,78,89,.08)}
  .pay-opt input{accent-color:var(--red);width:18px;height:18px}
  .pay-opt .pl{font-weight:600;text-transform:uppercase;font-size:13px;letter-spacing:.04em}
  .terms{display:flex;gap:10px;align-items:flex-start;margin:18px 0;font-size:13px;opacity:.85;line-height:1.5}
  .terms input{accent-color:var(--red);margin-top:3px;width:16px;height:16px;flex:0 0 auto}
  .os-item{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.14);font-size:14px}
  .os-item .n{font-weight:600;text-transform:uppercase}
  .os-item .m{font-family:var(--accent);font-style:italic;color:var(--red);font-size:13px;text-transform:none}
  .os-qty{opacity:.6;font-size:13px}

/* ===== Entradas (iframe / enlace) en single evento ===== */
.tickets-block{background:var(--black);color:var(--white);padding:clamp(40px,6vw,80px) clamp(18px,4vw,48px)}
.tickets-block .ti-inner{max-width:var(--maxw);margin:0 auto}
.tickets-block h2{font-weight:700;text-transform:uppercase;font-size:clamp(26px,3.4vw,44px);letter-spacing:-.02em;margin-bottom:22px}
.tickets-block h2 em{font-family:var(--accent);font-style:italic;font-weight:500;text-transform:none;color:var(--red)}
.ticket-embed{position:relative;width:100%;min-height:560px;border:1px solid rgba(255,255,255,.14);background:var(--black-2)}
.ticket-embed iframe{width:100%;min-height:560px;border:0;display:block}
.ticket-link-box{display:flex;flex-wrap:wrap;align-items:center;gap:18px;background:var(--black-2);border:1px solid rgba(255,255,255,.14);padding:clamp(24px,4vw,40px)}
.ticket-link-box .tl-text{flex:1;min-width:220px}
.ticket-link-box .tl-text strong{display:block;text-transform:uppercase;font-size:18px;letter-spacing:-.01em}
.ticket-link-box .tl-text span{opacity:.7;font-size:14px}

/* ===== WooCommerce (marca) ===== */
.woocommerce-page{background:var(--black);color:var(--white)}
.alg-woo-wrap{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,6vw,80px) clamp(18px,4vw,48px)}
.woocommerce .button,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce #respond input#submit,.woocommerce-page .button{
  background:var(--red)!important;color:var(--black)!important;border:2px solid var(--red)!important;border-radius:0!important;
  font-family:var(--font)!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.05em!important;
  padding:14px 26px!important;transition:background .2s,color .2s!important}
.woocommerce .button:hover,.woocommerce a.button:hover,.woocommerce button.button:hover{background:transparent!important;color:var(--red)!important}
.woocommerce .button.alt,.woocommerce button.button.alt{background:var(--red)!important;color:var(--black)!important}
.woocommerce span.price,.woocommerce div.product p.price,.woocommerce ul.products li.product .price{
  color:#fff!important;font-family:var(--accent)!important;font-style:italic!important;font-weight:600!important;font-size:26px!important}
.woocommerce-page input.input-text,.woocommerce-page select,.woocommerce-page textarea,
.woocommerce form .form-row input.input-text,.woocommerce form .form-row select{
  background:var(--black-2)!important;border:2px solid rgba(255,255,255,.18)!important;color:#fff!important;border-radius:0!important;padding:12px 14px!important}
.woocommerce table.shop_table,.woocommerce-cart table.cart,.woocommerce-checkout .shop_table{
  border:1px solid rgba(255,255,255,.16)!important;background:transparent!important}
.woocommerce table.shop_table th,.woocommerce table.shop_table td{border-color:rgba(255,255,255,.12)!important;color:#fff!important}
.woocommerce .cart_totals h2,.woocommerce-checkout h3,.woocommerce-billing-fields h3{color:var(--red)!important;text-transform:uppercase}
.woocommerce ul.products li.product .price{font-size:20px!important}

/* ===== Menú de navegación (wp_nav_menu) ===== */
.nav-links .nav-menu{display:flex;align-items:center;gap:clamp(14px,2vw,30px);list-style:none;margin:0;padding:0}
.nav-links .nav-menu li{margin:0}
.nav-links .nav-menu a{font-weight:600;text-transform:uppercase;font-size:12.5px;letter-spacing:.08em;color:var(--white);position:relative}
.nav-links .nav-menu a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--black);transition:width .3s}
.nav-links .nav-menu a:hover::after{width:100%}
/* Un ítem de menú con la clase CSS "btn" se muestra como botón */
.nav-links .nav-menu li.btn{background:none}
.nav-links .nav-menu li.btn>a{background:var(--black);color:var(--white);padding:11px 20px;border:2px solid var(--black);letter-spacing:.06em}
.nav-links .nav-menu li.btn>a::after{display:none}
.nav-links .nav-menu li.btn>a:hover{background:var(--white);color:var(--black);border-color:var(--white)}

/* Botón hamburguesa */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;background:none;border:0;cursor:pointer;padding:0;z-index:1110}
.nav-toggle span{display:block;height:2px;width:24px;background:var(--white);transition:transform .3s,opacity .3s}
.nav.open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav-toggle span:nth-child(2){opacity:0}
.nav.open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:820px){
	.nav-toggle{display:flex}
	.nav-links{position:fixed;top:0;right:0;height:100vh;width:min(82vw,330px);background:var(--black);
		flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:20px;
		padding:96px 30px 30px;transform:translateX(100%);transition:transform .35s cubic-bezier(.16,1,.3,1);z-index:1100;box-shadow:-20px 0 60px rgba(0,0,0,.4)}
	.nav.open .nav-links{transform:none}
	.nav-links .nav-menu{flex-direction:column;align-items:flex-start;gap:20px;width:100%}
	.nav-links .nav-menu a{font-size:17px}
	.nav-links .nav-menu a::after{background:var(--red)}
	.nav-links .btn,.nav-links .nav-menu li.btn>a{width:100%;text-align:center;justify-content:center;display:block}
}

/* ===== Error 404 ===== */
.error404-wrap{position:relative;background:var(--red);color:var(--black);min-height:84vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:150px 24px 90px;overflow:hidden}
.error404-wrap .ring{position:absolute;border:2px solid rgba(22,18,16,.12);border-radius:50%}
.error404-wrap .ring-1{width:46vw;height:46vw;top:-16vw;right:-14vw}
.error404-wrap .ring-2{width:30vw;height:30vw;bottom:-14vw;left:-10vw;border-color:rgba(255,255,255,.2)}
.e404-inner{position:relative;z-index:2;max-width:680px;margin:0 auto}
.e404-num{font-family:var(--font);font-weight:700;font-size:clamp(120px,27vw,300px);line-height:.82;letter-spacing:-.05em;color:var(--white);text-shadow:5px 7px 0 rgba(22,18,16,.18)}
.e404-eyebrow{display:block;color:var(--white);margin-bottom:8px}
.e404-title{font-weight:700;text-transform:uppercase;font-size:clamp(26px,4.4vw,52px);line-height:.95;letter-spacing:-.02em;margin:14px 0 12px}
.e404-title em{font-family:var(--accent);font-style:italic;font-weight:500;text-transform:none;color:var(--white)}
.e404-text{font-size:clamp(15px,1.6vw,18px);line-height:1.6;max-width:44ch;margin:0 auto 8px}
.e404-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.e404-search{display:flex;gap:10px;max-width:420px;margin:26px auto 0}
.e404-search input[type=search]{flex:1;background:rgba(255,255,255,.18);border:2px solid var(--black);color:var(--black);font-family:var(--font);font-size:15px;padding:13px 14px}
.e404-search input[type=search]::placeholder{color:rgba(22,18,16,.6)}
.e404-search input[type=search]:focus{outline:none;background:#fff}
