/* JimmyBet — page blocks: hero, fade swiper, meetings, prestige, virtues, shared pages. */

.page-head { max-width: var(--reading-max); margin: var(--sp-6) auto 0; text-align: center; }
.page-head h1 { font-size: var(--fs-xl); margin: var(--sp-3) 0; font-weight: 500; }
.page-head__sub { color: var(--fg-100); }

/* ---- Hero (centered editorial) ---- */
.hero { text-align: center; max-width: var(--reading-max); margin: var(--sp-7) auto 0; }
.hero__kicker { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: .24em; text-transform: uppercase; color: var(--accent); }
.hero__title { font-size: var(--fs-2xl); font-weight: 500; line-height: var(--lh-tight); margin: var(--sp-4) 0; letter-spacing: -.02em; }
.hero__title em { font-style: italic; color: var(--accent); }
.hero__sub { font-size: var(--fs-md); color: var(--fg-100); max-width: 56ch; margin: 0 auto; }
.hero__actions { display: flex; gap: var(--sp-3); justify-content: center; margin-top: var(--sp-5); flex-wrap: wrap; }
.hero__rule { width: 1px; height: 56px; background: linear-gradient(var(--accent), transparent); margin: var(--sp-6) auto 0; }
.featured-bet { max-width: 520px; margin: var(--sp-6) auto 0; background: var(--bg-100); border: 1px solid var(--gold-line); border-radius: var(--r-lg); padding: var(--sp-5); box-shadow: 0 0 0 1px var(--gold-soft), var(--sh-2); }
.featured-bet__meta { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-300); }
.featured-bet__teams { font-family: var(--font-display); font-size: var(--fs-md); color: var(--fg-000); margin: var(--sp-3) 0 var(--sp-4); }
.featured-bet__teams span { color: var(--accent); font-style: italic; }
.featured-bet__odds { display: flex; gap: var(--sp-2); justify-content: center; }
.featured-bet__odds .odds-chip { flex: 1; max-width: 130px; }

/* ---- Fade swiper / meetings ---- */
.swiper { position: relative; }
.swiper--fade { max-width: 620px; margin: 0 auto; min-height: 320px; }
.swiper--fade .swiper__track { position: relative; }
.swiper--fade.is-fade [data-swiper-slide] { position: absolute; inset: 0; transition: opacity var(--t-slow) var(--ease); }
.swiper--fade [data-swiper-slide]:first-child { position: relative; }
.meeting { background: var(--bg-100); border: 1px solid var(--bg-300); border-radius: var(--r-lg); padding: var(--sp-5); }
.meeting__head { display: flex; justify-content: space-between; align-items: baseline; }
.meeting__track { font-family: var(--font-display); font-size: var(--fs-lg); color: var(--fg-000); }
.meeting__state { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-300); }
.meeting__next { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--accent); margin: var(--sp-2) 0 var(--sp-4); }
.meeting__runners { list-style: none; }
.meeting__runners li { display: grid; grid-template-columns: 26px 1fr auto; gap: var(--sp-3); align-items: center; padding: var(--sp-3) 0; border-top: 1px solid var(--bg-300); }
.runner__no { font-family: var(--font-mono); width: 24px; height: 24px; display: grid; place-items: center; border: 1px solid var(--gold-line); color: var(--accent); border-radius: var(--r-xs); font-size: var(--fs-xs); }
.runner__name { color: var(--fg-000); font-size: var(--fs-sm); }
.runner__name small { color: var(--fg-300); }
.meeting__link { display: inline-block; margin-top: var(--sp-4); font-family: var(--font-mono); font-size: var(--fs-xs); }
.swiper__dots { display: flex; gap: 8px; justify-content: center; margin-top: var(--sp-4); }
.swiper__dots button { width: 8px; height: 8px; border-radius: 50%; border: 1px solid var(--gold-line); background: transparent; cursor: pointer; padding: 0; }
.swiper__dots button[aria-current="true"] { background: var(--accent); border-color: var(--accent); }
.swiper__arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--gold-line); background: var(--bg-050); color: var(--accent); cursor: pointer; }
.swiper__arrow--prev { left: -8px; } .swiper__arrow--next { right: -8px; }

/* ---- Prestige banner ---- */
.prestige-banner { text-align: center; max-width: var(--reading-max); margin: 0 auto; padding: var(--sp-8) var(--sp-6); border: 1px solid var(--gold-line); border-radius: var(--r-xl); background: linear-gradient(180deg, var(--gold-soft), transparent); }
.prestige-banner h3 { font-size: var(--fs-lg); font-weight: 500; margin: var(--sp-2) 0 var(--sp-3); }
.prestige-banner p { color: var(--fg-100); max-width: 56ch; margin: 0 auto var(--sp-5); }
.prestige-banner__actions { display: flex; gap: var(--sp-3); justify-content: center; flex-wrap: wrap; }

/* ---- Virtues ---- */
.virtues { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); max-width: var(--reading-max); margin: 0 auto; }
.virtues article { text-align: center; padding: 0 var(--sp-3); }
.virtues__n { font-family: var(--font-display); font-style: italic; font-size: var(--fs-lg); color: var(--accent); }
.virtues h4 { font-size: var(--fs-md); font-weight: 500; margin: var(--sp-2) 0; }
.virtues p { color: var(--fg-300); font-size: var(--fs-sm); }

/* ---- Shared: chip filter ---- */
.chiprow { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin: var(--sp-5) auto; justify-content: center; max-width: var(--reading-max); }
.chip { background: transparent; border: 1px solid var(--bg-300); color: var(--fg-100); padding: 7px 16px; border-radius: var(--r-pill); font-family: var(--font-body); font-size: var(--fs-sm); cursor: pointer; transition: var(--t-fast); }
.chip:hover { border-color: var(--accent); color: var(--accent); }
.chip.is-on { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.market-block { max-width: var(--reading-max); margin: var(--sp-6) auto 0; }
.market__legend { display: none; }

/* ---- Shared: racing ---- */
.racegrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px,1fr)); gap: var(--sp-4); max-width: var(--content-max); margin: var(--sp-5) auto 0; }
.racecard { background: var(--bg-100); border: 1px solid var(--bg-300); border-radius: var(--r-lg); padding: var(--sp-5); }
.racecard__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: var(--sp-3); }
.racecard__track { font-family: var(--font-display); font-size: var(--fs-md); color: var(--fg-000); }
.racecard__track small { color: var(--fg-300); 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); }
.racecard__runners { list-style: none; }
.racecard__runners li { display: grid; grid-template-columns: 26px 1fr auto; gap: var(--sp-3); align-items: center; padding: var(--sp-3) 0; border-top: 1px solid var(--bg-300); }
.racecard__going { display: inline-block; margin-top: var(--sp-3); font-size: var(--fs-xs); color: var(--fg-300); }

/* ---- Shared: promotions ---- */
.promo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px,1fr)); gap: var(--sp-4); max-width: var(--content-max); margin: var(--sp-5) auto 0; }
.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--gold { border-top: 2px solid var(--accent); }
.promo-card--sage { border-top: 2px solid var(--sage); }
.promo-card__tag { font-family: var(--font-mono); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .16em; color: var(--accent); }
.promo-card h2 { font-size: var(--fs-md); font-weight: 500; }
.promo-card p { color: var(--fg-100); font-size: var(--fs-sm); }

/* ---- Shared: cta strip ---- */
.cta-strip { display: flex; gap: var(--sp-5); align-items: center; justify-content: space-between; flex-wrap: wrap; max-width: var(--reading-max); margin: var(--sp-6) auto 0; padding: var(--sp-6); border: 1px solid var(--gold-line); border-radius: var(--r-xl); background: linear-gradient(180deg, var(--gold-soft), transparent); }
.cta-strip h3 { font-size: var(--fs-md); font-weight: 500; margin-bottom: var(--sp-2); }
.cta-strip p { color: var(--fg-100); }
.cta-strip__actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; }

/* ---- Shared: FAQ ---- */
.faq { display: flex; flex-direction: column; gap: var(--sp-2); max-width: var(--reading-max); margin: var(--sp-5) auto 0; }
.faq__item { border-bottom: 1px solid var(--bg-300); padding: var(--sp-4) 0; }
.faq__item summary { cursor: pointer; font-family: var(--font-display); font-size: var(--fs-md); 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); }
.faq__item[open] summary::after { content: "–"; }
.faq__item p { margin-top: var(--sp-3); color: var(--fg-100); }

/* ---- Shared: auth ---- */
.auth { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-7); max-width: var(--content-max); margin: var(--sp-6) auto 0; align-items: start; }
.auth--narrow { grid-template-columns: minmax(0, 460px); justify-content: center; }
.auth__intro h1 { font-size: var(--fs-xl); font-weight: 500; margin: var(--sp-3) 0; }
.auth__form { padding: var(--sp-6); background: var(--bg-100); border: 1px solid var(--bg-300); border-radius: var(--r-lg); }
.auth__form h1 { font-size: var(--fs-lg); font-weight: 500; 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: 24px; position: relative; color: var(--fg-100); }
.ticklist li::before { content: "—"; position: absolute; left: 0; color: var(--accent); }

/* ---- Shared: contact / account ---- */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: var(--sp-6); max-width: var(--content-max); margin: var(--sp-6) auto 0; 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); font-weight: 500; 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); max-width: var(--content-max); margin: var(--sp-5) auto 0; }
.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); }

/* ---- Shared: prose / legal ---- */
.prose { padding: var(--sp-6); max-width: var(--reading-max); margin: var(--sp-5) auto 0; }
.prose h2 { font-size: var(--fs-md); font-weight: 500; margin: var(--sp-5) 0 var(--sp-2); color: var(--accent); }
.prose p { color: var(--fg-100); margin-bottom: var(--sp-3); }
.legal { max-width: var(--reading-max); margin: 0 auto; }
.crumbs { font-size: var(--fs-xs); color: var(--fg-300); margin-bottom: var(--sp-4); text-align: center; }
.legal__head { text-align: center; }
.legal__head h1 { font-size: var(--fs-xl); font-weight: 500; margin: var(--sp-3) 0; }
.legal__lead { color: var(--fg-100); }
.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); font-weight: 500; margin-bottom: var(--sp-2); color: var(--accent); }
.legal__section p { color: var(--fg-100); }
.legal__rg { margin: var(--sp-6) auto 0; max-width: var(--reading-max); background: var(--sage-soft); border: 1px solid var(--gold-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-display); font-size: clamp(4rem,12vw,8rem); color: var(--accent); display: block; }
.errpage h1 { font-size: var(--fs-lg); font-weight: 500; margin: var(--sp-3) 0; }
.errpage .hero__actions { justify-content: center; }

@media (max-width: 820px) {
    .virtues { grid-template-columns: 1fr; }
    .auth, .contact-grid { grid-template-columns: 1fr; }
    .swiper__arrow { display: none; }
}

/* ===== Imagery slots (drop MJ exports into assets/img/) ===== */
.hero { position: relative; border-radius: var(--r-lg); padding: var(--sp-8) var(--sp-6);
    background-image: linear-gradient(180deg, rgba(13,20,16,.86) 0%, rgba(13,20,16,.74) 60%, rgba(13,20,16,.92) 100%), url('/assets/img/hero.jpg');
    background-size: cover; background-position: center; }
.swiper--fade [data-swiper-slide] .meeting { background-size: cover; background-position: center; }
.swiper--fade [data-swiper-slide]:nth-child(1) .meeting { background-image: linear-gradient(180deg, rgba(13,20,16,.82), rgba(13,20,16,.94)), url('/assets/img/banner-1.jpg'); }
.swiper--fade [data-swiper-slide]:nth-child(2) .meeting { background-image: linear-gradient(180deg, rgba(13,20,16,.82), rgba(13,20,16,.94)), url('/assets/img/banner-2.jpg'); }
.swiper--fade [data-swiper-slide]:nth-child(3) .meeting { background-image: linear-gradient(180deg, rgba(13,20,16,.82), rgba(13,20,16,.94)), url('/assets/img/banner-3.jpg'); }
.prestige-banner { background-image: linear-gradient(180deg, rgba(13,20,16,.80), rgba(13,20,16,.93)), url('/assets/img/feature.jpg'); background-size: cover; background-position: center; }

/* ===== 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; }

/* ===== Boxed sections: category grid, fact bar, boxed virtues ===== */
.catgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px,1fr)); gap: var(--sp-4); max-width: var(--content-max); margin: 0 auto; }
.catbox { display: flex; flex-direction: column; gap: 4px; padding: var(--sp-5); background: var(--bg-100); border: 1px solid var(--bg-300); border-radius: var(--r-lg); transition: var(--t-fast); }
.catbox:hover { border-color: var(--gold-line); transform: translateY(-2px); text-decoration: none; box-shadow: var(--sh-2); }
.catbox__ico { font-size: 1.6rem; }
.catbox__name { font-family: var(--font-display); font-size: var(--fs-md); color: var(--fg-000); }
.catbox__meta { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--accent); }
.factbar { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--bg-300); border: 1px solid var(--bg-300); border-radius: var(--r-lg); overflow: hidden; max-width: var(--content-max); margin: 0 auto; }
.factbar div { background: var(--bg-100); padding: var(--sp-5); text-align: center; }
.factbar b { display: block; font-family: var(--font-display); font-size: var(--fs-lg); color: var(--accent); }
.factbar span { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-300); text-transform: uppercase; letter-spacing: .08em; }
.virtues { grid-template-columns: repeat(3, 1fr); }
.virtues article { background: var(--bg-100); border: 1px solid var(--bg-300); border-radius: var(--r-lg); padding: var(--sp-5); text-align: left; }
@media (max-width: 700px){ .factbar { grid-template-columns: 1fr 1fr; } }

/* ===== Betting board: compact hero, coupon, sport tabs ===== */
.hero--compact { padding: var(--sp-6) var(--sp-5) var(--sp-4); }
.hero--compact .hero__title { font-size: var(--fs-lg); margin: var(--sp-2) 0 var(--sp-3); }
.hero--compact .hero__sub { font-size: var(--fs-base); }
.coupon { max-width: var(--content-max); margin: 0 auto; background: var(--bg-100); border: 1px solid var(--gold-line); border-radius: var(--r-lg); padding: var(--sp-6); box-shadow: 0 0 0 1px var(--gold-soft), var(--sh-2); }
.coupon__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: var(--sp-4); }
.coupon__tag { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
.coupon__meta { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-300); }
.coupon__teams { display: flex; align-items: center; justify-content: center; gap: var(--sp-4); font-family: var(--font-display); font-size: var(--fs-lg); color: var(--fg-000); text-align: center; margin-bottom: var(--sp-5); }
.coupon__vs { color: var(--accent); font-style: italic; font-size: var(--fs-md); }
.coupon__odds { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3); }
.coupon__odds .odds-chip { padding: 14px; }
.coupon__odds .odds-chip__price { font-size: var(--fs-md); }
.coupon__note { text-align: center; font-size: var(--fs-xs); color: var(--fg-300); margin-top: var(--sp-3); }
.sporttabs { display: flex; flex-wrap: wrap; gap: var(--sp-1); max-width: var(--content-max); margin: var(--sp-7) auto 0; border-bottom: 1px solid var(--bg-300); padding-bottom: var(--sp-2); }
.sporttab { font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm); color: var(--fg-100); padding: 9px 16px; border-radius: var(--r-sm) var(--r-sm) 0 0; }
.sporttab:hover { background: var(--bg-150); color: var(--accent); text-decoration: none; }
.market { max-width: var(--content-max); margin: 0 auto var(--sp-4); }
.market__caption { display: flex; justify-content: space-between; align-items: center; }
.market__cols { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-500); font-style: normal; }
.section__head { max-width: var(--content-max); margin-left: auto; margin-right: auto; }
@media (max-width: 560px){ .coupon__odds { grid-template-columns: 1fr 1fr 1fr; } .coupon__teams { font-size: var(--fs-md); } }

/* ===== Premium highlights trio ===== */
.highlights { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--sp-4); max-width: var(--content-max); margin: 0 auto; }
.hl { background: var(--bg-100); border: 1px solid var(--bg-300); border-top: 2px solid var(--accent); border-radius: var(--r-lg); padding: var(--sp-5); }
.hl__tag { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: .14em; text-transform: uppercase; color: var(--accent); }
.hl h3 { font-size: var(--fs-md); font-weight: 500; margin: var(--sp-2) 0; }
.hl p { color: var(--fg-100); font-size: var(--fs-sm); }
@media (max-width: 760px){ .highlights { grid-template-columns: 1fr; } }
