
/* ── Majors 24 hub · Grandstand ── */

:where(.v-majors24) main { flex:1; padding-bottom:56px; }

/* ── Shared tooltip (ink panel, matches driver award chips) ──
   Applies to: hero weather, split weather, disabled season, feature chips. */
:where(.v-majors24) .hero-wx::after,
:where(.v-majors24) .spc-wx::after,
:where(.v-majors24) .feat::after,
:where(.v-majors24) .season-seg.disabled::after {
  content:attr(data-tip); position:absolute; left:50%; bottom:calc(100% + 9px); transform:translateX(-50%);
  width:max-content; max-width:230px; background:var(--ink); color:var(--paper);
  font-family:var(--font-body); font-size:11.5px; font-weight:500; line-height:1.45;
  letter-spacing:0; text-transform:none; text-align:center; white-space:normal;
  padding:7px 10px; border-radius:4px; box-shadow:0 4px 14px rgba(27,24,18,.22);
  opacity:0; pointer-events:none; transition:opacity .12s; z-index:40;
}
:where(.v-majors24) .hero-wx::before,
:where(.v-majors24) .spc-wx::before,
:where(.v-majors24) .feat::before,
:where(.v-majors24) .season-seg.disabled::before {
  content:''; position:absolute; left:50%; bottom:calc(100% + 4px); transform:translateX(-50%);
  border:5px solid transparent; border-top-color:var(--ink);
  opacity:0; pointer-events:none; transition:opacity .12s; z-index:40;
}
:where(.v-majors24) .hero-wx:hover::after,
:where(.v-majors24) .spc-wx:hover::after,
:where(.v-majors24) .feat:hover::after,
:where(.v-majors24) .season-seg.disabled:hover::after,
:where(.v-majors24) .hero-wx:hover::before,
:where(.v-majors24) .spc-wx:hover::before,
:where(.v-majors24) .feat:hover::before,
:where(.v-majors24) .season-seg.disabled:hover::before { opacity:1; }

/* ── Hero — centered display masthead (AMajors) ── */
:where(.v-majors24) .hero { padding:46px 0 6px; text-align:center; }
:where(.v-majors24) .hero-logo { height:54px; width:auto; display:block; margin:0 auto; }
:where(.v-majors24) .hero-h1 {
  font-family:var(--font-display); font-weight:800; letter-spacing:-0.015em; line-height:1.06;
  font-size:clamp(36px, 6.5vw, 56px); color:var(--ink); margin:14px 0 0;
}
:where(.v-majors24) .hero-year { color:var(--series); }
:where(.v-majors24) .hero-wx { display:none; margin-left:14px; font-size:.42em; vertical-align:middle; position:relative; cursor:help; }
:where(.v-majors24) .hero p { font-size:15px; color:var(--sub); line-height:1.6; max-width:560px; margin:14px auto 0; }

/* Year selector — underline tabs on a hairline */
:where(.v-majors24) .season-switch { display:inline-flex; gap:4px; margin-top:26px; padding:0; background:none; border:none; border-bottom:1px solid var(--line); border-radius:0; }
:where(.v-majors24) .season-seg {
  padding:8px 16px; border:none; border-bottom:2px solid transparent; background:none; border-radius:0;
  font-family:var(--font-body); font-size:14px; font-weight:600; color:var(--faint);
  cursor:pointer; transition:color .12s; font-variant-numeric:tabular-nums;
}
:where(.v-majors24) .season-seg:hover:not(.active):not(.disabled) { color:var(--ink); }
:where(.v-majors24) .season-seg.active { color:var(--ink); font-weight:800; border-bottom-color:var(--series); }
:where(.v-majors24) .season-seg.disabled { color:var(--faint); opacity:.55; cursor:not-allowed; position:relative; }

/* ── Section heads — overline + trailing hairline ── */
:where(.v-majors24) .srx { padding:36px 0 0; }
:where(.v-majors24) .srx-label {
  display:flex; align-items:center; gap:16px; flex-wrap:wrap; row-gap:10px; margin-bottom:16px;
  font-family:var(--font-body); font-size:11px; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--faint);
}
:where(.v-majors24) .srx-label::after { content:''; flex:1 1 40px; height:1px; background:var(--line); order:2; }
:where(.v-majors24) .srx-label .hint { order:3; font-weight:500; letter-spacing:0; text-transform:none; font-size:12px; color:var(--faint); font-variant-numeric:tabular-nums; }
:where(.v-majors24) .srx-label .class-tabs { order:4; }

/* ── Class filter buttons (Results filter-button spec) ── */
:where(.v-majors24) .class-tabs { display:flex; gap:6px; flex-wrap:wrap; }
:where(.v-majors24) .class-tab {
  padding:6px 14px; border-radius:4px; border:1px solid var(--line); background:none;
  font-family:var(--font-body); font-size:12.5px; font-weight:700; letter-spacing:.02em; text-transform:none;
  color:var(--sub); cursor:pointer; transition:border-color .12s, color .12s, background .12s; user-select:none;
}
:where(.v-majors24) .class-tab:hover { border-color:var(--faint); color:var(--ink); }
:where(.v-majors24) .class-tab.active-neutral,
:where(.v-majors24) .class-tab.active-cls0,
:where(.v-majors24) .class-tab.active-cls1,
:where(.v-majors24) .class-tab.active-cls2 {
  background:var(--ink); border-color:var(--ink); color:var(--paper);
}
:where(.v-majors24) .class-tab.off { opacity:.5; }
:where(.v-majors24) .class-tab.disabled { opacity:.45; cursor:not-allowed; }
:where(.v-majors24) .class-tab .soon { font-size:11px; font-weight:500; opacity:.8; margin-left:5px; }

/* ── Class labels — colored text, data not decoration ──
   (.cls-pill is styled globally in grandstand.css; .class-pill aligned here) */
:where(.v-majors24) .class-pill {
  font-family:var(--font-body); font-size:10.5px; font-weight:800; letter-spacing:.1em;
  text-transform:uppercase; padding:0; border-radius:0; background:none;
  display:inline-block; line-height:1.3;
}
:where(.v-majors24) .pill-cls0 { color:var(--gtp); }
:where(.v-majors24) .pill-cls1 { color:var(--lmp2); }
:where(.v-majors24) .pill-cls2 { color:var(--gt3); }
:where(.v-majors24) .car-badge { font-family:var(--font-body); font-size:12px; font-weight:700; padding:1px 6px; border-radius:3px; border:1px solid; font-variant-numeric:tabular-nums; }

/* ── Event at a glance — hairline stat columns, no boxes ──
   Section-head hairline is the top rule (no per-cell top border = no double line);
   columns separated by soft hairlines, second row gets a soft top rule.
   Label ABOVE value per the established stat-strip convention (driver career strip). */
:where(.v-majors24) .totals { display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
:where(.v-majors24) .stat { position:relative; display:flex; flex-direction:column; align-items:flex-start; background:none; border:none; border-left:1px solid var(--line-soft); border-radius:0; box-shadow:none; padding:6px 18px 16px; }
:where(.v-majors24) .stat:first-child { border-left:none; padding-left:0; }
:where(.v-majors24) .stat:nth-child(n+5) { border-top:1px solid var(--line-soft); padding-top:14px; }
:where(.v-majors24) .stat:nth-child(4n+1) { border-left:none; padding-left:0; }
:where(.v-majors24) .stat .ticon { display:none; }
:where(.v-majors24) .stat .lbl { order:1; margin:0 0 6px; font-size:10.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--sub); line-height:1.2; }
:where(.v-majors24) .stat .val { order:2; font-family:var(--font-display); font-weight:800; font-size:26px; letter-spacing:-.01em; line-height:1.05; color:var(--ink); font-variant-numeric:tabular-nums; }
:where(.v-majors24) .stat .sub { order:3; margin-top:6px; font-size:11.5px; color:var(--faint); line-height:1.35; font-variant-numeric:tabular-nums; }
:where(.v-majors24) .stat .sub b { color:var(--sub); font-weight:700; }
:where(.v-majors24) .stat.accent .val { color:var(--series); }

/* ── Feature chips (what's behind every split) ── */
:where(.v-majors24) .feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:16px; }
:where(.v-majors24) .feat {
  position:relative; cursor:help; display:flex; align-items:center; gap:8px;
  font-family:var(--font-body); font-size:12.5px; font-weight:600; color:var(--sub);
  background:var(--surface); border:1px solid var(--line); border-radius:4px; padding:10px 13px;
}
:where(.v-majors24) .feat-ic { font-size:14px; line-height:1; flex-shrink:0; }

/* ── The splits — ruled rows (AMajors) ── */
:where(.v-majors24) .splits-grid { display:block; border-top:1px solid var(--line); }
:where(.v-majors24) .split-card {
  display:grid; grid-template-columns:128px 1fr 150px; gap:6px 18px; align-items:center;
  padding:13px 14px; border:none; border-bottom:1px solid var(--line-soft); border-radius:0;
  background:none; box-shadow:none; text-decoration:none; color:inherit; transition:background .12s;
}
:where(.v-majors24) .split-card:hover { background:var(--surface); }
:where(.v-majors24) .spc-head { display:flex; flex-direction:column; align-items:flex-start; gap:3px; }
:where(.v-majors24) .spc-no { font-family:var(--font-display); font-weight:800; font-size:16px; color:var(--ink); transition:none; }
:where(.v-majors24) .spc-wx { margin-left:8px; font-size:.8em; vertical-align:1px; position:relative; cursor:help; font-family:var(--font-body); font-weight:400; }
:where(.v-majors24) .spc-sof { font-size:11.5px; color:var(--faint); font-variant-numeric:tabular-nums; }
:where(.v-majors24) .spc-sof b { color:var(--sub); font-weight:700; }
:where(.v-majors24) .spc-wins { display:grid; grid-template-columns:repeat(3,1fr); gap:4px 18px; min-width:0; }
:where(.v-majors24) .winner-row { display:flex; align-items:baseline; gap:8px; min-width:0; }
:where(.v-majors24) .winner-row .cls-pill { flex-shrink:0; min-width:34px; }
:where(.v-majors24) .winner-car { font-size:12px; font-weight:700; color:var(--faint); flex-shrink:0; font-variant-numeric:tabular-nums; }
:where(.v-majors24) .winner-team { font-size:13px; font-weight:600; color:var(--sub); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
:where(.v-majors24) .spc-foot { display:flex; flex-direction:column; align-items:flex-end; gap:3px; border:none; padding:0; margin:0; }
:where(.v-majors24) .spc-laps { font-size:12.5px; color:var(--faint); font-variant-numeric:tabular-nums; }
:where(.v-majors24) .spc-laps b { color:var(--ink); font-weight:700; }
:where(.v-majors24) .spc-cta { font-size:11.5px; font-weight:700; color:var(--faint); white-space:nowrap; transform:translateX(-4px); transition:color .12s, transform .12s; }
:where(.v-majors24) .split-card:hover .spc-cta { color:var(--red); transform:translateX(0); }

/* ── Awards & stories — bordered surface tiles ── */
:where(.v-majors24) .grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
:where(.v-majors24) #awgrid { align-items:start; }
:where(.v-majors24) .aw-card { position:relative; display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--line); border-radius:4px; box-shadow:none; overflow:hidden; text-decoration:none; color:inherit; }
:where(.v-majors24) .aw-head { padding:13px 16px 11px; display:flex; align-items:center; justify-content:space-between; gap:10px; }
:where(.v-majors24) .aw-emoji { font-size:16px; line-height:1; flex-shrink:0; }
:where(.v-majors24) .aw-title { font-family:var(--font-display); font-weight:800; font-size:15.5px; color:var(--ink); line-height:1.25; }
:where(.v-majors24) .aw-scope { margin-left:10px; font-family:var(--font-body); font-size:10.5px; font-weight:600; letter-spacing:.05em; color:var(--faint); white-space:nowrap; vertical-align:1px; }
:where(.v-majors24) .aw-beta { position:absolute; top:12px; right:12px; font-size:9px; font-weight:700; color:var(--faint); border:1px solid var(--line); border-radius:3px; padding:1px 5px; }
:where(.v-majors24) .aw-row { display:grid; grid-template-columns:34px 1fr auto; gap:10px; align-items:baseline; padding:8px 16px; border-top:1px solid var(--line-soft); }
:where(.v-majors24) .aw-rank { font-family:var(--font-display); font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--faint); font-variant-numeric:tabular-nums; }
:where(.v-majors24) .aw-who { display:flex; align-items:baseline; gap:8px; min-width:0; }
:where(.v-majors24) .aw-who .class-pill { min-width:40px; flex-shrink:0; }
:where(.v-majors24) .aw-name { font-size:13.5px; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
:where(.v-majors24) .aw-val { font-size:13px; font-weight:700; color:var(--sub); font-variant-numeric:tabular-nums; }
:where(.v-majors24) .aw-row.first .aw-name { font-weight:700; }
:where(.v-majors24) .aw-row.cls0.first { background:color-mix(in srgb, var(--gtp) 8%, transparent); }  :where(.v-majors24) .aw-row.cls0.first .aw-rank { color:var(--gtp); }
:where(.v-majors24) .aw-row.cls1.first { background:color-mix(in srgb, var(--lmp2) 8%, transparent); } :where(.v-majors24) .aw-row.cls1.first .aw-rank { color:var(--lmp2); }
:where(.v-majors24) .aw-row.cls2.first { background:color-mix(in srgb, var(--gt3) 8%, transparent); }  :where(.v-majors24) .aw-row.cls2.first .aw-rank { color:var(--gt3); }
:where(.v-majors24) .aw-row.muted .aw-name { color:var(--faint); font-style:normal; }
:where(.v-majors24) a.aw-row { text-decoration:none; color:inherit; transition:background .12s; }
:where(.v-majors24) a.aw-row:hover { background:var(--paper); }
:where(.v-majors24) .aw-card .aw-extra { display:grid; max-height:0; opacity:0; overflow:hidden; padding-top:0; padding-bottom:0; border-top-width:0; transition:max-height .28s ease, opacity .18s ease, padding .28s ease, border-width .28s ease, background .12s ease; }
:where(.v-majors24) .aw-card.expanded .aw-extra { max-height:46px; opacity:1; padding-top:8px; padding-bottom:8px; border-top-width:1px; }
:where(.v-majors24) .aw-expand { display:block; width:100%; text-align:left; padding:10px 16px; margin-top:auto; font-family:var(--font-body); font-size:11.5px; font-weight:700; color:var(--faint); background:none; border:none; border-top:1px solid var(--line-soft); cursor:pointer; transition:color .12s; }
:where(.v-majors24) .aw-expand:hover { color:var(--ink); }
:where(.v-majors24) .golink { padding:10px 16px; font-size:11.5px; color:var(--faint); margin-top:auto; border-top:1px solid var(--line-soft); }

/* ── Scatter panel ── */
:where(.v-majors24) .card { background:var(--surface); border:1px solid var(--line); border-radius:4px; box-shadow:none; overflow:hidden; }
:where(.v-majors24) .card.chart-panel { overflow:visible; }
:where(.v-majors24) .card-head { padding:13px 16px; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
:where(.v-majors24) .card-title { font-family:var(--font-display); font-weight:800; font-size:15px; color:var(--ink); }
:where(.v-majors24) .chart-area { padding:14px 16px 10px; }
:where(.v-majors24) .chart-wrap { position:relative; width:100%; height:400px; }
:where(.v-majors24) #scatter { width:100%; height:100%; display:block; }
:where(.v-majors24) .sc-tip { position:absolute; pointer-events:none; opacity:0; transform:translate(-50%,-115%); background:var(--ink); color:var(--paper); font-family:var(--font-body); font-size:11.5px; padding:6px 9px; border-radius:4px; white-space:nowrap; box-shadow:0 4px 14px rgba(27,24,18,.22); transition:opacity .08s; z-index:5; font-variant-numeric:tabular-nums; }
:where(.v-majors24) .sc-tip .tname { color:var(--surface); font-weight:700; }
:where(.v-majors24) .chart-foot { font-size:11.5px; color:var(--faint); padding:0 16px 13px; }

/* ── Responsive ladder: 360 floor · <720 compact · ≥1024 full ── */
@media (max-width:1023.9px) {
  :where(.v-majors24) .spc-wins { grid-template-columns:1fr; gap:3px; }
}
@media (max-width:919.9px) {
  :where(.v-majors24) .grid { grid-template-columns:1fr; }
}
@media (max-width:719.9px) {
  :where(.v-majors24) .hero { padding-top:32px; }
  :where(.v-majors24) .hero-logo { height:40px; margin-top:14px; }
  :where(.v-majors24) .season-switch { flex-wrap:wrap; justify-content:center; max-width:100%; }
  :where(.v-majors24) .season-seg { padding:6px 10px; font-size:12.5px; }
  :where(.v-majors24) .srx { padding-top:30px; }
  :where(.v-majors24) .totals { grid-template-columns:repeat(2,1fr); }
  :where(.v-majors24) .stat { padding:6px 14px 13px; }
  :where(.v-majors24) .stat:nth-child(4n+1) { border-left:1px solid var(--line-soft); padding-left:14px; }
  :where(.v-majors24) .stat:nth-child(2n+1) { border-left:none; padding-left:0; }
  :where(.v-majors24) .stat:nth-child(n+3) { border-top:1px solid var(--line-soft); padding-top:12px; }
  :where(.v-majors24) .stat .val { font-size:21px; }
  :where(.v-majors24) .feat-grid { grid-template-columns:repeat(2,1fr); }
  :where(.v-majors24) .split-card { grid-template-columns:1fr; gap:7px; padding:12px 10px; }
  :where(.v-majors24) .spc-head { flex-direction:row; justify-content:space-between; align-items:baseline; width:100%; }
  :where(.v-majors24) .spc-foot { flex-direction:row; justify-content:space-between; align-items:baseline; width:100%; }
  :where(.v-majors24) .spc-cta { transform:none; }
  :where(.v-majors24) .aw-head,
:where(.v-majors24) .aw-row,
:where(.v-majors24) .aw-expand,
:where(.v-majors24) .golink { padding-left:12px; padding-right:12px; }
}
