:root{--bg:#070707;--panel:#0d0d0f;--text:#f5f5f5;--muted:#a7a7aa;--red:#d71920;--line:rgba(255,255,255,.1);--max:1220px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,Arial,sans-serif;overflow-x:hidden}body.menu-open{overflow:hidden}.noise{position:fixed;inset:0;pointer-events:none;z-index:1000;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/%3E%3C/svg%3E")}.cursor-dot{position:fixed;width:16px;height:16px;border:1px solid rgba(255,255,255,.6);border-radius:50%;pointer-events:none;z-index:1200;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s}.site-header{height:78px;position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:0 4vw;z-index:500;transition:.3s;border-bottom:1px solid transparent}.site-header.scrolled{background:rgba(5,5,5,.9);backdrop-filter:blur(16px);border-bottom-color:var(--line)}.brand{display:flex;align-items:center;text-decoration:none}.brand img{display:block;width:150px;height:auto;filter:drop-shadow(0 5px 15px rgba(0,0,0,.5))}.main-nav{display:flex;gap:28px}.main-nav a{color:#ddd;text-decoration:none;text-transform:uppercase;font-size:12px;font-weight:700;letter-spacing:1px;position:relative}.main-nav a:after{content:"";position:absolute;left:0;right:100%;bottom:-8px;height:2px;background:var(--red);transition:.25s}.main-nav a:hover:after,.main-nav a.active:after{right:0}.menu-toggle{display:none;background:none;border:0}.hero{min-height:100vh;position:relative;display:grid;place-items:center;background:#050505 url('../assets/img/hero-vendetta.png') center center/cover no-repeat;overflow:hidden}.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at center,rgba(0,0,0,.04),rgba(0,0,0,.34) 62%,#050505 100%),linear-gradient(to bottom,rgba(0,0,0,.12),rgba(0,0,0,.52))}.red-beam{position:absolute;width:460px;height:2px;background:linear-gradient(90deg,transparent,var(--red),transparent);filter:blur(.5px);opacity:.8}.beam-a{transform:rotate(42deg)}.beam-b{transform:rotate(-42deg)}.hero-content{position:relative;text-align:center;padding:120px 20px 50px}.eyebrow,.section-kicker{color:var(--red);letter-spacing:3px;font-size:12px;font-weight:800}.hero h1,.section h2,.about h2,.contact h2{font-family:'Bebas Neue';margin:0;letter-spacing:2px}.hero h1{margin:0;line-height:1}.hero-logo img{display:block;width:min(820px,78vw);height:auto;margin:0 auto;filter:drop-shadow(0 12px 30px rgba(0,0,0,.85))}.hero-tagline{letter-spacing:10px;font-size:14px;margin:30px 0}.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn{border:1px solid var(--line);padding:15px 23px;text-transform:uppercase;letter-spacing:.8px;font-weight:800;font-size:12px;cursor:pointer;color:white;background:#111;transition:.25s}.btn:hover{transform:translateY(-3px);border-color:var(--red);box-shadow:0 12px 30px rgba(215,25,32,.2)}.btn-primary{background:var(--red);border-color:var(--red)}.btn-ghost{background:rgba(0,0,0,.35)}.btn-outline{background:transparent;border-color:rgba(215,25,32,.7)}.scroll-cue{position:absolute;bottom:25px;color:white;text-decoration:none;font-size:32px;animation:bounce 1.4s infinite}.section{max-width:var(--max);margin:auto;padding:110px 28px}.featured{display:grid;grid-template-columns:420px 1fr;gap:70px;align-items:center}.featured-art{position:relative}.featured-art img{width:100%;display:block;border:1px solid var(--line);box-shadow:0 25px 80px rgba(0,0,0,.6)}.vinyl{position:absolute;width:70%;aspect-ratio:1;border-radius:50%;background:repeating-radial-gradient(circle,#111 0 6px,#191919 7px 9px);right:-30%;top:15%;z-index:-1}.featured-copy h2,.section-heading h2{font-size:clamp(48px,7vw,88px)}.featured-copy p{max-width:680px;color:var(--muted);line-height:1.8}.platforms{display:flex;gap:10px;flex-wrap:wrap;margin:28px 0}.platforms a{color:#ddd;text-decoration:none;border:1px solid var(--line);padding:10px 14px;font-size:12px}.section-heading{display:flex;align-items:end;justify-content:space-between;margin-bottom:35px}.album-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.album-card{background:var(--panel);border:1px solid var(--line);overflow:hidden;transition:.3s}.album-card:hover{transform:translateY(-8px);border-color:rgba(215,25,32,.6)}.album-card img{width:100%;aspect-ratio:1;object-fit:cover;filter:saturate(.8)}.album-card div{padding:18px}.album-card h3{margin:0 0 8px;text-transform:uppercase}.album-card p{color:var(--muted);font-size:12px}.album-card button{background:none;border:0;color:var(--red);font-weight:800;padding:0;cursor:pointer}.event-list{display:grid;gap:12px}.event-card{display:grid;grid-template-columns:120px 1fr auto;align-items:center;gap:25px;padding:20px 24px;background:var(--panel);border:1px solid var(--line);transition:.25s}.event-card:hover{border-color:rgba(215,25,32,.6);transform:translateX(6px)}.date strong{font-family:'Bebas Neue';font-size:60px;color:var(--red);line-height:.8}.date span{display:block;letter-spacing:4px}.event-card h3{margin:0 0 7px;text-transform:uppercase}.event-card p{margin:0;color:var(--muted)}.event-card button{background:transparent;color:white;border:1px solid var(--red);padding:11px 18px;text-transform:uppercase;cursor:pointer}.gallery-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.gallery-grid-real{align-items:stretch}.gallery-item{position:relative;padding:10px;border:1px solid var(--line);overflow:hidden;background:linear-gradient(180deg,#141414,#0b0b0c);cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:230px;border-radius:12px}.gallery-item.poster{min-height:300px}.gallery-item.landscape{grid-column:span 2;min-height:230px}.gallery-item img{width:100%;height:100%;object-fit:contain;transition:.35s;filter:none}.gallery-item:hover{border-color:rgba(215,25,32,.55);box-shadow:0 18px 50px rgba(0,0,0,.35)}.gallery-item:hover img{transform:scale(1.02)}.gallery-caption{position:absolute;left:10px;right:10px;bottom:8px;padding:8px 10px;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.78));color:#fff;text-align:left;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700}.about{display:grid;grid-template-columns:1fr 1fr;min-height:700px;background:#090909;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.about-copy{padding:110px 6vw;align-self:center}.about h2{font-size:clamp(60px,8vw,118px);line-height:.9}.about-copy p:not(.section-kicker){max-width:620px;color:var(--muted);line-height:1.8}.about-image{min-height:640px;overflow:hidden;background:#050505;display:flex;align-items:center;justify-content:center}.about-image img{width:100%;height:100%;object-fit:cover;object-position:center;filter:none}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px}.mail-link{color:white;font-size:22px;text-decoration:none;border-bottom:1px solid var(--red)}.contact-form{display:grid;gap:16px}.contact-form label{display:grid;gap:8px;color:#ddd;font-size:13px}.contact-form input,.contact-form textarea,.newsletter input{background:#0b0b0c;border:1px solid var(--line);color:white;padding:14px;outline:none}.contact-form input:focus,.contact-form textarea:focus,.newsletter input:focus{border-color:var(--red)}footer{border-top:1px solid var(--line);padding:45px 4vw;display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;align-items:center;background:#050505}.footer-logo{display:block;width:145px;height:auto;margin-bottom:8px}footer p{color:var(--muted);font-size:12px}.socials{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.social-icon{width:44px;height:44px;border:1px solid rgba(255,255,255,.16);border-radius:50%;display:grid;place-items:center;color:#f2f2f2;text-decoration:none;font-size:19px;background:rgba(255,255,255,.025);transition:transform .25s,border-color .25s,background .25s,color .25s}.social-icon:hover{transform:translateY(-4px);border-color:var(--red);background:rgba(215,25,32,.12);color:#fff}.social-icon[aria-label="YouTube"]:hover{background:#ff0000;border-color:#ff0000}.social-icon[aria-label="Instagram"]:hover{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);border-color:transparent}.social-icon[aria-label="TikTok"]:hover{background:#111;border-color:#25f4ee;box-shadow:3px 0 0 #fe2c55}.social-icon[aria-label="Spotify"]:hover{background:#1db954;border-color:#1db954}.newsletter label{display:block;margin-bottom:10px}.newsletter div{display:flex}.newsletter input{width:100%}.newsletter button{width:50px;background:var(--red);border:0;color:white}.modal{border:1px solid var(--line);background:#090909;color:white;max-width:900px;width:90%;padding:0}.modal::backdrop{background:rgba(0,0,0,.85);backdrop-filter:blur(8px)}.modal-close{position:absolute;right:12px;top:8px;background:none;border:0;color:white;font-size:34px;cursor:pointer;z-index:2}.video-placeholder{min-height:500px;display:grid;place-content:center;text-align:center;background:radial-gradient(circle,rgba(215,25,32,.2),transparent 50%),#080808}.video-placeholder span{font-size:70px}.image-modal img{display:block;width:100%;max-height:85vh;object-fit:contain}.toast{position:fixed;right:24px;bottom:24px;background:#111;border:1px solid rgba(215,25,32,.7);padding:15px 20px;z-index:1000;transform:translateY(150%);transition:.35s}.toast.show{transform:translateY(0)}.reveal,.reveal-left,.reveal-right{opacity:0;transition:opacity .8s ease,transform .8s ease}.reveal{transform:translateY(35px)}.reveal-left{transform:translateX(-45px)}.reveal-right{transform:translateX(45px)}.visible{opacity:1;transform:none}@keyframes bounce{50%{transform:translateY(8px)}}@media(max-width:900px){.cursor-dot{display:none}.menu-toggle{display:block;position:relative;z-index:600}.menu-toggle span{display:block;width:28px;height:2px;background:white;margin:7px}.main-nav{position:fixed;inset:0;background:#070707;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:translateX(100%);transition:.35s}.main-nav.open{transform:none}.main-nav a{font-size:20px}.hero-logo img{width:min(720px,92vw)}.hero-tagline{letter-spacing:5px}.featured{grid-template-columns:1fr}.featured-art{max-width:520px}.album-grid{grid-template-columns:repeat(2,1fr)}.gallery-grid{grid-template-columns:1fr}.about{grid-template-columns:1fr}.about-image{min-height:420px;order:-1}.contact-grid,footer{grid-template-columns:1fr}.event-card{grid-template-columns:90px 1fr}.event-card button{grid-column:2}.vinyl{display:none}}@media(max-width:560px){.section{padding:80px 18px}.site-header{padding:0 18px}.hero-actions{flex-direction:column;align-items:center}.hero-actions .btn{width:min(330px,100%)}.album-grid{grid-template-columns:1fr}.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.gallery-item,.gallery-item.poster,.gallery-item.landscape{min-height:150px;aspect-ratio:auto;padding:6px}.gallery-item.landscape{grid-column:span 2;min-height:170px}.gallery-caption{font-size:9px;letter-spacing:.8px;padding:6px 7px;left:6px;right:6px;bottom:5px}.event-card{grid-template-columns:68px 1fr;padding:17px 14px}.date strong{font-size:48px}.featured{gap:38px}.featured-copy h2,.section-heading h2{font-size:54px}.about-copy{padding:80px 20px}.about h2{font-size:64px}}


@media(max-width:900px){.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.gallery-item{min-height:220px}.gallery-item.poster{min-height:280px}.gallery-item.landscape{grid-column:span 2;min-height:220px}}

@media(max-width:560px){.brand img{width:118px}.hero{background-position:58% center}.hero-logo img{width:94vw}.hero-content{padding-top:105px}.hero-tagline{font-size:11px;line-height:1.7}}

.inline-btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
.album-link{color:var(--red);font-weight:800;text-decoration:none;font-size:12px}
.play-orb{display:grid;place-items:center;text-decoration:none;margin:22px auto 0}
.platforms a:hover{border-color:var(--red);color:#fff}

@media(max-width:900px){.about-image img{object-position:67% center}}
@media(max-width:560px){.about-image{min-height:300px}.about-image img{object-position:68% center}.social-icon{width:40px;height:40px;font-size:17px}}


/* Procesos visuales de formularios (demostración sin backend) */
.form-submit{position:relative;min-height:50px;display:flex;align-items:center;justify-content:center;gap:10px}
.form-submit:disabled,.newsletter button:disabled{cursor:wait;opacity:.88}
.button-loader,.newsletter-loader{display:none;width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:formSpin .7s linear infinite}
.form-submit.is-loading .button-label{opacity:.75}
.form-submit.is-loading .button-loader{display:inline-block}
.form-status,.newsletter-status{min-height:0;margin:0;opacity:0;transform:translateY(8px);transition:.3s;color:var(--muted);font-size:13px;line-height:1.5}
.form-status.is-processing,.form-status.is-success,.newsletter-status.is-processing,.newsletter-status.is-success{opacity:1;transform:none;margin-top:4px}
.form-status.is-processing,.newsletter-status.is-processing{color:#d8d8d8}
.form-status.is-success{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid rgba(50,205,120,.35);background:rgba(50,205,120,.07);color:#dff7e8}
.status-check{width:30px;height:30px;flex:0 0 30px;border-radius:50%;display:grid;place-items:center;background:#22a85a;color:#fff;font-weight:900}
.newsletter-status.is-success{color:#9be3b8}
.newsletter button{position:relative;display:grid;place-items:center;min-width:58px}
.newsletter button.is-loading .newsletter-arrow{display:none}
.newsletter button.is-loading .newsletter-loader{display:block}
.contact-form input:disabled,.contact-form textarea:disabled,.newsletter input:disabled{opacity:.65}
@keyframes formSpin{to{transform:rotate(360deg)}}
@media(max-width:560px){.form-status.is-success{align-items:flex-start}.newsletter-status{font-size:12px}}
.ticket-modal{width:min(720px,94vw);border:1px solid rgba(255,255,255,.14);background:#09090a;color:#fff;padding:0;box-shadow:0 24px 60px rgba(0,0,0,.58);contain:layout paint;transform:translateZ(0)}.ticket-modal::backdrop{background:rgba(0,0,0,.9)}.ticket-modal-inner{padding:38px}.ticket-modal-header{padding-right:40px;border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:24px}.ticket-modal-header h2{font-family:'Bebas Neue';font-size:58px;letter-spacing:1.5px;margin:0}.ticket-modal-header p:last-child{color:var(--muted);margin:8px 0 0}.ticket-form{display:grid;gap:22px}.ticket-summary{display:grid;grid-template-columns:1fr 150px;gap:16px;background:#111114;border:1px solid var(--line);padding:18px}.ticket-summary>div{display:flex;justify-content:space-between;align-items:center}.ticket-summary label{display:grid;gap:8px;font-size:12px;color:#ccc}.quantity-label{align-self:start}.quantity-control{display:grid;grid-template-columns:42px minmax(68px,1fr) 42px;align-items:center;border:1px solid rgba(255,255,255,.14);background:#09090a;overflow:hidden}.quantity-btn{height:46px;border:0;background:#141417;color:#fff;font-size:24px;cursor:pointer;transition:.22s}.quantity-btn:hover{background:var(--red)}.quantity-btn:active{transform:scale(.96)}.quantity-control input{width:100%;height:46px;border:0;border-left:1px solid rgba(255,255,255,.1);border-right:1px solid rgba(255,255,255,.1);background:#0b0b0d;color:#fff;text-align:center;font-size:18px;font-weight:700;outline:none;-moz-appearance:textfield}.quantity-control input::-webkit-outer-spin-button,.quantity-control input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quantity-control:focus-within{border-color:var(--red);box-shadow:0 0 0 3px rgba(215,25,32,.12)}.quantity-help{color:#777;font-size:10px;line-height:1.4}.ticket-total{grid-column:1/-1;border-top:1px solid var(--line);padding-top:15px}.ticket-total strong{font-size:24px;color:var(--red)}.ticket-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.ticket-fields label{display:grid;gap:8px;font-size:13px}.ticket-fields label:last-child{grid-column:1/-1}.ticket-fields input{background:#0b0b0d;color:#fff;border:1px solid var(--line);padding:14px;outline:none}.ticket-fields input:focus{border-color:var(--red)}.ticket-submit{width:100%;position:relative}.ticket-submit.is-loading .ticket-button-label{opacity:0}.ticket-submit.is-loading .button-loader{display:block}.ticket-note{margin:0;color:#777;font-size:12px;text-align:center}.ticket-status{display:none;padding:18px;border:1px solid rgba(215,25,32,.45);background:rgba(215,25,32,.08)}.ticket-status.show{display:block}.ticket-status.success{border-color:rgba(52,211,153,.45);background:rgba(52,211,153,.08)}.ticket-code{font-family:monospace;letter-spacing:2px;color:#fff}.ticket-close{position:absolute;right:18px;top:12px}.ticket-button[disabled]{opacity:.65;cursor:not-allowed}@media(max-width:620px){.ticket-modal-inner{padding:26px 18px}.ticket-modal-header h2{font-size:42px}.ticket-summary,.ticket-fields{grid-template-columns:1fr}.ticket-fields label:last-child{grid-column:auto}}


/* Scrollbar personalizada Vendetta */
html{scrollbar-width:thin;scrollbar-color:var(--red) #09090a}
*{scrollbar-width:thin;scrollbar-color:var(--red) #09090a}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:#09090a;border-left:1px solid rgba(255,255,255,.05)}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#ef202b,#8f0d14);border:3px solid #09090a;border-radius:999px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.14)}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#ff3440,#b30f19)}
::-webkit-scrollbar-corner{background:#09090a}
.ticket-modal::-webkit-scrollbar-track{background:#070708}
.ticket-modal::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#ef202b,#750b11);border-color:#070708}
@media(max-width:620px){.quantity-control{grid-template-columns:44px minmax(70px,1fr) 44px}.quantity-btn,.quantity-control input{height:48px}}

/* Optimización del modal de entradas para evitar tirones */
body.ticket-modal-open .noise{display:none}
body.ticket-modal-open .cursor-dot{display:none}
.ticket-modal[open]{animation:ticketModalIn .16s ease-out}
@keyframes ticketModalIn{from{opacity:0;transform:translateY(8px) scale(.992)}to{opacity:1;transform:translateY(0) scale(1)}}
@media(prefers-reduced-motion:reduce){.ticket-modal[open]{animation:none}}
