/*
Theme Name: RAISEBOX Theme
Theme URI: https://raisebox.io
Description: RAISEBOX brand child theme of Twenty Twenty-Five.
Author: RAISEBOX
Author URI: https://raisebox.io
Template: twentytwentyfive
Version: 1.1.0
Requires at least: 6.5
Tested up to: 6.9
Requires PHP: 7.4
Text Domain: raisebox-theme
*/

@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@400;500;600;700&family=Rajdhani:wght@500;600;700&display=swap");

/* ==============================
   RAISEBOX  Palette Test Match
   ============================== */

:root {
  --bg: #0C1A2E;
  --surface: #1A2744;
  --surface-elevated: #243352;
  --accent: #DB0A40;
  --accent-hover: #FF1744;
  --text-primary: #FFFFFF;
  --text-secondary: rgba(255,255,255,0.7);
  --text-tertiary: rgba(255,255,255,0.45);
  --border: rgba(255,255,255,0.1);
  --light-bg: #F0F2F5;
  --light-text: #0C1A2E;
}

*, *::before, *::after { box-sizing: border-box; }

body {
  background: var(--bg) !important;
  color: var(--text-primary) !important;
  font-family: 'Inter', -apple-system, sans-serif !important;
  font-size: 16px;
  line-height: 1.6;
  margin: 0;
  padding: 0;
}

.wp-site-blocks {
  background: var(--bg) !important;
}

/* ---- TYPOGRAPHY ---- */

h1, h2, h3, h4, h5, h6,
.wp-block-heading {
  color: var(--text-primary) !important;
  line-height: 1.1;
}

h1,
.wp-block-heading.has-large-font-size,
.wp-block-heading.has-x-large-font-size {
  font-family: 'Bebas Neue', Impact, sans-serif !important;
  font-size: clamp(48px, 6vw, 80px) !important;
  letter-spacing: -0.01em;
  line-height: 0.95 !important;
  margin-bottom: 24px !important;
}

h2, .wp-block-heading:not(.has-large-font-size):not(.has-x-large-font-size) {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: clamp(28px, 4vw, 40px) !important;
  font-weight: 700 !important;
  margin-bottom: 16px !important;
}

h3 {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: clamp(20px, 3vw, 24px) !important;
  font-weight: 700 !important;
  margin-bottom: 12px !important;
}

h4 {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 20px !important;
  font-weight: 700 !important;
}

p, li, td, th, dd, dt, figcaption {
  color: var(--text-secondary) !important;
  font-size: 16px;
  line-height: 1.7;
}

/* ---- LINKS ---- */

a {
  color: var(--accent) !important;
  text-decoration: none;
  transition: color 0.2s;
}
a:hover {
  color: var(--accent-hover) !important;
}

/* ---- HEADER / NAV ---- */

header.wp-block-template-part,
.wp-block-template-part[data-type="header"] {
  background: var(--surface) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 16px 48px !important;
  position: sticky;
  top: 0;
  z-index: 100;
}

.wp-block-site-title a,
.wp-block-site-title {
  color: var(--text-primary) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 20px !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  text-decoration: none !important;
}

.wp-block-navigation a,
.wp-block-navigation-item a {
  color: var(--text-secondary) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  text-decoration: none !important;
  transition: color 0.2s;
}
.wp-block-navigation a:hover,
.wp-block-navigation-item a:hover {
  color: var(--text-primary) !important;
}

/* ---- BUTTONS  RACE RED ---- */

.wp-block-button__link,
.wp-element-button {
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  border-radius: 8px !important;
  padding: 14px 32px !important;
  cursor: pointer;
  transition: all 0.2s !important;
  display: inline-block !important;
  text-decoration: none !important;
}

/* Primary (filled) button  Race Red */
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
  background: var(--accent) !important;
  color: white !important;
  border: none !important;
}
.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
  background: var(--accent-hover) !important;
  transform: translateY(-2px);
}

/* Outline button  white border */
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent !important;
  color: white !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  border-color: white !important;
  background: rgba(255,255,255,0.05) !important;
}

/* Button row spacing */
.wp-block-buttons {
  gap: 16px !important;
  display: flex !important;
  flex-wrap: wrap !important;
  margin-bottom: 24px !important;
}

/* ---- SEPARATOR ---- */

.wp-block-separator {
  border-color: var(--border) !important;
  opacity: 1 !important;
  margin: 32px 0 !important;
}

/* ---- CARDS (columns as cards) ---- */

.wp-block-column {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  padding: 32px !important;
  transition: all 0.3s !important;
}
.wp-block-column:hover {
  border-color: rgba(255,255,255,0.2) !important;
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.3);
}

/* Columns container  gap between cards */
.wp-block-columns {
  gap: 24px !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin-top: 24px !important;
  margin-bottom: 24px !important;
}
.wp-block-columns:hover {
  transform: none !important;
  box-shadow: none !important;
  border-color: transparent !important;
}

/* ---- GROUP BLOCKS ---- */

.wp-block-group {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}
.wp-block-group:hover {
  transform: none !important;
  box-shadow: none !important;
}

/* ---- SECTION SPACING ---- */

.wp-block-post-content {
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: 100% !important;
  padding-left: clamp(24px, 4vw, 48px) !important;
  padding-right: clamp(24px, 4vw, 48px) !important;
  box-sizing: border-box !important;
}

/* Vertical spacing between sections */
.wp-block-post-content > .wp-block-separator {
  margin: 48px auto !important;
  max-width: 1000px;
}

/* Content blocks max width */
.wp-block-post-content > * {
  max-width: 1000px;
  margin-left: auto !important;
  margin-right: auto !important;
}

.wp-block-post-content > .wp-block-columns {
  max-width: 1000px;
}

.wp-block-post-content > .wp-block-heading {
  margin-top: 48px !important;
}

/* Section vertical rhythm */
.wp-block-post-content > p {
  margin-bottom: 20px !important;
}

/* ---- ALIGNFULL FIX ---- */

.wp-block-group.alignfull {
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
}

/* ---- HIDE PAGE TITLE ---- */

.wp-block-post-title,
.entry-title,
h1.wp-block-post-title,
.page .wp-block-post-title,
body.page .wp-block-post-title,
.home .wp-block-post-title {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ---- LIST STYLING ---- */

.wp-block-list li {
  margin-bottom: 0.5rem;
}
.wp-block-list li::marker {
  color: var(--accent);
}

/* ---- BLOCKQUOTE ---- */

blockquote, .wp-block-quote {
  border-left: 4px solid var(--accent) !important;
  padding-left: 1.5rem;
}

/* ---- FOOTER ---- */

footer.wp-block-template-part,
.wp-block-template-part[data-type="footer"] {
  background: #0A1525 !important;
  border-top: 1px solid var(--border) !important;
  padding: 60px 48px 32px !important;
}

footer .wp-block-column {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}
footer .wp-block-column:hover {
  transform: none !important;
  box-shadow: none !important;
  border-color: transparent !important;
}

footer .wp-block-columns {
  gap: 48px !important;
}

footer h3, footer h4, footer h5,
footer .wp-block-heading {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--text-secondary) !important;
  margin-bottom: 16px !important;
}

footer p {
  color: var(--text-tertiary) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
}

footer a {
  color: var(--text-tertiary) !important;
  font-size: 14px !important;
  transition: color 0.2s;
}
footer a:hover {
  color: var(--text-primary) !important;
}

footer .wp-block-separator {
  border-color: var(--border) !important;
  margin: 32px 0 24px !important;
}

/* ---- RACING STRIPE ---- */

body::before {
  content: '';
  display: block;
  width: 100%;
  height: 3px;
  background: var(--accent);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}
.admin-bar body::before {
  top: 32px;
}

/* ---- SELECTION ---- */

::selection {
  background: var(--accent);
  color: white;
}

/* ---- RESPONSIVE ---- */

@media (max-width: 1024px) {
  header.wp-block-template-part {
    padding: 12px 24px !important;
  }
  .wp-block-post-content {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
  footer.wp-block-template-part {
    padding: 40px 24px 24px !important;
  }
}

@media (max-width: 768px) {
  .wp-block-columns {
    flex-direction: column !important;
    gap: 16px !important;
  }
  .wp-block-column {
    padding: 24px !important;
  }
  .wp-block-buttons {
    flex-direction: column !important;
  }
  .wp-block-button__link {
    width: 100% !important;
    text-align: center !important;
  }
  header.wp-block-template-part {
    padding: 12px 16px !important;
  }
  .wp-block-post-content {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  footer.wp-block-template-part {
    padding: 32px 16px 20px !important;
  }
  footer .wp-block-columns {
    gap: 24px !important;
  }
  .wp-block-post-content > .wp-block-heading {
    margin-top: 32px !important;
  }
}

@media (max-width: 480px) {
  h1,
  .wp-block-heading.has-large-font-size {
    font-size: 40px !important;
  }
  h2 {
    font-size: 28px !important;
  }
}


/* ===================== NAVIGATION DROPDOWN / SUBMENU ===================== */

/* Submenu container - hidden by default */
.wp-block-navigation .wp-block-navigation__submenu-container {
  display: none !important;
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  z-index: 1000 !important;
  min-width: 220px !important;
  background: #1A2744 !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 12px !important;
  padding: 8px 0 !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.4) !important;
  margin-top: 0 !important;
}

/* Show submenu on hover */
.wp-block-navigation-submenu:hover > .wp-block-navigation__submenu-container,
.wp-block-navigation-submenu:focus-within > .wp-block-navigation__submenu-container,
.wp-block-navigation .has-child:hover > .wp-block-navigation__submenu-container,
.wp-block-navigation .has-child:focus-within > .wp-block-navigation__submenu-container {
  display: flex !important;
  flex-direction: column !important;
}

/* Submenu links */
.wp-block-navigation__submenu-container .wp-block-navigation-item__content,
.wp-block-navigation__submenu-container .wp-block-navigation-link__content,
.wp-block-navigation__submenu-container a {
  color: rgba(255,255,255,0.7) !important;
  text-decoration: none !important;
  padding: 10px 20px !important;
  display: block !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  transition: all 0.2s !important;
  white-space: nowrap !important;
}

.wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover,
.wp-block-navigation__submenu-container .wp-block-navigation-link__content:hover,
.wp-block-navigation__submenu-container a:hover {
  color: #FFFFFF !important;
  background: rgba(255,255,255,0.05) !important;
}

/* Submenu items */
.wp-block-navigation__submenu-container .wp-block-navigation-item,
.wp-block-navigation__submenu-container .wp-block-navigation-link {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Parent submenu item needs relative positioning */
.wp-block-navigation-submenu,
.wp-block-navigation .has-child {
  position: relative !important;
}

/* Submenu icon/arrow styling */
.wp-block-navigation-submenu__toggle,
.wp-block-navigation__submenu-icon {
  color: rgba(255,255,255,0.5) !important;
  margin-left: 4px !important;
}



/* ===================== FIX: Nav group overflow clipping dropdown ===================== */

/* The wp-block-group wrapping the navigation has overflow:hidden which clips the dropdown */
header .wp-block-group,
.wp-block-template-part > .wp-block-group,
.wp-block-navigation .wp-block-group {
  overflow: visible !important;
}

/* Also fix any ancestor in the header template part */
header,
header *:not(.wp-block-navigation__submenu-container) {
  overflow: visible !important;
}

/* Ensure the header/template-part itself allows overflow */
.wp-block-template-part,
.wp-block-template-part > * {
  overflow: visible !important;
}

