/*
Theme Name: Jacksonville Speedway
Theme URI: https://jacksonvillespeedway.com
Author: Jacksonville Speedway
Author URI: https://jacksonvillespeedway.com
Description: Block theme for Jacksonville Speedway. Brand-accurate, mobile-first, code-driven. Built against brand-book/brand.json.
Version: 0.1.0
Requires at least: 6.5
Requires PHP: 8.0
Tested up to: 6.9
License: Proprietary
Text Domain: speedway
Tags: block-theme, full-site-editing, motorsport
*/

/* =========================================================
   Speedway brand tokens are defined in theme.json.
   This stylesheet holds motifs and rules that can't be
   expressed in theme.json: the signature track stripe,
   small global resets, and targeted WooCommerce overrides.
   ========================================================= */

/* Track stripe — signature brand motif.
   Fixed to the right edge, full viewport height.
   Proportions scale down on narrow screens. */
body::after {
  content: "";
  position: fixed;
  top: 0;
  right: 12px;
  width: 20px;
  height: 100vh;
  background: linear-gradient(
    to right,
    #FF0000 0, #FF0000 10px,
    #000000 10px, #000000 14px,
    #8A8A8A 14px, #8A8A8A 20px
  );
  z-index: 9999;
  pointer-events: none;
}

@media (max-width: 640px) {
  body::after {
    right: 8px;
    width: 12px;
    background: linear-gradient(
      to right,
      #FF0000 0, #FF0000 6px,
      #000000 6px, #000000 8px,
      #8A8A8A 8px, #8A8A8A 12px
    );
  }
}

/* Keep content clear of the stripe */
.wp-site-blocks {
  padding-right: 32px;
}
@media (max-width: 640px) {
  .wp-site-blocks {
    padding-right: 20px;
  }
}

/* Display headings are uppercase per brand voice */
h1, h2, h3, h4, h5, h6,
.wp-block-heading {
  text-transform: uppercase;
  letter-spacing: 0.01em;
  line-height: 1.02;
}

/* Buttons: square corners, condensed display font, uppercase */
.wp-block-button__link {
  border-radius: 0 !important;
  font-family: "Saira Condensed", Arial Narrow, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Hide WooCommerce cart + account icons from the global site header */
header .wc-block-mini-cart,
header .woocommerce-mini-cart,
header .wp-block-woocommerce-mini-cart,
header [class*="mini-cart"],
header .wc-block-customer-account,
header .wp-block-woocommerce-customer-account,
header [class*="customer-account"] {
  display: none !important;
}

/* Hide WP login / account nav item (visible when logged in) */
header .wp-block-navigation .wp-login-logout,
header .wp-block-navigation [class*="login"],
header .wp-block-navigation [class*="account"],
header .wp-block-navigation li.wp-block-woocommerce-customer-account,
header .wp-block-navigation li:has(svg[class*="account"]),
header .wp-block-navigation li:has(svg[class*="person"]) {
  display: none !important;
}

/* ── Desktop header only ────────────────────────── */
@media (min-width: 641px) {
  /* Nav sizing — controlled here rather than in block attrs */
  header .wp-block-navigation .wp-block-navigation-item__content {
    font-size: clamp(0.95rem, 0.5vw + 0.75rem, 1.2rem) !important;
    padding-left: 0.85rem !important;
    padding-right: 0.85rem !important;
    white-space: nowrap;
  }
  header .wp-block-navigation__container {
    flex-wrap: nowrap !important;
  }

  /* Shift logo + tagline up ~10% of header height (476px × 10% ≈ 48px)
     into the darker sky area above the cars */
  header .wp-block-cover .wp-block-cover__inner-container > .wp-block-group {
    transform: translateY(-48px);
  }
}


/* ── Mobile header ───────────────────────────────── */
@media (max-width: 640px) {
  /* Shrink the cover block so the image scales by width, showing more cars.
     At ~160px the 1920px-wide image renders ~850px wide on a 390px screen
     — roughly half the lineup visible instead of one car. */
  header .wp-block-cover {
    min-height: 160px !important;
  }

  /* Reduce logo size so it fits the shorter header */
  header .wp-block-cover .wp-block-image img {
    width: 200px !important;
    max-width: 60vw !important;
  }
}

/* ── Row card pattern — sitewide primitive (added 2026-04-21) ───────────────
   Apply class="speedway-row" to any list row, team member block, result row,
   or any repeating item that benefits from the charcoal card + red-reveal treatment.
   Use .speedway-row--center for vertically centered rows (event lists).
   The 3px left border slot is always reserved — transparent until hover. */

.speedway-row {
  background: #1C1C1C;
  border-left: 3px solid transparent;
  padding: 0.85rem 1rem;
  margin-bottom: 2px;
  transition: border-left-color 180ms ease;
}
.speedway-row:hover {
  border-left-color: #FF0000;
}
.speedway-row--center {
  display: flex;
  align-items: center;
  gap: 1rem;
}

/* WooCommerce quick wins — detailed overrides come later */
.woocommerce button.button,
.woocommerce a.button,
.woocommerce-page button.button,
.woocommerce-page a.button {
  border-radius: 0;
  background: #FF0000;
  color: #FFFFFF;
  font-family: "Saira Condensed", Arial Narrow, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Single product Add to Cart — restore full size */
.woocommerce .single_add_to_cart_button,
.woocommerce-page .single_add_to_cart_button {
  background: #FF0000 !important;
  color: #FFFFFF !important;
  font-family: "Saira Condensed", Arial Narrow, sans-serif !important;
  font-size: 1.1rem !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  padding: 0.75rem 2rem !important;
  border-radius: 0 !important;
  border: none !important;
}

/* WooCommerce form elements — white background so they read on the dark theme.
   The body is #000 so selects/inputs are invisible without this. */
.woocommerce select,
.woocommerce-page select {
  background-color: #ffffff !important;
  color: #000000 !important;
  border: 1px solid #999999 !important;
  border-radius: 0 !important;
}
.woocommerce select option,
.woocommerce-page select option {
  background-color: #ffffff;
  color: #000000;
}

.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce input[type="password"],
.woocommerce textarea,
.woocommerce-page input[type="text"],
.woocommerce-page input[type="email"],
.woocommerce-page input[type="tel"],
.woocommerce-page input[type="password"],
.woocommerce-page textarea {
  background-color: #ffffff !important;
  color: #000000 !important;
  border: 1px solid #999999 !important;
  border-radius: 0 !important;
}

/* ── Compact nav bar (added 2026-04-21) ─────────────────────────────────────
   Claude Design-inspired: logo left, nav center, Buy Tickets right.
   Sits between the info bar and the photo cover header.
   REVERT: Remove this whole section + the speedway-red-nav-hidden rule below,
           then remove className "speedway-red-nav-hidden" from header.html. */

/* Nav links group — left-aligned, flows after the logo */
.speedway-compact-nav__links {
  display: flex !important;
}

/* Nav link base style: track-gray inactive, no underline */
.speedway-compact-nav .wp-block-navigation-item__content {
  color: #8A8A8A !important;
  text-decoration: none !important;
  padding-bottom: 5px !important;
  border-bottom: 2px solid transparent !important;
  transition: color 120ms ease, border-color 120ms ease;
  font-size: 0.88rem !important;
  padding-left: 0.75rem !important;
  padding-right: 0.75rem !important;
  white-space: nowrap;
}

/* Hover: white text */
.speedway-compact-nav .wp-block-navigation-item a:hover .wp-block-navigation-item__content,
.speedway-compact-nav .wp-block-navigation-item a:hover {
  color: #FFFFFF !important;
}

/* Active page: white text + 2px red bottom border.
   WP block nav uses aria-current="page" on the anchor; classic menus use current-menu-item on the li.
   Front page specifically gets menu-item-home class from WP. */
.speedway-compact-nav .wp-block-navigation-item__content[aria-current="page"],
.speedway-compact-nav .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content,
.speedway-compact-nav .wp-block-navigation-item.current-menu-item > a,
.speedway-compact-nav .wp-block-navigation-item.current_page_item .wp-block-navigation-item__content,
.speedway-compact-nav .wp-block-navigation-item.menu-item-home .wp-block-navigation-item__content {
  color: #FFFFFF !important;
  border-bottom-color: #FF0000 !important;
}

/* Mobile: compact nav collapses to logo + MENU toggle */
@media (max-width: 640px) {
  /* Inner flex row: logo left, MENU button pushed to right */
  .speedway-compact-nav .wp-block-group > .wp-block-group {
    justify-content: space-between !important;
  }
  .speedway-compact-nav__links {
    flex: 1 !important;
    justify-content: flex-end !important;
  }

  /* Smaller logo on mobile */
  .speedway-compact-nav .wp-block-image img {
    width: 140px !important;
  }

  /* Replace hamburger SVG with "MENU ▼" text */
  .speedway-compact-nav .wp-block-navigation__responsive-container-open svg {
    display: none !important;
  }
  .speedway-compact-nav .wp-block-navigation__responsive-container-open::after {
    content: "MENU \25BC";
    font-family: "Saira Condensed", Arial Narrow, sans-serif;
    font-weight: 800;
    font-size: 1rem;
    letter-spacing: 0.1em;
    color: #ffffff;
  }
  .speedway-compact-nav .wp-block-navigation__responsive-container-open {
    background: transparent !important;
    border: none !important;
    padding: 0.25rem 0.5rem !important;
    display: flex !important;
    align-items: center !important;
    cursor: pointer;
  }
}

/* ── Full Season Schedule (speedway/schedule-list block) ─────────────────────
   Used on the /2026-season-schedule/ page via templates/page-schedule.html.
   4-column grid: date | event info | times | status badge.
   Extends .speedway-row for the charcoal card + red-border-reveal treatment.
   Mobile: collapses to 2-col (date + info), times/status hidden. */

/* Postponement notice banner */
.speedway-schedule-notice {
  background: #1C1C1C;
  border: 2px solid #FF0000;
  padding: 1rem 1.25rem;
  margin-bottom: 1.5rem;
  display: flex;
  gap: 0.875rem;
  align-items: flex-start;
}
.speedway-schedule-notice__badge {
  flex-shrink: 0;
  background: #FF0000;
  color: #FFF;
  font-family: "Saira Condensed", "Arial Narrow", sans-serif;
  font-weight: 800;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 0.2rem 0.55rem;
  margin-top: 0.1rem;
}
.speedway-schedule-notice__text {
  margin: 0;
  color: #CCCCCC;
  font-size: 0.9rem;
  line-height: 1.55;
}
.speedway-schedule-notice__text a { color: #FF0000; }

/* Section count label */
.speedway-schedule-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #8A8A8A;
  border-bottom: 1px solid #2a2a2a;
  padding-bottom: 8px;
  margin-bottom: 4px;
}

/* Schedule row — 4-col grid layered on top of .speedway-row */
.speedway-schedule-list {
  display: flex;
  flex-direction: column;
}
.speedway-schedule-row {
  display: grid;
  grid-template-columns: 90px 1fr 160px 110px;
  gap: 0 1.5rem;
  align-items: center;
  text-decoration: none;
  color: inherit;
}
.speedway-schedule-row--postponed { opacity: 0.6; }

/* Date column */
.speedway-schedule-date { padding-top: 2px; }
.ssd-month {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #8A8A8A;
}
.ssd-day {
  font-family: "Saira Condensed", "Arial Narrow", sans-serif;
  font-size: 30px;
  font-weight: 900;
  line-height: 0.95;
  color: #FFF;
}
.ssd-weekday {
  font-size: 11px;
  color: #4A4A4A;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 2px;
}

/* Event info column */
.speedway-schedule-name {
  font-family: "Saira Condensed", "Arial Narrow", sans-serif;
  font-size: 19px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.1;
  color: #FFF;
}
.speedway-schedule-name.sn-special   { color: #FF0000; }
.speedway-schedule-name.sn-postponed { color: #4A4A4A; text-decoration: line-through; }
.speedway-schedule-classes {
  margin-top: 3px;
  font-size: 13px;
  color: #CCCCCC;
}

/* Times column */
.speedway-schedule-times {
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #8A8A8A;
  line-height: 1.7;
}

/* Status column */
.speedway-schedule-status { text-align: right; }
.speedway-status--postponed,
.speedway-status--special,
.speedway-status--tickets {
  font-family: "Saira Condensed", "Arial Narrow", sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.speedway-status--postponed { color: #FF0000; }
.speedway-status--special   { color: #8A8A8A; }
.speedway-status--tickets   { color: #FF0000; text-decoration: none; }
.speedway-status--tickets:hover { text-decoration: underline; }

/* Mobile: 2-col (date + info), times and status hidden */
@media (max-width: 640px) {
  .speedway-schedule-row {
    grid-template-columns: 72px 1fr;
  }
  .speedway-schedule-times,
  .speedway-schedule-status { display: none; }
  .ssd-day                   { font-size: 24px; }
  .speedway-schedule-name    { font-size: 16px; }
}

