/* ====== Fan Guide 2026 — pages.css ====== */

/* ---- Home hero ---- */
.hero {
  position: relative; overflow: hidden;
  background:
    radial-gradient(1100px 520px at 88% -10%, rgba(31,143,255,.34), transparent 60%),
    radial-gradient(820px 480px at -8% 118%, rgba(226,31,43,.26), transparent 56%),
    var(--sky-900);
  color: #fff;
}
.hero__deco {
  position: absolute; inset: 0; pointer-events: none; opacity: .55;
  background-image: radial-gradient(rgba(255,255,255,.16) 1.4px, transparent 1.7px);
  background-size: 28px 28px;
  mask-image: radial-gradient(75% 75% at 72% 6%, #000, transparent);
}
.hero__inner { position: relative; display: grid; grid-template-columns: 1.1fr .9fr; gap: 48px; align-items: center; padding-block: clamp(56px, 8vw, 110px); }
.hero h1 { color: #fff; margin: 16px 0 18px; }
.hero h1 span { background: linear-gradient(90deg, var(--sky-300), var(--maple-400)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero p { color: rgba(255,255,255,.85); font-size: 1.16rem; max-width: 52ch; }
.hero .btn-row { margin-top: 28px; }
.hero__meta { margin-top: 30px; display: flex; gap: 26px; flex-wrap: wrap; }
.hero__meta div b { font-family: var(--font-head); font-size: 1.6rem; color: #fff; display: block; line-height: 1; }
.hero__meta div span { font-size: .82rem; color: rgba(255,255,255,.7); }

/* Hero visual ticket/card */
.hero__art {
  position: relative; border-radius: 22px; padding: 26px;
  background: linear-gradient(160deg, rgba(255,255,255,.16), rgba(255,255,255,.05));
  border: 1px solid rgba(255,255,255,.2); box-shadow: var(--shadow-lg);
  backdrop-filter: blur(6px);
}
.hero__art .ticket {
  background: #fff; border-radius: 16px; overflow: hidden; color: var(--ink); box-shadow: var(--shadow);
}
.ticket__top { padding: 16px 20px; background: linear-gradient(135deg, var(--maple-500), var(--maple-700)); color: #fff; display: flex; justify-content: space-between; align-items: center; }
.ticket__top b { font-family: var(--font-head); letter-spacing: .04em; }
.ticket__body { padding: 20px; }
.ticket__teams { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.ticket__team { text-align: center; flex: 1; }
.ticket__team .flag { width: 54px; height: 36px; margin: 0 auto 8px; border-radius: 6px; }
.ticket__team b { font-family: var(--font-head); font-size: 1.05rem; }
.ticket__vs { font-family: var(--font-head); font-weight: 800; color: var(--muted); font-size: .9rem; }
.ticket__foot { margin-top: 16px; padding-top: 14px; border-top: 1px dashed var(--line); display: flex; justify-content: space-between; font-size: .82rem; color: var(--muted); }
.hero__art .badge-float {
  position: absolute; top: -14px; right: -10px; transform: rotate(8deg);
  background: linear-gradient(135deg, var(--sky-400, var(--sky-500)), var(--sky-700));
  color: #fff; font-family: var(--font-head); font-weight: 800; font-size: .8rem;
  padding: 8px 14px; border-radius: 999px; box-shadow: var(--shadow);
}

/* Host city chips */
.hostbar { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 26px; }
.host-chip { display: inline-flex; align-items: center; gap: .5rem; padding: .5rem .85rem; border-radius: 999px; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.16); font-size: .88rem; color: #fff; }
.host-chip b { font-family: var(--font-head); }

/* Editorial featured row */
.featured { display: grid; grid-template-columns: 1.3fr 1fr; gap: 28px; }
.featured__main { position: relative; border-radius: var(--radius); overflow: hidden; min-height: 380px; display: flex; align-items: flex-end; color: #fff; }
.featured__main .gen { position: absolute; inset: 0; }
.featured__main .body { position: relative; padding: 32px; }
.featured__main h3 { color: #fff; font-size: clamp(1.4rem, 2.6vw, 2rem); margin: 10px 0; }
.featured__main p { color: rgba(255,255,255,.86); max-width: 46ch; }
.featured__side { display: grid; gap: 20px; align-content: start; }
.mini { display: grid; grid-template-columns: 96px 1fr; gap: 14px; align-items: center; padding-bottom: 18px; border-bottom: 1px solid var(--line); }
.mini:last-child { border-bottom: 0; padding-bottom: 0; }
.mini__media { width: 96px; height: 72px; border-radius: 12px; overflow: hidden; position: relative; }
.mini h4 { font-size: 1.02rem; }
.mini h4 a { color: var(--ink); }
.mini h4 a:hover { color: var(--maple-600); }
.mini__meta { font-size: .76rem; color: var(--muted); }

/* CTA band */
.cta-band {
  border-radius: var(--radius); overflow: hidden; position: relative; color: #fff;
  background: linear-gradient(135deg, var(--maple-500), var(--maple-700));
  padding: clamp(34px, 5vw, 56px); text-align: center;
}
.cta-band::after { content: ""; position: absolute; inset: 0; opacity: .25; background-image: radial-gradient(rgba(255,255,255,.4) 1.2px, transparent 1.4px); background-size: 22px 22px; }
.cta-band h2, .cta-band p { color: #fff; position: relative; }
.cta-band .btn-row { position: relative; justify-content: center; margin-top: 24px; }

/* Newsletter-ish info row (no form) */
.editorial-note { background: var(--paper-2); border: 1px dashed var(--line); border-radius: var(--radius); padding: clamp(22px,3vw,34px); }

/* Contacts page */
.contact-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.contact-card { text-align: center; padding: 30px 22px; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; transition: transform .25s var(--ease), box-shadow .25s var(--ease); }
.contact-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.contact-card .feature__icon { margin: 0 auto 16px; width: 58px; height: 58px; }
.contact-card a { font-family: var(--font-head); font-weight: 700; font-size: 1.05rem; }
.map-faux { border-radius: var(--radius); min-height: 320px; position: relative; overflow: hidden; border: 1px solid var(--line); }
.map-faux .pin { position: absolute; left: 50%; top: 46%; transform: translate(-50%,-50%); width: 46px; height: 46px; color: var(--maple-600); filter: drop-shadow(0 6px 10px rgba(0,0,0,.25)); }

/* Legal / prose pages */
.prose { max-width: 76ch; }
.prose h2 { margin: 38px 0 14px; }
.prose h3 { margin: 26px 0 10px; }
.prose p, .prose li { margin-bottom: .9rem; }
.prose ul { margin-bottom: 1.2rem; }
.toc-legal { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px 26px; margin-bottom: 30px; }
.toc-legal ol { margin: 0; }
.toc-legal a { font-weight: 600; }

/* About team */
.team { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.member { text-align: center; }
.member__avatar { width: 96px; height: 96px; border-radius: 50%; margin: 0 auto 14px; display: grid; place-items: center; font-family: var(--font-head); font-weight: 800; font-size: 1.8rem; color: #fff; }
.member h4 { margin-bottom: 2px; }
.member span { color: var(--muted); font-size: .9rem; }

/* values list */
.values { display: grid; grid-template-columns: repeat(2,1fr); gap: 28px; }

/* ---- Photo backgrounds & media (final polish) ---- */
/* Hero / page-hero photo layer sits under the existing gradient scrim */
.hero__photo, .page-hero__photo {
  position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none;
}
.hero__photo img, .page-hero__photo img {
  width: 100%; height: 100%; object-fit: cover;
}
/* Darken so light text stays readable on top of the photo */
.hero__photo::after, .page-hero__photo::after {
  content: ""; position: absolute; inset: 0;
}
.hero__photo::after {
  background:
    radial-gradient(1100px 520px at 88% -10%, rgba(31,143,255,.34), transparent 60%),
    linear-gradient(120deg, rgba(10,37,64,.92) 0%, rgba(10,37,64,.78) 45%, rgba(10,37,64,.6) 100%);
}
.page-hero__photo::after {
  background: linear-gradient(120deg, rgba(10,37,64,.92) 0%, rgba(10,37,64,.8) 50%, rgba(10,37,64,.66) 100%);
}
.hero .hero__inner, .page-hero .container { position: relative; z-index: 1; }

/* Real photo inside card / mini / featured media */
.card__media img, .mini__media img, .featured__main .featured__img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.mini__media img { transition: transform .5s var(--ease); }
.mini:hover .mini__media img { transform: scale(1.06); }
.featured__main .featured__img {
  position: absolute; inset: 0; z-index: 0;
}
.featured__main::after {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(180deg, rgba(10,37,64,.15) 0%, rgba(10,37,64,.55) 55%, rgba(10,37,64,.88) 100%);
}
.featured__main .body { z-index: 1; }
.featured__main:hover .featured__img { transform: scale(1.04); transition: transform .6s var(--ease); }

/* Photo card with a city label overlay (host cities) */
.card__media:has(> img)::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; top: 40%; z-index: 1;
  background: linear-gradient(180deg, transparent, rgba(10,37,64,.72)); pointer-events: none;
}
.card__media > .gen__label { z-index: 2; left: 16px; bottom: 14px; }

@media (max-width: 980px) {
  .hero__inner { grid-template-columns: 1fr; }
  .hero__art { max-width: 460px; }
  .featured { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .team { grid-template-columns: 1fr; }
  .values { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .hero__meta { gap: 18px; }
  .mini { grid-template-columns: 78px 1fr; }
}
