/*
Theme Name: HGRE Theme
Theme URI: https://hgrealestate.com/
Author: Heather Groom
Author URI: https://hgrealestate.com/
Description: Custom WordPress theme for Heather Groom Real Estate, inspired by Annie Cannon's site.
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hgre-theme
Tags: real estate, luxury, responsive
*/

/* @import rules must be at the top of the stylesheet */
@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@300;400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Arapey:ital@0;1&family=Karla:ital,wght@0,200;0,300;0,400;1,200;1,300&family=Manrope:wght@200;300;400;500&display=swap');

/* HGRE Brand Color Palette */
:root {
  --primary-bg: #fff;
  --light-gray: #D3DBDD;     /* HGRE Brand Light Gray */
  --off-white: #F4F4F5;      /* HGRE Brand Very Light Gray/Off-White */
  --dark-gray: #231F20;      /* HGRE Brand Dark Gray/Near-Black */
  --border-gray: #e0e0e0;
  --button-hover: #1a1a1a;   /* Darker version of dark gray for hover */
  --hero-overlay: rgba(35, 31, 32, 0.7);
  --text-shadow: 0 2px 4px rgba(35, 31, 32, 0.3);
  --box-shadow: 0 4px 16px rgba(35, 31, 32, 0.08);
  --box-shadow-hover: 0 8px 32px rgba(35, 31, 32, 0.12);
  --gray-gradient: linear-gradient(135deg, #231F20 0%, #434343 100%);
  
  /* Spacing System - 12px Unit Base */
  --space-unit: 12px;
  --space-xs: 12px;    /* 1 unit */
  --space-sm: 24px;    /* 2 units */
  --space-md: 48px;    /* 4 units */
  --space-lg: 80px;    /* 6.666 units */
  --space-xl: 120px;   /* 10 units */
  --space-xxl: 160px;  /* 13.333 units */
  
  /* Primary Color for Accents */
  --primary-color: #231F20; /* Dark gray for accents */
}

body {
  background: var(--primary-bg);
  color: var(--dark-gray);
  font-family: 'Raleway', Arial, sans-serif;
  margin: 0;
  padding: 0;
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

/* Enhanced Header - Transparent Overlay Style */
.site-header {
  background: var(--primary-bg);
  border-bottom: 1px solid var(--border-gray);
  padding: 1.5rem 0 1rem 0;
  text-align: center;
  position: relative;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

/* Transparent Header Overlay (Adam Hammodat Style) */
.transparent-header {
  position: fixed; /* Changed from absolute to fixed for scroll behavior */
  top: 0;
  left: 0;
  right: 0;
  background: #ffffff; /* Solid white background matching Adam's style */
  border-bottom: 1px solid var(--border-gray);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
  z-index: 1000;
  padding: 1.5rem 0;
  transition: transform 0.3s ease-in-out; /* Smooth hide/show animation */
}

/* Header Scroll Behavior - Hide/Show on Scroll */
.site-header.header-visible {
  transform: translateY(0);
}

.site-header.header-hidden {
  transform: translateY(-100%); /* Hide by moving up */
}

.header-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
}

/* Header Navigation Sections */
.header-nav {
  flex: 1;
  display: flex;
  align-items: center;
}

.header-nav-left {
  justify-content: flex-start;
}

.header-nav-right {
  justify-content: flex-end;
}

.header-menu {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: center;
  gap: 2rem;
}

.header-menu li {
  margin: 0;
}

.header-menu a {
  color: #000000; /* Black text matching Adam's style */
  text-decoration: none;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.05em;
  transition: opacity 0.3s ease;
  text-shadow: none; /* No shadow needed on white background */
}

.header-menu a:hover {
  opacity: 0.8;
}

/* Dropdown Menu */
.menu-item-has-children {
  position: relative;
}

.dropdown-arrow {
  font-size: 0.7rem;
  margin-left: 0.3rem;
  display: inline-block;
  transition: transform 0.3s ease;
}

.menu-item-has-children:hover .dropdown-arrow {
  transform: rotate(180deg);
}

.sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  background: #ffffff; /* White background matching Adam's style */
  list-style: none;
  margin: 0;
  padding: 0.5rem 0;
  min-width: 180px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s ease;
  border-radius: 0; /* Sharp corners matching Adam's style */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  border: 1px solid var(--border-gray);
}

.menu-item-has-children:hover .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Prevent general rule from affecting nested level-2 submenus */
.menu-item-nested .sub-menu-level-2 {
  opacity: 0 !important;
  visibility: hidden !important;
  transform: translateX(-10px) !important;
}

.sub-menu li {
  margin: 0;
}

.sub-menu a {
  display: block;
  padding: 0.75rem 1.5rem;
  color: #000000; /* Black text matching Adam's style */
  text-decoration: none;
  font-size: 0.9rem;
  transition: background 0.2s ease;
}

.sub-menu a:hover {
  background: var(--light-gray); /* Light gray hover matching Adam's style */
}

/* Region Headers in Top Areas Menu */
.sub-menu .menu-region-header {
  padding: 0.5rem 1.5rem;
  margin-top: 0.5rem;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.sub-menu .menu-region-header:first-child {
  margin-top: 0;
  border-top: none;
}

.sub-menu .menu-region-header .region-name {
  display: block;
  color: var(--dark-gray);
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 0.25rem 0;
}

/* Option 2: Two-Column Layout */
.sub-menu-two-column {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-width: 360px;
  column-gap: 0;
}

.sub-menu-two-column li {
  grid-column: span 1;
}

.sub-menu-two-column .menu-region-header {
  grid-column: 1 / -1; /* Span both columns */
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  margin-top: 0.5rem;
  padding: 0.5rem 1.5rem;
}

.sub-menu-two-column .menu-region-header:first-child {
  margin-top: 0;
  border-top: none;
}

/* Option 6: Nested Submenus */
.menu-item-nested .sub-menu-nested {
  min-width: 200px;
}

.menu-item-nested .menu-region-item {
  position: relative;
}

.menu-item-nested .menu-region-item > a {
  padding-right: 2rem;
  cursor: pointer;
}

.menu-item-nested .menu-region-item .dropdown-arrow {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.6rem;
  transition: transform 0.3s ease;
  display: inline-block;
}

.menu-item-nested .menu-region-item:hover > .dropdown-arrow {
  transform: translateY(-50%) rotate(90deg);
}

.menu-item-nested .sub-menu-level-2 {
  position: absolute;
  left: 100%;
  top: 0;
  margin-left: 0.5rem;
  min-width: 180px;
  opacity: 0;
  visibility: hidden;
  transform: translateX(-10px);
  transition: all 0.3s ease;
  z-index: 1000;
  background: #ffffff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  border: 1px solid var(--border-gray);
  padding: 0.5rem 0;
}

/* Only show submenu when hovering the specific region item, not the parent */
.menu-item-nested .menu-region-item:hover > .sub-menu-level-2 {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateX(0) !important;
}

.menu-item-nested .sub-menu-level-2 li {
  margin: 0;
}

.menu-item-nested .sub-menu-level-2 a {
  padding: 0.75rem 1.5rem;
  font-size: 0.9rem;
  display: block;
  color: #000000;
  text-decoration: none;
  transition: background 0.2s ease;
}

.menu-item-nested .sub-menu-level-2 a:hover {
  background: var(--light-gray);
}

/* Center Branding */
.header-branding {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 2rem;
}

.branding-link {
  display: block;
  text-decoration: none;
}

.luxury-branding-image {
  max-height: 80px;
  width: auto;
  height: auto;
  display: block;
}

/* Sign In Button */
.header-signin {
  position: absolute;
  top: 1.5rem;
  right: 2rem;
}

.signin-button {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #000000; /* Black text matching Adam's style */
  text-decoration: none;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 14px;
  font-weight: 500;
  padding: 0.5rem 1rem;
  border: 1px solid var(--border-gray);
  border-radius: 0; /* Sharp corners matching Adam's style */
  transition: all 0.3s ease;
  text-shadow: none;
  background: transparent;
}

.signin-button:hover {
  background: var(--light-gray); /* Light gray hover matching Adam's style */
  border-color: #000000;
}

.signin-icon {
  font-size: 1.2rem;
  font-weight: 300;
}

/* Hamburger Menu (Mobile) */
.mobile-menu-toggle {
  display: none;
}

/* Show hamburger on mobile */
@media (max-width: 768px) {
  .mobile-menu-toggle {
    display: block !important;
  }
}

.hamburger-menu {
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  justify-content: center;
}

.hamburger-menu span {
  display: block;
  width: 24px;
  height: 2px;
  background: #000000; /* Black for white header background */
  transition: all 0.3s ease;
}

.hamburger-menu.active span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

.hamburger-menu.active span:nth-child(2) {
  opacity: 0;
}

.hamburger-menu.active span:nth-child(3) {
  transform: rotate(-45deg) translate(7px, -6px);
}

/* Mobile Menu Overlay */
.mobile-menu-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.mobile-menu-overlay.active {
  opacity: 1;
  visibility: visible;
}

/* Mobile Menu Container */
.mobile-menu-container {
  position: fixed;
  top: 0;
  right: -100%;
  width: 80%;
  max-width: 400px;
  height: 100%;
  background: #ffffff;
  z-index: 9999;
  overflow-y: auto;
  transition: right 0.3s ease;
  box-shadow: -2px 0 10px rgba(0, 0, 0, 0.1);
}

.mobile-menu-container.active {
  right: 0 !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.mobile-menu-container .mobile-menu-wrapper {
  padding: 2rem 1.5rem;
}

.mobile-menu-container .header-nav {
  display: block;
  width: 100%;
  margin-bottom: 2rem;
}

.mobile-menu-container .header-nav:last-child {
  margin-bottom: 0;
}

.mobile-menu-container .header-nav-left,
.mobile-menu-container .header-nav-right {
  width: 100%;
}

.mobile-menu-container .header-menu {
  flex-direction: column;
  gap: 0;
  align-items: flex-start;
}

.mobile-menu-container .header-menu li {
  width: 100%;
  border-bottom: 1px solid var(--light-gray);
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.mobile-menu-container .header-menu li:last-child {
  border-bottom: none;
}

.mobile-menu-container .header-menu li.mobile-menu-toggle {
  display: none !important;
}

/* Ensure all menu items from both navs are visible in mobile menu */
.mobile-menu-container .header-nav-left .header-menu li,
.mobile-menu-container .header-nav-right .header-menu li {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  width: 100% !important;
}

.mobile-menu-container .header-menu a {
  display: block;
  padding: 1rem 0;
  color: #000000;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  text-decoration: none;
  width: 100%;
}

.mobile-menu-container .header-menu a:hover {
  color: #333333;
}

.mobile-menu-container .sub-menu {
  position: static;
  opacity: 1;
  visibility: visible;
  transform: none;
  box-shadow: none;
  border: none;
  background: var(--light-gray);
  margin: 0;
  padding: 0.5rem 0;
  display: none;
  width: 100%;
  list-style: none;
}

.mobile-menu-container .menu-item-has-children.sub-menu-open .sub-menu {
  display: block !important;
}

.mobile-menu-container .sub-menu li {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

.mobile-menu-container .sub-menu li:last-child {
  border-bottom: none;
}

.mobile-menu-container .sub-menu a {
  padding: 0.75rem 1.5rem;
  font-size: 14px;
  color: #666666;
  display: block;
  width: 100%;
}

.mobile-menu-container .sub-menu .menu-region-header {
  padding: 0.75rem 1.5rem;
  margin-top: 0.5rem;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  border-bottom: none;
}

.mobile-menu-container .sub-menu .menu-region-header:first-child {
  margin-top: 0;
  border-top: none;
}

.mobile-menu-container .sub-menu .menu-region-header .region-name {
  color: var(--dark-gray);
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.mobile-menu-container .dropdown-arrow {
  float: right;
  transition: transform 0.3s ease;
}

.mobile-menu-container .menu-item-has-children.sub-menu-open .dropdown-arrow {
  transform: rotate(180deg);
}

/* Responsive Design */
@media (max-width: 1024px) {
  .header-container {
    padding: 0 1.5rem;
  }
  
  .header-menu {
    gap: 1.5rem;
  }
  
  .luxury-branding-image {
    max-height: 60px;
  }
}

@media (max-width: 768px) {
  .header-container {
    justify-content: space-between;
  }
  
  .header-nav-left {
    flex: 0 0 auto;
  }
  
  .header-branding {
    flex: 0 0 auto;
    margin: 0 auto;
  }
  
  .header-nav-right {
    flex: 0 0 auto;
    margin-left: auto;
  }
  
  /* Hide ALL menu items on mobile except hamburger */
  .header-nav-left .header-menu li:not(.mobile-menu-toggle),
  .header-nav-right .header-menu li {
    display: none !important;
  }
  
  /* Show only hamburger on mobile */
  .header-nav-left .header-menu li.mobile-menu-toggle {
    display: block !important;
  }
  
  .mobile-menu-toggle {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
    z-index: 10000 !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  
  .hamburger-menu {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
    z-index: 10001 !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    margin: 0 !important;
    padding: 0.5rem !important;
    cursor: pointer !important;
    background: transparent !important;
    border: none !important;
  }
  
  .hamburger-menu span {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    background: #000000 !important;
    width: 24px !important;
    height: 3px !important;
  }
  
  .header-signin {
    position: static;
    margin-left: auto;
  }
  
  .luxury-branding-image {
    max-height: 50px;
  }
  
  .header-menu {
    gap: 1rem;
  }
}

.site-title {
  font-family: 'Raleway', Arial, sans-serif;
  font-size: 2.8rem;
  font-weight: 700;
  color: var(--dark-gray);
  margin: 0;
  letter-spacing: -0.02em;
}

.site-title a {
  color: var(--dark-gray);
  text-decoration: none;
  transition: color 0.3s ease;
}

.site-title a:hover {
  color: var(--button-hover);
}

.site-description {
  color: var(--dark-gray);
  font-size: 1.1rem;
  margin-top: 0.5rem;
  font-weight: 400;
  letter-spacing: 0.02em;
}

/* Enhanced Navigation */
.main-nav {
  margin: 2rem 0 1.5rem 0;
  position: relative;
}

/* Header Search Form */
.header-search {
  margin: 1rem 0;
  display: flex;
  justify-content: center;
}

.header-search form {
  display: flex;
  max-width: 400px;
  width: 100%;
}

.header-search input[type="search"] {
  flex: 1;
  padding: 0.75rem 1rem;
  border: 2px solid var(--light-gray);
  border-radius: 8px 0 0 8px;
  font-size: 1rem;
  outline: none;
  transition: border-color 0.2s;
  font-family: inherit;
}

.header-search input[type="search"]:focus {
  border-color: var(--dark-gray);
}

.header-search input[type="submit"] {
  padding: 0.75rem 1.5rem;
  background: var(--dark-gray);
  color: white;
  border: 2px solid var(--dark-gray);
  border-radius: 0 8px 8px 0;
  cursor: pointer;
  font-weight: 500;
  transition: all 0.2s;
  font-family: inherit;
}

.header-search input[type="submit"]:hover {
  background: var(--button-hover);
  border-color: var(--button-hover);
}

/* Recent Post Cards */
.recent-post-card:hover {
  transform: translateY(-5px);
}

.recent-post-card .post-title a:hover {
  color: var(--button-hover);
}

.main-menu {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  justify-content: center;
  gap: 3rem;
  align-items: center;
}

.main-menu li a {
  color: var(--dark-gray);
  text-decoration: none;
  font-weight: 600;
  font-size: 1.1rem;
  transition: all 0.3s ease;
  position: relative;
  padding: 0.5rem 0;
  letter-spacing: 0.02em;
}

.main-menu li a:hover {
  color: var(--button-hover);
}

.main-menu li a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--dark-gray);
  transition: width 0.3s ease;
}

.main-menu li a:hover::after {
  width: 100%;
}

/* Enhanced Dropdown Menu */
.main-menu li {
  position: relative;
}

.main-menu .sub-menu {
  display: none;
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  background: #fff;
  min-width: 200px;
  box-shadow: var(--box-shadow);
  border-radius: 8px;
  z-index: 1000;
  padding: 1rem 0;
  margin-top: 0.5rem;
  opacity: 0;
  transition: all 0.3s ease;
}

.main-menu li:hover > .sub-menu {
  display: block;
  opacity: 1;
}

.main-menu .sub-menu li {
  display: block;
  padding: 0;
  margin: 0;
}

.main-menu .sub-menu li a {
  display: block;
  padding: 0.75rem 1.5rem;
  color: var(--dark-gray);
  font-weight: 500;
  font-size: 1rem;
  white-space: nowrap;
  border-radius: 0;
}

.main-menu .sub-menu li a:hover {
  background: var(--light-gray);
  color: var(--button-hover);
}

.main-menu .sub-menu li a::after {
  display: none;
}

/* Hero Section - Full Viewport with Rotating Background */
.hero-section {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 600px;
  max-height: 100vh;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
}

/* Ensure hero fills viewport on all screen sizes */
@media (max-height: 600px) {
  .hero-section {
    min-height: 100vh;
  }
}

/* Background Media Container */
.hero-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.hero-media-container {
  position: relative;
  width: 100%;
  height: 100%;
}

.hero-media-item {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  z-index: 1;
}

.hero-media-item.active {
  opacity: 1;
  z-index: 2;
}

.hero-media-item video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}

/* Dark Overlay for Text Readability */
.hero-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  z-index: 2;
}

/* Hero Content - Matching Adam Hammodat exactly */
.hero-content {
  position: relative;
  z-index: 3;
  max-width: 1440px;
  width: 100%;
  padding: var(--space-md-c, 2rem) var(--space-xl-a, 3rem);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  height: 100%;
  gap: 8%;
}

.hero-content .copy-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs-c, 0.5rem);
}

.hero-title {
  font-family: 'Arapey', 'Georgia', serif;
  font-size: 48px;
  font-weight: 700;
  letter-spacing: 8px;
  line-height: 44px;
  text-transform: uppercase;
  color: #ffffff;
  margin: 0;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}

.hero-tagline {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 23px;
  font-weight: 700;
  color: #ffffff;
  margin: 0 0 2rem 0; /* Added bottom margin */
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
}

/* Action Tabs - Left aligned like Adam */
.hero-action-tabs {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  gap: 0;
  margin-bottom: var(--space-sm-b, 1rem);
  border: none;
}

.action-tab {
  background: transparent;
  border: none;
  border-radius: 0;
  color: rgba(255, 255, 255, 0.7);
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.8px;
  line-height: 18px;
  padding: var(--space-xs-a, 0.5rem);
  padding-right: var(--space-md-a, 1.5rem);
  cursor: pointer;
  transition: all 0.3s ease;
  text-transform: uppercase;
  position: relative;
  white-space: nowrap;
  z-index: 1;
  overflow: hidden;
}

.action-tab::before,
.action-tab::after {
  content: '';
  position: absolute;
  left: 0;
  width: 100%;
  height: 80%;
  top: -80%;
  transition: all 0.3s ease 0s;
  z-index: -1;
}

.action-tab::after {
  background-color: #ffffff;
  bottom: -4px;
  clip-path: none;
  height: 1px;
  top: auto;
}

.action-tab:hover,
.action-tab:focus,
.action-tab:active {
  color: #ffffff !important;
}

.action-tab.active {
  color: #ffffff;
}

.action-tab.active::before,
.action-tab:hover::before {
  top: 0;
}

.action-tab.active::after,
.action-tab:hover::after {
  bottom: 0;
}

/* Hero Search - Left aligned like Adam */
.hero-search {
  margin-bottom: 20px;
  width: 60%;
}

.hero-search-form {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 20px;
  width: 100%;
  background-color: #ffffff;
  padding: 20px;
  justify-content: space-between;
}

.hero-search-input {
  flex: 1;
  width: 100%;
  padding: 0;
  border: none;
  outline: none;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.8px;
  line-height: 24px;
  color: #666666;
  background: transparent;
}

.hero-search-input::placeholder {
  color: #666666;
}

.hero-search-button {
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-search-button svg {
  width: 20px;
  height: 20px;
  color: #666666;
}

.hero-search-button:hover svg {
  color: #000000;
}

/* Explore Link */
.hero-explore-link {
  color: #ffffff;
  text-decoration: none;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.8px;
  line-height: 20px;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
  transition: opacity 0.3s ease;
}

.hero-explore-link:hover {
  opacity: 0.8;
}

/* Enhanced Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 2rem;
  background: var(--dark-gray);
  color: white;
  text-decoration: none;
  border-radius: 50px;
  font-weight: 600;
  font-size: 1rem;
  transition: all 0.3s ease;
  border: 2px solid var(--dark-gray);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  min-height: 44px;
  min-width: 44px;
  -webkit-tap-highlight-color: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.btn:hover {
  background: var(--button-hover);
  border-color: var(--button-hover);
  transform: translateY(-2px);
  box-shadow: var(--box-shadow-hover);
}

.btn-outline {
  background: transparent;
  color: white;
  border-color: white;
}

.btn-outline:hover {
  background: white;
  color: var(--dark-gray);
}

.btn-gold {
  background: var(--gray-gradient);
  border: 2px solid var(--dark-gray);
  color: white;
  font-weight: 700;
}

.btn-gold:hover {
  background: var(--dark-gray);
  border-color: var(--dark-gray);
  transform: translateY(-2px);
  box-shadow: var(--box-shadow-hover);
}

/* About Section - Matching Adam Hammodat Spacing Design Exactly */
.about-section {
  max-width: 100%;
  position: relative;
  background: #ffffff;
  margin: 0; /* No margins - sections flow naturally */
  padding: 0; /* No section-level padding - padding is on content-wrapper */
}

.about-section .container {
  gap: calc(11.666 * 12px); /* var(--space-xxl-a) = 140px */
  margin: 0 auto;
  max-width: 1440px !important; /* Override base container max-width */
  padding: calc(13.333 * 12px) calc(10 * 12px) !important; /* var(--space-xxl-b) var(--space-xl-c) = 160px 120px - override container default padding */
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.about-row-wrap {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: calc(11.666 * 12px); /* var(--space-xxl-a) = 140px */
}

.about-img-wrapper {
  flex: 1 1;
  max-width: 400px; /* 20% smaller than 500px (500 * 0.8 = 400) */
  overflow: hidden;
  position: relative;
  height: auto; /* Let height be determined by image natural aspect ratio */
}

.about-agent-photo {
  height: auto; /* Match Adam's - maintain natural aspect ratio */
  width: 100%;
  object-fit: cover;
  object-position: 50% 50%;
  display: block;
}

.about-copy-wrapper {
  flex: 1 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: calc(2.0 * 12px); /* var(--space-sm-c) = 24px for vertical-spacing */
}

.about-subheading {
  color: #000000;
  font-family: 'Manrope', Arial, sans-serif;
  font-size: 18px;
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 3.5px; /* var(--tertiary-letter-spacing) */
  line-height: 24px; /* var(--tertiary-line-height) */
  text-transform: uppercase;
  margin: 0;
}

.about-agent-name {
  font-family: 'Arapey', 'Georgia', serif; /* var(--secondary-font-family) */
  font-size: 36px; /* Default h2 size */
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 1.44px; /* var(--secondary-letter-spacing) */
  line-height: 40px; /* var(--secondary-line-height) */
  color: #000000;
  margin: 0;
}

.about-bio {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 15px; /* Default p size */
  font-weight: 300; /* var(--regular) = 300 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
  color: #000000;
  margin: 0;
}

.btn-about-learn-more {
  display: inline-block;
  background: #808080; /* var(--link-color) */
  color: #ffffff !important;
  text-decoration: none;
  border-radius: 0; /* No rounded corners! */
  border: none;
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 16px;
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 0.8px;
  line-height: 22px; /* var(--primary-line-height) */
  padding: 12px 30px;
  position: relative;
  text-transform: capitalize; /* Not uppercase! */
  transition: ease-out 0.8s;
  overflow: hidden;
  box-shadow: inset 0 0 0 0 #666666; /* var(--link-hover-color) */
  margin-top: 0;
}

.btn-about-learn-more:hover {
  background: #ffffff !important;
  color: #ffffff !important;
  box-shadow: inset 400px 0 0 0 #666666; /* slide-right effect */
}

/* Responsive About Section */
@media (min-width: 1200px) {
  .about-agent-name {
    font-size: 38px; /* Larger on desktop */
  }
  
  .about-bio {
    font-size: 16px; /* Larger on desktop */
  }
}

@media (max-width: 1200px) {
  .about-section .container {
    align-items: flex-start;
    gap: calc(8.333 * 12px); /* var(--space-xl-b) = 100px */
    justify-content: flex-start;
    padding: calc(13.333 * 12px) calc(6.666 * 12px) !important; /* var(--space-xxl-b) var(--space-xl-a) = 160px 80px */
  }
  
  .about-row-wrap {
    gap: calc(8.333 * 12px); /* var(--space-xl-b) = 100px */
  }
  
  .about-img-wrapper {
    justify-content: flex-start;
  }
  
  .about-img-wrapper .about-agent-photo {
    max-width: 320px; /* 20% smaller than 400px (400 * 0.8 = 320) for tablet */
  }
  
  .about-copy-wrapper {
    max-width: 450px;
    align-items: flex-start;
  }
}

@media (max-width: 768px) {
  .about-section .container {
    padding: calc(8.0 * 12px) calc(2.5 * 12px) !important; /* Reduced padding for mobile */
    gap: calc(3.0 * 12px) !important; /* Smaller gap for mobile */
  }
  
  .about-row-wrap {
    flex-direction: column !important; /* Stack vertically on mobile */
    gap: calc(3.0 * 12px) !important;
    align-items: center !important;
  }
  
  .about-img-wrapper {
    max-width: 100% !important;
    width: 100%;
  }
  
  .about-img-wrapper .about-agent-photo {
    max-width: 100% !important;
    width: 100%;
  }
  
  .about-copy-wrapper {
    max-width: 100% !important;
    width: 100%;
    align-items: center !important;
    text-align: center !important;
  }
  
  .about-subheading {
    text-align: center;
  }
  
  .about-agent-name {
    text-align: center;
    font-size: 28px !important;
    line-height: 32px !important;
  }
  
  .about-bio {
    text-align: center;
    font-size: 14px !important;
    line-height: 20px !important;
  }
}

@media (max-width: 428px) {
  .about-section .container {
    padding: calc(6.0 * 12px) calc(1.5 * 12px) !important; /* Even smaller padding for very small screens */
    gap: calc(2.5 * 12px) !important;
  }
  
  .about-row-wrap {
    gap: calc(2.5 * 12px) !important;
  }
  
  .about-agent-name {
    font-size: 24px !important;
    line-height: 28px !important;
  }
  
  .about-bio {
    font-size: 13px !important;
    line-height: 18px !important;
  }
}

/* About Page Styles - Matching New Design System */
.about-hero-section {
  background: linear-gradient(135deg, var(--dark-gray) 0%, var(--button-hover) 100%) !important;
  color: white !important;
  text-align: center !important;
  padding: 6rem 0 4rem 0 !important; /* Reduced padding for better proportions */
  margin: 0 !important;
  margin-top: 80px !important; /* Account for fixed header */
}

.about-hero-title {
  color: white !important;
  font-family: 'Arapey', 'Georgia', serif !important;
  font-size: 48px !important;
  font-weight: 400 !important;
  letter-spacing: 1.44px !important;
  line-height: 1.2 !important;
  margin-bottom: 1.5rem !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2) !important;
}

.about-hero-subtitle {
  color: white !important;
  opacity: 0.95 !important;
  max-width: 700px !important;
  margin: 0 auto !important;
  font-family: 'Karla', Arial, sans-serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  letter-spacing: 0.28px !important;
  line-height: 1.6 !important;
}

.about-page-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 4rem;
  align-items: start;
  margin-bottom: 4rem;
}

.about-profile-column {
  text-align: center;
}

.about-profile-image {
  width: 100%;
  max-width: 400px;
  border-radius: 0; /* Sharp corners */
  box-shadow: var(--box-shadow);
  margin-bottom: 2rem;
  display: block;
}

.about-quick-facts {
  background: var(--light-gray);
  padding: 2rem;
  border-radius: 0; /* Sharp corners */
  text-align: left;
  box-shadow: var(--box-shadow);
}

.about-quick-facts-title {
  color: #000000;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 0.8px;
  line-height: 22px;
  margin-bottom: 1.5rem;
  text-align: center;
  text-transform: uppercase;
}

.about-quick-facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.about-quick-facts-list li {
  margin-bottom: 0.8rem;
  display: flex;
  align-items: center;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 22px;
  color: #000000;
}

.about-quick-facts-star {
  color: #000000;
  margin-right: 0.5rem;
  font-size: 16px;
}

.about-bio-column {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.about-bio-title {
  color: #000000;
  font-family: 'Arapey', 'Georgia', serif;
  font-size: 36px;
  font-weight: 400;
  letter-spacing: 1.44px;
  line-height: 40px;
  margin-bottom: 0;
}

.about-bio-text {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 22px;
  color: #000000;
  margin-bottom: 0;
}

.about-bio-text strong {
  font-weight: 400;
}

.about-section-gray {
  background: var(--light-gray);
}

.about-cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  margin-top: 3rem;
}

.about-card {
  background: white;
  padding: 2.5rem;
  border-radius: 0; /* Sharp corners */
  box-shadow: var(--box-shadow);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.about-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--box-shadow-hover);
}

.about-card-title {
  color: #000000;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 0.8px;
  line-height: 22px;
  margin-bottom: 1.5rem;
  text-transform: uppercase;
}

.about-card-text {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 22px;
  color: #000000;
  margin-bottom: 1.5rem;
}

.about-card-text:last-child {
  margin-bottom: 0;
}

.about-card-list {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 22px;
  color: #000000;
  margin-bottom: 1.5rem;
  padding-left: 1.5rem;
}

.about-card-list li {
  margin-bottom: 0.5rem;
}

/* ============================================
   COMMUNITY PAGE STYLES
   Design Standards Implementation
   ============================================ */

/* Section Base Styles */
.section {
  margin: 0;
  padding: 0;
}

.section-primary {
  background: white !important;
  padding: var(--space-lg) 0 !important; /* 80px top/bottom - reduced from 160px */
}

.section-secondary {
  background: var(--off-white) !important;
  padding: var(--space-lg) 0 !important; /* 80px top/bottom - reduced from 160px */
}

.section-accent {
  background: linear-gradient(135deg, var(--dark-gray) 0%, var(--button-hover) 100%);
  color: white;
  padding: var(--space-lg) 0; /* 80px top/bottom - reduced from 160px */
}

/* Container Standardization */
.community-page .container {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 var(--space-md) !important; /* 48px sides - reduced for better readability */
}

/* Section Content - Max width for readability */
.community-page .section-content {
  max-width: 800px !important;
  margin: 0 auto !important;
}

/* Typography Hierarchy */
.section-heading {
  font-family: 'Arapey', 'Georgia', serif;
  font-size: 36px;
  font-weight: 400;
  letter-spacing: 1.44px;
  line-height: 1.2;
  margin-bottom: var(--space-lg);
  color: var(--dark-gray);
}

.subsection-heading {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 24px;
  font-weight: 400;
  letter-spacing: 0.8px;
  line-height: 1.3;
  text-transform: uppercase;
  margin-bottom: var(--space-md);
  color: var(--dark-gray);
}

.card-title {
  font-family: 'Arapey', 'Georgia', serif;
  font-size: 20px;
  font-weight: 400;
  letter-spacing: 0.5px;
  line-height: 1.4;
  margin-bottom: var(--space-sm);
  color: var(--dark-gray);
}

/* Area Page Content Typography */
.area-content-text {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 1.6;
  color: var(--dark-gray);
  margin-bottom: var(--space-md);
}

.area-content-text:last-of-type {
  margin-bottom: var(--space-lg);
}

.area-features-list {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0;
}

.area-features-list li {
  padding: 0.75rem 0;
  padding-left: 2rem;
  position: relative;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 1.6;
  color: var(--dark-gray);
}

.area-features-list li::before {
  content: '★';
  position: absolute;
  left: 0;
  color: var(--primary-color);
  font-size: 18px;
}

/* Alternative bullet for transportation lists */
.area-features-list li[style*="padding-left: 1.5rem"]::before {
  content: '•';
  font-size: 20px;
}

.area-features-list li strong {
  font-weight: 400;
  color: var(--dark-gray);
}

/* Quick Stats Section */
.community-stats-section {
  padding: var(--space-xxl) 0;
  background: var(--off-white);
}

.community-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md); /* 48px - reduced to prevent overflow */
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}

.stat-card {
  background: white;
  padding: var(--space-lg); /* 80px - reduced to fit better */
  text-align: center;
  border-radius: 0;
  box-shadow: var(--box-shadow);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  min-width: 0; /* Prevent grid overflow */
  box-sizing: border-box;
}

.stat-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--box-shadow-hover);
}

.stat-value {
  font-family: 'Arapey', 'Georgia', serif;
  font-size: 2.5rem;
  font-weight: 400; /* Not 700! */
  color: var(--primary-color);
  margin-bottom: var(--space-xs);
  line-height: 1.1;
}

.stat-label {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: var(--dark-gray);
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1.5;
}

/* Neighborhoods Section */
.neighborhoods-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-md); /* 48px */
  max-width: 1200px;
  margin: 0 auto;
}

.neighborhood-card {
  background: white !important;
  padding: var(--space-md) !important; /* 48px - reduced from 120px */
  border-radius: 0 !important;
  box-shadow: var(--box-shadow) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.neighborhood-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--box-shadow-hover);
}

.neighborhood-card h3 {
  font-family: 'Arapey', 'Georgia', serif;
  font-size: 20px;
  font-weight: 400; /* Not 700! */
  letter-spacing: 0.5px;
  line-height: 1.4;
  color: var(--dark-gray);
  margin-top: 0;
  margin-bottom: var(--space-sm);
}

.neighborhood-card p {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 1.6;
  color: var(--dark-gray);
  margin: 0;
}

/* Amenities Section */
.amenities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--space-md); /* 48px */
  max-width: 1200px;
  margin: 0 auto;
}

.amenity-category {
  background: white !important;
  padding: var(--space-md) !important; /* 48px - reduced from 120px */
  border-radius: 0 !important;
  box-shadow: var(--box-shadow) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.amenity-category:hover {
  transform: translateY(-4px);
  box-shadow: var(--box-shadow-hover);
}

.amenity-category h3 {
  font-family: 'Arapey', 'Georgia', serif;
  font-size: 20px;
  font-weight: 400; /* Not 700! */
  letter-spacing: 0.5px;
  line-height: 1.4;
  color: var(--dark-gray);
  margin-top: 0;
  margin-bottom: var(--space-sm);
  border-bottom: 2px solid var(--primary-color);
  padding-bottom: var(--space-xs);
}

.amenity-category ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.amenity-category li {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 1.8;
  color: var(--dark-gray);
  padding: var(--space-xs) 0;
  padding-left: var(--space-md);
  position: relative;
}

.amenity-category li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--primary-color);
  font-weight: 400;
}

/* CTA Sections */
.cta-primary {
  background: linear-gradient(135deg, var(--dark-gray) 0%, var(--button-hover) 100%);
  color: white;
  padding: var(--space-xxl);
  text-align: center;
  border-radius: 0;
}

.cta-primary h2,
.cta-primary h3 {
  color: white;
  margin-top: 0;
  margin-bottom: var(--space-sm);
}

.cta-primary p {
  color: rgba(255, 255, 255, 0.9);
  font-size: 1.1rem;
  margin-bottom: var(--space-lg);
}

.cta-primary .btn {
  background: white;
  color: var(--dark-gray);
  padding: 16px 48px;
  font-size: 18px;
  font-weight: 400;
  border-radius: 0;
  text-transform: uppercase;
  letter-spacing: 1px;
  text-decoration: none;
  display: inline-block;
  transition: transform 0.3s ease;
}

.cta-primary .btn:hover {
  transform: translateY(-2px);
}

.cta-secondary {
  background: var(--light-gray);
  padding: var(--space-xl);
  border-radius: 0;
}

/* Section Content Spacing */
.section-content {
  max-width: 1200px;
  margin: 0 auto;
}

/* Yelp-Powered "Where To..." Section */
.yelp-section-header {
  text-align: center;
  margin-bottom: var(--space-lg);
}

.yelp-powered-by {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: #999999;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: var(--space-xs);
}

.yelp-section-title {
  margin-bottom: var(--space-lg);
}

.yelp-categories-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-xl);
  max-width: 800px;
  margin: 0 auto;
}

.yelp-category-column {
  width: 100%;
}

.yelp-category-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.yelp-category-list li {
  border-bottom: 1px solid var(--border-gray);
  padding: var(--space-sm) 0;
}

.yelp-category-list li:last-child {
  border-bottom: none;
}

.yelp-category-link {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: var(--dark-gray);
  text-decoration: none;
  display: block;
  transition: color 0.3s ease;
  letter-spacing: 0.28px;
}

.yelp-category-link:hover {
  color: var(--primary-color);
}

.yelp-disclaimer {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 14px;
  font-weight: 300;
  color: var(--dark-gray);
  margin-top: var(--space-lg);
  text-align: center;
  font-style: italic;
}

/* Responsive Community Page Styles */
@media (max-width: 1200px) {
  .community-page .container {
    padding: 0 var(--space-lg); /* 80px sides */
  }
  
  .amenities-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .community-stats-grid {
    gap: var(--space-sm); /* 24px on smaller screens */
  }
  
  .stat-card {
    padding: var(--space-md); /* 48px on smaller screens */
  }
}

@media (max-width: 1024px) {
  .community-stats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm); /* 24px */
  }
  
  .stat-card {
    padding: var(--space-md); /* 48px */
  }
}

@media (max-width: 768px) {
  .community-page .container {
    padding: 0 var(--space-md); /* 48px sides */
  }
  
  .section-primary,
  .section-secondary,
  .section-accent {
    padding: var(--space-xl) 0; /* 80px reduced from 160px */
  }
  
  .section-heading {
    font-size: 28px;
    margin-bottom: var(--space-md);
  }
  
  .subsection-heading {
    font-size: 20px;
    margin-bottom: var(--space-sm);
  }
  
  .community-stats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm); /* 24px on mobile */
  }
  
  .stat-card {
    padding: var(--space-md); /* 48px on mobile */
  }
  
  .stat-value {
    font-size: 2rem;
  }
  
  .neighborhoods-grid {
    grid-template-columns: 1fr;
    gap: var(--space-md); /* 48px */
  }
  
  .amenities-grid {
    grid-template-columns: 1fr;
    gap: var(--space-md); /* 48px */
  }
  
  .amenity-category,
  .neighborhood-card {
    padding: var(--space-lg); /* 80px */
  }
  
  .cta-primary {
    padding: var(--space-xl);
  }
  
  .yelp-categories-grid {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }
}

.about-business-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
  margin-top: 3rem;
}

.about-business-content {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.about-business-title {
  color: #000000;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 0.8px;
  line-height: 22px;
  margin-bottom: 0;
  text-transform: uppercase;
}

.about-business-text {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 22px;
  color: #000000;
  margin-bottom: 0;
}

.about-business-ventures {
  background: var(--light-gray);
  padding: 2.5rem;
  border-radius: 0; /* Sharp corners */
}

.about-business-ventures-title {
  color: #000000;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 0.8px;
  line-height: 22px;
  margin-bottom: 1.5rem;
  text-transform: uppercase;
}

.about-business-ventures-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.about-business-ventures-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 22px;
  color: #000000;
}

.about-business-ventures-bullet {
  width: 12px;
  height: 12px;
  background: #000000;
  border-radius: 0; /* Sharp corners for bullets */
  flex-shrink: 0;
}

.about-education-content {
  margin-bottom: 2rem;
}

.about-education-item {
  margin-bottom: 1.5rem;
}

.about-education-item:last-child {
  margin-bottom: 0;
}

.about-education-degree {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 0.28px;
  line-height: 22px;
  color: #000000;
  margin-bottom: 0.5rem;
}

.about-education-school {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 22px;
  color: #000000;
  margin-bottom: 0;
}

.about-cta-container {
  text-align: center;
}

.about-cta-description {
  font-family: 'Karla', Arial, sans-serif;
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.28px;
  line-height: 22px;
  color: #000000;
  margin-bottom: 2rem;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

.about-cta-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.btn-about-primary {
  background: #333333 !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 0 !important;
  -webkit-border-radius: 0 !important;
  -moz-border-radius: 0 !important;
  padding: 12px 30px !important;
  font-family: 'Karla', Arial, sans-serif !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  letter-spacing: 0.8px !important;
  line-height: 22px !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  display: inline-block !important;
  transition: background 0.3s ease !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}

.btn-about-primary:hover {
  background: #1a1a1a !important;
  color: #ffffff !important;
  transform: none !important;
  box-shadow: none !important;
}

.btn-about-secondary {
  background: transparent !important;
  color: #000000 !important;
  border: 1px solid #333333 !important;
  border-radius: 0 !important;
  -webkit-border-radius: 0 !important;
  -moz-border-radius: 0 !important;
  padding: 12px 30px !important;
  font-family: 'Karla', Arial, sans-serif !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  letter-spacing: 0.8px !important;
  line-height: 22px !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  display: inline-block !important;
  transition: background 0.3s ease, color 0.3s ease !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}

.btn-about-secondary:hover {
  background: #333333 !important;
  color: #ffffff !important;
  transform: none !important;
  box-shadow: none !important;
}

/* Responsive About Page */
@media (max-width: 992px) {
  .about-page-grid {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  
  .about-cards-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  
  .about-business-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}

@media (max-width: 768px) {
  .about-hero-title {
    font-size: 32px;
  }
  
  .about-bio-title {
    font-size: 32px;
  }
  
  .about-profile-image {
    max-width: 100%;
  }
  
  .about-card {
    padding: 1.5rem;
  }
  
  .about-business-ventures {
    padding: 1.5rem;
  }
}

@media (min-width: 1200px) {
  .about-hero-title {
    font-size: 38px;
  }
  
  .about-bio-title {
    font-size: 38px;
  }
  
  .about-bio-text,
  .about-card-text,
  .about-business-text {
    font-size: 16px;
  }
}

/* Container and Layout */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

.section {
  padding: 5rem 0;
  margin: 0; /* No margins between sections - they flow naturally like Adam's design */
}

/* About section overrides - no section padding, padding is on content-wrapper */
.about-section.section {
  padding: 0;
}

.section-title {
  font-family: 'Arapey', 'Georgia', serif; /* Match Adam's style */
  font-size: 36px; /* Match Adam's section headings */
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 1.44px; /* var(--secondary-letter-spacing) */
  line-height: 40px; /* var(--secondary-line-height) */
  text-align: center;
  margin-bottom: 3rem;
  color: #000000; /* var(--true-black) */
}

/* Services Section - Matching Adam's Style */
.services-section {
  background: var(--light-gray);
  padding: 5rem 0;
  margin: 0;
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 3rem;
}

.service-card {
  background: white;
  padding: 2rem;
  border-radius: 0; /* Sharp corners matching Adam's style */
  text-align: center;
  box-shadow: var(--box-shadow);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.service-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--box-shadow-hover);
}

.service-card h3 {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 16px; /* Match Adam's body text size */
  font-weight: 400; /* var(--bold) = 400 */
  color: #000000; /* var(--true-black) */
  margin-bottom: 1rem;
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
}

.service-card p {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 15px; /* Match Adam's body text size */
  font-weight: 300; /* var(--regular) = 300 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
  color: #000000; /* var(--true-black) */
  margin-bottom: 1.5rem;
}

.service-card .btn {
  background: #333333; /* Dark button matching Adam's style */
  color: #ffffff;
  border: none;
  border-radius: 0; /* No rounded corners like Adam's buttons */
  padding: 12px 30px;
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 16px;
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 0.8px;
  line-height: 22px; /* var(--primary-line-height) */
  text-transform: capitalize;
  text-decoration: none;
  display: inline-block;
  transition: background 0.3s ease;
  margin-top: 1rem;
}

.service-card .btn:hover {
  background: #1a1a1a; /* Darker on hover */
  color: #ffffff;
}

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

@media (max-width: 768px) {
  .services-grid {
    grid-template-columns: 1fr;
  }
  
  .section-title {
    font-size: 32px;
  }
}

@media (min-width: 1200px) {
  .section-title {
    font-size: 38px; /* Larger on desktop */
  }
  
  .service-card p {
    font-size: 16px; /* Larger on desktop */
  }
}

/* Enhanced Typography */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Raleway', Arial, sans-serif;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 1rem;
  color: var(--dark-gray);
}

h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.5rem; }

p {
  margin-bottom: 1.5rem;
  line-height: 1.7;
}

/* Testimonials Section - Matching Adam's Style */
.testimonials-section {
  background: #ffffff; /* Changed from var(--light-gray) to white to maintain alternating pattern after removing Featured Properties section */
  padding: 5rem 0;
  margin: 0;
}

.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 3rem;
}

.testimonial {
  background: white;
  padding: 2rem;
  border-radius: 0; /* Sharp corners matching Adam's style */
  box-shadow: var(--box-shadow);
  text-align: left;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.testimonial:hover {
  transform: translateY(-4px);
  box-shadow: var(--box-shadow-hover);
}

.testimonial-content {
  font-family: 'Arapey', 'Georgia', serif; /* Italic serif for quotes */
  font-style: italic;
  font-size: 15px; /* Match Adam's body text size */
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
  color: #000000; /* var(--true-black) */
  margin-bottom: 1.5rem;
  padding: 0; /* Remove left padding */
}

.testimonial-author {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 16px;
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
  color: #000000; /* var(--true-black) */
  margin-bottom: 0.5rem;
}

.testimonial-author-title {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 15px;
  font-weight: 300; /* var(--regular) = 300 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
  color: #000000; /* var(--true-black) */
}

.testimonials-review-section {
  margin-top: 3rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
}

.review-qr-container {
  text-align: center;
}

.review-qr-image {
  max-width: 200px;
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  border-radius: 0;
}

.review-qr-caption {
  margin-top: 1rem;
  font-family: 'Karla', Arial, sans-serif;
  font-size: 14px;
  font-weight: 300;
  color: #000000;
  letter-spacing: 0.28px;
}

.testimonials-actions {
  text-align: center;
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.btn-google-reviews {
  background: #333333; /* Dark button matching Adam's style */
  color: #ffffff;
  border: none;
  border-radius: 0; /* Sharp corners */
  padding: 12px 30px;
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 16px;
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 0.8px;
  line-height: 22px; /* var(--primary-line-height) */
  text-transform: uppercase;
  text-decoration: none;
  display: inline-block;
  transition: background 0.3s ease;
}

.btn-google-reviews:hover {
  background: #1a1a1a; /* Darker on hover */
  color: #ffffff;
}

.btn-leave-review {
  background: transparent;
  color: #000000; /* var(--true-black) */
  border: 1px solid #333333;
  border-radius: 0; /* Sharp corners */
  padding: 12px 30px;
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 16px;
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 0.8px;
  line-height: 22px; /* var(--primary-line-height) */
  text-transform: uppercase;
  text-decoration: none;
  display: inline-block;
  transition: background 0.3s ease, color 0.3s ease;
}

.btn-leave-review:hover {
  background: #333333;
  color: #ffffff;
}

.btn-icon-text {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

/* Responsive Testimonials Section */
@media (max-width: 992px) {
  .testimonials-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .testimonials-review-section {
    gap: 1.5rem;
  }
  
  .review-qr-image {
    max-width: 180px;
  }
}

@media (max-width: 768px) {
  .testimonials-grid {
    grid-template-columns: 1fr;
  }
  
  .testimonials-review-section {
    gap: 1.5rem;
  }
  
  .review-qr-image {
    max-width: 150px;
  }
  
  .testimonials-actions {
    flex-direction: column;
    width: 100%;
  }
  
  .testimonials-actions .btn {
    width: 100%;
    max-width: 300px;
  }
  
  .testimonial {
    padding: 1.5rem;
  }
}

@media (min-width: 1200px) {
  .testimonial-content {
    font-size: 16px; /* Larger on desktop */
  }
  
  .testimonial-author {
    font-size: 16px;
  }
  
  .testimonial-author-title {
    font-size: 16px;
  }
}

/* Contact CTA Section - Matching Adam's Style */
.cta-section {
  background: var(--light-gray); /* Light gray to maintain alternating pattern */
  padding: 5rem 0;
  margin: 0;
  text-align: center;
}

.cta-description {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 15px; /* Match Adam's body text size */
  font-weight: 300; /* var(--regular) = 300 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
  color: #000000; /* var(--true-black) */
  max-width: 600px;
  margin: 0 auto 2rem auto;
}

.cta-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

/* CTA Buttons - Force sharp corners with maximum specificity */
.cta-section a.btn-cta-primary,
.cta-actions a.btn-cta-primary,
a.btn-cta-primary,
.btn-cta-primary {
  background: #333333 !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 0 !important;
  -webkit-border-radius: 0 !important;
  -moz-border-radius: 0 !important;
  padding: 12px 30px !important;
  font-family: 'Karla', Arial, sans-serif !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  letter-spacing: 0.8px !important;
  line-height: 22px !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  display: inline-block !important;
  transition: background 0.3s ease !important;
  min-width: auto !important;
  min-height: auto !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}

.cta-section a.btn-cta-primary:hover,
.cta-actions a.btn-cta-primary:hover,
a.btn-cta-primary:hover,
.btn-cta-primary:hover {
  background: #1a1a1a !important;
  color: #ffffff !important;
  transform: none !important;
  box-shadow: none !important;
}

.cta-section a.btn-cta-secondary,
.cta-actions a.btn-cta-secondary,
a.btn-cta-secondary,
.btn-cta-secondary {
  background: transparent !important;
  color: #000000 !important;
  border: 1px solid #333333 !important;
  border-radius: 0 !important;
  -webkit-border-radius: 0 !important;
  -moz-border-radius: 0 !important;
  padding: 12px 30px !important;
  font-family: 'Karla', Arial, sans-serif !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  letter-spacing: 0.8px !important;
  line-height: 22px !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  display: inline-block !important;
  transition: background 0.3s ease, color 0.3s ease !important;
  min-width: auto !important;
  min-height: auto !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}

.cta-section a.btn-cta-secondary:hover,
.cta-actions a.btn-cta-secondary:hover,
a.btn-cta-secondary:hover,
.btn-cta-secondary:hover {
  background: #333333 !important;
  color: #ffffff !important;
  transform: none !important;
  box-shadow: none !important;
}

/* Responsive CTA Section */
@media (min-width: 1200px) {
  .cta-description {
    font-size: 16px; /* Larger on desktop */
  }
}

/* Blog Posts Section - Matching Adam's Style */
.blog-posts-section {
  background: #ffffff; /* White to maintain alternating pattern */
  padding: 5rem 0;
  margin: 0;
}

.blog-posts-description {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 15px; /* Match Adam's body text size */
  font-weight: 300; /* var(--regular) = 300 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
  color: #000000; /* var(--true-black) */
  text-align: center;
  margin-bottom: 3rem;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.blog-posts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 2rem;
}

.blog-post-card {
  background: white;
  border-radius: 0; /* Sharp corners matching Adam's style */
  overflow: hidden;
  box-shadow: var(--box-shadow);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.blog-post-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--box-shadow-hover);
}

.blog-post-image {
  width: 100%;
  overflow: hidden;
}

.blog-post-thumbnail {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
}

.blog-post-content {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.blog-post-meta {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 14px;
  font-weight: 300; /* var(--regular) = 300 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 20px;
  color: #666666; /* Lighter gray for meta */
  margin-bottom: 0.75rem;
  text-transform: uppercase;
}

.blog-post-title {
  margin: 0 0 1rem 0;
  flex-shrink: 0;
}

.blog-post-title a {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 18px;
  font-weight: 700; /* Bold for first line */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 24px;
  color: #000000; /* var(--true-black) */
  text-decoration: none;
  transition: color 0.3s ease;
  display: block;
}

.blog-post-title a:hover {
  color: #333333;
}

.blog-post-excerpt {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 15px;
  font-weight: 300; /* var(--regular) = 300 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
  color: #000000; /* var(--true-black) */
  margin-bottom: 1.25rem;
  flex-grow: 1;
}

.blog-post-link {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 14px;
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 0.8px;
  line-height: 22px; /* var(--primary-line-height) */
  color: #333333;
  text-decoration: none;
  text-transform: uppercase;
  display: inline-block;
  transition: color 0.3s ease;
  margin-top: auto;
  align-self: flex-start;
}

.blog-post-link:hover {
  color: #000000;
  text-decoration: underline;
}

.blog-posts-empty {
  text-align: center;
  grid-column: 1 / -1;
  padding: 2rem;
}

.blog-posts-empty p {
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 15px;
  font-weight: 300; /* var(--regular) = 300 */
  letter-spacing: 0.28px; /* var(--primary-letter-spacing) */
  line-height: 22px; /* var(--primary-line-height) */
  color: #000000; /* var(--true-black) */
}

.blog-posts-actions {
  text-align: center;
}

.btn-blog-view-all {
  background: #333333; /* Dark button matching Adam's style */
  color: #ffffff;
  border: none;
  border-radius: 0; /* Sharp corners */
  padding: 12px 30px;
  font-family: 'Karla', Arial, sans-serif; /* var(--primary-font-family) */
  font-size: 16px;
  font-weight: 400; /* var(--bold) = 400 */
  letter-spacing: 0.8px;
  line-height: 22px; /* var(--primary-line-height) */
  text-transform: uppercase;
  text-decoration: none;
  display: inline-block;
  transition: background 0.3s ease;
}

.btn-blog-view-all:hover {
  background: #1a1a1a; /* Darker on hover */
  color: #ffffff;
}

/* Responsive Blog Posts Section */
@media (max-width: 992px) {
  .blog-posts-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .blog-posts-grid {
    grid-template-columns: 1fr;
  }
  
  .blog-post-content {
    padding: 1.25rem;
  }
}

@media (min-width: 1200px) {
  .blog-posts-description {
    font-size: 16px; /* Larger on desktop */
  }
  
  .blog-post-meta,
  .blog-post-excerpt {
    font-size: 16px; /* Larger on desktop */
  }
  
  .blog-post-title a {
    font-size: 16px;
  }
}

/* Enhanced Listings */
.featured-listings {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 2rem;
  margin-top: 3rem;
}

.listing-card {
  background: white;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--box-shadow);
  transition: all 0.3s ease;
  border: 1px solid var(--border-gray);
}

.listing-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--box-shadow-hover);
}

.listing-card img {
  width: 100%;
  height: 250px;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.listing-card:hover img {
  transform: scale(1.05);
}

.listing-info {
  padding: 1.5rem;
}

.listing-price {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--primary-red);
  margin-bottom: 0.5rem;
}

.listing-address {
  font-size: 1.1rem;
  color: var(--charcoal);
  margin-bottom: 0.5rem;
  font-weight: 500;
}

.listing-details {
  color: var(--dark-gray);
  font-size: 0.9rem;
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.listing-detail {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

/* Enhanced Footer */
.site-footer {
  background: var(--light-gray); /* Light gray to create separation from white blog posts section above */
  color: var(--dark-gray);
  padding: 3rem 0 1rem 0;
  text-align: center;
}

.footer-content {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 2rem;
  margin-bottom: 2rem;
}

.footer-section h3 {
  color: var(--dark-gray);
  margin-bottom: 1rem;
  font-size: 1.2rem;
}

.footer-section p, .footer-section a {
  color: var(--dark-gray);
  text-decoration: none;
  line-height: 1.6;
}

.footer-section a:hover {
  color: var(--button-hover);
}

.footer-bottom {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  padding-top: 1rem;
  color: var(--medium-gray);
  font-size: 0.9rem;
}

/* Enhanced Mobile Responsive Design */
@media (max-width: 768px) {
  .container {
    padding: 0 1rem;
  }
  
  /* Header & Navigation */
  .site-header {
    padding: 1rem 0;
  }
  
  .site-title {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  
  .site-description {
    font-size: 1.1rem;
    margin-bottom: 1rem;
  }
  
  .main-menu {
    flex-direction: column;
    gap: 0.75rem;
    align-items: center;
    margin: 1.5rem 0;
  }
  
  .main-menu li a {
    font-size: 1.1rem;
    padding: 0.75rem 1.5rem;
    display: block;
    width: auto;
    text-align: center;
  }
  
  .main-menu .sub-menu {
    position: static;
    box-shadow: none;
    min-width: 0;
    border-radius: 0;
    background: none;
    padding: 0;
    margin-top: 0;
    opacity: 1;
    display: none;
  }
  
  .main-menu .sub-menu li a {
    padding: 0.5rem 1rem;
    color: var(--dark-gray);
    font-size: 1rem;
  }
  
  /* Hero Section - Responsive */
  .hero-section {
    height: 100vh;
    min-height: 100vh;
    max-height: 100vh;
  }
  
  .hero-content {
    margin-top: 0;
    padding: var(--space-md-a, 1.5rem);
    align-items: flex-start;
    gap: 10%;
  }
  
  .hero-title {
    font-size: 42px;
    letter-spacing: 7px;
    line-height: 40px;
  }
  
  .hero-tagline {
    font-size: 20px;
  }
  
  .hero-action-tabs {
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-start;
  }
  
  .hero-search {
    width: 100%;
  }
  
  .action-tab {
    padding: 0.75rem 1.5rem;
    font-size: 0.9rem;
  }
  
  .hero-search {
    max-width: 100%;
    width: 100%;
  }
  
  .hero-search-form {
    max-width: 100%;
    width: 100%;
  }
  
  .hero-search-input {
    padding: 1rem 1.5rem;
    font-size: 1rem;
  }
  
  .hero-search-button {
    padding: 1rem 1.5rem;
  }
  
  .btn {
    width: auto;
    min-width: 200px;
    max-width: 300px;
    padding: 1rem 2rem;
    font-size: 1rem;
  }
  
  /* Content Sections */
  .section {
    padding: 3rem 0;
  }
  
  .section-title {
    font-size: 2rem;
    margin-bottom: 2rem;
  }
  
  /* Grid Layouts */
  .featured-listings {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  
  /* About Page Grid */
  .about-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  
  .about-page-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  
  /* Testimonials */
  .testimonial {
    padding: 2rem;
    margin-bottom: 1.5rem;
  }
  
  /* Footer */
  .footer-content {
    grid-template-columns: 1fr;
    gap: 2rem;
    text-align: center;
  }
  
  .footer-section {
    padding: 0 1rem;
  }
  
  /* Typography */
  h1 { font-size: 2.2rem; }
  h2 { font-size: 1.8rem; }
  h3 { font-size: 1.5rem; }
  
  p {
    font-size: 1rem;
    line-height: 1.6;
  }
}

@media (max-width: 480px) {
  .container {
    padding: 0 1rem;
  }
  
  /* Header */
  .site-title {
    font-size: 2rem;
  }
  
  .site-description {
    font-size: 1rem;
  }
  
  /* Hero Section */
  .hero-section {
    height: 60vh;
  }
  
  .hero-title {
    font-size: 2.2rem;
    line-height: 1.1;
  }
  
  .hero-subtitle {
    font-size: 1rem;
  }
  
  .hero-buttons {
    gap: 1rem;
  }
  
  .btn {
    min-width: 180px;
    max-width: 280px;
    padding: 0.875rem 1.5rem;
    font-size: 0.95rem;
  }
  
  /* Content */
  .section {
    padding: 2.5rem 0;
  }
  
  .section-title {
    font-size: 1.8rem;
  }
  
  /* Testimonials */
  .testimonial {
    padding: 1.5rem;
  }
  
  /* Listings */
  .listing-info {
    padding: 1rem;
  }
  
  .listing-price {
    font-size: 1.2rem;
  }
  
  .listing-address {
    font-size: 1rem;
  }
  
  /* Typography */
  h1 { font-size: 1.9rem; }
  h2 { font-size: 1.6rem; }
  h3 { font-size: 1.3rem; }
  
  p {
    font-size: 0.95rem;
  }
  
  /* Footer */
  .footer-section {
    padding: 0 0.75rem;
  }
}

/* iPhone Landscape Optimizations */
@media (max-width: 896px) and (orientation: landscape) {
  .hero-section {
    height: 50vh;
  }
  
  .hero-title {
    font-size: 2rem;
  }
  
  .hero-subtitle {
    font-size: 1rem;
  }
  
  .section {
    padding: 2rem 0;
  }
  
  .site-header {
    padding: 0.75rem 0;
  }
  
  .site-title {
    font-size: 2rem;
  }
} 

/* ========================================
   HGRE Q&A Integration Styles
   ======================================== */

/* Q&A Single Template Styles */
.qa-single-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 40px;
}

.qa-content-wrapper {
    background: #fff;
    padding: 30px;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.qa-breadcrumb {
    margin-bottom: 30px;
    padding: 15px 0;
    border-bottom: 1px solid #eee;
}

.qa-breadcrumb ol {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.qa-breadcrumb li {
    margin-right: 10px;
    color: #666;
}

.qa-breadcrumb li:not(:last-child)::after {
    content: '→';
    margin-left: 10px;
    color: #ccc;
}

.qa-breadcrumb a {
    color: #0073aa;
    text-decoration: none;
}

.qa-breadcrumb a:hover {
    text-decoration: underline;
}

.qa-question-header {
    margin-bottom: 30px;
}

.qa-question-title {
    font-size: 2.5em;
    color: #333;
    margin-bottom: 20px;
    line-height: 1.2;
}

.qa-metadata {
    background: #f8f9fa;
    padding: 20px;
    border-radius: 6px;
    margin-bottom: 20px;
}

.qa-meta-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
    margin-bottom: 20px;
}

.qa-meta-item {
    display: flex;
    flex-direction: column;
}

.qa-meta-label {
    font-weight: 600;
    color: #666;
    font-size: 0.9em;
    margin-bottom: 5px;
}

.qa-meta-value {
    color: #333;
    font-size: 1.1em;
}

.qa-quality-scores {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.qa-score-item {
    background: #fff;
    padding: 10px 15px;
    border-radius: 4px;
    border: 1px solid #ddd;
}

.qa-score-label {
    font-weight: 600;
    color: #666;
    font-size: 0.9em;
}

.qa-score-value {
    color: #0073aa;
    font-weight: 600;
    margin-left: 5px;
}

/* Guest Information Sections */
.qa-guest-info {
    margin-top: 30px;
    padding: 24px;
    background: #f8f9fa;
    border-radius: 8px;
    border-left: 4px solid #0073aa;
    font-family: 'Karla', Arial, sans-serif;
}

.qa-section-title {
    font-family: 'Arapey', 'Georgia', serif;
    font-size: 20px;
    font-weight: 400;
    color: var(--dark-gray);
    margin-bottom: 16px;
    margin-top: 0;
    letter-spacing: 0.5px;
}

.qa-credentials-section,
.qa-expertise-section,
.qa-social-section {
    margin-bottom: 20px;
}

.qa-credentials-section:last-child,
.qa-expertise-section:last-child,
.qa-social-section:last-child {
    margin-bottom: 0;
}

.qa-credentials-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.qa-credential-item {
    padding: 10px 14px;
    margin-bottom: 10px;
    background: #fff;
    border-radius: 4px;
    border-left: 3px solid #0073aa;
    font-family: 'Karla', Arial, sans-serif;
    font-size: 15px;
    font-weight: 300;
    letter-spacing: 0.28px;
    line-height: 22px;
    color: var(--dark-gray);
}

.qa-expertise-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.qa-expertise-tag {
    display: inline-block;
    padding: 8px 14px;
    background: #0073aa;
    color: #fff;
    border-radius: 20px;
    font-family: 'Karla', Arial, sans-serif;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.28px;
}

.qa-social-links {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.qa-social-link {
    display: inline-block;
    padding: 8px 16px;
    background: #0073aa;
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
    transition: background 0.3s;
}

.qa-social-link:hover {
    background: #005a87;
    color: #fff;
}

.qa-influence-high {
    color: #28a745;
    font-weight: 600;
}

.qa-influence-medium {
    color: #ffc107;
    font-weight: 600;
}

.qa-influence-low {
    color: #6c757d;
}

.qa-guest-header {
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid #e0e0e0;
}

.qa-guest-name {
    font-family: 'Arapey', 'Georgia', serif;
    font-size: 24px;
    font-weight: 400;
    color: var(--dark-gray);
    margin-bottom: 8px;
    margin-top: 0;
    letter-spacing: 0.5px;
}

.qa-guest-business {
    font-family: 'Karla', Arial, sans-serif;
    font-size: 16px;
    font-weight: 400;
    color: var(--dark-gray);
    margin-bottom: 0;
    letter-spacing: 0.28px;
}

.qa-answer-section {
    margin-bottom: 30px;
}

.qa-answer-content {
    font-size: 1.1em;
    line-height: 1.7;
    color: #333;
}

.qa-answer-content h2,
.qa-answer-content h3,
.qa-answer-content h4 {
    color: #0073aa;
    margin-top: 25px;
    margin-bottom: 15px;
}

.qa-answer-content p {
    margin-bottom: 15px;
}

.qa-answer-content ul,
.qa-answer-content ol {
    margin-bottom: 15px;
    padding-left: 20px;
}

.qa-article-footer {
    border-top: 1px solid #eee;
    padding-top: 30px;
    margin-bottom: 30px;
}

.qa-taxonomies {
    margin-bottom: 20px;
}

.qa-taxonomy-group {
    margin-bottom: 15px;
}

.qa-taxonomy-group h3 {
    font-size: 1.1em;
    color: #666;
    margin-bottom: 10px;
}

.qa-taxonomy-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.qa-taxonomy-link {
    background: #0073aa;
    color: #fff;
    padding: 5px 12px;
    border-radius: 20px;
    text-decoration: none;
    font-size: 0.9em;
    transition: background-color 0.3s;
}

.qa-taxonomy-link:hover {
    background: #005a87;
    color: #fff;
}

.qa-priority-p1 {
    background: #dc3545;
}

.qa-priority-p2 {
    background: #fd7e14;
}

.qa-priority-p3 {
    background: #28a745;
}

.qa-publication-info {
    color: #666;
    font-size: 0.9em;
}

.qa-publication-info p {
    margin-bottom: 5px;
}

.qa-related-section {
    margin-bottom: 30px;
}

.qa-related-section h2 {
    color: #333;
    margin-bottom: 20px;
    font-size: 1.8em;
}

.qa-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
}

.qa-related-item {
    background: #f8f9fa;
    padding: 20px;
    border-radius: 6px;
    border-left: 4px solid #0073aa;
}

.qa-related-item h3 {
    margin-bottom: 10px;
}

.qa-related-item h3 a {
    color: #0073aa;
    text-decoration: none;
}

.qa-related-item h3 a:hover {
    text-decoration: underline;
}

.qa-related-meta {
    margin-top: 15px;
    font-size: 0.9em;
    color: #666;
}

.qa-related-date,
.qa-related-category {
    margin-right: 15px;
}

.qa-social-sharing {
    margin-bottom: 30px;
    text-align: center;
}

.qa-social-sharing h3 {
    margin-bottom: 15px;
    color: #333;
}

.qa-social-buttons {
    display: flex;
    justify-content: center;
    gap: 15px;
    flex-wrap: wrap;
}

.qa-social-button {
    padding: 10px 20px;
    border-radius: 25px;
    text-decoration: none;
    color: #fff;
    font-weight: 600;
    transition: opacity 0.3s;
}

.qa-social-button:hover {
    opacity: 0.8;
    color: #fff;
}

.qa-twitter {
    background: #1da1f2;
}

.qa-facebook {
    background: #4267b2;
}

.qa-linkedin {
    background: #0077b5;
}

.qa-content-actions {
    margin-bottom: 30px;
}

.qa-action-buttons {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}

.qa-action-btn {
    padding: 12px 24px;
    border: 2px solid #0073aa;
    background: #fff;
    color: #0073aa;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
}

.qa-action-btn:hover {
    background: #0073aa;
    color: #fff;
}

.qa-sidebar {
    background: #f8f9fa;
    padding: 25px;
    border-radius: 8px;
    height: fit-content;
}

.qa-sidebar-widget {
    margin-bottom: 30px;
}

.qa-sidebar-widget h3 {
    color: #333;
    margin-bottom: 15px;
    font-size: 1.3em;
}

.qa-category-list,
.qa-recent-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.qa-category-list li,
.qa-recent-list li {
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid #eee;
}

.qa-category-list li:last-child,
.qa-recent-list li:last-child {
    border-bottom: none;
}

.qa-category-list a,
.qa-recent-list a {
    color: #0073aa;
    text-decoration: none;
    font-weight: 500;
}

.qa-category-list a:hover,
.qa-recent-list a:hover {
    text-decoration: underline;
}

.qa-category-count,
.qa-recent-date {
    color: #666;
    font-size: 0.9em;
    margin-left: 10px;
}

/* Q&A Archive Template Styles */
.qa-archive-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
}

.qa-archive-header {
    text-align: center;
    margin-bottom: 40px;
    padding: 40px 20px;
    background: linear-gradient(135deg, #0073aa, #005a87);
    color: #fff;
    border-radius: 8px;
}

.qa-archive-title {
    font-size: 3em;
    margin-bottom: 15px;
    color: #fff;
}

.qa-archive-description {
    font-size: 1.2em;
    opacity: 0.9;
    max-width: 600px;
    margin: 0 auto;
}

.qa-search-filter-section {
    background: #fff;
    padding: 30px;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    margin-bottom: 30px;
}

.qa-search-container {
    max-width: 1000px;
    margin: 0 auto;
}

.qa-search-form {
    width: 100%;
}

.qa-search-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    align-items: end;
}

.qa-search-field {
    display: flex;
    flex-direction: column;
}

.qa-search-field label {
    font-weight: 600;
    color: #333;
    margin-bottom: 8px;
    font-size: 0.9em;
}

.qa-search-field input,
.qa-search-field select {
    padding: 12px;
    border: 2px solid #ddd;
    border-radius: 6px;
    font-size: 1em;
    transition: border-color 0.3s;
}

.qa-search-field input:focus,
.qa-search-field select:focus {
    outline: none;
    border-color: #0073aa;
}

.qa-search-btn,
.qa-reset-btn {
    padding: 12px 24px;
    border: none;
    border-radius: 6px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
}

.qa-search-btn {
    background: #0073aa;
    color: #fff;
}

.qa-search-btn:hover {
    background: #005a87;
}

.qa-reset-btn {
    background: #6c757d;
    color: #fff;
}

.qa-reset-btn:hover {
    background: #545b62;
}

.qa-results-section {
    background: #fff;
    padding: 30px;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    margin-bottom: 30px;
}

.qa-results-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid #eee;
}

.qa-results-header h2 {
    color: #333;
    margin: 0;
    font-size: 1.8em;
}

.qa-results-count {
    color: #666;
    font-size: 1.1em;
}

.qa-loading {
    text-align: center;
    padding: 40px;
}

.qa-loading-spinner {
    border: 4px solid #f3f3f3;
    border-top: 4px solid #0073aa;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
    margin: 0 auto 20px;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.qa-results-grid {
    display: grid;
    gap: 25px;
}

.qa-result-item {
    background: #f8f9fa;
    padding: 25px;
    border-radius: 8px;
    border-left: 4px solid #0073aa;
    transition: transform 0.3s, box-shadow 0.3s;
}

.qa-result-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}

.qa-result-header {
    margin-bottom: 15px;
}

.qa-result-title {
    margin-bottom: 10px;
}

.qa-result-title a {
    color: #0073aa;
    text-decoration: none;
    font-size: 1.4em;
    font-weight: 600;
}

.qa-result-title a:hover {
    text-decoration: underline;
}

.qa-result-meta {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    font-size: 0.9em;
    color: #666;
}

.qa-meta-guest,
.qa-meta-episode,
.qa-meta-date {
    background: #fff;
    padding: 5px 10px;
    border-radius: 4px;
    border: 1px solid #ddd;
}

.qa-result-content {
    margin-bottom: 20px;
}

.qa-result-excerpt {
    color: #333;
    line-height: 1.6;
    margin-bottom: 15px;
}

.qa-result-scores {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}

.qa-score {
    padding: 5px 12px;
    border-radius: 20px;
    font-size: 0.9em;
    font-weight: 600;
    color: #fff;
}

.qa-score.quality {
    background: #28a745;
}

.qa-score.authority {
    background: #17a2b8;
}

.qa-result-footer {
    border-top: 1px solid #eee;
    padding-top: 20px;
}

.qa-result-taxonomies {
    margin-bottom: 15px;
}

.qa-taxonomy-tags {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}

.qa-taxonomy-tag {
    background: #0073aa;
    color: #fff;
    padding: 5px 12px;
    border-radius: 20px;
    text-decoration: none;
    font-size: 0.8em;
    transition: background-color 0.3s;
}

.qa-taxonomy-tag:hover {
    background: #005a87;
    color: #fff;
}

.qa-location-tag {
    background: #6f42c1;
}

.qa-location-tag:hover {
    background: #5a32a3;
}

.qa-result-actions {
    text-align: right;
}

.qa-read-more {
    background: #0073aa;
    color: #fff;
    padding: 10px 20px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 600;
    transition: background-color 0.3s;
}

.qa-read-more:hover {
    background: #005a87;
    color: #fff;
}

.qa-pagination {
    margin-top: 30px;
    text-align: center;
}

.qa-pagination .page-numbers {
    display: inline-block;
    padding: 10px 15px;
    margin: 0 5px;
    background: #f8f9fa;
    color: #0073aa;
    text-decoration: none;
    border-radius: 4px;
    transition: all 0.3s;
}

.qa-pagination .page-numbers:hover,
.qa-pagination .current {
    background: #0073aa;
    color: #fff;
}

.qa-no-results {
    text-align: center;
    padding: 40px;
    color: #666;
}

.qa-no-results h3 {
    color: #333;
    margin-bottom: 15px;
}

.qa-no-results-actions {
    margin-top: 20px;
}

.qa-reset-search-btn,
.qa-browse-all-btn {
    display: inline-block;
    margin: 0 10px;
    padding: 12px 24px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 600;
    transition: all 0.3s;
}

.qa-reset-search-btn {
    background: #6c757d;
    color: #fff;
    border: none;
    cursor: pointer;
}

.qa-reset-search-btn:hover {
    background: #545b62;
}

.qa-browse-all-btn {
    background: #0073aa;
    color: #fff;
}

.qa-browse-all-btn:hover {
    background: #005a87;
    color: #fff;
}

.qa-featured-section {
    background: #fff;
    padding: 30px;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.qa-featured-section h2 {
    color: #333;
    margin-bottom: 25px;
    font-size: 1.8em;
    text-align: center;
}

.qa-featured-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 25px;
}

.qa-featured-item {
    background: #f8f9fa;
    padding: 25px;
    border-radius: 8px;
    border-left: 4px solid #28a745;
    transition: transform 0.3s;
}

.qa-featured-item:hover {
    transform: translateY(-2px);
}

.qa-featured-item h3 {
    margin-bottom: 15px;
}

.qa-featured-item h3 a {
    color: #0073aa;
    text-decoration: none;
}

.qa-featured-item h3 a:hover {
    text-decoration: underline;
}

.qa-featured-item p {
    color: #333;
    line-height: 1.6;
    margin-bottom: 15px;
}

.qa-featured-meta {
    font-size: 0.9em;
    color: #666;
}

.qa-featured-date,
.qa-featured-category {
    margin-right: 15px;
}

/* Responsive Design */
@media (max-width: 768px) {
    .qa-single-container {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 15px;
    }
    
    .qa-content-wrapper,
    .qa-sidebar {
        padding: 20px;
    }
    
    .qa-question-title {
        font-size: 2em;
    }
    
    .qa-meta-grid {
        grid-template-columns: 1fr;
    }
    
    .qa-quality-scores {
        flex-direction: column;
        gap: 10px;
    }
    
    .qa-related-grid {
        grid-template-columns: 1fr;
    }
    
    .qa-search-row {
        grid-template-columns: 1fr;
        gap: 15px;
    }
    
    .qa-action-buttons {
        flex-direction: column;
    }
    
    .qa-social-buttons {
        flex-direction: column;
        align-items: center;
    }
    
    .qa-archive-title {
        font-size: 2.5em;
    }
    
    .qa-featured-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .qa-question-title {
        font-size: 1.8em;
    }
    
    .qa-archive-title {
        font-size: 2em;
    }
    
    .qa-content-wrapper,
    .qa-sidebar,
    .qa-search-filter-section,
    .qa-results-section,
    .qa-featured-section {
        padding: 15px;
    }
    
    .qa-meta-grid {
        gap: 10px;
    }
    
    .qa-quality-scores {
        gap: 8px;
    }
} 