/*
Theme Name: A² Media
Theme URI: https://a2media.example.com
Author: Tom Bonge
Description: Modern agency theme for A² Media. Created by Tom Bonge.
Version: 1.0
Tags: dark, modern, elegant, gallery, team, ticker
*/

:root {
  /* Fonts */
  --font-heading: 'Montserrat', Arial, sans-serif;
  --font-body: 'Lato', Arial, sans-serif;

  /* Colors */
  --color-text: #e7e7ea;
  --color-text-muted: #d0d0d0;
  --color-text-subtle: #888;
  --color-white: #fff;
  --color-placeholder-text: #444;

  --color-bg: #19191d;
  --color-bg-section: #1f1f24;
  --color-bg-header-footer: #18181b;
  --color-bg-element: #23232b; /* Used for inputs, ticker, team/client tiles */
  --color-bg-button-hover: #111116;
  --color-button-grad-start: #2b2b32;
  --color-button-grad-end: #23232b;

  --color-border: #23232b; /* Default border, hr, header/footer */
  --color-border-focus: #44445a;
  --color-border-light: #222; /* Press release item */
  --color-border-medium: #333; /* Team/Client image */

  --color-accent: #7fc7ff;

  /* Radii */
  --radius-sm: 2px;
  --radius-md: 6px;
  --radius-lg: 8px;
  --radius-xl: 12px; /* Used for sections, team/client tiles (consolidated 13px) */
  --radius-round: 50%;

  /* Spacing (Examples - add more as needed) */
  --spacing-base: 1rem;
  --spacing-sm: 0.5rem;
  --spacing-md: 1.5rem;
  --spacing-lg: 2rem;
  --spacing-xl: 2.5rem;
  --spacing-xxl: 3rem; /* 48px */

  /* Gradients */
  --gradient-accent: linear-gradient(90deg, var(--color-accent) 0%, var(--color-white) 100%);
  --gradient-button: linear-gradient(90deg, var(--color-button-grad-start) 0, var(--color-button-grad-end) 100%);
}

/* --- Base Styles --- */
body, html {
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-bg);
  font-size: 1.07rem; /* Base font size */
  line-height: 1.3;
  -webkit-font-smoothing: antialiased;
  margin: 0;
  padding: 0;
}

.site-content {
  padding-left: 2.8vw; /* Keep vw for responsive scaling */
  padding-right: 2.8vw;
}
@media (max-width: 700px) {
  .site-content {
    padding-left: 18px; /* Consider var(--spacing-md) or similar */
    padding-right: 18px;
  }
}

/* --- Typography --- */
h1, h2, h3, h4, h5, h6,
.elementor-heading-title,
.wp-block-heading {
  font-family: var(--font-heading);
  font-weight: 400; /* Base weight, overridden below */
  line-height: 1.2;
  color: var(--color-white);
  margin-top: 0; /* Add default margin reset */
  margin-bottom: var(--spacing-base);
}

/* Specific Heading Sizes/Weights */
h1, .elementor-heading-title.elementor-size-xxl { font-size: 2.7rem; font-weight: 500; }
h2, .elementor-heading-title.elementor-size-xl { font-size: 2.1rem; font-weight: 400; }
h3, .elementor-heading-title.elementor-size-lg { font-size: 1.55rem; font-weight: 400; }
h4, .elementor-heading-title.elementor-size-md { font-size: 1.2rem; }
h5, .elementor-heading-title.elementor-size-sm { font-size: 1.07rem; }
h6, .elementor-heading-title.elementor-size-xs { font-size: 0.97rem; }

/* Title Styles with Underlines */
.team-title,
.page-title,
.prfirm-press-release-archive .archive-header h1 {
  font-family: var(--font-heading);
  color: var(--color-white);
  display: inline-block;
  text-align: center;
  letter-spacing: 0.01em;
  line-height: 1.13;
  position: relative;
}

.team-title {
  font-weight: 400;
  font-size: 2rem;
  margin-bottom: 2.1rem;
  margin-top: 0.8rem;
}
.page-title {
  font-weight: 200;
  font-size: 2.3rem;
  margin-bottom: 1.1rem;
  text-shadow: 0 2px 18px rgba(0,0,0,0.16);
}
.prfirm-press-release-archive .archive-header h1 {
    font-size: 2.2em;
}

.team-title::after,
.page-title::after,
.prfirm-press-release-archive .archive-header h1::after {
  content: '';
  display: block;
  width: 90%;
  margin: 14px auto 0 auto;
  border-radius: var(--radius-sm);
  background: var(--gradient-accent);
}
.team-title::after {
  max-width: 8em;
  height: 3px;
}
.page-title::after {
  max-width: 8.5em;
  height: 4px;
  margin-top: 12px;
}
.prfirm-press-release-archive .archive-header h1::after {
    max-width: 8em;
    height: 3px;
}

.page-title-wrapper {
  text-align: center;
}

/* Elementor and WP text widgets */
p, li, .elementor-widget-text-editor, .wp-block-paragraph {
  font-family: var(--font-body);
  color: var(--color-text);
  font-size: 1.07rem;
  line-height: 1.3;
  margin-top: 0;
  margin-bottom: var(--spacing-base);
}
li {
  margin-bottom: var(--spacing-sm);
}

/* --- Links --- */
a {
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.16s;
}
a:hover, a:focus {
  color: var(--color-white);
  text-decoration: underline;
}

/* --- Layout & Sections --- */
section, .wp-block-group, .elementor-section, .elementor-widget-container {
  background: var(--color-bg-section);
  border-radius: var(--radius-xl);
  box-shadow: 0 2px 16px 0 rgba(0,0,0,0.12);
  margin-bottom: var(--spacing-lg);
  padding: 2.2rem 2vw; /* Keep vw for responsive padding */
}

/* Ensure equal top and bottom padding for hooked-in page sections on front page */
.above-team-section,
.below-team-section {
  padding-top: 2.2rem !important;
  padding-bottom: 2.2rem !important;
}

/* Card-like containers for widgets/blocks */
.wp-block-cover, .elementor-widget-container, .wp-block-group {
  border-radius: var(--radius-xl);
  box-shadow: 0 2px 16px 0 rgba(0,0,0,0.12);
}

/* Prevent double bottom padding for hooked-in page blocks */
.block-one-section > *:last-child,
.block-two-section > *:last-child,
.block-three-section > *:last-child {
  margin-bottom: 0 !important;
}

/* Prevent double card effect for team section inside block sections */
.block-one-section .team-section,
.block-two-section .team-section,
.block-three-section .team-section {
  background: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important; /* Also remove padding */
  margin-bottom: 0 !important; /* And margin */
}

/* --- Forms & Buttons --- */
button, .wp-block-button__link, .elementor-button {
  font-family: var(--font-heading);
  font-weight: 500;
  background: var(--gradient-button);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-md);
  padding: 0.7em 2.1em;
  font-size: 1.02rem;
  letter-spacing: 0.04em;
  cursor: pointer;
  box-shadow: 0 1px 8px 0 rgba(0,0,0,0.13);
  transition: background 0.18s, color 0.18s, box-shadow 0.18s;
  text-decoration: none; /* Ensure no underline */
  display: inline-block; /* Ensure proper padding */
}
button:hover, .wp-block-button__link:hover, .elementor-button:hover,
button:focus, .wp-block-button__link:focus, .elementor-button:focus {
  background: var(--color-bg-button-hover);
  color: var(--color-white);
  box-shadow: 0 2px 16px 0 rgba(0,0,0,0.19);
  text-decoration: none; /* Ensure no underline */
  outline: 2px solid var(--color-accent); /* Added focus style */
  outline-offset: 2px;
}

input, textarea, select {
  font-family: var(--font-body);
  background: var(--color-bg-element);
  color: var(--color-text);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 0.6em 1em;
  font-size: var(--spacing-base);
  transition: border 0.17s;
  width: 100%; /* Make inputs generally full-width */
  box-sizing: border-box; /* Include padding/border in width */
}
input:focus, textarea:focus, select:focus {
  border-color: var(--color-border-focus);
  outline: none;
}

/* --- HR Divider --- */
hr {
  border: none;
  border-top: 1.5px solid var(--color-border);
  margin: var(--spacing-xl) 0;
}

/* --- Header --- */
.site-header {
  background: var(--color-bg-header-footer);
  border-bottom: 1.5px solid var(--color-border);
  z-index: 10;
  width: 100%;
  padding: var(--spacing-sm) 0; /* Add some default vertical padding */
  /* Flexbox alignment likely handled in header.php */
}
.sticky-header {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  box-shadow: 0 2px 16px 0 rgba(0,0,0,0.13);
  background: var(--color-bg-header-footer); /* Ensure bg matches */
}
.site-header-logo,
.site-header-menu {
  display: flex;
  align-items: center;
}
.site-logo-img {
  display: block;
  height: auto;
  margin: 0 auto; /* Centering if needed */
  border-radius: var(--radius-lg);
}
@media (max-width: 900px) {
  .site-header {
    flex-direction: column;
    padding: var(--spacing-sm) 0 var(--spacing-base) 0;
  }
  .site-header-logo,
  .site-header-menu {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100%;
    justify-content: center;
    margin-bottom: var(--spacing-sm); /* Add space between logo and menu */
  }
  .site-header-menu {
     margin-bottom: 0;
  }
}

/* --- Main Menu --- */
.main-menu,
.main-menu ul,
.main-menu li,
.main-menu li ul {
  all: unset; /* Reset WP styles */
  display: revert; /* Use browser defaults before applying flex */
}
.main-menu {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center; /* Center menu items */
  margin: 0;
  padding: 0;
  list-style: none;
  background: none;
  border: none;
  gap: 0; /* Gap applied via margin on li */
  flex-wrap: wrap; /* Allow wrapping on smaller screens if needed */
}
.main-menu > li {
  display: flex;
  align-items: center;
  margin: 0 var(--spacing-md); /* Use variable for spacing */
  padding: 0;
  background: none;
  position: relative;
}
.main-menu > li > a {
  font-family: var(--font-heading);
  color: var(--color-white);
  font-weight: 400;
  font-size: 1.07rem;
  text-transform: capitalize;
  letter-spacing: 0.08em;
  background: none;
  text-decoration: none;
  border: none;
  border-radius: 0;
  display: block;
  padding: var(--spacing-sm) 0; /* Use variable */
  transition: color 0.18s cubic-bezier(.4,0,.2,1);
  position: relative;
}
.main-menu > li > a:visited,
.main-menu > li > a:active {
  color: var(--color-white);
  background: none;
  outline: none; /* Remove default outline */
}
.main-menu > li > a:focus {
  color: var(--color-white);
  background: none;
  outline: 2px solid var(--color-accent); /* Added visible focus style */
  outline-offset: 2px;
  text-decoration: none; /* Ensure no underline on focus */
}
.main-menu > li > a::after {
  content: '';
  display: block;
  height: 2px;
  width: 0%;
  background: var(--color-white);
  border-radius: var(--radius-sm);
  transition: width 0.28s cubic-bezier(.4,0,.2,1);
  margin-top: 5px;
}
.main-menu > li > a:hover::after,
.main-menu > li.current-menu-item > a::after {
  width: 100%;
  background: var(--color-white);
}
.main-menu > li > a:hover,
.main-menu > li.current-menu-item > a {
  color: var(--color-white);
  background: none;
  outline: none; /* Remove focus outline on hover/current */
}
.main-menu ul { /* Hide sub-menus */
  display: none;
}
@media (max-width: 900px) {
  .main-menu {
    flex-direction: column;
    align-items: center;
    gap: 0;
  }
  .main-menu > li {
    margin: 0.1rem 0; /* Reduce vertical margin */
  }
}

/* --- Footer --- */
.site-footer {
  background: var(--color-bg-header-footer);
  color: var(--color-text);
  font-family: var(--font-body);
  padding: var(--spacing-lg) 0 var(--spacing-md) 0; /* Use variables */
  border-top: 2px solid var(--color-border);
  margin-top: var(--spacing-xxl); /* Use variable */
  text-align: center;
}
.site-footer .footer-main {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-sm); /* Use variable */
}
.site-footer .footer-links {
  margin-bottom: var(--spacing-sm);
}
.site-footer .footer-link {
  font-family: var(--font-heading);
  color: var(--color-white);
  margin: 0 0.8em; /* Adjust spacing */
  font-size: 1.07rem;
  text-decoration: none;
  transition: color 0.18s;
  letter-spacing: 0.01em;
  display: inline-block; /* Ensure spacing works */
  margin-bottom: var(--spacing-sm); /* Add bottom margin for wrapping */
}
.site-footer .footer-link:last-child {
  margin-right: 0.8em; /* Keep consistent spacing */
}
.site-footer .footer-link:hover,
.site-footer .footer-link:focus {
  color: var(--color-accent);
  text-decoration: underline;
  outline: none; /* Remove default focus outline if underline is sufficient */
}
.site-footer .footer-contact {
  color: var(--color-text);
  font-size: var(--spacing-base);
  margin-bottom: var(--spacing-sm);
}
.site-footer .footer-social {
  margin: var(--spacing-sm) 0 0 0;
}
.site-footer .footer-social-link {
  display: inline-block;
  margin: 0 0.5em;
  vertical-align: middle;
  color: var(--color-white);
  transition: color 0.18s, transform 0.18s;
}
.site-footer .footer-social-link:hover,
.site-footer .footer-social-link:focus {
  color: var(--color-accent);
  transform: scale(1.14);
  outline: none; /* Remove default focus outline */
}
.site-footer .footer-social-link svg {
  vertical-align: middle;
  fill: currentColor;
  width: 24px; /* Add explicit size */
  height: 24px; /* Add explicit size */
}
.site-footer .footer-separator {
  display: inline-block;
  vertical-align: middle;
  margin: 0 0.7em;
  color: var(--color-white);
  font-size: 1.1em;
  opacity: 0.7;
}
.site-footer .footer-copyright {
  margin-top: var(--spacing-md);
  color: var(--color-text-subtle);
  font-size: 0.98rem;
}
@media (max-width: 700px) {
  .site-footer .footer-main {
    gap: var(--spacing-sm);
  }
  .site-footer .footer-link {
    margin: 0 0.5em var(--spacing-sm) 0.5em; /* Adjust spacing for mobile */
    font-size: 0.99rem;
  }
  .site-footer .footer-contact {
    font-size: 0.95rem;
  }
}

/* --- Gallery --- */
.main-gallery {
  margin: var(--spacing-xl) auto var(--spacing-lg) auto;
  max-width: 100%;
  padding: 0 15px;
  position: relative;
}

.swiper-container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
}

.swiper-wrapper {
  display: flex;
  width: 100%;
  height: auto;
  box-sizing: border-box;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: auto;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg-element);
}

.swiper-slide img {
  width: 100%;
  height: auto;
  max-height: 600px;
  object-fit: contain;
  display: block;
}

/* Navigation buttons */
.swiper-button-next,
.swiper-button-prev {
  color: var(--color-white);
  background: rgba(0, 0, 0, 0.3);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  transition: background-color 0.3s, transform 0.2s;
}

.swiper-button-next:after,
.swiper-button-prev:after {
  font-size: 24px;
  font-weight: bold;
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
  background: rgba(0, 0, 0, 0.6);
  transform: scale(1.1);
}

/* Pagination */
.swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background: var(--color-white);
  opacity: 0.5;
  margin: 0 5px !important;
  transition: all 0.3s;
}

.swiper-pagination-bullet-active {
  background: var(--color-accent);
  opacity: 1;
  transform: scale(1.2);
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .swiper-container {
    border-radius: var(--radius-lg);
  }
  
  .swiper-button-next,
  .swiper-button-prev {
    width: 36px;
    height: 36px;
  }
  
  .swiper-button-next:after,
  .swiper-button-prev:after {
    font-size: 20px;
  }
  
  .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
  }
}

/* Fallback for no images */
.swiper-slide[style*="background:#f5f5f5"] {
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-height: 300px;
  color: var(--color-text-muted);
  font-family: var(--font-body);
  padding: var(--spacing-lg);
  text-align: center;
}

/* --- Ticker --- */
.ticker {
  background: var(--color-bg-element);
  color: var(--color-text-muted); /* Use muted text color */
  font-size: 1.2rem;
  padding: var(--spacing-sm) 0; /* Use variable */
  overflow: hidden;
  white-space: nowrap;
  border-radius: var(--radius-md);
  margin: 0 auto var(--spacing-xl) auto; /* Use variables */
  max-width: 700px; /* Consider variable */
}
.ticker-text {
  display: inline-block;
  padding-left: 100%;
  animation: ticker-scroll 18s linear infinite;
}
@keyframes ticker-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}

/* --- Team Section --- */
.team-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: var(--spacing-xl) auto var(--spacing-xxl) auto; /* Use variables */
  max-width: 900px; /* Consider variable */
}
.team-members {
  display: flex;
  flex-direction: row;
  justify-content: center;
  gap: var(--spacing-xl); /* Use variable */
  max-width: 900px; /* Match section width */
  margin: 0 auto;
  flex-wrap: wrap; /* Allow wrapping */
}
.team-member {
  background: var(--color-bg-element);
  border-radius: var(--radius-xl);
  padding: var(--spacing-lg) var(--spacing-md) var(--spacing-base) var(--spacing-md); /* Use variables */
  text-align: center;
  color: var(--color-text-muted);
  box-shadow: 0 4px 24px rgba(0,0,0,0.3);
  width: 240px; /* Consider flex-basis or min/max width */
  margin-bottom: var(--spacing-lg); /* Add margin for wrapped items */
}
.team-member img {
  border-radius: var(--radius-round);
  width: 110px; /* Consider variable */
  height: 110px; /* Consider variable */
  object-fit: cover;
  margin: 0 auto var(--spacing-md) auto; /* Center image */
  border: 3px solid var(--color-border-medium);
  display: block; /* Ensure margin auto works */
}
.team-member h3 {
  margin: var(--spacing-sm) 0 var(--spacing-sm) 0;
  font-size: 1.1rem;
  color: var(--color-white);
  font-family: var(--font-heading);
}
.team-member p {
  font-size: 0.96rem;
  color: var(--color-text-muted);
  font-family: var(--font-body);
  margin-bottom: 0; /* Remove default p margin */
}
@media (max-width: 900px) {
  .team-members {
     gap: var(--spacing-lg); /* Adjust gap */
  }
  .team-member {
    width: calc(50% - var(--spacing-lg)); /* Example for 2 columns */
  }
}
@media (max-width: 600px) {
  .team-member {
    width: calc(100% - var(--spacing-lg)); /* Example for 1 column */
  }
}

/* --- Press Release Archive / List --- */
.prfirm-press-release-archive {
    color: var(--color-text-muted);
    font-family: var(--font-body);
}
.prfirm-press-release-archive .archive-header {
    text-align: center;
    margin-bottom: var(--spacing-lg);
}
/* Archive header h1 styles merged above */

.prfirm-press-release-list {
    max-width: 900px; /* Consider variable */
    margin: 0 auto;
    padding: 0;
    list-style: none; /* Remove list bullets */
}
.prfirm-press-release-archive-item {
    border-bottom: 1px solid var(--color-border-light);
    padding: var(--spacing-md) 0; /* Adjust padding */
    display: flex;
    gap: var(--spacing-md);
    align-items: flex-start;
    flex-wrap: wrap;
}
.prfirm-press-release-archive-item:last-child {
    border-bottom: none; /* Remove border on last item */
}
.prfirm-press-release-thumb {
    flex: 0 0 120px; /* Consider variable */
    max-width: 120px; /* Prevent shrinking */
}
.prfirm-press-release-thumb img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: var(--radius-sm);
}
.prfirm-press-release-summary {
    flex: 1 1 0;
    min-width: 200px; /* Allow wrapping */
}
.prfirm-press-release-title { /* This is the h3 */
    font-family: var(--font-heading);
    font-weight: 400;
    font-size: 1.2rem;
    margin: 0 0 var(--spacing-sm) 0;
    color: var(--color-white); /* Ensure color */
}
.prfirm-press-release-title a {
  font-family: var(--font-heading); /* Inherit? */
  font-weight: 600;
  font-size: 1.15rem; /* This seems redundant if h3 is 1.2rem */
  color: var(--color-white);
  margin: 0; /* Remove margin */
  /* Inherits global link styles */
}
.prfirm-press-release-meta {
    font-family: var(--font-body);
    font-size: 0.96rem;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-sm);
}
.prfirm-press-release-excerpt {
  font-size: 0.97rem;
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-weight: 300;
  margin-top: 0;
  margin-bottom: 0; /* Remove default p margin */
  line-height: 1.3;
}
.prfirm-press-release-pagination {
    margin: var(--spacing-lg) 0;
    text-align: center;
}

/* --- Clients Page --- */
.clients-page .clients-title {
  font-family: var(--font-heading);
  font-size: 2.2rem;
  font-weight: 500;
  color: var(--color-white);
  text-align: center;
  margin: var(--spacing-xl) 0 var(--spacing-xl) 0; /* Use variables */
  letter-spacing: 0.01em;
}
.clients-grid-wrapper {
  max-width: 1200px; /* Consider variable */
  margin: 0 auto;
  padding: 0 2vw; /* Keep vw */
}
.clients-section {
  padding: var(--spacing-xxl) var(--spacing-lg);
  margin: 0 auto;
  max-width: 100%;
  box-sizing: border-box;
}

.clients-section .page-title-wrapper {
  margin-bottom: var(--spacing-lg);
}

.clients-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: var(--spacing-lg);
  margin: 0 auto;
  padding: var(--spacing-md) 0;
}
a.client-tile {
  background: var(--color-bg-element);
  border-radius: var(--radius-xl);
  box-shadow: 0 4px 24px rgba(0,0,0,0.16);
  padding: var(--spacing-xl);
  text-align: center;
  transition: box-shadow 0.18s, transform 0.18s;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  height: 100%;
  box-sizing: border-box;
}

a.client-tile:hover,
a.client-tile:focus {
  box-shadow: 0 8px 32px rgba(0,0,0,0.22);
  transform: scale(1.027);
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  text-decoration: none; /* Ensure no underline on hover */
}

/* Ensure headings inside the link don't have default link styles */
a.client-tile .client-name,
a.client-tile .client-desc {
  color: inherit;
  text-decoration: none;
}

/* Remove any default link styling from the client name */
a.client-tile .client-name:hover,
a.client-tile .client-name:focus {
  text-decoration: none;
}

/* Make sure the entire tile is clickable */
a.client-tile,
a.client-tile * {
  position: relative;
  z-index: 1;
}
.client-image {
  width: 100%;
  padding: var(--spacing-sm);
  box-sizing: border-box;
  margin: 0 auto var(--spacing-base) auto;
  display: flex;
  align-items: center;
  justify-content: center;
}

.client-logo,
.client-image-placeholder {
  width: 100%;
  max-width: 350px; /* Increased from 300px */
  height: auto;
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  border: 3px solid var(--color-border-medium);
  display: block;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  padding: 8px; /* Reduced from 15px */
  box-sizing: border-box;
  margin: 0 auto;
  transition: all 0.3s ease;
}

/* Medium screens */
@media (min-width: 768px) {
  .client-logo,
  .client-image-placeholder {
    max-width: 450px; /* Increased from 400px */
    padding: 10px; /* Reduced from 20px */
  }
}

/* Large screens */
@media (min-width: 1024px) {
  .client-logo,
  .client-image-placeholder {
    max-width: 550px; /* Increased from 500px */
    padding: 12px; /* Reduced from 25px */
  }
}

/* Ensure the client image container can accommodate the larger images */
.client-image {
  width: 100%;
  padding: var(--spacing-sm); /* Reduced from md */
  box-sizing: border-box;
  margin: 0 auto var(--spacing-sm) auto; /* Reduced bottom margin */
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
}

.client-image-placeholder {
  background: var(--color-bg-element) url('data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\' width=\'150\' height=\'150\'><rect fill=\'#23232b\' width=\'150\' height=\'150\'/><text x=\'50%\' y=\'50%\' font-size=\'18\' fill=\'#444\' text-anchor=\'middle\' alignment-baseline=\'middle\'>No Image</text></svg>') center center no-repeat;
  background-size: contain;
  aspect-ratio: 1 / 1;
}

/* Press Release Single Page Styles */
.press-release-single-card {
  background: var(--color-bg-element);
  border-radius: var(--radius-xl);
  box-shadow: 0 4px 24px rgba(0,0,0,0.16);
  padding: var(--spacing-xl);
  margin: var(--spacing-xl) auto;
  max-width: 1200px;
  transition: box-shadow 0.18s, transform 0.18s;
}

.press-release-single-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}

.press-release-single-image {
  text-align: center;
  margin: 0 auto;
  width: 100%;
  max-width: 500px;
}

.press-release-single-featured {
  width: 100%;
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  border: 3px solid var(--color-border-medium);
  padding: 25px;
  box-sizing: border-box;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.press-release-single-info {
  text-align: left;
}

.press-release-single-header {
  margin-bottom: var(--spacing-lg);
}

.press-release-single-title {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 0 0 var(--spacing-sm) 0;
  line-height: 1.2;
}

.press-release-single-subtitle {
  font-size: 1.5rem;
  color: var(--color-text-light);
  margin-bottom: var(--spacing-md);
  line-height: 1.4;
}

.press-release-single-meta {
  color: var(--color-text-muted);
  font-size: 1rem;
  margin-top: var(--spacing-sm);
}

.press-release-single-content-inner {
  line-height: 1.7;
  font-size: 1.1rem;
  color: var(--color-text);
}

.press-release-pdf-download {
  margin-top: var(--spacing-lg);
}

.press-release-pdf-download .button {
  display: inline-block;
  background: var(--color-accent);
  color: var(--color-white);
  padding: 0.8em 1.6em;
  border-radius: var(--radius-md);
  text-decoration: none;
  font-weight: 600;
  transition: all 0.2s ease;
}

.press-release-pdf-download .button:hover {
  background: var(--color-accent-dark);
  transform: translateY(-2px);
}

.press-release-related {
  margin-top: var(--spacing-xxl);
  padding-top: var(--spacing-xl);
  border-top: 1px solid var(--color-border-light);
}

.related-press-releases {
  list-style: none;
  padding: 0;
  margin: var(--spacing-md) 0 0 0;
}

.related-press-release {
  margin-bottom: var(--spacing-sm);
  padding: 0;
}

.related-press-release a {
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.2s ease;
}

.related-press-release a:hover {
  color: var(--color-accent-light);
  text-decoration: underline;
}

/* Responsive adjustments */
@media (min-width: 768px) {
  .press-release-single-content {
    flex-direction: row;
    align-items: flex-start;
  }
  
  .press-release-single-image {
    flex: 0 0 400px;
    margin: 0;
  }
  
  .press-release-single-info {
    flex: 1;
    padding-left: var(--spacing-xl);
  }
}

@media (min-width: 1024px) {
  .press-release-single-image {
    flex: 0 0 500px;
  }
}

/* Single Client Page Styles */
.client-single-card {
  background: var(--color-bg-element);
  border-radius: var(--radius-xl);
  box-shadow: 0 4px 24px rgba(0,0,0,0.16);
  padding: var(--spacing-xl);
  margin: var(--spacing-xl) auto;
  max-width: 1200px;
  transition: box-shadow 0.18s, transform 0.18s;
}

.client-single-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}

.client-single-image {
  text-align: center;
  margin: 0 auto;
  width: 100%;
  max-width: 500px;
}

.client-single-logo {
  width: 100%;
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  border: 3px solid var(--color-border-medium);
  padding: 25px;
  box-sizing: border-box;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.client-single-info {
  text-align: center;
}

.client-single-header {
  margin-bottom: var(--spacing-lg);
}

.client-single-title {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 0 0 var(--spacing-sm) 0;
  line-height: 1.2;
}

.client-single-excerpt {
  font-size: 1.25rem;
  color: var(--color-text-light);
  margin-bottom: var(--spacing-md);
  line-height: 1.5;
}

.client-single-description {
  text-align: left;
  line-height: 1.7;
  font-size: 1.1rem;
  color: var(--color-text);
}

.client-single-description p:first-child {
  margin-top: 0;
}

.client-single-description p:last-child {
  margin-bottom: 0;
}

/* Responsive adjustments */
@media (min-width: 768px) {
  .client-single-content {
    flex-direction: row;
    align-items: flex-start;
    text-align: left;
  }
  
  .client-single-image {
    flex: 0 0 400px;
    margin: 0;
  }
  
  .client-single-info {
    flex: 1;
    text-align: left;
    padding-left: var(--spacing-xl);
  }
}

@media (min-width: 1024px) {
  .client-single-image {
    flex: 0 0 500px;
  }
}
.client-info {
  margin-top: var(--spacing-sm);
}
.client-name { /* This is the h3 */
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1.15rem;
  color: var(--color-white);
  margin: 0 0 var(--spacing-sm) 0;
}
.client-desc { /* This is the excerpt/paragraph */
  font-size: 0.97rem;
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-weight: 300;
  margin: 0;
  line-height: 1.3;
}
/* Arrow Navigation */
.client-navigation-wrapper,
.press-release-navigation-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.nav-arrow {
  position: absolute;
  top: 0;
  height: 100%;
  width: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  opacity: 0.7;
  transition: all 0.3s ease;
  z-index: 10;
}

.nav-arrow:hover {
  opacity: 1;
  color: var(--color-accent);
  transform: scale(1.1);
}

.nav-arrow--prev {
  left: -80px;
  right: auto;
}

.nav-arrow--next {
  right: -80px;
  left: auto;
}

.nav-arrow svg {
  width: 24px;
  height: 40px;
}

/* Adjust container padding to make room for arrows */
.container {
  position: relative;
  padding: 0 60px;
}

/* Hide arrows on mobile */
@media (max-width: 1024px) {
  .nav-arrow {
    display: none;
  }
  
  .container {
    padding: 0 20px;
  }
}

/* Post Navigation */
.post-navigation {
  display: flex;
  justify-content: space-between;
  margin: var(--spacing-xxl) 0 0;
  padding: var(--spacing-lg) 0;
  border-top: 1px solid var(--color-border-light);
}

.post-navigation__link {
  display: flex;
  align-items: center;
  text-decoration: none;
  color: var(--color-text);
  transition: all 0.2s ease;
  font-family: var(--font-heading);
  font-weight: 500;
  padding: var(--spacing-sm) 0;
  position: relative;
}

.post-navigation__link:hover {
  color: var(--color-accent);
}

.post-navigation__link::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.3s ease;
}

.post-navigation__link:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

.post-navigation__link--prev {
  padding-left: 2rem;
  text-align: left;
}

.post-navigation__link--next {
  padding-right: 2rem;
  text-align: right;
  margin-left: auto;
}

.post-navigation__arrow {
  font-size: 1.25rem;
  line-height: 1;
  transition: transform 0.2s ease;
  display: inline-block;
}

.post-navigation__link--prev .post-navigation__arrow {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

.post-navigation__link--next .post-navigation__arrow {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}

.post-navigation__link--prev:hover .post-navigation__arrow {
  transform: translateX(-4px) translateY(-50%);
}

.post-navigation__link--next:hover .post-navigation__arrow {
  transform: translateX(4px) translateY(-50%);
}

.post-navigation__content {
  display: inline-block;
  position: relative;
}

.post-navigation__label {
  display: block;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.25rem;
}

.post-navigation__title {
  font-size: 0.95rem;
  font-weight: 500;
  display: inline;
  line-height: 1.4;
}

/* Specific styles for client navigation */
.post-navigation--client {
  margin-top: var(--spacing-xxl);
}

/* Specific styles for press release navigation */
.post-navigation--press-release {
  margin-top: var(--spacing-xxl);
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .post-navigation {
    flex-direction: column;
    gap: var(--spacing-md);
  }
  
  .post-navigation__link--prev,
  .post-navigation__link--next {
    padding: 0.5rem 0;
  }
}

/* Press Release Archive Styles */
.press-releases-archive {
  padding: var(--spacing-xl) 0;
  max-width: var(--content-width);
  margin: 0 auto;
  padding: var(--spacing-xl) var(--spacing-lg);
}

.press-releases-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-xl);
  margin: 0;
  max-width: 100%;
}

.press-release-card {
  background: var(--color-bg-element);
  border-radius: var(--radius-lg);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  transition: all 0.25s ease;
  overflow: hidden;
  border: 1px solid var(--color-border-light);
  padding: 0;
  height: 100%;
  display: flex;
}

.press-release-card-link {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: inherit;
  padding: var(--spacing-lg);
  box-sizing: border-box;
}

.press-release-card:hover .press-release-card-link {
  text-decoration: none;
}

.press-release-card-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}

.press-release-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.press-release-image {
  width: 100%;
  max-width: 200px;
  background: var(--color-bg);
  padding: var(--spacing-sm);
  border: 3px solid var(--color-border-medium);
  border-radius: var(--radius-sm);
  box-sizing: border-box;
  flex-shrink: 0;
  margin: 0;
}

.press-release-thumbnail {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  transition: transform 0.3s ease;
}

.press-release-card:hover .press-release-thumbnail {
  transform: scale(1.03);
}

.press-release-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 0;
}

.press-release-meta {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--color-text-muted);
  margin-bottom: var(--spacing-sm);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.press-release-location {
  color: var(--color-text-muted);
}

.press-release-title {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 600;
  margin: 0 0 var(--spacing-sm) 0;
  line-height: 1.3;
  color: var(--color-white);
}

.press-release-title {
  color: var(--color-white);
  transition: color 0.2s ease;
}

.press-release-card:hover .press-release-title {
  color: var(--color-accent);
}

.press-release-excerpt {
  color: var(--color-text-muted);
  margin: 0 0 var(--spacing-md) 0;
  font-family: var(--font-body);
  font-size: 0.97rem;
  font-weight: 300;
  line-height: 1.3;
}

.press-release-excerpt p {
  margin: 0 0 1em 0;
  color: var(--color-text-muted);
}

.press-release-excerpt p:last-child {
  margin-bottom: 0;
}

.press-release-read-more {
  color: var(--color-accent);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.95rem;
  display: inline-flex;
  align-items: center;
  width: fit-content;
  text-decoration: none;
  transition: all 0.2s ease;
  margin-top: auto;
}

.press-release-read-more::after {
  content: '→';
  margin-left: 0.5em;
  transition: transform 0.2s ease;
}

.press-release-card:hover .press-release-read-more {
  color: var(--color-accent-dark);
}

.press-release-card:hover .press-release-read-more::after {
  transform: translateX(4px);
}

/* Desktop styles */
@media (min-width: 768px) {
  .press-releases-archive {
    padding: var(--spacing-xxl) var(--spacing-xl);
  }
  
  .press-release-card-inner {
    flex-direction: row;
    align-items: flex-start;
    gap: var(--spacing-xl);
  }
  
  .press-release-image {
    margin-top: 0.25em; /* Align with first line of text */
  }
  
  .press-release-content {
    padding-top: 0;
  }
}

/* Pagination */
.press-releases-pagination {
  margin-top: var(--spacing-xxl);
  text-align: center;
}

.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin: 0 4px;
  border-radius: var(--radius-md);
  background: var(--color-bg-element);
  color: var(--color-text);
  text-decoration: none;
  font-weight: 600;
  transition: all 0.2s ease;
}

.pagination .page-numbers.current,
.pagination .page-numbers:hover {
  background: var(--color-accent);
  color: white;
}

.pagination .page-numbers.prev,
.pagination .page-numbers.next {
  width: auto;
  padding: 0 var(--spacing-md);
}

@media (max-width: 700px) {
  .clients-grid {
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); /* Adjust min size */
    gap: var(--spacing-md); /* Adjust gap */
  }
  .client-tile {
    padding: var(--spacing-md) var(--spacing-sm) var(--spacing-base) var(--spacing-sm); /* Adjust padding */
  }
  .client-image {
    padding: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
  }
  /* Image aspect ratio already handled */
}
/* --- End Clients Page Styles --- */
