/* Throwing 2 Honor Website V2 - Responsive / Mobile Optimization Pass 1 */

* { box-sizing: border-box; }

html, body {
  max-width: 100%;
  overflow-x: hidden;
}

img, video, iframe {
  max-width: 100%;
}

img {
  height: auto;
}

iframe {
  border: 0;
}

.container,
.content,
.section-inner,
.wrap,
.page-wrap,
.hero-inner,
.nav-inner,
.footer-inner,
.stats-grid,
.cards-grid,
.card-grid,
.gear-grid,
.product-grid,
.partner-grid,
.impact-grid,
.event-grid,
.timeline-grid,
.flyer-grid,
.logo-grid {
  max-width: 100%;
}

nav,
.nav,
.main-nav,
.site-nav {
  flex-wrap: wrap;
}

nav a,
.nav a,
.main-nav a,
.site-nav a {
  white-space: nowrap;
}

.hero,
section,
.card,
.event-card,
.gear-card,
.product-card,
.impact-card,
.donation-card,
.partner-card,
.timeline-card {
  overflow-wrap: anywhere;
}

.button-row,
.cta-row,
.actions,
.hero-actions,
.card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
}

.button-row a,
.cta-row a,
.actions a,
.hero-actions a,
.card-actions a,
.button-row button,
.cta-row button,
.actions button,
.hero-actions button,
.card-actions button {
  min-height: 44px;
}

.launch-flyer-image,
.flyer-image,
.poster-image,
.coming-soon-image,
.scholarship-flyer,
.gear-image,
.product-image,
.product-media,
.gear-media {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.launch-flyer-image img,
.flyer-image img,
.poster-image img,
.coming-soon-image img,
.scholarship-flyer img,
.gear-image img,
.product-image img,
.product-media img,
.gear-media img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.video-wrapper,
.youtube-wrapper,
.embed-wrapper {
  position: relative;
  width: 100%;
  max-width: 100%;
  aspect-ratio: 16 / 9;
}

.video-wrapper iframe,
.youtube-wrapper iframe,
.embed-wrapper iframe {
  width: 100%;
  height: 100%;
}

@media (max-width: 1100px) {
  nav,
  .nav,
  .main-nav,
  .site-nav {
    gap: 0.55rem !important;
  }

  nav a,
  .nav a,
  .main-nav a,
  .site-nav a {
    font-size: 0.86rem !important;
  }

  .grid,
  .cards-grid,
  .card-grid,
  .stats-grid,
  .gear-grid,
  .product-grid,
  .partner-grid,
  .impact-grid,
  .event-grid,
  .timeline-grid,
  .flyer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .hero h1,
  h1 {
    font-size: clamp(2.1rem, 6vw, 4rem) !important;
    line-height: 1.05;
  }

  .hero h2,
  h2 {
    font-size: clamp(1.55rem, 4.6vw, 2.7rem) !important;
    line-height: 1.12;
  }
}

@media (max-width: 767px) {
  body {
    font-size: 15px;
  }

  header,
  .site-header {
    position: relative;
  }

  header .container,
  .site-header .container,
  .nav-inner,
  .topbar,
  .brand-row {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center;
    gap: 0.85rem;
  }

  .brand,
  .logo-wrap,
  .site-branding {
    justify-content: center !important;
    text-align: center;
  }

  .brand img,
  .logo-wrap img,
  .site-logo,
  header img {
    max-width: 96px;
    height: auto;
  }

  nav,
  .nav,
  .main-nav,
  .site-nav {
    width: 100%;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem !important;
    padding: 0 0.75rem;
  }

  nav a,
  .nav a,
  .main-nav a,
  .site-nav a {
    width: 100%;
    display: flex !important;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0.55rem 0.45rem !important;
    font-size: 0.82rem !important;
    line-height: 1.1;
    border-radius: 10px;
  }

  .container,
  .content,
  .section-inner,
  .wrap,
  .page-wrap,
  .hero-inner,
  main,
  section {
    width: 100%;
  }

  section,
  .section,
  .hero {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  .grid,
  .cards-grid,
  .card-grid,
  .stats-grid,
  .gear-grid,
  .product-grid,
  .partner-grid,
  .impact-grid,
  .event-grid,
  .timeline-grid,
  .flyer-grid,
  .two-column,
  .three-column,
  .columns {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .hero,
  .hero-inner,
  .feature-row,
  .product-row,
  .gear-row,
  .impact-row,
  .about-row,
  .mission-row {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .hero h1,
  h1 {
    font-size: clamp(1.9rem, 9vw, 3rem) !important;
    line-height: 1.04;
  }

  .hero h2,
  h2 {
    font-size: clamp(1.35rem, 7vw, 2.15rem) !important;
    line-height: 1.12;
  }

  h3 {
    font-size: clamp(1.1rem, 5vw, 1.55rem) !important;
  }

  p,
  li {
    line-height: 1.6;
  }

  .button-row,
  .cta-row,
  .actions,
  .hero-actions,
  .card-actions {
    flex-direction: column !important;
    align-items: stretch !important;
    width: 100%;
  }

  .button-row a,
  .cta-row a,
  .actions a,
  .hero-actions a,
  .card-actions a,
  .button-row button,
  .cta-row button,
  .actions button,
  .hero-actions button,
  .card-actions button,
  .btn,
  .button {
    width: 100%;
    text-align: center;
    justify-content: center;
  }

  table {
    display: block;
    width: 100%;
    overflow-x: auto;
  }

  .launch-flyer-image img,
  .flyer-image img,
  .poster-image img,
  .coming-soon-image img,
  .scholarship-flyer img {
    max-height: none;
  }
}

@media (max-width: 430px) {
  nav,
  .nav,
  .main-nav,
  .site-nav {
    grid-template-columns: 1fr;
  }

  section,
  .section,
  .hero {
    padding-left: 0.85rem !important;
    padding-right: 0.85rem !important;
  }

  .card,
  .event-card,
  .gear-card,
  .product-card,
  .impact-card,
  .donation-card,
  .partner-card,
  .timeline-card {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}

/* =========================================================
   Throwing 2 Honor Website V2
   Mobile Cleanup Pass 2
   Fixes mobile nav overflow, leftover menu text, and badge overflow.
   ========================================================= */

/* Hide old placeholder mobile menu text if any older template still renders it. */
.menu-coming-soon,
.mobile-menu-coming-soon,
.menu-placeholder,
.nav-placeholder,
.mobile-nav-placeholder,
[aria-label="Menu coming soon"] {
  display: none !important;
}

/* Make header/nav predictable on phones. */
@media (max-width: 767px) {
  header,
  .site-header {
    min-height: 0 !important;
    height: auto !important;
    overflow: visible !important;
  }

  header .container,
  .site-header .container,
  .nav-inner,
  .topbar,
  .brand-row,
  .header-inner {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
    gap: 0.8rem !important;
  }

  .brand,
  .site-branding,
  .logo-wrap,
  .brand-block {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    gap: 0.4rem !important;
  }

  .brand img,
  .site-branding img,
  .logo-wrap img,
  .site-logo,
  header img {
    max-width: 92px !important;
    width: auto !important;
    height: auto !important;
    margin: 0 auto !important;
  }

  .brand h1,
  .site-branding h1,
  .brand-title {
    font-size: 1.55rem !important;
    line-height: 1.05 !important;
    text-align: center !important;
    margin: 0 !important;
    white-space: normal !important;
  }

  .tagline,
  .brand-tagline,
  .site-tagline {
    font-size: 0.85rem !important;
    line-height: 1.25 !important;
    letter-spacing: 0.18em !important;
    text-align: center !important;
    white-space: normal !important;
  }

  nav,
  .nav,
  .main-nav,
  .site-nav {
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    align-items: stretch !important;
    justify-content: center !important;
    gap: 0.5rem !important;
    padding: 0.5rem 0 !important;
    margin: 0 auto !important;
    overflow: visible !important;
  }

  nav a,
  .nav a,
  .main-nav a,
  .site-nav a {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0.65rem 0.45rem !important;
    margin: 0 !important;
    font-size: 0.78rem !important;
    line-height: 1.12 !important;
    text-align: center !important;
    white-space: normal !important;
    overflow: visible !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    border-radius: 10px !important;
  }

  nav a::before,
  nav a::after,
  .nav a::before,
  .nav a::after,
  .main-nav a::before,
  .main-nav a::after,
  .site-nav a::before,
  .site-nav a::after {
    max-width: 100% !important;
  }

  /* Keep active underline contained inside the mobile nav tile. */
  nav a.active,
  .nav a.active,
  .main-nav a.active,
  .site-nav a.active {
    overflow: hidden !important;
  }
}

@media (max-width: 430px) {
  nav,
  .nav,
  .main-nav,
  .site-nav {
    grid-template-columns: 1fr !important;
  }

  nav a,
  .nav a,
  .main-nav a,
  .site-nav a {
    font-size: 0.82rem !important;
  }
}

/* Fix oversized price/status badges on mobile, especially America 250. */
.price-badge,
.compact-badge {
  max-width: 100% !important;
  overflow: hidden !important;
  display: inline-flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  text-align: center !important;
}

.price-badge .price,
.compact-badge .price {
  line-height: 1 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

.price-badge span,
.compact-badge span {
  max-width: 100% !important;
}

@media (max-width: 767px) {
  .price-badge,
  .compact-badge {
    width: 100% !important;
    border-radius: 22px !important;
    padding: 1rem !important;
  }

  .price-badge .price,
  .compact-badge .price {
    font-size: clamp(1.65rem, 9vw, 2.7rem) !important;
    letter-spacing: 0.02em !important;
  }

  .price-badge span:not(.price),
  .compact-badge span:not(.price) {
    display: block !important;
    width: 100% !important;
    font-size: clamp(0.85rem, 4vw, 1.15rem) !important;
    letter-spacing: 0.08em !important;
  }

  .product-info,
  .gear-feature,
  .product-spotlight {
    overflow: hidden !important;
  }
}

/* General mobile protection for large headings on product pages. */
@media (max-width: 767px) {
  .product-info h2,
  .gear-feature h2,
  .section-title {
    max-width: 100% !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
  }
}

/* America 250 newest gear placement/update */
.featured-newest-gear {
  border-top: 4px solid rgba(237, 28, 36, 0.9);
}

.featured-newest-gear .section-title::after {
  content: "NEWEST ITEM";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 0.75rem;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(237, 28, 36, 0.12);
  border: 1px solid rgba(237, 28, 36, 0.35);
  color: #ed1c24;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  vertical-align: middle;
}

@media (max-width: 767px) {
  .featured-newest-gear .section-title::after {
    display: flex;
    width: fit-content;
    margin: 0.65rem auto 0;
  }

  .featured-newest-gear .price-badge.compact-badge .price {
    font-size: clamp(2.4rem, 14vw, 4rem) !important;
  }
}

/* =========================================================
   Throwing 2 Honor Website V2
   Mobile Cleanup Pass 3
   Fixes About page mobile nav overflow and makes homepage
   group photo visible on mobile.
   ========================================================= */

/* Hard stop for right-side mobile nav clipping on pages like about.html */
@media (max-width: 767px) {
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  header,
  .site-header,
  header *,
  .site-header * {
    box-sizing: border-box !important;
  }

  header,
  .site-header {
    width: 100vw !important;
    max-width: 100vw !important;
    margin: 0 !important;
    left: 0 !important;
    right: auto !important;
    transform: none !important;
    overflow: hidden !important;
  }

  header .container,
  .site-header .container,
  .header-inner,
  .nav-inner {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    transform: none !important;
  }

  nav,
  .nav,
  .main-nav,
  .site-nav {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    transform: none !important;
    position: static !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
  }

  nav a,
  .nav a,
  .main-nav a,
  .site-nav a {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    font-size: 0.74rem !important;
    letter-spacing: 0.02em !important;
  }

  nav a.active::after,
  .nav a.active::after,
  .main-nav a.active::after,
  .site-nav a.active::after {
    left: 12% !important;
    right: 12% !important;
    width: auto !important;
    max-width: 76% !important;
    transform: none !important;
  }
}

@media (max-width: 430px) {
  nav,
  .nav,
  .main-nav,
  .site-nav {
    grid-template-columns: 1fr 1fr !important;
  }

  nav a,
  .nav a,
  .main-nav a,
  .site-nav a {
    font-size: 0.70rem !important;
    min-height: 40px !important;
    padding: 0.55rem 0.25rem !important;
  }
}

/* Make the hidden/preview homepage team photo visible on mobile. */
@media (max-width: 767px) {
  .team-photo,
  .team-photo-section,
  .home-team-photo,
  .mission-team-photo,
  .hero-photo,
  .hero-image,
  .team-image,
  .photo-feature,
  .image-feature,
  .home-photo,
  .homepage-photo,
  .featured-photo,
  .team-photo-wrap,
  .team-image-wrap,
  .hero-media,
  .home-hero-media {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .team-photo img,
  .team-photo-section img,
  .home-team-photo img,
  .mission-team-photo img,
  .hero-photo img,
  .hero-image img,
  .team-image img,
  .photo-feature img,
  .image-feature img,
  .home-photo img,
  .homepage-photo img,
  .featured-photo img,
  .team-photo-wrap img,
  .team-image-wrap img,
  .hero-media img,
  .home-hero-media img,
  img[src*="t2h-team-photo"] {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* If the home hero uses the team photo as a background, stop cropping it on mobile. */
  .hero,
  .home-hero,
  .homepage-hero {
    background-size: contain !important;
    background-position: center top !important;
    background-repeat: no-repeat !important;
    height: auto !important;
    min-height: 0 !important;
  }

  .hero::before,
  .home-hero::before,
  .homepage-hero::before {
    max-width: 100% !important;
  }
}

/* =========================================================
   Throwing 2 Honor Website V2
   Mobile Cleanup Pass 4
   Hard fixes header/nav being pushed off-screen on about.html
   and any page using the same desktop header structure.
   ========================================================= */

@media (max-width: 767px) {
  /* Force the full header to act as a single-column mobile block. */
  body header,
  body .site-header {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 1rem 0 !important;
    position: relative !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    overflow: visible !important;
  }

  body header > *,
  body .site-header > *,
  body header .container,
  body .site-header .container,
  body header .header-inner,
  body .site-header .header-inner,
  body header .nav-inner,
  body .site-header .nav-inner {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 auto !important;
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    position: static !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    overflow: visible !important;
  }

  /* Brand/logo block stays centered above the menu. */
  body header .brand,
  body .site-header .brand,
  body header .site-branding,
  body .site-header .site-branding,
  body header .logo-wrap,
  body .site-header .logo-wrap {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    margin: 0 0 1rem 0 !important;
    padding: 0 !important;
    position: static !important;
    transform: none !important;
  }

  body header .brand img,
  body .site-header .brand img,
  body header .site-branding img,
  body .site-header .site-branding img,
  body header .logo-wrap img,
  body .site-header .logo-wrap img,
  body header img.site-logo,
  body .site-header img.site-logo {
    display: block !important;
    width: auto !important;
    max-width: 104px !important;
    height: auto !important;
    margin: 0 auto 0.45rem auto !important;
    flex: 0 0 auto !important;
  }

  body header .brand h1,
  body .site-header .brand h1,
  body header .site-branding h1,
  body .site-header .site-branding h1,
  body header .brand-title,
  body .site-header .brand-title {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    text-align: center !important;
    font-size: 1.55rem !important;
    line-height: 1.05 !important;
    margin: 0 !important;
    white-space: normal !important;
  }

  body header .tagline,
  body .site-header .tagline,
  body header .brand-tagline,
  body .site-header .brand-tagline,
  body header .site-tagline,
  body .site-header .site-tagline {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    text-align: center !important;
    font-size: 0.78rem !important;
    line-height: 1.25 !important;
    letter-spacing: 0.18em !important;
    margin-top: 0.35rem !important;
    white-space: normal !important;
  }

  /* Nav must not remain beside the logo. */
  body header nav,
  body .site-header nav,
  body header .nav,
  body .site-header .nav,
  body header .main-nav,
  body .site-header .main-nav,
  body header .site-nav,
  body .site-header .site-nav {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: 100% !important;
    max-width: 430px !important;
    min-width: 0 !important;
    margin: 0 auto !important;
    padding: 0 !important;
    gap: 0.5rem !important;
    align-items: stretch !important;
    justify-content: center !important;
    position: static !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    overflow: visible !important;
  }

  body header nav a,
  body .site-header nav a,
  body header .nav a,
  body .site-header .nav a,
  body header .main-nav a,
  body .site-header .main-nav a,
  body header .site-nav a,
  body .site-header .site-nav a {
    display: flex !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 42px !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 0.6rem 0.35rem !important;
    margin: 0 !important;
    position: relative !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    font-size: 0.76rem !important;
    line-height: 1.12 !important;
    letter-spacing: 0.02em !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    border-radius: 10px !important;
  }

  body header nav a.active::after,
  body .site-header nav a.active::after,
  body header .nav a.active::after,
  body .site-header .nav a.active::after,
  body header .main-nav a.active::after,
  body .site-header .main-nav a.active::after,
  body header .site-nav a.active::after,
  body .site-header .site-nav a.active::after {
    left: 18% !important;
    right: 18% !important;
    width: auto !important;
    max-width: 64% !important;
    transform: none !important;
  }
}

@media (max-width: 390px) {
  body header nav,
  body .site-header nav,
  body header .nav,
  body .site-header .nav,
  body header .main-nav,
  body .site-header .main-nav,
  body header .site-nav,
  body .site-header .site-nav {
    grid-template-columns: 1fr !important;
    max-width: 300px !important;
  }

  body header nav a,
  body .site-header nav a,
  body header .nav a,
  body .site-header .nav a,
  body header .main-nav a,
  body .site-header .main-nav a,
  body header .site-nav a,
  body .site-header .site-nav a {
    font-size: 0.82rem !important;
  }
}

/* =========================================================
   Throwing 2 Honor Website V2
   Button Readability Fix
   Fixes low-contrast red/disabled CTA buttons.
   ========================================================= */

/* Make red CTA buttons readable everywhere */
.btn.red,
a.btn.red,
button.btn.red,
.btn-primary,
a.btn-primary,
.button.red,
a.button.red {
  color: #ffffff !important;
  background: #ed1c24 !important;
  border-color: #ed1c24 !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.45) !important;
  opacity: 1 !important;
}

.btn.red:hover,
a.btn.red:hover,
button.btn.red:hover,
.btn-primary:hover,
a.btn-primary:hover,
.button.red:hover,
a.button.red:hover {
  color: #ffffff !important;
  background: #ff2b33 !important;
  border-color: #ff2b33 !important;
}

/* Make white/light buttons readable */
.btn.white,
a.btn.white,
.btn.light,
a.btn.light,
.btn.secondary,
a.btn.secondary,
.btn.navy,
a.btn.navy {
  opacity: 1 !important;
}

/* Disabled scholarship / prelaunch buttons should be clearly readable, not invisible */
.scholarship-button-disabled,
.btn.disabled,
.btn-disabled,
a.btn.disabled,
a.btn-disabled,
button:disabled,
a[aria-disabled="true"] {
  color: #ffffff !important;
  background: #7b1117 !important;
  border: 1px solid rgba(255,255,255,0.35) !important;
  opacity: 0.92 !important;
  filter: none !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.55) !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}

/* If any disabled button sits on a red background class, keep text bright */
.scholarship-button-disabled *,
.btn.disabled *,
.btn-disabled *,
a[aria-disabled="true"] * {
  color: #ffffff !important;
}

/* Specific hero CTA safety for Media / Scholarship / Impact pages */
.hero-actions .btn,
.cta-row .btn,
.actions .btn,
.card-actions .btn,
.gear-actions .btn {
  font-weight: 900 !important;
  letter-spacing: 0.03em !important;
}

/* Mobile safety: ensure CTA text does not fade into button color */
@media (max-width: 767px) {
  .btn.red,
  a.btn.red,
  button.btn.red,
  .btn-primary,
  a.btn-primary,
  .scholarship-button-disabled,
  .btn.disabled,
  .btn-disabled,
  a.btn.disabled,
  a.btn-disabled,
  button:disabled,
  a[aria-disabled="true"] {
    color: #ffffff !important;
    opacity: 1 !important;
    min-height: 46px !important;
  }
}

/* =========================================================
   Throwing 2 Honor Website V2
   Navigation Consistency Fix
   Keeps desktop/tablet nav on one consistent row where possible.
   ========================================================= */

@media (min-width: 768px) {
  header,
  .site-header {
    width: 100% !important;
    overflow: visible !important;
  }

  header .container,
  .site-header .container,
  header .header-inner,
  .site-header .header-inner,
  header .nav-inner,
  .site-header .nav-inner {
    width: 100% !important;
    max-width: 1320px !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 1.2rem !important;
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
  }

  header .brand,
  .site-header .brand,
  header .site-branding,
  .site-header .site-branding,
  header .logo-wrap,
  .site-header .logo-wrap {
    flex: 0 0 auto !important;
    min-width: 330px !important;
    max-width: 390px !important;
  }

  header nav,
  .site-header nav,
  header .nav,
  .site-header .nav,
  header .main-nav,
  .site-header .main-nav,
  header .site-nav,
  .site-header .site-nav {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: none !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: clamp(0.55rem, 1vw, 1.1rem) !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
  }

  header nav a,
  .site-header nav a,
  header .nav a,
  .site-header .nav a,
  header .main-nav a,
  .site-header .main-nav a,
  header .site-nav a,
  .site-header .site-nav a {
    flex: 0 1 auto !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    font-size: clamp(0.64rem, 0.82vw, 0.83rem) !important;
    line-height: 1.1 !important;
    padding-left: 0.1rem !important;
    padding-right: 0.1rem !important;
    letter-spacing: 0.01em !important;
  }
}

/* Mid-size desktop/laptop: tighten logo and nav enough to prevent Partners dropping. */
@media (min-width: 768px) and (max-width: 1240px) {
  header .brand,
  .site-header .brand,
  header .site-branding,
  .site-header .site-branding,
  header .logo-wrap,
  .site-header .logo-wrap {
    min-width: 295px !important;
    max-width: 330px !important;
  }

  header .brand img,
  .site-header .brand img,
  header .site-branding img,
  .site-header .site-branding img,
  header .logo-wrap img,
  .site-header .logo-wrap img {
    max-width: 110px !important;
    height: auto !important;
  }

  header nav,
  .site-header nav,
  header .nav,
  .site-header .nav,
  header .main-nav,
  .site-header .main-nav,
  header .site-nav,
  .site-header .site-nav {
    gap: 0.55rem !important;
  }

  header nav a,
  .site-header nav a,
  header .nav a,
  .site-header .nav a,
  header .main-nav a,
  .site-header .main-nav a,
  header .site-nav a,
  .site-header .site-nav a {
    font-size: 0.68rem !important;
  }
}

/* Small tablets: allow a clean centered wrap instead of one orphan item. */
@media (min-width: 768px) and (max-width: 940px) {
  header .container,
  .site-header .container,
  header .header-inner,
  .site-header .header-inner,
  header .nav-inner,
  .site-header .nav-inner {
    flex-direction: column !important;
    justify-content: center !important;
    text-align: center !important;
  }

  header .brand,
  .site-header .brand,
  header .site-branding,
  .site-header .site-branding,
  header .logo-wrap,
  .site-header .logo-wrap {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  header nav,
  .site-header nav,
  header .nav,
  .site-header .nav,
  header .main-nav,
  .site-header .main-nav,
  header .site-nav,
  .site-header .site-nav {
    justify-content: center !important;
    flex-wrap: wrap !important;
  }
}

/* Partner card clickability */
.partner-logo-link {
  display: inline-block;
  color: inherit;
  text-decoration: none !important;
}

.partner-logo-link img {
  transition: transform 0.2s ease, filter 0.2s ease;
}

.partner-logo-link:hover img {
  transform: scale(1.03);
  filter: brightness(1.08);
}

.partner-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
  padding: 11px 17px;
  border-radius: 999px;
  background: #ed1c24;
  color: #ffffff !important;
  text-decoration: none !important;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid rgba(255,255,255,0.25);
  box-shadow: 0 10px 24px rgba(237,28,36,0.22);
}

.partner-link-btn:hover {
  background: #ff2b33;
  color: #ffffff !important;
}

@media (max-width: 767px) {
  .partner-link-btn {
    width: 100%;
  }
}

/* Partners final cleanup */
#partners .partner-link-btn,
.proud-partners .partner-link-btn,
.home-partners .partner-link-btn {
  display: none !important;
}

.partner-logo-link {
  display: inline-block;
  text-decoration: none !important;
}

.partner-logo-link img {
  transition: transform 0.2s ease, filter 0.2s ease;
}

.partner-logo-link:hover img {
  transform: scale(1.03);
  filter: brightness(1.08);
}

/* =========================================================
   Throwing 2 Honor Website V2
   Mobile Landscape Header Fix
   Fixes iPhone landscape / small tablet width where desktop
   nav can get pushed off-screen or disappear.
   ========================================================= */

@media (min-width: 768px) and (max-width: 1050px) {
  body header.site-header,
  body .site-header {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 10px 0 12px !important;
    overflow: visible !important;
  }

  body header.site-header .nav-wrap,
  body .site-header .nav-wrap,
  body header.site-header .header-inner,
  body .site-header .header-inner,
  body header.site-header .nav-inner,
  body .site-header .nav-inner {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 auto !important;
    padding: 0 14px !important;
    gap: 10px !important;
    overflow: visible !important;
  }

  body header.site-header .brand,
  body .site-header .brand {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 auto !important;
    gap: 12px !important;
    text-align: left !important;
  }

  body header.site-header .logo-badge,
  body .site-header .logo-badge {
    flex: 0 0 auto !important;
  }

  body header.site-header .logo-badge img,
  body .site-header .logo-badge img,
  body header.site-header .brand img,
  body .site-header .brand img {
    width: auto !important;
    max-width: 82px !important;
    height: auto !important;
  }

  body header.site-header .brand-name,
  body .site-header .brand-name {
    font-size: 1.55rem !important;
    line-height: 1.02 !important;
    white-space: normal !important;
  }

  body header.site-header .brand-tagline,
  body .site-header .brand-tagline {
    font-size: 0.72rem !important;
    letter-spacing: 0.12em !important;
    white-space: normal !important;
  }

  body header.site-header nav.main-nav,
  body .site-header nav.main-nav,
  body header.site-header .main-nav,
  body .site-header .main-nav {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    width: 100% !important;
    max-width: 920px !important;
    min-width: 0 !important;
    margin: 0 auto !important;
    padding: 0 !important;
    gap: 6px !important;
    align-items: stretch !important;
    justify-content: center !important;
    overflow: visible !important;
    position: static !important;
    transform: none !important;
  }

  body header.site-header nav.main-nav a,
  body .site-header nav.main-nav a,
  body header.site-header .main-nav a,
  body .site-header .main-nav a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 34px !important;
    padding: 6px 4px !important;
    margin: 0 !important;
    font-size: 0.66rem !important;
    line-height: 1.05 !important;
    text-align: center !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    overflow: hidden !important;
    border-radius: 8px !important;
  }

  body header.site-header nav.main-nav a.active::after,
  body .site-header nav.main-nav a.active::after,
  body header.site-header .main-nav a.active::after,
  body .site-header .main-nav a.active::after {
    left: 15% !important;
    right: 15% !important;
    width: auto !important;
    max-width: 70% !important;
  }
}

/* Very short landscape phones: make the header even more compact. */
@media (min-width: 768px) and (max-width: 1050px) and (max-height: 520px) {
  body header.site-header,
  body .site-header {
    padding: 8px 0 10px !important;
  }

  body header.site-header .nav-wrap,
  body .site-header .nav-wrap {
    gap: 8px !important;
  }

  body header.site-header .logo-badge img,
  body .site-header .logo-badge img,
  body header.site-header .brand img,
  body .site-header .brand img {
    max-width: 64px !important;
  }

  body header.site-header .brand-name,
  body .site-header .brand-name {
    font-size: 1.25rem !important;
  }

  body header.site-header .brand-tagline,
  body .site-header .brand-tagline {
    font-size: 0.62rem !important;
    letter-spacing: 0.10em !important;
  }

  body header.site-header nav.main-nav,
  body .site-header nav.main-nav,
  body header.site-header .main-nav,
  body .site-header .main-nav {
    grid-template-columns: repeat(9, minmax(0, 1fr)) !important;
    max-width: 980px !important;
    gap: 4px !important;
  }

  body header.site-header nav.main-nav a,
  body .site-header nav.main-nav a,
  body header.site-header .main-nav a,
  body .site-header .main-nav a {
    min-height: 30px !important;
    padding: 5px 2px !important;
    font-size: 0.58rem !important;
    letter-spacing: 0 !important;
  }
}

/* =========================================================
   Throwing 2 Honor Website V2
   Events Portrait Mobile Fix
   Fixes iPhone portrait event cards squeezing into narrow columns.
   ========================================================= */

@media (max-width: 767px) {
  body .featured-events,
  body .events-featured,
  body .events-grid,
  body .featured-grid,
  body .event-grid,
  body .event-cards,
  body .event-card-grid,
  body .event-layout,
  body .featured-event-layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
    max-width: 100% !important;
    gap: 1.4rem !important;
  }

  body .event-card,
  body .featured-event,
  body .event-panel,
  body .event-feature-card,
  body .blood-drive-card,
  body .video-card,
  body .event-video-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
    overflow: hidden !important;
  }

  body .event-card *,
  body .featured-event *,
  body .event-panel *,
  body .event-feature-card *,
  body .blood-drive-card *,
  body .video-card *,
  body .event-video-card * {
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body .event-meta,
  body .event-details,
  body .event-info,
  body .event-stats,
  body .detail-grid,
  body .event-detail-grid,
  body .info-grid,
  body .date-time-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
    gap: 0.85rem !important;
  }

  body .event-meta > *,
  body .event-details > *,
  body .event-info > *,
  body .event-stats > *,
  body .detail-grid > *,
  body .event-detail-grid > *,
  body .info-grid > *,
  body .date-time-grid > * {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    white-space: normal !important;
  }

  body .event-card h2,
  body .event-card h3,
  body .featured-event h2,
  body .featured-event h3,
  body .event-panel h2,
  body .event-panel h3,
  body .event-feature-card h2,
  body .event-feature-card h3 {
    font-size: clamp(1.8rem, 10vw, 2.65rem) !important;
    line-height: 0.98 !important;
    letter-spacing: 0.015em !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
  }

  body .event-card p,
  body .featured-event p,
  body .event-panel p,
  body .event-feature-card p {
    font-size: 1rem !important;
    line-height: 1.55 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  body .event-card .btn,
  body .featured-event .btn,
  body .event-panel .btn,
  body .event-feature-card .btn,
  body .video-card .btn,
  body .event-video-card .btn {
    width: 100% !important;
    text-align: center !important;
    justify-content: center !important;
  }
}

@media (max-width: 460px) and (orientation: portrait) {
  body .events-grid,
  body .featured-grid,
  body .event-grid,
  body .event-cards,
  body .event-card-grid,
  body .event-layout,
  body .featured-event-layout {
    grid-template-columns: 1fr !important;
    display: grid !important;
  }

  body .event-card,
  body .featured-event,
  body .event-panel,
  body .event-feature-card,
  body .blood-drive-card,
  body .video-card,
  body .event-video-card {
    border-radius: 22px !important;
    padding: 1.15rem !important;
  }
}

/* Shop Gear Store Transition Update */
.store-status {
  background: radial-gradient(circle at top left, rgba(237,28,36,.18), transparent 34%),
              linear-gradient(135deg, #061225 0%, #111827 100%);
  color: #ffffff;
  padding: 46px 22px;
  border-top: 4px solid rgba(237,28,36,.85);
  border-bottom: 1px solid rgba(255,255,255,.12);
}

.store-status-inner {
  max-width: 1120px;
  margin: 0 auto;
}

.store-status-card {
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 28px;
  padding: clamp(24px, 4vw, 42px);
  background: rgba(4,18,39,.72);
  box-shadow: 0 24px 60px rgba(0,0,0,.28);
  overflow: hidden;
  position: relative;
}

.store-status-card::after {
  content: "STORE";
  position: absolute;
  right: -18px;
  bottom: -24px;
  font-size: clamp(5rem, 15vw, 10rem);
  font-weight: 900;
  color: rgba(255,255,255,.045);
  letter-spacing: .02em;
  pointer-events: none;
}

.store-status-kicker {
  color: #ed1c24;
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: .16em;
  margin-bottom: 12px;
}

.store-status-card h2 {
  margin: 0 0 18px;
  color: #ffffff;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: 1;
  text-transform: uppercase;
}

.store-status-card p {
  max-width: 920px;
  color: rgba(255,255,255,.88);
  font-size: 1.08rem;
  line-height: 1.65;
}

.store-promise-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 26px;
  position: relative;
  z-index: 1;
}

.store-promise-grid div {
  border-radius: 18px;
  padding: 18px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
}

.store-promise-grid strong {
  display: block;
  color: #ffffff;
  font-size: 1rem;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.store-promise-grid span {
  display: block;
  color: rgba(255,255,255,.82);
  line-height: 1.45;
}

.store-status-banner {
  margin-top: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 13px 18px;
  border-radius: 999px;
  background: #ed1c24;
  color: #ffffff;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
  position: relative;
  z-index: 1;
}

@media (max-width: 767px) {
  .store-promise-grid {
    grid-template-columns: 1fr;
  }
  .store-status-banner {
    width: 100%;
    border-radius: 18px;
    text-align: center;
  }
}

/* Shop Gear Removed / Vendor Review Update */
.gear-hold-hero {
  background: radial-gradient(circle at 18% 20%, rgba(237,28,36,.22), transparent 34%),
              radial-gradient(circle at 85% 0%, rgba(59,130,246,.18), transparent 30%),
              linear-gradient(135deg, #050b14 0%, #0b1728 55%, #101827 100%);
  color: #ffffff;
  padding: clamp(58px, 8vw, 112px) 22px;
  text-align: center;
  border-bottom: 4px solid rgba(237,28,36,.9);
}

.gear-hold-inner {
  max-width: 1040px;
  margin: 0 auto;
}

.gear-hold-kicker {
  color: #ed1c24;
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: .16em;
  margin-bottom: 16px;
}

.gear-hold-hero h1 {
  margin: 0;
  font-size: clamp(3rem, 8vw, 6.8rem);
  line-height: .9;
  text-transform: uppercase;
  color: #ffffff;
}

.gear-hold-lead {
  max-width: 900px;
  margin: 24px auto 0;
  color: rgba(255,255,255,.88);
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  line-height: 1.55;
}

.gear-hold-alert {
  margin: 34px auto 0;
  max-width: 860px;
  display: grid;
  gap: 8px;
  padding: 22px;
  border-radius: 22px;
  background: rgba(237,28,36,.14);
  border: 1px solid rgba(237,28,36,.42);
  box-shadow: 0 18px 40px rgba(0,0,0,.24);
}

.gear-hold-alert strong {
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 1.05rem;
}

.gear-hold-alert span {
  color: rgba(255,255,255,.84);
  line-height: 1.5;
}

.gear-hold-section {
  background: #f6f4ef;
  padding: 58px 22px;
}

.gear-hold-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  max-width: 1120px;
  margin: 0 auto;
}

.gear-hold-card {
  background: #ffffff;
  border-radius: 24px;
  padding: 30px;
  box-shadow: 0 18px 42px rgba(0,0,0,.10);
  border: 1px solid rgba(7,17,31,.08);
}

.gear-hold-icon {
  font-size: 2.2rem;
  margin-bottom: 14px;
}

.gear-hold-card h2 {
  margin: 0 0 12px;
  color: #07111f;
  font-size: 1.45rem;
  line-height: 1.12;
}

.gear-hold-card p {
  margin: 0;
  color: #334155;
  line-height: 1.58;
}

.gear-hold-next {
  background: linear-gradient(135deg, #07111f 0%, #111827 100%);
  color: #ffffff;
  text-align: center;
  padding: 58px 22px 72px;
}

.gear-hold-next .section-title {
  color: #ffffff;
}

.gear-hold-next .section-lead {
  color: rgba(255,255,255,.86);
}

.gear-hold-steps {
  max-width: 1050px;
  margin: 30px auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.gear-hold-steps div {
  padding: 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
}

.gear-hold-steps strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: #ed1c24;
  color: #ffffff;
  margin-bottom: 10px;
}

.gear-hold-steps span {
  display: block;
  color: rgba(255,255,255,.84);
  line-height: 1.4;
}

.gear-hold-actions {
  justify-content: center;
}

@media (max-width: 900px) {
  .gear-hold-grid,
  .gear-hold-steps {
    grid-template-columns: 1fr;
  }
}

/* Shop Gear events page inline link */
.inline-store-link {
  color: #ffffff !important;
  font-weight: 900;
  text-decoration: underline;
  text-decoration-thickness: 3px;
  text-underline-offset: 4px;
}

.inline-store-link:hover {
  color: #ff2b33 !important;
}
