/* ==========================================================================
   TICKETU · Estilos específicos del HOME (Index)
   Se carga SOLO en la página de inicio, encima de ticketu.css.
   No incluye tokens, botones, header, menú, footer ni toast (ya en ticketu.css).
   ========================================================================== */

/* ============ HERO ============ */
.hero{position:relative;background:var(--ink);overflow:hidden}
.slides{position:relative;height:clamp(460px,72vh,680px)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .9s var(--ease);pointer-events:none}
.slide.active{opacity:1;pointer-events:auto}
.slide img{width:100%;height:100%;object-fit:cover}
.slide::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(15,11,8,.92) 0%,rgba(15,11,8,.7) 38%,rgba(15,11,8,.15) 75%,rgba(15,11,8,.45) 100%)}
@media (max-width:760px){.slide::after{background:linear-gradient(0deg,rgba(15,11,8,.95) 8%,rgba(15,11,8,.55) 55%,rgba(15,11,8,.4) 100%)}}
.slide-body{position:absolute;inset:0;z-index:2;display:flex;align-items:flex-end;padding-bottom:clamp(54px,9vh,96px)}
.slide-content{max-width:640px}
.slide-kicker{display:inline-flex;align-items:center;gap:.5em;background:var(--orange);color:#fff;font-weight:700;
  font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;padding:.4em .9em;border-radius:999px;margin-bottom:18px}
.slide h1{color:#fff;font-size:clamp(2.4rem,6vw,4.6rem);font-weight:800;margin-bottom:14px}
.slide-meta{display:flex;flex-wrap:wrap;gap:18px;color:var(--on-dark);font-weight:500;margin-bottom:26px;font-size:1.02rem}
.slide-meta span{display:inline-flex;align-items:center;gap:.5em}
.slide-meta svg{color:var(--orange)}
.slide-cta{display:flex;gap:12px;flex-wrap:wrap}
.slide.active .slide-kicker{animation:rise .6s var(--ease) both}
.slide.active h1{animation:rise .7s .06s var(--ease) both}
.slide.active .slide-meta{animation:rise .7s .12s var(--ease) both}
.slide.active .slide-cta{animation:rise .7s .18s var(--ease) both}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

.hero-nav{position:absolute;z-index:3;bottom:clamp(54px,9vh,96px);right:clamp(16px,4vw,40px);display:flex;gap:10px}
.hero-arrow{width:50px;height:50px;border-radius:50%;border:1.5px solid rgba(255,255,255,.35);color:#fff;display:grid;place-items:center;
  background:rgba(255,255,255,.06);backdrop-filter:blur(6px);transition:.25s}
.hero-arrow:hover{background:#fff;color:var(--ink);border-color:#fff}
.hero-dots{position:absolute;z-index:3;bottom:24px;left:clamp(16px,4vw,40px);display:flex;gap:8px}
.dot-btn{width:30px;height:5px;border-radius:3px;background:rgba(255,255,255,.3);transition:.3s}
.dot-btn.active{background:var(--orange);width:46px}

/* ============ SEARCH (ticket-stub signature) ============ */
.search-zone{position:relative;z-index:5;margin-top:-44px}
.searchbar{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-3);
  display:grid;grid-template-columns:1.6fr 1fr 1fr auto;align-items:stretch;gap:0;overflow:hidden;position:relative}
.searchbar::before{content:"";position:absolute;top:14px;bottom:14px;right:calc(0px);width:0}
.s-field{display:flex;align-items:center;gap:12px;padding:18px 22px;border-right:1px dashed var(--line-2);min-width:0}
.s-field svg{color:var(--orange);flex-shrink:0}
.s-field label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.s-field input,.s-field select{border:none;background:none;font-family:inherit;font-size:1rem;font-weight:600;color:var(--text);width:100%;padding:0;outline:none}
.s-field input::placeholder{color:#9a938c;font-weight:500}
.s-field select{cursor:pointer;-webkit-appearance:none;appearance:none}
.s-submit{display:flex;align-items:center}
.s-submit button{height:100%;background:var(--orange);color:#fff;font-weight:700;font-size:1.02rem;padding:0 32px;
  display:flex;align-items:center;gap:.6em;transition:background .2s;width:100%}
.s-submit button:hover{background:var(--orange-600)}
@media (max-width:860px){
  .search-zone{margin-top:-30px}
  .searchbar{grid-template-columns:1fr 1fr;gap:0}
  .s-field{border-right:1px dashed var(--line-2);border-bottom:1px dashed var(--line-2)}
  .s-field:nth-child(2){border-right:none}
  .s-submit{grid-column:1/-1}
  .s-submit button{padding:16px;justify-content:center}
}
@media (max-width:520px){
  .searchbar{grid-template-columns:1fr}
  .s-field{border-right:none}
}

/* ============ SECTIONS (home) ============ */
section{position:relative}
.section{padding-block:clamp(48px,7vw,88px)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:30px;flex-wrap:wrap}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.6rem);font-weight:700}
.section-head p{color:var(--muted);margin-top:8px;font-size:1.04rem;max-width:46ch}
.section-link{display:inline-flex;align-items:center;gap:.4em;font-weight:700;color:var(--orange-700);font-size:.98rem;transition:gap .2s}
.section-link:hover{gap:.7em}

/* ============ CATEGORIES ============ */
.cats{display:grid;grid-template-columns:repeat(8,1fr);gap:14px}
.cat{display:flex;flex-direction:column;align-items:center;gap:12px;padding:22px 10px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-md);transition:.28s var(--ease);text-align:center}
.cat:hover{border-color:var(--orange-200);box-shadow:var(--shadow-2);transform:translateY(-4px)}
.cat-ic{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:var(--orange-100);color:var(--orange-700);transition:.28s}
.cat:hover .cat-ic{background:var(--orange);color:#fff}
.cat span{font-weight:600;font-size:.94rem;color:var(--text)}
@media (max-width:1080px){.cats{grid-template-columns:repeat(4,1fr)}}
@media (max-width:560px){.cats{grid-template-columns:repeat(2,1fr)}}

/* ============ FILTER CHIPS ============ */
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.chip{padding:.6em 1.15em;border-radius:999px;border:1.5px solid var(--line-2);background:var(--surface);
  font-weight:600;font-size:.94rem;color:var(--text);transition:.2s}
.chip:hover{border-color:var(--ink)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ============ EVENT CARDS ============ */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:24px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;box-shadow:none;
  display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-2)}
.card.is-buyable{cursor:pointer}
.card-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.card:hover .card-media img{transform:scale(1.06)}
.card-date{position:absolute;top:12px;left:12px;background:rgba(22,17,13,.86);backdrop-filter:blur(4px);color:#fff;
  border-radius:10px;padding:7px 11px;text-align:center;line-height:1;min-width:50px}
.card-date .d{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.35rem}
.card-date .m{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);margin-top:3px}
.badge{position:absolute;top:12px;right:12px;color:#fff;font-weight:700;font-size:.72rem;letter-spacing:.04em;
  padding:.42em .8em;border-radius:999px;display:inline-flex;align-items:center;gap:.4em;text-transform:uppercase;box-shadow:0 4px 12px rgba(0,0,0,.18)}
.badge .bdot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.9)}
.badge--inaug{background:var(--orange)}
.badge--2x1{background:var(--blue)}
.badge--free{background:var(--green)}
.card-body{padding:16px 18px 18px;display:flex;flex-direction:column;flex:1}
.card-cat{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--orange-700);margin-bottom:7px}
.card h3{font-family:"Bricolage Grotesque";font-weight:700;font-size:1.18rem;letter-spacing:-.01em;margin-bottom:8px;line-height:1.12}
.card-venue{display:flex;align-items:center;gap:.45em;color:var(--muted);font-size:.9rem;margin-bottom:4px}
.card-venue svg{flex-shrink:0;color:#a59c93}
.card-foot{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px}
.price small{display:block;font-size:.72rem;color:var(--muted);font-weight:500}
.price b{font-family:"Bricolage Grotesque";font-size:1.25rem;font-weight:700;color:var(--text)}
.price b.free{color:var(--green)}

/* ============ SLIDER (destacados / ciudades) ============ */
.slider-wrap{position:relative}
.slider{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(300px,1fr);gap:22px;overflow-x:auto;
  scroll-snap-type:x mandatory;padding-bottom:8px;scrollbar-width:none}
.slider::-webkit-scrollbar{display:none}
.slider>*{scroll-snap-align:start}
@media (max-width:760px){.slider{grid-auto-columns:minmax(260px,82%)}}
.slider-btns{display:flex;gap:8px}
.sl-btn{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--line-2);background:var(--surface);color:var(--text);display:grid;place-items:center;transition:.22s}
.sl-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.sl-btn:disabled{opacity:.35;cursor:not-allowed}
.sl-btn:disabled:hover{background:var(--surface);color:var(--text);border-color:var(--line-2)}

/* feature card (destacados) */
.feat{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:330px;display:flex;align-items:flex-end;color:#fff}
.feat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.feat:hover img{transform:scale(1.05)}
.feat::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,11,8,.94),rgba(15,11,8,.15) 65%)}
.feat-body{position:relative;z-index:2;padding:24px}
.feat .tag{display:inline-block;background:var(--orange);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.34em .8em;border-radius:999px;margin-bottom:12px}
.feat h3{font-size:1.55rem;font-weight:800;margin-bottom:6px}
.feat p{color:var(--on-dark);font-size:.94rem}
.feat-explore{background:var(--ink);color:#fff;border-radius:var(--r-lg);min-height:330px;display:flex;flex-direction:column;
  justify-content:center;align-items:flex-start;padding:30px;gap:14px}
.feat-explore h3{font-size:1.7rem;font-weight:800;color:#fff}
.feat-explore p{color:var(--on-dark-muted)}

/* ciudades (slider del home) */
.city{position:relative;border-radius:var(--r-md);overflow:hidden;min-height:300px;display:flex;align-items:flex-end;color:#fff}
.city img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.city:hover img{transform:scale(1.06)}
.city::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,11,8,.9),rgba(15,11,8,.05) 60%)}
.city-body{position:relative;z-index:2;padding:22px;width:100%}
.city h3{font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:2px}
.city-foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.city-count{color:var(--on-dark);font-size:.92rem;font-weight:500}
.city-go{width:42px;height:42px;border-radius:50%;background:#fff;color:var(--ink);display:grid;place-items:center;transition:.25s}
.city:hover .city-go{background:var(--orange);color:#fff;transform:rotate(-45deg)}

/* ============ PASADOS ============ */
.past{background:var(--ink);color:var(--on-dark)}
.past h2{color:#fff}
.past .section-head p{color:var(--on-dark-muted)}
.past-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.past-card{display:flex;gap:16px;align-items:center;background:var(--ink-2);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r-md);padding:14px;transition:.25s}
.past-card:hover{border-color:rgba(255,255,255,.18);background:var(--ink-3)}
.past-thumb{width:84px;height:84px;border-radius:10px;overflow:hidden;flex-shrink:0;position:relative}
.past-thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(.7) brightness(.85);transition:.3s}
.past-card:hover .past-thumb img{filter:grayscale(0) brightness(1)}
.past-fin{position:absolute;inset:auto 0 0 0;background:rgba(0,0,0,.7);color:#fff;font-size:.6rem;font-weight:700;text-align:center;letter-spacing:.08em;padding:3px;text-transform:uppercase}
.past-info{min-width:0}
.past-info .pc{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--orange);margin-bottom:4px}
.past-info h3{font-size:1.08rem;color:#fff;font-weight:700;margin-bottom:4px}
.past-info .pv{color:var(--on-dark-muted);font-size:.86rem}
.past-info .pgal{display:inline-flex;align-items:center;gap:.35em;margin-top:7px;color:var(--on-dark);font-weight:600;font-size:.84rem}
.past-info .pgal:hover{color:var(--orange)}

/* ============ NEWSLETTER ============ */
.news-sec{padding-block:clamp(48px,7vw,88px)}
.news{position:relative;background:linear-gradient(120deg,var(--orange) 0%,var(--orange-600) 100%);border-radius:var(--r-xl);
  padding:clamp(34px,5vw,60px);overflow:hidden;color:#fff}
.news::before,.news::after{content:"";position:absolute;width:46px;height:46px;border-radius:50%;background:var(--bg);
  top:50%;transform:translateY(-50%)}
.news::before{left:-23px}
.news::after{right:-23px}
.news-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr 1fr;gap:30px;align-items:center}
.news h2{color:#fff;font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:800;max-width:18ch}
.news p{color:rgba(255,255,255,.92);margin-top:12px;max-width:42ch;font-size:1.05rem}
.news-form{display:flex;gap:10px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.4);
  padding:8px;border-radius:999px;backdrop-filter:blur(6px)}
.news-form input{flex:1;border:none;background:none;outline:none;color:#fff;font-family:inherit;font-size:1rem;font-weight:500;padding:0 16px;min-width:0}
.news-form input::placeholder{color:rgba(255,255,255,.78)}
.news-form button{background:#fff;color:var(--orange-700);font-weight:700;padding:.8em 1.5em;border-radius:999px;transition:.2s;white-space:nowrap}
.news-form button:hover{background:var(--ink);color:#fff}
.news-note{margin-top:12px;font-size:.82rem;color:rgba(255,255,255,.85)}
.news-ok{margin-top:14px;font-weight:700;display:none;align-items:center;gap:.5em}
.news-ok.show{display:inline-flex}
@media (max-width:760px){.news-grid{grid-template-columns:1fr;gap:22px}}
