/*
Theme Name: SKDA 2025
Theme URI: https://example.com/twenty-twenty-four-child
Description: SKDA theme, child of 2024 theme
Author: Stephen Suess
Author URI: https://stephensuess.com
Template: twentytwentyfour
Version: 1.0.0
*/

/* ==========================================================================
   Global - Remove border-radius from all images
   ========================================================================== */
img,
.wp-block-image img,
.wp-block-post-featured-image img,
.wp-block-cover img,
.wp-block-media-text img {
  border-radius: 0 !important;
}

/* ==========================================================================
   Global - Link hover color change (no underline)
   ========================================================================== */
a {
  text-decoration: none;
  transition: color 0.2s ease;
}

a:hover {
  color: #d87715 !important;
  text-decoration: none !important;
}

/* ==========================================================================
   Global Site Width - Max 2000px centered with white sides
   ========================================================================== */

/* Body background (visible on sides beyond 2000px) */
body {
  background-color: #ffffff;
}

/* Main site wrapper - constrain and center all content */
.wp-site-blocks {
  max-width: 2000px;
  margin-left: auto;
  margin-right: auto;
  background-color: var(--wp--preset--color--base, #f9f9f9);
}

/* Ensure full-width aligned blocks don't exceed site width */
.wp-site-blocks .alignfull {
  max-width: 2000px;
  margin-left: auto;
  margin-right: auto;
}

/* Header and footer full width within the 2000px container */
.wp-site-blocks > header,
.wp-site-blocks > footer {
  max-width: 100%;
}

/* Ensure wide alignments respect the container */
.wp-site-blocks .alignwide {
  max-width: min(2000px, 100%);
}

/* ==========================================================================
   Home Page - Full viewport slider without white stripe
   ========================================================================== */

/* Hide footer on home page */
body.home footer.wp-block-template-part,
body.home .wp-block-template-part[data-area="footer"] {
  display: none !important;
}

/* Remove any padding/margin on home page that could create gaps */
body.home .wp-site-blocks {
  padding: 0 !important;
  margin: 0 auto !important;
}

/* Ensure the slider container takes full viewport */
body.home .homeslider,
body.home .wp-block-nextend-smartslider3 {
  height: 100vh !important;
  min-height: 100vh !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Prevent any block gap from creating space */
body.home .wp-site-blocks > * + * {
  margin-top: 0 !important;
}

/* Smart Slider internal elements - remove all padding/margins */
body.home .n2-section-smartslider {
  margin: 0 !important;
  padding: 0 !important;
  height: 100vh !important;
}

body.home .n2-ss-margin,
body.home .n2-ss-slider,
body.home .n2-ss-slider-wrapper,
body.home .n2-ss-slider-wrapper-inside {
  margin: 0 !important;
  padding: 0 !important;
}

body.home .n2-padding {
  padding: 0 !important;
}

body.home #n2-ss-2-align,
body.home .n2-ss-align {
  margin: 0 !important;
  padding: 0 !important;
}

/* Override the margin-top: -20px and compensate */
body.home .n2-section-smartslider,
body.home #n2-ss-2,
body.home .n2-ss-slider-1,
body.home .n2-ss-slider-2,
body.home .n2-ss-slider-3 {
  margin-top: 0 !important;
  height: 100vh !important;
}

/* ==========================================================================
   Navigation - Uppercase menu items
   ========================================================================== */
.wp-block-navigation .wp-block-navigation-item a,
.wp-block-navigation .wp-block-navigation__submenu-container a {
  text-transform: uppercase;
  text-decoration: none !important;
  transition: color 0.2s ease;
}

.wp-block-navigation .wp-block-navigation-item a:hover,
.wp-block-navigation .wp-block-navigation__submenu-container a:hover {
  color: #d87715 !important;
  text-decoration: none !important;
}

/* Remove focus outline from navigation, breadcrumb, and connect page links */
.wp-block-navigation a:focus,
.wp-block-navigation a:focus-visible,
div.breadcrumbs.wp-block-bcn-breadcrumb-trail a:focus,
div.breadcrumbs.wp-block-bcn-breadcrumb-trail a:focus-visible,
.connect-box a:focus,
.connect-box a:focus-visible,
.newsletter-popup-trigger:focus,
.newsletter-popup-trigger:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

/* Force navigation to collapse to hamburger at 650px (override WP default 600px) */
@media (max-width: 650px) {
  .wp-block-navigation__responsive-container:not(.is-menu-open) .wp-block-navigation__container {
    display: none !important;
  }

  .wp-block-navigation__responsive-container-open {
    display: flex !important;
  }
}

/* Mobile menu - reduce submenu indentation */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item {
  padding-left: 0.5rem !important;
}

/* Ensure navigation dropdowns appear above page content */
.wp-block-navigation__submenu-container {
  z-index: 99999 !important;
  position: relative;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  padding: 0.25rem 0 !important;
  gap: 0 !important;
}

/* Reduce spacing between submenu items - override Global Styles */
body .wp-block-navigation ul.wp-block-navigation__submenu-container,
body .wp-block-navigation .wp-block-navigation__submenu-container {
  padding-top: 0.15rem !important;
  padding-bottom: 0.15rem !important;
  min-width: 0 !important;
  min-width: unset !important;
  width: auto !important;
}

body .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item {
  margin: 0 !important;
  padding: 0 !important;
}

body .wp-block-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  padding: 0.2rem 1rem !important;
  line-height: 1.3 !important;
}

/* Mobile menu icon - white on home page */
body.home .wp-block-navigation__responsive-container-open,
body.home .wp-block-navigation__responsive-container-open svg {
  color: white !important;
  fill: white !important;
}

/* Mobile menu opened - black text on white background */
body.home .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a,
body.home .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
  color: #000 !important;
}

/* Close button should be black when menu is open */
body.home .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close,
body.home .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close svg {
  color: #000 !important;
  fill: #000 !important;
}

header.wp-block-template-part {
  position: relative;
  z-index: 10000;
}

/* Mobile header padding to align with content */
@media (max-width: 750px) {
  header.wp-block-template-part {
    padding-left: 5px;
    padding-right: 5px;
    box-sizing: border-box;
  }
}

/* Ensure grid doesn't interfere with dropdown */
.terms-grid {
  position: relative;
  z-index: 1;
}

/* ==========================================================================
   Project Categories Grid - Hover zoom effect
   ========================================================================== */
/* Override the plugin's background-size to enable animation */
.term-item {
  background-size: 100% !important;
  transition: background-size 0.3s ease;
}

.term-item:hover {
  background-size: 110% !important;
}

/* ==========================================================================
   Project Grid - Hover zoom effect (matches people/news grids)
   ========================================================================== */
.project-grid-item img,
.project-grid-item .wp-block-post-featured-image img {
  transition: transform 0.3s ease, filter 0.3s ease;
}

.project-grid-item:hover img,
.project-grid-item:hover .wp-block-post-featured-image img {
  transform: scale(1.05);
}

/* ==========================================================================
   People/Employee Grid - Responsive padding to match project-categories
   ========================================================================== */
/* Remove constrained layout padding */
.post-type-archive-employee main.wp-block-group.is-layout-constrained {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Apply responsive padding to the grid */
.post-type-archive-employee .wp-block-post-template {
  padding-left: var(--wp--preset--spacing--20) !important;
  padding-right: var(--wp--preset--spacing--20) !important;
}

@media (max-width: 768px) {
  .post-type-archive-employee .wp-block-post-template {
    padding-left: var(--wp--preset--spacing--10) !important;
    padding-right: var(--wp--preset--spacing--10) !important;
  }
}

@media (max-width: 600px) {
  .post-type-archive-employee .wp-block-post-template {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}

/* ==========================================================================
   Logo - White on home page, project pages, and connect page
   ========================================================================== */
body.home .wp-block-site-logo img.custom-logo,
body.home .custom-logo-link img.custom-logo,
body.home img.custom-logo,
body.single-project .wp-block-site-logo img.custom-logo,
body.single-project .custom-logo-link img.custom-logo,
body.single-project img.custom-logo,
body.page-template-page-connect .wp-block-site-logo img.custom-logo,
body.page-template-page-connect .custom-logo-link img.custom-logo,
body.page-template-page-connect img.custom-logo {
  filter: brightness(0) invert(1) drop-shadow(0 1px 3px rgba(0, 0, 0, 0.5)) !important;
  transition: filter 0.2s ease;
}

/* White logo pages - orange on hover */
body.home .wp-block-site-logo a:hover img.custom-logo,
body.home .custom-logo-link:hover img.custom-logo,
body.single-project .wp-block-site-logo a:hover img.custom-logo,
body.single-project .custom-logo-link:hover img.custom-logo,
body.page-template-page-connect .wp-block-site-logo a:hover img.custom-logo,
body.page-template-page-connect .custom-logo-link:hover img.custom-logo {
  filter: brightness(0) saturate(100%) invert(56%) sepia(98%) saturate(401%) hue-rotate(6deg) brightness(93%) contrast(91%) drop-shadow(0 1px 3px rgba(0, 0, 0, 0.5)) !important;
}

/* ==========================================================================
   Logo - Size increase (1.5x)
   ========================================================================== */
.wp-block-site-logo {
  transform: scale(1.5);
  transform-origin: left center;
}

/* Logo - Remove focus outline and add hover color */
.wp-block-site-logo a:focus,
.wp-block-site-logo a:focus-visible,
.custom-logo-link:focus,
.custom-logo-link:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

.wp-block-site-logo img,
.custom-logo-link img {
  transition: filter 0.2s ease;
}

.wp-block-site-logo a:hover img,
.custom-logo-link:hover img {
  filter: brightness(0) saturate(100%) invert(56%) sepia(98%) saturate(401%) hue-rotate(6deg) brightness(93%) contrast(91%) !important;
}

/* ==========================================================================
   Breadcrumbs - Styling and alignment
   ========================================================================== */
div.breadcrumbs.wp-block-bcn-breadcrumb-trail {
  padding-left: var(--wp--preset--spacing--20) !important;
  margin-left: 0 !important;
  margin-bottom: 10px;
  margin-top: 30px !important;
  color: #808080 !important;
}

@media (max-width: 768px) {
  div.breadcrumbs.wp-block-bcn-breadcrumb-trail {
    padding-left: var(--wp--preset--spacing--10) !important;
  }
}

@media (max-width: 600px) {
  div.breadcrumbs.wp-block-bcn-breadcrumb-trail {
    padding-left: 1rem !important;
  }
}

/* Grey color for breadcrumb links (50% black) */
div.breadcrumbs.wp-block-bcn-breadcrumb-trail a,
div.breadcrumbs.wp-block-bcn-breadcrumb-trail span {
  text-transform: uppercase !important;
  text-decoration: none !important;
  transition: color 0.2s ease;
}

div.breadcrumbs.wp-block-bcn-breadcrumb-trail a:not(:hover),
div.breadcrumbs.wp-block-bcn-breadcrumb-trail span:not(:hover) {
  color: #808080 !important;
}

div.breadcrumbs.wp-block-bcn-breadcrumb-trail a:hover {
  text-decoration: none !important;
  color: #d87715 !important;
}

/* ==========================================================================
   Taxonomy Archive Pages - Match project-categories spacing
   ========================================================================== */
body.tax-project-type .wp-block-query > .wp-block-group {
  padding-left: var(--wp--preset--spacing--20) !important;
  padding-right: var(--wp--preset--spacing--20) !important;
}

/* Breadcrumbs on taxonomy pages - no extra padding since container handles it */
body.tax-project-type div.breadcrumbs.wp-block-bcn-breadcrumb-trail {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body.tax-project-type div.breadcrumbs.wp-block-bcn-breadcrumb-trail a:hover {
  color: #d87715 !important;
}

@media (max-width: 768px) {
  body.tax-project-type .wp-block-query > .wp-block-group {
    padding-left: var(--wp--preset--spacing--10) !important;
    padding-right: var(--wp--preset--spacing--10) !important;
  }
}

@media (max-width: 600px) {
  body.tax-project-type .wp-block-query > .wp-block-group {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}

/* ==========================================================================
   Grid Titles - Unified styling across all grid pages
   (People, Project Categories, Project Category Archives, News)
   ========================================================================== */
.terms-grid .term-title,
.project-grid-item .wp-block-post-title,
.project-grid-item.wp-block-post-title,
.employee-card .wp-block-post-title,
.employee-card h5.wp-block-post-title.has-large-font-size,
.news-grid-title {
  font-family: Carlito, Calibri, sans-serif !important;
  font-size: 1.2rem !important;
  font-weight: 400 !important;
  color: #ffffff !important;
  text-transform: uppercase !important;
}

/* ==========================================================================
   Project Titles - Afacad font for non-grid contexts
   ========================================================================== */
.project-title,
article .entry-title,
.type-project .entry-title,
.project-type .entry-title {
  font-family: Afacad, sans-serif;
  text-transform: uppercase;
}

/* ==========================================================================
   Project Pages - White menu text with subtle dark shadow for readability
   ========================================================================== */
body.single-project .wp-block-navigation a,
body.single-project .wp-block-navigation .wp-block-navigation-item__content,
body.single-project .wp-block-navigation .wp-block-navigation-item a {
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5) !important;
}

/* White hamburger icon on project pages (before menu opens) */
body.single-project .wp-block-navigation__responsive-container-open,
body.single-project .wp-block-navigation__responsive-container-open svg {
  color: white !important;
  fill: white !important;
}

/* Mobile menu opened on project pages - black text on white background */
body.single-project .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a,
body.single-project .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
  color: #000 !important;
  text-shadow: none !important;
}

body.single-project .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close,
body.single-project .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close svg {
  color: #000 !important;
  fill: #000 !important;
}

/* Remove focus outline from mobile menu icon */
.wp-block-navigation__responsive-container-open:focus,
.wp-block-navigation__responsive-container-open:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

/* Position close button at far right to match hamburger position */
.wp-block-navigation__responsive-container.is-menu-open {
  padding-top: 0 !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close.wp-block-navigation__responsive-container-close.wp-block-navigation__responsive-container-close {
  position: fixed !important;
  top: 35px !important;
  right: 15px !important;
  z-index: 100001 !important;
}

/* ==========================================================================
   Single Project - Title/Description layout
   ========================================================================== */
/* Top-align the columns */
body.single-project .wp-block-columns.alignwide {
  align-items: flex-start !important;
}

/* Left column - 35% width, extra spacing from description */
body.single-project .wp-block-columns.alignwide > .wp-block-column:first-child {
  flex-basis: 35% !important;
  padding-right: 25px !important;
}

/* Right column - 65% width, remove top padding */
body.single-project .wp-block-columns.alignwide > .wp-block-column:last-child {
  flex-basis: 65% !important;
}

/* Remove any top padding/margin from right column content */
body.single-project .wp-block-columns.alignwide > .wp-block-column:last-child > .wp-block-group {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

body.single-project .wp-block-columns.alignwide > .wp-block-column:last-child .wp-block-group {
  margin-top: 0 !important;
  padding-top: 0 !important;
  align-items: flex-start !important;
}

body.single-project .wp-block-columns.alignwide > .wp-block-column:last-child .mfb-field-wrapper {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Larger title */
body.single-project .wp-block-post-title {
  font-size: 1.8rem !important;
  font-weight: 700 !important;
  margin-bottom: 0.5rem !important;
}

/* Larger subtitle/location */
body.single-project .mfb-field-wrapper[data-field-name="wpcf-project-location"] {
  font-size: 1.2rem !important;
}

/* Under 1000px: remove margins to match photo blocks */
@media (max-width: 1000px) {
  body.single-project .wp-block-columns.alignwide {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

/* Under 800px: stack layout with centered title/subtitle, edge-to-edge text */
@media (max-width: 800px) {
  /* Remove padding from parent alignwide group */
  body.single-project .wp-block-group.alignwide {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  body.single-project .wp-block-columns.alignwide {
    flex-direction: column !important;
  }

  body.single-project .wp-block-columns.alignwide > .wp-block-column:first-child,
  body.single-project .wp-block-columns.alignwide > .wp-block-column:last-child {
    flex-basis: 100% !important;
    width: 100% !important;
  }

  /* Center the title and subtitle - override has-text-align-right */
  body.single-project .wp-block-columns.alignwide > .wp-block-column:first-child {
    text-align: center !important;
    margin-bottom: 1rem !important;
  }

  body.single-project .wp-block-post-title.has-text-align-right,
  body.single-project .wp-block-mfb-meta-field-block.has-text-align-right {
    text-align: center !important;
  }

  /* Text block stretches to edges - override inline padding on column and all nested elements */
  body.single-project .wp-block-columns.alignwide > .wp-block-column:last-child,
  body.single-project .wp-block-columns.alignwide > .wp-block-column:last-child .wp-block-group,
  body.single-project .wp-block-columns.alignwide > .wp-block-column:last-child .wp-block-mfb-meta-field-block {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

/* Image+Text row typography */
.image-text-content p,
.text-only-row p {
  font-size: 1.2rem !important;
}

/* Project description typography - match image/text rows */
body.single-project .wp-block-mfb-meta-field-block .value,
body.single-project .wp-block-mfb-meta-field-block .value p {
  font-size: 1.2rem !important;
}

@media (max-width: 1000px) {
  .image-text-content p,
  .text-only-row p,
  body.single-project .wp-block-mfb-meta-field-block .value,
  body.single-project .wp-block-mfb-meta-field-block .value p {
    font-size: 1rem !important;
  }
}

/* ==========================================================================
   Project Image Rows - Safari fix: give images intrinsic size hint
   ========================================================================== */
.row-images-container .row-image img {
  width: 100%;
  height: auto;
}

/* ==========================================================================
   Light Header Image - Dark menu text for projects with light featured images
   ========================================================================== */
body.light-header-image .wp-block-navigation a,
body.light-header-image .wp-block-navigation .wp-block-navigation-item__content,
body.light-header-image .wp-block-navigation .wp-block-navigation-item a {
  color: #333333 !important;
  text-shadow: 0 1px 3px rgba(255, 255, 255, 0.7) !important;
}

body.light-header-image .wp-block-site-title a {
  color: #333333 !important;
}

/* Dark submenu caret on light header images */
body.light-header-image .wp-block-navigation__submenu-icon {
  color: #333333 !important;
}
body.light-header-image .wp-block-navigation__submenu-icon svg {
  stroke: #333333 !important;
}

/* Black logo on light header images */
body.light-header-image .wp-block-site-logo img.custom-logo,
body.light-header-image .custom-logo-link img.custom-logo,
body.light-header-image img.custom-logo {
  filter: brightness(0) drop-shadow(0 1px 3px rgba(255, 255, 255, 0.7)) !important;
}

/* ==========================================================================
   SKDA Page Template - Responsive text columns
   ========================================================================== */

/* White background for SKDA pages (override the grey base) */
.skda-page-template {
  background-color: #ffffff;
}

/* SKDA Page Template container for container queries */
.skda-page-template {
  container-type: inline-size;
}

/* Responsive text columns: 2 columns above 1000px container width, 1 column below */
.responsive-text-columns {
  column-count: 1;
  column-gap: 25px;
  padding-left: 25px;
  padding-right: 25px;
}

/* Remove top margin from first element in content area */
.responsive-text-columns > *:first-child {
  margin-top: 0 !important;
}

@container (min-width: 1000px) {
  .responsive-text-columns {
    column-count: 2;
  }

  /* Prevent headings from being orphaned at bottom of column */
  .responsive-text-columns h1,
  .responsive-text-columns h2,
  .responsive-text-columns h3,
  .responsive-text-columns h4 {
    break-after: avoid;
  }

  /* Keep paragraphs together when possible */
  .responsive-text-columns p {
    break-inside: avoid;
  }
}

/* Full-width images span both columns, stay within margins */
.responsive-text-columns .wp-block-image.alignfull,
.responsive-text-columns .wp-block-gallery.alignfull,
.responsive-text-columns .alignfull,
.responsive-text-columns .wp-block-image.alignwide,
.responsive-text-columns .wp-block-gallery.alignwide,
.responsive-text-columns .alignwide {
  column-span: all;
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}

/* Full-width images/galleries span both columns with consistent spacing */
.responsive-text-columns .wp-block-image,
.responsive-text-columns .wp-block-gallery,
.responsive-text-columns .wp-block-columns,
.responsive-text-columns figure {
  column-span: all;
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
  margin-bottom: 1.5em;
}

/* First element at top should have no top margin */
.responsive-text-columns > *:first-child {
  margin-top: 0 !important;
}

/* All paragraphs have consistent margins - no special treatment after images */
.responsive-text-columns p {
  margin-top: 0;
  margin-bottom: 1em;
}

/* Responsive padding for SKDA page template - match other pages */
@media (max-width: 768px) {
  .responsive-text-columns {
    padding-left: var(--wp--preset--spacing--10) !important;
    padding-right: var(--wp--preset--spacing--10) !important;
  }
}

@media (max-width: 600px) {
  .responsive-text-columns {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}

/* ==========================================================================
   News Page Template
   ========================================================================== */

.news-page-template {
  background-color: #ffffff;
}

/* Remove all border-radius in news template */
.news-page-template .wp-block-post-featured-image,
.news-page-template .wp-block-post-featured-image img,
.news-page-template figure,
.news-page-template figure img {
  border-radius: 0 !important;
}

/* ----- Hero Section ----- */
.news-hero-query {
  margin: 0;
  padding: 0;
}

.news-hero-template {
  display: block;
}

.news-hero-item {
  display: flex;
  flex-direction: row;
  height: 500px;
  margin: 40px 25px 0 25px;
  overflow: hidden;
}

.news-hero-item > * {
  flex: 0 0 50%;
  height: 100%;
  min-height: 500px;
  max-height: 500px;
}

/* Hero Left - Image with title overlay */
.news-hero-left {
  position: relative;
  width: 50%;
  height: 500px !important;
  overflow: hidden;
  padding: 0 !important;
  margin: 0 !important;
}

.news-hero-left .news-hero-image {
  width: 100%;
  height: 100%;
  margin: 0;
  border-radius: 0 !important;
}

.news-hero-left .news-hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 !important;
}

.news-hero-title,
.news-hero-title.wp-block-post-title {
  margin: 0 0 20px 0 !important;
  font-family: Carlito, Calibri, sans-serif !important;
  font-size: 1.75rem !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: #333333 !important;
}

.news-hero-title a {
  color: #333333;
  text-decoration: none;
}

.news-hero-title a:hover {
  text-decoration: underline;
}

/* Hero Right - Content area */
.news-hero-right {
  width: 50%;
  height: 500px !important;
  padding: 40px;
  display: flex;
  flex-direction: column;
  background-color: #f5f5f5;
  box-sizing: border-box;
  margin: 0 !important;
  overflow: hidden;
}

.news-hero-content-wrapper {
  flex: 1;
  overflow: hidden;
  margin: 0 !important;
  padding: 0 !important;
  position: relative;
}

/* Fade out effect at bottom of content */
.news-hero-content-wrapper::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 60px;
  background: linear-gradient(to bottom, rgba(245, 245, 245, 0) 0%, rgba(245, 245, 245, 1) 100%);
  pointer-events: none;
}

.news-hero-content {
  font-size: 20px;
  line-height: 1.6;
  color: #333;
  margin: 0;
}

.news-hero-content p {
  margin: 0 0 1em 0;
}

/* Hide images, videos, embeds - only show text */
.news-hero-content img,
.news-hero-content figure,
.news-hero-content .wp-block-image,
.news-hero-content .wp-block-video,
.news-hero-content .wp-block-embed,
.news-hero-content iframe {
  display: none !important;
}

.news-hero-link {
  display: inline-block;
  margin-top: 30px;
  padding: 10px 0;
  font-size: 16px;
  font-weight: 600;
  color: #333;
  text-decoration: none;
  flex-shrink: 0;
}

.news-hero-link:hover {
  text-decoration: underline;
}

/* Hero responsive - stack on narrow screens */
@media (max-width: 800px) {
  .news-hero-item {
    flex-direction: column;
    height: auto;
  }

  .news-hero-left,
  .news-hero-right {
    width: 100%;
  }

  .news-hero-left {
    height: 350px;
  }

  .news-hero-right {
    padding: 30px;
  }
}

/* ----- Grid Section ----- */
.news-grid-query {
  margin: 0.75rem 25px 25px 25px;
}

.news-grid-template {
  gap: 0.75rem;
}

.news-grid-item {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background-color: #333;
  border-radius: 0 !important;
}

.news-grid-item .news-grid-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  z-index: 1;
  border-radius: 0 !important;
}

.news-grid-item .news-grid-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease, filter 0.3s ease;
  border-radius: 0 !important;
}

/* Dark overlay for better title readability */
.news-grid-item::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.1) 50%, rgba(0,0,0,0) 100%);
  z-index: 2;
  pointer-events: none;
  transition: background 0.3s ease;
}

.news-grid-title {
  position: absolute;
  bottom: 20px;
  left: 20px;
  right: 20px;
  margin: 0;
  font-weight: 600;
  line-height: 1.3;
  z-index: 3;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
  /* font-family, font-size, color set in unified Grid Titles section */
}

.news-grid-title a {
  color: #ffffff;
  text-decoration: none;
}

/* Hover effect - subtle darkening and zoom */
.news-grid-item:hover .news-grid-image img {
  transform: scale(1.05);
  filter: brightness(0.8);
}

.news-grid-item:hover::after {
  background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.3) 50%, rgba(0,0,0,0.1) 100%);
}

/* Grid responsive - fewer columns on narrow screens */
@media (max-width: 1200px) {
  .news-grid-template {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

@media (max-width: 800px) {
  .news-grid-template {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 500px) {
  .news-grid-template {
    grid-template-columns: 1fr !important;
  }
}

/* ==========================================================================
   Connect Page Template
   ========================================================================== */

/* Remove any site-level padding on connect page */
.page-template-page-connect .wp-site-blocks {
  padding: 0 !important;
  margin: 0 !important;
}

.page-template-page-connect .wp-block-group {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.page-template-page-connect header.wp-block-template-part {
  position: relative;
  z-index: 100;
  width: 100%;
}

.connect-page-template {
  position: relative;
  width: 100%;
  min-height: 100vh;
  margin: 0 !important;
  overflow-x: hidden;
}

/* Featured image as full-screen background - fixed to viewport */
.connect-page-template .connect-background-image {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 1;
  margin: 0 !important;
}

.connect-page-template .connect-background-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 !important;
}

/* Content overlay - no background darkening */
.connect-overlay {
  position: relative !important;
  width: 100% !important;
  max-width: 2000px;
  margin: 0 auto;
  z-index: 2;
  min-height: 100vh;
  background: transparent;
  padding-top: 40px;
  padding-bottom: 60px;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

/* White menu text for connect page */
.page-template-page-connect .wp-block-navigation a,
.page-template-page-connect .wp-block-site-title a {
  color: white !important;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

/* White hamburger menu icon on connect page */
.page-template-page-connect .wp-block-navigation__responsive-container-open,
.page-template-page-connect .wp-block-navigation__responsive-container-open svg {
  color: white !important;
  fill: white !important;
}

/* Mobile menu opened on connect page - black text on white background */
.page-template-page-connect .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a,
.page-template-page-connect .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
  color: #000 !important;
  text-shadow: none !important;
}

.page-template-page-connect .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close,
.page-template-page-connect .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close svg {
  color: #000 !important;
  fill: #000 !important;
}

/* Post content area in connect page */
.connect-content-area,
.connect-content-area.wp-block-post-content,
.connect-content-area.is-layout-flow {
  width: 100%;
  padding-top: var(--wp--preset--spacing--20);
  padding-right: max(1rem, var(--wp--preset--spacing--20));
  padding-bottom: var(--wp--preset--spacing--20);
  padding-left: max(1rem, var(--wp--preset--spacing--20));
}

/* 3-column grid layout */
.connect-grid,
.connect-grid.is-layout-flow,
.connect-grid.wp-block-group-is-layout-flow {
  display: grid !important;
  grid-template-columns: auto auto auto !important;
  gap: 90px !important;
  justify-content: start !important;
}

/* Remove WordPress default padding and gap from connect boxes */
.connect-box.has-global-padding,
.connect-box.is-layout-constrained {
  padding: 0 !important;
  --wp--style--block-gap: 4px !important;
}

.connect-box.is-layout-constrained > * + * {
  margin-top: 4px !important;
}

/* 2 columns on medium screens */
@media (max-width: 900px) {
  .connect-grid,
  .connect-grid.is-layout-flow,
  .connect-grid.wp-block-group-is-layout-flow {
    grid-template-columns: auto auto !important;
    gap: 30px !important;
    justify-content: start !important;
  }
}

/* 1 column on small screens */
@media (max-width: 600px) {
  .connect-grid,
  .connect-grid.is-layout-flow,
  .connect-grid.wp-block-group-is-layout-flow {
    grid-template-columns: 1fr !important;
    gap: 25px !important;
  }
}


.connect-box {
  min-width: 0;
}

/* Box titles */
.connect-box-title {
  font-size: 1.5rem;
  text-transform: uppercase;
  margin-bottom: 0.75rem !important;
  font-weight: 500;
  color: #ffffff !important;
  text-align: left !important;
}

/* Left align all text in boxes */
.connect-box,
.connect-box p,
.connect-box h3,
.connect-box h4,
.connect-box a {
  text-align: left !important;
}

/* White text styling */
.connect-overlay,
.connect-overlay p,
.connect-overlay h1,
.connect-overlay h2,
.connect-overlay h3,
.connect-overlay h4,
.connect-overlay a {
  color: #ffffff !important;
}

.connect-box p,
.connect-box li,
.connect-box h4 {
  margin: 0 0 4px 0 !important;
  padding: 0 !important;
  line-height: 1.4;
}

.connect-box a {
  text-decoration: none;
  transition: opacity 0.2s ease;
}

.connect-box a:hover {
  color: #d87715 !important;
  text-decoration: none;
}

/* Jobs list styling - match other links */
.connect-jobs-query {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.connect-jobs-query .wp-block-post-template,
.connect-jobs-query ul.wp-block-post-template.is-layout-flow {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  --wp--style--block-gap: 4px !important;
}

.connect-jobs-query .wp-block-post-template li,
.connect-jobs-query .wp-block-post-template li.wp-block-post {
  margin: 0 0 4px 0 !important;
  padding: 0 !important;
}

.connect-jobs-query .wp-block-query-no-results {
  margin: 0 !important;
  padding: 0 !important;
}

.connect-jobs-query .wp-block-query-no-results p {
  margin: 0 !important;
}

.connect-openings .connect-jobs-query {
  margin-top: 0 !important;
}

.connect-openings .connect-jobs-query > * {
  margin-top: 0 !important;
}

.connect-job-link {
  font-size: inherit;
  font-weight: normal;
  font-family: inherit;
  margin: 0 !important;
  text-transform: none;
  letter-spacing: normal;
}

.connect-job-link a {
  color: #ffffff !important;
  text-decoration: none;
  font-weight: normal;
  transition: opacity 0.2s ease;
}

.connect-job-link a:hover {
  color: #d87715 !important;
  text-decoration: none;
}

.connect-no-jobs {
  opacity: 0.9;
  margin-top: 0 !important;
}

/* Subheadings in connect boxes */
.connect-subhead {
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  text-transform: uppercase;
  margin-top: 1.5rem !important;
  margin-bottom: 0.25rem !important;
  color: #ffffff !important;
}

.connect-box .connect-subhead:first-of-type {
  margin-top: 0 !important;
}

/* Paragraphs after subheads need less top margin */
.connect-box .connect-subhead + p {
  margin-top: 0 !important;
}

/* Sections within connect boxes - spacing between grouped items */
.page-template-page-connect .connect-section.wp-block-group {
  margin-bottom: 1.5rem !important;
}

.page-template-page-connect .connect-positions.wp-block-group {
  margin-bottom: 2rem !important;
}

/* Social links inline */
.connect-social-links {
  margin-top: 1.5rem !important;
}

.connect-social-links a {
  margin-right: 1.5rem;
  text-transform: uppercase;
}

/* Newsletter link */
.connect-newsletter-link {
  margin-top: 1rem !important;
}

.connect-newsletter-link a {
  text-transform: uppercase;
  font-weight: 500;
}

/* Newsletter Popup Modal */
.newsletter-modal-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  z-index: 100000;
  justify-content: center;
  align-items: center;
}

.newsletter-modal-overlay.active {
  display: flex;
}

.newsletter-modal {
  background: #ffffff;
  padding: 40px;
  max-width: 500px;
  width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

.newsletter-modal-close {
  position: absolute;
  top: 15px;
  right: 15px;
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: #333;
  line-height: 1;
  padding: 5px;
}

.newsletter-modal-close:hover {
  color: #000;
}

.newsletter-modal h2 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  color: #333;
  font-size: 1.5rem;
}

.newsletter-modal .newsletter-subtitle {
  margin-top: 0;
  margin-bottom: 1.5rem;
  color: #666;
  font-size: 0.95rem;
}

.newsletter-modal label {
  display: block;
  margin-bottom: 0.4rem;
  color: #333;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.newsletter-modal label .asterisk {
  color: #d87715;
}

.newsletter-modal input[type="email"],
.newsletter-modal input[type="text"],
.newsletter-modal select {
  width: 100%;
  padding: 12px;
  border: 1px solid #ccc;
  font-size: 1rem;
  font-family: inherit;
  box-sizing: border-box;
  transition: border-color 0.2s ease;
}

.newsletter-modal input[type="email"]:focus,
.newsletter-modal input[type="text"]:focus,
.newsletter-modal select:focus {
  outline: none;
  border-color: #d87715;
}

.newsletter-modal select {
  appearance: none;
  background: #fff url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 8L1 3h10z'/%3E%3C/svg%3E") no-repeat right 12px center;
  padding-right: 36px;
}

.newsletter-modal .mc-field-group {
  margin-bottom: 1.25rem;
}

.newsletter-modal .mc-field-row {
  display: flex;
  gap: 1rem;
}

.newsletter-modal .mc-field-half {
  flex: 1;
}

.newsletter-modal button[type="submit"] {
  background: #333;
  color: #fff;
  border: none;
  padding: 14px 32px;
  cursor: pointer;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  width: 100%;
  margin-top: 0.5rem;
  transition: background-color 0.2s ease;
}

.newsletter-modal button[type="submit"]:hover {
  background: #d87715;
}

/* Mobile - reduce padding */
@media (max-width: 750px) {
  .connect-overlay,
  .connect-overlay.is-layout-constrained {
    padding-top: 120px;
    padding-bottom: 40px;
  }
}

/* ==========================================================================
   Job Posts - Hide date and author byline
   ========================================================================== */
/* Hide the date/byline row on job posts - target only within template-part */
body.single-job .wp-block-template-part .wp-block-post-date,
body.single-job .wp-block-template-part .wp-block-group.is-content-justification-left {
  display: none !important;
}

/* ==========================================================================
   Testimonials Page
   ========================================================================== */

.testimonials-page-template {
  background-color: #ffffff;
}

/* Remove constrained layout, add consistent padding */
.testimonials-page-template .entry-content.wp-block-post-content {
  max-width: 100% !important;
  padding-right: var(--wp--preset--spacing--20);
  padding-bottom: var(--wp--preset--spacing--20);
  padding-left: var(--wp--preset--spacing--20);
}

/* Breadcrumb spacing on testimonials page */
.testimonials-page-template .entry-content .breadcrumbs.wp-block-bcn-breadcrumb-trail {
  margin-top: 30px !important;
  margin-bottom: 10px !important;
}

/* Hide the default page title - we'll use breadcrumb */
.testimonials-page-template .wp-block-post-title {
  display: none !important;
}

/* Testimonials grid container */
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
  max-width: 2000px;
}

/* Featured image - spans 2x2 grid area */
.testimonial-featured-image {
  grid-column: span 2;
  grid-row: span 2;
  aspect-ratio: 1 / 1;
  overflow: hidden;
}

.testimonial-featured-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Individual testimonial card */
.testimonial-card {
  background: #f5f5f5;
  padding: 25px;
  display: flex;
  flex-direction: column;
  aspect-ratio: 1 / 1;
  overflow: hidden;
}

/* Card header - static at top */
.testimonial-header {
  flex-shrink: 0;
}

.testimonial-header h3 {
  font-family: Carlito, Calibri, sans-serif !important;
  font-size: 1.25rem !important;
  font-weight: 600 !important;
  color: #333333 !important;
  text-transform: uppercase !important;
  margin: 0 0 0.75rem 0 !important;
  padding: 0 !important;
}

/* Card body - scrollable testimonial text */
.testimonial-body {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
  padding-right: 8px;
  margin-right: -8px;
}

/* Custom scrollbar for testimonial body */
.testimonial-body::-webkit-scrollbar {
  width: 4px;
}

.testimonial-body::-webkit-scrollbar-track {
  background: transparent;
}

.testimonial-body::-webkit-scrollbar-thumb {
  background: #ccc;
  border-radius: 2px;
}

.testimonial-body::-webkit-scrollbar-thumb:hover {
  background: #999;
}

.testimonial-body p {
  font-family: Carlito, Calibri, sans-serif;
  color: #4a4a4a;
  font-size: 1.05rem;
  line-height: 1.55;
  margin: 0 0 0.75rem 0 !important;
  padding: 0 !important;
}

.testimonial-body p:last-child {
  margin-bottom: 0 !important;
}

/* Card footer - static at bottom */
.testimonial-footer {
  flex-shrink: 0;
  margin-top: 0.75rem;
}

.testimonial-footer p {
  font-family: Carlito, Calibri, sans-serif;
  color: #4a4a4a;
  font-size: 0.95rem;
  line-height: 1.4;
  margin: 0 !important;
  padding: 0 !important;
}

/* Testimonial author (em tag) */
.testimonial-footer em {
  display: block;
  font-family: Carlito, Calibri, sans-serif;
  color: #d87715;
  font-style: normal;
  font-weight: 500;
  font-size: 1rem;
}

/* Responsive - 3 columns */
@media (max-width: 1200px) {
  .testimonials-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Responsive - 2 columns */
@media (max-width: 800px) {
  .testimonials-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* On 2 columns, featured image still spans 2x2 (full width for 2 rows) */
  .testimonial-featured-image {
    grid-column: span 2;
    grid-row: span 2;
  }
}

/* Responsive - 1 column */
@media (max-width: 500px) {
  .testimonials-grid {
    grid-template-columns: 1fr;
  }

  /* On 1 column, featured image only spans 1 column but stays tall */
  .testimonial-featured-image {
    grid-column: span 1;
    grid-row: span 2;
  }
}

