/* ========================================
   LAYERS + TOKENS
   ======================================== */
   @layer reset, base, components, utilities;

   @layer base {
     :root {
       /* Brand */
       --red-pantone: #e63946;
       --honeydew: #f1faee;
       --non-photo-blue: #a8dadc;
       --cerulean: #457b9d;
       --berkeley-blue: #1d3557;
   
       /* Neutrals & surfaces */
       --bg: #ffffff;
       --fg: var(--berkeley-blue);
       --surface: #ffffff;
       --surface-muted: #f8f9fa;
   
      /* Typography & rhythm */
      --font-sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Verdana, Geneva, Tahoma, sans-serif;
      --fs-xs: clamp(.78rem, .74rem + .2vw, .88rem);
      --fs-sm: clamp(.9rem, .85rem + .25vw, 1rem);
      --fs-md: clamp(1rem, .95rem + .4vw, 1.2rem);
      --fs-lg: clamp(1.6rem, 1.1rem + 2.5vw, 3rem);
      --fs-xl: clamp(2rem, 1.5rem + 3vw, 4rem);
   
       /* Spacing & radii */
       --space-1: .25rem; --space-2: .5rem; --space-3: .75rem;
       --space-4: 1rem;  --space-5: 1.5rem; --space-6: 2rem;
       --radius-sm: .375rem; --radius-md: .5rem; --radius-lg: .75rem; --radius-xl: 1rem;
   
       /* Elevation */
      --shadow-1: 0 1px 2px rgb(0 0 0 / .08);
      --shadow-2: 0 2px 8px rgb(0 0 0 / .12);
      --shadow-3: 0 10px 30px rgb(0 0 0 / .15);
    }
  
    /* Dark theme disabled - light mode only */
    /* @media (prefers-color-scheme: dark) {
      :root {
        --bg: #0e1525;
        --fg: #e6eef9;
        --surface: #121a2b;
        --surface-muted: #0f1626;
        --cerulean: #6fb0e6;
        --berkeley-blue: #dce6ff;
        --non-photo-blue: #2a3a55;
        --shadow-1: 0 1px 2px rgb(0 0 0 / .45);
        --shadow-2: 0 2px 8px rgb(0 0 0 / .5);
        --shadow-3: 0 10px 30px rgb(0 0 0 / .55);
      }
    } */
  }
   
   /* ========================================
      RESET
      ======================================== */
   @layer reset {
     *, *::before, *::after { box-sizing: border-box; }
     html, body { height: 100%; }
     body {
       margin: 0;
       font-family: var(--font-sans);
       color: var(--fg);
       background: var(--bg);
       -webkit-font-smoothing: antialiased;
       text-rendering: optimizeLegibility;
     }
     img, svg, video, canvas { display: block; max-width: 100%; }
   }
   
   /* ========================================
      BASE
      ======================================== */
   @layer base {
     a {
       color: var(--cerulean);
       text-decoration: none;
       font-weight: 600;
     }
     a:hover { color: var(--red-pantone); text-decoration: underline; }
   
     header {
       margin-block-end: 1.5rem;
       padding: 2.5rem 1.25rem;
       color: white;
       text-align: center;
       background: linear-gradient(135deg, #b31217 0%, #8b0000 50%, #d11a2a 100%);
       box-shadow: 0 4px 12px rgba(90, 24, 154, 0.4);
     }
    header h1 {
      margin: 0 0 .75rem 0;
      font-size: var(--fs-lg);
      font-weight: 900;
      letter-spacing: -0.01em;
      /* Fallback color */
      color: white;
      /* Modern gradient text effect */
      background: linear-gradient(135deg, 
        #ffffff 0%, 
        #f1faee 40%,
        #a8dadc 80%,
        #ffffff 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      text-shadow: none;
      /* Add a subtle glow effect */
      filter: drop-shadow(0 2px 8px rgba(255, 255, 255, 0.3));
      animation: header-shine 4s ease-in-out infinite;
    }
    
    /* Subtle shine animation for main title */
    @keyframes header-shine {
      0%, 100% { 
        filter: drop-shadow(0 2px 8px rgba(255, 255, 255, 0.3)) brightness(1);
      }
      50% { 
        filter: drop-shadow(0 4px 12px rgba(255, 255, 255, 0.5)) brightness(1.15);
      }
    }
    
    /* Support for browsers without background-clip */
    @supports not (-webkit-background-clip: text) {
      header h1 {
        color: white;
        -webkit-text-fill-color: unset;
        text-shadow: 2px 2px 4px rgb(0 0 0 / .3);
      }
    }
     header > p {
       margin: 0;
       font-size: var(--fs-sm);
       color: var(--honeydew);
       opacity: .95;
     }
   
     main {
       max-width: 75rem; /* 1200px */
       margin-inline: auto;
       padding-inline: 1.25rem;
     }
   
     footer {
       margin-block-start: 2.5rem;
       padding: 1.5rem 1.25rem;
       text-align: center;
       color: var(--cerulean);
       border-top: 2px solid var(--non-photo-blue);
       background: var(--surface-muted);
     }
     .footer-content {
       display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap;
       gap: .75rem; max-width: 75rem; margin: 0 auto 1rem;
     }
     .feedback-line { margin: 0; font-size: .9rem; color: var(--berkeley-blue); }
     .feedback-line a { color: var(--cerulean); text-decoration: underline; font-weight: 700; }
     .feedback-line a:hover { color: var(--red-pantone); }
     .last-updated { margin: 0; font-size: .8rem; color: var(--cerulean); font-style: italic; }
   
    /* Accessibility niceties */
    :focus-visible { outline: 3px solid var(--cerulean); outline-offset: 3px; border-radius: var(--radius-sm); }
  }
  
  /* Reduced motion preferences - at root level for better performance */
  @media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.01ms !important;
      scroll-behavior: auto !important;
    }
    /* Specifically disable modal animations */
    .modal[open] .modal-content { animation: none !important; }
    .close-btn, .register-button { transition: none !important; }
    .modal-title { animation: none !important; }
    .modal-header::before { animation: none !important; opacity: 0.4 !important; }
    header h1 { animation: none !important; filter: drop-shadow(0 2px 8px rgba(255, 255, 255, 0.3)) !important; }
   }
   
   /* ========================================
      COMPONENTS
      ======================================== */
   @layer components {
     /* Summary stats */
     .summary { margin: .6rem 0 1rem; }
   
    /* Make the grid component-responsive with container queries */
    .summary-card {
      display: grid;
      gap: .5rem;
      grid-template-columns: repeat(5, minmax(5rem, 1fr)); /* Reduced from 110px to 80px for better mobile fit */
      border: 2px solid var(--cerulean);
      background: var(--surface);
      padding: .75rem;
      border-radius: var(--radius-md);
      box-shadow: var(--shadow-1);
      overflow: hidden; /* Prevent overflow on mobile */
    }
    
    /* Fallback for browsers without container query support */
    @supports not (container-type: inline-size) {
      @media (max-width: 50rem) {
        .summary-card { grid-template-columns: repeat(5, 1fr); }
      }
      @media (max-width: 40rem) {
        .summary-card { grid-template-columns: repeat(2, 1fr); }
      }
    }
    
    /* Modern container queries for supported browsers */
    @supports (container-type: inline-size) {
      .summary-card {
        container-type: inline-size;
      }
      @container (max-width: 50rem) {
        .summary-card { grid-template-columns: repeat(3, 1fr); }
      }
      @container (max-width: 40rem) {
        .summary-card { grid-template-columns: repeat(3, 1fr); }
      }
    }
   
    .summary-item {
      text-align: center;
      padding: .75rem .375rem;
      border-radius: var(--radius-sm);
      transition: background .2s ease, transform .15s ease, box-shadow .2s ease;
    }
    .summary-item:hover { background: var(--surface-muted); }
    
    /* Clickable statistics - Interactive states */
    .summary-item.clickable-stat {
      cursor: pointer;
      border: 1px solid transparent;
    }
    .summary-item.clickable-stat:hover {
      background: color-mix(in oklab, var(--cerulean), transparent 92%);
      transform: translateY(-2px);
      box-shadow: 0 4px 12px rgba(69, 123, 157, 0.15);
      border-color: color-mix(in oklab, var(--cerulean), transparent 70%);
    }
    .summary-item.clickable-stat:active {
      transform: translateY(0);
      box-shadow: 0 2px 6px rgba(69, 123, 157, 0.1);
    }
   
     .summary-number {
       font-size: 1.5rem;
       font-weight: 800;
       color: var(--cerulean);
     }
     .summary-label {
       font-size: .75rem;
       color: var(--berkeley-blue);
       text-transform: uppercase;
       letter-spacing: .06em;
       font-weight: 700;
     }
     .summary-sub { font-size: .75rem; color: var(--cerulean); }
   
     /* Map container */
     .map-container {
       display: block;
       margin-block: 1.875rem;
       padding: 1.875rem;
       background: linear-gradient(145deg, var(--surface-muted), var(--surface));
       border-radius: var(--radius-xl);
       box-shadow: var(--shadow-3), inset 0 1px 2px rgb(255 255 255 / .9);
     }
   
    #map {
      width: 100%;
      max-width: 68.75rem; /* 1100px */
      margin-inline: auto;
      background: var(--surface);
      border-radius: var(--radius-lg);
      padding: 1.25rem;
      box-shadow: 0 8px 24px rgb(0 0 0 / .12), 0 2px 8px rgb(0 0 0 / .08), inset 0 -2px 4px rgb(0 0 0 / .03);
      filter: drop-shadow(0 4px 6px rgb(0 0 0 / .05));
      position: relative;
    }
    
    /* Aspect ratio with fallback for older browsers */
    @supports not (aspect-ratio: 1) {
      #map {
        /* Fallback: 959/593 ≈ 61.8% height */
        padding-bottom: 61.8%;
        height: 0;
      }
    }
    @supports (aspect-ratio: 1) {
      #map {
        aspect-ratio: 959 / 593;
      }
    }
    #map::before {
      content: "";
      position: absolute; inset: 0;
      /* Fallback for browsers without color-mix support */
      background: linear-gradient(135deg,
        rgba(168, 218, 220, 0.05) 0%,
        transparent 50%,
        rgba(69, 123, 157, 0.03) 100%);
      /* Modern color-mix for supported browsers */
      background: linear-gradient(135deg,
        color-mix(in oklab, var(--non-photo-blue), transparent 95%) 0%,
        transparent 50%,
        color-mix(in oklab, var(--cerulean), transparent 97%) 100%);
      border-radius: inherit;
      pointer-events: none;
    }
   
    /* ========================================
       MODAL / POPUP WINDOW (Glass Morphism Design)
       ======================================== */
    
    /* Backdrop - Softer glass effect with gradient overlay */
    .modal {
      display: none;
      position: fixed; inset: 0; z-index: 1000;
      /* Fallback for older browsers */
      background: rgba(29, 53, 87, 0.5);
      /* Modern gradient overlay */
      background: linear-gradient(180deg, rgb(29 53 87 / .60), rgb(29 53 87 / .35));
      -webkit-backdrop-filter: blur(6px) saturate(110%);
      backdrop-filter: blur(6px) saturate(110%);
    }
    .modal[open] { display: grid; place-items: center; }
    
    /* Modal Content - Glass card with gradient border */
    .modal-content {
      position: relative;
      width: min(90vw, 45rem);
      max-height: 85vh; /* Prevent modal from being taller than viewport */
      margin: 0; /* centered by grid on parent */
      padding: 1.25rem 1.25rem 1rem;
      border-radius: var(--radius-lg);
      /* Fallback background */
      background: var(--surface);
      /* Modern subtle gradient */
      background: linear-gradient(180deg, 
        color-mix(in oklab, var(--surface), white 6%), 
        color-mix(in oklab, var(--surface), #000 2%));
      box-shadow: 0 20px 60px rgb(0 0 0 / .25), var(--shadow-2);
      border: 0;
      outline: 1.5px solid transparent; /* fallback */
      display: flex;
      flex-direction: column;
    }
    
    /* Layered gradient border ring effect */
    .modal-content::before {
      content: "";
      position: absolute; inset: -1px;
      border-radius: inherit;
      padding: 1px;
      /* Fallback border */
      background: var(--cerulean);
      /* Modern gradient border */
      background: linear-gradient(135deg, 
        color-mix(in oklab, var(--cerulean), white 20%), 
        transparent 30%, 
        color-mix(in oklab, var(--non-photo-blue), white 20%));
      -webkit-mask:
        linear-gradient(#000 0 0) content-box, 
        linear-gradient(#000 0 0);
      -webkit-mask-composite: xor;
      mask:
        linear-gradient(#000 0 0) content-box, 
        linear-gradient(#000 0 0);
      mask-composite: exclude;
      pointer-events: none;
    }
    
    /* Enter animation - Smooth pop-in effect */
    @keyframes modal-pop {
      from { transform: translateY(10px) scale(.98); opacity: 0; }
      to   { transform: translateY(0) scale(1); opacity: 1; }
    }
    .modal[open] .modal-content {
      animation: modal-pop .18s ease-out both;
    }
    
    /* Modal Header - Title bar with divider */
    .modal-header {
      display: flex; align-items: center; gap: .75rem;
      padding: .5rem .25rem 1rem;
      /* Fallback border */
      border-bottom: 2px solid var(--non-photo-blue);
      /* Modern gradient border */
      border-bottom: 2px solid transparent;
      border-image: linear-gradient(90deg, 
        color-mix(in oklab, var(--cerulean), transparent 30%), 
        color-mix(in oklab, var(--non-photo-blue), transparent 50%),
        transparent) 1;
      margin-bottom: 1rem;
      flex-shrink: 0; /* Keep header fixed size */
      position: relative;
    }
    
    /* Decorative accent before title */
    .modal-header::before {
      content: "★";
      position: absolute;
      left: -0.5rem;
      top: 0.5rem;
      font-size: 1.2rem;
      color: var(--cerulean);
      opacity: 0.4;
      animation: star-pulse 2s ease-in-out infinite;
    }
    
    @keyframes star-pulse {
      0%, 100% { 
        opacity: 0.4;
        transform: scale(1);
      }
      50% { 
        opacity: 0.7;
        transform: scale(1.1);
      }
    }
    
    /* Animated gradient underline */
    .modal-header::after {
      content: "";
      position: absolute;
      bottom: -2px;
      left: 0;
      right: 0;
      height: 2px;
      background: linear-gradient(90deg, 
        var(--cerulean) 0%, 
        var(--non-photo-blue) 50%,
        transparent 100%);
      opacity: 0.6;
    }
    
    .modal-title {
      font-size: clamp(1.5rem, 4vw, 2rem);
      font-weight: 900;
      /* Fallback color */
      color: var(--berkeley-blue);
      /* Modern gradient text */
      background: linear-gradient(135deg, 
        var(--berkeley-blue) 0%, 
        var(--cerulean) 60%,
        color-mix(in oklab, var(--cerulean), white 20%) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      letter-spacing: -0.02em;
      line-height: 1.2;
      text-shadow: 0 2px 12px rgba(69, 123, 157, 0.15);
      animation: title-shine 3s ease-in-out infinite;
    }
    
    /* Subtle shine animation on title */
    @keyframes title-shine {
      0%, 100% { 
        filter: brightness(1);
      }
      50% { 
        filter: brightness(1.1);
      }
    }
    
    /* Support for browsers without background-clip */
    @supports not (-webkit-background-clip: text) {
      .modal-title {
        color: var(--berkeley-blue);
        -webkit-text-fill-color: unset;
      }
    }
    
    /* Close Button - Circular with better hit target */
    .close-btn {
      position: absolute; inset-block-start: .6rem; inset-inline-end: .6rem;
      display: grid; place-items: center;
      width: 2rem; height: 2rem; line-height: 1;
      border-radius: 999px;
      font-size: 1.1rem; font-weight: 700;
      color: var(--cerulean);
      /* Fallback background */
      background: rgba(168, 218, 220, 0.1);
      /* Modern color-mix */
      background: color-mix(in oklab, var(--cerulean), transparent 94%);
      /* Fallback border */
      border: 1px solid rgba(168, 218, 220, 0.25);
      /* Modern border */
      box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--cerulean), transparent 75%);
      transition: transform .12s ease, background .15s ease, color .15s ease;
      cursor: pointer;
    }
    .close-btn:hover {
      /* Fallback */
      background: var(--cerulean);
      /* Modern color-mix */
      background: color-mix(in oklab, var(--cerulean), white 70%);
      color: white;
      transform: translateY(-1px);
    }
    .close-btn:focus-visible {
      outline: 3px solid var(--cerulean);
      outline-offset: 3px;
    }
    
    /* Modal Body - Content spacing with scroll */
    .modal-body {
      overflow-y: auto; /* Enable vertical scrolling */
      overflow-x: hidden; /* Prevent horizontal scroll */
      flex: 1; /* Take up remaining space */
      min-height: 0; /* Important for flex scrolling */
      padding-right: .25rem; /* Space for scrollbar */
    }
    .modal-body > * + * { margin-block-start: .75rem; }
    
    /* Custom scrollbar styling for the modal */
    /* Firefox scrollbar */
    .modal-body {
      scrollbar-width: thin;
      scrollbar-color: color-mix(in oklab, var(--cerulean), transparent 40%) color-mix(in oklab, var(--non-photo-blue), transparent 90%);
    }
    /* Webkit (Chrome, Safari, Edge) scrollbar */
    .modal-body::-webkit-scrollbar {
      width: 8px;
    }
    .modal-body::-webkit-scrollbar-track {
      background: color-mix(in oklab, var(--non-photo-blue), transparent 90%);
      border-radius: 10px;
    }
    .modal-body::-webkit-scrollbar-thumb {
      background: color-mix(in oklab, var(--cerulean), transparent 40%);
      border-radius: 10px;
    }
    .modal-body::-webkit-scrollbar-thumb:hover {
      background: var(--cerulean);
    }
    
    /* Election Items - List styling */
    #modal-elections-list .election-item {
      margin: .4rem 0; padding: .75rem 0;
      /* Fallback border */
      border-top: 1px dashed var(--non-photo-blue);
      /* Modern subtle border */
      border-top: 1px dashed color-mix(in oklab, var(--non-photo-blue), transparent 50%);
    }
    #modal-elections-list .election-item:first-child { border-top: 0; }
    #modal-elections-list .election-item h4 {
      margin: 0 0 .375rem; font-size: 1rem; color: var(--cerulean); font-weight: 700;
    }
    
    /* Election Card - Enhanced card design for individual elections */
    .election-card {
      margin: 0.75rem 0;
      padding: 1rem;
      /* Fallback background */
      background: var(--surface-muted);
      /* Modern gradient background */
      background: linear-gradient(135deg, 
        color-mix(in oklab, var(--surface), white 4%),
        color-mix(in oklab, var(--surface), var(--non-photo-blue) 2%));
      border-radius: var(--radius-md);
      /* Fallback border */
      border: 1px solid var(--non-photo-blue);
      /* Modern border */
      border: 1px solid color-mix(in oklab, var(--non-photo-blue), transparent 70%);
      box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }
    .election-card:hover {
      transform: translateY(-2px);
      box-shadow: 0 4px 16px rgba(69, 123, 157, 0.12);
    }
    
    /* Election Badge - Colorful type indicators */
    .election-badge {
      display: inline-block;
      padding: 0.25rem 0.65rem;
      border-radius: 999px;
      font-size: 0.7rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      white-space: nowrap;
      box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
    }
    
    /* Registration Info Card - Highlighted section */
    .registration-info {
      margin-bottom: 0.75rem;
      /* Fallback gradient */
      background: linear-gradient(135deg, rgba(168, 218, 220, 0.15), rgba(69, 123, 157, 0.08));
      /* Modern radial + linear gradient combo */
      background:
        radial-gradient(120% 80% at 20% 0%, 
          color-mix(in oklab, var(--cerulean), transparent 88%), 
          transparent 60%),
        linear-gradient(135deg, 
          color-mix(in oklab, var(--non-photo-blue), transparent 92%), 
          color-mix(in oklab, var(--cerulean), transparent 95%));
      padding: 1rem;
      border-radius: var(--radius-md);
      /* Fallback border */
      border: 2px solid rgba(69, 123, 157, 0.3);
      /* Modern border */
      border: 2px solid color-mix(in oklab, var(--cerulean), transparent 70%);
      box-shadow: 0 2px 12px rgba(69, 123, 157, 0.1);
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }
    .registration-info:hover {
      transform: translateY(-1px);
      box-shadow: 0 4px 16px rgba(69, 123, 157, 0.15);
    }
    
    /* Empty State Message */
    .no-elections-message {
      font-style: italic; color: var(--cerulean);
      padding: .75rem; text-align: center;
      /* Fallback */
      background: var(--surface-muted);
      /* Modern subtle tint */
      background: color-mix(in oklab, var(--surface), white 6%);
      border-radius: var(--radius-sm);
      box-shadow: var(--shadow-1);
    }
    
    /* Register Button - Primary CTA with gradient */
    .register-button {
      display: inline-block;
      padding: .625rem 1.1rem;
      /* Fallback solid color */
      background: var(--cerulean);
      /* Modern gradient */
      background: linear-gradient(180deg, 
        color-mix(in oklab, var(--cerulean), white 10%), 
        var(--cerulean));
      color: white;
      border-radius: .625rem;
      font-weight: 800;
      text-decoration: none;
      transition: transform .15s ease, box-shadow .2s ease, filter .15s ease;
      margin-top: .5rem;
      box-shadow: 0 6px 16px rgb(69 123 157 / .28);
    }
    .register-button:hover {
      transform: translateY(-2px);
      filter: brightness(1.03);
      box-shadow: 0 10px 24px rgb(69 123 157 / .34);
    }
    
    /* Responsive - Dense layout on small screens */
    @media (max-width: 32rem) {
      .modal-content { 
        padding: 1rem .9rem .85rem; 
        border-radius: var(--radius-md); 
      }
      .modal-header { padding-right: 2.25rem; } /* leave room for close btn */
    }
   
     /* Tooltip */
     #tooltip {
       position: absolute; display: none;
       background: var(--berkeley-blue); color: white;
       padding: .5rem .75rem; border-radius: var(--radius-sm);
       font-size: .8125rem; pointer-events: none; z-index: 1500;
       box-shadow: var(--shadow-2);
       transform: translateY(-4px);
     }
   }
   /* ========================================
   HERO SECTION (END OF PAGE)
   ======================================== */
.hero-end {
  position: relative;
  background: white;
  color: #333;
  padding: 4rem 2rem;
  text-align: center;
  margin-top: 3rem;
  overflow: hidden;
}

/* Add subtle pattern overlay */
.hero-end::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: 
    radial-gradient(circle at 20% 50%, rgba(220, 38, 38, 0.05) 0%, transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(239, 68, 68, 0.03) 0%, transparent 50%);
  pointer-events: none;
}

.hero-content {
  max-width: 800px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.hero-end h2 {
  font-size: clamp(2rem, 5vw, 3rem);
  margin: 0 0 1rem 0;
  font-weight: 700;
  line-height: 1.2;
  /* Red gradient text */
  background: linear-gradient(135deg, #dc2626 0%, #b91c1c 50%, #ef4444 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-end p {
  font-size: clamp(1.125rem, 2.5vw, 1.25rem);
  margin: 0 0 2rem 0;
  color: #4b5563; /* Dark gray for readability on white */
  line-height: 1.6;
}

.hero-cta {
  display: inline-block;
  background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%);
  color: white;
  padding: 1rem 2.5rem;
  border-radius: 8px;
  font-weight: 600;
  font-size: 1.125rem;
  text-decoration: none;
  transition: transform 0.2s, box-shadow 0.2s;
  box-shadow: 0 4px 6px rgba(220, 38, 38, 0.3);
}

.hero-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 12px rgba(220, 38, 38, 0.4);
  background: linear-gradient(135deg, #b91c1c 0%, #991b1b 100%);
  text-decoration: none;
}

.hero-cta:active {
  transform: translateY(0);
}

/* Mobile responsive */
@media (max-width: 48rem) {
  .hero-end {
    padding: 3rem 1.5rem;
    margin-top: 2rem;
  }
  
  .hero-cta {
    padding: 0.875rem 2rem;
    font-size: 1rem;
  }
}
   /* ========================================
      UTILITIES
      ======================================== */
   @layer utilities {
     .center { display: grid; place-items: center; }
     .stack > * + * { margin-block-start: var(--space-4); }
     .sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
   }
   
  /* ========================================
     RESPONSIVE (VIEWPORT)
     ======================================== */
  
  /* Tablet and below */
  @media (max-width: 48rem) {
    header h1 { font-size: clamp(1.8rem, 4vw, 2.25rem); }
    header > p { font-size: var(--fs-sm); }
    .footer-content { flex-direction: column; text-align: center; }
    .map-container { padding: 1.25rem; }
    #map { padding: .9375rem; }
    
    /* Better summary card spacing on tablet */
    .summary-card {
      padding: 0.5rem;
      gap: 0.4rem;
    }
  }
  
  /* Mobile - Small screens */
  @media (max-width: 40rem) {
    main {
      padding-inline: 0.75rem;
    }
    
    header {
      padding: 1.5rem 0.75rem;
    }
    
    .summary-card {
      grid-template-columns: repeat(2, 1fr) !important;
      padding: 0.4rem;
      gap: 0.35rem;
    }
    
    .summary-item {
      padding: 0.5rem 0.25rem;
      min-width: 0; /* Allow items to shrink */
    }
    
    .summary-number {
      font-size: 1.25rem;
    }
    
    .summary-label,
    .summary-sub {
      font-size: 0.65rem;
    }
    
    .map-container {
      padding: 0.75rem;
      margin-block: 1rem;
    }
  }
  
  /* Mobile - Very small screens */
  @media (max-width: 30rem) {
    body {
      font-size: 0.9rem;
    }
    
    main {
      padding-inline: 0.5rem;
    }
    
    header {
      padding: 1.25rem 0.5rem;
    }
    
    header h1 {
      font-size: clamp(1.5rem, 5vw, 2rem);
    }
    
    .summary-card {
      grid-template-columns: repeat(2, 1fr) !important;
      padding: 0.3rem;
      gap: 0.25rem;
      border-width: 1px;
    }
    
    .summary-item {
      padding: 0.4rem 0.2rem;
    }
    
    .summary-number {
      font-size: 1.1rem;
    }
    
    .summary-label,
    .summary-sub {
      font-size: 0.6rem;
      letter-spacing: 0.03em;
    }
    
    .map-container {
      padding: 0.5rem;
    }
    
    #map {
      padding: 0.5rem;
    }
  }
   