/**
 * Child Theme Bundle (generated)
 * Consolidated stylesheet for all child-theme components, widgets, and page layouts.
 * DO NOT EDIT THIS FILE DIRECTLY. Edit source CSS files and run ./scripts/build-bundle.sh.
 * Keep design-tokens.css and utilities.css enqueued separately for variables/utilities.
 */

/* ==========================
   DESIGN TOKENS - FONT SIZES (15% increase applied)
   ========================== */

:root {
  /* Font Sizes - Responsive scale from 16px to 60px (15% increase applied) */
  --font-size-xs: 1.00625rem;      /* 16.1px - Small labels, captions, metadata (was 14px) */
  --font-size-sm: 1.00625rem;      /* 16.1px - Small labels, captions, metadata (was 14px) */
  --font-size-base: 1.15rem;        /* 18.4px - Body text, default content (was 16px) */
  --font-size-md: 1.29375rem;      /* 20.7px - Emphasized body, small subheadings (was 18px) */
  --font-size-lg: 1.4375rem;       /* 23px - Subheadings, emphasis (was 20px) */
  --font-size-xl: 1.725rem;        /* 27.6px - Section subheadings (was 24px) */
  --font-size-2xl: 2.15625rem;     /* 34.5px - Feature section titles (was 30px) */
  --font-size-3xl: 2.5875rem;      /* 41.4px - Page section headings (was 36px) */
  --font-size-4xl: 3.1625rem;      /* 50.6px - Major page titles (was 44px) */
  --font-size-5xl: 3.7375rem;      /* 59.8px - Hero headlines (was 52px) */

  /* Font Weights - Figtree available weights */
  --font-weight-light: 300;      /* Light - Optional subtext, supporting content */
  --font-weight-normal: 400;     /* Regular - Body text, default content */
  --font-weight-medium: 500;     /* Medium - Emphasized text, secondary headings */
  --font-weight-semibold: 600;   /* Semibold - Buttons, callouts, strong labels */
  --font-weight-bold: 700;       /* Bold - Primary headings, critical emphasis */

  /* Line Heights - Optimized for readability */
  --line-height-tight: 1.25;     /* Headings, impact text */
  --line-height-snug: 1.375;     /* Tight headings */
  --line-height-base: 1.65;      /* Body paragraphs, primary content */
  --line-height-relaxed: 1.8;    /* Long-form content, accessibility */

  /* Letter Spacing */
  --letter-spacing-tight: -0.02em;  /* Impactful headings, visual impact */
  --letter-spacing-normal: 0;       /* Default, most text */
  --letter-spacing-wide: 0.05em;    /* Uppercase labels, emphasis */

  /* Typography - Font Families */
  --font-family-base: 'Figtree', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-family-primary: 'Figtree', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;

  /* Colors - Brand (Catholic Charities) */
  --cc-primary: #0066cc;           /* Catholic Charities blue */
  --cc-primary-dark: #0052a3;     /* Darker blue */
  --cc-primary-light: #e7f3ff;    /* Light blue background */
  --color-primary: #2f4089;        /* Chambray - Primary brand color */
  --color-primary-dark: #202c63;   /* Darker version */
  --color-primary-light: #e7f3ff; /* Light version */
  --color-secondary: #4b96da;      /* Nepal - Secondary accent */
  --color-accent: #8eb8c5;         /* Spring - Accent color */

  /* Colors - Backgrounds */
  --color-background: #eef2f9;     /* Aqua - Page background */
  --color-bg: #ffffff;              /* White - Card/component background */
  --color-bg-alt: #f8f9fa;         /* Light gray - Alternate background */
  --color-white: #ffffff;           /* Pure white */
  --color-light-gray: #f9f9f9;     /* Light gray */

  /* Colors - Text */
  --color-text: #212529;            /* Main text color */
  --color-text-light: #495057;     /* Light text */
  --color-text-muted: #6c757d;      /* Muted text */
  --color-text-secondary: #3d4668;  /* Secondary text */
  --color-heading: #202c63;         /* Heading color */

  /* Colors - UI Elements */
  --color-border: #e9ecef;         /* Border color */
  --color-borders: #d8dcef;         /* Alternative border color */
  --color-borders-light: #e7ebf9;   /* Light border */
  --color-border-light: #e9ecef;    /* Light border (alias) */
  --color-border-hover: #0066cc;    /* Border hover state */
  --color-gray-100: #f3f4f6;        /* Gray 100 */
  --color-gray-300: #d1d5db;        /* Gray 300 */
  --color-gray-400: #9ca3af;        /* Gray 400 */
  --color-gray-700: #374151;        /* Gray 700 */

  /* Spacing - Fixed pixel values (do not scale with font size) */
  --spacing-xs: 8px;                /* Extra small spacing */
  --spacing-sm: 12px;               /* Small spacing */
  --spacing-md: 16px;               /* Medium spacing */
  --spacing-lg: 24px;               /* Large spacing */
  --spacing-xl: 32px;               /* Extra large spacing */
  --spacing-2xl: 48px;              /* 2X extra large spacing */
  --spacing-3xl: 64px;              /* 3X extra large spacing - Large section spacing */
  --spacing-2xs: 4px;               /* Extra extra small spacing */

  /* Border Radius */
  --border-radius-sm: 0.375rem;     /* 6px */
  --border-radius-md: 0.5rem;       /* 8px */
  --border-radius-lg: 0.75rem;      /* 12px */
  --border-radius-xl: 1rem;         /* 16px */
  --border-radius-full: 9999px;      /* Full circle */

  /* Border Width */
  --border-width-thin: 1px;         /* Thin border */
  --border-width-base: 1px;         /* Base border */
  --border-width-thick: 2px;        /* Thick border */
  --border-width-focus: 2px;        /* Focus outline width */

  /* Shadows */
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.08);
  --shadow-md: 0 4px 12px rgba(47, 64, 137, 0.15);
  --shadow-lg: 0 8px 24px rgba(47, 64, 137, 0.15);
  --shadow-xl: 0 20px 60px rgba(26, 54, 93, 0.2);
  --shadow-hover: 0 8px 24px rgba(47, 64, 137, 0.25);

  /* Transitions */
  --transition-fast: 0.15s ease;
  --transition-base: 0.3s ease;
  --transition-slow: 0.5s ease;
  --transition-colors: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;

  /* Container */
  --container-max-width: 1200px;
  --container-padding: 2rem;

  /* Z-index */
  --z-dropdown: 1000;
}

/* ==========================
   CORE COMPONENTS
   ========================== */

/* Source: components/base/button.css */
/**
 * Button Component
 * ================
 * Reusable button styling for all CTA, form, and navigation buttons
 * BEM naming convention: .cc-button, .cc-button--variant, .cc-button__icon
 *
 * Variants: primary, secondary, outline, link
 * Sizes: sm, md (default), lg
 * States: default, hover, active, focus, disabled
 * Icon support with left/right positioning
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE BUTTON STYLES
   ============================================ */

.cc-button {
  /* Layout & Display */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-xs);

  /* Sizing - Touch-friendly minimum */
  min-height: 44px;
  padding: 0.75rem 1.5rem;

  /* Typography */
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  line-height: 1.5;
  letter-spacing: var(--letter-spacing-normal);
  text-decoration: none;
  text-align: center;
  white-space: nowrap;

  /* Appearance */
  border: var(--border-width-base) solid transparent;
  border-radius: var(--border-radius-md);
  cursor: pointer;

  /* Transitions */
  transition: var(--transition-base);
  transition-property: background-color, border-color, color, box-shadow, transform;

  /* Remove default button styles */
  background: none;
  color: inherit;

  /* Accessibility */
  -webkit-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

/* Remove default button styles for <button> elements */
.cc-button::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/* Focus state for keyboard navigation */
.cc-button:focus-visible {
  outline: var(--border-width-focus) solid var(--color-primary);
  outline-offset: 2px;
}

/* Disabled state */
.cc-button:disabled,
.cc-button[aria-disabled="true"],
.cc-button.cc-button--disabled {
  opacity: 0.6;
  cursor: not-allowed;
  background-color: var(--color-gray-400) !important;
  color: var(--color-text-light) !important;
  border-color: var(--color-gray-400) !important;
  box-shadow: none !important;
  transform: none !important;
}

/* ============================================
   BUTTON VARIANTS
   ============================================ */

/* Primary Button - Brand color background */
.cc-button--primary {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

.cc-button--primary:hover:not(:disabled):not([aria-disabled="true"]) {
  background-color: var(--color-primary-dark);
  color: var(--color-white);
  border-color: var(--color-primary-dark);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.cc-button--primary:active:not(:disabled):not([aria-disabled="true"]) {
  background-color: var(--color-primary-dark);
  color: var(--color-white);
  transform: translateY(0);
}

/* Secondary Button - Light background with brand text */
.cc-button--secondary {
  background-color: var(--color-bg-alt);
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.cc-button--secondary:hover:not(:disabled):not([aria-disabled="true"]) {
  background-color: var(--color-primary);
  color: var(--color-white);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.cc-button--secondary:active:not(:disabled):not([aria-disabled="true"]) {
  background-color: var(--color-primary-dark);
  color: var(--color-white);
  transform: translateY(0);
}

/* Outline Button - Border only, transparent background */
.cc-button--outline {
  background-color: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.cc-button--outline:hover:not(:disabled):not([aria-disabled="true"]) {
  background-color: var(--color-primary-light);
  color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
}

.cc-button--outline:active:not(:disabled):not([aria-disabled="true"]) {
  background-color: var(--color-primary);
  color: var(--color-white);
  transform: translateY(0);
}

/* Link Button - Minimal styling, text-only appearance */
.cc-button--link {
  background-color: transparent;
  color: var(--color-primary);
  border-color: transparent;
  padding: 0.25rem 0; /* Minimal padding for link style */
  min-height: auto; /* Don't enforce minimum height */
  text-decoration: underline;
}

.cc-button--link:hover:not(:disabled):not([aria-disabled="true"]) {
  color: var(--color-primary-dark);
  text-decoration: none;
}

.cc-button--link:active:not(:disabled):not([aria-disabled="true"]) {
  color: var(--color-primary-dark);
}


/* ============================================
   BUTTON SIZES
   ============================================ */

/* Small Button */
.cc-button--sm {
  min-height: 36px;
  padding: 0.5rem 1rem;
  font-size: clamp(0.8125rem, 2vw, var(--font-size-sm));
}

/* Medium Button - Default size */
.cc-button--md {
  min-height: 44px;
  padding: 0.75rem 1.5rem;
  font-size: var(--font-size-base);
}

/* Large Button */
.cc-button--lg {
  min-height: 52px;
  padding: 1rem 2rem;
  font-size: clamp(1rem, 2.5vw, 1.125rem);
}

/* Hero/CTA Button - Extra emphasis for important actions */
.cc-button--hero {
  min-height: 56px;
  padding: 1.25rem 2.5rem;
  font-size: 1.125rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.03em; /* 0.5px converted to em (0.5/16 ≈ 0.03125em) */
  box-shadow: var(--shadow-md);
}

.cc-button--hero:hover:not(:disabled):not([aria-disabled="true"]) {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}


/* ============================================
   ICON BUTTON ELEMENTS
   ============================================ */

.cc-button__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25em;
  height: 1.25em;
  flex-shrink: 0;
}

/* Icon left (default) - icon appears before text */
.cc-button__icon--left {
  order: -1;
  margin-right: var(--spacing-xs);
}

/* Icon right - icon appears after text */
.cc-button__icon--right {
  order: 1;
  margin-left: var(--spacing-xs);
}

/* Icon only button - no text, just icon */
.cc-button--icon-only {
  min-width: 44px;
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: var(--border-radius-md);
}

.cc-button--icon-only.cc-button--sm {
  min-width: 36px;
  width: 36px;
  height: 36px;
}

.cc-button--icon-only.cc-button--lg {
  min-width: 52px;
  width: 52px;
  height: 52px;
}

/* Icon button with circular styling */
.cc-button--icon-circle {
  border-radius: var(--border-radius-full);
  aspect-ratio: 1 / 1;
}


/* ============================================
   BUTTON STATES & EFFECTS
   ============================================ */

/* Loading state */
.cc-button.cc-button--loading {
  pointer-events: none;
  opacity: 0.8;
}

.cc-button--loading .cc-button__icon {
  animation: spin 1s linear infinite;
}

/* Group of buttons */
.cc-button-group {
  display: flex;
  gap: var(--spacing-xs);
  flex-wrap: wrap;
}

.cc-button-group--vertical {
  flex-direction: column;
}

.cc-button-group--block .cc-button {
  flex: 1;
  min-width: 100%;
}


/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-button {
    /* Ensure touch-friendly on mobile */
    min-height: 44px;
  }

  .cc-button--sm {
    min-height: 40px;
    padding: 0.5rem 1rem;
    font-size: var(--font-size-sm);
  }

  .cc-button--lg {
    min-height: 48px;
    padding: 0.875rem 1.5rem;
    font-size: var(--font-size-base);
  }

  /* Stack buttons vertically on small screens */
  .cc-button-group {
    flex-direction: column;
  }

  .cc-button-group .cc-button {
    width: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-button {
    transition: none;
  }

  .cc-button--loading .cc-button__icon {
    animation: none;
  }
}


/* ============================================
   ANIMATIONS
   ============================================ */

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* Ripple effect on click (subtle interaction) */
@keyframes ripple {
  to {
    transform: scale(4);
    opacity: 0;
  }
}


/* ============================================
   LEGACY ALIASES (.cc-btn)
   ============================================ */

.cc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-xs);
  min-height: 44px;
  padding: 0.75rem 1.5rem;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  line-height: 1.5;
  letter-spacing: var(--letter-spacing-normal);
  text-decoration: none;
  text-align: center;
  white-space: nowrap;
  border: var(--border-width-base) solid transparent;
  border-radius: var(--border-radius-md);
  cursor: pointer;
  transition: var(--transition-base);
  transition-property: background-color, border-color, color, box-shadow, transform;
}

.cc-btn-primary,
.cc-btn--primary {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

.cc-btn-primary:hover,
.cc-btn--primary:hover {
  background-color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.cc-btn-secondary,
.cc-btn--secondary {
  background-color: var(--color-bg-alt);
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.cc-btn-secondary:hover,
.cc-btn--secondary:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.cc-btn-outline {
  background-color: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.cc-btn-outline:hover {
  background-color: var(--color-primary-light);
  color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
}

.cc-btn--large {
  padding: var(--spacing-lg) var(--spacing-xl);
  font-size: var(--font-size-lg);
}

.cc-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}


/* ============================================
   DARK MODE SUPPORT (Future)
   ============================================ */

/* Placeholder for dark mode styling */
@media (prefers-color-scheme: dark) {
  /* Dark mode variants would be defined here */
  /* Currently using CSS variables that support light mode only */
}

/* Source: components/base/badge.css */
/**
 * Badge Component
 * ===============
 * Status badges, labels, and tag styling
 * BEM naming convention: .cc-badge, .cc-badge--type, .cc-badge__icon
 *
 * Types: success, warning, error, info, neutral (default)
 * Sizes: sm, md (default), lg
 * Features: Icon support, close button, pill variant
 * Variants: filled (default), outline
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE BADGE STYLES
   ============================================ */

.cc-badge {
  /* Display & Layout */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2xs);

  /* Typography */
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  text-decoration: none;

  /* Appearance */
  padding: 0.25rem 0.75rem;
  border-radius: var(--border-radius-md);
  border: var(--border-width-thin) solid transparent;

  /* Cursor and interaction */
  cursor: default;
  white-space: nowrap;

  /* Transitions */
  transition: var(--transition-colors);

  /* Prevent text selection */
  user-select: none;
}

/* Remove default anchor styling if used as a link */
.cc-badge[href] {
  cursor: pointer;
}

.cc-badge[href]:hover {
  opacity: 0.85;
}


/* ============================================
   BADGE TYPES (Color Variants)
   ============================================ */

/* Neutral Badge - Default (Gray) */
.cc-badge--neutral {
  background-color: var(--color-gray-100);
  color: var(--color-gray-700);
  border-color: var(--color-gray-300);
}

.cc-badge--neutral.cc-badge--outline {
  background-color: transparent;
  border-color: var(--color-gray-400);
}

/* Success Badge - Green */
.cc-badge--success {
  background-color: #d4edda;
  color: #155724;
  border-color: #c3e6cb;
}

.cc-badge--success.cc-badge--outline {
  background-color: transparent;
  color: #155724;
  border-color: #155724;
}

/* Warning Badge - Yellow/Amber */
.cc-badge--warning {
  background-color: #fff3cd;
  color: #856404;
  border-color: #ffeeba;
}

.cc-badge--warning.cc-badge--outline {
  background-color: transparent;
  color: #856404;
  border-color: #856404;
}

/* Error/Danger Badge - Red */
.cc-badge--error,
.cc-badge--danger {
  background-color: #f8d7da;
  color: #721c24;
  border-color: #f5c6cb;
}

.cc-badge--error.cc-badge--outline,
.cc-badge--danger.cc-badge--outline {
  background-color: transparent;
  color: #721c24;
  border-color: #721c24;
}

/* Info Badge - Blue */
.cc-badge--info {
  background-color: #d1ecf1;
  color: #0c5460;
  border-color: #bee5eb;
}

.cc-badge--info.cc-badge--outline {
  background-color: transparent;
  color: #0c5460;
  border-color: #0c5460;
}

/* Primary Brand Badge - Uses primary color */
.cc-badge--primary {
  background-color: var(--color-primary-light);
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.cc-badge--primary.cc-badge--outline {
  background-color: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

/* Secondary Brand Badge */
.cc-badge--secondary {
  background-color: #e3f2fd;
  color: var(--color-secondary);
  border-color: var(--color-secondary);
}

.cc-badge--secondary.cc-badge--outline {
  background-color: transparent;
  color: var(--color-secondary);
  border-color: var(--color-secondary);
}


/* ============================================
   BADGE SIZES
   ============================================ */

/* Small Badge */
.cc-badge--sm {
  padding: 0.1875rem 0.5rem;
  font-size: 0.6875rem;
  gap: var(--spacing-2xs);
}

/* Medium Badge - Default */
.cc-badge--md {
  padding: 0.25rem 0.75rem;
  font-size: var(--font-size-xs);
}

/* Large Badge */
.cc-badge--lg {
  padding: 0.375rem 1rem;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}


/* ============================================
   BADGE ICON SUPPORT
   ============================================ */

.cc-badge__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1em;
  height: 1em;
  flex-shrink: 0;
}

/* Icon positioned before text */
.cc-badge__icon--left {
  order: -1;
  margin-right: var(--spacing-2xs);
}

/* Icon positioned after text */
.cc-badge__icon--right {
  order: 1;
  margin-left: var(--spacing-2xs);
}

/* Icon only badge */
.cc-badge--icon-only {
  padding: 0.25rem;
  width: 1.75rem;
  height: 1.75rem;
}

.cc-badge--icon-only.cc-badge--sm {
  width: 1.5rem;
  height: 1.5rem;
  padding: 0.1875rem;
}

.cc-badge--icon-only.cc-badge--lg {
  width: 2rem;
  height: 2rem;
  padding: 0.375rem;
}


/* ============================================
   BADGE VARIANTS
   ============================================ */

/* Pill Badge - Fully rounded */
.cc-badge--pill {
  border-radius: var(--border-radius-full);
  padding-left: 0.875rem;
  padding-right: 0.875rem;
}

.cc-badge--pill.cc-badge--sm {
  padding-left: 0.625rem;
  padding-right: 0.625rem;
}

.cc-badge--pill.cc-badge--lg {
  padding-left: 1.125rem;
  padding-right: 1.125rem;
}

/* Solid variant - High contrast (default for non-outline) */
.cc-badge--solid {
  /* Default behavior - no additional styles needed */
}

/* Light variant - Softer colors */
.cc-badge--light {
  opacity: 0.8;
}

/* Dot variant - Just a colored dot */
.cc-badge--dot {
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  padding: 0;
  border-radius: var(--border-radius-full);
  vertical-align: middle;
  margin: 0 var(--spacing-xs);
}


/* ============================================
   CLOSE BUTTON
   ============================================ */

.cc-badge__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25em;
  height: 1.25em;
  margin-left: var(--spacing-2xs);
  padding: 0;
  border: none;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-size: 1.2em;
  line-height: 1;
  opacity: 0.7;
  transition: opacity 0.2s;
  flex-shrink: 0;
}

.cc-badge__close:hover {
  opacity: 1;
}

.cc-badge__close:focus-visible {
  outline: 1px solid currentColor;
  outline-offset: 2px;
}

/* Close button styling specific to badge types */
.cc-badge--success .cc-badge__close:hover {
  color: #155724;
  opacity: 1;
}

.cc-badge--warning .cc-badge__close:hover {
  color: #856404;
  opacity: 1;
}

.cc-badge--error .cc-badge__close:hover {
  color: #721c24;
  opacity: 1;
}

.cc-badge--info .cc-badge__close:hover {
  color: #0c5460;
  opacity: 1;
}


/* ============================================
   BADGE STATES
   ============================================ */

/* Dismissible badge animation */
.cc-badge--dismissible {
  animation: slideOut 0.3s ease-out forwards;
}

@keyframes slideOut {
  0% {
    opacity: 1;
    transform: translateX(0) scaleX(1);
  }

  100% {
    opacity: 0;
    transform: translateX(-10px) scaleX(0);
  }
}

/* Badge counter - numeric counts */
.cc-badge--counter {
  min-width: 1.5rem;
  text-align: center;
  padding: 0.125rem 0.375rem;
}

/* Notification badge - typically positioned absolutely */
.cc-badge--notification {
  position: absolute;
  min-width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border-radius: var(--border-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  z-index: var(--z-dropdown);
}

/* Animation for notification badge */
@keyframes badgePulse {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.1);
  }

  100% {
    transform: scale(1);
  }
}

.cc-badge--notification.cc-badge--pulse {
  animation: badgePulse 2s ease-in-out infinite;
}


/* ============================================
   BADGE GROUPS
   ============================================ */

.cc-badge-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  align-items: center;
}

.cc-badge-list--vertical {
  flex-direction: column;
  align-items: flex-start;
}

.cc-badge-list--inline {
  display: flex;
  gap: var(--spacing-2xs);
}


/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-badge--lg {
    padding: 0.25rem 0.75rem;
    font-size: var(--font-size-xs);
  }

  .cc-badge--pill.cc-badge--lg {
    padding-left: 0.875rem;
    padding-right: 0.875rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-badge {
    transition: none;
  }

  .cc-badge__close {
    transition: none;
  }

  .cc-badge--dismissible {
    animation: none;
  }

  .cc-badge--notification.cc-badge--pulse {
    animation: none;
  }
}

/* Source: components/base/card.css */
/**
 * Card Component
 * ==============
 * Flexible card container for displaying content blocks
 * BEM naming convention: .cc-card, .cc-card__image, .cc-card__content, etc.
 *
 * Features: Image support, content sections, hover effects
 * Variants: hoverable (default), clickable, no-border
 * Responsive: Adaptive padding on mobile, flexible image sizing
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE CARD STYLES
   ============================================ */

.cc-card {
  /* Layout */
  display: flex;
  flex-direction: column;
  height: 100%;

  /* Appearance */
  background-color: var(--color-white);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-lg);

  /* Spacing */
  padding: var(--spacing-lg);

  /* Transitions */
  transition: var(--transition-base);
  transition-property: border-color, box-shadow, transform;

  /* Overflow handling */
  overflow: hidden;

  /* Remove any default list styling if used in lists */
  list-style: none;
}

/* Default hover effect - lift and shadow */
.cc-card--hoverable {
  cursor: pointer;
}

.cc-card--hoverable:hover {
  border-color: var(--color-border-hover);
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

.cc-card--hoverable:focus-within {
  border-color: var(--color-border-hover);
  box-shadow: var(--shadow-hover);
}

/* Clickable variant - entire card is a link */
.cc-card--clickable {
  text-decoration: none;
  color: inherit;
}

.cc-card--clickable:hover,
.cc-card--clickable:focus {
  border-color: var(--color-border-hover);
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

/* Remove border variant */
.cc-card--no-border {
  border-color: transparent;
  box-shadow: var(--shadow-sm);
}

.cc-card--no-border:hover {
  box-shadow: var(--shadow-md);
}

/* Flat variant - no shadow or border */
.cc-card--flat {
  border-color: transparent;
  background-color: var(--color-bg-alt);
  box-shadow: none;
}

.cc-card--flat:hover {
  background-color: var(--color-bg-section);
}


/* ============================================
   CARD SECTIONS
   ============================================ */

/* Card Image Container */
.cc-card__image {
  /* Reset margins and padding */
  margin: -var(--spacing-lg) -var(--spacing-lg) var(--spacing-lg) -var(--spacing-lg);
  padding: 0;
  width: calc(100% + 2 * var(--spacing-lg));

  /* Aspect ratio for consistent sizing */
  aspect-ratio: 16 / 9;

  /* Image sizing */
  overflow: hidden;
  background-color: var(--color-gray-100);
  background-size: cover;
  background-position: center;
}

.cc-card__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* Image variants */
.cc-card__image--sm {
  aspect-ratio: 4 / 3;
  margin-bottom: var(--spacing-md);
}

.cc-card__image--md {
  aspect-ratio: 16 / 9;
  margin-bottom: var(--spacing-lg);
}

.cc-card__image--lg {
  aspect-ratio: 2 / 1;
  margin-bottom: var(--spacing-xl);
}

.cc-card__image--square {
  aspect-ratio: 1 / 1;
}

.cc-card__image--tall {
  aspect-ratio: 3 / 4;
}

/* Badge overlay on image */
.cc-card__image .cc-badge {
  position: absolute;
  top: var(--spacing-md);
  right: var(--spacing-md);
  z-index: var(--z-dropdown);
}


/* Card Content Container */
.cc-card__content {
  /* Layout - takes up remaining space */
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.cc-card__body {
  flex: 1;
}


/* Card Title */
.cc-card__title {
  /* Typography */
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-snug);
  color: var(--color-heading);

  /* Spacing */
  margin: 0;
  padding: 0;
  word-wrap: break-word;

  /* Multi-line text handling */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Title link styling */
.cc-card__title a {
  color: inherit;
  text-decoration: none;
}

.cc-card__title a:hover {
  color: var(--color-primary);
}


/* Card Description/Body Text */
.cc-card__description,
.cc-card__text {
  /* Typography */
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text-secondary);

  /* Spacing */
  margin: 0;
  padding: 0;

  /* Multi-line text handling - optional truncation */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Metadata/Meta information */
.cc-card__meta {
  /* Typography */
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);

  /* Spacing */
  margin-top: var(--spacing-sm);
  display: flex;
  gap: var(--spacing-md);
  align-items: center;
}

.cc-card__meta-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-2xs);
}


/* Card Footer */
.cc-card__footer {
  /* Spacing - separate from content */
  margin-top: var(--spacing-lg);
  padding-top: var(--spacing-lg);
  border-top: var(--border-width-thin) solid var(--color-border-light);

  /* Layout */
  display: flex;
  gap: var(--spacing-md);
  align-items: center;
  justify-content: space-between;
}

/* Footer without top border */
.cc-card__footer--no-border {
  border-top: none;
  margin-top: var(--spacing-md);
  padding-top: 0;
}

/* Multiple actions in footer */
.cc-card__footer-actions {
  display: flex;
  gap: var(--spacing-sm);
  margin-left: auto;
}

.cc-card__footer-actions .cc-button {
  flex-shrink: 0;
}


/* ============================================
   CARD STATES
   ============================================ */

/* Selected/Active state */
.cc-card--selected {
  border-color: var(--color-primary);
  background-color: var(--color-primary-light);
}

/* Disabled state */
.cc-card--disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
}

/* Loading state */
.cc-card--loading {
  opacity: 0.8;
  position: relative;
}

.cc-card--loading::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-dropdown);
}


/* ============================================
   CARD LAYOUTS
   ============================================ */

/* Horizontal Layout - Image left, content right */
.cc-card--horizontal {
  flex-direction: row;
  gap: var(--spacing-lg);
}

.cc-card--horizontal .cc-card__image {
  margin: -var(--spacing-lg) 0 -var(--spacing-lg) -var(--spacing-lg);
  width: 40%;
  flex-shrink: 0;
  aspect-ratio: auto;
  height: auto;
  min-height: 200px;
}

.cc-card--horizontal .cc-card__content {
  flex: 1;
}

/* Two-column card layout */
.cc-card--split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
}

.cc-card--split .cc-card__image {
  margin: -var(--spacing-lg) 0 -var(--spacing-lg) -var(--spacing-lg);
  width: calc(100% + var(--spacing-lg));
}

/* Minimal card - reduced padding */
.cc-card--minimal {
  padding: var(--spacing-md);
}

.cc-card--minimal .cc-card__image {
  margin: -var(--spacing-md) -var(--spacing-md) var(--spacing-md) -var(--spacing-md);
  width: calc(100% + 2 * var(--spacing-md));
}

/* Compact card - no image, minimal spacing */
.cc-card--compact {
  padding: var(--spacing-md);
}

.cc-card--compact .cc-card__title {
  font-size: var(--font-size-base);
}

.cc-card--compact .cc-card__description {
  display: none;
}


/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-card {
    padding: var(--spacing-md);
  }

  .cc-card__image {
    margin: -var(--spacing-md) -var(--spacing-md) var(--spacing-md) -var(--spacing-md);
    width: calc(100% + 2 * var(--spacing-md));
    aspect-ratio: 4 / 3;
  }

  .cc-card--horizontal {
    flex-direction: column;
    gap: var(--spacing-md);
  }

  .cc-card--horizontal .cc-card__image {
    width: 100%;
    aspect-ratio: 4 / 3;
    margin: -var(--spacing-md) -var(--spacing-md) var(--spacing-md) -var(--spacing-md);
  }

  .cc-card--split {
    grid-template-columns: 1fr;
  }

  .cc-card__title {
    font-size: var(--font-size-base);
  }

  .cc-card__description {
    -webkit-line-clamp: 2;
  }

  .cc-card__footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .cc-card__footer-actions {
    width: 100%;
  }

  .cc-card__footer-actions .cc-button {
    flex: 1;
  }
}

@media (max-width: 480px) {
  .cc-card {
    padding: var(--spacing-sm);
  }

  .cc-card__image {
    margin: -var(--spacing-sm) -var(--spacing-sm) var(--spacing-sm) -var(--spacing-sm);
    width: calc(100% + 2 * var(--spacing-sm));
    aspect-ratio: 1 / 1;
  }

  .cc-card__title {
    font-size: var(--font-size-base);
    -webkit-line-clamp: 1;
  }

  .cc-card__description {
    -webkit-line-clamp: 1;
  }

  .cc-card__meta {
    flex-direction: column;
    gap: var(--spacing-xs);
    font-size: var(--font-size-2xs);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-card {
    transition: none;
  }
}

/* Source: components/base/icon-box.css */
/**
 * Icon Box Component
 * ==================
 * Feature displays with icon, title, description, and optional CTA
 * BEM naming convention: .cc-icon-box, .cc-icon-box__icon, .cc-icon-box__content
 *
 * Features: Icon positioning (top, left, right), circular backgrounds
 * Icon Positions: top (default), left, right
 * Responsive: Stack vertically on mobile, icon size adjusts
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE ICON BOX STYLES
   ============================================ */

.cc-icon-box {
  /* Layout & Display */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: var(--spacing-lg);
  text-align: center;

  /* Height - Fill container */
  height: 100%;
  min-height: auto;

  /* Spacing */
  padding: 0;

  /* Typography reset */
  color: inherit;
}

/* Icon Box Container - Wrapper for spacing adjustments */
.cc-icon-box__wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-lg);
  width: 100%;
}


/* ============================================
   ICON ELEMENT
   ============================================ */

.cc-icon-box__icon {
  /* Display & Sizing */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 70px;
  height: 70px;
  flex-shrink: 0;

  /* Appearance */
  background: transparent;
  color: var(--color-primary);
  border-radius: var(--border-radius-md);

  /* Typography for icon fonts */
  font-size: 2rem;
  line-height: 1;

  /* Transitions */
  transition: var(--transition-base);

  /* Remove any default button/link styling */
  border: none;
}

/* Icon circle background variant */
.cc-icon-box__icon--circle {
  border-radius: var(--border-radius-full);
}

/* Icon with background circle */
.cc-icon-box__icon--with-bg,
.cc-icon-box--with-bg .cc-icon-box__icon {
  background-color: var(--color-primary-light);
  border: 2px solid transparent;
  transition: var(--transition-base);
}

.cc-icon-box__icon--with-bg:hover,
.cc-icon-box--with-bg .cc-icon-box__icon:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  transform: scale(1.1);
}

/* Gradient background variant */
.cc-icon-box__icon--gradient {
  background: linear-gradient(
    135deg,
    var(--color-primary) 0%,
    var(--color-secondary) 100%
  );
  color: var(--color-white);
}

/* Icon sizing variants */
.cc-icon-box__icon--sm {
  width: 50px;
  height: 50px;
  font-size: 1.5rem;
}

.cc-icon-box__icon--md {
  width: 70px;
  height: 70px;
  font-size: 2rem;
}

.cc-icon-box__icon--lg {
  width: 90px;
  height: 90px;
  font-size: 2.5rem;
}

.cc-icon-box__icon--xl {
  width: 110px;
  height: 110px;
  font-size: 3rem;
}

/* SVG and IMG icon sizing */
.cc-icon-box__icon svg,
.cc-icon-box__icon img {
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}


/* ============================================
   CONTENT SECTION
   ============================================ */

.cc-icon-box__content {
  /* Layout */
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  width: 100%;

  /* Text alignment inherited from parent */
}

/* Icon Box Title */
.cc-icon-box__title {
  /* Typography */
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-snug);
  color: var(--color-heading);

  /* Spacing */
  margin: 0;
  padding: 0;
  word-wrap: break-word;
}

/* Icon Box Description */
.cc-icon-box__description {
  /* Typography */
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text-secondary);

  /* Spacing */
  margin: 0;
  padding: 0;

  /* Text handling */
  max-width: 600px;
  word-wrap: break-word;
}

/* Icon Box Link/CTA */
.cc-icon-box__link {
  /* Will be styled with .cc-button classes */
  align-self: center;
  margin-top: var(--spacing-sm);
}


/* ============================================
   ICON POSITIONS
   ============================================ */

/* Icon Top - Default (icon centered above content) */
.cc-icon-box--icon-top,
.cc-icon-box {
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.cc-icon-box--icon-top .cc-icon-box__icon,
.cc-icon-box .cc-icon-box__icon {
  margin-bottom: 0;
}

/* Icon Left - Icon on left, content on right */
.cc-icon-box--icon-left {
  flex-direction: row;
  align-items: flex-start;
  text-align: left;
  gap: var(--spacing-lg);
}

.cc-icon-box--icon-left .cc-icon-box__icon {
  margin-top: var(--spacing-sm);
  flex-shrink: 0;
}

.cc-icon-box--icon-left .cc-icon-box__content {
  flex: 1;
}

/* Icon Right - Icon on right, content on left */
.cc-icon-box--icon-right {
  flex-direction: row-reverse;
  align-items: flex-start;
  text-align: left;
  gap: var(--spacing-lg);
}

.cc-icon-box--icon-right .cc-icon-box__icon {
  margin-top: var(--spacing-sm);
  flex-shrink: 0;
}

.cc-icon-box--icon-right .cc-icon-box__content {
  flex: 1;
}

/* Icon Center - Icon inline with title */
.cc-icon-box--icon-inline {
  flex-direction: row;
  align-items: center;
  text-align: left;
}

.cc-icon-box--icon-inline .cc-icon-box__icon {
  width: 40px;
  height: 40px;
  font-size: 1.25rem;
  margin-right: var(--spacing-md);
}


/* ============================================
   ICON BOX VARIANTS
   ============================================ */

/* With Background variant */
.cc-icon-box--with-bg .cc-icon-box__icon {
  background-color: var(--color-primary-light);
}

/* No Link variant - removes spacing for CTA */
.cc-icon-box--no-link .cc-icon-box__link {
  display: none;
}

/* Hover Effects */
.cc-icon-box--hoverable {
  transition: var(--transition-base);
  cursor: pointer;
  padding: var(--spacing-lg);
  border-radius: var(--border-radius-lg);
  background-color: transparent;
}

.cc-icon-box--hoverable:hover {
  background-color: var(--color-bg-alt);
  transform: translateY(-4px);
}

.cc-icon-box--hoverable:hover .cc-icon-box__icon {
  color: var(--color-primary-dark);
  transform: scale(1.1);
}

.cc-icon-box--hoverable:hover .cc-icon-box__title {
  color: var(--color-primary);
}

/* Bordered variant */
.cc-icon-box--bordered {
  padding: var(--spacing-lg);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-lg);
}

.cc-icon-box--bordered.cc-icon-box--hoverable:hover {
  border-color: var(--color-primary);
}

/* Highlight variant - bright background */
.cc-icon-box--highlight {
  padding: var(--spacing-lg);
  background-color: var(--color-bg-section);
  border-radius: var(--border-radius-lg);
}


/* ============================================
   COLOR VARIANTS
   ============================================ */

/* Success variant */
.cc-icon-box--success .cc-icon-box__icon {
  color: #28a745;
}

.cc-icon-box--success .cc-icon-box__icon--with-bg {
  background-color: #d4edda;
}

.cc-icon-box--success .cc-icon-box__title {
  color: #155724;
}

/* Warning variant */
.cc-icon-box--warning .cc-icon-box__icon {
  color: #ff9800;
}

.cc-icon-box--warning .cc-icon-box__icon--with-bg {
  background-color: #fff3cd;
}

.cc-icon-box--warning .cc-icon-box__title {
  color: #856404;
}

/* Error variant */
.cc-icon-box--error .cc-icon-box__icon {
  color: #dc3545;
}

.cc-icon-box--error .cc-icon-box__icon--with-bg {
  background-color: #f8d7da;
}

.cc-icon-box--error .cc-icon-box__title {
  color: #721c24;
}

/* Info variant */
.cc-icon-box--info .cc-icon-box__icon {
  color: #17a2b8;
}

.cc-icon-box--info .cc-icon-box__icon--with-bg {
  background-color: #d1ecf1;
}

.cc-icon-box--info .cc-icon-box__title {
  color: #0c5460;
}


/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 1024px) {
  /* Stack horizontally on tablets */
  .cc-icon-box--icon-left,
  .cc-icon-box--icon-right {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--spacing-lg);
  }

  .cc-icon-box--icon-left .cc-icon-box__content,
  .cc-icon-box--icon-right .cc-icon-box__content {
    flex: 1;
  }

  .cc-icon-box__title {
    font-size: var(--font-size-lg);
  }
}

@media (max-width: 768px) {
  /* Stack all positions vertically on mobile */
  .cc-icon-box,
  .cc-icon-box--icon-top,
  .cc-icon-box--icon-left,
  .cc-icon-box--icon-right,
  .cc-icon-box--icon-inline {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--spacing-md);
  }

  .cc-icon-box__icon {
    width: 60px;
    height: 60px;
    font-size: 1.75rem;
  }

  .cc-icon-box__title {
    font-size: var(--font-size-lg);
  }

  .cc-icon-box__description {
    font-size: var(--font-size-base);
  }

  .cc-icon-box--bordered,
  .cc-icon-box--highlight {
    padding: var(--spacing-md);
  }

  .cc-icon-box--hoverable {
    padding: var(--spacing-md);
  }
}

@media (max-width: 480px) {
  .cc-icon-box__icon {
    width: 50px;
    height: 50px;
    font-size: 1.5rem;
  }

  .cc-icon-box__icon--sm {
    width: 40px;
    height: 40px;
    font-size: 1.25rem;
  }

  .cc-icon-box__icon--lg {
    width: 70px;
    height: 70px;
    font-size: 2rem;
  }

  .cc-icon-box__icon--xl {
    width: 80px;
    height: 80px;
    font-size: 2.25rem;
  }

  .cc-icon-box__title {
    font-size: var(--font-size-base);
  }

  .cc-icon-box__description {
    font-size: var(--font-size-sm);
  }

  .cc-icon-box__link {
    width: 100%;
  }

  .cc-icon-box__link .cc-button {
    width: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-icon-box,
  .cc-icon-box__icon,
  .cc-icon-box--hoverable {
    transition: none;
  }

  .cc-icon-box--hoverable:hover .cc-icon-box__icon {
    transform: none;
  }

  .cc-icon-box--hoverable:hover {
    transform: none;
  }
}

/* Source: components/sections/hero.css */
/**
 * Hero Section Component Styles
 *
 * Shared styles for cc-hero component used on archive and single templates.
 * Based on the Sacramento Food Bank hero layout (full-width gradient, breadcrumbs,
 * title, supporting text, and CTA buttons).
 */

.cc-hero {
  position: relative;
  width: 100vw;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  margin-top: -100px;
  padding-top: 100px;
  color: #fff;
  overflow: hidden;
  z-index: 1;
}

.cc-hero__background,
.cc-hero__overlay {
  position: absolute;
  inset: 0;
}

.cc-hero__background {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.cc-hero__overlay {
  mix-blend-mode: normal;
}

/* Gradient overlay that blends into marquee blue */
.cc-hero__overlay::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 60%;
  background: linear-gradient(to bottom, transparent 0%, rgba(47, 64, 137, 0.3) 40%, rgba(47, 64, 137, 0.7) 80%, #2f4089 100%);
  pointer-events: none;
  z-index: 1;
}

/* Height variants */
.cc-hero--full .cc-hero__content {
  padding: 4rem 0;
}

.cc-hero--large .cc-hero__content {
  padding: 3.5rem 0;
}

.cc-hero--medium .cc-hero__content {
  padding: 3rem 0;
}

.cc-hero__content {
  position: relative;
  z-index: 1;
}

.cc-hero__inner {
  width: min(1100px, 100% - 3rem);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
}

/* Alignment modifiers */
.cc-hero__content--center .cc-hero__inner {
  align-items: center;
  text-align: center;
}

.cc-hero__content--right .cc-hero__inner {
  align-items: flex-end;
  text-align: right;
}

/* Breadcrumbs inside hero */
.cc-hero__breadcrumbs {
  margin-bottom: var(--spacing-lg);
}

.cc-hero .cc-breadcrumb {
  padding-top: 0;
  padding-bottom: 0;
  color: #ffffff;
  font-weight: var(--font-weight-semibold);
}

.cc-hero .cc-breadcrumb__link {
  color: #ffffff;
  font-weight: var(--font-weight-semibold);
}

.cc-hero .cc-breadcrumb__link:hover,
.cc-hero .cc-breadcrumb__link:focus-visible {
  color: #ffffff;
}

/* Ensure visited breadcrumb links are also white inside hero */
.cc-hero .cc-breadcrumb__link:visited {
  color: #ffffff;
}



.cc-hero .cc-breadcrumb__separator {
  color: rgba(255, 255, 255, 0.6);
}

/* Title, subtitle, description */
.cc-hero .cc-hero__title {
  font-size: var(--font-size-5xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: #ffffff;
  margin: 0 0 var(--spacing-md);
}

.cc-hero .cc-hero__title i {
  margin-right: var(--spacing-sm);
}

.cc-hero .cc-hero__subtitle {
  font-size: var(--font-size-xl);
  margin: 0 0 var(--spacing-md);
  color: #ffffff;
}

.cc-hero .cc-hero__description {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
  max-width: 46rem;
  margin: 0 0 var(--spacing-lg);
  color: #ffffff;
}

/* Actions */
.cc-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-md);
}

.cc-hero__actions .cc-button {
  display: inline-flex;
  align-items: center;
}

/* Responsive adjustments */
@media (max-width: 1024px) {
  .cc-hero {
    height: auto !important;
    min-height: auto !important;
  }

  .cc-hero--full .cc-hero__content,
  .cc-hero--large .cc-hero__content,
  .cc-hero--medium .cc-hero__content {
    padding: 0.5rem 0 2rem; /* Significantly reduced top padding */
  }

  .cc-hero__inner {
    width: min(100%, 100% - 5rem); /* 30pt (~40px) per side = 80px total = 5rem */
  }

  .cc-hero__content--left .cc-hero__inner,
  .cc-hero__content--center .cc-hero__inner,
  .cc-hero__content--right .cc-hero__inner {
    align-items: flex-start;
    text-align: left;
  }

  .cc-hero__title {
    font-size: 2rem; /* Reduced from 2.5rem */
    margin-bottom: 0.5rem;
    line-height: 1.1;
  }

  .cc-hero__subtitle {
    font-size: 1rem;
    margin-bottom: 0.5rem;
    line-height: 1.3;
  }

  .cc-hero__description {
    font-size: 0.9375rem;
    margin-bottom: 1rem;
    line-height: 1.5;
  }

  .cc-hero__actions {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
    margin-top: 0.5rem;
  }
  
  .cc-hero__actions .cc-button {
    width: 100%;
    justify-content: center;
    padding: 0.75rem 1rem;
  }

  /* Compact breadcrumbs for mobile */
  .cc-hero__breadcrumbs {
    margin-bottom: 0.5rem;
    font-size: 0.8125rem;
  }
}

/* Source: components/content/grid-layouts.css */
/**
 * Grid Layouts Component
 * ======================
 * Responsive grid layouts for displaying content cards
 * BEM naming convention: .cc-grid, .cc-grid--*, .cc-grid__*
 *
 * Variants: 2-col, 3-col, 4-col, masonry, equal-height
 * Features: Responsive breakpoints, filter controls, sorting
 * Responsive: Adapts from 4-col to 1-col as screen shrinks
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE GRID STYLES
   ============================================ */

.cc-grid {
  /* Display */
  display: grid;

  /* Default: 3 columns */
  grid-template-columns: repeat(3, 1fr);

  /* Spacing */
  gap: var(--gap-lg);
  margin: 0;
  padding: 0;

  /* List reset */
  list-style: none;
}

.cc-grid__item {
  /* Item styling */
  display: block;
  min-height: 0;

  /* Remove any default margins */
  margin: 0;
  padding: 0;
}

/* ============================================
   GRID COLUMN VARIANTS
   ============================================ */

/* 2 Column Grid */
.cc-grid--cols-2 {
  grid-template-columns: repeat(2, 1fr);
  gap: var(--gap-lg);
}

/* 3 Column Grid - Default */
.cc-grid--cols-3 {
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap-lg);
}

/* 4 Column Grid */
.cc-grid--cols-4 {
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap-lg);
}

/* 5 Column Grid */
.cc-grid--cols-5 {
  grid-template-columns: repeat(5, 1fr);
  gap: var(--gap-lg);
}

/* Single Column */
.cc-grid--cols-1 {
  grid-template-columns: 1fr;
}

/* ============================================
   GRID GAP VARIANTS
   ============================================ */

.cc-grid--gap-sm {
  gap: var(--gap-sm);
}

.cc-grid--gap-md {
  gap: var(--gap-md);
}

.cc-grid--gap-lg {
  gap: var(--gap-lg);
}

.cc-grid--gap-xl {
  gap: var(--gap-xl);
}

.cc-grid--gap-2xl {
  gap: var(--gap-2xl);
}

/* ============================================
   MASONRY GRID LAYOUT
   ============================================ */

.cc-grid--masonry {
  /* Use CSS grid with auto-fit for masonry-like layout */
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--gap-lg);
}

.cc-grid--masonry-2 {
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: var(--gap-lg);
}

/* Column Count for masonry-like effect */
.cc-grid--masonry-3 {
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap-lg);
}

.cc-grid__item--featured {
  /* Featured item spans 2 columns */
  grid-column: span 2;
}

.cc-grid__item--featured.cc-grid--masonry-2 {
  grid-column: span 2;
}

/* ============================================
   EQUAL HEIGHT GRIDS
   ============================================ */

.cc-grid--equal-height .cc-grid__item {
  /* All items have equal height */
  display: flex;
}

.cc-grid--equal-height .cc-grid__item > * {
  /* Card inside takes full height */
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* ============================================
   GRID CONTAINER
   ============================================ */

.cc-grid-container {
  /* Optional wrapper for grid with controls */
  width: 100%;
  max-width: 100%;
}

.cc-grid-container__header {
  /* Header section with filters and sorts */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
  margin-bottom: var(--spacing-2xl);
}

.cc-grid-container__title {
  /* Section title */
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-heading);
  margin: 0;
  padding: 0;
}

.cc-grid-container__controls {
  /* Filter and sort controls */
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--spacing-lg);
}

/* ============================================
   FILTER & SORT CONTROLS
   ============================================ */

.cc-grid-filter {
  /* Filter group */
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-md);
  align-items: center;
}

.cc-grid-filter__label {
  /* Filter label */
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.cc-grid-filter__options {
  /* Filter option list */
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

.cc-grid-filter__option {
  /* Individual filter button */
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1rem;
  background-color: var(--color-bg-alt);
  color: var(--color-text-secondary);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: var(--transition-colors);
  text-decoration: none;
}

.cc-grid-filter__option:hover {
  background-color: var(--color-primary-light);
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.cc-grid-filter__option--active {
  /* Active filter */
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

.cc-grid-filter__option--active:hover {
  background-color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
}

/* Sort dropdown */
.cc-grid-sort {
  /* Sort control wrapper */
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.cc-grid-sort__label {
  /* Sort label */
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  white-space: nowrap;
}

.cc-grid-sort__select {
  /* Sort select element */
  padding: 0.5rem 0.75rem;
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  font-family: var(--font-family-primary);
  color: var(--color-text-secondary);
  background-color: var(--color-white);
  cursor: pointer;
  transition: var(--transition-colors);
}

.cc-grid-sort__select:hover {
  border-color: var(--color-primary);
  background-color: var(--color-primary-light);
}

.cc-grid-sort__select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

/* ============================================
   GRID LOADING & EMPTY STATES
   ============================================ */

.cc-grid--loading {
  /* Loading state */
  opacity: 0.6;
  pointer-events: none;
}

.cc-grid-skeleton {
  /* Skeleton loading placeholder */
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap-lg);
}

.cc-grid-skeleton__item {
  /* Skeleton item */
  background: linear-gradient(
    90deg,
    var(--color-gray-100) 0%,
    var(--color-gray-200) 50%,
    var(--color-gray-100) 100%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--border-radius-lg);
  aspect-ratio: 16 / 9;
}

@keyframes shimmer {
  0% {
    background-position: 200% 0;
  }

  100% {
    background-position: -200% 0;
  }
}

.cc-grid-empty {
  /* Empty state message */
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--spacing-3xl) var(--spacing-lg);
  color: var(--color-text-muted);
}

.cc-grid-empty__icon {
  /* Empty state icon */
  font-size: 3rem;
  margin-bottom: var(--spacing-lg);
  color: var(--color-gray-300);
}

.cc-grid-empty__title {
  /* Empty state title */
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-md);
}

.cc-grid-empty__message {
  /* Empty state message */
  font-size: var(--font-size-base);
  color: var(--color-text-muted);
  margin: 0;
}

/* ============================================
   GRID PAGINATION
   ============================================ */

.cc-grid-pagination {
  /* Pagination wrapper */
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-md);
  margin-top: var(--spacing-2xl);
  padding: var(--spacing-lg);
}

.cc-grid-pagination__item {
  /* Pagination item */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  text-decoration: none;
  color: var(--color-text-secondary);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  font-weight: var(--font-weight-semibold);
  transition: var(--transition-colors);
}

.cc-grid-pagination__item:hover:not(.cc-grid-pagination__item--current) {
  background-color: var(--color-primary-light);
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.cc-grid-pagination__item--current {
  /* Current page */
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

.cc-grid-pagination__item--disabled {
  /* Disabled pagination item */
  opacity: 0.5;
  cursor: not-allowed;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 1200px) {
  .cc-grid--cols-5 {
    grid-template-columns: repeat(4, 1fr);
  }

  .cc-grid--cols-4 {
    grid-template-columns: repeat(3, 1fr);
  }

  .cc-grid--masonry {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  }
}

@media (max-width: 1024px) {
  .cc-grid--cols-4,
  .cc-grid--cols-5 {
    grid-template-columns: repeat(3, 1fr);
  }

  .cc-grid--cols-3 {
    grid-template-columns: repeat(2, 1fr);
  }

  .cc-grid--masonry {
    grid-template-columns: repeat(2, 1fr);
  }

  .cc-grid__item--featured {
    grid-column: span 1;
  }
}

@media (max-width: 768px) {
  .cc-grid--cols-2,
  .cc-grid--cols-3,
  .cc-grid--cols-4,
  .cc-grid--cols-5 {
    grid-template-columns: repeat(2, 1fr);
  }

  .cc-grid--masonry {
    grid-template-columns: 1fr;
  }

  .cc-grid-container__header {
    margin-bottom: var(--spacing-xl);
  }

  .cc-grid-container__controls {
    flex-direction: column;
    align-items: stretch;
  }

  .cc-grid-filter {
    flex-direction: column;
    align-items: stretch;
  }

  .cc-grid-filter__options {
    width: 100%;
  }

  .cc-grid-sort {
    width: 100%;
  }

  .cc-grid-sort__select {
    width: 100%;
  }

  .cc-grid {
    gap: var(--gap-md);
  }

  .cc-grid-skeleton {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--gap-md);
  }
}

@media (max-width: 480px) {
  .cc-grid--cols-1,
  .cc-grid--cols-2,
  .cc-grid--cols-3,
  .cc-grid--cols-4,
  .cc-grid--cols-5 {
    grid-template-columns: 1fr;
  }

  .cc-grid {
    gap: var(--gap-sm);
  }

  .cc-grid-skeleton {
    grid-template-columns: 1fr;
    gap: var(--gap-sm);
  }

  .cc-grid-container__title {
    font-size: var(--font-size-2xl);
  }

  .cc-grid-filter__option {
    padding: 0.375rem 0.75rem;
    font-size: var(--font-size-xs);
  }

  .cc-grid-pagination {
    gap: var(--spacing-sm);
  }

  .cc-grid-pagination__item {
    width: 40px;
    height: 40px;
    font-size: var(--font-size-sm);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-grid-skeleton__item {
    animation: none;
  }

  .cc-grid-filter__option,
  .cc-grid-sort__select {
    transition: none;
  }
}

/* Source: components/content/agency-card.css */
/**
 * Agency Card Component
 * ====================
 * Official reusable agency card component styles
 * Used by: templates/components/content/agency-card.php
 * 
 * Last Updated: 2025-11-15
 * Version: 2.0
 */

/* ============================================
   BASE AGENCY CARD STYLES
   ============================================ */

.agency-card {
    background: var(--color-bg);
    border: var(--border-width-base) solid var(--color-border);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-lg) var(--spacing-xl);
    transition: var(--transition-base);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    box-sizing: border-box;
    box-shadow: var(--shadow-sm);
    height: 100%;
    cursor: pointer;
    position: relative;
}

.agency-card.hidden {
    display: none;
}

.agency-card:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--cc-primary);
}

/* Prevent card click when clicking on links or buttons */
.agency-card a,
.agency-card button {
    position: relative;
    z-index: 2;
    cursor: pointer;
}

/* ============================================
   CARD LOGO
   ============================================ */

.agency-card-logo {
    width: 100%;
    height: auto;
    max-height: 300px; /* Increased from 225px */
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.agency-card-logo img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* ============================================
   CARD HEADER
   ============================================ */

.agency-card-header {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
    width: 100%;
}

.agency-name {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    margin: 0;
    line-height: var(--line-height-tight);
    flex: 1;
}

.agency-name a {
    color: var(--color-text);
    text-decoration: none;
    transition: var(--transition-base);
}

.agency-name a:hover {
    color: var(--cc-primary);
}

/* ============================================
   SERVICE BADGE
   ============================================ */

.service-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--cc-primary);
    color: #ffffff;
    border-radius: var(--border-radius-sm);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    white-space: nowrap;
    min-width: 32px;
    min-height: 32px;
    flex-shrink: 0;
}

.distance-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: linear-gradient(135deg, #0066cc 0%, #0052a3 100%);
    color: #fff;
    border-radius: var(--border-radius-sm);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    white-space: nowrap;
    box-shadow: 0 2px 4px rgba(0, 102, 204, 0.2);
}

.distance-badge i {
    font-size: 0.875em;
}

/* ============================================
   CARD BODY
   ============================================ */

.agency-card-body {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    width: 100%;
}

.agency-info {
    display: flex;
    gap: var(--spacing-sm);
    align-items: flex-start;
    font-size: 1.1rem; /* Increased from sm */
    margin: 0;
}

.agency-info:last-child {
    margin-bottom: 0;
}

.agency-info i {
    color: var(--cc-primary);
    font-size: var(--font-size-base);
    width: 16px;
    flex-shrink: 0;
    margin-top: 2px;
}

.info-content {
    color: var(--color-text-light);
    line-height: var(--line-height-base);
}

.info-content a {
    color: var(--cc-primary);
    text-decoration: none;
}

.info-content a:hover {
    text-decoration: underline;
}

.info-content strong {
    color: var(--color-text);
}

/* ============================================
   CARD FOOTER
   ============================================ */

.agency-card-footer {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-sm);
    padding: 0;
    border: none;
}

.btn-agency-details {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) var(--spacing-lg);
    background: var(--cc-primary);
    color: var(--color-bg);
    border-radius: var(--border-radius-md);
    font-size: 1rem; /* Increased from sm */
    font-weight: var(--font-weight-semibold);
    text-decoration: none;
    transition: var(--transition-base);
    width: 100%;
}

.btn-agency-details:hover {
    background: var(--cc-primary-dark);
}

.btn-agency-website {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) var(--spacing-lg);
    background: var(--color-bg-alt);
    color: var(--color-text-light);
    border: var(--border-width-base) solid var(--color-border);
    border-radius: var(--border-radius-md);
    font-size: 1rem; /* Increased from sm */
    font-weight: var(--font-weight-semibold);
    text-decoration: none;
    transition: var(--transition-base);
    width: 100%;
}

.btn-agency-website:hover {
    background: var(--color-bg);
    color: var(--cc-primary);
    border-color: var(--cc-primary);
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 1024px) {
    .agency-card {
        padding: var(--spacing-md) var(--spacing-lg);
    }
    
    .agency-card-header {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .agency-card-body {
        gap: var(--spacing-xs);
    }
    
    .agency-card-footer {
        flex-direction: column;
    }
    
    .btn-agency-details,
    .btn-agency-website {
        width: 100%;
    }
}

@media (max-width: 768px) {
    .agency-card {
        padding: var(--spacing-md);
    }
    
    .agency-card-header {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .agency-name {
        font-size: var(--font-size-lg);
    }
    
    .agency-card-body {
        gap: var(--spacing-xs);
    }
    
    .agency-info {
        font-size: var(--font-size-xs);
    }
    
    .agency-card-footer {
        flex-direction: column;
    }
    
    .btn-agency-details,
    .btn-agency-website {
        width: 100%;
        justify-content: center;
    }
}

/* Source: components/content/service-card.css */
/**
 * Service Card Component
 * ======================
 * Display service information with icon, description, link
 * Simple anchor-based component structure
 *
 * Last Updated: 2025-01-XX
 * Version: 2.0
 */

/* ============================================
   SIMPLE SERVICE CARD STYLES (NEW)
   ============================================ */

/* Service Card - Simple Link-based Component */
.service-card {
  background: var(--color-bg, #fff);
  border: var(--border-width-base, 1px) solid var(--color-border, #e5e7eb);
  border-radius: var(--border-radius-lg, 12px);
  padding: var(--spacing-xl, 2rem);
  text-decoration: none;
  color: inherit;
  transition: var(--transition-base, all 0.3s ease);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md, 1rem);
}

.service-card:hover {
  border-color: var(--color-border-hover, #0066cc);
  box-shadow: var(--shadow-hover, 0 8px 24px rgba(0, 102, 204, 0.15));
  transform: translateY(-4px);
}

.service-icon {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, var(--cc-primary, #0066cc) 0%, var(--cc-primary-dark, #0052a3) 100%);
  color: var(--color-bg, #fff);
  border-radius: var(--border-radius-lg, 12px);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-3xl, 1.75rem);
}

.service-name {
  font-size: var(--font-size-2xl, 1.375rem);
  font-weight: var(--font-weight-bold, 700);
  color: var(--color-text, #212529);
  margin: 0;
  line-height: var(--line-height-tight, 1.3);
}

.service-excerpt {
  font-size: var(--font-size-base, 1rem);
  color: var(--color-text-muted, #6c757d);
  line-height: var(--line-height-base, 1.6);
  margin: 0;
  flex-grow: 1;
}

.service-link-text {
  font-size: var(--font-size-base, 1rem);
  font-weight: var(--font-weight-semibold, 600);
  color: var(--cc-primary, #0066cc);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs, 0.5rem);
}

.service-card:hover .service-link-text {
  gap: var(--spacing-sm, 0.75rem);
}

@media (max-width: 768px) {
  .service-card {
    padding: var(--spacing-lg, 1.5rem);
  }
}

/* ============================================
   LEGACY SERVICE CARD STYLES (DEPRECATED)
   BEM naming convention: .cc-service-card, .cc-service-card__*
   ============================================ */

.cc-service-card {
  /* Extends base card component */
  display: flex;
  flex-direction: column;
  height: 100%;

  /* Appearance */
  background-color: var(--color-white);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-lg);
  padding: var(--spacing-lg);

  /* Transitions */
  transition: var(--transition-base);
  transition-property: border-color, box-shadow, transform;

  /* Overflow handling */
  overflow: hidden;
}

/* Default hover effect */
.cc-service-card:hover {
  border-color: var(--color-border-hover);
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

/* ============================================
   SERVICE CARD ICON
   ============================================ */

.cc-service-card__icon {
  /* Display & Sizing */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  margin-bottom: var(--spacing-lg);
  flex-shrink: 0;

  /* Appearance */
  background-color: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--border-radius-md);
  font-size: 1.75rem;

  /* Transitions */
  transition: var(--transition-base);

  /* SVG and IMG sizing */
}

.cc-service-card__icon svg,
.cc-service-card__icon img {
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

/* Icon hover effect */
.cc-service-card:hover .cc-service-card__icon {
  background-color: var(--color-primary);
  color: var(--color-white);
  transform: scale(1.1);
}

/* ============================================
   SERVICE CARD CONTENT
   ============================================ */

.cc-service-card__content {
  /* Layout - expands to fill */
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

/* Service Title */
.cc-service-card__title {
  /* Typography */
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-snug);
  color: var(--color-heading);

  /* Spacing */
  margin: 0;
  padding: 0;

  /* Link styling */
  text-decoration: none;
}

.cc-service-card__title a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-colors);
}

.cc-service-card__title a:hover {
  color: var(--color-primary);
}

/* Service Description */
.cc-service-card__description {
  /* Typography */
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text-secondary);

  /* Spacing */
  margin: 0;
  padding: 0;

  /* Multi-line truncation */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Service Category/Badge */
.cc-service-card__category {
  /* Badge-like styling */
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.75rem;
  background-color: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  width: fit-content;
}

/* ============================================
   SERVICE CARD FOOTER (CTA & RELATED)
   ============================================ */

.cc-service-card__footer {
  /* Layout */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);

  /* Spacing */
  margin-top: auto;
  padding-top: var(--spacing-lg);
  border-top: var(--border-width-thin) solid var(--color-border-light);
}

.cc-service-card__link {
  /* Primary CTA button */
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  text-decoration: none;
  color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
  transition: var(--transition-colors);
}

.cc-service-card__link:hover {
  color: var(--color-primary-dark);
}

.cc-service-card__link-icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

/* Related services list */
.cc-service-card__related {
  /* Layout */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);

  /* Spacing */
  padding-top: var(--spacing-sm);
  border-top: var(--border-width-thin) solid var(--color-border-light);
}

.cc-service-card__related-label {
  /* Typography */
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.cc-service-card__related-items {
  /* Layout */
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
}

.cc-service-card__related-item {
  /* Link styling */
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.5rem;
  background-color: var(--color-gray-100);
  color: var(--color-text-secondary);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-xs);
  text-decoration: none;
  transition: var(--transition-colors);
}

.cc-service-card__related-item:hover {
  background-color: var(--color-primary-light);
  color: var(--color-primary);
}

/* ============================================
   SERVICE CARD VARIANTS
   ============================================ */

/* Grid Variant - Default (card style) */
.cc-service-card--grid {
  /* Icon centered above title */
  text-align: center;
}

.cc-service-card--grid .cc-service-card__icon {
  margin-left: auto;
  margin-right: auto;
}

/* List Variant - Horizontal layout */
.cc-service-card--list {
  flex-direction: row;
  align-items: flex-start;
  gap: var(--spacing-lg);
  padding: var(--spacing-md);
}

.cc-service-card--list .cc-service-card__icon {
  margin-bottom: 0;
  flex-shrink: 0;
  width: 50px;
  height: 50px;
  font-size: 1.5rem;
}

.cc-service-card--list .cc-service-card__content {
  flex: 1;
  text-align: left;
}

.cc-service-card--list .cc-service-card__description {
  -webkit-line-clamp: 2;
}

.cc-service-card--list .cc-service-card__footer {
  flex-direction: row;
  align-items: center;
  padding: 0;
  border: none;
  margin: 0;
}

/* Hero Overlay Variant - Image background with content overlay */
.cc-service-card--hero {
  position: relative;
  min-height: 300px;
  padding: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border: none;
  border-radius: var(--border-radius-lg);
  overflow: hidden;
}

.cc-service-card--hero::before {
  /* Dark overlay */
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(0, 102, 204, 0.9) 0%,
    rgba(0, 82, 163, 0.85) 100%
  );
  z-index: 1;
}

.cc-service-card--hero .cc-service-card__icon {
  background-color: var(--color-white);
  color: var(--color-primary);
  position: relative;
  z-index: 2;
  margin-bottom: var(--spacing-lg);
}

.cc-service-card--hero .cc-service-card__content {
  position: relative;
  z-index: 2;
  color: var(--color-white);
  text-align: center;
}

.cc-service-card--hero .cc-service-card__title {
  color: var(--color-white);
}

.cc-service-card--hero .cc-service-card__title a {
  color: var(--color-white);
}

.cc-service-card--hero .cc-service-card__title a:hover {
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.5);
}

.cc-service-card--hero .cc-service-card__description {
  color: rgba(255, 255, 255, 0.95);
}

.cc-service-card--hero .cc-service-card__category {
  background-color: rgba(255, 255, 255, 0.2);
  color: var(--color-white);
  border: 1px solid rgba(255, 255, 255, 0.3);
  margin-left: auto;
  margin-right: auto;
}

.cc-service-card--hero .cc-service-card__footer {
  border-top-color: rgba(255, 255, 255, 0.2);
}

.cc-service-card--hero .cc-service-card__link {
  color: var(--color-white);
  justify-content: center;
}

.cc-service-card--hero .cc-service-card__link:hover {
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.5);
}

/* ============================================
   SERVICE CARD STATES
   ============================================ */

/* Featured/Popular service */
.cc-service-card--featured {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-lg);
}

/* New/Highlighted service */
.cc-service-card--new {
  position: relative;
}

.cc-service-card--new::after {
  /* "New" indicator */
  content: 'New';
  position: absolute;
  top: var(--spacing-lg);
  right: var(--spacing-lg);
  padding: 0.25rem 0.625rem;
  background-color: #ff9800;
  color: var(--color-white);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  z-index: var(--z-dropdown);
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-service-card {
    padding: var(--spacing-md);
  }

  .cc-service-card--list {
    flex-direction: column;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
  }

  .cc-service-card--list .cc-service-card__icon {
    width: 50px;
    height: 50px;
  }

  .cc-service-card--hero {
    min-height: 250px;
  }

  .cc-service-card__description {
    -webkit-line-clamp: 2;
  }

  .cc-service-card__footer {
    padding-top: var(--spacing-md);
  }
}

@media (max-width: 480px) {
  .cc-service-card {
    padding: var(--spacing-sm);
  }

  .cc-service-card--grid .cc-service-card__icon {
    width: 50px;
    height: 50px;
    font-size: 1.5rem;
    margin-bottom: var(--spacing-md);
  }

  .cc-service-card--list {
    padding: var(--spacing-sm);
  }

  .cc-service-card__title {
    font-size: var(--font-size-base);
  }

  .cc-service-card__description {
    font-size: var(--font-size-sm);
    -webkit-line-clamp: 2;
  }

  .cc-service-card--hero {
    min-height: 200px;
  }

  .cc-service-card__related {
    display: none;
  }

  .cc-service-card--new::after {
    top: var(--spacing-sm);
    right: var(--spacing-sm);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-service-card,
  .cc-service-card__icon,
  .cc-service-card__title a,
  .cc-service-card__link,
  .cc-service-card__related-item {
    transition: none;
  }

  .cc-service-card:hover .cc-service-card__icon {
    transform: none;
  }
}

/* Source: components/content/location-card.css */
/**
 * Location Card Component
 * =======================
 * Display location information with map, address, hours, contact
 * BEM naming convention: .cc-location-card, .cc-location-card__*
 *
 * Features: Map preview, hours display, contact info, directions button
 * Map integration: Leaflet or similar embedded map
 * Responsive: Map adapts to mobile, content stacks
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE LOCATION CARD STYLES
   ============================================ */

.cc-location-card {
  /* Extends base card component */
  display: flex;
  flex-direction: column;
  height: 100%;

  /* Appearance */
  background-color: var(--color-white);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-lg);
  padding: 0;

  /* Transitions */
  transition: var(--transition-base);
  transition-property: border-color, box-shadow, transform;

  /* Overflow handling */
  overflow: hidden;
}

/* Default hover effect */
.cc-location-card:hover {
  border-color: var(--color-border-hover);
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

/* ============================================
   LOCATION CARD MAP
   ============================================ */

.cc-location-card__map {
  /* Map container sizing */
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 200px;

  /* Spacing */
  margin: 0;
  padding: 0;

  /* Background while loading */
  background-color: var(--color-gray-100);

  /* Overflow for proper border radius */
  border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0;
  overflow: hidden;
}

/* Map iframe and embed styling */
.cc-location-card__map iframe,
.cc-location-card__map embed {
  display: block;
  width: 100%;
  height: 100%;
  border: none;
}

/* Map zoom controls visibility */
.cc-location-card__map .leaflet-control-zoom {
  opacity: 0.9;
}

/* Map marker styling (Leaflet) */
.cc-location-card__map .leaflet-marker-icon {
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2));
}

/* ============================================
   LOCATION CARD CONTENT
   ============================================ */

.cc-location-card__content {
  /* Layout - takes remaining space */
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  padding: var(--spacing-lg);
}

/* Location Name/Title */
.cc-location-card__name {
  /* Typography */
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-snug);
  color: var(--color-heading);

  /* Spacing */
  margin: 0;
  padding: 0;

  /* Link styling */
  text-decoration: none;
}

.cc-location-card__name a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-colors);
}

.cc-location-card__name a:hover {
  color: var(--color-primary);
}

/* Location Designation (e.g., "Main Office", "Satellite Office") */
.cc-location-card__designation {
  /* Typography */
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  font-weight: var(--font-weight-semibold);

  /* Spacing */
  margin: 0;
  padding: 0;
}

/* ============================================
   LOCATION CARD ADDRESS & CONTACT
   ============================================ */

.cc-location-card__address {
  /* Layout */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);

  /* Spacing */
  padding-bottom: var(--spacing-sm);
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
}

.cc-location-card__address-line {
  /* Typography */
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-base);

  /* Spacing */
  margin: 0;
  padding: 0;
}

.cc-location-card__address-link {
  /* Link styling */
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition-colors);
}

.cc-location-card__address-link:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

/* Contact Information */
.cc-location-card__contact {
  /* Layout */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);

  /* Spacing */
  padding-bottom: var(--spacing-sm);
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
}

.cc-location-card__contact-item {
  /* Layout */
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);

  /* Typography */
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.cc-location-card__contact-icon {
  /* Icon sizing */
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--color-primary);
}

.cc-location-card__contact-text {
  /* Text styling */
  margin: 0;
  padding: 0;
}

.cc-location-card__contact-link {
  /* Link styling */
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition-colors);
}

.cc-location-card__contact-link:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

/* ============================================
   LOCATION CARD HOURS
   ============================================ */

.cc-location-card__hours {
  /* Layout */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);

  /* Spacing */
  padding-bottom: var(--spacing-sm);
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
}

.cc-location-card__hours-header {
  /* Layout */
  display: flex;
  align-items: center;
  justify-content: space-between;

  /* Typography */
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
}

.cc-location-card__hours-status {
  /* Status indicator */
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2xs);
  padding: 0.125rem 0.5rem;
  border-radius: var(--border-radius-md);
  font-size: 0.75rem;
  font-weight: var(--font-weight-semibold);
}

.cc-location-card__hours-status--open {
  background-color: #d4edda;
  color: #155724;
}

.cc-location-card__hours-status--closed {
  background-color: #f8d7da;
  color: #721c24;
}

.cc-location-card__hours-status--limited {
  background-color: #fff3cd;
  color: #856404;
}

/* Individual hours */
.cc-location-card__hours-list {
  /* Layout */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  max-height: 200px;
  overflow-y: auto;
}

.cc-location-card__hours-item {
  /* Layout */
  display: flex;
  justify-content: space-between;
  align-items: center;

  /* Typography */
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.cc-location-card__hours-day {
  /* Day label */
  font-weight: var(--font-weight-semibold);
  min-width: 60px;
}

.cc-location-card__hours-time {
  /* Time display */
  text-align: right;
}

.cc-location-card__hours-time--closed {
  color: var(--color-text-muted);
}

/* Expandable hours toggle */
.cc-location-card__hours-toggle {
  /* Button styling */
  background: none;
  border: none;
  padding: 0;
  color: var(--color-primary);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  text-decoration: underline;
  transition: color var(--transition-colors);
}

.cc-location-card__hours-toggle:hover {
  color: var(--color-primary-dark);
}

/* ============================================
   LOCATION CARD SERVICES
   ============================================ */

.cc-location-card__services {
  /* Layout */
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);

  /* Spacing */
  padding-bottom: var(--spacing-sm);
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
}

.cc-location-card__service {
  /* Badge-like styling */
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.625rem;
  background-color: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
}

/* ============================================
   LOCATION CARD FOOTER (CTA)
   ============================================ */

.cc-location-card__footer {
  /* Layout */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);

  /* Spacing */
  padding: var(--spacing-lg);
}

.cc-location-card__directions-btn {
  /* Uses .cc-button styling */
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  width: 100%;
  padding: var(--spacing-md) var(--spacing-lg);
  background-color: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--border-radius-md);
  font-weight: var(--font-weight-semibold);
  cursor: pointer;
  text-decoration: none;
  transition: var(--transition-base);
}

.cc-location-card__directions-btn:hover {
  background-color: var(--color-primary-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.cc-location-card__directions-icon {
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
}

/* Secondary action link */
.cc-location-card__call-btn {
  /* Phone call link */
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm);
  color: var(--color-primary);
  text-decoration: none;
  font-weight: var(--font-weight-semibold);
  border-radius: var(--border-radius-md);
  transition: var(--transition-colors);
}

.cc-location-card__call-btn:hover {
  background-color: var(--color-primary-light);
  color: var(--color-primary-dark);
}

/* ============================================
   LOCATION CARD VARIANTS
   ============================================ */

/* Compact variant - No map, minimal layout */
.cc-location-card--compact {
  padding: var(--spacing-md);
}

.cc-location-card--compact .cc-location-card__map {
  display: none;
}

.cc-location-card--compact .cc-location-card__content {
  padding: 0;
  gap: var(--spacing-sm);
}

/* Minimal variant - Just key info */
.cc-location-card--minimal {
  padding: 0;
}

.cc-location-card--minimal .cc-location-card__map {
  aspect-ratio: 4 / 3;
}

.cc-location-card--minimal .cc-location-card__content {
  padding: var(--spacing-md);
  gap: var(--spacing-sm);
}

.cc-location-card--minimal .cc-location-card__services {
  display: none;
}

.cc-location-card--minimal .cc-location-card__footer {
  padding: var(--spacing-md);
  gap: var(--spacing-sm);
}

/* Featured/Highlighted location */
.cc-location-card--featured {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-lg);
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-location-card__map {
    aspect-ratio: 4 / 3;
    min-height: 180px;
  }

  .cc-location-card__content {
    padding: var(--spacing-md);
    gap: var(--spacing-sm);
  }

  .cc-location-card__name {
    font-size: var(--font-size-base);
  }

  .cc-location-card__hours-list {
    max-height: 150px;
  }

  .cc-location-card__footer {
    padding: var(--spacing-md);
  }
}

@media (max-width: 480px) {
  .cc-location-card {
    padding: 0;
  }

  .cc-location-card__map {
    aspect-ratio: 1 / 1;
    min-height: 150px;
    border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0;
  }

  .cc-location-card__content {
    padding: var(--spacing-sm);
    gap: var(--spacing-xs);
  }

  .cc-location-card__name {
    font-size: var(--font-size-sm);
  }

  .cc-location-card__designation {
    display: none;
  }

  .cc-location-card__address-line {
    font-size: var(--font-size-xs);
  }

  .cc-location-card__contact-item {
    font-size: var(--font-size-xs);
  }

  .cc-location-card__hours {
    padding-bottom: var(--spacing-xs);
  }

  .cc-location-card__hours-item {
    font-size: var(--font-size-xs);
  }

  .cc-location-card__hours-list {
    max-height: 120px;
  }

  .cc-location-card__services {
    padding-bottom: var(--spacing-xs);
  }

  .cc-location-card__service {
    padding: 0.1875rem 0.5rem;
    font-size: 0.7rem;
  }

  .cc-location-card__footer {
    padding: var(--spacing-sm);
    gap: var(--spacing-sm);
  }

  .cc-location-card__directions-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
  }

  .cc-location-card__call-btn {
    padding: var(--spacing-xs);
    font-size: var(--font-size-sm);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-location-card,
  .cc-location-card__name a,
  .cc-location-card__address-link,
  .cc-location-card__contact-link,
  .cc-location-card__directions-btn,
  .cc-location-card__call-btn {
    transition: none;
  }

  .cc-location-card:hover .cc-location-card__directions-btn {
    transform: none;
  }
}

/* Source: components/content/pilgrimage-card.css */
/**
 * Pilgrimage Card Component Styles
 * 
 * Reusable card component for displaying pilgrimage offerings
 * in archive pages and listings.
 */

/* ============================================================================
   Base Card Styles
   ========================================================================= */

.cc-pilgrimage-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(26, 54, 93, 0.06);
	transition: all 0.3s ease;
	height: 100%;
}

.cc-pilgrimage-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(26, 54, 93, 0.12);
}

.cc-pilgrimage-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
}

/* ============================================================================
   Image Section
   ========================================================================= */

.cc-pilgrimage-card__image {
	position: relative;
	width: 100%;
	height: 240px;
	overflow: hidden;
	background: linear-gradient(135deg, #1a365d 0%, #2f4089 100%);
}

.cc-pilgrimage-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.cc-pilgrimage-card:hover .cc-pilgrimage-card__image img {
	transform: scale(1.05);
}

.cc-pilgrimage-card__badge {
	position: absolute;
	top: 1rem;
	right: 1rem;
	padding: 0.5rem 1rem;
	background: #D4AF37;
	color: #fff;
	font-size: 0.875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.03em; /* 0.5px converted to em */
	border-radius: 4px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

/* ============================================================================
   Content Section
   ========================================================================= */

.cc-pilgrimage-card__content {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 1.5rem;
}

.cc-pilgrimage-card__title {
	font-family: var(--font-family-primary);
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a365d;
	margin: 0 0 1rem;
	line-height: 1.3;
}

.cc-pilgrimage-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 1.25rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid #e5e7eb;
}

.cc-pilgrimage-card__meta-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.9375rem;
	color: #6b7280;
}

.cc-pilgrimage-card__meta-item i {
	color: #2f4089;
	font-size: 1rem;
}

/* ============================================================================
   Footer Section
   ========================================================================= */

.cc-pilgrimage-card__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: auto;
	padding-top: 1rem;
	gap: 1rem;
}

.cc-pilgrimage-card__price {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.cc-pilgrimage-card__price-label {
	font-size: 0.75rem;
	color: #6b7280;
	text-transform: uppercase;
	letter-spacing: 0.03em; /* 0.5px converted to em */
}

.cc-pilgrimage-card__price-amount {
	font-size: 1.75rem;
	font-weight: 700;
	color: #1a365d;
	line-height: 1;
}

.cc-pilgrimage-card__price-note {
	font-size: 0.8125rem;
	color: #9ca3af;
}

.cc-pilgrimage-card__date {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 0.75rem;
	background: #f3f4f6;
	border-radius: 4px;
	font-size: 0.875rem;
	color: #1f2937;
}

.cc-pilgrimage-card__date i {
	color: #2f4089;
}

/* ============================================================================
   CTA Section
   ========================================================================= */

.cc-pilgrimage-card__cta {
	margin-top: 1.25rem;
	padding-top: 1.25rem;
	border-top: 1px solid #e5e7eb;
}

.cc-pilgrimage-card__cta-text {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1rem;
	font-weight: 600;
	color: #2f4089;
	transition: gap 0.3s ease;
}

.cc-pilgrimage-card:hover .cc-pilgrimage-card__cta-text {
	gap: 0.75rem;
}

.cc-pilgrimage-card__cta-text i {
	transition: transform 0.3s ease;
}

.cc-pilgrimage-card:hover .cc-pilgrimage-card__cta-text i {
	transform: translateX(4px);
}

/* ============================================================================
   Variant: Featured
   ========================================================================= */

.cc-pilgrimage-card--featured {
	border: 2px solid #D4AF37;
}

.cc-pilgrimage-card--featured .cc-pilgrimage-card__title {
	color: #2f4089;
}

/* ============================================================================
   Variant: Compact
   ========================================================================= */

.cc-pilgrimage-card--compact .cc-pilgrimage-card__image {
	height: 180px;
}

.cc-pilgrimage-card--compact .cc-pilgrimage-card__content {
	padding: 1.25rem;
}

.cc-pilgrimage-card--compact .cc-pilgrimage-card__title {
	font-size: 1.25rem;
}

/* ============================================================================
   Responsive Design
   ========================================================================= */

@media (max-width: 768px) {
	.cc-pilgrimage-card__image {
		height: 200px;
	}

	.cc-pilgrimage-card__title {
		font-size: 1.25rem;
	}

	.cc-pilgrimage-card__footer {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}

	.cc-pilgrimage-card__price-amount {
		font-size: 1.5rem;
	}
}

@media (max-width: 480px) {
	.cc-pilgrimage-card__content {
		padding: 1.25rem;
	}

	.cc-pilgrimage-card__meta {
		flex-direction: column;
		gap: 0.75rem;
	}
}


/* Source: components/navigation/breadcrumb.css */
/**
 * Breadcrumb Navigation Component
 * ===============================
 * Display hierarchical navigation breadcrumbs for page hierarchy
 * BEM naming convention: .cc-breadcrumb, .cc-breadcrumb__*, variants
 *
 * Features: Text-only, icon support, custom separators, schema.org microdata
 * Responsive: Collapses on mobile, shows abbreviated path
 * Accessibility: Proper ARIA attributes, semantic HTML
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE BREADCRUMB STYLES
   ============================================ */

.cc-breadcrumb {
  /* Breadcrumb navigation container */
  display: block;
  margin: 0;
  padding: var(--spacing-sm) 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.cc-breadcrumb__list {
  /* List of breadcrumb items */
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--spacing-xs);
  list-style: none;
  margin: 0;
  padding: 0;
}

.cc-breadcrumb__item {
  /* Individual breadcrumb item */
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

/* Separator between items (use pseudo-element, hide markup separator spans) */
.cc-breadcrumb__item:not(:last-child)::after {
  content: '/';
  color: var(--color-border);
  margin-left: var(--spacing-xs);
  font-weight: var(--font-weight-regular);
}

.cc-breadcrumb__separator {
  display: none;
}

/* ============================================
   BREADCRUMB LINKS & TEXT
   ============================================ */

.cc-breadcrumb__link {
  /* Breadcrumb link styling */
  color: var(--color-primary);
  text-decoration: none;
  transition: var(--transition-colors);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.cc-breadcrumb__link:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

.cc-breadcrumb__link:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: var(--border-radius-sm);
}

/* Current/active breadcrumb item */
.cc-breadcrumb__item.is-current,
.cc-breadcrumb__item[aria-current="page"] {
  color: var(--color-text-secondary);
  font-weight: var(--font-weight-semibold);
}

.cc-breadcrumb__item.is-current .cc-breadcrumb__link,
.cc-breadcrumb__item[aria-current="page"] .cc-breadcrumb__link {
  color: inherit;
  cursor: default;
  pointer-events: none;
}

/* ============================================
   BREADCRUMB ICONS
   ============================================ */

.cc-breadcrumb__icon {
  /* Icon in breadcrumb item */
  width: 1rem;
  height: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: inherit;
}

/* Home icon styling */
.cc-breadcrumb__home-icon {
  width: 1.125rem;
  height: 1.125rem;
}

/* ============================================
   BREADCRUMB VARIANTS
   ============================================ */

/* Text-only variant (no icons) */
.cc-breadcrumb--text-only .cc-breadcrumb__icon {
  display: none;
}

/* With icons variant */
.cc-breadcrumb--with-icons {
  /* Icons visible by default */
}

/* Custom separator variant */
.cc-breadcrumb--separator-arrow .cc-breadcrumb__item:not(:last-child)::after {
  content: '›';
  font-size: 1.25rem;
  margin-left: var(--spacing-sm);
  margin-right: var(--spacing-xs);
}

.cc-breadcrumb--separator-pipe .cc-breadcrumb__item:not(:last-child)::after {
  content: '|';
  margin-left: var(--spacing-sm);
  margin-right: var(--spacing-sm);
}

.cc-breadcrumb--separator-dash .cc-breadcrumb__item:not(:last-child)::after {
  content: '-';
  margin-left: var(--spacing-sm);
  margin-right: var(--spacing-sm);
}

.cc-breadcrumb--separator-dot .cc-breadcrumb__item:not(:last-child)::after {
  content: '•';
  margin-left: var(--spacing-sm);
  margin-right: var(--spacing-sm);
}

/* No separator variant */
.cc-breadcrumb--no-separator .cc-breadcrumb__item:not(:last-child)::after {
  content: '';
  margin: 0;
}

/* ============================================
   BREADCRUMB WITH BACKGROUND
   ============================================ */

.cc-breadcrumb--bg {
  background-color: var(--color-bg-alt);
  padding: var(--spacing-md);
  border-radius: var(--border-radius-md);
  border: var(--border-width-thin) solid var(--color-border-light);
}

.cc-breadcrumb--bg-primary {
  background-color: var(--color-primary-light);
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.cc-breadcrumb--bg-primary .cc-breadcrumb__link {
  color: var(--color-primary-dark);
}

.cc-breadcrumb--bg-primary .cc-breadcrumb__link:hover {
  color: var(--color-primary);
}

.cc-breadcrumb--bg-dark {
  background-color: var(--color-gray-800);
  color: var(--color-white);
  border-color: var(--color-gray-700);
}

.cc-breadcrumb--bg-dark .cc-breadcrumb__link {
  color: var(--color-white);
}

.cc-breadcrumb--bg-dark .cc-breadcrumb__link:hover {
  color: var(--color-gray-100);
}

/* ============================================
   BREADCRUMB COLLAPSED STATE (MOBILE)
   ============================================ */

.cc-breadcrumb--collapsed {
  /* Show only first, current, and last items */
}

.cc-breadcrumb--collapsed .cc-breadcrumb__item:not(:first-child):not(:last-child):not(.is-current) {
  display: none;
}

.cc-breadcrumb--collapsed .cc-breadcrumb__item:nth-child(2) {
  /* Show ellipsis between first and current */
}

.cc-breadcrumb--collapsed .cc-breadcrumb__item:first-child:not(:last-child)::after {
  content: ' / ... / ';
  color: var(--color-border);
  margin-left: var(--spacing-xs);
  margin-right: var(--spacing-xs);
}

/* ============================================
   BREADCRUMB STATES
   ============================================ */

/* Visited link state */
.cc-breadcrumb__link:visited {
  color: var(--color-primary);
}

/* Disabled breadcrumb item */
.cc-breadcrumb__item.is-disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.cc-breadcrumb__item.is-disabled .cc-breadcrumb__link {
  color: var(--color-text-muted);
  pointer-events: none;
}

/* ============================================
   BREADCRUMB SCHEMA.ORG SUPPORT
   ============================================ */

/* Hidden microdata (for schema.org) */
.cc-breadcrumb-schema {
  display: none;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-breadcrumb {
    font-size: var(--font-size-xs);
    gap: var(--spacing-2xs);
  }

  .cc-breadcrumb__item:not(:last-child)::after {
    margin-left: var(--spacing-2xs);
  }

  .cc-breadcrumb--separator-arrow .cc-breadcrumb__item:not(:last-child)::after {
    margin-left: var(--spacing-xs);
    margin-right: var(--spacing-2xs);
  }

  .cc-breadcrumb--separator-pipe .cc-breadcrumb__item:not(:last-child)::after {
    margin-left: var(--spacing-xs);
    margin-right: var(--spacing-xs);
  }

  /* Automatically collapse on tablets */
  .cc-breadcrumb:not(.cc-breadcrumb--no-collapse) {
    /* Will be controlled by JavaScript for smart collapsing */
  }

  .cc-breadcrumb--bg {
    padding: var(--spacing-sm);
  }
}

@media (max-width: 480px) {
  .cc-breadcrumb {
    font-size: var(--font-size-xs);
    gap: var(--spacing-2xs);
    padding: var(--spacing-xs) 0;
  }

  .cc-breadcrumb__icon {
    width: 0.875rem;
    height: 0.875rem;
  }

  .cc-breadcrumb__home-icon {
    width: 1rem;
    height: 1rem;
  }

  /* Hide intermediate breadcrumbs on mobile */
  .cc-breadcrumb__item:not(:first-child):not(:last-child):not(.is-current) {
    display: none;
  }

  .cc-breadcrumb__item:nth-child(2) {
    /* Show ellipsis between first and current */
  }

  .cc-breadcrumb__item:first-child:not(:last-child)::after {
    content: ' ... ';
    margin-left: var(--spacing-2xs);
    margin-right: var(--spacing-2xs);
  }

  .cc-breadcrumb--bg {
    padding: var(--spacing-xs);
    gap: 2px;
  }

  .cc-breadcrumb__link {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-breadcrumb__link {
    transition: none;
  }
}

/* Source: components/navigation/pagination.css */
/**
 * Pagination Navigation Component
 * ===============================
 * Display page navigation with prev/next and numbered page links
 * BEM naming convention: .cc-pagination, .cc-pagination__*, variants
 *
 * Features: Text links, numbered pages, prev/next arrows, disabled states
 * Variants: Default, minimal, boxed, centered
 * Responsive: Reduces pages on mobile, shows prev/next only on small screens
 * Accessibility: ARIA labels, rel=prev/next, keyboard navigation
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE PAGINATION STYLES
   ============================================ */

.cc-pagination {
  /* Pagination container */
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  list-style: none;
  margin: var(--spacing-lg) 0;
  padding: 0;
}

.cc-pagination__item {
  /* Individual pagination item */
  display: flex;
  align-items: center;
}

/* ============================================
   PAGINATION LINKS & BUTTONS
   ============================================ */

.cc-pagination__link,
.cc-pagination__button {
  /* Pagination link/button styling */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 0.5rem 0.75rem;
  color: var(--color-primary);
  text-decoration: none;
  background-color: var(--color-white);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-regular);
  transition: var(--transition-colors);
  cursor: pointer;
}

.cc-pagination__link:hover,
.cc-pagination__button:hover {
  color: var(--color-primary-dark);
  background-color: var(--color-primary-light);
  border-color: var(--color-primary);
}

.cc-pagination__link:focus-visible,
.cc-pagination__button:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* Current/active page */
.cc-pagination__item.is-current .cc-pagination__link,
.cc-pagination__item[aria-current="page"] .cc-pagination__link {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
  cursor: default;
  pointer-events: none;
}

/* ============================================
   PAGINATION PREV/NEXT BUTTONS
   ============================================ */

.cc-pagination__prev,
.cc-pagination__next {
  /* Previous/next page buttons */
}

.cc-pagination__prev:disabled,
.cc-pagination__next:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  color: var(--color-text-muted);
  border-color: var(--color-border-light);
}

.cc-pagination__prev:disabled:hover,
.cc-pagination__next:disabled:hover {
  background-color: var(--color-white);
  border-color: var(--color-border-light);
}

/* ============================================
   PAGINATION ICONS & TEXT
   ============================================ */

.cc-pagination__icon {
  /* Arrow icons in prev/next buttons */
  width: 1rem;
  height: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.cc-pagination__text {
  /* Text label in pagination items */
  display: inline;
}

.cc-pagination__number {
  /* Page number display */
  font-weight: inherit;
  min-width: 2.25rem;
  text-align: center;
}

/* ============================================
   PAGINATION ELLIPSIS
   ============================================ */

.cc-pagination__ellipsis {
  /* Ellipsis between page numbers (...) */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  color: var(--color-text-muted);
  font-weight: var(--font-weight-regular);
  cursor: default;
}

/* ============================================
   PAGINATION VARIANTS
   ============================================ */

/* Default variant (numbered pages) */
.cc-pagination--default {
  /* Standard pagination with all page numbers */
}

/* Minimal variant (prev/next only) */
.cc-pagination--minimal {
  gap: var(--spacing-md);
}

.cc-pagination--minimal .cc-pagination__item:not(.is-prev):not(.is-next):not(.is-current) {
  display: none;
}

.cc-pagination--minimal .cc-pagination__item.is-current {
  display: flex;
}

/* Boxed variant */
.cc-pagination--boxed {
  background-color: var(--color-bg-alt);
  padding: var(--spacing-md);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-lg);
}

/* Lined variant (no box backgrounds) */
.cc-pagination--lined .cc-pagination__link,
.cc-pagination--lined .cc-pagination__button {
  background-color: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  padding: 0.5rem 0.75rem;
}

.cc-pagination--lined .cc-pagination__link:hover,
.cc-pagination--lined .cc-pagination__button:hover {
  border-bottom-color: var(--color-primary);
  background-color: transparent;
}

.cc-pagination--lined .cc-pagination__item.is-current .cc-pagination__link {
  border-bottom-color: var(--color-primary);
  background-color: transparent;
  color: var(--color-primary);
}

/* Text-only variant */
.cc-pagination--text-only .cc-pagination__link,
.cc-pagination--text-only .cc-pagination__button {
  border: none;
  background-color: transparent;
  color: var(--color-primary);
  padding: 0.5rem;
}

.cc-pagination--text-only .cc-pagination__link:hover,
.cc-pagination--text-only .cc-pagination__button:hover {
  background-color: var(--color-primary-light);
  border-radius: var(--border-radius-md);
}

.cc-pagination--text-only .cc-pagination__item.is-current .cc-pagination__link {
  background-color: transparent;
  color: var(--color-primary-dark);
  font-weight: var(--font-weight-semibold);
}

/* ============================================
   PAGINATION ALIGNMENT
   ============================================ */

.cc-pagination--left {
  justify-content: flex-start;
}

.cc-pagination--center {
  justify-content: center;
}

.cc-pagination--right {
  justify-content: flex-end;
}

.cc-pagination--between {
  justify-content: space-between;
}

/* ============================================
   PAGINATION SIZES
   ============================================ */

.cc-pagination--sm .cc-pagination__link,
.cc-pagination--sm .cc-pagination__button {
  min-width: 36px;
  min-height: 36px;
  padding: 0.25rem 0.5rem;
  font-size: var(--font-size-xs);
}

.cc-pagination--lg .cc-pagination__link,
.cc-pagination--lg .cc-pagination__button {
  min-width: 52px;
  min-height: 52px;
  padding: 0.75rem 1rem;
  font-size: var(--font-size-base);
}

/* ============================================
   PAGINATION INFO/META
   ============================================ */

.cc-pagination__info {
  /* Pagination info text (e.g., "Page 2 of 10") */
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  flex-basis: 100%;
  justify-content: center;
  margin-bottom: var(--spacing-md);
}

.cc-pagination__info-label {
  font-weight: var(--font-weight-semibold);
}

/* ============================================
   PAGINATION STATES
   ============================================ */

/* Loading state */
.cc-pagination--loading {
  opacity: 0.6;
  pointer-events: none;
}

.cc-pagination--loading .cc-pagination__link,
.cc-pagination--loading .cc-pagination__button {
  pointer-events: none;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-pagination {
    gap: var(--spacing-xs);
  }

  .cc-pagination__link,
  .cc-pagination__button {
    min-width: 40px;
    min-height: 40px;
    padding: 0.375rem 0.625rem;
    font-size: var(--font-size-xs);
  }

  /* Hide middle page numbers on tablets */
  .cc-pagination__item:not(.is-prev):not(.is-next):not(.is-current):not(.is-first):not(.is-last) {
    display: none;
  }

  /* Show first and last pages */
  .cc-pagination__item.is-first,
  .cc-pagination__item.is-last {
    display: flex;
  }

  .cc-pagination--boxed {
    padding: var(--spacing-sm);
  }
}

@media (max-width: 480px) {
  .cc-pagination {
    gap: var(--spacing-2xs);
    margin: var(--spacing-md) 0;
  }

  .cc-pagination__link,
  .cc-pagination__button {
    min-width: 36px;
    min-height: 36px;
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
  }

  /* Show only prev/next and current on mobile */
  .cc-pagination__item:not(.is-prev):not(.is-next):not(.is-current) {
    display: none;
  }

  .cc-pagination__item.is-current {
    display: flex;
  }

  .cc-pagination__ellipsis {
    display: none;
  }

  .cc-pagination--boxed {
    padding: var(--spacing-xs);
    gap: var(--spacing-2xs);
  }

  .cc-pagination__info {
    font-size: var(--font-size-xs);
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
  }

  /* Center text-only pagination on mobile */
  .cc-pagination--text-only {
    justify-content: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-pagination__link,
  .cc-pagination__button {
    transition: none;
  }
}

/* Source: components/navigation/archive-filter.css */
/**
 * Archive Filter Navigation Component
 * ====================================
 * Filter controls for archive pages with dropdowns, checkboxes, and sliders
 * BEM naming convention: .cc-archive-filter, .cc-archive-filter__*, variants
 *
 * Features: Search, dropdowns, checkboxes, sliders, mobile collapse, filter counts
 * Variants: Sidebar, modal, collapsible, inline
 * Responsive: Sidebar → modal on mobile, collapsible accordion on tablet
 * Accessibility: ARIA attributes, keyboard navigation, focus states
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE ARCHIVE FILTER STYLES
   ============================================ */

.cc-archive-filter {
  /* Archive filter container */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
  padding: var(--spacing-lg);
  background-color: var(--color-white);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-lg);
}

.cc-archive-filter--sidebar {
  flex-direction: column;
  max-width: 300px;
  position: relative;
}

.cc-archive-filter--modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: var(--z-index-modal);
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: var(--spacing-md);
}

.cc-archive-filter--modal .cc-archive-filter {
  width: 100%;
  max-width: 100%;
  border-radius: var(--border-radius-xl) var(--border-radius-xl) 0 0;
  animation: slideUp var(--transition-timing-slow) ease-out;
}

/* ============================================
   ARCHIVE FILTER HEADER
   ============================================ */

.cc-archive-filter__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-md);
  padding-bottom: var(--spacing-md);
  border-bottom: var(--border-width-thin) solid var(--color-border);
}

.cc-archive-filter__title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
  margin: 0;
  padding: 0;
}

.cc-archive-filter__close {
  display: none;
  width: 32px;
  height: 32px;
  padding: 0;
  background: none;
  border: none;
  color: var(--color-text-secondary);
  cursor: pointer;
  font-size: 1.25rem; /* 20px converted to rem */
  align-items: center;
  justify-content: center;
  transition: color var(--transition-colors);
}

.cc-archive-filter__close:hover {
  color: var(--color-primary);
}

.cc-archive-filter__close:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ============================================
   ARCHIVE FILTER SEARCH
   ============================================ */

.cc-archive-filter__search {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.cc-archive-filter__search-input {
  width: 100%;
  padding: 0.75rem 1rem 0.75rem 2.75rem;
  font-size: var(--font-size-sm);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  transition: var(--transition-colors);
}

.cc-archive-filter__search-input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

.cc-archive-filter__search-icon {
  position: absolute;
  left: 0.75rem;
  width: 1rem;
  height: 1rem;
  color: var(--color-text-muted);
  pointer-events: none;
}

.cc-archive-filter__search-clear {
  position: absolute;
  right: 0.75rem;
  width: 20px;
  height: 20px;
  padding: 0;
  background: none;
  border: none;
  color: var(--color-text-muted);
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  transition: color var(--transition-colors);
}

.cc-archive-filter__search-input:not(:placeholder-shown) ~ .cc-archive-filter__search-clear {
  display: flex;
}

.cc-archive-filter__search-clear:hover {
  color: var(--color-primary);
}

/* ============================================
   ARCHIVE FILTER GROUPS
   ============================================ */

.cc-archive-filter__group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.cc-archive-filter__group--collapsible {
  border: var(--border-width-thin) solid var(--color-border-light);
  border-radius: var(--border-radius-md);
  overflow: hidden;
}

.cc-archive-filter__group-toggle {
  width: 100%;
  padding: var(--spacing-md);
  background: none;
  border: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-md);
  cursor: pointer;
  transition: background-color var(--transition-colors);
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
}

.cc-archive-filter__group-toggle:hover {
  background-color: var(--color-bg-alt);
}

.cc-archive-filter__group-toggle:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: -2px;
}

.cc-archive-filter__group-toggle-icon {
  width: 1.25rem;
  height: 1.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--transition-colors);
  flex-shrink: 0;
}

.cc-archive-filter__group--collapsed .cc-archive-filter__group-toggle-icon {
  transform: rotate(0deg);
}

.cc-archive-filter__group--expanded .cc-archive-filter__group-toggle-icon {
  transform: rotate(180deg);
}

.cc-archive-filter__group-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  padding: var(--spacing-md);
  background-color: transparent;
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-timing), padding var(--transition-colors);
}

.cc-archive-filter__group--expanded .cc-archive-filter__group-content {
  max-height: 500px;
  padding: var(--spacing-md);
}

/* ============================================
   ARCHIVE FILTER GROUP LABEL
   ============================================ */

.cc-archive-filter__group-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
  margin: 0;
  padding: var(--spacing-md) 0;
  display: block;
}

.cc-archive-filter__group--collapsible .cc-archive-filter__group-label {
  padding: 0;
  display: none;
}

/* ============================================
   ARCHIVE FILTER DROPDOWN
   ============================================ */

.cc-archive-filter__select {
  width: 100%;
  padding: 0.625rem 0.75rem;
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  background-color: var(--color-white);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%232f4089' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 12px;
  padding-right: 2.25rem;
  cursor: pointer;
  transition: var(--transition-colors);
}

.cc-archive-filter__select:hover {
  border-color: var(--color-primary-light);
  background-color: var(--color-bg-alt);
}

.cc-archive-filter__select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

.cc-archive-filter__select option {
  color: var(--color-text-secondary);
  background-color: var(--color-white);
}

/* ============================================
   ARCHIVE FILTER CHECKBOXES
   ============================================ */

.cc-archive-filter__checkbox-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  list-style: none;
  margin: 0;
  padding: 0;
}

.cc-archive-filter__checkbox-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.cc-archive-filter__checkbox-input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.cc-archive-filter__checkbox-label {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  cursor: pointer;
  user-select: none;
  flex-grow: 1;
}

.cc-archive-filter__checkbox-visual {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  border: 2px solid var(--color-border);
  border-radius: var(--border-radius-sm);
  background-color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-colors);
}

.cc-archive-filter__checkbox-input:checked + .cc-archive-filter__checkbox-label .cc-archive-filter__checkbox-visual {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='white' d='M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 11-1.06-1.06l7.25-7.25a.75.75 0 011.06 0z'/%3E%3Cpath fill='white' d='M2.22 9.22a.75.75 0 010 1.06l-1.5 1.5a.75.75 0 11-1.06-1.06l1.5-1.5a.75.75 0 011.06 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 14px;
}

.cc-archive-filter__checkbox-input:focus-visible + .cc-archive-filter__checkbox-label .cc-archive-filter__checkbox-visual {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.cc-archive-filter__checkbox-text {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.cc-archive-filter__checkbox-count {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-left: auto;
}

/* ============================================
   ARCHIVE FILTER RANGE SLIDER
   ============================================ */

.cc-archive-filter__slider-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.cc-archive-filter__slider-labels {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-sm);
}

.cc-archive-filter__slider-label {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.cc-archive-filter__slider-value {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
}

.cc-archive-filter__slider-range {
  width: 100%;
  height: 6px;
  background-color: var(--color-border);
  border-radius: var(--border-radius-full);
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}

.cc-archive-filter__slider-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: var(--border-radius-full);
  background-color: var(--color-primary);
  cursor: pointer;
  border: 2px solid var(--color-white);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  transition: box-shadow var(--transition-colors);
}

.cc-archive-filter__slider-range::-webkit-slider-thumb:hover {
  box-shadow: 0 2px 8px rgba(47, 64, 137, 0.3);
}

.cc-archive-filter__slider-range::-webkit-slider-thumb:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.cc-archive-filter__slider-range::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: var(--border-radius-full);
  background-color: var(--color-primary);
  cursor: pointer;
  border: 2px solid var(--color-white);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  transition: box-shadow var(--transition-colors);
}

.cc-archive-filter__slider-range::-moz-range-thumb:hover {
  box-shadow: 0 2px 8px rgba(47, 64, 137, 0.3);
}

/* ============================================
   ARCHIVE FILTER BUTTONS
   ============================================ */

.cc-archive-filter__actions {
  display: flex;
  gap: var(--spacing-md);
  padding-top: var(--spacing-md);
  border-top: var(--border-width-thin) solid var(--color-border);
}

.cc-archive-filter__button {
  flex: 1;
  padding: 0.75rem 1rem;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  background-color: var(--color-white);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: var(--transition-colors);
  min-height: 44px;
}

.cc-archive-filter__button:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background-color: var(--color-primary-light);
}

.cc-archive-filter__button:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.cc-archive-filter__button--apply {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

.cc-archive-filter__button--apply:hover {
  background-color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
}

.cc-archive-filter__button--clear {
  background-color: var(--color-white);
  color: var(--color-text-secondary);
}

/* ============================================
   ARCHIVE FILTER ACTIVE FILTERS
   ============================================ */

.cc-archive-filter__active-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
  padding: var(--spacing-md);
  background-color: var(--color-bg-alt);
  border-radius: var(--border-radius-md);
  list-style: none;
  margin: 0;
  padding: var(--spacing-md);
}

.cc-archive-filter__active-filter-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: 0.5rem 0.75rem;
  background-color: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
}

.cc-archive-filter__active-filter-remove {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  padding: 0;
  background: none;
  border: none;
  color: var(--color-white);
  cursor: pointer;
  font-size: 0.875rem; /* 14px converted to rem */
  transition: color var(--transition-colors);
}

.cc-archive-filter__active-filter-remove:hover {
  color: var(--color-primary-light);
}

.cc-archive-filter__active-filter-remove:focus-visible {
  outline: 2px solid var(--color-white);
  outline-offset: 2px;
}

/* ============================================
   ARCHIVE FILTER VARIANTS
   ============================================ */

/* Borderless variant */
.cc-archive-filter--borderless {
  border: none;
  padding: var(--spacing-md) 0;
}

/* Boxed variant */
.cc-archive-filter--boxed {
  background-color: var(--color-bg-alt);
  border: var(--border-width-thin) solid var(--color-border);
  padding: var(--spacing-lg);
  border-radius: var(--border-radius-xl);
}

/* Compact variant */
.cc-archive-filter--compact .cc-archive-filter__group {
  gap: var(--spacing-sm);
}

.cc-archive-filter--compact .cc-archive-filter__group-label {
  padding: var(--spacing-sm) 0;
}

/* ============================================
   ARCHIVE FILTER LOADING STATE
   ============================================ */

.cc-archive-filter--loading {
  opacity: 0.7;
  pointer-events: none;
}

.cc-archive-filter--loading::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 24px;
  height: 24px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: var(--border-radius-full);
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 1024px) {
  .cc-archive-filter--sidebar {
    max-width: 100%;
  }

  .cc-archive-filter__group--collapsible .cc-archive-filter__group-content {
    max-height: 400px;
  }
}

@media (max-width: 768px) {
  .cc-archive-filter--sidebar {
    display: none;
  }

  .cc-archive-filter--sidebar.cc-archive-filter--mobile-visible {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: var(--z-index-modal);
    background-color: rgba(0, 0, 0, 0.5);
    border-radius: 0;
  }

  .cc-archive-filter {
    padding: var(--spacing-md);
  }

  .cc-archive-filter__close {
    display: flex;
  }

  .cc-archive-filter__group {
    gap: var(--spacing-sm);
  }

  .cc-archive-filter__actions {
    flex-direction: column;
  }

  .cc-archive-filter__button {
    width: 100%;
  }

  .cc-archive-filter--modal .cc-archive-filter {
    max-height: 90vh;
    overflow-y: auto;
  }
}

@media (max-width: 480px) {
  .cc-archive-filter {
    padding: var(--spacing-md);
    gap: var(--spacing-md);
  }

  .cc-archive-filter__header {
    padding-bottom: var(--spacing-sm);
  }

  .cc-archive-filter__title {
    font-size: var(--font-size-base);
  }

  .cc-archive-filter__search-input {
    font-size: 1rem; /* 16px converted to rem */
    min-height: 44px;
  }

  .cc-archive-filter__group-label {
    padding: var(--spacing-sm) 0;
  }

  .cc-archive-filter__actions {
    flex-direction: column;
    gap: var(--spacing-sm);
  }

  .cc-archive-filter__button {
    width: 100%;
    padding: 0.75rem 1rem;
    min-height: 44px;
  }

  .cc-archive-filter__active-filters {
    padding: var(--spacing-sm);
  }

  .cc-archive-filter--modal .cc-archive-filter {
    max-height: 95vh;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-archive-filter__group-toggle-icon,
  .cc-archive-filter__group-content,
  .cc-archive-filter__slider-range::-webkit-slider-thumb,
  .cc-archive-filter__slider-range::-moz-range-thumb,
  .cc-archive-filter__button,
  .cc-archive-filter__checkbox-visual {
    transition: none;
  }

  .cc-archive-filter--loading::after {
    animation: none;
    border-top-color: var(--color-primary);
  }
}

/* Source: components/navigation/sidebar-menu.css */
/**
 * Sidebar Menu Navigation Component
 * ==================================
 * Nested menu structure with icons, collapsible submenus, active states
 * BEM naming convention: .cc-sidebar-menu, .cc-sidebar-menu__*, variants
 *
 * Features: Nested items, collapsible submenus, icons, active/current states
 * Variants: Vertical, horizontal, compact, full-width, dark, light
 * Responsive: Vertical stacking on mobile, collapse on narrow screens
 * Accessibility: ARIA attributes, keyboard navigation, focus states
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE SIDEBAR MENU STYLES
   ============================================ */

.cc-sidebar-menu {
  /* Main menu container */
  display: flex;
  flex-direction: column;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  background-color: var(--color-white);
  border-radius: var(--border-radius-lg);
  border: var(--border-width-thin) solid var(--color-border);
  overflow: hidden;
}

.cc-sidebar-menu--borderless {
  border: none;
}

.cc-sidebar-menu--flush {
  border-radius: 0;
}

/* ============================================
   SIDEBAR MENU ITEMS
   ============================================ */

.cc-sidebar-menu__item {
  /* Individual menu item */
  display: flex;
  flex-direction: column;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
  position: relative;
}

.cc-sidebar-menu__item:last-child {
  border-bottom: none;
}

.cc-sidebar-menu__item--level-1 {
  /* Top-level menu item */
}

.cc-sidebar-menu__item--level-2 {
  /* Second-level menu item (submenu) */
  padding-left: 1rem;
  border-left: 2px solid var(--color-border-light);
  margin-left: 0;
}

.cc-sidebar-menu__item--level-3 {
  /* Third-level menu item */
  padding-left: 2rem;
  border-left: 2px solid var(--color-border-light);
}

.cc-sidebar-menu__item--level-4 {
  /* Fourth-level menu item */
  padding-left: 3rem;
  border-left: 2px solid var(--color-border-light);
}

/* ============================================
   SIDEBAR MENU LINKS
   ============================================ */

.cc-sidebar-menu__link {
  /* Main menu link/button */
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-sm);
  padding: var(--spacing-md) var(--spacing-lg);
  color: var(--color-text-secondary);
  text-decoration: none;
  background-color: transparent;
  border: none;
  cursor: pointer;
  transition: var(--transition-colors);
  width: 100%;
  text-align: left;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  min-height: 44px;
  position: relative;
}

.cc-sidebar-menu__link:hover {
  background-color: var(--color-bg-alt);
  color: var(--color-primary);
}

.cc-sidebar-menu__link:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: -2px;
}

/* Current/active menu item */
.cc-sidebar-menu__item.is-active > .cc-sidebar-menu__link,
.cc-sidebar-menu__item[aria-current="page"] > .cc-sidebar-menu__link {
  background-color: var(--color-primary-light);
  color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
  border-left: 3px solid var(--color-primary);
  padding-left: calc(var(--spacing-lg) - 3px);
}

.cc-sidebar-menu__item--level-2.is-active > .cc-sidebar-menu__link {
  border-left-color: var(--color-primary);
  padding-left: calc(1rem + var(--spacing-lg) - 3px);
}

.cc-sidebar-menu__item--level-3.is-active > .cc-sidebar-menu__link {
  border-left-color: var(--color-primary);
  padding-left: calc(2rem + var(--spacing-lg) - 3px);
}

/* ============================================
   SIDEBAR MENU ICON
   ============================================ */

.cc-sidebar-menu__icon {
  /* Menu item icon */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  flex-shrink: 0;
  color: inherit;
  font-size: 1.25rem;
}

.cc-sidebar-menu__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.cc-sidebar-menu__item.is-active > .cc-sidebar-menu__link .cc-sidebar-menu__icon {
  color: var(--color-primary);
}

/* ============================================
   SIDEBAR MENU TEXT & LABEL
   ============================================ */

.cc-sidebar-menu__text {
  /* Menu item text */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cc-sidebar-menu__label {
  /* Primary menu label */
  display: block;
  font-weight: inherit;
  color: inherit;
}

.cc-sidebar-menu__sublabel {
  /* Secondary menu sublabel (optional) */
  display: block;
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  font-weight: var(--font-weight-regular);
}

.cc-sidebar-menu__item.is-active > .cc-sidebar-menu__link .cc-sidebar-menu__sublabel {
  color: var(--color-text-secondary);
}

/* ============================================
   SIDEBAR MENU BADGE
   ============================================ */

.cc-sidebar-menu__badge {
  /* Badge/counter (e.g., notification count) */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 0.5rem;
  background-color: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--border-radius-full);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  flex-shrink: 0;
  margin-left: auto;
}

.cc-sidebar-menu__item.is-active > .cc-sidebar-menu__link .cc-sidebar-menu__badge {
  background-color: var(--color-primary-dark);
}

/* ============================================
   SIDEBAR MENU EXPAND INDICATOR
   ============================================ */

.cc-sidebar-menu__expand-indicator {
  /* Chevron/arrow icon for collapsible items */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  flex-shrink: 0;
  color: var(--color-border);
  transition: transform var(--transition-colors), color var(--transition-colors);
  font-size: 0.875rem;
  margin-left: auto;
}

.cc-sidebar-menu__item.is-expanded > .cc-sidebar-menu__link .cc-sidebar-menu__expand-indicator {
  transform: rotate(180deg);
  color: var(--color-primary);
}

.cc-sidebar-menu__item.is-active > .cc-sidebar-menu__link .cc-sidebar-menu__expand-indicator {
  color: var(--color-primary);
}

/* ============================================
   SIDEBAR MENU SUBMENU
   ============================================ */

.cc-sidebar-menu__submenu {
  /* Nested submenu container */
  display: flex;
  flex-direction: column;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-timing), opacity var(--transition-colors);
  opacity: 0;
  background-color: var(--color-bg-alt);
}

.cc-sidebar-menu__item.is-expanded > .cc-sidebar-menu__submenu {
  max-height: 2000px;
  opacity: 1;
}

.cc-sidebar-menu__submenu .cc-sidebar-menu__item {
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
  padding: 0;
  margin: 0;
}

.cc-sidebar-menu__submenu .cc-sidebar-menu__item:last-child {
  border-bottom: none;
}

.cc-sidebar-menu__submenu .cc-sidebar-menu__link {
  padding: var(--spacing-sm) var(--spacing-lg);
  padding-left: 2.5rem;
  font-size: var(--font-size-sm);
}

.cc-sidebar-menu__submenu .cc-sidebar-menu__item--level-2 .cc-sidebar-menu__link {
  padding-left: 2.5rem;
}

.cc-sidebar-menu__submenu .cc-sidebar-menu__item--level-3 .cc-sidebar-menu__link {
  padding-left: 3.5rem;
}

.cc-sidebar-menu__submenu .cc-sidebar-menu__item--level-4 .cc-sidebar-menu__link {
  padding-left: 4.5rem;
}

/* ============================================
   SIDEBAR MENU DIVIDER
   ============================================ */

.cc-sidebar-menu__divider {
  /* Visual divider between menu sections */
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  height: var(--border-width-thin);
  background-color: var(--color-border-light);
  border: none;
}

/* ============================================
   SIDEBAR MENU SECTION LABEL
   ============================================ */

.cc-sidebar-menu__section-label {
  /* Optional section label/heading */
  display: flex;
  list-style: none;
  margin: 0;
  padding: var(--spacing-md) var(--spacing-lg) var(--spacing-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  color: var(--color-text-muted);
  letter-spacing: 0.03em; /* 0.5px converted to em */
  border: none;
}

.cc-sidebar-menu__section-label:first-child {
  padding-top: var(--spacing-lg);
}

/* ============================================
   SIDEBAR MENU VARIANTS
   ============================================ */

/* Compact variant */
.cc-sidebar-menu--compact .cc-sidebar-menu__link {
  padding: var(--spacing-sm) var(--spacing-md);
  min-height: 40px;
}

.cc-sidebar-menu--compact .cc-sidebar-menu__submenu .cc-sidebar-menu__link {
  padding: var(--spacing-xs) var(--spacing-md);
  padding-left: 2rem;
  min-height: 36px;
}

.cc-sidebar-menu--compact .cc-sidebar-menu__icon {
  width: 1.25rem;
  height: 1.25rem;
  font-size: 1rem;
}

/* Dark variant */
.cc-sidebar-menu--dark {
  background-color: #1f233a;
  border-color: #3d4668;
}

.cc-sidebar-menu--dark .cc-sidebar-menu__link {
  color: #c5cfe0;
  border-bottom-color: #3d4668;
}

.cc-sidebar-menu--dark .cc-sidebar-menu__link:hover {
  background-color: #3d4668;
  color: var(--color-white);
}

.cc-sidebar-menu--dark .cc-sidebar-menu__item.is-active > .cc-sidebar-menu__link {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-left-color: var(--color-primary);
}

.cc-sidebar-menu--dark .cc-sidebar-menu__sublabel {
  color: #8a93a8;
}

.cc-sidebar-menu--dark .cc-sidebar-menu__submenu {
  background-color: #141829;
}

.cc-sidebar-menu--dark .cc-sidebar-menu__item {
  border-bottom-color: #3d4668;
}

/* Light variant (default) */
.cc-sidebar-menu--light {
  background-color: var(--color-white);
  border-color: var(--color-border);
}

.cc-sidebar-menu--light .cc-sidebar-menu__link {
  color: var(--color-text-secondary);
}

.cc-sidebar-menu--light .cc-sidebar-menu__submenu {
  background-color: var(--color-bg-alt);
}

/* Full width variant */
.cc-sidebar-menu--full-width {
  width: 100%;
  max-width: 100%;
}

/* Icon-only variant */
.cc-sidebar-menu--icon-only .cc-sidebar-menu__text {
  display: none;
}

.cc-sidebar-menu--icon-only .cc-sidebar-menu__link {
  justify-content: center;
  padding: var(--spacing-md);
}

.cc-sidebar-menu--icon-only .cc-sidebar-menu__icon {
  margin: 0;
}

/* ============================================
   SIDEBAR MENU ANIMATION STATES
   ============================================ */

/* Disabled menu item */
.cc-sidebar-menu__item.is-disabled > .cc-sidebar-menu__link {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Loading state */
.cc-sidebar-menu--loading .cc-sidebar-menu__link {
  opacity: 0.7;
  pointer-events: none;
}

/* ============================================
   SIDEBAR MENU WITH BREADCRUMB
   ============================================ */

.cc-sidebar-menu__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  padding: 0 var(--spacing-lg) var(--spacing-sm);
}

.cc-sidebar-menu__breadcrumb-item {
  display: inline;
}

.cc-sidebar-menu__breadcrumb-item:not(:last-child)::after {
  content: '/';
  margin: 0 var(--spacing-xs);
  color: var(--color-border);
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 1024px) {
  .cc-sidebar-menu {
    max-width: 100%;
  }

  .cc-sidebar-menu--icon-only .cc-sidebar-menu__text {
    display: none;
  }
}

@media (max-width: 768px) {
  .cc-sidebar-menu {
    border-radius: var(--border-radius-lg);
    max-width: 100%;
  }

  .cc-sidebar-menu__link {
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-base);
    min-height: 44px;
  }

  .cc-sidebar-menu__submenu .cc-sidebar-menu__link {
    padding: var(--spacing-sm) var(--spacing-lg);
    padding-left: 2.5rem;
  }

  .cc-sidebar-menu--compact .cc-sidebar-menu__link {
    padding: var(--spacing-sm) var(--spacing-md);
    min-height: 44px;
  }

  .cc-sidebar-menu__item--level-2 {
    padding-left: var(--spacing-lg);
  }

  .cc-sidebar-menu__item--level-3 {
    padding-left: calc(var(--spacing-lg) * 2);
  }
}

@media (max-width: 480px) {
  .cc-sidebar-menu {
    border-radius: var(--border-radius-md);
    max-width: 100%;
  }

  .cc-sidebar-menu__link {
    padding: 0.75rem 1rem;
    font-size: 1rem; /* 16px converted to rem */
    min-height: 44px;
    gap: var(--spacing-sm);
  }

  .cc-sidebar-menu__icon {
    width: 1.25rem;
    height: 1.25rem;
    font-size: 1rem;
  }

  .cc-sidebar-menu__submenu .cc-sidebar-menu__link {
    padding: 0.625rem 1rem;
    padding-left: 2rem;
    font-size: var(--font-size-sm);
  }

  .cc-sidebar-menu__expand-indicator {
    width: 1.25rem;
    height: 1.25rem;
  }

  .cc-sidebar-menu__badge {
    min-width: 20px;
    height: 20px;
    padding: 0 0.375rem;
    font-size: 0.65rem;
  }

  .cc-sidebar-menu--icon-only .cc-sidebar-menu__link {
    padding: var(--spacing-md);
  }

  /* Make menu full-width on mobile */
  .cc-sidebar-menu {
    width: 100%;
  }

  /* Reduce nesting indentation on mobile */
  .cc-sidebar-menu__item--level-2 {
    padding-left: 0.5rem;
  }

  .cc-sidebar-menu__item--level-3 {
    padding-left: 1rem;
  }

  .cc-sidebar-menu__submenu .cc-sidebar-menu__item--level-3 .cc-sidebar-menu__link {
    padding-left: 2.5rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-sidebar-menu__link,
  .cc-sidebar-menu__expand-indicator,
  .cc-sidebar-menu__submenu,
  .cc-sidebar-menu__badge {
    transition: none;
  }

  .cc-sidebar-menu__expand-indicator {
    transition: none;
  }

  .cc-sidebar-menu__item.is-expanded > .cc-sidebar-menu__link .cc-sidebar-menu__expand-indicator {
    transform: none;
  }
}

/* Source: components/interactive/accordion.css */
/**
 * Accordion Component
 * ===================
 * Expandable/collapsible content sections, FAQ layouts
 * BEM naming convention: .cc-accordion, .cc-accordion__*, variants
 *
 * Features: Expand/collapse animations, icon indicators
 * Variants: single-expand (default), multi-expand
 * Accessibility: Keyboard (arrow keys), ARIA attributes
 * Responsive: Full mobile support, stacking
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE ACCORDION STYLES
   ============================================ */

.cc-accordion {
  /* Container for accordion items */
  width: 100%;
  list-style: none;
  margin: 0;
  padding: 0;

  /* Border styling */
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-lg);
  overflow: hidden;
}

.cc-accordion__item {
  /* Individual accordion item */
  list-style: none;
  margin: 0;
  padding: 0;

  /* Border between items */
  border-bottom: var(--border-width-thin) solid var(--color-border);
}

.cc-accordion__item:last-child {
  /* Remove bottom border from last item */
  border-bottom: none;
}

/* ============================================
   ACCORDION HEADER/TRIGGER
   ============================================ */

.cc-accordion__trigger {
  /* Clickable header */
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--spacing-lg);

  /* Typography */
  background-color: var(--color-white);
  border: none;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
  text-align: left;
  cursor: pointer;

  /* Transition */
  transition: var(--transition-colors);

  /* Remove button default styles */
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;

  /* Focus state */
  position: relative;
}

.cc-accordion__trigger:hover {
  background-color: var(--color-primary-light);
}

.cc-accordion__trigger:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: -2px;
}

.cc-accordion__trigger[aria-expanded="true"] {
  /* Active/expanded state */
  background-color: var(--color-primary-light);
  color: var(--color-primary);
}

/* Trigger text content */
.cc-accordion__trigger-text {
  /* Text wrapper */
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.cc-accordion__trigger-title {
  /* Main question/title */
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: inherit;
  margin: 0;
  padding: 0;
}

.cc-accordion__trigger-subtitle {
  /* Optional subtitle/context */
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  color: var(--color-text-muted);
  margin: 0;
  padding: 0;
}

/* ============================================
   ACCORDION ICON/INDICATOR
   ============================================ */

.cc-accordion__icon {
  /* Expand/collapse indicator icon */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  margin-left: var(--spacing-lg);
  flex-shrink: 0;

  /* Color */
  color: var(--color-primary);

  /* Transition - smooth rotation */
  transition: transform var(--duration-base) var(--ease-out);

  /* SVG sizing */
  font-size: 1.25rem;
  line-height: 1;
}

.cc-accordion__trigger[aria-expanded="true"] .cc-accordion__icon {
  /* Rotate icon when expanded */
  transform: rotate(180deg);
}

/* Alternative arrow icon styling */
.cc-accordion__icon--plus {
  /* Plus/minus style icon */
}

.cc-accordion__trigger[aria-expanded="true"] .cc-accordion__icon--plus::before {
  /* Change plus to minus when open */
  content: '';
}

/* ============================================
   ACCORDION CONTENT PANEL
   ============================================ */

.cc-accordion__panel {
  /* Content panel - hidden by default */
  display: none;
  width: 100%;
  padding: 0;
  margin: 0;

  /* Appearance */
  background-color: var(--color-white);
  border-top: var(--border-width-thin) solid var(--color-border-light);

  /* Overflow for long content */
  overflow: hidden;

  /* Animation */
  animation: slideDown var(--duration-base) var(--ease-out);
}

.cc-accordion__trigger[aria-expanded="true"] ~ .cc-accordion__panel {
  /* Show panel when trigger is expanded */
  display: block;
}

/* Slide down animation */
@keyframes slideDown {
  from {
    opacity: 0;
    max-height: 0;
  }

  to {
    opacity: 1;
    max-height: 1000px;
  }
}

/* Slide up animation for closing */
@keyframes slideUp {
  from {
    opacity: 1;
    max-height: 1000px;
  }

  to {
    opacity: 0;
    max-height: 0;
  }
}

.cc-accordion__panel-content {
  /* Inner content wrapper */
  padding: var(--spacing-lg);

  /* Typography */
  color: var(--color-text-secondary);
  line-height: var(--line-height-base);
}

/* Nested elements in accordion content */
.cc-accordion__panel-content p {
  margin: 0 0 var(--spacing-md) 0;
}

.cc-accordion__panel-content p:last-child {
  margin-bottom: 0;
}

.cc-accordion__panel-content ul,
.cc-accordion__panel-content ol {
  margin: 0 0 var(--spacing-md) var(--spacing-lg);
  padding-left: var(--spacing-lg);
}

.cc-accordion__panel-content li {
  margin-bottom: var(--spacing-sm);
}

.cc-accordion__panel-content a {
  color: var(--color-primary);
  text-decoration: underline;
  transition: color var(--transition-colors);
}

.cc-accordion__panel-content a:hover {
  color: var(--color-primary-dark);
}

/* ============================================
   ACCORDION VARIANTS
   ============================================ */

/* Single Expand (default) - only one item open at a time */
.cc-accordion--single .cc-accordion__item:not(:first-child) .cc-accordion__trigger[aria-expanded="true"] {
  /* Automatically close others via JavaScript */
}

/* Multi-Expand - multiple items can be open */
.cc-accordion--multi {
  /* Allow multiple items to be expanded */
}

/* Bordered accordion (default) */
.cc-accordion--bordered {
  /* Default with borders */
}

/* Borderless accordion */
.cc-accordion--borderless {
  border: none;
}

.cc-accordion--borderless .cc-accordion__item {
  border-bottom: none;
  padding-bottom: var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
}

.cc-accordion--borderless .cc-accordion__item:last-child {
  padding-bottom: 0;
  margin-bottom: 0;
}

/* Flush accordion - no rounded corners */
.cc-accordion--flush {
  border-radius: 0;
}

/* Seamless accordion - minimal styling */
.cc-accordion--seamless {
  border: none;
}

.cc-accordion--seamless .cc-accordion__item {
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
}

.cc-accordion--seamless .cc-accordion__trigger {
  padding: var(--spacing-md) 0;
}

/* Compact accordion */
.cc-accordion--compact .cc-accordion__trigger {
  padding: var(--spacing-md) var(--spacing-lg);
}

.cc-accordion--compact .cc-accordion__panel-content {
  padding: var(--spacing-md) var(--spacing-lg);
}

/* Large accordion */
.cc-accordion--large .cc-accordion__trigger {
  padding: var(--spacing-xl) var(--spacing-2xl);
}

.cc-accordion--large .cc-accordion__trigger-title {
  font-size: var(--font-size-lg);
}

.cc-accordion--large .cc-accordion__panel-content {
  padding: var(--spacing-xl) var(--spacing-2xl);
}

/* ============================================
   ACCORDION COLOR VARIANTS
   ============================================ */

/* Primary color variant */
.cc-accordion--primary .cc-accordion__trigger:hover {
  background-color: var(--color-primary-light);
}

.cc-accordion--primary .cc-accordion__trigger[aria-expanded="true"] {
  background-color: var(--color-primary-light);
}

/* Success variant */
.cc-accordion--success .cc-accordion__trigger {
  color: #155724;
}

.cc-accordion--success .cc-accordion__trigger:hover {
  background-color: #d4edda;
}

.cc-accordion--success .cc-accordion__trigger[aria-expanded="true"] {
  background-color: #d4edda;
  color: #155724;
}

.cc-accordion--success .cc-accordion__icon {
  color: #28a745;
}

/* ============================================
   ACCORDION STATES
   ============================================ */

/* Disabled accordion item */
.cc-accordion__item--disabled .cc-accordion__trigger {
  opacity: 0.6;
  cursor: not-allowed;
  background-color: var(--color-gray-100);
}

.cc-accordion__item--disabled .cc-accordion__trigger:hover {
  background-color: var(--color-gray-100);
}

/* Active/featured item */
.cc-accordion__item--active .cc-accordion__trigger {
  background-color: var(--color-primary-light);
  color: var(--color-primary);
}

/* Loading state */
.cc-accordion__item--loading .cc-accordion__trigger {
  pointer-events: none;
  opacity: 0.8;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-accordion {
    border-radius: var(--border-radius-md);
  }

  .cc-accordion__trigger {
    padding: var(--spacing-md);
    font-size: var(--font-size-sm);
  }

  .cc-accordion__trigger-title {
    font-size: var(--font-size-sm);
  }

  .cc-accordion__trigger-subtitle {
    display: none;
  }

  .cc-accordion__icon {
    width: 20px;
    height: 20px;
    margin-left: var(--spacing-md);
    font-size: 1rem;
  }

  .cc-accordion__panel-content {
    padding: var(--spacing-md);
  }

  .cc-accordion--large .cc-accordion__trigger {
    padding: var(--spacing-lg);
  }

  .cc-accordion--large .cc-accordion__trigger-title {
    font-size: var(--font-size-base);
  }

  .cc-accordion--large .cc-accordion__panel-content {
    padding: var(--spacing-lg);
  }
}

@media (max-width: 480px) {
  .cc-accordion {
    border-radius: var(--border-radius-md);
  }

  .cc-accordion__trigger {
    padding: var(--spacing-sm);
  }

  .cc-accordion__trigger-title {
    font-size: var(--font-size-sm);
  }

  .cc-accordion__icon {
    width: 18px;
    height: 18px;
    margin-left: var(--spacing-sm);
  }

  .cc-accordion__panel-content {
    padding: var(--spacing-sm);
  }

  .cc-accordion__panel-content ul,
  .cc-accordion__panel-content ol {
    margin-left: var(--spacing-md);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-accordion__panel {
    animation: none;
  }

  .cc-accordion__trigger,
  .cc-accordion__icon {
    transition: none;
  }

  .cc-accordion__trigger[aria-expanded="true"] .cc-accordion__icon {
    transform: none;
  }
}

/* Source: components/interactive/filter.css */
/**
 * Filter/Search Component
 * =======================
 * Dynamic filtering and search controls for content discovery
 * BEM naming convention: .cc-filter, .cc-filter__*, variants
 *
 * Features: Filter buttons, search input, result count, tags
 * Variants: horizontal, vertical, dropdown, sidebar
 * Responsive: Mobile-optimized with collapsible filters
 * Accessibility: Keyboard navigation, ARIA labels
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE FILTER STYLES
   ============================================ */

.cc-filter {
  /* Filter container */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
  width: 100%;
}

.cc-filter--horizontal {
  /* Horizontal layout */
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
}

.cc-filter--vertical {
  /* Vertical layout */
  flex-direction: column;
  gap: var(--spacing-lg);
}

/* ============================================
   FILTER SEARCH INPUT
   ============================================ */

.cc-filter__search {
  /* Search input wrapper */
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 400px;

  /* Appearance */
  background-color: var(--color-white);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: 0 var(--spacing-md);

  /* Transition */
  transition: border-color var(--transition-colors);
}

.cc-filter__search:focus-within {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

.cc-filter__search-icon {
  /* Search icon */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  color: var(--color-text-muted);
  flex-shrink: 0;
  font-size: 1rem;
}

.cc-filter__search-input {
  /* Search input field */
  flex: 1;
  padding: var(--spacing-sm) 0;
  border: none;
  background: transparent;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  color: var(--color-text-secondary);
  outline: none;
}

.cc-filter__search-input::placeholder {
  color: var(--color-text-muted);
}

.cc-filter__search-clear {
  /* Clear search button */
  display: none;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  background: transparent;
  border: none;
  color: var(--color-text-muted);
  cursor: pointer;
  flex-shrink: 0;
  transition: color var(--transition-colors);
}

.cc-filter__search-input:not(:placeholder-shown) ~ .cc-filter__search-clear {
  display: flex;
}

.cc-filter__search-clear:hover {
  color: var(--color-primary);
}

/* ============================================
   FILTER GROUPS
   ============================================ */

.cc-filter-group {
  /* Group of related filters */
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-md);
  align-items: center;
}

.cc-filter-group--vertical {
  flex-direction: column;
  align-items: stretch;
}

.cc-filter-group__label {
  /* Group label */
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
  min-width: fit-content;
}

.cc-filter-group__controls {
  /* Filter control buttons */
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

/* ============================================
   FILTER BUTTON/TAG
   ============================================ */

.cc-filter__button {
  /* Individual filter button */
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: 0.5rem 1rem;

  /* Typography */
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  text-decoration: none;

  /* Appearance */
  background-color: var(--color-bg-alt);
  color: var(--color-text-secondary);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);

  /* Cursor */
  cursor: pointer;

  /* Transition */
  transition: var(--transition-colors);
}

.cc-filter__button:hover {
  background-color: var(--color-primary-light);
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.cc-filter__button--active {
  /* Active filter */
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

.cc-filter__button--active:hover {
  background-color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
}

.cc-filter__button-count {
  /* Result count in filter button */
  display: inline-block;
  padding: 0 0.375rem;
  font-size: 0.75rem;
  font-weight: var(--font-weight-semibold);
  opacity: 0.75;
}

.cc-filter__button--active .cc-filter__button-count {
  opacity: 1;
}

.cc-filter__button-icon {
  /* Icon in filter button */
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  font-size: 1rem;
  line-height: 1;
}

/* ============================================
   FILTER TAGS (ACTIVE FILTERS)
   ============================================ */

.cc-filter-tags {
  /* Active filter tags display */
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
  align-items: center;
  padding: var(--spacing-md) 0;
}

.cc-filter-tags__label {
  /* "Active filters:" label */
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  white-space: nowrap;
}

.cc-filter-tag {
  /* Individual active filter tag */
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2xs);
  padding: 0.375rem 0.75rem;

  /* Typography */
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);

  /* Appearance */
  background-color: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--border-radius-md);
  border: var(--border-width-thin) solid var(--color-primary);
}

.cc-filter-tag__remove {
  /* Remove tag button */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  background: transparent;
  border: none;
  color: inherit;
  cursor: pointer;
  font-size: 0.875rem;
  flex-shrink: 0;
  transition: opacity var(--transition-colors);
}

.cc-filter-tag__remove:hover {
  opacity: 0.7;
}

.cc-filter-tags__clear {
  /* Clear all filters button */
  padding: 0;
  background: transparent;
  border: none;
  color: var(--color-primary);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  text-decoration: underline;
  transition: color var(--transition-colors);
}

.cc-filter-tags__clear:hover {
  color: var(--color-primary-dark);
  text-decoration: none;
}

/* ============================================
   FILTER DROPDOWN
   ============================================ */

.cc-filter-dropdown {
  /* Dropdown select for filters */
  padding: 0.5rem 0.75rem;
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  background-color: var(--color-white);
  cursor: pointer;
  transition: border-color var(--transition-colors);
}

.cc-filter-dropdown:hover {
  border-color: var(--color-primary);
}

.cc-filter-dropdown:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

/* ============================================
   FILTER RESULTS
   ============================================ */

.cc-filter-results {
  /* Results summary section */
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-lg);
  padding: var(--spacing-lg) 0;

  /* Border styling */
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
}

.cc-filter-results__count {
  /* Result count text */
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.cc-filter-results__count-number {
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
}

.cc-filter-results__sort {
  /* Sort controls in results section */
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.cc-filter-results__sort-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  white-space: nowrap;
}

/* ============================================
   FILTER STATES
   ============================================ */

/* Loading state */
.cc-filter--loading {
  opacity: 0.6;
  pointer-events: none;
}

.cc-filter--loading .cc-filter__button,
.cc-filter--loading .cc-filter__search-input {
  pointer-events: none;
}

/* Empty state */
.cc-filter-empty {
  text-align: center;
  padding: var(--spacing-2xl) var(--spacing-lg);
  color: var(--color-text-muted);
}

.cc-filter-empty__icon {
  font-size: 2rem;
  margin-bottom: var(--spacing-lg);
  color: var(--color-gray-300);
}

.cc-filter-empty__message {
  font-size: var(--font-size-base);
  margin: 0;
}

/* ============================================
   FILTER SIDEBAR
   ============================================ */

.cc-filter-sidebar {
  /* Sidebar filter container */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
  padding: var(--spacing-lg);

  /* Appearance */
  background-color: var(--color-bg-alt);
  border-radius: var(--border-radius-lg);
  border: var(--border-width-thin) solid var(--color-border);
}

.cc-filter-sidebar__section {
  /* Individual filter section */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.cc-filter-sidebar__section-title {
  /* Section title */
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-heading);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0;
  padding: 0;
  border-bottom: var(--border-width-thin) solid var(--color-border);
  padding-bottom: var(--spacing-md);
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-filter {
    flex-direction: column;
  }

  .cc-filter--horizontal {
    flex-direction: column;
    align-items: stretch;
  }

  .cc-filter__search {
    max-width: none;
  }

  .cc-filter-group {
    flex-direction: column;
  }

  .cc-filter-group__label {
    display: none;
  }

  .cc-filter-group__controls {
    width: 100%;
  }

  .cc-filter-results {
    flex-direction: column;
    align-items: flex-start;
  }

  .cc-filter-sidebar {
    padding: var(--spacing-md);
  }
}

@media (max-width: 480px) {
  .cc-filter__button {
    font-size: var(--font-size-xs);
    padding: 0.375rem 0.75rem;
  }

  .cc-filter-tag {
    font-size: var(--font-size-xs);
    padding: 0.25rem 0.5rem;
  }

  .cc-filter-results {
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-md);
  }

  .cc-filter-results__sort {
    width: 100%;
    flex-direction: column;
  }

  .cc-filter-results__sort-label {
    display: none;
  }

  .cc-filter-sidebar {
    padding: var(--spacing-sm);
    gap: var(--spacing-lg);
  }

  .cc-filter-sidebar__section {
    gap: var(--spacing-sm);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-filter__button,
  .cc-filter__search,
  .cc-filter__button--active {
    transition: none;
  }
}

/* Source: components/interactive/modal.css */
/**
 * Modal Component
 * ===============
 * Dialog/modal windows for overlays, forms, confirmations
 * BEM naming convention: .cc-modal, .cc-modal__*, variants
 *
 * Features: Header, body, footer sections, close button
 * Animations: Fade-in, slide-up, scale effects
 * Accessibility: Keyboard (ESC), focus trap, overlay dismiss
 * Responsive: Full mobile support, adaptive sizing
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   MODAL BACKDROP/OVERLAY
   ============================================ */

.cc-modal-backdrop {
  /* Fixed overlay that covers entire viewport */
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: var(--z-modal-backdrop);

  /* Animation */
  animation: fadeIn var(--duration-base) var(--ease-out);

  /* Transition for closing */
  transition: opacity var(--duration-base) var(--ease-in);
  opacity: 1;

  /* Prevent scrolling when modal is open */
  overflow: hidden;
}

.cc-modal-backdrop.cc-modal-backdrop--hidden {
  opacity: 0;
  pointer-events: none;
}

/* ============================================
   BASE MODAL STYLES
   ============================================ */

.cc-modal {
  /* Position centered on screen */
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: var(--z-modal);

  /* Size constraints */
  width: 90%;
  max-width: 600px;
  max-height: 90vh;

  /* Appearance */
  background-color: var(--color-white);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-xl);
  border: none;

  /* Overflow */
  overflow: hidden;
  display: flex;
  flex-direction: column;

  /* Animation */
  animation: slideUp var(--duration-base) var(--ease-out);

  /* Transition for closing */
  transition: all var(--duration-base) var(--ease-in);
  opacity: 1;
}

.cc-modal.cc-modal--hidden {
  opacity: 0;
  transform: translate(-50%, -45%);
  pointer-events: none;
}

/* Modal animation - slide up */
@keyframes slideUp {
  from {
    opacity: 0;
    transform: translate(-50%, -45%);
  }

  to {
    opacity: 1;
    transform: translate(-50%, -50%);
  }
}

/* Fade in animation */
@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* Scale animation variant */
.cc-modal--scale {
  animation: scaleIn var(--duration-base) var(--ease-out);
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.95);
  }

  to {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
}

/* ============================================
   MODAL HEADER
   ============================================ */

.cc-modal__header {
  /* Layout */
  display: flex;
  align-items: center;
  justify-content: space-between;

  /* Spacing */
  padding: var(--spacing-xl);
  border-bottom: var(--border-width-thin) solid var(--color-border-light);

  /* Appearance */
  background-color: var(--color-white);
  flex-shrink: 0;
}

.cc-modal__title {
  /* Typography */
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-heading);

  /* Spacing */
  margin: 0;
  padding: 0;

  /* Multi-line handling */
  flex: 1;
  word-wrap: break-word;
}

.cc-modal__close {
  /* Close button */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin-left: var(--spacing-lg);
  flex-shrink: 0;

  /* Appearance */
  background: transparent;
  border: none;
  color: var(--color-text-secondary);
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;

  /* Transition */
  transition: color var(--transition-colors);

  /* Focus state */
  border-radius: var(--border-radius-md);
}

.cc-modal__close:hover {
  color: var(--color-primary);
  background-color: var(--color-primary-light);
}

.cc-modal__close:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ============================================
   MODAL BODY
   ============================================ */

.cc-modal__body {
  /* Layout */
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;

  /* Spacing */
  padding: var(--spacing-xl);

  /* Scrollbar styling */
  scroll-behavior: smooth;
}

/* Scrollbar styling for modal body */
.cc-modal__body::-webkit-scrollbar {
  width: 8px;
}

.cc-modal__body::-webkit-scrollbar-track {
  background-color: var(--color-gray-100);
}

.cc-modal__body::-webkit-scrollbar-thumb {
  background-color: var(--color-gray-400);
  border-radius: 4px;
}

.cc-modal__body::-webkit-scrollbar-thumb:hover {
  background-color: var(--color-gray-500);
}

/* ============================================
   MODAL FOOTER
   ============================================ */

.cc-modal__footer {
  /* Layout */
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: flex-start;
  gap: var(--spacing-md);

  /* Spacing */
  padding: var(--spacing-lg);
  border-top: var(--border-width-thin) solid var(--color-border-light);

  /* Appearance */
  background-color: var(--color-gray-50);
  flex-shrink: 0;
}

.cc-modal__footer--stacked {
  flex-direction: column-reverse;
  gap: var(--spacing-sm);
}

.cc-modal__footer--centered {
  justify-content: center;
}

.cc-modal__button {
  /* Button styling - extends .cc-button */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-xs);
  padding: 0.75rem 1.5rem;
  min-height: 44px;

  /* Typography */
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  text-decoration: none;

  /* Appearance */
  background-color: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--border-radius-md);
  cursor: pointer;

  /* Transition */
  transition: var(--transition-base);
}

.cc-modal__button:hover {
  background-color: var(--color-primary-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.cc-modal__button--secondary {
  background-color: var(--color-bg-alt);
  color: var(--color-primary);
  border: var(--border-width-thin) solid var(--color-primary);
}

.cc-modal__button--secondary:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.cc-modal__button--cancel {
  background-color: transparent;
  color: var(--color-text-secondary);
  border: var(--border-width-thin) solid var(--color-border);
}

.cc-modal__button--cancel:hover {
  background-color: var(--color-gray-100);
  border-color: var(--color-text-secondary);
}

/* ============================================
   MODAL VARIANTS
   ============================================ */

/* Small modal */
.cc-modal--sm {
  max-width: 400px;
}

/* Medium modal - default */
.cc-modal--md {
  max-width: 600px;
}

/* Large modal */
.cc-modal--lg {
  max-width: 800px;
}

/* Full-width modal */
.cc-modal--full {
  width: 95%;
  max-width: 100%;
  max-height: 95vh;
}

/* Alert/Confirmation modal */
.cc-modal--alert {
  max-width: 400px;
}

.cc-modal--alert .cc-modal__body {
  text-align: center;
  padding: var(--spacing-2xl) var(--spacing-xl);
}

/* Danger/Destructive action modal */
.cc-modal--danger .cc-modal__header {
  border-bottom-color: #f8d7da;
  background-color: #fff5f7;
}

.cc-modal--danger .cc-modal__title {
  color: #721c24;
}

.cc-modal--danger .cc-modal__button {
  background-color: #dc3545;
}

.cc-modal--danger .cc-modal__button:hover {
  background-color: #c82333;
}

/* Success/Confirmation modal */
.cc-modal--success .cc-modal__header {
  border-bottom-color: #c3e6cb;
  background-color: #f0f7f4;
}

.cc-modal--success .cc-modal__title {
  color: #155724;
}

.cc-modal--success .cc-modal__button {
  background-color: #28a745;
}

.cc-modal--success .cc-modal__button:hover {
  background-color: #218838;
}

/* ============================================
   MODAL STATES
   ============================================ */

/* Loading state */
.cc-modal--loading {
  pointer-events: none;
  opacity: 0.8;
}

.cc-modal--loading .cc-modal__button {
  pointer-events: none;
  opacity: 0.6;
}

.cc-modal--loading .cc-modal__spinner {
  display: block;
}

/* Fullscreen on mobile */
.cc-modal--fullscreen {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  border-radius: 0;
  top: 0;
  left: 0;
  transform: none;
}

/* ============================================
   MODAL CONTENT ELEMENTS
   ============================================ */

.cc-modal__icon {
  /* Icon in modal body */
  display: block;
  font-size: 3rem;
  color: var(--color-primary);
  margin-bottom: var(--spacing-lg);
  text-align: center;
}

.cc-modal__icon--danger {
  color: #dc3545;
}

.cc-modal__icon--success {
  color: #28a745;
}

.cc-modal__icon--warning {
  color: #ffc107;
}

.cc-modal__message {
  /* Message text */
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text-secondary);
  margin: 0 0 var(--spacing-lg) 0;
}

.cc-modal__actions {
  /* Action button group */
  display: flex;
  gap: var(--spacing-md);
  margin-top: var(--spacing-lg);
}

/* ============================================
   FOCUS TRAP & KEYBOARD
   ============================================ */

.cc-modal[open] {
  /* Dialog element when open */
  display: flex;
}

.cc-modal::backdrop {
  /* Native backdrop for dialog element */
  background-color: rgba(0, 0, 0, 0.5);
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-modal {
    width: 95%;
    max-width: none;
    max-height: 95vh;
  }

  .cc-modal--sm,
  .cc-modal--md {
    max-width: 95%;
  }

  .cc-modal--lg {
    max-width: 95%;
  }

  .cc-modal__header {
    padding: var(--spacing-lg);
  }

  .cc-modal__body {
    padding: var(--spacing-lg);
  }

  .cc-modal__footer {
    padding: var(--spacing-lg);
    flex-direction: column;
  }

  .cc-modal__button {
    width: 100%;
  }

  .cc-modal--alert .cc-modal__body {
    padding: var(--spacing-lg);
  }
}

@media (max-width: 480px) {
  .cc-modal {
    width: 100%;
    max-height: 100%;
    border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    transform: translateY(0);
    animation: slideUpMobile var(--duration-base) var(--ease-out);
  }

  .cc-modal.cc-modal--hidden {
    transform: translateY(100%);
  }

  @keyframes slideUpMobile {
    from {
      opacity: 0;
      transform: translateY(100%);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  .cc-modal__header {
    padding: var(--spacing-md) var(--spacing-md) var(--spacing-lg) var(--spacing-md);
  }

  .cc-modal__title {
    font-size: var(--font-size-lg);
  }

  .cc-modal__body {
    padding: var(--spacing-md);
  }

  .cc-modal__footer {
    padding: var(--spacing-md);
    gap: var(--spacing-sm);
  }

  .cc-modal__button {
    padding: 0.625rem 1.25rem;
    font-size: var(--font-size-sm);
  }

  .cc-modal--fullscreen {
    border-radius: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-modal,
  .cc-modal-backdrop,
  .cc-modal__button,
  .cc-modal__close {
    animation: none;
    transition: none;
  }
}

/* Source: components/interactive/slider.css */
/**
 * Slider/Carousel Component
 * =======================
 * Image carousel with navigation controls, auto-play, and touch support
 * BEM naming convention: .cc-slider, .cc-slider__*, variants
 *
 * Features: Image carousel, prev/next arrows, dot pagination, auto-play
 * Transitions: fade (default), slide
 * Keyboard: Arrow keys (left/right), Home/End, Page Up/Down
 * Touch support: Swipe left/right gestures
 * Responsive: Controls adapt to mobile, images fill container
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE SLIDER STYLES
   ============================================ */

.cc-slider {
  /* Position relative for overlays and controls */
  position: relative;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
  background-color: var(--color-gray-100);
  border-radius: var(--border-radius-lg);
}

.cc-slider__wrapper {
  /* Container for slides with overflow hidden */
  position: relative;
  width: 100%;
  overflow: hidden;
  background-color: #000;
}

/* ============================================
   SLIDER TRACK & SLIDES
   ============================================ */

.cc-slider__track {
  /* Container for all slides */
  display: flex;
  width: 100%;
  height: 100%;
  transition: transform var(--transition-base) ease-out;
}

.cc-slider__slide {
  /* Individual slide item */
  position: relative;
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-gray-100);
  overflow: hidden;
}

.cc-slider__slide-image {
  /* Slide image */
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.cc-slider__slide-content {
  /* Content overlay on slide */
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-2xl);
  text-align: center;
  background: linear-gradient(
    135deg,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.5) 100%
  );
  color: var(--color-white);
  opacity: 0;
  transition: opacity var(--transition-colors) ease-out;
  z-index: 5;
}

.cc-slider__slide.is-active .cc-slider__slide-content {
  /* Show content on active slide */
  opacity: 1;
}

.cc-slider__slide-title {
  /* Slide title text */
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-snug);
  color: var(--color-white);
  margin: 0;
  padding: 0 var(--spacing-lg);
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.cc-slider__slide-description {
  /* Slide description text */
  font-size: var(--font-size-lg);
  line-height: var(--line-height-base);
  color: rgba(255, 255, 255, 0.95);
  margin: var(--spacing-md) 0 0 0;
  padding: 0 var(--spacing-lg);
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.cc-slider__slide-cta {
  /* CTA button on slide */
  margin-top: var(--spacing-lg);
  z-index: 6;
}

/* ============================================
   SLIDER NAVIGATION - ARROWS
   ============================================ */

.cc-slider__nav-button {
  /* Prev/Next arrow buttons */
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: var(--z-dropdown);
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.5);
  color: var(--color-white);
  border: none;
  cursor: pointer;
  font-size: 1.5rem;
  transition: var(--transition-colors);
  border-radius: var(--border-radius-md);
}

.cc-slider__nav-button:hover {
  background-color: rgba(0, 0, 0, 0.8);
}

.cc-slider__nav-button:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.cc-slider__nav-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.cc-slider__nav-button--prev {
  left: var(--spacing-lg);
}

.cc-slider__nav-button--next {
  right: var(--spacing-lg);
}

.cc-slider__nav-icon {
  /* Arrow icon */
  width: 1.5rem;
  height: 1.5rem;
  display: block;
}

/* ============================================
   SLIDER NAVIGATION - DOTS
   ============================================ */

.cc-slider__dots {
  /* Dot pagination container */
  position: absolute;
  bottom: var(--spacing-lg);
  left: 50%;
  transform: translateX(-50%);
  z-index: var(--z-dropdown);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  list-style: none;
  margin: 0;
  padding: 0;
}

.cc-slider__dot {
  /* Individual dot button */
  display: inline-block;
  width: 12px;
  height: 12px;
  background-color: rgba(255, 255, 255, 0.5);
  border: none;
  border-radius: var(--border-radius-full);
  cursor: pointer;
  transition: var(--transition-colors);
  padding: 0;
}

.cc-slider__dot:hover {
  background-color: rgba(255, 255, 255, 0.8);
}

.cc-slider__dot.is-active {
  background-color: var(--color-white);
  width: 32px;
  border-radius: var(--border-radius-full);
}

.cc-slider__dot:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ============================================
   SLIDER VARIANTS
   ============================================ */

/* Hero Variant - Large hero slider */
.cc-slider--hero {
  min-height: 500px;
}

.cc-slider--hero .cc-slider__wrapper {
  aspect-ratio: 16 / 9;
  min-height: 500px;
}

.cc-slider--hero .cc-slider__slide-title {
  font-size: clamp(1.75rem, 5vw, 3.5rem);
}

.cc-slider--hero .cc-slider__slide-description {
  font-size: clamp(1rem, 2vw, 1.5rem);
}

/* Thumbnail Variant - Smaller carousel */
.cc-slider--thumbnail {
  min-height: 250px;
}

.cc-slider--thumbnail .cc-slider__wrapper {
  aspect-ratio: 4 / 3;
  min-height: 250px;
}

.cc-slider--thumbnail .cc-slider__nav-button {
  width: 40px;
  height: 40px;
  font-size: 1.25rem;
}

.cc-slider--thumbnail .cc-slider__nav-button--prev {
  left: var(--spacing-md);
}

.cc-slider--thumbnail .cc-slider__nav-button--next {
  right: var(--spacing-md);
}

/* Full-width Variant - Covers full viewport width */
.cc-slider--full-width {
  margin: 0 -2rem;
  width: calc(100% + 4rem);
}

.cc-slider--full-width .cc-slider__wrapper {
  aspect-ratio: 16 / 9;
}

/* No Controls Variant - Auto-play only, no navigation */
.cc-slider--no-controls .cc-slider__nav-button,
.cc-slider--no-controls .cc-slider__dots {
  display: none;
}

/* Fade Transition - Default */
.cc-slider--fade .cc-slider__slide {
  position: absolute;
  opacity: 0;
  transition: opacity 0.6s ease-out;
}

.cc-slider--fade .cc-slider__slide.is-active {
  position: relative;
  opacity: 1;
}

.cc-slider--fade .cc-slider__track {
  display: none;
}

/* Slide Transition - Transform-based */
.cc-slider--slide .cc-slider__track {
  display: flex;
}

.cc-slider--slide .cc-slider__slide {
  opacity: 1;
  transition: transform 0.6s ease-out;
}

/* ============================================
   SLIDER CONTROLS
   ============================================ */

.cc-slider__controls {
  /* Control bar below slider */
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md);
  background-color: var(--color-bg-alt);
  border-top: var(--border-width-thin) solid var(--color-border-light);
}

.cc-slider__info {
  /* Slide counter and info */
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.cc-slider__counter {
  /* Current/Total slide number */
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
}

.cc-slider__play-btn {
  /* Play/Pause button */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background-color: var(--color-primary-light);
  color: var(--color-primary);
  border: none;
  border-radius: var(--border-radius-md);
  cursor: pointer;
  font-size: 1rem;
  transition: var(--transition-colors);
}

.cc-slider__play-btn:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.cc-slider__play-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ============================================
   SLIDER STATES & ANIMATIONS
   ============================================ */

/* Loading state */
.cc-slider--loading {
  opacity: 0.6;
  pointer-events: none;
}

/* Auto-play indicator (visual feedback) */
.cc-slider__play-btn.is-playing {
  background-color: var(--color-primary);
  color: var(--color-white);
}

/* Touch indicator (shows swipe is supported) */
.cc-slider--touch .cc-slider__slide {
  cursor: grab;
}

.cc-slider--touch.is-dragging .cc-slider__slide {
  cursor: grabbing;
}

/* Slide transition animations */
@keyframes slideInFromRight {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes slideInFromLeft {
  from {
    transform: translateX(-100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes fadeInSlide {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.cc-slider--animate-in {
  animation: fadeInSlide 0.6s ease-out;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-slider {
    border-radius: var(--border-radius-md);
  }

  .cc-slider--hero .cc-slider__wrapper {
    aspect-ratio: 4 / 3;
    min-height: 300px;
  }

  .cc-slider--hero .cc-slider__slide-title {
    font-size: clamp(1.25rem, 4vw, 2.5rem);
  }

  .cc-slider--hero .cc-slider__slide-description {
    font-size: clamp(0.875rem, 1.5vw, 1.25rem);
  }

  .cc-slider__nav-button {
    width: 44px;
    height: 44px;
    font-size: 1.25rem;
  }

  .cc-slider__nav-button--prev {
    left: var(--spacing-md);
  }

  .cc-slider__nav-button--next {
    right: var(--spacing-md);
  }

  .cc-slider__slide-content {
    padding: var(--spacing-xl);
  }

  .cc-slider__dots {
    bottom: var(--spacing-md);
  }

  .cc-slider__controls {
    padding: var(--spacing-sm);
  }
}

@media (max-width: 480px) {
  .cc-slider {
    border-radius: var(--border-radius-md);
  }

  .cc-slider--hero .cc-slider__wrapper {
    aspect-ratio: 1 / 1;
    min-height: 200px;
  }

  .cc-slider--thumbnail .cc-slider__wrapper {
    aspect-ratio: 1 / 1;
    min-height: 180px;
  }

  .cc-slider--full-width {
    margin: 0 -1rem;
    width: calc(100% + 2rem);
  }

  .cc-slider__nav-button {
    width: 40px;
    height: 40px;
    font-size: 1rem;
  }

  .cc-slider__nav-button--prev {
    left: var(--spacing-sm);
  }

  .cc-slider__nav-button--next {
    right: var(--spacing-sm);
  }

  .cc-slider__slide-title {
    font-size: var(--font-size-lg);
  }

  .cc-slider__slide-description {
    font-size: var(--font-size-base);
    display: none;
  }

  .cc-slider__slide-content {
    padding: var(--spacing-lg);
  }

  .cc-slider__dots {
    bottom: var(--spacing-sm);
    gap: var(--spacing-xs);
  }

  .cc-slider__dot {
    width: 10px;
    height: 10px;
  }

  .cc-slider__dot.is-active {
    width: 28px;
  }

  .cc-slider__controls {
    flex-direction: column-reverse;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm);
  }

  .cc-slider__info {
    font-size: var(--font-size-xs);
  }

  .cc-slider__play-btn {
    width: 36px;
    height: 36px;
    font-size: 0.875rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-slider__track,
  .cc-slider__slide,
  .cc-slider__slide-content,
  .cc-slider__dot,
  .cc-slider__nav-button {
    transition: none;
    animation: none;
  }

  .cc-slider--fade .cc-slider__slide {
    transition: none;
  }

  .cc-slider--animate-in {
    animation: none;
  }
}

/* Source: components/forms/form-field.css */
/**
 * Form Field Wrapper Component
 * ============================
 * Consistent form field styling with label, help text, error messages
 * BEM naming convention: .cc-form-field, .cc-form-field__*, variants
 *
 * Features: Labels, required indicators, help text, error messages, success states
 * Accessibility: For attribute linking, ARIA labels, screen reader support
 * Layout: Stacked (default), inline, horizontal variants
 * Validation: Error states, warning, success confirmation
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE FORM FIELD STYLES
   ============================================ */

.cc-form-field {
  /* Form field container wrapper */
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-lg);
  width: 100%;
}

.cc-form-field--inline {
  /* Inline layout - label and input side by side */
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-md);
}

.cc-form-field--horizontal {
  /* Horizontal layout with label on left, 40% width */
  flex-direction: row;
  align-items: flex-start;
  gap: var(--spacing-lg);
}

.cc-form-field--compact {
  /* Compact spacing */
  gap: var(--spacing-xs);
  margin-bottom: var(--spacing-md);
}

/* ============================================
   FORM FIELD LABEL
   ============================================ */

.cc-form-field__label {
  /* Form field label */
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  line-height: var(--line-height-snug);
  margin: 0;
  padding: 0;
}

.cc-form-field--inline .cc-form-field__label {
  white-space: nowrap;
}

.cc-form-field--horizontal .cc-form-field__label {
  width: 40%;
  flex-shrink: 0;
  padding-top: 0.625rem;
}

/* Label for readonly/disabled fields */
.cc-form-field__label:disabled {
  color: var(--color-text-muted);
  cursor: not-allowed;
}

/* ============================================
   REQUIRED INDICATOR
   ============================================ */

.cc-form-field__required {
  /* Required asterisk indicator */
  color: #dc3545;
  font-weight: var(--font-weight-bold);
  margin-left: 0.25rem;
}

.cc-form-field__required::after {
  content: '*';
}

/* Optional indicator */
.cc-form-field__optional {
  color: var(--color-text-muted);
  font-size: 0.875rem;
  font-weight: var(--font-weight-regular);
  margin-left: 0.5rem;
}

.cc-form-field__optional::after {
  content: '(Optional)';
}

/* ============================================
   FORM FIELD INPUT WRAPPER
   ============================================ */

.cc-form-field__input-wrapper {
  /* Wrapper for input element */
  display: flex;
  flex-direction: column;
  width: 100%;
  flex: 1;
}

.cc-form-field--inline .cc-form-field__input-wrapper {
  flex: 1;
  min-width: 200px;
}

.cc-form-field--horizontal .cc-form-field__input-wrapper {
  width: 60%;
  flex-shrink: 0;
}

/* ============================================
   FORM FIELD HELP TEXT
   ============================================ */

.cc-form-field__help {
  /* Help text below input */
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  line-height: var(--line-height-base);
  margin: 0;
  padding: 0;
  display: block;
}

/* ============================================
   FORM FIELD ERROR STATE
   ============================================ */

.cc-form-field--error {
  /* Field error state */
}

.cc-form-field--error .cc-form-field__label {
  color: #dc3545;
}

.cc-form-field--error .cc-form-field__help {
  display: block;
  color: #dc3545;
  font-weight: var(--font-weight-semibold);
}

.cc-form-field--error .cc-form-field__error-message {
  display: block;
  color: #dc3545;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  margin-top: 0.25rem;
}

/* Error icon */
.cc-form-field__error-icon {
  width: 1rem;
  height: 1rem;
  color: #dc3545;
  flex-shrink: 0;
  margin-right: var(--spacing-xs);
}

/* ============================================
   FORM FIELD WARNING STATE
   ============================================ */

.cc-form-field--warning {
  /* Field warning state */
}

.cc-form-field--warning .cc-form-field__label {
  color: #ff9800;
}

.cc-form-field--warning .cc-form-field__warning-message {
  display: block;
  color: #ff9800;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  margin-top: 0.25rem;
}

.cc-form-field__warning-icon {
  width: 1rem;
  height: 1rem;
  color: #ff9800;
  flex-shrink: 0;
  margin-right: var(--spacing-xs);
}

/* ============================================
   FORM FIELD SUCCESS STATE
   ============================================ */

.cc-form-field--success {
  /* Field success state */
}

.cc-form-field--success .cc-form-field__label {
  color: #28a745;
}

.cc-form-field--success .cc-form-field__success-message {
  display: block;
  color: #28a745;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  margin-top: 0.25rem;
}

.cc-form-field__success-icon {
  width: 1rem;
  height: 1rem;
  color: #28a745;
  flex-shrink: 0;
  margin-right: var(--spacing-xs);
}

/* ============================================
   FORM FIELD STATES
   ============================================ */

/* Disabled field */
.cc-form-field--disabled {
  opacity: 0.6;
  pointer-events: none;
}

.cc-form-field--disabled .cc-form-field__label {
  color: var(--color-text-muted);
  cursor: not-allowed;
}

/* Readonly field */
.cc-form-field--readonly .cc-form-field__label {
  color: var(--color-text-secondary);
}

/* Loading state */
.cc-form-field--loading {
  opacity: 0.7;
  pointer-events: none;
}

.cc-form-field--loading .cc-form-field__label {
  opacity: 0.8;
}

/* Focused state (applied via focus-within) */
.cc-form-field:focus-within {
  /* Used for styling field when input is focused */
}

/* ============================================
   FORM FIELD LAYOUT VARIANTS
   ============================================ */

/* Stacked layout (default) */
.cc-form-field--stacked {
  flex-direction: column;
  gap: var(--spacing-sm);
}

/* Fieldset wrapper for grouped fields */
.cc-form-fieldset {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
  border: none;
  margin: 0;
  padding: var(--spacing-lg);
  background-color: transparent;
}

.cc-form-fieldset__legend {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-heading);
  margin: 0 0 var(--spacing-md) 0;
  padding: 0;
}

/* Field group for grouped fields */
.cc-form-field-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  padding: var(--spacing-lg);
  border: var(--border-width-thin) solid var(--color-border-light);
  border-radius: var(--border-radius-md);
  background-color: var(--color-bg-alt);
}

.cc-form-field-group__title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0;
  padding: 0;
  padding-bottom: var(--spacing-sm);
  border-bottom: var(--border-width-thin) solid var(--color-border);
}

/* ============================================
   FORM FIELD ICON/ADDON SUPPORT
   ============================================ */

.cc-form-field__icon {
  /* Icon inside field (prefix/suffix) */
  width: 1rem;
  height: 1rem;
  color: var(--color-text-muted);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cc-form-field--error .cc-form-field__icon {
  color: #dc3545;
}

.cc-form-field--warning .cc-form-field__icon {
  color: #ff9800;
}

.cc-form-field--success .cc-form-field__icon {
  color: #28a745;
}

/* ============================================
   FORM FIELD CHARACTER COUNTER
   ============================================ */

.cc-form-field__counter {
  /* Character counter display */
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-top: 0.25rem;
}

.cc-form-field__counter-text {
  margin: 0;
  padding: 0;
}

.cc-form-field__counter-progress {
  width: 3rem;
  height: 4px;
  background-color: var(--color-border);
  border-radius: var(--border-radius-full);
  overflow: hidden;
}

.cc-form-field__counter-bar {
  height: 100%;
  background-color: var(--color-primary);
  width: 0;
  transition: width var(--transition-colors);
}

.cc-form-field__counter-bar--warning {
  background-color: #ff9800;
}

.cc-form-field__counter-bar--full {
  background-color: #dc3545;
}

/* ============================================
   FORM FIELD DESCRIPTIONS
   ============================================ */

.cc-form-field__description {
  /* Long form description text */
  font-size: var(--font-size-sm);
  line-height: var(--line-height-base);
  color: var(--color-text-secondary);
  margin: 0;
  padding: 0;
}

/* Hint text for additional guidance */
.cc-form-field__hint {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  font-style: italic;
  margin: 0;
  padding: 0;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-form-field--inline {
    flex-direction: column;
    gap: var(--spacing-sm);
  }

  .cc-form-field--inline .cc-form-field__label {
    white-space: normal;
  }

  .cc-form-field--inline .cc-form-field__input-wrapper {
    min-width: auto;
  }

  .cc-form-field--horizontal {
    flex-direction: column;
    gap: var(--spacing-sm);
  }

  .cc-form-field--horizontal .cc-form-field__label {
    width: 100%;
    padding-top: 0;
  }

  .cc-form-field--horizontal .cc-form-field__input-wrapper {
    width: 100%;
  }

  .cc-form-fieldset {
    padding: var(--spacing-md);
  }

  .cc-form-field-group {
    padding: var(--spacing-md);
  }
}

@media (max-width: 480px) {
  .cc-form-field {
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
  }

  .cc-form-field--compact {
    margin-bottom: var(--spacing-sm);
  }

  .cc-form-field__label {
    font-size: var(--font-size-sm);
  }

  .cc-form-field__help {
    font-size: var(--font-size-xs);
  }

  .cc-form-fieldset {
    padding: var(--spacing-sm);
  }

  .cc-form-field-group {
    padding: var(--spacing-sm);
  }

  .cc-form-field__counter {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-xs);
  }

  .cc-form-field__counter-progress {
    width: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-form-field__counter-bar {
    transition: none;
  }
}

/* Source: components/forms/text-input.css */
/**
 * Text Input & Textarea Component
 * ===============================
 * Text field styling with focus states, validation, icons, and variants
 * BEM naming convention: .cc-input, .cc-textarea, .cc-input__*, variants
 *
 * Features: Focus states, validation, icons (prefix/suffix), sizes
 * Keyboard: Tab navigation, Enter submit, Arrow keys in textarea
 * Validation: Error borders, success checkmarks, warning styles
 * Accessibility: Proper labels, ARIA attributes, high contrast focus
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE TEXT INPUT STYLES
   ============================================ */

.cc-input,
.cc-textarea {
  /* Base input styling */
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: var(--color-white);
  color: var(--color-text-secondary);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  transition: var(--transition-colors);
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
}

.cc-input::placeholder,
.cc-textarea::placeholder {
  color: var(--color-text-muted);
}

/* ============================================
   INPUT FOCUS STATE
   ============================================ */

.cc-input:focus,
.cc-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  background-color: var(--color-white);
  box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

.cc-input:focus-visible,
.cc-textarea:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ============================================
   INPUT HOVER STATE
   ============================================ */

.cc-input:hover:not(:disabled):not(:readonly),
.cc-textarea:hover:not(:disabled):not(:readonly) {
  border-color: var(--color-primary-light);
  background-color: var(--color-bg-alt);
}

/* ============================================
   INPUT DISABLED STATE
   ============================================ */

.cc-input:disabled,
.cc-textarea:disabled {
  background-color: var(--color-gray-100);
  border-color: var(--color-border-light);
  color: var(--color-text-muted);
  cursor: not-allowed;
  opacity: 0.6;
}

.cc-input:disabled::placeholder,
.cc-textarea:disabled::placeholder {
  color: var(--color-text-muted);
}

/* ============================================
   INPUT READONLY STATE
   ============================================ */

.cc-input:readonly,
.cc-textarea:readonly {
  background-color: var(--color-gray-50);
  border-color: var(--color-border-light);
  color: var(--color-text-secondary);
  cursor: default;
}

/* ============================================
   INPUT VARIANTS - SIZES
   ============================================ */

/* Small input */
.cc-input--sm,
.cc-textarea--sm {
  padding: 0.5rem 0.75rem;
  font-size: var(--font-size-sm);
  min-height: 36px;
}

/* Medium input (default) */
.cc-input--md,
.cc-textarea--md {
  padding: 0.75rem 1rem;
  font-size: var(--font-size-base);
  min-height: 44px;
}

/* Large input */
.cc-input--lg,
.cc-textarea--lg {
  padding: 1rem 1.25rem;
  font-size: var(--font-size-lg);
  min-height: 52px;
}

/* ============================================
   TEXT INPUT (SINGLE LINE)
   ============================================ */

.cc-input {
  display: block;
  min-height: 44px;
}

/* Input with prefix icon */
.cc-input--with-prefix {
  padding-left: 2.75rem;
}

/* Input with suffix icon */
.cc-input--with-suffix {
  padding-right: 2.75rem;
}

/* Input type=search (clear button) */
.cc-input[type="search"]::-webkit-search-cancel-button {
  display: none;
}

/* Input type=number spinner controls */
.cc-input[type="number"] {
  /* Remove spinners */
}

.cc-input[type="number"]::-webkit-outer-spin-button,
.cc-input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.cc-input[type="number"] {
  -moz-appearance: textfield;
}

/* ============================================
   TEXTAREA SPECIFIC STYLES
   ============================================ */

.cc-textarea {
  display: block;
  resize: vertical;
  min-height: 100px;
  font-family: var(--font-family-primary);
  line-height: var(--line-height-base);
}

/* Textarea no resize */
.cc-textarea--no-resize {
  resize: none;
}

/* Textarea fixed height */
.cc-textarea--fixed {
  resize: none;
  min-height: 150px;
  max-height: 150px;
}

/* Textarea auto-grow (for JavaScript) */
.cc-textarea--auto-grow {
  resize: none;
  overflow: hidden;
  min-height: 100px;
}

/* Textarea with scrollbar styling */
.cc-textarea {
  scrollbar-width: thin;
  scrollbar-color: var(--color-border) var(--color-bg-alt);
}

.cc-textarea::-webkit-scrollbar {
  width: 8px;
}

.cc-textarea::-webkit-scrollbar-track {
  background: var(--color-bg-alt);
  border-radius: var(--border-radius-md);
}

.cc-textarea::-webkit-scrollbar-thumb {
  background: var(--color-border);
  border-radius: var(--border-radius-md);
}

.cc-textarea::-webkit-scrollbar-thumb:hover {
  background: var(--color-primary);
}

/* ============================================
   INPUT VALIDATION STATES
   ============================================ */

/* Error state */
.cc-input--error,
.cc-textarea--error {
  border-color: #dc3545;
  background-color: rgba(220, 53, 69, 0.05);
}

.cc-input--error:focus,
.cc-textarea--error:focus {
  border-color: #dc3545;
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

/* Warning state */
.cc-input--warning,
.cc-textarea--warning {
  border-color: #ff9800;
  background-color: rgba(255, 152, 0, 0.05);
}

.cc-input--warning:focus,
.cc-textarea--warning:focus {
  border-color: #ff9800;
  box-shadow: 0 0 0 3px rgba(255, 152, 0, 0.1);
}

/* Success state */
.cc-input--success,
.cc-textarea--success {
  border-color: #28a745;
  background-color: rgba(40, 167, 69, 0.05);
}

.cc-input--success:focus,
.cc-textarea--success:focus {
  border-color: #28a745;
  box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.1);
}

/* ============================================
   INPUT WITH ICONS (WRAPPER)
   ============================================ */

.cc-input-wrapper {
  /* Wrapper for input with prefix/suffix icons */
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.cc-input-wrapper__icon {
  /* Icon inside input (prefix or suffix) */
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  color: var(--color-text-muted);
  pointer-events: none;
  flex-shrink: 0;
}

.cc-input-wrapper__icon--prefix {
  left: 0.75rem;
}

.cc-input-wrapper__icon--suffix {
  right: 0.75rem;
}

.cc-input-wrapper.cc-input-wrapper--error .cc-input-wrapper__icon {
  color: #dc3545;
}

.cc-input-wrapper.cc-input-wrapper--warning .cc-input-wrapper__icon {
  color: #ff9800;
}

.cc-input-wrapper.cc-input-wrapper--success .cc-input-wrapper__icon {
  color: #28a745;
}

/* Icon - Clickable suffix (like clear button) */
.cc-input-wrapper__icon--clickable {
  cursor: pointer;
  pointer-events: all;
  transition: color var(--transition-colors);
}

.cc-input-wrapper__icon--clickable:hover {
  color: var(--color-primary);
}

/* ============================================
   INPUT SPECIAL VARIANTS
   ============================================ */

/* Borderless input */
.cc-input--borderless,
.cc-textarea--borderless {
  border: none;
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
  border-radius: 0;
  padding: 0.75rem 0;
  background-color: transparent;
}

.cc-input--borderless:focus,
.cc-textarea--borderless:focus {
  border-bottom-color: var(--color-primary);
  box-shadow: none;
  background-color: transparent;
}

/* Filled input */
.cc-input--filled,
.cc-textarea--filled {
  background-color: var(--color-bg-alt);
  border-color: transparent;
}

.cc-input--filled:focus,
.cc-textarea--filled:focus {
  border-color: var(--color-primary);
  background-color: var(--color-white);
}

/* Rounded input (pill shape) */
.cc-input--rounded,
.cc-textarea--rounded {
  border-radius: var(--border-radius-full);
}

/* Flushed input (no padding on sides) */
.cc-input--flush {
  padding-left: 0;
  padding-right: 0;
  border: none;
  border-bottom: var(--border-width-thin) solid var(--color-border);
  border-radius: 0;
  background-color: transparent;
}

.cc-input--flush:focus {
  border-bottom-color: var(--color-primary);
  box-shadow: none;
}

/* ============================================
   INPUT LOADING STATE
   ============================================ */

.cc-input--loading,
.cc-textarea--loading {
  opacity: 0.7;
  pointer-events: none;
}

.cc-input-wrapper--loading::after {
  content: '';
  position: absolute;
  right: 0.75rem;
  width: 16px;
  height: 16px;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: var(--border-radius-full);
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* ============================================
   INPUT FIELD TYPES
   ============================================ */

/* Email input */
.cc-input[type="email"] {
  /* Default styling applies */
}

/* Password input */
.cc-input[type="password"] {
  letter-spacing: 0.15em;
  font-family: 'Courier New', monospace;
}

/* Password reveal toggle (for JavaScript) */
.cc-input[type="password"].cc-input--password-visible {
  font-family: var(--font-family-primary);
  letter-spacing: normal;
}

/* URL input */
.cc-input[type="url"] {
  direction: ltr;
}

/* Telephone input */
.cc-input[type="tel"] {
  /* Default styling applies */
}

/* Date input */
.cc-input[type="date"],
.cc-input[type="time"],
.cc-input[type="datetime-local"],
.cc-input[type="month"],
.cc-input[type="week"] {
  /* Default styling applies */
}

/* ============================================
   INPUT AUTOCOMPLETION
   ============================================ */

.cc-input:-webkit-autofill,
.cc-textarea:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px var(--color-white) inset;
  -webkit-text-fill-color: var(--color-text-secondary);
}

.cc-input:-webkit-autofill:focus,
.cc-textarea:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px var(--color-white) inset, 0 0 0 3px rgba(47, 64, 137, 0.1);
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-input,
  .cc-textarea {
    font-size: 1rem; /* 16px converted to rem - Prevents zoom on iOS */
    min-height: 44px;
  }

  .cc-input--sm,
  .cc-textarea--sm {
    min-height: 40px;
  }

  .cc-input--lg,
  .cc-textarea--lg {
    min-height: 48px;
  }

  .cc-textarea {
    min-height: 120px;
  }
}

@media (max-width: 480px) {
  .cc-input,
  .cc-textarea {
    padding: 0.75rem 1rem;
    font-size: 1rem; /* 16px converted to rem - Prevents zoom on iOS */
    border-radius: var(--border-radius-md);
  }

  .cc-input--sm,
  .cc-textarea--sm {
    padding: 0.5rem 0.75rem;
  }

  .cc-input--lg,
  .cc-textarea--lg {
    padding: 0.875rem 1rem;
  }

  .cc-textarea {
    min-height: 100px;
  }

  .cc-textarea--fixed {
    min-height: 120px;
    max-height: 120px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-input,
  .cc-textarea,
  .cc-input-wrapper__icon--clickable {
    transition: none;
  }

  .cc-input-wrapper--loading::after {
    animation: none;
    border-top-color: var(--color-primary);
  }
}

/* Source: components/forms/select.css */
/**
 * Select & Dropdown Component
 * ===========================
 * Custom styled select dropdowns with option groups and search support
 * BEM naming convention: .cc-select, .cc-select__*, variants
 *
 * Features: Custom styling, option groups, multi-select, searchable variant
 * Keyboard: Tab/Shift+Tab, Arrow keys, Enter select, Escape close
 * Validation: Error/warning/success states matching form field patterns
 * Accessibility: Semantic select elements, ARIA attributes, screen readers
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE SELECT STYLES
   ============================================ */

.cc-select {
  /* Native select with custom styling */
  position: relative;
  width: 100%;
  display: block;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;

  /* Appearance */
  padding: 0.75rem 2.5rem 0.75rem 1rem;
  background-color: var(--color-white);
  color: var(--color-text-secondary);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);

  /* Typography */
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);

  /* States */
  cursor: pointer;
  transition: var(--transition-colors);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%233d4668' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 12px;
  padding-right: 2.5rem;
  min-height: 44px;
}

.cc-select:hover:not(:disabled) {
  border-color: var(--color-primary-light);
  background-color: var(--color-bg-alt);
}

.cc-select:focus,
.cc-select:focus-visible {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

/* ============================================
   SELECT SIZES
   ============================================ */

.cc-select--sm {
  padding: 0.5rem 2.25rem 0.5rem 0.75rem;
  font-size: var(--font-size-sm);
  min-height: 36px;
}

.cc-select--lg {
  padding: 1rem 2.75rem 1rem 1.25rem;
  font-size: var(--font-size-lg);
  min-height: 52px;
}

/* ============================================
   SELECT VALIDATION STATES
   ============================================ */

.cc-select--error {
  border-color: #dc3545;
  background-color: rgba(220, 53, 69, 0.05);
}

.cc-select--error:focus {
  border-color: #dc3545;
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

.cc-select--warning {
  border-color: #ff9800;
  background-color: rgba(255, 152, 0, 0.05);
}

.cc-select--warning:focus {
  border-color: #ff9800;
  box-shadow: 0 0 0 3px rgba(255, 152, 0, 0.1);
}

.cc-select--success {
  border-color: #28a745;
  background-color: rgba(40, 167, 69, 0.05);
}

.cc-select--success:focus {
  border-color: #28a745;
  box-shadow: 0 0 0 3px rgba(40, 167, 69, 0.1);
}

/* ============================================
   SELECT DISABLED STATE
   ============================================ */

.cc-select:disabled {
  background-color: var(--color-gray-100);
  border-color: var(--color-border-light);
  color: var(--color-text-muted);
  cursor: not-allowed;
  opacity: 0.6;
}

/* ============================================
   SELECT OPTIONS STYLING
   ============================================ */

.cc-select option {
  /* Option styling (limited browser support) */
  padding: 0.5rem;
  background-color: var(--color-white);
  color: var(--color-text-secondary);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
}

.cc-select option:checked {
  background: linear-gradient(
    var(--color-primary),
    var(--color-primary)
  );
  background-color: var(--color-primary);
  color: var(--color-white);
}

.cc-select option:hover {
  background-color: var(--color-primary-light);
  color: var(--color-primary);
}

.cc-select optgroup {
  /* Option group styling */
  font-family: var(--font-family-primary);
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
  background-color: var(--color-bg-alt);
}

/* ============================================
   SELECT WITH WRAPPER (CUSTOM STYLING)
   ============================================ */

.cc-select-wrapper {
  /* Wrapper for enhanced custom select styling */
  position: relative;
  display: block;
  width: 100%;
  box-sizing: border-box;
}

.cc-select-wrapper.cc-select-wrapper--with-icon {
  /* Select with icon support */
}

.cc-select-wrapper__icon {
  /* Icon inside select wrapper */
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.5rem;
  height: 1.5rem;
  color: var(--color-text-muted);
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.cc-select-wrapper.cc-select-wrapper--error .cc-select-wrapper__icon {
  color: #dc3545;
}

.cc-select-wrapper.cc-select-wrapper--warning .cc-select-wrapper__icon {
  color: #ff9800;
}

.cc-select-wrapper.cc-select-wrapper--success .cc-select-wrapper__icon {
  color: #28a745;
}

.cc-select-wrapper--with-icon .cc-select {
  padding-left: 2.75rem;
}

/* ============================================
   CUSTOM SELECT DROPDOWN (FOR JAVASCRIPT)
   ============================================ */

.cc-select-custom {
  /* Custom select container */
  position: relative;
  width: 100%;
  display: block;
  box-sizing: border-box;
  font-family: var(--font-family-primary);
}

.cc-select-custom__button {
  /* Custom select button (replaces native select) */
  width: 100%;
  padding: 0.75rem 2.5rem 0.75rem 1rem;
  background-color: var(--color-white);
  color: var(--color-text-secondary);
  border: var(--border-width-thin) solid var(--color-border);
  border-radius: var(--border-radius-md);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  cursor: pointer;
  text-align: left;
  transition: var(--transition-colors);
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%233d4668' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 12px;
  padding-right: 2.5rem;
}

.cc-select-custom__button:hover {
  border-color: var(--color-primary-light);
  background-color: var(--color-bg-alt);
}

.cc-select-custom__button:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

.cc-select-custom__button:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.cc-select-custom__button[aria-expanded="true"] {
  border-color: var(--color-primary);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

/* Dropdown icon rotation on open */
.cc-select-custom__button[aria-expanded="true"]::after {
  transform: scaleY(-1);
}

.cc-select-custom__button::after {
  content: '';
  display: inline-block;
  width: 12px;
  height: 12px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%233d4668' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px;
  flex-shrink: 0;
  margin-left: var(--spacing-sm);
  transition: transform var(--transition-colors);
}

/* ============================================
   CUSTOM SELECT DROPDOWN LIST
   ============================================ */

.cc-select-custom__list {
  /* Dropdown list (role="listbox") */
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: var(--z-dropdown);
  min-width: 100%;
  max-height: 300px;
  overflow-y: auto;
  background-color: var(--color-white);
  border: var(--border-width-thin) solid var(--color-border);
  border-top: none;
  border-radius: 0 0 var(--border-radius-md) var(--border-radius-md);
  margin: 0;
  padding: 0;
  list-style: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  display: none;
}

.cc-select-custom__list[aria-expanded="true"],
.cc-select-custom__list.is-open {
  display: block;
  animation: slideDown 0.2s ease-out;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.cc-select-custom__option {
  /* Individual option item */
  padding: 0.75rem 1rem;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: var(--transition-colors);
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
  font-size: var(--font-size-base);
}

.cc-select-custom__option:last-child {
  border-bottom: none;
}

.cc-select-custom__option:hover {
  background-color: var(--color-primary-light);
  color: var(--color-primary);
}

.cc-select-custom__option[aria-selected="true"],
.cc-select-custom__option.is-selected {
  background-color: rgba(47, 64, 137, 0.1);
  color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
}

.cc-select-custom__option[aria-selected="true"]::before,
.cc-select-custom__option.is-selected::before {
  content: '✓';
  margin-right: var(--spacing-sm);
  color: var(--color-primary);
  font-weight: var(--font-weight-bold);
}

.cc-select-custom__option:focus {
  outline: none;
  background-color: var(--color-bg-alt);
}

.cc-select-custom__option:disabled {
  color: var(--color-text-muted);
  cursor: not-allowed;
  opacity: 0.6;
}

/* Option group label */
.cc-select-custom__optgroup-label {
  padding: 0.5rem 1rem;
  background-color: var(--color-bg-alt);
  color: var(--color-text-secondary);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: default;
  border-bottom: var(--border-width-thin) solid var(--color-border-light);
}

/* ============================================
   MULTI-SELECT VARIANT
   ============================================ */

.cc-select[multiple] {
  padding: 0.5rem;
  min-height: 120px;
}

.cc-select[multiple] option {
  padding: 0.5rem;
  margin-bottom: 0.25rem;
  border-radius: var(--border-radius-sm);
}

.cc-select[multiple] option:checked {
  background: linear-gradient(
    var(--color-primary),
    var(--color-primary)
  );
  background-color: var(--color-primary);
  color: var(--color-white);
}

/* Custom multi-select tags display */
.cc-select-custom--multi .cc-select-custom__button {
  padding: 0.5rem 2.5rem 0.5rem 0.75rem;
  min-height: auto;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  align-items: flex-start;
}

.cc-select-custom--multi .cc-select-custom__tag {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: 0.25rem 0.5rem;
  background-color: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  margin: 0.25rem 0;
}

.cc-select-custom--multi .cc-select-custom__tag-remove {
  cursor: pointer;
  opacity: 0.7;
  transition: opacity var(--transition-colors);
}

.cc-select-custom--multi .cc-select-custom__tag-remove:hover {
  opacity: 1;
}

/* ============================================
   SELECT VARIANTS
   ============================================ */

/* Borderless select */
.cc-select--borderless {
  border: none;
  border-bottom: var(--border-width-thin) solid var(--color-border);
  border-radius: 0;
  padding: 0.75rem 2.5rem 0.75rem 0;
  background-position: right center;
  background-color: transparent;
}

.cc-select--borderless:focus {
  border-bottom-color: var(--color-primary);
  box-shadow: none;
  background-color: transparent;
}

/* Filled select */
.cc-select--filled {
  background-color: var(--color-bg-alt);
  border-color: transparent;
}

.cc-select--filled:focus {
  border-color: var(--color-primary);
  background-color: var(--color-white);
}

/* Flushed select */
.cc-select--flush {
  padding: 0.75rem 2.5rem 0.75rem 0;
  border: none;
  border-bottom: var(--border-width-thin) solid var(--color-border);
  border-radius: 0;
  background-color: transparent;
}

.cc-select--flush:focus {
  border-bottom-color: var(--color-primary);
  box-shadow: none;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-select,
  .cc-select-custom__button {
    font-size: 1rem; /* 16px converted to rem - Prevents zoom on iOS */
    min-height: 44px;
  }

  .cc-select--sm,
  .cc-select-custom--sm .cc-select-custom__button {
    min-height: 40px;
  }

  .cc-select--lg,
  .cc-select-custom--lg .cc-select-custom__button {
    min-height: 48px;
  }

  .cc-select-custom__list {
    max-height: 250px;
  }
}

@media (max-width: 480px) {
  .cc-select,
  .cc-select-custom__button {
    padding: 0.75rem 2.25rem 0.75rem 1rem;
    font-size: 1rem; /* 16px converted to rem - Prevents zoom on iOS */
    border-radius: var(--border-radius-md);
  }

  .cc-select--sm,
  .cc-select-custom--sm .cc-select-custom__button {
    padding: 0.5rem 2rem 0.5rem 0.75rem;
  }

  .cc-select--lg,
  .cc-select-custom--lg .cc-select-custom__button {
    padding: 0.875rem 2.5rem 0.875rem 1.25rem;
  }

  .cc-select-custom__list {
    max-height: 200px;
  }

  .cc-select-custom__option {
    padding: 0.625rem 0.875rem;
    font-size: var(--font-size-sm);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-select,
  .cc-select-custom__button,
  .cc-select-custom__option,
  .cc-select-custom__list {
    transition: none;
    animation: none;
  }

  .cc-select-custom__button::after {
    transition: none;
  }
}

/* Source: components/forms/checkbox-radio.css */
/**
 * Checkbox & Radio Button Component
 * ==================================
 * Custom styled checkboxes and radio buttons with states and grouping
 * BEM naming convention: .cc-checkbox, .cc-radio, .cc-*__*, variants
 *
 * Features: Custom styling, grouped controls, disabled states, validation
 * Keyboard: Tab/Shift+Tab, Space/Enter select, Arrow keys for groups
 * Validation: Error/warning/success states, group-level feedback
 * Accessibility: Proper labels, ARIA attributes, screen reader support
 *
 * Last Updated: 2025-11-15
 * Version: 1.0
 */

/* ============================================
   BASE CHECKBOX STYLES
   ============================================ */

/* Hide native checkbox */
.cc-checkbox {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* Checkbox wrapper (contains visual box and label) */
.cc-checkbox-wrapper {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  cursor: pointer;
  user-select: none;
  font-size: var(--font-size-base);
}

/* Custom checkbox box */
.cc-checkbox-wrapper::before {
  content: '';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  background-color: var(--color-white);
  border: 2px solid var(--color-border);
  border-radius: var(--border-radius-sm);
  transition: var(--transition-colors);
  cursor: pointer;
}

/* Checkbox label */
.cc-checkbox-wrapper__label {
  display: block;
  cursor: pointer;
  margin: 0;
  padding: 0;
  font-weight: var(--font-weight-regular);
  color: var(--color-text-secondary);
  line-height: var(--line-height-base);
}

/* ============================================
   CHECKBOX STATES
   ============================================ */

/* Checkbox checked state */
.cc-checkbox:checked + .cc-checkbox-wrapper::before {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='white' d='M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 11-1.06-1.06l7.25-7.25a.75.75 0 011.06 0z'/%3E%3Cpath fill='white' d='M2.22 9.22a.75.75 0 010 1.06l-1.5 1.5a.75.75 0 11-1.06-1.06l1.5-1.5a.75.75 0 011.06 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 14px;
}

/* Checkbox hover state */
.cc-checkbox-wrapper:hover {
  /* Applied to wrapper */
}

.cc-checkbox:not(:disabled) + .cc-checkbox-wrapper:hover::before {
  border-color: var(--color-primary);
}

/* Checkbox focus state */
.cc-checkbox:focus-visible + .cc-checkbox-wrapper::before {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* Checkbox disabled state */
.cc-checkbox:disabled + .cc-checkbox-wrapper {
  opacity: 0.6;
  cursor: not-allowed;
}

.cc-checkbox:disabled + .cc-checkbox-wrapper::before {
  background-color: var(--color-gray-100);
  border-color: var(--color-border-light);
  cursor: not-allowed;
}

.cc-checkbox:disabled + .cc-checkbox-wrapper::before {
  cursor: not-allowed;
}

/* Checkbox indeterminate state */
.cc-checkbox:indeterminate + .cc-checkbox-wrapper::before {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Crect x='3' y='7' width='10' height='2' fill='white'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 14px;
}

/* ============================================
   CHECKBOX VARIANTS
   ============================================ */

/* Small checkbox */
.cc-checkbox--sm + .cc-checkbox-wrapper::before {
  width: 18px;
  height: 18px;
  border-radius: var(--border-radius-xs);
}

.cc-checkbox--sm + .cc-checkbox-wrapper {
  font-size: var(--font-size-sm);
  gap: var(--spacing-xs);
}

/* Large checkbox */
.cc-checkbox--lg + .cc-checkbox-wrapper::before {
  width: 24px;
  height: 24px;
  border-radius: var(--border-radius-sm);
  border-width: 2px;
}

.cc-checkbox--lg + .cc-checkbox-wrapper {
  font-size: var(--font-size-lg);
  gap: var(--spacing-md);
}

/* Rounded checkbox (pill shape) */
.cc-checkbox--rounded + .cc-checkbox-wrapper::before {
  border-radius: var(--border-radius-full);
}

/* ============================================
   BASE RADIO STYLES
   ============================================ */

/* Hide native radio */
.cc-radio {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* Radio wrapper */
.cc-radio-wrapper {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  cursor: pointer;
  user-select: none;
  font-size: var(--font-size-base);
}

/* Custom radio circle */
.cc-radio-wrapper::before {
  content: '';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  background-color: var(--color-white);
  border: 2px solid var(--color-border);
  border-radius: var(--border-radius-full);
  transition: var(--transition-colors);
  cursor: pointer;
  position: relative;
}

/* Radio label */
.cc-radio-wrapper__label {
  display: block;
  cursor: pointer;
  margin: 0;
  padding: 0;
  font-weight: var(--font-weight-regular);
  color: var(--color-text-secondary);
  line-height: var(--line-height-base);
}

/* ============================================
   RADIO STATES
   ============================================ */

/* Radio checked state */
.cc-radio:checked + .cc-radio-wrapper::before {
  border-color: var(--color-primary);
  background-color: var(--color-white);
  box-shadow: inset 0 0 0 4px var(--color-white), inset 0 0 0 6px var(--color-primary);
}

/* Radio hover state */
.cc-radio:not(:disabled) + .cc-radio-wrapper:hover::before {
  border-color: var(--color-primary);
}

/* Radio focus state */
.cc-radio:focus-visible + .cc-radio-wrapper::before {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* Radio disabled state */
.cc-radio:disabled + .cc-radio-wrapper {
  opacity: 0.6;
  cursor: not-allowed;
}

.cc-radio:disabled + .cc-radio-wrapper::before {
  background-color: var(--color-gray-100);
  border-color: var(--color-border-light);
  cursor: not-allowed;
}

/* ============================================
   RADIO VARIANTS
   ============================================ */

/* Small radio */
.cc-radio--sm + .cc-radio-wrapper::before {
  width: 18px;
  height: 18px;
}

.cc-radio--sm + .cc-radio-wrapper:checked::before {
  box-shadow: inset 0 0 0 3px var(--color-white), inset 0 0 0 5px var(--color-primary);
}

.cc-radio--sm + .cc-radio-wrapper {
  font-size: var(--font-size-sm);
  gap: var(--spacing-xs);
}

/* Large radio */
.cc-radio--lg + .cc-radio-wrapper::before {
  width: 24px;
  height: 24px;
  border-width: 2px;
}

.cc-radio--lg + .cc-radio-wrapper:checked::before {
  box-shadow: inset 0 0 0 5px var(--color-white), inset 0 0 0 7px var(--color-primary);
}

.cc-radio--lg + .cc-radio-wrapper {
  font-size: var(--font-size-lg);
  gap: var(--spacing-md);
}

/* ============================================
   CHECKBOX/RADIO VALIDATION STATES
   ============================================ */

/* Error state */
.cc-checkbox--error + .cc-checkbox-wrapper::before,
.cc-radio--error + .cc-radio-wrapper::before {
  border-color: #dc3545;
}

.cc-checkbox--error:checked + .cc-checkbox-wrapper::before,
.cc-radio--error:checked + .cc-radio-wrapper::before {
  background-color: #dc3545;
  border-color: #dc3545;
}

.cc-checkbox--error:checked + .cc-checkbox-wrapper::before {
  border-color: #dc3545;
}

.cc-checkbox--error + .cc-checkbox-wrapper::before {
  border-color: #dc3545;
}

/* Warning state */
.cc-checkbox--warning + .cc-checkbox-wrapper::before,
.cc-radio--warning + .cc-radio-wrapper::before {
  border-color: #ff9800;
}

.cc-checkbox--warning:checked + .cc-checkbox-wrapper::before {
  background-color: #ff9800;
  border-color: #ff9800;
}

.cc-radio--warning:checked + .cc-radio-wrapper::before {
  border-color: #ff9800;
  box-shadow: inset 0 0 0 4px var(--color-white), inset 0 0 0 6px #ff9800;
}

/* Success state */
.cc-checkbox--success + .cc-checkbox-wrapper::before,
.cc-radio--success + .cc-radio-wrapper::before {
  border-color: #28a745;
}

.cc-checkbox--success:checked + .cc-checkbox-wrapper::before {
  background-color: #28a745;
  border-color: #28a745;
}

.cc-radio--success:checked + .cc-radio-wrapper::before {
  border-color: #28a745;
  box-shadow: inset 0 0 0 4px var(--color-white), inset 0 0 0 6px #28a745;
}

/* ============================================
   CHECKBOX/RADIO GROUPS
   ============================================ */

.cc-checkbox-group,
.cc-radio-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  width: 100%;
}

.cc-checkbox-group--horizontal,
.cc-radio-group--horizontal {
  flex-direction: row;
  gap: var(--spacing-lg);
  flex-wrap: wrap;
}

.cc-checkbox-group--inline,
.cc-radio-group--inline {
  flex-direction: row;
  gap: var(--spacing-md);
  flex-wrap: wrap;
}

.cc-checkbox-group__item,
.cc-radio-group__item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

/* Group label */
.cc-checkbox-group__label,
.cc-radio-group__label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
  margin-bottom: var(--spacing-md);
  padding: 0;
}

/* Group error message */
.cc-checkbox-group__error,
.cc-radio-group__error {
  display: block;
  color: #dc3545;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  margin-top: var(--spacing-sm);
}

/* Group help text */
.cc-checkbox-group__help,
.cc-radio-group__help {
  display: block;
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  margin-top: var(--spacing-sm);
}

/* ============================================
   CHECKBOX/RADIO WITH DESCRIPTION
   ============================================ */

.cc-checkbox-description,
.cc-radio-description {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.cc-checkbox-description__label,
.cc-radio-description__label {
  font-weight: var(--font-weight-semibold);
  color: var(--color-heading);
}

.cc-checkbox-description__text,
.cc-radio-description__text {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-base);
}

/* ============================================
   SWITCH VARIANT (TOGGLE)
   ============================================ */

.cc-switch {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.cc-switch-wrapper {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  cursor: pointer;
  user-select: none;
}

/* Switch toggle track */
.cc-switch-wrapper::before {
  content: '';
  display: inline-block;
  width: 44px;
  height: 24px;
  background-color: var(--color-border);
  border-radius: var(--border-radius-full);
  transition: background-color var(--transition-colors);
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
}

/* Switch toggle knob */
.cc-switch-wrapper::after {
  content: '';
  position: absolute;
  width: 20px;
  height: 20px;
  background-color: var(--color-white);
  border-radius: var(--border-radius-full);
  transition: transform var(--transition-colors), box-shadow var(--transition-colors);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  cursor: pointer;
  top: 2px;
  left: 2px;
  z-index: 1;
}

/* Switch checked state */
.cc-switch:checked + .cc-switch-wrapper::before {
  background-color: var(--color-primary);
}

.cc-switch:checked + .cc-switch-wrapper::after {
  transform: translateX(20px);
}

/* Switch disabled state */
.cc-switch:disabled + .cc-switch-wrapper {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Switch focus state */
.cc-switch:focus-visible + .cc-switch-wrapper::before {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.cc-switch-wrapper__label {
  cursor: pointer;
  font-weight: var(--font-weight-regular);
  color: var(--color-text-secondary);
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .cc-checkbox-group--horizontal,
  .cc-radio-group--horizontal {
    flex-direction: column;
    gap: var(--spacing-md);
  }

  .cc-checkbox-group--inline,
  .cc-radio-group--inline {
    gap: var(--spacing-md);
  }

  .cc-checkbox-wrapper,
  .cc-radio-wrapper {
    min-height: 44px;
  }
}

@media (max-width: 480px) {
  .cc-checkbox-wrapper,
  .cc-radio-wrapper {
    gap: var(--spacing-sm);
    min-height: 40px;
  }

  .cc-checkbox-wrapper::before,
  .cc-radio-wrapper::before {
    width: 20px;
    height: 20px;
    min-width: 20px;
  }

  .cc-checkbox-group--horizontal,
  .cc-radio-group--horizontal {
    flex-direction: column;
    gap: var(--spacing-md);
  }

  .cc-checkbox-group--inline,
  .cc-radio-group--inline {
    gap: var(--spacing-md);
  }

  .cc-switch-wrapper::before {
    width: 40px;
    height: 22px;
  }

  .cc-switch:checked + .cc-switch-wrapper::after {
    transform: translateX(18px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cc-checkbox-wrapper::before,
  .cc-checkbox-wrapper:hover::before,
  .cc-radio-wrapper::before,
  .cc-radio-wrapper:hover::before,
  .cc-switch-wrapper::before,
  .cc-switch-wrapper::after {
    transition: none;
  }
}

/* Source: components/forms/wpforms.css */
/**
 * WPForms Contact Form Styling
 * Matches production site design at https://catholiccharitiesca.org/contact/
 *
 * @package HelloElementorChild
 * @since 1.0.0
 */

/* ============================================================================
   Form Container
   ========================================================================= */

.wpforms-container {
	max-width: 100%;
	margin: 0 auto;
}

.wpforms-form {
	font-family: var(--font-body, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif);
}

/* ============================================================================
   Form Title & Description
   ========================================================================= */

.wpforms-title {
	font-family: var(--font-heading, 'Figtree', sans-serif);
	font-size: 1.75rem;
	font-weight: 600;
	color: var(--color-text-primary, #1a1a1a);
	margin-bottom: 0.5rem;
}

.wpforms-description {
	font-size: 1rem;
	color: var(--color-text-secondary, #666);
	margin-bottom: 2rem;
}

/* ============================================================================
   Field Containers
   ========================================================================= */

.wpforms-field {
	margin-bottom: 1.5rem;
}

.wpforms-field-label {
	display: block;
	font-weight: 500;
	font-size: 0.95rem;
	color: var(--color-text-primary, #1a1a1a);
	margin-bottom: 0.5rem;
}

.wpforms-required-label {
	color: var(--color-error, #dc3545);
	margin-left: 0.25rem;
}

/* ============================================================================
   Text Inputs & Textarea
   ========================================================================= */

.wpforms-field input[type="text"],
.wpforms-field input[type="email"],
.wpforms-field input[type="tel"],
.wpforms-field input[type="url"],
.wpforms-field input[type="number"],
.wpforms-field textarea,
.wpforms-field select {
	width: 100%;
	padding: 0.75rem 1rem;
	font-size: 1rem;
	font-family: inherit;
	color: var(--color-text-primary, #1a1a1a);
	background-color: #fff;
	border: 1px solid var(--color-border, #ddd);
	border-radius: 4px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.wpforms-field input[type="text"]:focus,
.wpforms-field input[type="email"]:focus,
.wpforms-field input[type="tel"]:focus,
.wpforms-field input[type="url"]:focus,
.wpforms-field input[type="number"]:focus,
.wpforms-field textarea:focus,
.wpforms-field select:focus {
	outline: none;
	border-color: var(--color-primary, #0066cc);
	box-shadow: 0 0 0 3px rgba(0, 102, 204, 0.1);
}

.wpforms-field textarea {
	min-height: 120px;
	resize: vertical;
}

/* ============================================================================
   Name Field (First/Last)
   ========================================================================= */

.wpforms-field-name {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

.wpforms-field-name .wpforms-field-row {
	display: contents;
}

.wpforms-field-name .wpforms-field-row-block {
	display: flex;
	flex-direction: column;
}

.wpforms-field-name .wpforms-field-sublabel {
	font-size: 0.85rem;
	color: var(--color-text-secondary, #666);
	margin-top: 0.25rem;
}

/* ============================================================================
   Select Dropdown
   ========================================================================= */

.wpforms-field select {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 12px;
	padding-right: 2.5rem;
	cursor: pointer;
}

/* ============================================================================
   Submit Button
   ========================================================================= */

.wpforms-submit-container {
	margin-top: 2rem;
}

.wpforms-submit {
	display: inline-block;
	padding: 0.875rem 2rem;
	font-size: 1rem;
	font-weight: 600;
	font-family: var(--font-heading, 'Figtree', sans-serif);
	color: #fff;
	background-color: var(--color-primary, #0066cc);
	border: none;
	border-radius: 4px;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.1s ease;
}

.wpforms-submit:hover {
	background-color: var(--color-primary-dark, #0052a3);
}

.wpforms-submit:active {
	transform: translateY(1px);
}

.wpforms-submit:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

/* ============================================================================
   Captcha / Security Question
   ========================================================================= */

.wpforms-field-captcha {
	margin-bottom: 1.5rem;
}

.wpforms-field-captcha .wpforms-field-label {
	margin-bottom: 0.75rem;
}

.wpforms-field-captcha-question {
	font-size: 1rem;
	font-weight: 500;
	color: var(--color-text-primary, #1a1a1a);
	margin-bottom: 0.5rem;
}

.wpforms-field-captcha input {
	max-width: 150px;
}

/* ============================================================================
   Validation & Error States
   ========================================================================= */

.wpforms-error {
	color: var(--color-error, #dc3545);
	font-size: 0.875rem;
	margin-top: 0.5rem;
	display: block;
}

.wpforms-field.wpforms-has-error input,
.wpforms-field.wpforms-has-error textarea,
.wpforms-field.wpforms-has-error select {
	border-color: var(--color-error, #dc3545);
}

.wpforms-field.wpforms-has-error input:focus,
.wpforms-field.wpforms-has-error textarea:focus,
.wpforms-field.wpforms-has-error select:focus {
	box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

/* ============================================================================
   Confirmation Message
   ========================================================================= */

.wpforms-confirmation-container {
	padding: 1.5rem;
	background-color: #d4edda;
	border: 1px solid #c3e6cb;
	border-radius: 4px;
	color: #155724;
	font-size: 1rem;
	margin-bottom: 1.5rem;
}

.wpforms-confirmation-container p {
	margin: 0;
}

/* ============================================================================
   Loading State
   ========================================================================= */

.wpforms-submit.wpforms-submit-processing {
	opacity: 0.7;
	cursor: wait;
}

/* ============================================================================
   Responsive Design
   ========================================================================= */

@media (max-width: 768px) {
	.wpforms-field-name {
		grid-template-columns: 1fr;
	}

	.wpforms-title {
		font-size: 1.5rem;
	}

	.wpforms-submit {
		width: 100%;
		text-align: center;
	}
}

@media (max-width: 480px) {
	.wpforms-field input[type="text"],
	.wpforms-field input[type="email"],
	.wpforms-field input[type="tel"],
	.wpforms-field input[type="url"],
	.wpforms-field input[type="number"],
	.wpforms-field textarea,
	.wpforms-field select {
		font-size: 1rem; /* 16px converted to rem - Prevents zoom on iOS (1rem = 16px at default) */
	}
}


/* Source: components.css */
/**
 * Elementor Component Styling
 * Defines styles for reusable component library and homepage sections
 */

/* ========================================
   TRANSPARENT HEADER - PRIORITY OVERRIDE
   ======================================== */
/* Match Elementor specificity and handle both default and sticky states */
body.cc-transparent-header .elementor-location-header .elementor-element.elementor-element-c8deb65:not(.elementor-motion-effects-element-type-background),
body.cc-transparent-header .elementor-location-header .elementor-element.elementor-element-c8deb65 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    background-color: transparent !important;
}

/* Handle sticky state with transparent background */
body.cc-transparent-header .elementor-location-header .elementor-element.elementor-element-c8deb65.elementor-sticky--effects {
    background-color: transparent !important;
}

/* Force transparent on specific archive types */
body.cc-transparent-header.post-type-archive-agency .elementor-location-header .elementor-element.elementor-element-c8deb65:not(.elementor-motion-effects-element-type-background),
body.cc-transparent-header.post-type-archive-agency .elementor-location-header .elementor-element.elementor-element-c8deb65 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    background-color: transparent !important;
}

body.cc-transparent-header.post-type-archive-agency .elementor-location-header .elementor-element.elementor-element-c8deb65.elementor-sticky--effects {
    background-color: transparent !important;
}

/* ========================================
   HERO SECTION (aca-hero-v1)
   ======================================== */
.aca-hero-v1 {
    position: relative;
    overflow: hidden;
}

.aca-hero-content {
    z-index: 2;
}


.aca-hero-content h1 {
    font-size: clamp(2rem, 5vw, 3.5rem);
    line-height: 1.2;
    letter-spacing: -0.02em;
    font-weight: 700;
}

.aca-hero-media {
    position: relative;
}

.aca-hero-image {
    width: 100%;
    height: auto;
    border-radius: 12px;
    overflow: hidden;
}

.aca-hero-image img {
    width: 100%;
    height: auto;
    display: block;
}

/* ========================================
   CTA BANNER (aca-cta-banner)
   ======================================== */
.aca-cta-banner {
    border-radius: 12px;
    text-align: left;
}

.aca-cta-banner h2 {
    font-size: clamp(1.5rem, 4vw, 2.5rem);
    line-height: 1.3;
    margin-bottom: 1rem;
}

.aca-cta-banner p {
    font-size: 1.05rem;
    line-height: 1.65;
    margin-bottom: 1.5rem;
    opacity: 0.95;
}

/* ========================================
   STATS STRIP (aca-stats-strip)
   ======================================== */
.aca-stats-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    border-radius: 12px;
}

.aca-stat-block {
    flex: 1;
    min-width: 200px;
}

.aca-stat-block h3 {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 700;
    margin-bottom: 0.5rem;
    line-height: 1.1;
}

.aca-stat-block p {
    font-size: 0.95rem;
    line-height: 1.5;
    margin: 0;
}

/* ========================================
   FEATURE GRID (aca-feature-grid)
   ======================================== */
.aca-feature-grid {
    text-align: left;
}

.aca-feature-grid h2 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    line-height: 1.3;
    margin-bottom: 1rem;
}



/* ========================================
   MAP SECTION (aca-map-section)
   ======================================== */
.aca-map-section {
    border-radius: 12px;
}

.aca-map-section h2 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    line-height: 1.3;
    margin-bottom: 1rem;
}


/* ========================================
   TESTIMONIAL (aca-testimonial)
   ======================================== */
.aca-testimonial {
    background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
}

.aca-testimonial-avatar {
    flex-shrink: 0;
    min-width: 150px;
}

.aca-testimonial-avatar img {
    border-radius: 50%;
    width: 150px;
    height: 150px;
    object-fit: cover;
}

.aca-quote {
    font-size: 1.25rem;
    font-style: italic;
    font-weight: 500;
    line-height: 1.6;
    margin-bottom: 1rem;
}

.aca-testimonial h4 {
    font-size: 1.15rem;
    margin-bottom: 0.25rem;
}

.aca-testimonial .cc-text-muted {
    font-size: 0.95rem;
}

/* ========================================
   BLOG HIGHLIGHTS (aca-blog-highlights)
   ======================================== */
.aca-blog-highlights {
    text-align: left;
}

.aca-blog-highlights h2 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    line-height: 1.3;
    margin-bottom: 1rem;
}

.aca-blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
}

.aca-blog-grid article {
    border-radius: 12px;
    overflow: hidden;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    transition: all 0.3s ease;
}

.aca-blog-grid article:hover {
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
    transform: translateY(-4px);
}

/* ========================================
   EVENT LISTING (aca-event-listing)
   ======================================== */
.aca-event-listing {
    text-align: left;
}

.aca-event-listing h2 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    line-height: 1.3;
    margin-bottom: 1rem;
}

.aca-event-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
}

.aca-event-grid article {
    border-radius: 12px;
    overflow: hidden;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    transition: all 0.3s ease;
}

.aca-event-grid article:hover {
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
    transform: translateY(-4px);
}

/* ========================================
   PARTNERS CAROUSEL (aca-partners-carousel)
   ======================================== */
.aca-partners-carousel {
    text-align: left;
}

.aca-partners-carousel h2 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    line-height: 1.3;
    margin-bottom: 1rem;
}

.aca-partners-carousel .swiper-wrapper {
    padding: 1rem 0;
}

.aca-partners-carousel .swiper-slide {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 2rem;
    min-height: 250px;
}

.aca-partners-carousel .swiper-slide img {
    max-width: 100%;
    max-height: 280px;
    object-fit: contain;
}

/* ========================================
   DUAL CTA (aca-dual-cta)
   ======================================== */
.aca-dual-cta {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
}

.aca-dual-cta .cc-card {
    height: 100%;
}

.aca-dual-cta h3 {
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.aca-dual-cta p {
    margin-bottom: 1.5rem;
    font-size: 1rem;
}

/* ========================================
   CONTACT BLOCK (aca-contact-block)
   ======================================== */
.aca-contact-block {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: start;
}

.aca-contact-form {
    background: #ffffff;
}

.aca-contact-form h3 {
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.aca-form-placeholder {
    padding: 2rem;
    text-align: center;
    background: #f8fafc;
    border-radius: 8px;
    border: 2px dashed #cbd5e1;
    min-height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
}

.aca-contact-details h3 {
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.aca-contact-details p {
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 1rem;
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */
@media (max-width: 1024px) {
    .aca-hero-v1 {
        flex-direction: column;
    }

    .aca-hero-content,
    .aca-hero-media {
        width: 100% !important;
    }

    .aca-contact-block {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .aca-dual-cta {
        flex-direction: column;
    }

}

@media (max-width: 768px) {
    .aca-testimonial {
        flex-direction: column;
        text-align: center;
    }

    .aca-testimonial-avatar {
        margin-bottom: 1.5rem;
    }

    .aca-quote {
        font-size: 1.1rem;
    }

    .aca-blog-grid,
    .aca-event-grid {
        grid-template-columns: 1fr;
    }

    .aca-partners-carousel .swiper-slide {
        min-height: 120px;
    }
}

/* ========================================
   HEADER CTA BUTTON (Enhanced for visibility)
   Enhanced specificity via body class instead of !important
   ======================================== */
/* Header button - white background for contrast against blue header */
body.cc-header-default header .cc-btn-primary,
body header .cc-btn-primary {
    background: #ffffff;
    color: var(--color-primary);
    font-weight: 700;
    padding: 0.875rem 1.75rem;
    font-size: 1rem;
    border: 2px solid #ffffff;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2), 0 0 0 0 rgba(255, 255, 255, 0.4);
    text-transform: none;
    letter-spacing: 0.01em;
    min-height: 48px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

body.cc-header-default header .cc-btn-primary:hover,
body header .cc-btn-primary:hover {
    background: #f8f9fa;
    color: var(--color-primary);
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3), 0 0 0 4px rgba(255, 255, 255, 0.2);
    border-color: #ffffff;
}

body.cc-header-default header .cc-btn-primary:active,
body header .cc-btn-primary:active {
    transform: translateY(-1px) scale(1.01);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}

/* Add subtle glow animation for attention */
@keyframes buttonGlow {
    0%, 100% {
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2), 0 0 0 0 rgba(255, 255, 255, 0.4);
    }
    50% {
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2), 0 0 0 3px rgba(255, 255, 255, 0.3);
    }
}

body.cc-header-default header .cc-btn-primary:focus,
body header .cc-btn-primary:focus {
    outline: 3px solid rgba(255, 255, 255, 0.5);
    outline-offset: 2px;
    animation: buttonGlow 2s ease-in-out infinite;
}


/* ============================================
   WIDGET AREA STYLES (Refactored Phase 9)
   ============================================ */

/**
 * Primary Sidebar Widgets
 * Styling for widgets displayed in main sidebars
 */
.cc-widget {
    background-color: var(--color-white, #ffffff);
    border: 1px solid var(--color-border-light, #e0e0e0);
    border-radius: var(--border-radius-md, 8px);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    transition: all var(--transition-speed, 0.3s) ease;
}

.cc-widget:hover {
    border-color: var(--color-primary, #2f4089);
    box-shadow: 0 2px 8px rgba(47, 64, 137, 0.08);
}

.cc-widget-title {
    font-size: var(--text-lg, 1.125rem);
    font-weight: 700;
    color: var(--color-heading, #202c63);
    margin: 0 0 var(--spacing-md) 0;
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid var(--color-primary, #2f4089);
    line-height: var(--line-height-tight, 1.3);
}

/* Widget content styling */
.cc-widget ul,
.cc-widget ol {
    list-style: none;
    margin: 0;
    padding: 0;
}

.cc-widget li {
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--color-border-light, #e0e0e0);
}

.cc-widget li:last-child {
    border-bottom: none;
}

.cc-widget a {
    color: var(--color-primary, #2f4089);
    text-decoration: none;
    font-weight: 500;
    transition: color var(--transition-speed, 0.3s) ease;
}

.cc-widget a:hover {
    color: var(--color-secondary, #4b96da);
    text-decoration: underline;
}

.cc-widget a:focus {
    outline: 2px solid var(--color-primary, #2f4089);
    outline-offset: 2px;
}

/* Widget text styling */
.cc-widget p {
    color: var(--color-text-secondary, #3d4668);
    font-size: var(--text-base, 1rem);
    line-height: var(--line-height-relaxed, 1.65);
    margin: var(--spacing-sm) 0;
}

.cc-widget p:first-child {
    margin-top: 0;
}

.cc-widget p:last-child {
    margin-bottom: 0;
}

/* ============================================
   FOOTER WIDGET STYLES
   ============================================ */

/**
 * Footer Sidebar Widgets
 * Styling for widgets displayed in footer areas
 */
.cc-footer-widget {
    padding: var(--spacing-lg) 0;
}

.cc-footer-widget:not(:last-child) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.cc-footer-widget-title {
    font-size: var(--text-lg, 1.125rem);
    font-weight: 700;
    color: var(--color-white, #ffffff);
    margin: 0 0 var(--spacing-md) 0;
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid rgba(255, 255, 255, 0.3);
    line-height: var(--line-height-tight, 1.3);
}

/* Footer widget content */
.cc-footer-widget ul,
.cc-footer-widget ol {
    list-style: none;
    margin: 0;
    padding: 0;
}

.cc-footer-widget li {
    padding: var(--spacing-sm) 0;
}

.cc-footer-widget a {
    color: rgba(255, 255, 255, 0.8);
    text-decoration: none;
    font-weight: 500;
    transition: color var(--transition-speed, 0.3s) ease;
}

.cc-footer-widget a:hover {
    color: var(--color-white, #ffffff);
    text-decoration: underline;
}

.cc-footer-widget a:focus {
    outline: 2px solid rgba(255, 255, 255, 0.5);
    outline-offset: 2px;
    border-radius: var(--border-radius-sm, 4px);
}

/* Footer widget text */
.cc-footer-widget p {
    color: rgba(255, 255, 255, 0.8);
    font-size: var(--text-base, 1rem);
    line-height: var(--line-height-relaxed, 1.65);
    margin: var(--spacing-sm) 0;
}

.cc-footer-widget p:first-child {
    margin-top: 0;
}

.cc-footer-widget p:last-child {
    margin-bottom: 0;
}

/* ============================================
   RESPONSIVE WIDGET STYLING
   ============================================ */

@media (max-width: 768px) {
    .cc-widget {
        padding: var(--spacing-md);
        margin-bottom: var(--spacing-md);
    }

    .cc-widget-title {
        font-size: var(--text-base, 1rem);
        margin-bottom: var(--spacing-sm);
    }

    .cc-footer-widget {
        padding: var(--spacing-md) 0;
    }

    .cc-footer-widget-title {
        font-size: var(--text-base, 1rem);
    }
}

/* ============================================
   ACCESSIBILITY
   ============================================ */

.cc-widget:focus-within {
    border-color: var(--color-primary, #2f4089);
    box-shadow: 0 2px 8px rgba(47, 64, 137, 0.15);
}

@media (prefers-reduced-motion: reduce) {
    .cc-widget,
    .cc-widget a {
        transition: none !important;
    }
}



/* ============================================
   HOMEPAGE LAYOUT (migrated from homepage-improvements.css)
   ============================================ */
/**
 * Homepage Layout Improvements
 * Restructures narrative flow, improves visual hierarchy, and makes service directory scannable
 */

/* ============================================
   TRANSPARENT HEADER EFFECT (Homepage Only)
   ============================================ */
/* Transparent header with sticky effects - only applies on home page */
/* Using #elem-custom-header for specific targeting */

/* Make header transparent on initial load (before sticky activates) */
.cc-transparent-header.home #elem-custom-header {
    background-color: transparent !important;
    transition: background-color 2s ease !important;
}

/* Keep header transparent when sticky but not scrolled */
.cc-transparent-header.home #elem-custom-header.elementor-sticky {
    background-color: transparent !important;
    transition: background-color 2s ease !important;
}

/* Apply semi-transparent brand blue background when sticky effects are active (on scroll) */
.cc-transparent-header.home #elem-custom-header.elementor-sticky.elementor-sticky--effects {
    background-color: rgba(47, 64, 137, 0.5) !important; /* Semi-transparent brand color */
}

/* Also target background wrapper if Elementor uses one */
.cc-transparent-header.home #elem-custom-header.elementor-sticky.elementor-sticky--effects .elementor-background-overlay {
    background-color: rgba(47, 64, 137, 0.5) !important;
}

.cc-transparent-header.home #elem-custom-header.elementor-sticky.elementor-sticky--effects > .e-con-inner,
.cc-transparent-header.home #elem-custom-header.elementor-sticky.elementor-sticky--effects > .elementor-container {
    min-height: 80px;
}

.cc-transparent-header.home #elem-custom-header.elementor-sticky > .e-con-inner,
.cc-transparent-header.home #elem-custom-header.elementor-sticky > .elementor-container {
    transition: min-height 1s ease !important;
}

/* Push hero section under transparent header on homepage */
/* Push hero section under transparent header on homepage */
.cc-transparent-header.home .aca-hero-v1,
.cc-transparent-header.home .elementor-section:first-child {
    margin-top: -100px; /* Negative margin to push under header */
    position: relative;
    z-index: 1; /* Hero content behind header */
}

/* Ensure header stays above hero content */
.cc-transparent-header.home .elementor-sticky {
    z-index: 100 !important; /* Header above hero - don't override Elementor's positioning */
}

/* Responsive adjustments for hero positioning */
@media (max-width: 1024px) {
    .cc-transparent-header.home .aca-hero-v1,
    .cc-transparent-header.home .elementor-section:first-child {
        margin-top: -90px; /* Slightly less on tablet */
    }
}

@media (max-width: 768px) {
    .cc-transparent-header.home .aca-hero-v1,
    .cc-transparent-header.home .elementor-section:first-child {
        margin-top: -80px; /* Less on mobile */
    }
}

/* ============================================
   TRANSPARENT HEADER EFFECT (Additional Pages)
   ============================================ */
/* Apply transparent header effect to:
   - /agency/ (archive)
   - /our-calling/ (page-id-48)
   - /who-we-are/ (page-id-413)
   - Single agency pages
   - Single service pages
*/

/* Universal transparent header - using #elem-custom-header for specific targeting */

/* Make header transparent on initial load (before sticky activates) */
.cc-transparent-header #elem-custom-header {
    background-color: transparent !important;
    transition: background-color 2s ease !important;
}

/* Keep header transparent when sticky but not scrolled */
.cc-transparent-header #elem-custom-header.elementor-sticky {
    background-color: transparent !important;
    transition: background-color 2s ease !important;
}

/* Admin Bar Adjustment: When logged in, the sticky header needs to sit below the admin bar */
.admin-bar.cc-transparent-header #elem-custom-header.elementor-sticky {
    top: 32px !important; /* Default admin bar height */
}

@media (max-width: 782px) {
    .admin-bar.cc-transparent-header #elem-custom-header.elementor-sticky {
        top: 46px !important; /* Mobile admin bar height */
    }
}

/* Apply semi-transparent background when sticky effects are active (on scroll) */
.cc-transparent-header #elem-custom-header.elementor-sticky.elementor-sticky--effects {
    background-color: rgba(47, 64, 137, 0.5) !important; /* Semi-transparent brand color */
}

/* Target the container element directly */
.cc-transparent-header #elem-custom-header.elementor-sticky.elementor-sticky--effects > .elementor-container,
.cc-transparent-header #elem-custom-header.elementor-sticky.elementor-sticky--effects > .e-con-inner {
    background-color: rgba(47, 64, 137, 0.5) !important;
}

/* Also target background wrapper if Elementor uses one */
.cc-transparent-header #elem-custom-header.elementor-sticky.elementor-sticky--effects .elementor-background-overlay {
    background-color: rgba(47, 64, 137, 0.5) !important;
}

/* Min-height transitions */
.cc-transparent-header #elem-custom-header.elementor-sticky.elementor-sticky--effects > .e-con-inner,
.cc-transparent-header #elem-custom-header.elementor-sticky.elementor-sticky--effects > .elementor-container {
    min-height: 80px;
}

.cc-transparent-header #elem-custom-header.elementor-sticky > .e-con-inner,
.cc-transparent-header #elem-custom-header.elementor-sticky > .elementor-container {
    transition: min-height 1s ease !important;
}

/* Push hero section under transparent header - ALL pages except homepage */
/* Applies to all single pages, archive pages, and general pages */
.cc-transparent-header:not(.home) .aca-hero-v1,
.cc-transparent-header:not(.home) .elementor-section:first-child,
.cc-transparent-header.page-id-48 .aca-hero-v1,
.cc-transparent-header.page-id-48 .elementor-section:first-child,
.cc-transparent-header.page-id-413 .aca-hero-v1,
.cc-transparent-header.page-id-413 .elementor-section:first-child,
.cc-transparent-header.post-type-archive-agency .aca-hero-v1,
.cc-transparent-header.post-type-archive-agency .elementor-section:first-child,
.cc-transparent-header.post-type-archive-service .aca-hero-v1,
.cc-transparent-header.post-type-archive-service .elementor-section:first-child,
.cc-transparent-header.post-type-archive-location .aca-hero-v1,
.cc-transparent-header.post-type-archive-location .elementor-section:first-child,
.cc-transparent-header.post-type-archive-event .aca-hero-v1,
.cc-transparent-header.post-type-archive-event .elementor-section:first-child,
.cc-transparent-header.post-type-archive-program .aca-hero-v1,
.cc-transparent-header.post-type-archive-program .elementor-section:first-child,
.cc-transparent-header.post-type-archive-resource .aca-hero-v1,
.cc-transparent-header.post-type-archive-resource .elementor-section:first-child,
.cc-transparent-header.single-agency .aca-hero-v1,
.cc-transparent-header.single-agency .elementor-section:first-child,
.cc-transparent-header.single-service .aca-hero-v1,
.cc-transparent-header.single-service .elementor-section:first-child,
.cc-transparent-header.single-location .aca-hero-v1,
.cc-transparent-header.single-location .elementor-section:first-child,
.cc-transparent-header.single-event .aca-hero-v1,
.cc-transparent-header.single-event .elementor-section:first-child,
.cc-transparent-header.single-program .aca-hero-v1,
.cc-transparent-header.single-program .elementor-section:first-child,
.cc-transparent-header.single-resource .aca-hero-v1,
.cc-transparent-header.single-resource .elementor-section:first-child,
.cc-transparent-header.single-staff .aca-hero-v1,
.cc-transparent-header.single-staff .elementor-section:first-child,
.cc-transparent-header.page .aca-hero-v1:not(.home),
.cc-transparent-header.page .elementor-section:first-child:not(.home) {
    margin-top: -100px !important; /* Negative margin to push under header */
    padding-top: 100px !important; /* Add padding to compensate for header height */
    position: relative;
    z-index: 1; /* Hero content behind header */
    min-height: calc(80vh + 100px) !important; /* Ensure full height including header space */
}

/* Agency hero - push under header but keep original height */
.cc-transparent-header.single-agency .agency-hero {
    margin-top: -100px !important; /* Negative margin to push under header */
    padding-top: 100px !important; /* Add padding to compensate for header height */
    position: relative;
    z-index: 1; /* Hero content behind header */
    /* Don't set min-height - let it use its natural height */
}

/* Archive hero (Elementor-based archives) - push under header but keep original height */
.cc-transparent-header.post-type-archive-agency .archive-hero,
.cc-transparent-header.post-type-archive-agency .agencies-hero,
.cc-transparent-header.post-type-archive-service .archive-hero,
.cc-transparent-header.post-type-archive-location .archive-hero,
.cc-transparent-header.post-type-archive-event .archive-hero,
.cc-transparent-header.post-type-archive-program .archive-hero,
.cc-transparent-header.post-type-archive-resource .archive-hero {
    margin-top: -100px !important; /* Negative margin to push under header */
    padding-top: 140px !important; /* Add extra padding to create more space from header */
    position: relative;
    z-index: 1; /* Hero content behind header */
    /* Don't set min-height - let it use its natural height */
}

/* Agency archive hero (cc-hero component) - push hero under header so background covers transparent header */
.cc-transparent-header.post-type-archive-agency .agency-hero--archive {
    margin-top: -100px !important;       /* Negative margin to push hero under header */
    padding-top: 140px !important;       /* Extra padding to keep content clear of header */
    position: relative;
    z-index: 1;                          /* Ensure hero is behind header but above page background */
}

/* Service archive hero (cc-hero component) - push hero under header so background covers transparent header */
.cc-transparent-header.post-type-archive-service .service-hero--archive {
    margin-top: -100px !important;       /* Negative margin to push hero under header */
    padding-top: 140px !important;       /* Extra padding to keep content clear of header */
    position: relative;
    z-index: 1;                          /* Ensure hero is behind header but above page background */
    width: 100vw !important;             /* Full viewport width */
    max-width: none !important;          /* Override any max-width constraints */
    left: 50% !important;                /* Center for breakout */
    right: 50% !important;               /* Center for breakout */
    margin-left: -50vw !important;       /* Break out of container */
    margin-right: -50vw !important;      /* Break out of container */
}

/* Pilgrimage archive hero (cc-hero component) - push hero under header so background covers transparent header */
.cc-transparent-header.post-type-archive-pilgrimage .pilgrimage-hero--archive {
    margin-top: -100px !important;       /* Negative margin to push hero under header */
    padding-top: 100px !important;       /* Padding to compensate for header height - matches other archives */
    padding-bottom: 4rem !important;     /* Bottom padding for content */
    position: relative !important;
    z-index: 1;                          /* Ensure hero is behind header but above page background */
    overflow: visible !important;        /* Allow background to show */
    width: 100vw !important;             /* Full viewport width */
    max-width: none !important;          /* Override any max-width constraints */
    left: 50% !important;                /* Center for breakout */
    right: 50% !important;               /* Center for breakout */
    margin-left: -50vw !important;       /* Break out of container */
    margin-right: -50vw !important;      /* Break out of container */
}

/* Ensure pilgrimage archive hero background is visible and properly positioned */
.cc-transparent-header.post-type-archive-pilgrimage .pilgrimage-hero--archive .cc-hero__background {
    background-color: #1a365d !important;
    z-index: -1;                         /* Behind content and overlay */
    position: absolute !important;
    inset: 0 !important;
}

.cc-transparent-header.post-type-archive-pilgrimage .pilgrimage-hero--archive .cc-hero__overlay {
    z-index: 0;                          /* Between background and content */
    position: absolute !important;
    inset: 0 !important;
}

/* Pilgrimage archive header contrast */
body.post-type-archive-pilgrimage .elementor-location-header,
body.post-type-archive-pilgrimage .elementor-location-header > .elementor-section,
body.post-type-archive-pilgrimage .elementor-location-header > .e-con {
    background: var(--color-primary, #2f4089) !important;
    color: #ffffff !important;
}

body.post-type-archive-pilgrimage header a,
body.post-type-archive-pilgrimage .elementor-nav-menu--main .elementor-item,
body.post-type-archive-pilgrimage .elementor-nav-menu--main .elementor-item:before,
body.post-type-archive-pilgrimage .elementor-nav-menu--main .elementor-item:after {
    color: #ffffff !important;
    fill: #ffffff !important;
}

body.post-type-archive-pilgrimage .elementor-nav-menu--main .elementor-item:hover,
body.post-type-archive-pilgrimage .elementor-nav-menu--main .elementor-item.elementor-item-active {
    color: #e4e9f7 !important;
}

/* Sacred button styling on pilgrimage pages - ensure no color conflicts with transparent header */
.cc-transparent-header.single-pilgrimage .btn-sacred {
    background: var(--sacred-gold, #D4AF37) !important;
    color: var(--sacred-blue-deep, #1a365d) !important;
}

.cc-transparent-header.single-pilgrimage .btn-sacred:hover {
    background: var(--sacred-gold-light, #E5C158) !important;
    color: var(--sacred-blue-deep, #1a365d) !important;
}

/* Sticky container background for pilgrimage archive */
body.post-type-archive-pilgrimage .elementor-sticky,
body.post-type-archive-pilgrimage [data-id="c8deb65"],
body.post-type-archive-pilgrimage #trans_header {
    background: var(--color-primary, #2f4089) !important;
}

body.post-type-archive-pilgrimage .elementor-sticky.elementor-sticky--effects,
body.post-type-archive-pilgrimage [data-id="c8deb65"].elementor-sticky--effects {
    background: var(--color-primary, #2f4089) !important;
}

/* Single pilgrimage transparent header - override single-pilgrimage.css hardcoded solid blue */
/* Must use same selector structure (body.single-pilgrimage) as single-pilgrimage.css but with cc-transparent-header class for specificity */
body.cc-transparent-header.single-pilgrimage .elementor-sticky,
body.cc-transparent-header.single-pilgrimage [data-id="c8deb65"],
body.cc-transparent-header.single-pilgrimage #trans_header {
    background-color: transparent !important;
    transition: background-color 2s ease !important;
}

/* Header location wrapper */
body.cc-transparent-header.single-pilgrimage .elementor-location-header,
body.cc-transparent-header.single-pilgrimage .elementor-location-header > .elementor-section,
body.cc-transparent-header.single-pilgrimage .elementor-location-header > .e-con {
    background-color: transparent !important;
}

/* Apply solid brand blue background when scrolling/sticky effects active */
body.cc-transparent-header.single-pilgrimage .elementor-sticky.elementor-sticky--effects,
body.cc-transparent-header.single-pilgrimage [data-id="c8deb65"].elementor-sticky--effects,
body.cc-transparent-header.single-pilgrimage #trans_header.elementor-sticky--effects {
    background-color: var(--color-primary, #2f4089) !important;
}

/* Archive pages transparent header (service, agency, location, event, program, resource) */
/* Override Elementor's hardcoded background with matching specificity */
.cc-transparent-header.post-type-archive-service .elementor-40 .elementor-element.elementor-element-c8deb65:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-service .elementor-40 .elementor-element.elementor-element-c8deb65 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-agency .elementor-40 .elementor-element.elementor-element-c8deb65:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-agency .elementor-40 .elementor-element.elementor-element-c8deb65 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-location .elementor-40 .elementor-element.elementor-element-c8deb65:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-location .elementor-40 .elementor-element.elementor-element-c8deb65 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-event .elementor-40 .elementor-element.elementor-element-c8deb65:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-event .elementor-40 .elementor-element.elementor-element-c8deb65 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-program .elementor-40 .elementor-element.elementor-element-c8deb65:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-program .elementor-40 .elementor-element.elementor-element-c8deb65 > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-resource .elementor-40 .elementor-element.elementor-element-c8deb65:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-resource .elementor-40 .elementor-element.elementor-element-c8deb65 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    background-color: transparent !important;
    transition: background-color 2s ease !important;
}

/* Archive pages header on scroll - override to brand blue */
.cc-transparent-header.post-type-archive-service .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-service .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-agency .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-agency .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-location .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-location .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-event .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-event .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-program .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-program .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects > .elementor-motion-effects-container > .elementor-motion-effects-layer,
.cc-transparent-header.post-type-archive-resource .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects:not(.elementor-motion-effects-element-type-background),
.cc-transparent-header.post-type-archive-resource .elementor-40 .elementor-element.elementor-element-c8deb65.elementor-sticky--effects > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    background-color: #2f4089 !important;
}

/* Single pilgrimage hero - apply nav blend pattern */
.cc-transparent-header.single-pilgrimage .pilgrimage-hero {
    margin-top: -100px !important;
    padding-top: 100px !important;
    position: relative;
    z-index: 1;
}

/* ============================================
   HOMEPAGE CONTACT SECTION CLEANUP
   ============================================ */
/* Hide empty contact form column and let info span full width */
.home section.contact-section .aca-contact-form {
    display: none !important;
}

.home section.contact-section .container > div {
    display: flex !important;
    flex-direction: column !important;
    gap: 2rem !important;
    grid-template-columns: 1fr !important;
}

.home section.contact-section .contact-info,
.home section.contact-section .aca-contact-details {
    max-width: 640px;
    width: 100%;
}

/* ============================================
   UNIVERSAL PAGE CONTAINER STYLING (Non-Homepage)
   ============================================ */
/* Apply consistent max-width and padding to all non-home pages that are not using Elementor full-width template */
/* Exclude footer and hero sections from these rules */
/* Removed legacy container caps to allow Elementor to control widths */

/* Left align title and content in agency archive hero */
.cc-transparent-header.post-type-archive-agency .archive-hero h1,
.cc-transparent-header.post-type-archive-agency .archive-hero .archive-title,
.cc-transparent-header.post-type-archive-agency .agencies-hero h1,
.cc-transparent-header.post-type-archive-agency .agencies-hero .archive-title,
.cc-transparent-header.post-type-archive-agency .archive-header-wrapper,
.cc-transparent-header.post-type-archive-agency .archive-header-wrapper h1,
.cc-transparent-header.post-type-archive-agency .archive-header-wrapper .archive-title {
    text-align: left !important;
}

/* Who We Are hero - push under header but keep original height */
.cc-transparent-header.page-id-413 .who-we-are-hero {
    margin-top: -100px !important; /* Negative margin to push under header */
    padding-top: 140px !important; /* Add extra padding to create more space from header */
    position: relative;
    z-index: 1; /* Hero content behind header */
    /* Don't set min-height - let it use its natural height */
}

/* Service hero - extend background behind transparent header (nav blend) */
.cc-transparent-header.single-service .service-hero {
    margin-top: -100px !important;
    padding-top: 100px !important;
    position: relative;
    z-index: 1;
}

/* Ensure header stays above hero content */
.cc-transparent-header [data-id="c8deb65"].elementor-sticky {
    z-index: 100 !important; /* Header above hero - don't override Elementor's positioning */
}

/* Responsive adjustments for hero positioning */
@media (max-width: 1024px) {
    .cc-transparent-header.page-id-48 .aca-hero-v1,
    .cc-transparent-header.page-id-48 .elementor-section:first-child,
    .cc-transparent-header.page-id-413 .aca-hero-v1,
    .cc-transparent-header.page-id-413 .elementor-section:first-child,
    .cc-transparent-header.post-type-archive-agency .aca-hero-v1,
    .cc-transparent-header.post-type-archive-agency .elementor-section:first-child,
    .cc-transparent-header.single-agency .aca-hero-v1,
    .cc-transparent-header.single-agency .elementor-section:first-child,
    .cc-transparent-header.single-service .aca-hero-v1,
    .cc-transparent-header.single-service .elementor-section:first-child {
        margin-top: -90px !important; /* Slightly less on tablet */
        padding-top: 90px !important; /* Match the margin - override who-we-are.css */
        min-height: calc(70vh + 90px) !important; /* Adjust min-height for tablet */
    }
    
    /* Agency hero - responsive adjustments */
    .cc-transparent-header.single-agency .agency-hero {
        margin-top: -90px !important; /* Slightly less on tablet */
        padding-top: 90px !important; /* Match the margin */
    }
    
    /* Archive hero - responsive adjustments */
    .cc-transparent-header.post-type-archive-agency .archive-hero,
    .cc-transparent-header.post-type-archive-agency .agencies-hero {
        margin-top: -90px !important; /* Slightly less on tablet */
        padding-top: 130px !important; /* Extra padding for more space from header */
    }

    /* Agency archive hero (cc-hero) - responsive adjustments (tablet) */
    .cc-transparent-header.post-type-archive-agency .agency-hero--archive {
        margin-top: -90px !important;    /* Slightly less on tablet */
        padding-top: 130px !important;   /* Extra padding for more space from header */
    }

    /* Service archive hero (cc-hero) - responsive adjustments (tablet) */
    .cc-transparent-header.post-type-archive-service .service-hero--archive {
        margin-top: -90px !important;    /* Slightly less on tablet */
        padding-top: 130px !important;   /* Extra padding for more space from header */
    }

    /* Pilgrimage archive hero (cc-hero) - responsive adjustments (tablet) */
    .cc-transparent-header.post-type-archive-pilgrimage .pilgrimage-hero--archive {
        margin-top: -90px !important;    /* Slightly less on tablet */
        padding-top: 130px !important;   /* Extra padding for more space from header */
    }

    /* Who We Are hero - responsive adjustments */
    .cc-transparent-header.page-id-413 .who-we-are-hero {
        margin-top: -90px !important; /* Slightly less on tablet */
        padding-top: 130px !important; /* Extra padding for more space from header */
    }
    
}

@media (max-width: 768px) {
    .cc-transparent-header.page-id-48 .aca-hero-v1,
    .cc-transparent-header.page-id-48 .elementor-section:first-child,
    .cc-transparent-header.page-id-413 .aca-hero-v1,
    .cc-transparent-header.page-id-413 .elementor-section:first-child,
    .cc-transparent-header.post-type-archive-agency .aca-hero-v1,
    .cc-transparent-header.post-type-archive-agency .elementor-section:first-child,
    .cc-transparent-header.single-agency .aca-hero-v1,
    .cc-transparent-header.single-agency .elementor-section:first-child,
    .cc-transparent-header.single-service .aca-hero-v1,
    .cc-transparent-header.single-service .elementor-section:first-child {
        margin-top: -80px !important; /* Less on mobile */
        padding-top: 80px !important; /* Match the margin - override who-we-are.css */
        min-height: calc(60vh + 80px) !important; /* Adjust min-height for mobile */
    }
    
    /* Agency hero - mobile adjustments */
    .cc-transparent-header.single-agency .agency-hero {
        margin-top: -80px !important; /* Less on mobile */
        padding-top: 80px !important; /* Match the margin */
    }
    
    /* Archive hero - mobile adjustments */
    .cc-transparent-header.post-type-archive-agency .archive-hero,
    .cc-transparent-header.post-type-archive-agency .agencies-hero {
        margin-top: -80px !important; /* Less on mobile */
        padding-top: 120px !important; /* Extra padding for more space from header */
    }

    /* Agency archive hero (cc-hero) - mobile adjustments */
    .cc-transparent-header.post-type-archive-agency .agency-hero--archive {
        margin-top: -80px !important;    /* Less on mobile */
        padding-top: 120px !important;   /* Extra padding for more space from header */
    }

    /* Service archive hero (cc-hero) - mobile adjustments */
    .cc-transparent-header.post-type-archive-service .service-hero--archive {
        margin-top: -80px !important;    /* Less on mobile */
        padding-top: 120px !important;   /* Extra padding for more space from header */
    }

    /* Pilgrimage archive hero (cc-hero) - mobile adjustments */
    .cc-transparent-header.post-type-archive-pilgrimage .pilgrimage-hero--archive {
        margin-top: -80px !important;    /* Less on mobile */
        padding-top: 120px !important;   /* Extra padding for more space from header */
    }

    /* Who We Are hero - mobile adjustments */
    .cc-transparent-header.page-id-413 .who-we-are-hero {
        margin-top: -80px !important; /* Less on mobile */
        padding-top: 120px !important; /* Extra padding for more space from header */
    }
    
}

/* ============================================
   HOMEPAGE NARRATIVE RESTRUCTURING
   ============================================ */

/* Hide only specific broken/placeholder content selectively */
.aca-form-placeholder {
    display: none;
}

/* Only hide elements explicitly marked as broken or lorem */
[data-type="lorem"],
[data-type="placeholder"],
[data-broken="true"] {
    display: none;
}

/* ============================================
   VISUAL HIERARCHY & SPACING
   ============================================ */

/* Improve hero section prominence */
.aca-hero-v1,
[data-id="f8264a6b"] {
    min-height: 40vh;
    margin-bottom: 0;
}

/* Hero video background styling */
.hero-video-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    overflow: hidden;
}

.hero-video-background iframe {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100vw;
    height: 56.25vw; /* 16:9 aspect ratio */
    min-height: 100vh;
    min-width: 177.77vh; /* 16:9 aspect ratio */
    transform: translate(-50%, -50%);
    pointer-events: none;
}

.hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(0, 102, 204, 0.30) 0%, rgba(0, 82, 163, 0.40) 100%);
    z-index: 1;
}

/* Responsive adjustments for hero video */
@media (max-width: 768px) {
    .aca-hero-v1 {
        min-height: 35vh;
        padding: 2rem 1.5rem !important;
    }
    
    .hero-video-background iframe {
        width: 177.77vh;
        height: 100vh;
        min-width: 100vw;
        min-height: 56.25vw;
    }
}

/* Section spacing standards (scoped to page types using Elementor) */
.single-agency .elementor-section,
.single-service .elementor-section,
.single-pilgrimage .elementor-section,
.page .elementor-section,
.post .elementor-section {
    padding: 3rem 2rem;
}

@media (min-width: 1200px) {
    .single-agency .elementor-section,
    .single-service .elementor-section,
    .single-pilgrimage .elementor-section,
    .page .elementor-section,
    .post .elementor-section {
        padding: 4rem 2rem;
    }
}

/* Section titles should be prominent */
.elementor-section h2:first-of-type,
.elementor-section > [class*="heading"]:first-of-type h2 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 700;
    margin-bottom: 1.5rem;
    color: var(--color-heading, #333);
}

/* ============================================
   SERVICE DIRECTORY - CRITICAL FIX
   ============================================ */

.california_agencies_map,
.locations-map,
[class*="directory"] {
    max-width: var(--container-xl);
    margin: 0 auto;
}

/* Convert long list to 2-column layout */
.california_agencies_map ul,
.california_agencies_map ol,
[class*="agency-list"],
[class*="location-list"] {
    column-count: 2;
    column-gap: 2.5rem;
    column-fill: balance;
}

@media (max-width: 1024px) {
    .california_agencies_map ul,
    .california_agencies_map ol,
    [class*="agency-list"],
    [class*="location-list"] {
        column-count: 1;
    }
}

/* Improve list item styling */
.california_agencies_map li,
[class*="agency-list"] li,
[class*="location-list"] li {
    break-inside: avoid;
    padding: 0.75rem 0;
    border-bottom: 1px solid #e8e8e8;
    line-height: 1.6;
    font-size: 0.9rem;
}

.california_agencies_map li:last-child,
[class*="agency-list"] li:last-child,
[class*="location-list"] li:last-child {
    border-bottom: none;
}

/* Agency category grouping */
.agency-category,
[class*="category-group"] {
    break-inside: avoid;
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    background: #f9f9f9;
    border-left: 4px solid var(--color-primary, #2f4089);
    border-radius: 4px;
}

.agency-category-title,
[class*="category-title"] {
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--color-primary, #2f4089);
    margin: 0 0 1rem 0;
}

/* Directory filter/search container */
[class*="directory-filter"],
[class*="location-filter"] {
    margin-bottom: 2rem;
    padding: 1.5rem;
    background: #f5f5f5;
    border-radius: 8px;
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

[class*="directory-filter"] select,
[class*="directory-filter"] input,
[class*="location-filter"] select,
[class*="location-filter"] input {
    padding: 0.75rem;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 0.9rem;
}

/* ============================================
   FORM SECTION FIXES
   ============================================ */

/* Hide broken placeholder form text - only specific class */
.aca-form-placeholder {
    display: none !important;
}

/* Generic placeholder styling (if not hidden) */
.form-placeholder {
    opacity: 0.5;
}

/* Improve contact/form section styling */
[class*="contact-block"],
[class*="form-section"],
[class*="contact-section"] {
    padding: 2rem;
    background: #f9f9f9;
    border-radius: 8px;
    margin: 2rem 0;
}

[class*="contact-block"] h3,
[class*="form-section"] h3,
[class*="contact-section"] h3 {
    margin-top: 0;
}

/* ============================================
   PARTNER/LOGO SECTION
   ============================================ */

/* Hide empty partner slots, show filled ones */
[class*="partner"] figure:empty,
[class*="partner"] img[src=""],
[class*="partner"] [class*="empty"] {
    display: none;
}

/* ============================================
   CONTENT CARDS IMPROVEMENT
   ============================================ */

/* Consistent card styling - target ACA components specifically */
.home .cc-card {
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
    transition: all 0.3s ease;
}

.home .cc-card:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    border-color: var(--color-primary, #2f4089);
}

/* Blog and event cards from Elementor */
.aca-blog-grid article,
.aca-event-grid article {
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
    transition: all 0.3s ease;
}

.aca-blog-grid article:hover,
.aca-event-grid article:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    border-color: var(--color-primary, #2f4089);
}

/* ============================================
   BUTTON & CTA IMPROVEMENTS
   ============================================ */

/* Fix nested button styling */
.elementor-button-wrapper .elementor-button {
    display: inline-block;
    padding: 0.75rem 1.5rem !important;
    font-weight: 600;
    border-radius: 6px;
    transition: all 0.3s ease;
}

.elementor-button-wrapper .elementor-button:first-child {
    background-color: var(--color-primary, #2f4089);
    color: #ffffff;
    border: 2px solid var(--color-primary, #2f4089);
}

.elementor-button-wrapper .elementor-button:last-child {
    background-color: transparent;
    color: var(--color-primary, #2f4089);
    border: 2px solid var(--color-primary, #2f4089);
}

.elementor-button-wrapper .elementor-button:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(47, 64, 137, 0.2);
}

/* Prominent CTA section */
[class*="dual-cta"],
[class*="cta-section"] {
    margin: 3rem 0;
    padding: 2rem;
    background: linear-gradient(135deg, var(--color-primary, #2f4089) 0%, #202c63 100%);
    color: white;
    border-radius: 8px;
    text-align: center;
}

[class*="dual-cta"] h3,
[class*="cta-section"] h3 {
    color: white;
}

[class*="dual-cta"] p,
[class*="cta-section"] p {
    color: rgba(255, 255, 255, 0.95);
}

/* ============================================
   MOBILE IMPROVEMENTS
   ============================================ */

@media (max-width: 768px) {
    .elementor-section {
        padding: 2rem 1.5rem;
    }

    .aca-hero-v1,
    [class*="hero"] {
        min-height: auto;
    }

    /* Stack featured content on mobile */
    [class*="hero-content"],
    [class*="hero-media"] {
        margin-bottom: 1.5rem;
    }

    /* Reduce gaps on mobile */
    [class*="grid"],
    [class*="flex"] {
        gap: 1rem !important;
    }

    /* Single column on mobile */
    [class*="directory"],
    .california_agencies_map ul,
    .california_agencies_map ol {
        column-count: 1 !important;
    }
}

/* ============================================
   Z-INDEX & LAYERING MANAGEMENT
   ============================================ */

/* Prevent z-index collisions between modals and fixed elements */
.cc-modal,
[class*="modal-overlay"],
.elementor-popup {
    z-index: var(--z-tooltip) !important;
}

.cc-modal-backdrop,
[class*="modal-backdrop"],
.elementor-popup-overlay {
    z-index: var(--z-tooltip) !important;
}

/* Fixed donation button z-index is set in style.css (z-index: 9999) */
/* Removed conflicting z-index: 999 rule that was causing button to appear under footer */

/* Ensure modals appear above donate button */
.cc-modal,
[class*="modal"] {
    z-index: var(--z-tooltip);
}

/* ============================================
   ACCESSIBILITY & READABILITY
   ============================================ */

/* Text color specificity - target paragraphs in content */
.elementor-widget-container p,
article p,
.home .cc-card p {
    color: var(--color-text, #555);
}

/* Accessible focus states */
button:focus-visible,
a:focus-visible,
input:focus-visible {
    outline: 2px solid var(--color-primary, #2f4089);
    outline-offset: 2px;
}

/* Better link styling for content links only */
.elementor-widget-text-editor a,
article a,
.home .cc-card a {
    color: var(--color-primary, #2f4089);
    text-decoration: underline;
    transition: color 0.2s ease;
}

.elementor-widget-text-editor a:hover,
article a:hover,
.home .cc-card a:hover {
    color: #202c63;
    text-decoration: none;
}

/* ============================================
   CONTENT-SPECIFIC SECTIONS
   ============================================ */

/* Impact statement prominence */
[class*="impact"],
[class*="mission"] {
    font-size: 1.1rem;
    line-height: 1.8;
    margin: 1.5rem 0;
}

/* Statistics/metrics emphasis */
.aca-stat-block h3,
[class*="stat"] h3,
[class*="metric"] h3 {
    color: var(--color-primary, #2f4089);
}

/* Quote styling */
blockquote,
.aca-quote,
[class*="quote"] {
    border-left: 4px solid var(--color-primary, #2f4089);
    padding-left: 1.5rem;
    margin-left: 0;
    font-size: 1.1rem;
    font-style: italic;
    color: #555;
}

/* ============================================
   ANIMATIONS & MICRO-INTERACTIONS
   ============================================ */

/* Define fade-in animation */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInSlideLeft {
    from {
        opacity: 0;
        transform: translateX(-30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.7;
    }
}

/* Hero section title animation */
.aca-hero-content h1 {
    animation: fadeInUp 0.8s ease-out;
}

.aca-hero-content h1 + p {
    animation: fadeInUp 0.8s ease-out 0.2s both;
}

.aca-hero-content .cc-btn {
    animation: fadeInUp 0.8s ease-out 0.4s both;
}

/* Staggered animation for feature cards */
.aca-feature-grid .cc-card {
    animation: fadeInUp 0.6s ease-out;
}

.aca-feature-grid .cc-card:nth-child(2) {
    animation-delay: 0.1s;
}

.aca-feature-grid .cc-card:nth-child(3) {
    animation-delay: 0.2s;
}

.aca-feature-grid .cc-card:nth-child(n+4) {
    animation-delay: 0.3s;
}

/* Smooth transitions for interactive elements */
.aca-stats-strip .aca-stat-block h3 {
    transition: color 0.3s ease;
}

.aca-stats-strip .aca-stat-block:hover h3 {
    color: var(--color-primary, #2f4089);
}

/* Carousel auto-play smooth motion */
.swiper-slide {
    transition: transform 0.3s ease;
}

/* Testimonial slide-in animation */
.aca-testimonial {
    animation: fadeInUp 0.8s ease-out;
}

/* Blog and event cards staggered animation */
.aca-blog-grid article {
    animation: fadeInUp 0.6s ease-out;
}

.aca-blog-grid article:nth-child(2) {
    animation-delay: 0.1s;
}

.aca-blog-grid article:nth-child(3) {
    animation-delay: 0.2s;
}

/* CTA banner entrance animation */
.aca-cta-banner {
    animation: fadeInUp 0.8s ease-out;
}

/* Smooth button transitions */
.cc-btn,
.elementor-button {
    transition: all 0.3s ease;
}

/* Button hover lift effect */
.cc-btn:hover,
.elementor-button:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(47, 64, 137, 0.2);
}

/* Mobile animation adjustments */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Reduce animations on lower-end devices */
@media (max-width: 768px) {
    .aca-hero-content h1,
    .aca-feature-grid .cc-card,
    .aca-testimonial,
    .aca-blog-grid article {
        animation-duration: 0.5s;
    }
}

/* ============================================
   OUR IMPACT SECTION - TWO COLUMN LAYOUT
   ============================================ */

.our-impact-section {
    /* Section already has inline styles, this provides fallbacks */
}

/* Hover effect for stats table rows */
.our-impact-section .impact-two-column > div:last-child > div:hover {
    background-color: var(--color-bg-alt, #f4f6fb);
}

/* Responsive adjustments - stack to single column on mobile */
@media (max-width: 992px) {
    .impact-two-column {
        grid-template-columns: 1fr !important;
        gap: 2rem !important;
    }
}

@media (max-width: 768px) {
    .impact-two-column {
        gap: 2rem !important;
    }

    .our-impact-section .impact-two-column > div:last-child > div {
        grid-template-columns: 1fr !important;
        gap: 0.5rem !important;
        padding: 1.25rem 1.5rem !important;
        text-align: left !important;
    }

    .our-impact-section .impact-two-column > div:last-child > div > div:last-child {
        text-align: left !important;
    }

    .our-impact-section .impact-two-column > div:last-child > div h3 {
        font-size: 1rem !important;
    }

    .our-impact-section .impact-two-column > div:last-child > div span {
        font-size: 1.125rem !important;
    }
}

/* ============================================
   SERVICE CARDS SECTION - RESPONSIVE
   ============================================ */

/* Services section container */
.services-section {
    background: var(--color-bg-section);
    padding: var(--spacing-3xl) 0;
}

.services-section .section-header {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
}

.services-section .section-header h2 {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
}

.services-section .section-header p {
    font-size: var(--font-size-lg);
    color: var(--color-text-muted);
}

.services-section .cc-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xl);
}

.services-section .agency-services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--spacing-lg);
}

/* Service card hover effects */
.services-section .service-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-hover, 0 8px 24px rgba(47, 64, 137, 0.25)) !important;
    border-color: var(--color-primary, #2f4089) !important;
}

/* Service card link hover effect */
.services-section .service-card a:hover {
    gap: 0.75rem !important;
}

/* Responsive grid for service cards */
@media (max-width: 992px) {
    .services-section > .container > div:last-child {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    }
}

@media (max-width: 768px) {
    .services-section > .container > div:last-child {
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
    }

    .services-section .service-card > div:first-child {
        height: 180px !important;
    }

.services-section .service-card h3 {
    font-size: 1.25rem !important;
}
}

/* ============================================
   SINGLE AGENCY LAYOUT SAFEGUARDS
   ============================================ */
.single-agency .agency-content .cc-container {
    max-width: var(--container-xl);
    margin: 0 auto;
}

.single-agency .content-wrapper {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 350px);
    gap: var(--spacing-2xl);
    align-items: start;
}

.single-agency .services-section {
    background: var(--color-bg-section);
}

.single-agency .services-section .cc-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xl);
}

.single-agency .services-section .agency-services-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
}

.single-agency .content-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.single-agency .sidebar-card {
    background: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-sm);
    padding: var(--spacing-lg);
}

.single-agency .content-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.single-agency .sidebar-card {
    background: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-sm);
    padding: var(--spacing-lg);
}

/* ============================================
   PARTNER MARQUEE COMPONENT
   ============================================ */

/* Marquee Animation */
@keyframes partner-marquee-scroll {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

/* Partner Logos Marquee Container */
.partner-logos-marquee {
    position: relative;
    overflow: hidden;
    padding: 0;
    margin: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/* Dark variant (default) */
.partner-marquee--dark {
    background: linear-gradient(135deg, #2f4089 0%, #202c63 100%);
    padding: 3rem 0;
}

/* Light variant */
.partner-marquee--light {
    background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
    border-top: 1px solid rgba(47, 64, 137, 0.1);
    border-bottom: 1px solid rgba(47, 64, 137, 0.1);
    padding: 3rem 0;
}

/* Optional title header */
.partner-marquee-header {
    text-align: center;
    padding: 2rem 2rem 1rem;
}

.partner-marquee-title {
    font-size: 2rem;
    font-weight: 700;
    margin: 0;
}

.partner-marquee--dark .partner-marquee-title {
    color: #ffffff;
}

.partner-marquee--light .partner-marquee-title {
    color: #2f4089;
}

/* Marquee wrapper with animation */
.partner-marquee-wrapper {
    display: flex;
    width: fit-content;
    animation: partner-marquee-scroll 260s linear infinite;
}

/* Marquee track */
.partner-marquee-track {
    display: flex;
    gap: 4rem;
    align-items: center;
    flex-shrink: 0;
    padding: 2rem 0;
}

/* Individual logo item */
.partner-marquee-logo-item {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 120px;
    width: auto;
    flex-shrink: 0;
    opacity: 0.9;
    transition: opacity 0.3s ease;
    padding: 0 1rem;
}

/* Logo image */
.partner-marquee-logo-item img {
    height: 120px;
    width: auto;
    max-width: 200px;
    object-fit: contain;
    transition: all 0.3s ease;
}

/* Specific fix for Sacramento Food Bank logo */
.partner-marquee-logo-item img[src*="Sacramento-Food-Bank"] {
    max-width: 500px !important;
    width: auto !important;
    height: 100% !important;
    transform: scale(1.4);
}

/* Dark variant logo styling */
.partner-marquee--dark .partner-marquee-logo-item img {
    filter: brightness(0) invert(1) opacity(0.85);
}

/* Light variant logo styling */
.partner-marquee--light .partner-marquee-logo-item img {
    filter: grayscale(100%) opacity(0.7);
}

/* Hover effects */
.partner-marquee-logo-item:hover {
    opacity: 1;
}

.partner-marquee--dark .partner-marquee-logo-item:hover img {
    filter: brightness(0) invert(1) opacity(1);
    transform: scale(1.05);
}

.partner-marquee--light .partner-marquee-logo-item:hover img {
    filter: grayscale(0%) opacity(1);
    transform: scale(1.05);
}

/* Edge blur effects */
.partner-marquee-edge-blur {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 120px;
    z-index: 2;
    pointer-events: none;
}

/* Dark variant edge blur */
.partner-marquee--dark .partner-marquee-edge-left {
    left: 0;
    background: linear-gradient(to right, #2f4089 0%, rgba(47, 64, 137, 0.9) 50%, transparent 100%);
}

.partner-marquee--dark .partner-marquee-edge-right {
    right: 0;
    background: linear-gradient(to left, #202c63 0%, rgba(32, 44, 99, 0.9) 50%, transparent 100%);
}

/* Light variant edge blur */
.partner-marquee--light .partner-marquee-edge-left {
    left: 0;
    background: linear-gradient(to right, #f8fafc 0%, rgba(248, 250, 252, 0.9) 50%, transparent 100%);
}

.partner-marquee--light .partner-marquee-edge-right {
    right: 0;
    background: linear-gradient(to left, #ffffff 0%, rgba(255, 255, 255, 0.9) 50%, transparent 100%);
}

/* Partner Marquee Responsive Styles */
@media (max-width: 768px) {
    /* Adjust header padding */
    .partner-marquee-header {
        padding: 1.5rem 1rem 0.75rem;
    }

    .partner-marquee-title {
        font-size: 1.5rem;
    }

    /* Adjust marquee track */
    .partner-marquee-track {
        gap: 2rem;
        padding: 1.5rem 0;
    }

    /* Smaller logo items */
    .partner-marquee-logo-item {
        height: 60px;
        padding: 0 0.5rem;
    }

    .partner-marquee-logo-item img {
        height: 60px;
        max-width: 120px;
    }

    /* Faster animation on mobile */
    .partner-marquee-wrapper {
        animation-duration: 200s;
    }

    /* Narrower edge blur */
    .partner-marquee-edge-blur {
        width: 60px;
    }
}

/* ==========================
   WIDGETS
   ========================== */

/* Source: widgets/testimonial-carousel.css */
/* Testimonial Carousel Widget */
.cc-testimonial-carousel {
    width: 100%;
}

.cc-testimonials-container {
    position: relative;
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    overflow: hidden;
    border-radius: 8px;
}

.cc-testimonials-wrapper {
    display: flex;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.cc-testimonial-item {
    flex: 0 0 100%;
    padding: 3rem 2rem;
    background: linear-gradient(135deg, var(--color-primary, #2f4089) 0%, #202c63 100%);
    color: #ffffff;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 300px;
}

.cc-testimonial-quote {
    font-size: 1.25rem;
    font-style: italic;
    margin-bottom: 1.5rem;
    line-height: 1.8;
    position: relative;
    max-width: 600px;
}

.cc-testimonial-quote::before {
    content: '"';
    font-size: 4rem;
    position: absolute;
    top: -1rem;
    left: -0.5rem;
    opacity: 0.3;
    line-height: 1;
}

.cc-testimonial-author {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.cc-testimonial-avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid #ffffff;
    flex-shrink: 0;
}

.cc-testimonial-author-info {
    text-align: center;
}

.cc-testimonial-author-name {
    font-weight: 600;
    font-size: 1.1rem;
    display: block;
}

.cc-testimonial-author-role {
    font-size: 0.9rem;
    opacity: 0.9;
    display: block;
}

.cc-carousel-controls {
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin-top: 2rem;
}

.cc-carousel-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: #ddd;
    cursor: pointer;
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.cc-carousel-dot.active {
    background-color: var(--color-primary, #2f4089);
    border-color: var(--color-primary, #2f4089);
}

.cc-carousel-dot:hover {
    border-color: var(--color-primary, #2f4089);
}

@media (max-width: 768px) {
    .cc-testimonial-item {
        padding: 2rem 1.5rem;
        min-height: 280px;
    }

    .cc-testimonial-quote {
        font-size: 1rem;
    }

    .cc-testimonial-quote::before {
        font-size: 3rem;
        top: -0.5rem;
        left: -0.25rem;
    }

    .cc-testimonial-avatar {
        width: 60px;
        height: 60px;
    }

    .cc-testimonial-author-name {
        font-size: 1rem;
    }

    .cc-testimonial-author-role {
        font-size: 0.85rem;
    }
}

/* Source: widgets/team-member.css */
/* Team Member Widget */
.cc-team-members {
    width: 100%;
}

.cc-team-grid {
    display: grid;
    grid-template-columns: repeat(var(--cc-columns, 3), 1fr);
    gap: var(--gap, 2rem);
    width: 100%;
}

.cc-team-card {
    background-color: #ffffff;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    text-align: center;
}

.cc-team-card:hover {
    box-shadow: 0 8px 24px rgba(47, 64, 137, 0.15);
    transform: translateY(-4px);
}

.cc-team-photo {
    width: 100%;
    height: 280px;
    object-fit: cover;
    display: block;
    background-color: #f0f0f0;
}

.cc-team-info {
    padding: 1.5rem;
}

.cc-team-name {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
    color: var(--color-heading, #333);
}

.cc-team-title {
    font-size: 0.9rem;
    color: var(--color-primary, #2f4089);
    font-weight: 500;
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.03em; /* 0.5px converted to em */
}

.cc-team-bio {
    font-size: 0.9rem;
    color: var(--color-text-muted, #666);
    line-height: 1.6;
    margin-bottom: 1.5rem;
}

.cc-team-contact {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding-top: 1rem;
    border-top: 1px solid #e0e0e0;
}

.cc-team-contact-item {
    font-size: 0.85rem;
}

.cc-team-contact-item a {
    color: var(--color-primary, #2f4089);
    text-decoration: none;
    transition: color 0.3s ease;
}

.cc-team-contact-item a:hover {
    text-decoration: underline;
}

/* Grid column variations */
@media (max-width: 1024px) {
    .cc-team-grid {
        --cc-columns: 2;
    }
}

@media (max-width: 768px) {
    .cc-team-grid {
        --cc-columns: 1;
        gap: 1.5rem;
    }

    .cc-team-photo {
        height: 250px;
    }

    .cc-team-info {
        padding: 1.25rem;
    }

    .cc-team-name {
        font-size: 1.1rem;
    }
}

/* Source: widgets/agency-map.css */
/* Agency Map Widget */
.cc-agency-map {
    width: 100%;
}

.cc-map-header {
    margin-bottom: 2rem;
    text-align: center;
}

.cc-map-title {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 1rem;
    color: var(--color-heading, #333);
}

.cc-map-description {
    font-size: 1rem;
    color: var(--color-text-muted, #666);
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.6;
}

.cc-map-container {
    width: 100%;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.cc-map-wrapper {
    width: 100%;
}

.cc-map-wrapper iframe {
    width: 100%;
    border: none;
    display: block;
}

.cc-directory-wrapper {
    margin-top: 2rem;
    padding: 2rem;
    background-color: #f9f9f9;
    border-radius: 8px;
}

.cc-directory-columns-1 {
    display: grid;
    grid-template-columns: 1fr;
}

.cc-directory-columns-2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}

.cc-directory-columns-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.cc-directory-item {
    padding: 1.5rem;
    background-color: #ffffff;
    border-radius: 6px;
    border-left: 4px solid var(--color-primary, #2f4089);
}

.cc-directory-item-name {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
    color: var(--color-heading, #333);
}

.cc-directory-item-location {
    font-size: 0.9rem;
    color: var(--color-text-muted, #666);
    margin-bottom: 1rem;
}

.cc-directory-item-contact {
    font-size: 0.85rem;
}

.cc-directory-item-contact a {
    color: var(--color-primary, #2f4089);
    text-decoration: none;
    transition: color 0.3s ease;
}

.cc-directory-item-contact a:hover {
    text-decoration: underline;
}

@media (max-width: 1024px) {
    .cc-directory-columns-3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .cc-map-title {
        font-size: 1.5rem;
    }

    .cc-map-description {
        font-size: 0.9rem;
    }

    .cc-directory-columns-2,
    .cc-directory-columns-3 {
        grid-template-columns: 1fr;
    }

    .cc-directory-wrapper {
        padding: 1.5rem;
    }

    .cc-directory-item {
        padding: 1rem;
    }
}

/* Source: widgets/donation-form.css */
/* Donation Form Widget */
.cc-donation-form {
    max-width: 600px;
    margin: 0 auto;
}

.cc-donation-title {
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: 1rem;
    color: var(--color-heading, #333);
}

.cc-donation-description {
    font-size: 1rem;
    color: var(--color-text-muted, #666);
    margin-bottom: 2rem;
    line-height: 1.6;
}

.cc-donation-section {
    margin-bottom: 2rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid #e0e0e0;
}

.cc-donation-section:last-of-type {
    border-bottom: none;
}

.cc-section-label {
    display: block;
    font-weight: 600;
    font-size: 0.95rem;
    margin-bottom: 1rem;
    color: var(--color-heading, #333);
}

.cc-preset-amounts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.cc-preset-amount {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    border: 2px solid var(--color-primary, #2f4089);
    background-color: transparent;
    color: var(--color-primary, #2f4089);
    border-radius: 6px;
    cursor: pointer;
    font-size: 1.25rem;
    font-weight: 600;
    transition: all 0.3s ease;
}

.cc-preset-amount:hover {
    background-color: var(--color-primary, #2f4089);
    color: #ffffff;
}

.cc-preset-amount.active {
    background-color: var(--color-primary, #2f4089);
    color: #ffffff;
}

.cc-preset-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    margin-top: 0.5rem;
    opacity: 0.9;
}

.cc-custom-amount-wrapper {
    margin-top: 1.5rem;
}

.cc-custom-amount-wrapper label {
    display: block;
    font-size: 0.9rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
    color: var(--color-heading, #333);
}

.cc-custom-amount {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 1rem;
    transition: border-color 0.3s ease;
}

.cc-custom-amount:focus {
    outline: none;
    border-color: var(--color-primary, #2f4089);
    box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

.cc-donation-purposes {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.cc-purpose-option {
    display: flex;
    align-items: flex-start;
    cursor: pointer;
    padding: 1rem;
    border-radius: 6px;
    border: 1px solid #e0e0e0;
    transition: all 0.3s ease;
}

.cc-purpose-option:hover {
    border-color: var(--color-primary, #2f4089);
    background-color: rgba(47, 64, 137, 0.05);
}

.cc-purpose-option input[type="radio"] {
    margin-top: 0.25rem;
    margin-right: 1rem;
    accent-color: var(--color-primary, #2f4089);
    cursor: pointer;
}

.cc-purpose-text {
    flex: 1;
}

.cc-purpose-text strong {
    display: block;
    margin-bottom: 0.25rem;
    color: var(--color-heading, #333);
}

.cc-purpose-text small {
    display: block;
    font-size: 0.85rem;
    color: var(--color-text-muted, #666);
    line-height: 1.5; /* Fixed from 1.4 to meet WCAG 1.4.12 minimum */
}

.cc-recurring-option {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-weight: 500;
}

.cc-recurring-option input[type="checkbox"] {
    margin-right: 0.75rem;
    accent-color: var(--color-primary, #2f4089);
    cursor: pointer;
}

.cc-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 1rem;
}

.cc-form-input {
    padding: 0.75rem;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 1rem;
    font-family: inherit;
    transition: border-color 0.3s ease;
}

.cc-form-input:focus {
    outline: none;
    border-color: var(--color-primary, #2f4089);
    box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

.cc-form-input::placeholder {
    color: #999;
}

.cc-donate-btn {
    width: 100%;
    padding: 1rem 1.5rem;
    background-color: var(--color-primary, #2f4089);
    color: #ffffff;
    font-size: 1rem;
    font-weight: 600;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: 1.5rem;
}

.cc-donate-btn:hover {
    background-color: darken(var(--color-primary), 10%);
    transform: translateY(-2px);
    box-shadow: 0 8px 16px rgba(47, 64, 137, 0.2);
}

@media (max-width: 768px) {
    .cc-form-row {
        grid-template-columns: 1fr;
    }

    .cc-preset-amounts {
        grid-template-columns: repeat(2, 1fr);
    }

    .cc-donation-title {
        font-size: 1.5rem;
    }
}

/* Source: widgets/impact-stats.css */
/* Impact Stats Widget */
.cc-impact-stats {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap, 2rem);
    justify-content: center;
}

.cc-stat-item {
    flex: 1;
    min-width: 150px;
    max-width: 300px;
}

.cc-stat-icon {
    margin-bottom: 1rem;
    display: block;
}

.cc-stat-value {
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1.1;
    margin: 0;
    display: inline;
}

.cc-stat-suffix {
    font-size: 1.5rem;
    font-weight: 600;
    margin-left: 0.25rem;
}

.cc-stat-label {
    font-size: 0.95rem;
    font-weight: 500;
    margin-top: 0.5rem;
    display: block;
}

@media (max-width: 768px) {
    .cc-impact-stats {
        gap: 1.5rem;
    }

    .cc-stat-item {
        flex: 0 1 calc(50% - 0.75rem);
    }

    .cc-stat-value {
        font-size: 1.75rem;
    }
}

/* Source: widgets/service-cards.css */
/* Service Card Grid Widget */
.cc-service-cards {
    width: 100%;
}

.cc-service-grid-header {
    margin-bottom: 3rem;
    text-align: center;
}

.cc-service-grid-title {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 1rem;
    color: var(--color-heading, #333);
}

.cc-service-grid-description {
    font-size: 1rem;
    color: var(--color-text-muted, #666);
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.6;
}

.cc-service-grid {
    display: grid;
    grid-template-columns: repeat(var(--cc-columns, 3), 1fr);
    gap: var(--gap, 2rem);
    width: 100%;
}

.cc-service-card {
    padding: 2rem;
    background-color: var(--card-bg, #ffffff);
    border-radius: 8px;
    border: 1px solid #e0e0e0;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    text-align: center;
}

.cc-service-card:hover {
    border-color: var(--color-primary, #2f4089);
    box-shadow: 0 8px 24px rgba(47, 64, 137, 0.15);
    transform: translateY(-4px);
}

.cc-service-icon {
    margin: 0 auto 1rem;
    font-size: 3rem;
    color: var(--icon-color, var(--color-primary, #2f4089));
    display: block;
}

.cc-service-title {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
    color: var(--color-heading, #333);
}

.cc-service-description {
    font-size: 0.95rem;
    color: var(--color-text-muted, #666);
    line-height: 1.6;
    margin-bottom: 1.5rem;
    flex: 1;
}

.cc-service-button {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    background-color: var(--color-primary, #2f4089);
    color: #ffffff;
    text-decoration: none;
    border-radius: 6px;
    font-weight: 500;
    font-size: 0.9rem;
    transition: all 0.3s ease;
    border: none;
    cursor: pointer;
}

.cc-service-button:hover {
    background-color: darken(var(--color-primary), 10%);
    box-shadow: 0 4px 12px rgba(47, 64, 137, 0.2);
    transform: translateY(-2px);
}

/* Grid column variations */
@media (min-width: 1200px) {
    .cc-service-grid {
        --cc-columns: 3;
    }
}

@media (max-width: 1024px) {
    .cc-service-grid {
        --cc-columns: 2;
    }

    .cc-service-card {
        padding: 1.5rem;
    }
}

@media (max-width: 768px) {
    .cc-service-grid {
        --cc-columns: 1;
        gap: 1.5rem;
    }

    .cc-service-grid-title {
        font-size: 1.5rem;
    }

    .cc-service-card {
        padding: 1.5rem;
    }

    .cc-service-icon {
        font-size: 2.5rem;
    }
}

/* ==========================
   FEATURE / PAGE LAYOUTS
   ========================== */

/* Source: agency-finder.css */
/**
 * Agency Finder Styles (Refactored Phase 9)
 * Uses design tokens and BEM naming conventions
 * Consolidated from agency-finder.css + agency-finder-modal.css
 *
 * Component: Agency Finder Tool
 * Purpose: Interactive tool for users to find nearest Catholic Charities agencies
 * Design Tokens: All colors, spacing, and typography use CSS variables
 */

.cc-agency-finder {
  max-width: var(--container-max-width, 1200px);
  margin: 0 auto;
  padding: var(--spacing-lg) var(--spacing-md);
}

.agency-finder-header {
    text-align: center;
    margin-bottom: 3rem;
}

.agency-finder-header h2 {
    font-size: 2.5rem;
    color: var(--color-primary, #003A70);
    margin-bottom: 1rem;
    font-weight: 700;
}

.agency-finder-header p {
    font-size: 1.125rem;
    color: #666;
    max-width: 600px;
    margin: 0 auto;
}

/* Location Methods */
.cc-agency-finder__actions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.cc-location-method {
    background: white;
    border: 2px solid var(--color-border-light, #e0e0e0);
    border-radius: var(--border-radius-lg, 12px);
    padding: var(--spacing-xl);
    text-align: center;
    transition: all var(--transition-speed, 0.3s) ease;
}

.cc-location-method:hover {
    border-color: var(--color-primary, #2f4089);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.cc-location-method--primary {
    border-color: var(--color-primary, #2f4089);
    background: linear-gradient(135deg, rgba(47, 64, 137, 0.05) 0%, white 100%);
}

.cc-location-method__icon {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--spacing-lg);
    background: var(--color-primary, #2f4089);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 2rem;
}

.cc-location-method--secondary .cc-location-method__icon {
    background: var(--color-text-secondary, #666);
}

.cc-location-method h3 {
    font-size: var(--text-lg, 1.5rem);
    color: var(--color-text-primary, #333);
    margin-bottom: var(--spacing-sm);
    font-weight: 600;
}

.cc-location-method p {
    color: var(--color-text-secondary, #666);
    margin-bottom: var(--spacing-lg);
    line-height: var(--line-height-relaxed, 1.6);
}

/* Buttons */
.cc-agency-finder .cc-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: 0.75rem 1.5rem;
    font-size: var(--text-base, 1rem);
    font-weight: 600;
    text-decoration: none;
    border: none;
    border-radius: var(--border-radius-md, 8px);
    cursor: pointer;
    transition: all var(--transition-speed, 0.3s) ease;
    line-height: 1.5;
.cc-agency-finder .cc-btn--large {
    padding: var(--spacing-lg) var(--spacing-xl);
    font-size: var(--text-lg, 1.125rem);
}

.cc-agency-finder .cc-btn--primary {
    background: var(--color-primary, #2f4089);
    color: white;
}

.cc-agency-finder .cc-btn--primary:hover {
    background: #1f2d60;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(47, 64, 137, 0.3);
}

.cc-agency-finder .cc-btn--secondary {
    background: var(--color-text-secondary, #666);
    color: white;
}

.cc-agency-finder .cc-btn--secondary:hover {
    background: #555;
}

.cc-agency-finder .cc-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none !important;
}

/* Manual Location Form */
.cc-agency-finder__form {
    max-width: 400px;
    margin: 0 auto;
}

.cc-agency-finder__form-group {
    display: flex;
    gap: var(--spacing-sm);
}

.cc-agency-finder__form-group input[type="text"] {
    flex: 1;
    padding: 0.75rem var(--spacing-md);
    font-size: var(--text-base, 1rem);
    border: 2px solid var(--color-border-light, #ddd);
    border-radius: var(--border-radius-md, 8px);
    transition: border-color var(--transition-speed, 0.3s) ease;
}

.cc-agency-finder__form-group input[type="text"]:focus {
    outline: none;
    border-color: var(--color-primary, #2f4089);
}

.cc-agency-finder__form-group button {
    padding: 0.75rem var(--spacing-lg);
    white-space: nowrap;
}

/* Status Messages */
.cc-agency-finder__status {
    margin: var(--spacing-xl) 0;
    padding: var(--spacing-lg);
    border-radius: var(--border-radius-md, 8px);
    text-align: center;
    font-size: var(--text-lg, 1.125rem);
}

.cc-agency-finder__status--loading {
    background: #e3f2fd;
    color: #1565c0;
    border: 2px solid #90caf9;
}

.cc-agency-finder__status--success {
    background: #e8f5e9;
    color: #2e7d32;
    border: 2px solid #81c784;
}

.cc-agency-finder__status--error {
    background: #ffebee;
    color: #c62828;
    border: 2px solid #ef5350;
}

.cc-agency-finder__status p {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.cc-agency-finder__status i {
    font-size: var(--text-lg, 1.5rem);
}

/* Results Section */
.cc-agency-finder__results {
    margin-top: var(--spacing-2xl);
}

.cc-agency-finder__results-header {
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

.cc-agency-finder__results-header h3 {
    font-size: clamp(1.5rem, 4vw, 2rem);
    color: var(--color-primary, #2f4089);
    margin-bottom: var(--spacing-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.cc-agency-finder__results-header p {
    color: var(--color-text-secondary, #666);
    font-size: var(--text-lg, 1.125rem);
}

/* Agency Result Cards */
.cc-agency-finder__list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.cc-agency-result {
    background: white;
    border: 2px solid var(--color-border-light, #e0e0e0);
    border-radius: var(--border-radius-lg, 12px);
    padding: var(--spacing-xl);
    display: flex;
    gap: var(--spacing-lg);
    position: relative;
    transition: all var(--transition-speed, 0.3s) ease;
}

.cc-agency-result:hover {
    border-color: var(--color-primary, #2f4089);
    box-shadow: 0 4px 16px rgba(47, 64, 137, 0.1);
    transform: translateY(-2px);
}

.cc-agency-result--closest {
    border-color: #ffa726;
    background: linear-gradient(135deg, rgba(255, 167, 38, 0.05) 0%, white 100%);
    border-width: 3px;
}

.cc-agency-result__badge {
    position: absolute;
    top: -12px;
    right: 20px;
    background: #ffa726;
    color: white;
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    box-shadow: 0 2px 8px rgba(255, 167, 38, 0.3);
}

.cc-agency-result__rank {
    flex-shrink: 0;
    width: 50px;
    height: 50px;
    background: var(--color-primary, #2f4089);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 700;
}

.cc-agency-result--closest .cc-agency-result__rank {
    background: #ffa726;
}

.cc-agency-result__content {
    flex: 1;
}

.cc-agency-result__title {
    font-size: var(--text-lg, 1.5rem);
    color: var(--color-text-primary, #333);
    margin-bottom: var(--spacing-md);
    font-weight: 600;
}

.cc-agency-result__info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.cc-agency-result__info-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--color-text-secondary, #666);
    font-size: var(--text-base, 1rem);
}

.cc-agency-result__info-item--address {
    grid-column: 1 / -1;
}

.cc-agency-result__info-item i {
    color: var(--color-primary, #2f4089);
    font-size: var(--text-lg, 1.125rem);
    flex-shrink: 0;
}

.cc-agency-result__actions {
    display: flex;
    gap: var(--spacing-md);
    flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 768px) {
    .cc-agency-finder__header h2 {
        font-size: clamp(1.5rem, 5vw, 2rem);
    }

    .cc-agency-finder__actions {
        grid-template-columns: 1fr;
    }

    .cc-location-method__icon {
        width: 60px;
        height: 60px;
        font-size: 1.5rem;
    }

    .cc-agency-finder__form-group {
        flex-direction: column;
    }

    .cc-agency-result {
        flex-direction: column;
        padding: var(--spacing-lg);
    }

    .cc-agency-result__rank {
        width: 40px;
        height: 40px;
        font-size: 1.25rem;
    }

    .cc-agency-result__badge {
        position: static;
        margin-bottom: var(--spacing-md);
        align-self: flex-start;
    }

    .cc-agency-result__info {
        grid-template-columns: 1fr;
    }

    .cc-agency-result__actions {
        flex-direction: column;
    }

    .cc-btn {
        width: 100%;
        justify-content: center;
    }
}

/* Loading spinner animation */
@keyframes cc-spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

.fa-spinner {
    animation: cc-spin 1s linear infinite;
}

/* Accessibility */
.cc-btn:focus,
.cc-agency-finder__form-group input:focus {
    outline: 3px solid rgba(47, 64, 137, 0.3);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Source: california-map.css */
/**
 * California Agencies Map Styles
 */

.california-map-container {
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
    padding: 40px 20px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
}

/* Override Elementor/theme container restrictions */
.site-main .california-map-container,
.elementor-section .california-map-container {
    max-width: 100% !important;
    width: 100% !important;
}

.site-main .california-map-wrapper,
.elementor-section .california-map-wrapper {
    display: flex !important;
    flex-direction: row !important;
}

.california-map-header {
    text-align: center;
    margin-bottom: 40px;
}

.california-map-header h2 {
    font-size: 2.5rem;
    color: #0066cc;
    margin-bottom: 10px;
    font-weight: 700;
}

.map-subtitle {
    color: #666;
    font-size: 1.1rem;
    margin: 0;
}

.california-map-wrapper {
    position: relative;
    background: var(--color-bg-alt, #f4f6fb);
    border-radius: var(--border-radius-xl, 16px);
    padding: 40px;
    box-shadow: var(--shadow-lg, 0 10px 40px rgba(0, 0, 0, 0.1));
    margin-bottom: 60px;
    display: grid;
    gap: 32px;
    min-height: 560px;
    border: 1px solid var(--color-border-light, #e7ebf9);
}

.california-map-wrapper.has-detail-panel {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 400px);
    align-items: start;
}

.california-map-wrapper.california-map--no-detail,
.california-map-wrapper:not(.has-detail-panel) {
    grid-template-columns: minmax(0, 1fr);
}

.map-container {
    position: relative;
    width: 100%;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 520px;
}

.california-map-svg {
    width: 100%;
    height: auto;
    max-width: 100%;
    display: block;
    filter: drop-shadow(0 4px 6px rgba(0, 0, 0, 0.1));
}

.california-state {
    transition: all 0.3s ease;
}

.california-state:hover {
    fill: #d4e9f7;
}

/* Agency Markers */
.agency-marker {
    cursor: pointer;
    transition: all 0.3s ease;
}

.marker-circle {
    transition: all 0.3s ease;
}

.agency-marker:hover .marker-circle {
    r: 12;
    fill: #ff4757;
    filter: drop-shadow(0 0 8px rgba(220, 53, 69, 0.6));
}

.marker-pulse {
    animation: pulse 2s ease-out infinite;
    opacity: 0;
}

.agency-marker:hover .marker-pulse {
    animation: none;
}

.agency-marker.selected .marker-circle {
    r: 14;
    fill: #28a745;
    stroke-width: 3;
    filter: drop-shadow(0 0 12px rgba(40, 167, 69, 0.8));
}

.agency-marker.selected .marker-pulse {
    animation: none;
}

@keyframes pulse {
    0% {
        r: 8;
        opacity: 1;
        stroke-width: 2;
    }
    100% {
        r: 20;
        opacity: 0;
        stroke-width: 0;
    }
}

/* Detail Panel (always visible on right) */
.agency-detail-panel {
    width: 100%;
    max-width: 400px;
    background: #ffffff;
    border-radius: var(--border-radius-lg, 16px);
    padding: 0;
    box-shadow: var(--shadow-md, 0 10px 40px rgba(0, 0, 0, 0.15));
    border: 2px solid var(--cc-primary, #2f4089);
    max-height: 680px;
    overflow-y: auto;
    position: sticky;
    top: 24px;
    display: block;
}

/* Empty state (when no agency selected) */
.detail-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 60px 40px;
    min-height: 400px;
}

.detail-empty-state svg {
    color: #b0d4f1;
    margin-bottom: 24px;
    opacity: 0.5;
}

.detail-empty-state h4 {
    font-size: 1.4rem;
    color: #0066cc;
    font-weight: 700;
    margin: 0 0 12px 0;
}

.detail-empty-state p {
    font-size: 1rem;
    color: #666;
    margin: 0;
    line-height: 1.5;
}

/* Agency info container */
.detail-agency-info {
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.detail-panel-content {
    padding: 24px;
}

.detail-title {
    font-size: var(--font-size-2xl, 1.875rem);
    color: var(--cc-primary, #2f4089);
    font-weight: var(--font-weight-semibold, 600);
    margin: 0 0 24px 0;
    line-height: 1.3;
    padding-right: 40px;
}

.detail-section {
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid #e0e0e0;
}

.detail-section:last-of-type {
    border-bottom: none;
}

.detail-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: var(--font-weight-semibold, 600);
    color: #4c5473;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 8px;
}

.detail-label svg {
    color: #0066cc;
    flex-shrink: 0;
}

.detail-value {
    color: var(--color-text, #1f233a);
    font-size: 0.95rem;
    line-height: 1.6;
    padding-left: 26px;
}

.detail-address {
    font-style: normal;
}

.detail-website-link {
    color: #0066cc;
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
}

.detail-website-link:hover {
    color: #0052a3;
    text-decoration: underline;
}

.detail-actions {
    margin-top: 24px;
    padding-top: 20px;
    border-top: 2px solid #e3f2fd;
}

.detail-view-full-btn {
    display: block;
    background: var(--cc-primary, #2f4089);
    color: white !important;
    text-align: center;
    padding: 14px 24px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 700;
    transition: all 0.3s ease;
    font-size: 1rem;
}

.detail-view-full-btn:hover {
    background: var(--cc-primary-dark, #202c63);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 102, 204, 0.3);
}

/* Popup/Tooltip (Simplified) */
.agency-tooltip {
    position: absolute;
    background: #ffffff;
    border-radius: 12px;
    padding: 16px 20px;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
    max-width: 280px;
    z-index: var(--z-modal);
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity 0.2s ease, transform 0.2s ease;
    border: 2px solid var(--cc-primary, #2f4089);
    opacity: 0;
}

.agency-tooltip.show {
    display: block !important;
    opacity: 1;
    transform: translateY(0);
}

.tooltip-title {
    margin: 0 0 12px 0;
    font-size: 1.05rem;
    color: var(--cc-primary, #2f4089);
    font-weight: var(--font-weight-semibold, 600);
    line-height: 1.3;
}

.tooltip-content p {
    margin: 6px 0;
    font-size: 0.85rem;
    color: #333;
    line-height: 1.5;
    display: flex;
    gap: 6px;
}

.tooltip-content strong {
    color: #666;
    font-weight: 600;
}

.tooltip-content .location-text,
.tooltip-content .counties-text {
    color: #222;
    font-weight: 500;
}

.tooltip-action {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid #e0e0e0;
    text-align: center;
}

.tooltip-click-hint {
    color: var(--cc-primary, #2f4089);
    font-size: 0.75rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: #e3f2fd;
    border-radius: 12px;
}

/* Agency List */
.agencies-list {
    margin-top: 60px;
}

.agencies-list h3 {
    font-size: 2rem;
    color: #333;
    margin-bottom: 30px;
    text-align: center;
    font-weight: 700;
}

.california-map-wrapper .agencies-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
    margin-top: 30px;
}

@media (max-width: 1200px) {
    .california-map-wrapper .agencies-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .california-map-wrapper .agencies-grid {
        grid-template-columns: 1fr;
    }
}

.agency-card {
    background: #ffffff;
    border-radius: var(--border-radius-lg, 12px);
    padding: 25px;
    box-shadow: var(--shadow-sm, 0 4px 15px rgba(0, 0, 0, 0.08));
    transition: all 0.3s ease;
    border: 2px solid transparent;
    cursor: pointer;
}

.agency-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md, 0 8px 25px rgba(0, 102, 204, 0.15));
    border-color: var(--cc-primary, #2f4089);
}

.agency-card h4 {
    margin: 0 0 15px 0;
    font-size: 1.2rem;
    color: #0066cc;
    font-weight: 700;
    line-height: 1.3;
}

.agency-location {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #666;
    font-size: 0.95rem;
    margin: 10px 0;
}

.agency-location svg {
    color: #dc3545;
    flex-shrink: 0;
}

.agency-counties {
    color: #666;
    font-size: 0.9rem;
    margin: 10px 0;
    line-height: 1.5;
}

.agency-counties strong {
    color: #333;
}

.agency-link {
    display: inline-block;
    margin-top: 15px;
    padding: 10px 20px;
    background: var(--cc-primary, #2f4089);
    color: #ffffff;
    text-decoration: none;
    border-radius: 6px;
    font-weight: 600;
    transition: all 0.3s ease;
    font-size: 0.9rem;
}

.agency-link:hover {
    background: var(--cc-primary-dark, #202c63);
    transform: translateX(5px);
}

/* Responsive Design */
@media (max-width: 1200px) {
    .california-map-wrapper.has-detail-panel {
        grid-template-columns: minmax(0, 1fr);
    }
    
    .agency-detail-panel {
        position: relative;
        top: 0;
        max-width: 100%;
        max-height: none;
        order: initial;
    }
}

@media (max-width: 768px) {
    .california-map-container {
        padding: 20px 15px;
    }
    
    .california-map-header h2 {
        font-size: 1.8rem;
    }
    
    .map-subtitle {
        font-size: 1rem;
    }
    
    .california-map-wrapper {
        padding: 20px;
    }

    .california-map-wrapper .agencies-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .agency-tooltip {
        max-width: 280px;
        padding: 15px;
        font-size: 0.9rem;
    }
    
    .tooltip-title {
        font-size: 1.1rem;
    }
    
    .agency-detail-panel {
        max-height: 400px;
    }
    
    .detail-title {
        font-size: 1.3rem;
    }
}

/* Print Styles */
@media print {
    .agency-tooltip {
        display: none !important;
    }
    
    .california-map-wrapper {
        background: white;
        box-shadow: none;
    }
    
    .marker-pulse {
        display: none;
    }
}


/* Source: donate.css */
/**
 * Donate Page Styling (Refactored Phase 9)
 * Uses design tokens and BEM naming conventions
 *
 * Component: Donation Page
 * Purpose: Multi-step donation form with impact messaging
 * Design Tokens: All colors, spacing, and typography use CSS variables
 */

/* ============================================
   DONATION FORM STYLING
   ============================================ */

.cc-donate-form-wrapper {
    width: 100%;
}

.cc-donate-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.cc-donate-form__group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.cc-donate-form__row {
    display: flex;
    flex-direction: row;
    gap: var(--spacing-md);
    flex-wrap: wrap;
}

.cc-donate-form__row .cc-donate-form__group {
    flex: 1;
    min-width: 120px;
}

.cc-donate-form label {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text-primary, #1f233a);
    margin-bottom: var(--spacing-xs, 4px);
}

.cc-donate-form input[type="text"],
.cc-donate-form input[type="email"],
.cc-donate-form input[type="tel"],
.cc-donate-form textarea {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--text-base, 1rem);
    font-family: var(--font-family-base, 'Figtree', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif);
    color: var(--color-text-primary, #1f233a);
    background-color: white;
    border: 1px solid var(--color-border-light, #ddd);
    border-radius: var(--border-radius-md, 8px);
    transition: all var(--transition-speed, 0.3s) ease;
    box-sizing: border-box;
}

.cc-donate-form input[type="text"]:focus,
.cc-donate-form input[type="email"]:focus,
.cc-donate-form input[type="tel"]:focus,
.cc-donate-form textarea:focus {
    outline: none;
    border-color: var(--color-primary, #2f4089);
    box-shadow: 0 0 0 3px rgba(47, 64, 137, 0.1);
}

.cc-donate-form input[type="text"]::placeholder,
.cc-donate-form input[type="email"]::placeholder,
.cc-donate-form input[type="tel"]::placeholder,
.cc-donate-form textarea::placeholder {
    color: var(--color-text-muted, #5c6483);
    opacity: 0.6;
}

.cc-donate-form textarea {
    resize: vertical;
    min-height: 80px;
}

.cc-donate-form input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-right: var(--spacing-sm);
    cursor: pointer;
    accent-color: var(--color-primary, #2f4089);
}

.cc-donate-form label:has(input[type="checkbox"]) {
    display: flex;
    align-items: center;
    font-weight: 400;
    cursor: pointer;
    font-size: 0.9375rem;
    color: var(--color-text-secondary, #3d4668);
}

.cc-donate-form__note {
    font-size: 0.875rem;
    color: var(--color-text-muted, #5c6483);
    margin-top: var(--spacing-md);
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs, 6px);
}

.cc-donate-form__note i {
    color: var(--color-primary, #2f4089);
}

/* Donation Amount Input Styling */
.cc-donate__amount-input {
    font-size: var(--text-xl, 1.5rem) !important;
    font-weight: 600 !important;
    text-align: center !important;
    padding: var(--spacing-md) !important;
    border: 2px solid var(--color-primary, #2f4089) !important;
    color: var(--color-primary, #2f4089) !important;
    width: 100% !important;
    max-width: 260px;
    border-radius: var(--border-radius-md, 8px) !important;
}

.cc-donate__amount-input:focus {
    border-color: var(--color-primary, #2f4089) !important;
    box-shadow: 0 0 0 4px rgba(47, 64, 137, 0.15) !important;
}

/* ============================================
   QUICK DONATION AMOUNT BUTTONS
   ============================================ */

.cc-donate__amount-btn {
    min-width: 100px;
    padding: var(--spacing-sm) var(--spacing-lg) !important;
    font-size: var(--text-base, 1rem) !important;
    font-weight: 600 !important;
    transition: all var(--transition-speed, 0.3s) ease !important;
    background-color: white !important;
    color: var(--color-primary, #2f4089) !important;
    border: 2px solid var(--color-primary, #2f4089) !important;
    border-radius: 999px !important;
}

.cc-donate__amount-btn:hover {
    background-color: var(--color-primary, #2f4089) !important;
    color: white !important;
    border-color: var(--color-primary, #2f4089) !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(47, 64, 137, 0.25);
}

.cc-donate__amount-btn--active {
    background-color: var(--color-primary, #2f4089) !important;
    color: white !important;
    border-color: var(--color-primary, #2f4089) !important;
}

/* Amount selection card and other amount input */
.cc-donate__amount-card {
    padding: var(--spacing-2xl) var(--spacing-2xl) calc(var(--spacing-2xl) - 4px);
    border-radius: var(--border-radius-lg, 12px);
    box-shadow: 0 10px 30px rgba(32, 44, 99, 0.08);
    background-color: white;
    border: 1px solid #e0e5f5;
}

.cc-donate__amount-extra {
    width: 100%;
    max-width: 540px;
    text-align: center;
}

.cc-donate__amount-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text-primary, #1f233a);
    margin-bottom: var(--spacing-sm);
}

.cc-donate__amount-input-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    max-width: 320px;
    margin: 0 auto;
}

.cc-donate__amount-currency {
    font-size: var(--text-xl, 1.5rem);
    font-weight: 600;
    color: var(--color-primary, #2f4089);
}

.cc-donate__amount-note {
    font-size: 0.875rem;
    color: var(--color-text-muted, #5c6483);
    margin-top: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.cc-donate__continue-btn {
    width: 100%;
    max-width: 320px;
}

.cc-donate__hero-btn {
    margin-top: var(--spacing-md);
}

/* ============================================
   IMPACT MESSAGE SECTION
   ============================================ */

.cc-donate__impact-message {
    padding: 0;
}

.cc-donate__impact-list {
    margin-top: var(--spacing-xl);
}

.cc-donate__impact-item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid #e7ebf9;
}

.cc-donate__impact-item:last-child {
    border-bottom: none;
}

.cc-donate__impact-item i {
    font-size: var(--text-lg, 1.25rem);
    color: var(--color-primary, #2f4089);
    margin-top: 2px;
    flex-shrink: 0;
}

.cc-donate__impact-item strong {
    color: var(--color-heading, #202c63);
    font-weight: 600;
}

.cc-donate__trust-badge {
    margin-top: var(--spacing-2xl);
    padding: var(--spacing-lg);
    background: #f4f6fb;
    border-radius: var(--border-radius-md, 8px);
    border: 1px solid #e7ebf9;
}

.cc-donate__trust-badge h3 {
    font-size: var(--text-lg, 1.125rem);
    margin-bottom: var(--spacing-sm);
    color: var(--color-heading, #202c63);
    font-weight: 600;
}

.cc-donate__trust-badge p {
    font-size: 0.875rem;
    color: var(--color-text-muted, #5c6483);
    line-height: var(--line-height-relaxed, 1.65);
    margin-bottom: var(--spacing-md);
}

.cc-donate__trust-badge p:last-child {
    margin-bottom: 0;
}

.cc-donate__trust-badge strong {
    color: var(--color-text-primary, #1f233a);
    font-weight: 600;
}

/* ============================================
   OTHER WAYS TO GIVE CARDS
   ============================================ */

.cc-donate__other-ways-section .cc-card {
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: all var(--transition-speed, 0.3s) ease;
    min-height: 280px; /* Enforce minimum height for alignment */
}

.cc-donate__other-ways-section .cc-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(47, 64, 137, 0.15);
}

.cc-donate__other-ways-section .cc-card i {
    font-size: 2rem;
    color: var(--color-primary, #2f4089);
    margin-bottom: var(--spacing-md);
}

.cc-donate__other-ways-section .cc-card a {
    color: var(--color-primary, #2f4089);
    text-decoration: none;
    transition: color var(--transition-speed, 0.3s) ease;
}

.cc-donate__other-ways-section .cc-card a:hover {
    color: var(--color-heading, #202c63);
    text-decoration: underline;
}

/* ============================================
   RESPONSIVE DESIGN
   ============================================ */

@media (max-width: 768px) {
    .cc-donate-form__row {
        flex-direction: column;
    }

    .cc-donate-form__row .cc-donate-form__group {
        min-width: 100%;
    }

    .cc-donate__amount-btn {
        flex: 1;
        min-width: calc(50% - var(--spacing-sm));
    }

    .cc-donate__impact-item {
        flex-direction: column;
        gap: var(--spacing-sm);
    }

    .cc-donate__impact-item i {
        margin-top: 0;
    }
}

/* ============================================
   PAGE FLOW & SPACING IMPROVEMENTS
   ============================================ */

/* Remove excessive spacing between sections for better flow */
.donate-quick-amounts,
.cc-donate__quick-amounts {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.aca-stats-strip,
.cc-donate__stats-strip {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.donate-form-section,
.cc-donate__form-section {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.other-ways-to-give,
.cc-donate__other-ways-section {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

/* Smooth transitions between sections */
.aca-hero-v1,
.donate-quick-amounts,
.cc-donate__quick-amounts,
.aca-stats-strip,
.cc-donate__stats-strip,
.donate-form-section,
.cc-donate__form-section,
.other-ways-to-give,
.cc-donate__other-ways-section {
    transition: background-color var(--transition-speed, 0.3s) ease;
}

/* Better visual flow - ensure consistent container width */
.aca-hero-v1 .elementor-container,
.donate-quick-amounts .elementor-container,
.cc-donate__quick-amounts .elementor-container,
.aca-stats-strip .elementor-container,
.cc-donate__stats-strip .elementor-container,
.donate-form-section .elementor-container,
.cc-donate__form-section .elementor-container,
.other-ways-to-give .elementor-container,
.cc-donate__other-ways-section .elementor-container,
.aca-cta-banner .elementor-container {
    max-width: var(--container-max-width, 1200px);
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}

/* Backgrounds for key bands - matching style guide */
.aca-hero-v1 {
    background-color: white !important;
}

/* Quick amounts section - Aqua background from style guide */
.donate-quick-amounts,
.cc-donate__quick-amounts {
    background-color: var(--color-background, #eef2f9) !important;
    padding: 40px 0 80px 0 !important;
}

/* Unified white background for main content sections */
.donate-form-section,
.cc-donate__form-section {
    background-color: white !important;
    padding: 80px 0 !important;
}

.aca-stats-strip {
    background-color: var(--color-background, #eef2f9) !important;
    padding: 80px 0 !important;
}

.other-ways-to-give {
    background-color: white !important;
    padding: 80px 0 !important;
}

/* CTA Banner styling */
.aca-cta-banner {
    padding: 80px 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

/* Subtle separators and consistent vertical rhythm */
.aca-stats-strip {
    border-top: 1px solid #e7ebf9;
}

.donate-form-section,
.cc-donate__form-section {
    border-top: 1px solid #e7ebf9;
}

.other-ways-to-give {
    border-top: 1px solid #e7ebf9;
}

/* ============================================
   ANIMATIONS
   ============================================ */

@keyframes cc-fade-in-up {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.donate-quick-amounts,
.cc-donate__quick-amounts,
.donate-form-section,
.cc-donate__form-section,
.other-ways-to-give,
.cc-donate__other-ways-section {
    animation: cc-fade-in-up 0.6s ease-out;
}

/* Respect reduced motion preference */
@media (prefers-reduced-motion: reduce) {
    .donate-quick-amounts,
    .cc-donate__quick-amounts,
    .donate-form-section,
    .cc-donate__form-section,
    .other-ways-to-give,
    .cc-donate__other-ways-section,
    .cc-donate__amount-btn,
    .cc-donate-form input,
    .cc-donate-form textarea {
        animation: none !important;
        transition: none !important;
    }
}

/* ============================================
   ACCESSIBILITY
   ============================================ */

.cc-donate-form input:focus-visible,
.cc-donate-form textarea:focus-visible,
.cc-donate__amount-btn:focus-visible {
    outline: 2px solid var(--color-primary, #2f4089);
    outline-offset: 2px;
}

.cc-donate-form label:has(input[type="checkbox"]):focus-within {
    outline: 2px solid var(--color-primary, #2f4089);
    outline-offset: 2px;
    border-radius: var(--border-radius-sm, 4px);
}

/* ============================================
   DONATE PAGE LAYOUT TWEAKS
   ============================================ */

/* Body background for donate page - Aqua from style guide */
body.page-template-page-donate {
    background-color: var(--color-background, #eef2f9);
}

/* Force full-width layout for donate page */
.donate-page.site-main,
.cc-donate-page.site-main {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    background-color: var(--color-background, #eef2f9);
}

/* Hero alignment and spacing */
.cc-donate-page .aca-hero-v1 {
    padding-top: 80px !important;
    padding-bottom: 40px !important;
    width: 100% !important;
    max-width: 100% !important;
}

.cc-donate-page .aca-hero-v1 .aca-hero-content {
    text-align: center;
    max-width: 760px;
    margin: 0 auto;
}

.cc-donate-page .aca-hero-v1 .aca-hero-content h1 {
    font-size: clamp(2.25rem, 3vw, 2.75rem);
    line-height: 1.2;
    margin: 12px 0 16px;
}

.cc-donate-page .aca-hero-v1 .aca-hero-content .cc-text-primary {
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.875rem;
}

/* Donate hero background - solid blue gradient matching brand */
.cc-donate-page .aca-hero-v1 {
    background: linear-gradient(135deg, #0066cc 0%, #0052a3 100%);
    background-color: #0066cc;
    color: white;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.cc-donate-page .aca-hero-v1 .aca-hero-content h1,
.cc-donate-page .aca-hero-v1 .aca-hero-content p,
.cc-donate-page .aca-hero-v1 .aca-hero-content .cc-text-primary {
    color: white;
}

.cc-donate-page .aca-hero-v1 .aca-hero-content .cc-text-primary {
    opacity: 0.9;
}

/* Donate hero - header spacing similar to agency hero */
body.page-template-page-donate .aca-hero-v1 {
    margin-top: -100px !important;
    padding-top: 120px !important;
    padding-bottom: 40px !important;
    position: relative;
    z-index: 1;
}

/* Donate main - full-width content (match agency pages) */
body.page-template-page-donate .site-main.cc-donate-page {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

@media (max-width: 1024px) {
    body.page-template-page-donate .aca-hero-v1 {
        margin-top: -90px !important;
        padding-top: 110px !important;
        padding-bottom: 40px !important;
    }
}

@media (max-width: 767px) {
    body.page-template-page-donate .aca-hero-v1 {
        margin-top: -80px !important;
        padding-top: 100px !important;
        padding-bottom: 40px !important;
    }
}



/* Amount card layout */
.donation-amount-card,
.cc-donate__amount-card {
    max-width: 760px;
    margin: 0 auto;
    padding: 48px 40px;
    background-color: white;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(32, 44, 99, 0.08);
    border: 1px solid #e0e5f5;
}

.cc-donate__amount-card h2 {
    margin-bottom: var(--spacing-sm);
}

.cc-donate__amount-card .cc-donate__amount-buttons {
    margin-top: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

/* Form + impact two-column layout */
.donate-form-section .elementor-container,
.cc-donate__form-section .elementor-container {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-3xl, 48px);
    align-items: flex-start;
}

.donate-form-wrapper,
.cc-donate-form-wrapper {
    flex: 0 0 55% !important;
    max-width: 55% !important;
    min-width: 0;
}

.donate-impact-message h2,
.cc-donate__impact-message h2 {
    margin-bottom: var(--spacing-md);
    color: var(--color-heading, #202c63);
}

.donate-impact-message .impact-list,
.cc-donate__impact-message .impact-list {
    margin-top: var(--spacing-xl);
}

.donate-impact-message .impact-item,
.cc-donate__impact-message .impact-item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid #e7ebf9;
}

.donate-impact-message .impact-item:last-child,
.cc-donate__impact-message .impact-item:last-child {
    border-bottom: none;
}

.donate-impact-message .impact-item i,
.cc-donate__impact-message .impact-item i {
    font-size: var(--text-lg, 1.25rem);
    color: var(--color-primary, #2f4089);
    margin-top: 2px;
    flex-shrink: 0;
}

.donate-impact-message .impact-item strong,
.cc-donate__impact-message .impact-item strong {
    color: var(--color-heading, #202c63);
    font-weight: 600;
}

.donate-impact-message .trust-badge,
.cc-donate__impact-message .trust-badge {
    margin-top: var(--spacing-2xl);
    padding: var(--spacing-lg);
    background: #f4f6fb;
    border-radius: var(--border-radius-md, 8px);
    border: 1px solid #e7ebf9;
}

.donate-impact-message .trust-badge h3,
.cc-donate__impact-message .trust-badge h3 {
    font-size: var(--text-lg, 1.125rem);
    margin-bottom: var(--spacing-sm);
    color: var(--color-heading, #202c63);
    font-weight: 600;
}

.donate-impact-message .trust-badge p,
.cc-donate__impact-message .trust-badge p {
    font-size: 0.875rem;
    color: var(--color-text-muted, #5c6483);
    line-height: var(--line-height-relaxed, 1.65);
    margin-bottom: var(--spacing-md);
}

.donate-impact-message .trust-badge p:last-child,
.cc-donate__impact-message .trust-badge p:last-child {
    margin-bottom: 0;
}

.donate-impact-message .trust-badge strong,
.cc-donate__impact-message .trust-badge strong {
    color: var(--color-text-primary, #1f233a);
    font-weight: 600;
}

/* Stats grid */
.aca-stats-strip .aca-stat-block,
.cc-donate__stats-strip .aca-stat-block {
    flex: 1 1 220px;
    min-width: 200px;
    text-align: center;
}

.aca-stats-strip .aca-stat-block h3,
.cc-donate__stats-strip .aca-stat-block h3 {
    font-size: 2rem;
    margin-bottom: var(--spacing-xs, 4px);
}

.aca-stats-strip .aca-stat-block p,
.cc-donate__stats-strip .aca-stat-block p {
    margin: 0;
}

/* Responsive adjustments */
@media (max-width: 1024px) {
    .donate-form-section .elementor-container,
    .cc-donate__form-section .elementor-container {
        flex-direction: column;
    }

    .donate-form-wrapper,
    .cc-donate-form-wrapper,
    .donate-impact-message,
    .cc-donate__impact-message {
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }

    .other-ways-to-give .cc-card,
    .cc-donate__other-ways-section .cc-card {
        flex: 0 0 48% !important;
        max-width: 48% !important;
        min-width: 280px;
    }
}

@media (max-width: 768px) {
    .donate-quick-amounts,
    .donate-form-section,
    .aca-stats-strip,
    .other-ways-to-give {
        padding: 60px 0 !important;
    }
}

@media (max-width: 640px) {
    .other-ways-to-give .cc-card,
    .cc-donate__other-ways-section .cc-card {
        flex: 0 0 100% !important;
        max-width: 100% !important;
        min-width: 100%;
    }
    
    .donation-amount-card {
        padding: 32px 24px;
    }
}

/* ============================================
   PRINT STYLES
   ============================================ */

@media print {
    .cc-donate-form,
    .cc-donate__amount-btn,
    .cc-donate__other-ways-section {
        display: none;
    }
}


/* Source: our-calling.css */
/**
 * Our Calling Page Styles (Refactored Phase 9)
 * Uses design tokens and BEM naming conventions
 * Video gallery, quote sections, logos, and mission statement
 *
 * Component: Our Calling Page
 * Purpose: Inspirational page featuring testimonial videos, mission, and partner logos
 * Design Tokens: All colors, spacing, and typography use CSS variables
 */

/* ========================================
   HERO QUOTE SECTION
   ======================================== */
.cc-our-calling__quote {
    background-color: var(--color-background, #eef2f9);
    padding: var(--spacing-3xl) var(--spacing-xl);
    text-align: center;
}

.cc-our-calling__quote-content {
    max-width: 900px;
    margin: 0 auto;
}

.cc-our-calling__quote blockquote {
    font-size: clamp(1.5rem, 4vw, 2.75rem);
    line-height: var(--line-height-tight, 1.3);
    font-weight: 700;
    color: var(--color-heading, #202c63);
    margin: 0 0 var(--spacing-lg) 0;
    letter-spacing: -0.02em;
    animation: cc-fade-in-up 0.8s ease-out;
}

.cc-our-calling__quote-attribution {
    font-size: var(--text-sm, 0.875rem);
    font-weight: 500;
    color: var(--color-text-muted, #5c6483);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    animation: cc-fade-in-up 0.8s ease-out 0.2s both;
}

@media (min-width: 1200px) {
    .cc-our-calling__quote {
        padding: var(--spacing-4xl) var(--spacing-xl);
    }
}

/* ========================================
   VIDEO GALLERY SECTION
   ======================================== */
.cc-our-calling__videos {
    padding: var(--spacing-3xl) var(--spacing-xl);
    background-color: var(--color-white, #ffffff);
}

.cc-our-calling__videos-header {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
    animation: cc-fade-in-up 0.8s ease-out;
}

.cc-our-calling__videos-header h2 {
    font-size: clamp(1.875rem, 4vw, 2.25rem);
    font-weight: 700;
    color: var(--color-heading, #202c63);
    margin-bottom: var(--spacing-sm);
    line-height: var(--line-height-tight, 1.3);
}

.cc-our-calling__videos-header p {
    font-size: var(--text-lg, 1.125rem);
    font-weight: 400;
    color: var(--color-text-muted, #5c6483);
    line-height: var(--line-height-relaxed, 1.65);
    margin: 0;
}

/* Video Grid - Override Elementor flexbox */
.cc-our-calling__video-grid,
.e-con.cc-our-calling__video-grid,
.elementor-element.cc-our-calling__video-grid,
.e-flex.cc-our-calling__video-grid {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--spacing-xl) !important;
    max-width: var(--container-xl);
    margin: 0 auto;
    width: 100%;
    flex-direction: unset !important;
    flex-wrap: unset !important;
    flex: unset !important;
}

.cc-our-calling__video-grid > *,
.cc-our-calling__video-grid .elementor-widget,
.cc-our-calling__video-grid .elementor-element {
    width: 100% !important;
    max-width: 100% !important;
    flex: unset !important;
    flex-basis: unset !important;
}

/* Mobile: Single column */
@media (max-width: 767px) {
    .cc-our-calling__video-grid,
    .e-con.cc-our-calling__video-grid,
    .elementor-element.cc-our-calling__video-grid,
    .e-flex.cc-our-calling__video-grid {
        grid-template-columns: 1fr !important;
        gap: var(--spacing-lg) !important;
    }
}

@media (min-width: 1024px) {
    .cc-our-calling__video-grid,
    .e-con.cc-our-calling__video-grid,
    .elementor-element.cc-our-calling__video-grid,
    .e-flex.cc-our-calling__video-grid {
        gap: var(--spacing-2xl) !important;
    }
}

/* Video Card */
.cc-our-calling__video-card {
    background: var(--color-white, #ffffff);
    border: 1px solid var(--color-border-light, #d8dcef);
    border-radius: var(--border-radius-lg, 12px);
    overflow: hidden;
    transition: all var(--transition-speed, 0.3s) ease;
    cursor: pointer;
    animation: cc-fade-in-slide-left 0.6s ease-out;
    color: inherit;
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    text-align: left;
    outline: none;
    font-family: inherit;
}

.cc-our-calling__video-card:nth-child(1) {
    animation-delay: 0s;
}

.cc-our-calling__video-card:nth-child(2) {
    animation-delay: 0.1s;
}

.cc-our-calling__video-card:nth-child(3) {
    animation-delay: 0.2s;
}

.cc-our-calling__video-card:nth-child(4) {
    animation-delay: 0.3s;
}

.cc-our-calling__video-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg, 0 8px 24px rgba(47, 64, 137, 0.15));
    border-color: var(--color-primary, #2f4089);
    color: inherit;
}

.cc-our-calling__video-card:active {
    transform: translateY(-2px);
}

.cc-our-calling__video-card:focus-visible {
    outline: 2px solid var(--color-primary, #2f4089);
    outline-offset: 2px;
}

/* Video Thumbnail */
.cc-our-calling__video-thumbnail {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%; /* 16:9 aspect ratio */
    overflow: hidden;
    background-color: var(--color-gray-light, #f9f9f9);
}

.cc-our-calling__video-thumbnail img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-speed, 0.3s) ease;
}

.cc-our-calling__video-card:hover .cc-our-calling__video-thumbnail img {
    transform: scale(1.05);
}

/* Play Icon Overlay */
.cc-our-calling__video-play-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 72px;
    height: 72px;
    background-color: rgba(47, 64, 137, 0.9);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-speed, 0.3s) ease;
    z-index: 2;
}

.cc-our-calling__video-card:hover .cc-our-calling__video-play-overlay {
    background-color: var(--color-primary, #2f4089);
    transform: translate(-50%, -50%) scale(1.1);
}

.cc-our-calling__video-play-overlay svg {
    width: 28px;
    height: 28px;
    fill: var(--color-white, #ffffff);
    margin-left: 4px; /* Offset for play icon triangle */
}

/* Video Info */
.cc-our-calling__video-info {
    padding: var(--spacing-lg);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-md);
}

.cc-our-calling__video-title {
    font-size: clamp(1.125rem, 2vw, 1.25rem);
    font-weight: 600;
    color: var(--color-heading, #202c63);
    margin: 0;
    line-height: var(--line-height-snug, 1.4);
    flex: 1;
}

.cc-our-calling__video-duration {
    font-size: var(--text-sm, 0.875rem);
    font-weight: 500;
    color: var(--color-text-muted, #5c6483);
    background-color: var(--color-background, #eef2f9);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--border-radius-sm, 6px);
    white-space: nowrap;
    flex-shrink: 0;
}

/* ========================================
   VIDEO MODAL
   ======================================== */
.cc-our-calling__video-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.85);
    z-index: var(--z-tooltip);
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-speed, 0.3s) ease, visibility var(--transition-speed, 0.3s) ease;
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-xl);
}

.cc-our-calling__video-backdrop.active {
    opacity: 1;
    visibility: visible;
}

.cc-our-calling__video-modal {
    position: relative;
    width: 100%;
    max-width: var(--container-xl);
    max-height: 90vh;
    background: var(--color-white, #ffffff);
    border-radius: var(--border-radius-xl, 16px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
    z-index: var(--z-tooltip);
    opacity: 0;
    transform: scale(0.9);
    transition: opacity var(--transition-speed, 0.3s) ease, transform var(--transition-speed, 0.3s) ease;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.cc-our-calling__video-modal.active {
    opacity: 1;
    transform: scale(1);
}

.cc-our-calling__video-close {
    position: absolute;
    top: var(--spacing-md);
    right: var(--spacing-md);
    width: 44px;
    height: 44px;
    background: rgba(255, 255, 255, 0.9);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: var(--z-tooltip);
    transition: all var(--transition-speed, 0.3s) ease;
    padding: 0;
    outline: none;
}

.cc-our-calling__video-close:hover {
    background: var(--color-white, #ffffff);
    transform: rotate(90deg);
}

.cc-our-calling__video-close:focus-visible {
    outline: 2px solid var(--color-primary, #2f4089);
    outline-offset: 2px;
}

.cc-our-calling__video-close svg {
    width: 24px;
    height: 24px;
    stroke: var(--color-text-primary, #1f233a);
}

.cc-our-calling__video-modal-header {
    padding: var(--spacing-xl) var(--spacing-xl) var(--spacing-md) var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light, #e7ebf9);
}

.cc-our-calling__video-modal-title {
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: 700;
    color: var(--color-heading, #202c63);
    margin: 0;
    line-height: var(--line-height-tight, 1.3);
}

.cc-our-calling__video-modal-content {
    flex: 1;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cc-our-calling__video-embed-container {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%; /* 16:9 aspect ratio */
    overflow: hidden;
    background-color: var(--color-gray-light, #f9f9f9);
}

.cc-our-calling__video-embed-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
}

@media (max-width: 767px) {
    .cc-our-calling__video-backdrop {
        padding: var(--spacing-md);
    }

    .cc-our-calling__video-modal {
        max-height: 85vh;
        border-radius: var(--border-radius-lg, 12px);
    }

    .cc-our-calling__video-modal-header {
        padding: var(--spacing-lg) var(--spacing-lg) var(--spacing-md) var(--spacing-lg);
    }

    .cc-our-calling__video-modal-title {
        font-size: var(--text-lg, 1.25rem);
        padding-right: var(--spacing-2xl);
    }

    .cc-our-calling__video-close {
        top: var(--spacing-sm);
        right: var(--spacing-sm);
        width: 40px;
        height: 40px;
    }
}

/* ========================================
   LOGO GRID SECTION (2x2)
   ======================================== */
.cc-our-calling__logos {
    padding: var(--spacing-3xl) var(--spacing-xl);
    background-color: var(--color-gray-bg, #f4f6fb);
}

.cc-our-calling__logos-header {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
    animation: cc-fade-in-up 0.8s ease-out;
}

.cc-our-calling__logos-header h2 {
    font-size: clamp(1.875rem, 4vw, 2.25rem);
    font-weight: 700;
    color: var(--color-heading, #202c63);
    margin-bottom: var(--spacing-sm);
    line-height: var(--line-height-tight, 1.3);
}

.cc-our-calling__logos-header p {
    font-size: var(--text-lg, 1.125rem);
    font-weight: 400;
    color: var(--color-text-muted, #5c6483);
    line-height: var(--line-height-relaxed, 1.65);
    margin: 0;
}

/* Logo Grid - 2x2 */
.cc-our-calling__logo-grid,
.e-con.cc-our-calling__logo-grid,
.elementor-element.cc-our-calling__logo-grid,
.e-flex.cc-our-calling__logo-grid {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--spacing-2xl) !important;
    max-width: 1000px;
    margin: 0 auto;
    width: 100%;
    flex-direction: unset !important;
    flex-wrap: unset !important;
    flex: unset !important;
}

.cc-our-calling__logo-item,
.cc-our-calling__logo-grid .elementor-widget-image,
.cc-our-calling__logo-grid .elementor-image {
    width: 100% !important;
    max-width: 100% !important;
    flex: unset !important;
    flex-basis: unset !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.cc-our-calling__logo-item img,
.cc-our-calling__logo-grid img {
    max-width: 100% !important;
    height: auto !important;
    width: auto !important;
    max-height: 120px;
    object-fit: contain;
    filter: grayscale(0%);
    opacity: 1;
    transition: all var(--transition-speed, 0.3s) ease;
}

.cc-our-calling__logo-item:hover img,
.cc-our-calling__logo-grid .elementor-widget-image:hover img {
    opacity: 0.8;
    transform: scale(1.05);
}

/* Mobile: Single column */
@media (max-width: 767px) {
    .cc-our-calling__logos {
        padding: var(--spacing-2xl) var(--spacing-lg);
    }

    .cc-our-calling__logos-header {
        margin-bottom: var(--spacing-lg);
    }

    .cc-our-calling__logo-grid,
    .e-con.cc-our-calling__logo-grid,
    .elementor-element.cc-our-calling__logo-grid,
    .e-flex.cc-our-calling__logo-grid {
        grid-template-columns: 1fr !important;
        gap: var(--spacing-xl) !important;
    }

    .cc-our-calling__logo-item img,
    .cc-our-calling__logo-grid img {
        max-height: 100px;
    }
}

/* ========================================
   MISSION STATEMENT SECTION
   ======================================== */
.cc-our-calling__mission {
    background: linear-gradient(135deg, var(--color-primary, #2f4089) 0%, #202c63 100%);
    color: var(--color-white, #ffffff);
    padding: var(--spacing-3xl) var(--spacing-xl);
    text-align: center;
    animation: cc-fade-in-up 0.8s ease-out;
}

.cc-our-calling__mission-content {
    max-width: 900px;
    margin: 0 auto;
}

.cc-our-calling__mission h3 {
    font-size: clamp(1.875rem, 4vw, 2.25rem);
    font-weight: 700;
    line-height: var(--line-height-tight, 1.3);
    margin: 0;
    color: var(--color-white, #ffffff);
}

.cc-our-calling__mission-highlight {
    color: var(--color-secondary, #4b96da);
    font-weight: 700;
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */
@media (max-width: 767px) {
    .cc-our-calling__quote {
        padding: var(--spacing-2xl) var(--spacing-lg);
    }

    .cc-our-calling__videos {
        padding: var(--spacing-2xl) var(--spacing-lg);
    }

    .cc-our-calling__videos-header {
        margin-bottom: var(--spacing-xl);
    }

    .cc-our-calling__video-info {
        padding: clamp(1rem, 2vw, 1.25rem);
        flex-direction: column;
        align-items: flex-start;
    }

    .cc-our-calling__video-duration {
        align-self: flex-end;
    }

    .cc-our-calling__mission {
        padding: var(--spacing-2xl) var(--spacing-lg);
    }
}

/* ========================================
   ACCESSIBILITY - REDUCED MOTION
   ======================================== */
@media (prefers-reduced-motion: reduce) {
    .cc-our-calling__video-card,
    .cc-our-calling__quote blockquote,
    .cc-our-calling__quote-attribution,
    .cc-our-calling__videos-header,
    .cc-our-calling__mission,
    .cc-our-calling__video-backdrop,
    .cc-our-calling__video-modal {
        animation: none;
        transition: none;
    }

    .cc-our-calling__video-card:hover {
        transform: none;
    }

    .cc-our-calling__video-card:hover .cc-our-calling__video-thumbnail img {
        transform: none;
    }

    .cc-our-calling__video-card:hover .cc-our-calling__video-play-overlay {
        transform: translate(-50%, -50%);
    }

    .cc-our-calling__video-close:hover {
        transform: none;
    }
}

/* ========================================
   PRINT STYLES
   ======================================== */
@media print {
    .cc-our-calling__video-card {
        break-inside: avoid;
        page-break-inside: avoid;
    }

    .cc-our-calling__video-play-overlay {
        display: none;
    }
}

/* ========================================
   ANIMATION DEFINITIONS
   ======================================== */
@keyframes cc-fade-in-up {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes cc-fade-in-slide-left {
    from {
        opacity: 0;
        transform: translateX(20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}


/* Source: who-we-are.css */
/**
 * Who We Are Page Styling
 * Applies design system standards to the Who We Are page
 */

/* ========================================
   PAGE-SPECIFIC STYLING
   ======================================== */

/* Ensure proper typography hierarchy */
body.page-id-413 .elementor-heading-title,
body.page-id-413 h1,
body.page-id-413 h2,
body.page-id-413 h3 {
    font-family: 'Figtree', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: var(--color-heading, #1f233a);
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.02em;
}

/* H1 Styling - Page Title */
body.page-id-413 .elementor-widget-heading h1.elementor-heading-title {
    font-size: clamp(2rem, 5vw, 3.5rem);
    color: var(--color-primary, #2f4089);
    margin-bottom: 1rem;
}

/* H2 Styling - Section Titles */
body.page-id-413 .elementor-widget-heading h2.elementor-heading-title {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    color: var(--color-primary, #2f4089);
    margin-bottom: 1.5rem;
    margin-top: 3rem;
}

/* H3 Styling - Subsection Titles */
body.page-id-413 .elementor-widget-heading h3.elementor-heading-title {
    font-size: 1.35rem;
    color: var(--color-heading, #1f233a);
    margin-bottom: 1rem;
}

/* Body Text Styling */
body.page-id-413 .elementor-widget-text-editor,
body.page-id-413 .elementor-widget-text-editor p {
    font-family: 'Figtree', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 1rem;
    line-height: 1.65;
    color: var(--color-text, #1f233a);
    margin-bottom: 1rem;
}

/* Section Spacing */
body.page-id-413 .elementor-section {
    padding: 3rem 2rem;
}

body.page-id-413 .elementor-section:first-child {
    padding-top: 4rem;
}

/* Section Backgrounds - Alternate pattern */
body.page-id-413 .elementor-section:nth-child(even) {
    background-color: var(--color-background, #eef2f9);
}

body.page-id-413 .elementor-section:nth-child(odd) {
    background-color: #ffffff;
}

/* ========================================
   CONTENT LAYOUT IMPROVEMENTS
   ======================================== */

/* Two-column content sections */
body.page-id-413 .elementor-column[data-col="66"] {
    padding-right: 2rem;
}

body.page-id-413 .elementor-column[data-col="33"] {
    padding-left: 2rem;
}

@media (max-width: 768px) {
    body.page-id-413 .elementor-column[data-col="66"],
    body.page-id-413 .elementor-column[data-col="33"] {
        padding-left: 0;
        padding-right: 0;
    }
}

/* Image Styling */
body.page-id-413 .elementor-widget-image img {
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(47, 64, 137, 0.15);
    width: 100%;
    height: auto;
}

/* ========================================
   LIST STYLING (Team, Board, etc.)
   ======================================== */

body.page-id-413 .elementor-widget-text-editor ul,
body.page-id-413 .elementor-widget-text-editor ol {
    margin: 1.5rem 0;
    padding-left: 1.5rem;
}

body.page-id-413 .elementor-widget-text-editor li {
    margin-bottom: 0.75rem;
    line-height: 1.65;
    color: var(--color-text, #1f233a);
}

body.page-id-413 .elementor-widget-text-editor li strong {
    color: var(--color-primary, #2f4089);
    font-weight: 600;
}

/* ========================================
   AGENCY FINDER SECTION
   ======================================== */

/* Style the agency finder section to match design system */
body.page-id-413 .agency-finder-section {
    background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
    border-radius: 12px;
    padding: 3rem 2rem;
    margin: 3rem 0;
}

body.page-id-413 .agency-finder-section h2,
body.page-id-413 .agency-finder-section h3 {
    color: var(--color-primary, #2f4089);
    margin-bottom: 1.5rem;
}

/* ========================================
   BUTTON STYLING
   ======================================== */

body.page-id-413 .elementor-button,
body.page-id-413 .cc-btn {
    font-family: 'Figtree', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-weight: 600;
    border-radius: 8px;
    padding: 0.75rem 1.5rem;
    min-height: 44px;
    transition: all 0.3s ease;
}

body.page-id-413 .elementor-button.elementor-button-primary,
body.page-id-413 .cc-btn-primary {
    background: var(--color-primary, #2f4089);
    color: #ffffff;
    border: none;
}

body.page-id-413 .elementor-button.elementor-button-primary:hover,
body.page-id-413 .cc-btn-primary:hover {
    background: #202c63;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(47, 64, 137, 0.3);
}

/* ========================================
   SPACING & LAYOUT
   ======================================== */

/* Container max-width */
body.page-id-413 .elementor-container {
    max-width: var(--container-xl);
    margin: 0 auto;
}

/* Column gaps */
body.page-id-413 .elementor-row {
    gap: 2rem;
}

/* Spacer widget adjustments */
body.page-id-413 .elementor-widget-spacer {
    margin: 2rem 0;
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */

@media (max-width: 1024px) {
    body.page-id-413 .elementor-section {
        padding: 2rem 1.5rem;
    }
    
    body.page-id-413 .elementor-column[data-col="66"],
    body.page-id-413 .elementor-column[data-col="33"] {
        width: 100% !important;
        padding: 0;
        margin-bottom: 2rem;
    }
}

@media (max-width: 768px) {
    body.page-id-413 .elementor-section {
        padding: 2rem 1rem;
    }
    
    body.page-id-413 .elementor-heading-title {
        font-size: clamp(1.5rem, 6vw, 2.5rem) !important;
    }
}

/* ========================================
   ACCESSIBILITY
   ======================================== */

/* Focus states */
body.page-id-413 .elementor-button:focus-visible,
body.page-id-413 .cc-btn:focus-visible {
    outline: 3px solid var(--color-primary, #2f4089);
    outline-offset: 2px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    body.page-id-413 * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}


/* Source: single-agency.css */
/* Single Agency Styles - Using Design Tokens */
.single-agency {
    background: var(--color-bg);
    font-family: var(--font-family-base);
}

.single-agency h1,
.single-agency h2,
.single-agency h3,
.single-agency h4,
.single-agency h5,
.single-agency h6 {
    font-family: var(--font-family-primary);
}

/* Hero Section - Full Width */
.agency-hero {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    background: linear-gradient(135deg, #0066cc 0%, #0052a3 100%);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
    padding: 100px 0 4rem !important; /* Added top padding for nav */
    margin-top: -100px !important; /* Pull behind nav */
    border-bottom: none;
    color: #fff;
    position: relative;
}

.agency-hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.1);
    z-index: 0;
}

.agency-hero > .cc-container {
    position: relative;
    z-index: 1;
}

.breadcrumbs {
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-lg);
    color: rgba(255, 255, 255, 0.9);
}

.breadcrumbs a {
    color: rgba(255, 255, 255, 0.9);
    text-decoration: none;
}

.breadcrumbs a:hover {
    text-decoration: underline;
    color: #fff;
}

.breadcrumbs .separator {
    margin: 0 var(--spacing-xs);
    color: rgba(255, 255, 255, 0.5);
}

.agency-header-wrapper {
    display: flex;
    align-items: center;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.agency-logo-container {
    flex-shrink: 0;
    width: 150px; /* Increased from 120px - 25% increase */
    height: 150px; /* Increased from 120px - 25% increase */
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(10px);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-xs);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid rgba(255, 255, 255, 0.2);
    overflow: hidden;
}

.agency-logo {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

.agency-logo.is-svg {
    width: 110%;
    height: 110%;
    filter: brightness(0) invert(1);
    transform: scale(1.1);
}

.agency-header-content {
    flex: 1;
    min-width: 0;
}

.agency-title {
    font-size: var(--font-size-5xl);
    font-weight: var(--font-weight-bold);
    color: #fff;
    margin-bottom: var(--spacing-md);
    line-height: var(--line-height-tight);
}

.agency-tagline {
    font-size: var(--font-size-xl);
    color: rgba(255, 255, 255, 0.95);
    margin-bottom: 0;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.agency-tagline i {
    color: rgba(255, 255, 255, 0.9);
}

/* Ensure Hero Text is White - Specific Overrides */
.agency-hero .agency-title,
.agency-hero .agency-tagline,
.agency-hero .breadcrumbs,
.agency-hero .breadcrumbs a {
    color: #ffffff !important;
}

.agency-hero .agency-tagline i {
    color: rgba(255, 255, 255, 0.9) !important;
}

.agency-actions {
    display: flex;
    gap: var(--spacing-md);
    flex-wrap: wrap;
    margin-top: var(--spacing-lg);
}

.agency-hero .cc-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.75rem;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s;
    border: 2px solid transparent;
}

.agency-hero .cc-btn-primary {
    background: #fff;
    color: #0066cc;
    border-color: #fff;
}

.agency-hero .cc-btn-primary:hover {
    background: rgba(255, 255, 255, 0.9);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.agency-hero .cc-btn-secondary {
    background: transparent;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.5);
}

.agency-hero .cc-btn-secondary:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: #fff;
}

/* Main Content */
.agency-content {
    padding: var(--spacing-3xl) 0;
}

.content-wrapper {
    display: grid;
    grid-template-columns: 1fr 350px;
    gap: var(--spacing-2xl);
}

.main-content {
    font-size: var(--font-size-md);
    line-height: var(--line-height-relaxed);
    color: var(--color-text);
}

.agency-image {
    margin-bottom: var(--spacing-2xl);
    border-radius: var(--border-radius-lg);
    overflow: hidden;
}

.agency-image img {
    width: 100%;
    height: auto;
    display: block;
}

.main-content h2 {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    margin: var(--spacing-2xl) 0 var(--spacing-lg);
}

.main-content h3 {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    margin: var(--spacing-xl) 0 var(--spacing-md);
}

.main-content p {
    margin-bottom: var(--spacing-lg);
}

/* Sidebar */
.content-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

@media (min-width: 1025px) {
    .content-sidebar {
        position: sticky;
        top: 120px; /* Adjust based on header height */
        align-self: start;
    }
}

.sidebar-card {
    background: var(--color-bg-alt);
    border: var(--border-width-thin) solid var(--color-border);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-lg);
}

.sidebar-card h3 {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.sidebar-card h3 i {
    color: var(--cc-primary);
}

.single-agency .contact-card {
    background: linear-gradient(135deg, var(--cc-primary) 0%, var(--cc-primary-dark) 100%) !important;
    color: var(--color-bg);
    border: none !important;
}

.single-agency .contact-card h3,
.single-agency .contact-card p {
    color: var(--color-bg);
}

.contact-item {
    margin-bottom: var(--spacing-md);
}

.contact-item:last-of-type {
    margin-bottom: 0;
}

.contact-label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    opacity: 0.9;
    margin-bottom: var(--spacing-xs);
}

.contact-value {
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
}

.contact-value a {
    color: var(--color-bg);
    text-decoration: none;
}

.contact-value a:hover {
    text-decoration: underline;
}

.btn-directions {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-bg);
    color: var(--cc-primary);
    border-radius: var(--border-radius-md);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-decoration: none;
    margin-top: var(--spacing-md);
    transition: var(--transition-base);
    width: 100%;
    justify-content: center;
}

.btn-directions:hover {
    background: var(--color-bg-alt);
}

.stats-card {
    display: flex;
    gap: var(--spacing-lg);
}

.stat {
    flex: 1;
    text-align: center;
}

.stat-number {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-bold);
    color: var(--cc-primary);
    line-height: 1;
    margin-bottom: var(--spacing-xs);
}

.stat-label {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    line-height: var(--line-height-tight);
}

/* Services Section */
.services-section {
    background: var(--color-bg-section);
    padding: var(--spacing-3xl) 0;
}

.section-header {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
}

.section-header h2 {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    margin-bottom: var(--spacing-md);
}

.section-header p {
    font-size: var(--font-size-lg);
    color: var(--color-text-muted);
}

/* Locations Section */
.locations-section {
    background: var(--color-bg);
    padding: var(--spacing-3xl) 0;
}

.locations-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: var(--spacing-xl);
    margin-top: var(--spacing-2xl);
}

.location-card {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-xl);
    transition: var(--transition-base);
    display: flex;
    flex-direction: column;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.location-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    transform: translateY(-2px);
}

.location-card-header {
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 2px solid var(--color-border);
}

.location-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    margin: 0 0 var(--spacing-sm) 0;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.location-title i {
    color: var(--cc-primary);
    font-size: var(--font-size-lg);
    flex-shrink: 0;
}

.location-type-badge {
    display: inline-block;
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.03em; /* 0.5px converted to em */
    border-radius: var(--border-radius-sm);
    background: var(--color-bg-alt);
    color: var(--color-text);
    border: 1px solid var(--color-border);
}

.location-type-headquarters {
    background: linear-gradient(135deg, #0066cc 0%, #0052a3 100%);
    color: #fff;
    border-color: #0052a3;
}

.location-type-immigration_services {
    background: linear-gradient(135deg, #9b59b6 0%, #8e44ad 100%);
    color: #fff;
    border-color: #8e44ad;
}

.location-type-food_distribution {
    background: linear-gradient(135deg, #e67e22 0%, #d35400 100%);
    color: #fff;
    border-color: #d35400;
}

.location-type-community_services {
    background: linear-gradient(135deg, #27ae60 0%, #229954 100%);
    color: #fff;
    border-color: #229954;
}

.location-type-counseling_center {
    background: linear-gradient(135deg, #16a085 0%, #138d75 100%);
    color: #fff;
    border-color: #138d75;
}

.location-type-administrative {
    background: linear-gradient(135deg, #34495e 0%, #2c3e50 100%);
    color: #fff;
    border-color: #2c3e50;
}

.location-type-service_location {
    background: var(--color-bg-alt);
    color: var(--color-text-muted);
    border-color: var(--color-border);
}

.location-full-title {
    margin: 0 0 var(--spacing-sm) 0;
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.location-card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.location-info-item {
    display: flex;
    gap: var(--spacing-sm);
    align-items: flex-start;
}

.location-info-item > i {
    color: var(--cc-primary);
    font-size: var(--font-size-base);
    margin-top: 2px;
    flex-shrink: 0;
}

.location-info-content {
    flex: 1;
}

.location-info-content strong {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-xs);
}

.location-info-content p {
    font-size: var(--font-size-base);
    color: var(--color-text);
    margin: 0;
    line-height: var(--line-height-base);
}

.location-info-content a {
    color: var(--cc-primary);
    text-decoration: none;
}

.location-info-content a:hover {
    text-decoration: underline;
}

.location-card-footer {
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
}

/* CTA Section */
.cta-section {
    background: linear-gradient(135deg, var(--cc-primary) 0%, var(--cc-primary-dark) 100%);
    padding: var(--spacing-3xl) 0;
    color: var(--color-bg);
}

.cta-content {
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

.cta-content h2 {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--spacing-md);
}

.cta-content p {
    font-size: var(--font-size-xl);
    margin-bottom: var(--spacing-2xl);
    opacity: 0.95;
}

.cta-buttons {
    display: flex;
    gap: var(--spacing-md);
    justify-content: center;
    flex-wrap: wrap;
}

.btn-lg {
    padding: var(--spacing-lg) var(--spacing-2xl);
    font-size: var(--font-size-lg);
}

.cc-btn-outline {
    background: transparent;
    color: var(--color-bg);
    border-color: var(--color-bg);
}

.cc-btn-outline:hover {
    background: var(--color-bg);
    color: var(--cc-primary);
}

/* Mobile Responsive */
@media (max-width: 1024px) {
    .single-agency .content-wrapper {
        display: flex;
        flex-direction: column;
        gap: var(--spacing-lg);
    }
    
    .single-agency .content-sidebar {
        order: -1;
        width: 100%; /* Ensure full width */
    }
}

@media (max-width: 768px) {
    .agency-hero {
        padding: 100px 0 2rem !important; /* Reduced bottom padding */
        margin-top: -100px !important;
        min-height: auto !important;
        height: auto !important;
    }
    
    .agency-header-wrapper {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: var(--spacing-sm); /* Reduced gap */
        margin-bottom: var(--spacing-md); /* Reduced margin */
    }
    
    .agency-header-content {
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .agency-logo-container {
        width: 60px; /* Even smaller logo */
        height: 60px;
        padding: var(--spacing-2xs);
        margin-bottom: var(--spacing-xs);
    }
    
    .agency-title {
        font-size: var(--font-size-2xl); /* Smaller title */
        margin-bottom: var(--spacing-xs);
        line-height: 1.2;
    }
    
    .agency-tagline {
        font-size: var(--font-size-xs);
        justify-content: center;
        margin-bottom: var(--spacing-xs);
    }
    
    .agency-actions {
        width: 100%;
        flex-direction: column;
        margin-top: var(--spacing-sm);
        gap: var(--spacing-xs);
    }
    
    .agency-actions .cc-btn {
        width: 100%;
        justify-content: center;
        padding: 0.5rem 1rem; /* Compact buttons */
        font-size: var(--font-size-sm);
        min-height: 40px;
    }

    /* Body Content Improvements */
    .agency-content {
        padding: var(--spacing-xl) 0;
    }

    .main-content {
        font-size: var(--font-size-base); /* Readable font size */
        line-height: 1.6;
    }

    .main-content h2 {
        font-size: var(--font-size-2xl);
        margin: var(--spacing-xl) 0 var(--spacing-md);
    }

    .section-header h2 {
        font-size: var(--font-size-2xl);
    }
    
    .cta-content h2 {
        font-size: var(--font-size-2xl);
    }
    
    .cta-content p {
        font-size: var(--font-size-base);
    }
    
    .cta-buttons {
        flex-direction: column;
        width: 100%;
        gap: var(--spacing-sm);
    }
    
    .cta-buttons .cc-btn {
        width: 100%;
        justify-content: center;
    }
    
    .stats-card {
        flex-direction: row; /* Keep stats side-by-side if space permits, or wrap */
        flex-wrap: wrap;
        gap: var(--spacing-md);
    }
    
    .stat {
        flex: 1 1 45%; /* Allow stats to take up half width */
    }
}

/* Source: single-service.css */
/* Single Service Styles */
.single-service {
    background: #fff;
    font-family: var(--font-family-base);
}

.single-service h1,
.single-service h2,
.single-service h3,
.single-service h4,
.single-service h5,
.single-service h6 {
    font-family: var(--font-family-primary);
}

/* Hero Section styles are now handled by the shared cc-hero component in
   css/components/sections/hero.css. 
   However, we enforce the pull-up here to ensure it works with the transparent nav. */
body.single-service .service-hero {
    margin-top: -100px !important;
    padding-top: 100px !important;
}

.container {
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: 0 1.5rem;
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.75rem;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s;
    border: 2px solid transparent;
}

.btn-primary {
    background: #0066cc;
    color: #fff;
}

.btn-primary:hover {
    background: #0052a3;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,102,204,0.3);
}

.btn-secondary {
    background: #fff;
    color: #0066cc;
    border-color: #0066cc;
}

.btn-secondary:hover {
    background: #0066cc;
    color: #fff;
}

.btn-outline {
    background: transparent;
    color: #0066cc;
    border-color: #0066cc;
}

.btn-outline:hover {
    background: #0066cc;
    color: #fff;
}

.btn-lg {
    padding: 1.25rem 2rem;
    font-size: 1.125rem;
}

.btn-block {
    width: 100%;
    justify-content: center;
}

/* Service Content */
.service-content {
    padding: 4rem 0;
}

.content-wrapper {
    display: grid;
    grid-template-columns: 1fr 350px;
    gap: 3rem;
}

.main-content {
    font-size: 1.0625rem;
    line-height: 1.7;
    color: #212529;
}

.main-content h2 {
    font-size: 2rem;
    font-weight: 700;
    color: #212529;
    margin: 2.5rem 0 1.5rem;
}

.main-content h3 {
    font-size: 1.5rem;
    font-weight: 600;
    color: #212529;
    margin: 2rem 0 1rem;
}

.main-content ul,
.main-content ol {
    margin: 1.5rem 0;
    padding-left: 1.5rem;
}

.main-content li {
    margin-bottom: 0.75rem;
}

.main-content p {
    margin-bottom: 1.5rem;
}

/* Sidebar */
.content-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.sidebar-card {
    background: #f8f9fa;
    border: 1px solid #e9ecef;
    border-radius: 12px;
    padding: 1.5rem;
}

.sidebar-card h3 {
    font-size: 1.25rem;
    font-weight: 700;
    color: #212529;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.sidebar-card h3 i {
    color: #0066cc;
}

.sidebar-card p {
    font-size: 0.9375rem;
    color: #6c757d;
    margin-bottom: 1rem;
    line-height: 1.6;
}

.single-service .contact-card {
    background: linear-gradient(135deg, var(--cc-primary) 0%, var(--cc-primary-dark) 100%) !important;
    color: var(--color-bg);
    border: none !important;
}

.single-service .contact-card h3,
.single-service .contact-card p {
    color: var(--color-bg);
}

.contact-card .btn {
    background: #fff;
    color: #0066cc;
}

.stats-card {
    display: flex;
    gap: 1.5rem;
}

.stat {
    flex: 1;
    text-align: center;
}

.stat-number {
    font-size: 2.5rem;
    font-weight: 700;
    color: #0066cc;
    line-height: 1;
    margin-bottom: 0.5rem;
}

.stat-label {
    font-size: 0.875rem;
    color: #6c757d;
    line-height: 1.3;
}

.stat-link {
    text-decoration: none;
    color: inherit;
    display: block;
    transition: all 0.3s ease;
}

.stat-clickable {
    cursor: pointer;
    border-radius: 8px;
    padding: 0.5rem;
    margin: -0.5rem;
    transition: all 0.3s ease;
}

.stat-clickable:hover {
    background: rgba(0, 102, 204, 0.05);
    transform: translateY(-2px);
}

.stat-clickable:hover .stat-number {
    color: #0052a3;
}

.stat-clickable:hover .stat-label {
    color: #0066cc;
}

.stat-hint {
    font-size: 0.75rem;
    color: #0066cc;
    margin-top: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.stat-clickable:hover .stat-hint {
    opacity: 1;
}

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

.related-list li {
    margin-bottom: 0.75rem;
}

.related-list a {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: #495057;
    text-decoration: none;
    font-size: 0.9375rem;
    padding: 0.75rem;
    border-radius: 6px;
    transition: all 0.3s;
}

.related-list a:hover {
    background: #fff;
    color: #0066cc;
    padding-left: 1rem;
}

.related-list i {
    color: #0066cc;
    font-size: 0.75rem;
}

/* Agencies Section */
.agencies-section {
    background: #f8f9fa;
    padding: 4rem 0;
}

.section-header {
    text-align: center;
    margin-bottom: 3rem;
}

.section-header h2 {
    font-size: 2.5rem;
    font-weight: 700;
    color: #212529;
    margin-bottom: 1rem;
}

.section-header p {
    font-size: 1.125rem;
    color: #6c757d;
}

/* CTA Section */
.cta-section {
    background: linear-gradient(135deg, #0066cc 0%, #0052a3 100%);
    padding: 4rem 0;
    color: #fff;
}

.cta-content {
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

.cta-content h2 {
    font-size: 2.5rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.cta-content p {
    font-size: 1.25rem;
    margin-bottom: 2rem;
    opacity: 0.95;
}

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

.cta-section .btn-outline {
    border-color: #fff;
    color: #fff;
}

.cta-section .btn-outline:hover {
    background: #fff;
    color: #0066cc;
}

/* Mobile Responsive */
@media (max-width: 968px) {
    .content-wrapper {
        grid-template-columns: 1fr;
    }
    
    .content-sidebar {
        order: -1;
    }
}

@media (max-width: 768px) {
    .service-hero.has-featured-image {
        padding-top: 100px !important;
        padding-bottom: 2rem !important;
        height: auto !important;
        min-height: auto !important;
    }
    
    .service-title-wrapper {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }
    
    .service-icon-large {
        width: 60px;
        height: 60px;
        font-size: 2rem;
    }
    
    .service-title {
        font-size: 2rem;
    }
    
    .service-intro {
        font-size: 1rem;
    }
    
    .service-actions {
        flex-direction: column;
    }
    
    .service-actions .btn {
        width: 100%;
        justify-content: center;
    }
    
    .section-header h2 {
        font-size: 1.75rem;
    }
    
    .cta-content h2 {
        font-size: 1.75rem;
    }
    
    .cta-content p {
        font-size: 1rem;
    }
    
    .cta-buttons {
        flex-direction: column;
    }
    
    .stats-card {
        flex-direction: column;
        gap: 1rem;
    }
}

/* Source: single-pilgrimage.css */
/**
 * Sacred Journey - Editorial Pilgrimage Design
 *
 * A refined, editorial magazine aesthetic with:
 * - Elegant serif typography (Cormorant Garamond)
 * - Sacred blue and gold color palette
 * - Asymmetric magazine layouts
 * - Smooth scroll animations
 * - Contemplative, spiritual atmosphere
 */

/* ============================================================================
   Typography & Fonts
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Figtree:wght@300;400;500;600;700&display=swap');

:root {
	/* Sacred Color Palette */
	--sacred-blue-deep: #1a365d;
	--sacred-blue: #2f4089;
	--sacred-blue-light: #4b96da;
	--sacred-gold: #D4AF37;
	--sacred-gold-light: #E5C158;
	--sacred-cream: #FBF9F6;
	--sacred-ivory: #F5F3EF;
	--sacred-charcoal: #2d3748;
	--sacred-text: #1f2937;
	--sacred-text-light: #6b7280;

	/* Typography */
	--font-serif: 'Cormorant Garamond', Georgia, serif;
	--font-sans: 'Figtree', -apple-system, sans-serif;

	/* Spacing */
	--spacing-xs: 0.5rem;
	--spacing-sm: 1rem;
	--spacing-md: 1.5rem;
	--spacing-lg: 2.5rem;
	--spacing-xl: 4rem;
	--spacing-2xl: 6rem;

	/* Shadows */
	--shadow-sm: 0 2px 8px rgba(26, 54, 93, 0.06);
	--shadow-md: 0 4px 16px rgba(26, 54, 93, 0.1);
	--shadow-lg: 0 8px 32px rgba(26, 54, 93, 0.15);
	--shadow-xl: 0 20px 60px rgba(26, 54, 93, 0.2);
}

/* ============================================================================
   Base Styles
   ========================================================================= */

.pilgrimage-editorial {
	background: var(--sacred-cream);
	color: var(--sacred-text);
	font-family: var(--font-sans);
	line-height: 1.7;
	overflow-x: hidden;
}

.pilgrimage-editorial h1,
.pilgrimage-editorial h2,
.pilgrimage-editorial h3 {
	font-family: var(--font-serif);
	font-weight: 600;
	color: var(--sacred-blue-deep);
	line-height: 1.2;
}

/* ============================================================================
   Immersive Hero Section
   ========================================================================= */

/* Ensure header sits above hero without pushing it down */
#trans_header {
	position: relative;
	z-index: var(--z-dropdown);
}

/* Header styling - ensure contrast on light hero */
body.single-pilgrimage .elementor-sticky,
body.single-pilgrimage [data-id="c8deb65"],
body.single-pilgrimage #trans_header {
	background: var(--color-primary, #2f4089) !important;
	transition: background-color 0.3s ease, background 0.3s ease !important;
}

/* Ensure the header wrapper itself is solid (Elementor location header) */
body.single-pilgrimage .elementor-location-header,
body.single-pilgrimage .elementor-location-header > .elementor-section,
body.single-pilgrimage .elementor-location-header > .e-con {
	background: var(--color-primary, #2f4089) !important;
}

/* Apply solid background when sticky effects are active (on scroll) */
body.single-pilgrimage .elementor-sticky.elementor-sticky--effects,
body.single-pilgrimage [data-id="c8deb65"].elementor-sticky--effects {
	background: var(--color-primary, #2f4089) !important; /* Solid brand color */
}

/* Header text/icon contrast */
body.single-pilgrimage header,
body.single-pilgrimage header a,
body.single-pilgrimage .elementor-nav-menu--main .elementor-item,
body.single-pilgrimage .elementor-nav-menu--main .elementor-item:before,
body.single-pilgrimage .elementor-nav-menu--main .elementor-item:after {
	color: #ffffff !important;
	fill: #ffffff !important;
}

body.single-pilgrimage .elementor-nav-menu--main .elementor-item:hover,
body.single-pilgrimage .elementor-nav-menu--main .elementor-item.elementor-item-active {
	color: #e4e9f7 !important;
}

.pilgrimage-hero {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	background-size: cover;
	background-position: center top; /* Position from top to ensure coverage */
	background-attachment: fixed;
	isolation: isolate;
	overflow: hidden; /* Clip content but allow background to extend via negative margin */
	margin-top: -100px; /* Negative margin to push background under header */
	padding-top: 100px; /* Push content down so it doesn't overlap nav */
	padding-bottom: 6rem; /* Match standard hero component spacing */
	width: 100%;
	z-index: 1;
}

/* Ensure background-image extends properly */
.pilgrimage-hero[style*="background-image"] {
	background-size: cover;
	background-position: center top;
	background-repeat: no-repeat;
}

/* Video Background */
.hero-video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
	pointer-events: none;
}

/* YouTube Video Background */
.hero-video-wrapper {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100vw;
	height: 56.25vw; /* 16:9 aspect ratio */
	min-height: 100vh;
	min-width: 177.77vh; /* 16:9 aspect ratio */
	z-index: 0;
	pointer-events: none;
}

.hero-video-youtube {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}

/* Hero overlay with sacred gradient */
.hero-veil {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		135deg,
		rgba(26, 54, 93, 0.85) 0%,
		rgba(47, 64, 137, 0.75) 50%,
		rgba(75, 150, 218, 0.65) 100%
	);
	z-index: 1;
}

.hero-veil::after {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 20% 50%, rgba(212, 175, 55, 0.08) 0%, transparent 50%),
		radial-gradient(circle at 80% 80%, rgba(212, 175, 55, 0.06) 0%, transparent 50%);
	mix-blend-mode: overlay;
}

.hero-content-wrapper {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 900px;
	margin: 0 auto;
	padding: 0 2rem;
}

.hero-inner {
	text-align: center;
	color: #ffffff;
}

.hero-inner h1,
.hero-inner h2,
.hero-inner h3,
.hero-inner h4,
.hero-inner h5,
.hero-inner h6,
.hero-inner p {
	color: #ffffff;
}

/* Destination Badge */
.destination-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.625rem 1.5rem;
	background: rgba(255, 255, 255, 0.15);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 50px;
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.06em; /* 1px converted to em (1/16 ≈ 0.0625em) */
	text-transform: uppercase;
	margin-bottom: 2rem;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.badge-icon {
	flex-shrink: 0;
}

/* Hero Typography */
.hero-title {
	font-size: clamp(3rem, 7vw, 5.5rem);
	font-weight: 600;
	margin: 0 0 1.5rem;
	padding-top: 10rem;
	line-height: 1.1;
	letter-spacing: -0.02em;
	text-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
}

.hero-route {
	font-family: var(--font-serif);
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 400;
	font-style: italic;
	margin: 0 0 2rem;
	opacity: 0.95;
	letter-spacing: 0.01em;
}

.hero-divider {
	margin: 2rem auto;
	opacity: 0.9;
}

.hero-excerpt {
	font-size: clamp(1.125rem, 2vw, 1.375rem);
	line-height: 1.6;
	max-width: 600px;
	margin: 0 auto 3rem;
	opacity: 0.9;
	font-weight: 300;
}

/* Hero Meta Badges */
.hero-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	justify-content: center;
	margin-bottom: 3rem;
}

.meta-badge {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1.25rem;
	background: rgba(255, 255, 255, 0.1);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 8px;
	font-size: 0.9375rem;
	font-weight: 500;
}

.meta-icon {
	flex-shrink: 0;
	opacity: 0.9;
}

/* Hero CTA */
.hero-actions {
	margin-top: 3rem;
}

.btn-sacred {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	padding: 1.25rem 2.5rem;
	background: var(--sacred-gold);
	color: var(--sacred-blue-deep);
	font-family: var(--font-sans);
	font-size: 1.125rem;
	font-weight: 700;
	text-decoration: none;
	border-radius: 50px;
	border: 2px solid var(--sacred-gold);
	box-shadow: 0 8px 24px rgba(212, 175, 55, 0.3);
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	position: relative;
	overflow: hidden;
}

.btn-sacred::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, transparent, rgba(255, 255, 255, 0.2));
	transform: translateX(-100%);
	transition: transform 0.5s;
}

.btn-sacred:hover::before {
	transform: translateX(100%);
}

.btn-sacred:hover {
	background: var(--sacred-gold-light);
	border-color: var(--sacred-gold-light);
	transform: translateY(-3px);
	box-shadow: 0 12px 32px rgba(212, 175, 55, 0.4);
}

.btn-arrow {
	transition: transform 0.3s;
}

.btn-sacred:hover .btn-arrow {
	transform: translateX(4px);
}

/* Scroll Indicator */
.scroll-indicator {
	position: absolute;
	bottom: 3rem;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.75rem;
	color: rgba(255, 255, 255, 0.7);
	z-index: 2;
}

.scroll-line {
	width: 2px;
	height: 40px;
	background: linear-gradient(to bottom, transparent, var(--sacred-gold));
	animation: scrollPulse 2s ease-in-out infinite;
}

.scroll-text {
	font-size: 0.75rem;
	letter-spacing: 0.09em; /* 1.5px converted to em (1.5/16 ≈ 0.09375em) */
	text-transform: uppercase;
	font-weight: 600;
}

@keyframes scrollPulse {
	0%, 100% { opacity: 0.4; transform: translateY(0); }
	50% { opacity: 1; transform: translateY(8px); }
}

/* ============================================================================
   Editorial Container & Layout
   ========================================================================= */

.editorial-container {
	position: relative;
	max-width: var(--container-xl);
	margin: 0 auto;
	padding: var(--spacing-2xl) 2rem;
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 3rem;
	align-items: start;
	overflow: visible;
}

/* Sticky Pricing Panel - within parent container */
.pricing-feature {
	position: sticky;
	top: 80px;
	width: 100%;
	z-index: var(--z-dropdown);
	height: fit-content;
	align-self: start;
	order: 2;
}

/* Editorial Content Area - position first */
.editorial-content {
	order: 1;
}

.pricing-inner {
	background: linear-gradient(135deg, var(--sacred-blue-deep) 0%, var(--sacred-blue) 100%);
	padding: 2.5rem;
	border-radius: 16px;
	box-shadow: var(--shadow-xl);
	color: #ffffff;
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.pricing-inner::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle, rgba(212, 175, 55, 0.1) 0%, transparent 70%);
	animation: priceGlow 6s ease-in-out infinite;
}

.pricing-inner h1,
.pricing-inner h2,
.pricing-inner h3,
.pricing-inner h4,
.pricing-inner h5,
.pricing-inner h6,
.pricing-inner p {
	color: #ffffff;
}

@keyframes priceGlow {
	0%, 100% { transform: translate(0, 0); opacity: 0.5; }
	50% { transform: translate(-20px, -20px); opacity: 0.8; }
}

.pricing-label {
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-weight: 600;
	margin: 0 0 1.5rem;
	letter-spacing: 0.06em; /* 1px converted to em */
	text-transform: uppercase;
	opacity: 0.9;
	position: relative;
	z-index: 1;
	color: #ffffff;
}

.price-option {
	display: flex;
	flex-direction: column;
	padding: 1.5rem;
	background: rgba(255, 255, 255, 0.1);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	border-radius: 12px;
	margin-bottom: 1rem;
	border: 1px solid rgba(255, 255, 255, 0.15);
	position: relative;
	z-index: 1;
	color: #ffffff;
}

.price-option:last-of-type {
	margin-bottom: 0;
}

.price-option h4,
.price-option h5,
.price-option h6,
.price-option p,
.price-option span {
	color: #ffffff;
}

.price-value {
	font-family: var(--font-serif);
	font-size: 2.5rem;
	font-weight: 700;
	line-height: 1;
	margin-bottom: 0.5rem;
	color: var(--sacred-gold-light);
}

.price-detail {
	font-size: 0.875rem;
	opacity: 0.85;
	line-height: 1.5; /* Fixed from 1.4 to meet WCAG 1.4.12 minimum */
	color: #ffffff;
}

.price-notes {
	margin-top: 1.5rem;
	margin-bottom: 1.5rem;
	font-size: 0.8125rem;
	opacity: 0.8;
	line-height: 1.5;
	position: relative;
	z-index: 1;
	color: #ffffff;
}

/* Signup Modal Button */
.btn-signup-modal {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	width: 100%;
	padding: 1rem 1.5rem;
	background: var(--sacred-gold);
	color: var(--sacred-blue-deep);
	font-family: var(--font-sans);
	font-size: 1rem;
	font-weight: 700;
	text-decoration: none;
	border-radius: 12px;
	border: 2px solid var(--sacred-gold);
	box-shadow: 0 6px 16px rgba(212, 175, 55, 0.25);
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	position: relative;
	z-index: 1;
	cursor: pointer;
	overflow: hidden;
}

.btn-signup-modal::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, transparent, rgba(255, 255, 255, 0.15));
	transform: translateX(-100%);
	transition: transform 0.4s;
}

.btn-signup-modal:hover::before {
	transform: translateX(100%);
}

.btn-signup-modal:hover {
	background: var(--sacred-gold-light);
	border-color: var(--sacred-gold-light);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(212, 175, 55, 0.35);
}

.btn-signup-modal .btn-arrow {
	flex-shrink: 0;
	transition: transform 0.3s;
}

.btn-signup-modal:hover .btn-arrow {
	transform: translateX(2px);
}


/* ============================================================================
   Content Sections
   ========================================================================= */

.content-section {
	margin-bottom: var(--spacing-2xl);
}

.section-title {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 4vw, 2.75rem);
	font-weight: 600;
	color: var(--sacred-blue-deep);
	text-align: center;
	margin: 0 0 var(--spacing-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2rem;
	position: relative;
}

.title-line {
	flex: 1;
	height: 2px;
	background: linear-gradient(
		to right,
		transparent,
		var(--sacred-gold) 30%,
		var(--sacred-gold) 70%,
		transparent
	);
	max-width: 120px;
}

.section-header {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: var(--spacing-md);
}

.section-icon {
	color: var(--sacred-gold);
	flex-shrink: 0;
}

/* ============================================================================
   Introduction Section
   ========================================================================= */

.intro-section {
	padding: var(--spacing-xl) 0;
}

.intro-text,
.intro-section > *:not(.intro-text) {
	font-size: 1.1875rem;
	line-height: 1.8;
	color: var(--sacred-text);
}

.intro-text p:first-of-type::first-letter {
	font-family: var(--font-serif);
	font-size: 4.5rem;
	font-weight: 600;
	line-height: 1.2; /* Fixed from 0.9 to meet WCAG 1.4.12 - large heading can use 1.2 */
	float: left;
	margin: 0.1em 0.15em 0 0;
	color: var(--sacred-blue-deep);
}

/* ============================================================================
   Scheduled Dates Section
   ========================================================================= */

.dates-timeline {
	display: grid;
	gap: 1.25rem;
	margin-top: var(--spacing-lg);
}

.date-card {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.75rem 2rem;
	background: #ffffff;
	border: 2px solid var(--sacred-ivory);
	border-radius: 16px;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.date-card:hover {
	border-color: var(--sacred-gold);
	transform: translateX(8px);
	box-shadow: var(--shadow-md);
}

.date-header {
	display: flex;
	align-items: center;
	gap: 1.5rem;
}

.date-icon {
	color: var(--sacred-blue);
	flex-shrink: 0;
}

.date-info {
	display: flex;
	align-items: center;
	gap: 1rem;
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--sacred-blue-deep);
}

.date-separator {
	color: var(--sacred-gold);
	font-size: 1.5rem;
}

.date-status {
	padding: 0.5rem 1.25rem;
	border-radius: 50px;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	white-space: nowrap;
}

.date-status.status-open {
	background: linear-gradient(135deg, #d4edda, #c3e6cb);
	color: #155724;
}

.date-status.status-filling {
	background: linear-gradient(135deg, #fff3cd, #ffeaa7);
	color: #856404;
}

.date-status.status-waitlist,
.date-status.status-sold_out,
.date-status.status-sold-out {
	background: linear-gradient(135deg, #f8d7da, #f5c6cb);
	color: #721c24;
}

.date-status.status-completed {
	background: linear-gradient(135deg, #d6d8db, #c6c8ca);
	color: #383d41;
}

/* ============================================================================
   Historical Context Section
   ========================================================================= */

.historical-section {
	padding: var(--spacing-xl);
	background: #ffffff;
	border-radius: 20px;
	border: 3px solid var(--sacred-ivory);
	position: relative;
	overflow: hidden;
}

.historical-section::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 6px;
	height: 100%;
	background: linear-gradient(to bottom, var(--sacred-gold), var(--sacred-blue));
}

.historical-text {
	font-size: 1.0625rem;
	line-height: 1.9;
	color: var(--sacred-charcoal);
}

.historical-text p {
	margin-bottom: 1.5rem;
}

/* ============================================================================
   What's Included Section
   ========================================================================= */

.included-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1rem;
	margin-top: var(--spacing-lg);
}

.included-item {
	display: flex;
	align-items: flex-start;
	gap: 0.875rem;
	padding: 1.25rem;
	background: #ffffff;
	border: 2px solid var(--sacred-ivory);
	border-radius: 12px;
	transition: all 0.3s;
}

.included-item:hover {
	border-color: var(--sacred-gold);
	transform: translateY(-2px);
	box-shadow: var(--shadow-sm);
}

.check-icon {
	flex-shrink: 0;
	color: var(--sacred-gold);
	margin-top: 2px;
}

.included-item span {
	font-size: 0.9375rem;
	line-height: 1.5;
	color: var(--sacred-text);
}

.not-included-note {
	margin-top: 2rem;
	padding: 1.75rem;
	background: linear-gradient(135deg, #fef3f1, #fef9f7);
	border-left: 4px solid #dc3545;
	border-radius: 8px;
}

.note-header {
	font-weight: 700;
	color: #dc3545;
	margin-bottom: 0.75rem;
	font-size: 1rem;
	letter-spacing: 0.5px;
	text-transform: uppercase;
}

.not-included-note p {
	margin: 0;
	color: var(--sacred-text-light);
	line-height: 1.6;
}

/* ============================================================================
   Optional Add-ons Section
   ========================================================================= */

.addons-list {
	display: grid;
	gap: 1.5rem;
	margin-top: var(--spacing-lg);
}

.addon-item {
	background: #ffffff;
	border: 2px solid var(--sacred-ivory);
	border-radius: 16px;
	padding: 2rem;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	position: relative;
	overflow: hidden;
}

.addon-item::before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 100px;
	height: 100px;
	background: radial-gradient(circle, rgba(212, 175, 55, 0.08) 0%, transparent 70%);
	border-radius: 50%;
	transform: translate(40%, -40%);
}

.addon-item:hover {
	border-color: var(--sacred-gold);
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
}

.addon-title {
	font-family: var(--font-serif);
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--sacred-blue-deep);
	margin: 0 0 0.75rem;
}

.addon-description {
	color: var(--sacred-text-light);
	line-height: 1.6;
	margin-bottom: 1.25rem;
}

.addon-meta {
	display: flex;
	align-items: center;
	gap: 2rem;
	font-size: 0.9375rem;
}

.addon-dates {
	color: var(--sacred-text-light);
}

.addon-price {
	font-family: var(--font-serif);
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--sacred-blue);
}

/* ============================================================================
   Photo Gallery Section
   ========================================================================= */

.editorial-gallery {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 1rem;
	margin-top: var(--spacing-lg);
}

.gallery-item {
	position: relative;
	overflow: hidden;
	border-radius: 12px;
	display: block;
	cursor: pointer;
}

.gallery-item::before {
	content: '';
	display: block;
	padding-bottom: 100%;
}

.gallery-item img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.gallery-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(26, 54, 93, 0.8), rgba(212, 175, 55, 0.6));
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 0.3s;
}

.gallery-overlay svg {
	color: #ffffff;
}

.gallery-item:hover img {
	transform: scale(1.1);
}

.gallery-item:hover .gallery-overlay {
	opacity: 1;
}

/* Magazine-style asymmetric grid */
.gallery-item-1 {
	grid-column: span 7;
	grid-row: span 2;
}

.gallery-item-2 {
	grid-column: span 5;
}

.gallery-item-3 {
	grid-column: span 5;
}

.gallery-item-4 {
	grid-column: span 5;
	grid-row: span 2;
}

.gallery-item-5 {
	grid-column: span 7;
}

/* ============================================================================
   Logistics Section
   ========================================================================= */

.logistics-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 1.5rem;
	margin-top: var(--spacing-lg);
}

.logistics-item {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
	padding: 2rem;
	background: #ffffff;
	border: 2px solid var(--sacred-ivory);
	border-radius: 16px;
	transition: all 0.3s;
}

.logistics-item:hover {
	border-color: var(--sacred-blue-light);
	box-shadow: var(--shadow-sm);
}

.logistics-icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--sacred-blue-light), var(--sacred-blue));
	border-radius: 12px;
	color: #ffffff;
}

.logistics-label {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--sacred-text-light);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 0.5rem;
}

.logistics-value {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--sacred-blue-deep);
}

/* ============================================================================
   Sacred CTA Section
   ========================================================================= */

.sacred-cta {
	background: linear-gradient(135deg, var(--sacred-blue-deep) 0%, var(--sacred-blue) 100%);
	padding: var(--spacing-2xl) 2rem;
	position: relative;
	overflow: hidden;
	isolation: isolate;
}

.sacred-cta::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 20% 50%, rgba(212, 175, 55, 0.1) 0%, transparent 50%),
		radial-gradient(circle at 80% 50%, rgba(212, 175, 55, 0.08) 0%, transparent 50%);
	z-index: -1;
}

.cta-container {
	max-width: 800px;
	margin: 0 auto;
	text-align: center;
	color: #ffffff;
}

.cta-container h1,
.cta-container h2,
.cta-container h3,
.cta-container h4,
.cta-container h5,
.cta-container h6,
.cta-container p {
	color: #ffffff;
}

.cta-ornament {
	display: flex;
	justify-content: center;
	margin-bottom: 2rem;
	color: var(--sacred-gold);
	opacity: 0.7;
}

.cta-title {
	font-family: var(--font-serif);
	font-size: clamp(2.5rem, 5vw, 3.5rem);
	font-weight: 600;
	margin: 0 0 1.5rem;
	line-height: 1.2;
	color: #ffffff;
}

.cta-text {
	font-size: 1.25rem;
	line-height: 1.7;
	margin-bottom: 3rem;
	opacity: 0.95;
	font-weight: 300;
	color: #ffffff;
}

.cta-actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
}

.btn-sacred-large {
	padding: 1.5rem 3rem;
	background: var(--sacred-gold);
	color: var(--sacred-blue-deep);
	font-size: 1.25rem;
	font-weight: 700;
	text-decoration: none;
	border-radius: 50px;
	box-shadow: 0 8px 32px rgba(212, 175, 55, 0.3);
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	display: inline-block;
}

.btn-sacred-large:hover {
	background: var(--sacred-gold-light);
	transform: translateY(-3px);
	box-shadow: 0 12px 40px rgba(212, 175, 55, 0.4);
}

.btn-outline-sacred {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	padding: 1rem 2rem;
	background: transparent;
	color: #ffffff;
	font-weight: 600;
	text-decoration: none;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-radius: 50px;
	transition: all 0.3s;
}

.btn-outline-sacred:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: var(--sacred-gold);
}

.btn-text-sacred {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
	font-weight: 500;
	transition: all 0.3s;
}

.btn-text-sacred:hover {
	color: var(--sacred-gold);
	gap: 0.75rem;
}

/* ============================================================================
   Responsive Design
   ========================================================================= */

@media (max-width: 1200px) {
	.editorial-container {
		grid-template-columns: 1fr;
		gap: 2rem;
		padding: var(--spacing-xl) 2rem;
	}

	.pricing-feature {
		position: static;
		max-height: none;
		overflow-y: visible;
		margin-bottom: 2rem;
	}
}

@media (max-width: 968px) {
	:root {
		--spacing-xl: 3rem;
		--spacing-2xl: 4rem;
	}

	.pilgrimage-hero {
		background-attachment: scroll;
		margin-top: -100px;
		padding-top: 100px;
	}

	.hero-content-wrapper {
		padding: 0 1.5rem;
	}

	.hero-title {
		font-size: clamp(2.5rem, 8vw, 4rem);
	}

	.hero-meta {
		gap: 1rem;
	}

	.editorial-gallery {
		grid-template-columns: repeat(6, 1fr);
	}

	.gallery-item-1,
	.gallery-item-2,
	.gallery-item-3,
	.gallery-item-4,
	.gallery-item-5 {
		grid-column: span 6;
		grid-row: span 1;
	}
}

@media (max-width: 640px) {
	.pilgrimage-hero {
		margin-top: -100px;
		padding-top: 100px;
		padding-bottom: 3rem;
		min-height: auto;
		height: auto;
	}

	.hero-video-wrapper {
		min-height: auto;
		height: 100%;
		position: absolute;
	}

	.hero-title {
		padding-top: 4rem;
		margin-bottom: 1rem;
	}

	.hero-route {
		margin-bottom: 1rem;
	}

	.hero-excerpt {
		margin-bottom: 1.5rem;
	}

	.hero-meta {
		margin-bottom: 1.5rem;
	}

	.hero-actions {
		margin-top: 1.5rem;
	}

	.hero-content-wrapper {
		padding: 0 1.25rem;
	}

	.destination-badge {
		font-size: 0.75rem;
		padding: 0.5rem 1rem;
	}

	.section-title {
		flex-direction: column;
		gap: 1rem;
	}

	.title-line {
		max-width: 60px;
	}

	.included-grid {
		grid-template-columns: 1fr;
	}

	.date-card {
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem;
		padding: 1.5rem;
	}

	.date-info {
		flex-wrap: wrap;
	}

	.logistics-grid {
		grid-template-columns: 1fr;
	}

	.addon-meta {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}

	.cta-actions {
		width: 100%;
	}

	.btn-sacred-large,
	.btn-outline-sacred {
		width: 100%;
		justify-content: center;
	}
}

/* ============================================================================
   Modal Styles
   ========================================================================= */

.pilgrimage-modal {
	position: fixed;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 99999;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s, visibility 0.3s;
	pointer-events: none;
}

.pilgrimage-modal.active {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.modal-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	cursor: pointer;
	pointer-events: auto;
	z-index: 1;
}

.modal-content {
	position: relative;
	z-index: 100000;
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	max-width: 700px;
	width: 90%;
	max-height: 90vh;
	overflow-y: auto;
	animation: slideUp 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: auto;
	isolation: isolate;
}

@keyframes slideUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.modal-close {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f5f3ef;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	color: var(--sacred-blue-deep);
	transition: all 0.2s;
	z-index: var(--z-modal);
	padding: 0;
	pointer-events: auto;
}

.modal-close:hover {
	background: var(--sacred-gold);
	color: #ffffff;
	transform: rotate(90deg);
}

.modal-inner {
	padding: 3rem 2rem;
	position: relative;
	z-index: 2;
	pointer-events: auto;
}

.modal-title {
	font-family: var(--font-serif);
	font-size: 2rem;
	font-weight: 600;
	color: var(--sacred-blue-deep);
	margin: 0 0 1rem;
	line-height: 1.2;
}

.modal-description {
	font-size: 1rem;
	line-height: 1.6;
	color: var(--sacred-text-light);
	margin: 0 0 2rem;
}

/* Form Styles */
.signup-form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	pointer-events: auto;
	position: relative;
	z-index: 2;
}

.form-group {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	pointer-events: auto;
	position: relative;
	z-index: 2;
}

.form-group label {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--sacred-blue-deep);
	pointer-events: auto;
}

.form-group input {
	padding: 0.875rem 1rem;
	border: 2px solid var(--sacred-ivory);
	border-radius: 8px;
	font-size: 1rem;
	font-family: inherit;
	transition: all 0.2s;
	pointer-events: auto;
	position: relative;
	z-index: 2;
}

.form-group input:focus {
	outline: none;
	border-color: var(--sacred-gold);
	box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.1);
}

.form-group input::placeholder {
	color: var(--sacred-text-light);
	opacity: 0.6;
}

.btn-submit-form {
	padding: 1rem 1.5rem;
	background: var(--sacred-gold);
	color: var(--sacred-blue-deep);
	font-size: 1rem;
	font-weight: 700;
	border: 2px solid var(--sacred-gold);
	border-radius: 8px;
	cursor: pointer;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	margin-top: 0.5rem;
	pointer-events: auto;
	position: relative;
	z-index: 2;
}

.btn-submit-form:hover {
	background: var(--sacred-gold-light);
	border-color: var(--sacred-gold-light);
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(212, 175, 55, 0.25);
}

.btn-submit-form:active {
	transform: translateY(0);
}

/* Zoho Form in Modal Styling */
.signup-form-container {
	margin-top: 1.5rem;
}

.signup-form-container iframe {
	border-radius: 8px;
	max-height: 70vh;
}

/* Make buttons work as modal triggers */
.btn-sacred,
.btn-sacred-large {
	cursor: pointer;
}

/* Modal responsive */
@media (max-width: 640px) {
	.modal-content {
		width: 95%;
		border-radius: 12px;
	}

	.modal-inner {
		padding: 2rem 1.5rem;
	}

	.modal-title {
		font-size: 1.5rem;
	}

	.modal-close {
		width: 36px;
		height: 36px;
		top: 1rem;
		right: 1rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

/* Source: contact-card.css */
/**
 * Organization Contact Card Styles
 *
 * Branded contact card component matching CCC design system.
 * Uses design tokens for colors, spacing, and typography.
 *
 * @package HelloElementorChild
 * @since 1.0.0
 */

/* ============================================================================
   Contact Card Base
   ============================================================================ */

.org-contact-card {
	background: #ffffff;
	border-radius: 12px;
	box-shadow: 0 4px 12px rgba(47, 64, 137, 0.15);
	overflow: hidden;
	transition: all 0.3s ease;
	max-width: 500px;
	margin: 2rem auto;
}

.org-contact-card:hover {
	box-shadow: 0 8px 24px rgba(47, 64, 137, 0.25);
	transform: translateY(-4px);
}

/* ============================================================================
   Header
   ============================================================================ */

.org-contact-card__header {
	background: linear-gradient(135deg, var(--color-primary, #2f4089) 0%, var(--color-secondary, #4b96da) 100%);
	padding: 2rem 1.5rem;
	text-align: center;
}

.org-contact-card__title {
	color: #ffffff;
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0;
	text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* ============================================================================
   Body
   ============================================================================ */

.org-contact-card__body {
	padding: 2rem 1.5rem;
}

.org-contact-card__item {
	display: flex;
	gap: 1rem;
	margin-bottom: 1.5rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid #e5e7eb;
}

.org-contact-card__item:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}

/* Icon */
.org-contact-card__icon {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	background: linear-gradient(135deg, var(--color-primary, #2f4089) 0%, var(--color-secondary, #4b96da) 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	font-size: 1.125rem;
	box-shadow: 0 2px 8px rgba(47, 64, 137, 0.2);
}

.org-contact-card__content {
	flex: 1;
	min-width: 0;
}

.org-contact-card__label {
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-primary, #2f4089);
	margin-bottom: 0.5rem;
}

.org-contact-card__value {
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	color: #1f233a;
	text-decoration: none;
	transition: color 0.2s ease;
	word-break: break-word;
}

.org-contact-card__value--secondary {
	font-size: 0.875rem;
	margin-top: 0.25rem;
	color: #5c6483;
}

/* Links */
a.org-contact-card__value:hover {
	color: var(--color-secondary, #4b96da);
}

a.org-contact-card__value:focus {
	outline: 2px solid var(--color-secondary, #4b96da);
	outline-offset: 2px;
	border-radius: 4px;
}

/* Badge */
.org-contact-card__badge {
	display: inline-block;
	background: var(--color-background, #eef2f9);
	color: var(--color-primary, #2f4089);
	font-size: 0.625rem;
	font-weight: 600;
	text-transform: uppercase;
	padding: 0.25rem 0.5rem;
	border-radius: 4px;
	margin-left: 0.5rem;
	letter-spacing: 0.05em;
}

/* External Link Icon */
.org-contact-card__external-icon {
	font-size: 0.75rem;
	margin-left: 0.5rem;
	opacity: 0.6;
}

a.org-contact-card__value:hover .org-contact-card__external-icon {
	opacity: 1;
}

/* ============================================================================
   Social Links
   ============================================================================ */

.org-contact-card__social-links {
	display: flex;
	gap: 0.75rem;
	margin-top: 0.75rem;
}

.org-contact-card__social-link {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--color-background, #eef2f9);
	color: var(--color-primary, #2f4089);
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	transition: all 0.2s ease;
	font-size: 1.125rem;
}

.org-contact-card__social-link:hover {
	background: var(--color-primary, #2f4089);
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 8px rgba(47, 64, 137, 0.3);
}

.org-contact-card__social-link:focus {
	outline: 2px solid var(--color-secondary, #4b96da);
	outline-offset: 2px;
}

/* ============================================================================
   Footer
   ============================================================================ */

.org-contact-card__footer {
	background: var(--color-background, #eef2f9);
	padding: 1.5rem;
	text-align: center;
	border-top: 1px solid rgba(47, 64, 137, 0.1);
}

.org-contact-card__tagline {
	margin: 0;
	font-size: 0.875rem;
	color: var(--color-primary, #2f4089);
	font-weight: 500;
	font-style: italic;
}

/* ============================================================================
   Background Variants
   ============================================================================ */

/* Light Background (Default) */
.org-contact-card--bg-light {
	background: #ffffff;
}

/* Dark Background */
.org-contact-card--bg-dark {
	background: var(--color-primary, #2f4089);
}

.org-contact-card--bg-dark .org-contact-card__label {
	color: var(--color-accent, #8eb8c5);
}

.org-contact-card--bg-dark .org-contact-card__value {
	color: #ffffff;
}

.org-contact-card--bg-dark .org-contact-card__item {
	border-bottom-color: rgba(255, 255, 255, 0.1);
}

.org-contact-card--bg-dark .org-contact-card__icon {
	background: rgba(255, 255, 255, 0.2);
}

.org-contact-card--bg-dark .org-contact-card__badge {
	background: rgba(255, 255, 255, 0.2);
	color: #ffffff;
}

.org-contact-card--bg-dark .org-contact-card__social-link {
	background: rgba(255, 255, 255, 0.2);
	color: #ffffff;
}

.org-contact-card--bg-dark .org-contact-card__social-link:hover {
	background: #ffffff;
	color: var(--color-primary, #2f4089);
}

/* Gradient Background */
.org-contact-card--bg-gradient {
	background: linear-gradient(135deg, var(--color-primary, #2f4089) 0%, var(--color-secondary, #4b96da) 100%);
}

.org-contact-card--bg-gradient .org-contact-card__header {
	background: rgba(255, 255, 255, 0.1);
}

.org-contact-card--bg-gradient .org-contact-card__label {
	color: var(--color-accent, #8eb8c5);
}

.org-contact-card--bg-gradient .org-contact-card__value {
	color: #ffffff;
}

.org-contact-card--bg-gradient .org-contact-card__item {
	border-bottom-color: rgba(255, 255, 255, 0.1);
}

.org-contact-card--bg-gradient .org-contact-card__icon {
	background: rgba(255, 255, 255, 0.2);
}

.org-contact-card--bg-gradient .org-contact-card__footer {
	background: rgba(0, 0, 0, 0.1);
	border-top-color: rgba(255, 255, 255, 0.1);
}

.org-contact-card--bg-gradient .org-contact-card__tagline {
	color: #ffffff;
}

/* Transparent Background (for dark backgrounds) */
.org-contact-card--bg-transparent {
	background: transparent;
	box-shadow: none;
	border: 1px solid rgba(255, 255, 255, 0.15);
}

.org-contact-card--bg-transparent:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
	border-color: rgba(255, 255, 255, 0.25);
}

.org-contact-card--bg-transparent .org-contact-card__header {
	background: transparent;
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.org-contact-card--bg-transparent .org-contact-card__title {
	color: #ffffff;
}

.org-contact-card--bg-transparent .org-contact-card__label {
	color: var(--color-accent, #8eb8c5);
}

.org-contact-card--bg-transparent .org-contact-card__value {
	color: #ffffff;
}

.org-contact-card--bg-transparent .org-contact-card__value--secondary {
	color: rgba(255, 255, 255, 0.75);
}

.org-contact-card--bg-transparent .org-contact-card__item {
	border-bottom-color: rgba(255, 255, 255, 0.1);
}

.org-contact-card--bg-transparent .org-contact-card__icon {
	background: rgba(255, 255, 255, 0.15);
	color: #ffffff;
}

.org-contact-card--bg-transparent .org-contact-card__badge {
	background: rgba(255, 255, 255, 0.15);
	color: #ffffff;
}

.org-contact-card--bg-transparent .org-contact-card__social-link {
	background: rgba(255, 255, 255, 0.15);
	color: #ffffff;
}

.org-contact-card--bg-transparent .org-contact-card__social-link:hover {
	background: #ffffff;
	color: var(--color-primary, #2f4089);
}

.org-contact-card--bg-transparent .org-contact-card__footer {
	background: transparent;
	border-top-color: rgba(255, 255, 255, 0.15);
}

.org-contact-card--bg-transparent .org-contact-card__tagline {
	color: rgba(255, 255, 255, 0.8);
}

/* ============================================================================
   Style Variants
   ============================================================================ */

/* Minimal Style */
.org-contact-card--minimal {
	box-shadow: 0 2px 8px rgba(47, 64, 137, 0.1);
	border: 1px solid var(--color-background, #eef2f9);
}

.org-contact-card--minimal:hover {
	box-shadow: 0 4px 12px rgba(47, 64, 137, 0.15);
}

.org-contact-card--minimal .org-contact-card__body {
	padding: 1.5rem;
}

.org-contact-card--minimal .org-contact-card__icon {
	width: 36px;
	height: 36px;
	font-size: 1rem;
}

/* Compact Style */
.org-contact-card--compact .org-contact-card__body {
	padding: 1rem;
}

.org-contact-card--compact .org-contact-card__item {
	margin-bottom: 1rem;
	padding-bottom: 1rem;
}

.org-contact-card--compact .org-contact-card__icon {
	width: 32px;
	height: 32px;
	font-size: 0.875rem;
}

.org-contact-card--compact .org-contact-card__label {
	font-size: 0.625rem;
}

.org-contact-card--compact .org-contact-card__value {
	font-size: 0.875rem;
}

/* ============================================================================
   Responsive Design
   ============================================================================ */

@media (max-width: 768px) {
	.org-contact-card {
		margin: 1.5rem auto;
		max-width: 100%;
	}

	.org-contact-card__header {
		padding: 1.5rem 1rem;
	}

	.org-contact-card__title {
		font-size: 1.25rem;
	}

	.org-contact-card__body {
		padding: 1.5rem 1rem;
	}

	.org-contact-card__item {
		gap: 0.75rem;
		margin-bottom: 1.25rem;
		padding-bottom: 1.25rem;
	}

	.org-contact-card__icon {
		width: 40px;
		height: 40px;
		font-size: 1rem;
	}

	.org-contact-card__social-links {
		gap: 0.5rem;
	}

	.org-contact-card__social-link {
		width: 36px;
		height: 36px;
		font-size: 1rem;
	}
}

@media (max-width: 480px) {
	.org-contact-card__item {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}

	.org-contact-card__icon {
		width: 36px;
		height: 36px;
	}
}

/* ============================================================================
   Grid Layout
   ============================================================================ */

/* Grid Container */
.org-contact-card--grid {
	max-width: 100%;
	margin: 0;
	box-shadow: none;
	background: transparent;
	display: block;
}

.org-contact-card--grid:hover {
	box-shadow: none;
	transform: none;
}

/* Grid Header */
.org-contact-card__grid-header {
	margin-bottom: 2rem;
	padding: 0 1rem;
}

.org-contact-card__grid-title {
	margin: 0;
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-primary, #2f4089);
	font-family: var(--font-family-primary, 'Figtree', sans-serif);
}

/* Grid Items Container */
.org-contact-card--grid .org-contact-card__grid {
	display: grid;
	gap: 2rem 1.5rem;
	grid-template-columns: repeat(4, 1fr);
}

/* Grid Item Cards */
.org-contact-card--grid .org-contact-card__grid > .org-contact-card {
	margin: 0;
	max-width: 100%;
}

/* Four Column Layout */
.org-contact-card--grid-cols-4 .org-contact-card__grid {
	grid-template-columns: repeat(4, 1fr);
}

/* Three Column Layout */
.org-contact-card--grid-cols-3 .org-contact-card__grid {
	grid-template-columns: repeat(3, 1fr);
}

/* Two Column Layout */
.org-contact-card--grid-cols-2 .org-contact-card__grid {
	grid-template-columns: repeat(2, 1fr);
}

/* ============================================================================
   Grid Layout - Responsive Design
   ============================================================================ */

/* Tablet: 2 columns */
@media (max-width: 1024px) {
	.org-contact-card--grid-cols-4 .org-contact-card__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.5rem 1rem;
	}

	.org-contact-card--grid-cols-3 .org-contact-card__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.5rem 1rem;
	}
}

/* Mobile: 1 column */
@media (max-width: 768px) {
	.org-contact-card--grid {
		padding: 0;
	}

	.org-contact-card__grid-header {
		margin-bottom: 1.5rem;
		padding: 0;
	}

	.org-contact-card__grid-title {
		font-size: 1.5rem;
	}

	.org-contact-card--grid-cols-4 .org-contact-card__grid,
	.org-contact-card--grid-cols-3 .org-contact-card__grid,
	.org-contact-card--grid-cols-2 .org-contact-card__grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.org-contact-card--grid .org-contact-card__grid > .org-contact-card {
		max-width: 100%;
	}
}

@media (max-width: 480px) {
	.org-contact-card__grid-title {
		font-size: 1.25rem;
	}

	.org-contact-card--grid .org-contact-card__grid {
		gap: 1rem;
	}
}

/* ============================================================================
   Print Styles
   ============================================================================ */

@media print {
	.org-contact-card {
		box-shadow: none;
		border: 1px solid #ccc;
		break-inside: avoid;
	}

	.org-contact-card:hover {
		transform: none;
	}

	.org-contact-card__social-links {
		display: none;
	}
}

/* Source: footer-card.css */
/**
 * Organization Footer Card Styles
 *
 * Footer-optimized contact card with logo and horizontal layout.
 * Designed for dark footer backgrounds.
 *
 * @package HelloElementorChild
 * @since 1.0.0
 */

/* ============================================================================
   Footer Full-Width Override
   ============================================================================ */

/* Remove parent theme's max-width constraint on footer */
.site-footer,
.site-footer .footer-inner {
	max-width: 100% !important;
	width: 100%;
	margin-left: 0;
	margin-right: 0;
}

/* Ensure footer doesn't inherit page container constraints */
.site-footer.dynamic-footer {
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
}

/* ============================================================================
   Footer Card Base
   ============================================================================ */

.org-footer-card {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 3rem;
	padding: 3rem 2rem;
	width: 100%;
	flex: 1 1 100%;
	min-width: 0;
	color: #ffffff;
}

/* ============================================================================
   Brand Section (Logo + Tagline)
   ============================================================================ */

.org-footer-card__brand {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.org-footer-card__logo {
	max-width: 200px;
	height: auto;
	filter: brightness(0) invert(1); /* Make logo white on dark background */
}

.org-footer-card__name {
	color: #ffffff;
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0;
	line-height: 1.2;
}

.org-footer-card__tagline {
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.875rem;
	font-style: italic;
	margin: 0;
	line-height: 1.5;
	max-width: 250px;
}

/* ============================================================================
   Info Section (Contact Columns)
   ============================================================================ */

.org-footer-card__info {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 2rem;
}

.org-footer-card__column {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.org-footer-card__title {
	color: var(--color-accent, #8eb8c5);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin: 0 0 0.5rem 0;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.org-footer-card__link {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	color: rgba(255, 255, 255, 0.85);
	text-decoration: none;
	font-size: 0.875rem;
	line-height: 1.5;
	transition: color 0.2s ease, transform 0.2s ease;
}

.org-footer-card__link:hover {
	color: #ffffff;
	transform: translateX(4px);
}

.org-footer-card__link:focus {
	outline: 2px solid var(--color-accent, #8eb8c5);
	outline-offset: 2px;
	border-radius: 4px;
}

.org-footer-card__link i {
	flex-shrink: 0;
	width: 16px;
	opacity: 0.6;
	margin-top: 2px;
}

.org-footer-card__link:hover i {
	opacity: 1;
}

/* ============================================================================
   Social Links
   ============================================================================ */

.org-footer-card__social {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}

.org-footer-card__social-link {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.1);
	color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	transition: all 0.2s ease;
	font-size: 1.125rem;
	border: 1px solid rgba(255, 255, 255, 0.15);
}

.org-footer-card__social-link:hover {
	background: rgba(255, 255, 255, 0.2);
	border-color: rgba(255, 255, 255, 0.3);
	transform: translateY(-2px);
}

.org-footer-card__social-link:focus {
	outline: 2px solid var(--color-accent, #8eb8c5);
	outline-offset: 2px;
}

/* ============================================================================
   Layout Variants
   ============================================================================ */

/* Stacked Layout */
.org-footer-card--stacked {
	grid-template-columns: 1fr;
	gap: 2rem;
	text-align: center;
}

.org-footer-card--stacked .org-footer-card__brand {
	align-items: center;
}

.org-footer-card--stacked .org-footer-card__logo {
	margin: 0 auto;
}

.org-footer-card--stacked .org-footer-card__tagline {
	max-width: 100%;
}

.org-footer-card--stacked .org-footer-card__info {
	justify-items: center;
}

.org-footer-card--stacked .org-footer-card__column {
	align-items: center;
	text-align: center;
}

.org-footer-card--stacked .org-footer-card__link {
	justify-content: center;
}

.org-footer-card--stacked .org-footer-card__social {
	justify-content: center;
}

/* ============================================================================
   Responsive Design
   ============================================================================ */

@media (max-width: 1024px) {
	.org-footer-card {
		grid-template-columns: 1fr;
		gap: 2.5rem;
		padding: 2.5rem 1.5rem;
	}

	.org-footer-card__info {
		grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
		gap: 1.5rem;
	}
}

@media (max-width: 768px) {
	.org-footer-card {
		gap: 2rem;
		padding: 2rem 1rem;
	}

	.org-footer-card__brand {
		align-items: center;
		text-align: center;
	}

	.org-footer-card__logo {
		margin: 0 auto;
		max-width: 160px;
	}

	.org-footer-card__tagline {
		max-width: 100%;
	}

	.org-footer-card__info {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.org-footer-card__column {
		align-items: center;
		text-align: center;
	}

	.org-footer-card__title {
		text-align: center;
	}

	.org-footer-card__link {
		justify-content: center;
	}

	.org-footer-card__social {
		justify-content: center;
	}
}

@media (max-width: 480px) {
	.org-footer-card {
		padding: 1.5rem 0.75rem;
	}

	.org-footer-card__logo {
		max-width: 140px;
	}

	.org-footer-card__name {
		font-size: 1.25rem;
	}

	.org-footer-card__info {
		gap: 1.5rem;
	}

	.org-footer-card__link {
		font-size: 0.8125rem;
	}

	.org-footer-card__social-link {
		width: 36px;
		height: 36px;
		font-size: 1rem;
	}
}

/* ============================================================================
   Print Styles
   ============================================================================ */

@media print {
	.org-footer-card__social {
		display: none;
	}

	.org-footer-card__link:hover {
		transform: none;
	}
}
