/* JuicyBet — page-level blocks: hero, swiper, banners, cards, forms, legal. */

.page-head { margin-top: var(--sp-5); }
.page-head h1 { font-size: var(--fs-xl); margin: var(--sp-3) 0; }
.page-head__sub { color: var(--fg-100); max-width: 64ch; }

/* ---- Hero ---- */
.hero { margin-top: var(--sp-5); }
.hero__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: var(--sp-6); align-items: center; }
.hero__kicker { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-100); text-transform: uppercase; letter-spacing: .12em; }
.pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--up); box-shadow: 0 0 10px var(--up); animation: blink 1.4s infinite; }
.hero__title { font-size: var(--fs-2xl); line-height: var(--lh-tight); margin: var(--sp-4) 0; letter-spacing: -.02em; }
.hero__title em { background: linear-gradient(90deg, var(--accent), var(--accent-2)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero__sub { font-size: var(--fs-md); color: var(--fg-100); max-width: 52ch; }
.hero__actions { display: flex; gap: var(--sp-3); margin-top: var(--sp-5); flex-wrap: wrap; }
.hero__stats { display: flex; gap: var(--sp-6); margin-top: var(--sp-6); }
.hero__stats b { display: block; font-family: var(--font-display); font-size: var(--fs-lg); color: var(--fg-000); }
.hero__stats span { font-size: var(--fs-xs); color: var(--fg-300); text-transform: uppercase; letter-spacing: .08em; }

.featcard { position: relative; background: linear-gradient(160deg, var(--bg-100), var(--bg-050)); border: 1px solid var(--accent-line); border-radius: var(--r-xl); padding: var(--sp-5); box-shadow: var(--glow-mag); overflow: hidden; }
.featcard::after { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 60% at 80% 0%, color-mix(in srgb, var(--accent-2) 24%, transparent), transparent 60%); pointer-events: none; }
.featcard__top { display: flex; justify-content: space-between; align-items: center; position: relative; z-index: 1; }
.featcard__league { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-300); }
.featcard__teams { display: grid; grid-template-columns: 1fr auto 1fr; gap: var(--sp-3); align-items: center; text-align: center; margin: var(--sp-5) 0; font-family: var(--font-display); font-weight: 800; font-size: var(--fs-md); color: var(--fg-000); position: relative; z-index: 1; }
.featcard__vs { font-family: var(--font-mono); color: var(--accent); font-size: var(--fs-sm); }
.featcard__odds { display: flex; gap: var(--sp-2); position: relative; z-index: 1; }
.featcard__odds .odds-chip { flex: 1; }
.featcard__note { font-size: var(--fs-xs); color: var(--fg-300); margin-top: var(--sp-4); position: relative; z-index: 1; }

/* ---- Swiper (banners) ---- */
.swiper { position: relative; overflow: hidden; border-radius: var(--r-xl); }
.swiper__track { display: flex; transition: transform var(--t-slow) var(--ease); }
.banner { position: relative; flex: 0 0 100%; min-height: 220px; padding: var(--sp-7) var(--sp-6); display: flex; flex-direction: column; align-items: flex-start; justify-content: center; gap: var(--sp-3); overflow: hidden; }
.banner--magenta { background: linear-gradient(120deg, color-mix(in srgb, var(--accent) 30%, var(--bg-100)), var(--bg-050)); }
.banner--cyan { background: linear-gradient(120deg, color-mix(in srgb, var(--accent-2) 28%, var(--bg-100)), var(--bg-050)); }
.banner--lime { background: linear-gradient(120deg, color-mix(in srgb, var(--accent-3) 26%, var(--bg-100)), var(--bg-050)); }
.banner__tag { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-000); background: rgba(0,0,0,.3); padding: 4px 10px; border-radius: var(--r-pill); }
.banner__title { font-size: var(--fs-lg); max-width: 22ch; }
.banner__body { color: var(--fg-100); max-width: 46ch; }
.banner__glow { position: absolute; right: -60px; top: -60px; width: 240px; height: 240px; border-radius: 50%; background: var(--accent-3); filter: blur(70px); opacity: .25; }
.banner--cyan .banner__glow { background: var(--accent); }
.swiper__dots { display: flex; gap: 8px; justify-content: center; position: absolute; bottom: 14px; left: 0; right: 0; }
.swiper__dots button { width: 9px; height: 9px; border-radius: 50%; border: none; background: rgba(255,255,255,.35); cursor: pointer; padding: 0; }
.swiper__dots button[aria-current="true"] { background: var(--accent); width: 26px; border-radius: var(--r-pill); }
.swiper__arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--bg-300); background: rgba(10,6,18,.6); color: var(--fg-000); font-size: 1.4rem; cursor: pointer; display: grid; place-items: center; backdrop-filter: blur(6px); }
.swiper__arrow--prev { left: 12px; } .swiper__arrow--next { right: 12px; }
.swiper__arrow:hover { border-color: var(--accent-2); color: var(--accent-2); }

/* ---- Drag scroller (matches) ---- */
.drag { display: flex; gap: var(--sp-4); overflow-x: auto; padding-bottom: var(--sp-3); scroll-snap-type: x mandatory; cursor: grab; -ms-overflow-style: none; scrollbar-width: thin; }
.drag.is-drag { cursor: grabbing; }
.drag::-webkit-scrollbar { height: 6px; }
.drag::-webkit-scrollbar-thumb { background: var(--bg-300); border-radius: var(--r-pill); }
.matchcard { flex: 0 0 270px; scroll-snap-align: start; background: var(--bg-100); border: 1px solid var(--bg-300); border-radius: var(--r-lg); padding: var(--sp-4); transition: var(--t-fast); }
.matchcard:hover { border-color: var(--accent-line); box-shadow: var(--sh-2); transform: translateY(-3px); }
.matchcard__top { display: flex; justify-content: space-between; align-items: center; }
.matchcard__comp { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-300); }
.matchcard__teams { font-family: var(--font-display); font-weight: 700; color: var(--fg-000); text-align: center; margin: var(--sp-4) 0; }
.matchcard__v { font-family: var(--font-mono); color: var(--accent); font-size: var(--fs-xs); }
.matchcard__odds { display: flex; gap: var(--sp-2); }
.matchcard__odds .odds-chip { flex: 1; }

/* ---- Racing ---- */
.racegrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--sp-4); }
.racecard { background: var(--bg-100); border: 1px solid var(--bg-300); border-radius: var(--r-lg); padding: var(--sp-4); }
.racecard__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--sp-3); }
.racecard__track { font-family: var(--font-display); font-weight: 700; color: var(--fg-000); }
.racecard__track small { color: var(--fg-300); font-weight: 400; font-family: var(--font-mono); font-size: var(--fs-xs); }
.racecard__next { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--accent-3); }
.racecard__runners { list-style: none; }
.racecard__runners li { display: grid; grid-template-columns: 26px 1fr auto; gap: var(--sp-3); align-items: center; padding: 7px 0; border-top: 1px solid var(--bg-300); }
.runner__no { font-family: var(--font-mono); font-weight: 700; color: var(--accent-ink); background: var(--accent-2); width: 24px; height: 24px; border-radius: var(--r-xs); display: grid; place-items: center; font-size: var(--fs-xs); }
.runner__name { color: var(--fg-000); font-size: var(--fs-sm); }
.runner__name small { color: var(--fg-300); font-family: var(--font-mono); }
.racecard__going { display: inline-block; margin-top: var(--sp-3); font-size: var(--fs-xs); color: var(--fg-300); }

/* ---- CTA strip / promo grid ---- */
.cta-strip { display: flex; gap: var(--sp-5); align-items: center; justify-content: space-between; flex-wrap: wrap; background: linear-gradient(120deg, var(--accent-soft), var(--cyan-soft)); border: 1px solid var(--accent-line); border-radius: var(--r-xl); padding: var(--sp-6); }
.cta-strip h3 { font-size: var(--fs-lg); margin-bottom: var(--sp-2); }
.cta-strip p { color: var(--fg-100); max-width: 60ch; }
.cta-strip__actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.promo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: var(--sp-4); }
.promo-card { background: var(--bg-100); border: 1px solid var(--bg-300); border-radius: var(--r-lg); padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-3); align-items: flex-start; }
.promo-card--magenta { border-top: 3px solid var(--accent); }
.promo-card--cyan { border-top: 3px solid var(--accent-2); }
.promo-card--lime { border-top: 3px solid var(--accent-3); }
.promo-card__tag { font-family: var(--font-mono); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .12em; color: var(--accent-2); }
.promo-card h2 { font-size: var(--fs-md); }
.promo-card p { color: var(--fg-100); font-size: var(--fs-sm); }

/* ---- Chip filter ---- */
.chiprow { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin: var(--sp-5) 0; }
.chip { background: var(--bg-100); border: 1px solid var(--bg-300); color: var(--fg-100); padding: 8px 14px; border-radius: var(--r-pill); font-family: var(--font-display); font-weight: 600; font-size: var(--fs-sm); cursor: pointer; transition: var(--t-fast); }
.chip:hover { border-color: var(--accent-2); }
.chip.is-on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }

/* ---- FAQ ---- */
.faq { display: flex; flex-direction: column; gap: var(--sp-3); }
.faq__item { background: var(--bg-100); border: 1px solid var(--bg-300); border-radius: var(--r-lg); padding: var(--sp-4) var(--sp-5); }
.faq__item summary { cursor: pointer; font-family: var(--font-display); font-weight: 700; color: var(--fg-000); list-style: none; display: flex; justify-content: space-between; gap: var(--sp-3); }
.faq__item summary::after { content: "+"; color: var(--accent-2); font-size: 1.3rem; }
.faq__item[open] summary::after { content: "−"; }
.faq__item p { margin-top: var(--sp-3); color: var(--fg-100); }

/* ---- Auth ---- */
.auth { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-6); margin-top: var(--sp-5); align-items: start; }
.auth--narrow { grid-template-columns: minmax(0, 460px); justify-content: center; }
.auth__intro h1 { font-size: var(--fs-xl); margin: var(--sp-3) 0; }
.auth__form { padding: var(--sp-6); }
.auth__form h1 { margin: var(--sp-2) 0 var(--sp-4); }
.auth__alt { font-size: var(--fs-sm); color: var(--fg-300); margin-top: var(--sp-4); }
.ticklist { list-style: none; margin-top: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-2); }
.ticklist li { padding-left: 26px; position: relative; color: var(--fg-100); }
.ticklist li::before { content: "✓"; position: absolute; left: 0; color: var(--accent-3); font-weight: 700; }

/* ---- Contact / account ---- */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: var(--sp-6); align-items: start; }
.contact-info { display: grid; gap: var(--sp-4); }
.contact-tile, .acct-tile { padding: var(--sp-5); }
.contact-tile h3, .acct-tile h3 { font-size: var(--fs-md); margin-bottom: var(--sp-2); }
.contact-form { padding: var(--sp-6); }
.acct-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: var(--sp-4); margin-top: var(--sp-5); }
.acct-tile { display: flex; flex-direction: column; gap: var(--sp-3); align-items: flex-start; }
.acct-tile__big { font-size: var(--fs-xl); color: var(--accent-3); }

/* ---- Prose / legal ---- */
.prose { padding: var(--sp-6); }
.prose h2 { font-size: var(--fs-md); margin: var(--sp-5) 0 var(--sp-2); color: var(--accent-2); }
.prose p { color: var(--fg-100); margin-bottom: var(--sp-3); }
.legal { max-width: 820px; }
.crumbs { font-size: var(--fs-xs); color: var(--fg-300); margin-bottom: var(--sp-4); }
.legal__head h1 { font-size: var(--fs-xl); margin: var(--sp-3) 0; }
.legal__lead { color: var(--fg-100); font-size: var(--fs-md); }
.legal__updated { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-300); margin-top: var(--sp-2); }
.legal__body { margin-top: var(--sp-6); display: flex; flex-direction: column; gap: var(--sp-5); }
.legal__section h2 { font-size: var(--fs-md); margin-bottom: var(--sp-2); color: var(--accent-2); }
.legal__section p { color: var(--fg-100); }
.legal__rg { margin-top: var(--sp-6); background: var(--cyan-soft); border: 1px solid var(--accent-line); border-radius: var(--r-lg); padding: var(--sp-4) var(--sp-5); font-size: var(--fs-sm); color: var(--fg-000); }

/* ---- Error ---- */
.errpage { text-align: center; padding: var(--sp-9) 0; }
.errpage__code { font-family: var(--font-mono); font-weight: 700; font-size: clamp(4rem, 14vw, 9rem); background: linear-gradient(90deg, var(--accent), var(--accent-2)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; display: block; }
.errpage h1 { font-size: var(--fs-lg); margin: var(--sp-3) 0; }
.errpage .hero__actions { justify-content: center; }

@media (max-width: 860px) {
    .hero__grid, .auth, .contact-grid { grid-template-columns: 1fr; }
    .hero__stats { flex-wrap: wrap; gap: var(--sp-4); }
}

/* ===== Imagery slots (drop MJ exports into assets/img/) ===== */
.hero { position: relative; border-radius: var(--r-xl); padding: var(--sp-7) var(--sp-6);
    background-image: linear-gradient(115deg, rgba(10,6,18,.94) 0%, rgba(10,6,18,.62) 52%, rgba(34,224,255,.20) 100%), url('/assets/img/hero.jpg');
    background-size: cover; background-position: center; border: 1px solid var(--bg-300); }
.swiper__track > .banner { background-size: cover; background-position: center; }
.swiper__track > .banner:nth-child(1) { background-image: linear-gradient(120deg, rgba(255,43,214,.42), rgba(10,6,18,.86)), url('/assets/img/banner-1.jpg'); }
.swiper__track > .banner:nth-child(2) { background-image: linear-gradient(120deg, rgba(34,224,255,.40), rgba(10,6,18,.86)), url('/assets/img/banner-2.jpg'); }
.swiper__track > .banner:nth-child(3) { background-image: linear-gradient(120deg, rgba(182,255,60,.36), rgba(10,6,18,.88)), url('/assets/img/banner-3.jpg'); }

/* ===== Fix: hero grid children overflowing into bet slip ===== */
.hero { overflow: clip; }
.hero__grid { min-width: 0; }
.hero__copy, .hero__card { min-width: 0; }
.hero__title { overflow-wrap: anywhere; }
@media (max-width: 1240px) { .hero__grid { grid-template-columns: 1fr; } .hero__card { max-width: 460px; } }

/* ===== chip anchors + empty state + footer payments ===== */
.chiprow a.chip { text-decoration: none; }
.empty-state { padding: var(--sp-6); text-align: center; color: var(--fg-300); }
.empty-state p { margin: var(--sp-2) 0; }
.footer-pay { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-3); margin: var(--sp-5) 0; }
.footer-pay__label { font-size: var(--fs-xs); color: var(--fg-300); }
.footer-pay__logos { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.footer-pay__logos img { height: 22px; background: #fff; padding: 5px 8px; border-radius: 6px; }

/* stack hero earlier so featcard never meets the slip in tight 3-col */
@media (max-width: 1400px){ .hero__grid { grid-template-columns: 1fr; } .hero__card { max-width: 520px; } }

/* Hero always single-column inside the 3-col shell (main is narrow) — no clip/overflow */
.hero__grid { grid-template-columns: 1fr; }
.hero__card { max-width: 560px; }
.hero { overflow: visible; }
.featcard__teams { gap: var(--sp-2); }
.featcard__team { overflow-wrap: anywhere; }
