.elementor-1711 .elementor-element.elementor-element-6ws1fu4{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1711 .elementor-element.elementor-element-qsi7zf9{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1711 .elementor-element.elementor-element-ojacl6a{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1711 .elementor-element.elementor-element-huktej8{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1711 .elementor-element.elementor-element-t2n3mn4{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1711 .elementor-element.elementor-element-tfg8i0n{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1711 .elementor-element.elementor-element-xtdn3od{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1711 .elementor-element.elementor-element-bfec3e3{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1711 .elementor-element.elementor-element-wbrjl9h{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1711 .elementor-element.elementor-element-0qcsofu{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}/* Start custom CSS for html, class: .elementor-element-73eaead */<link rel="preconnect" href="https://fonts.googleapis.com">
  <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
  <link href="https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap" rel="stylesheet">
  <style>
    *, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

    :root {
      --navy: #0F2B4C;
      --navy-deep: #091D35;
      --navy-light: #1A3D66;
      --accent: #3097D1;
      --accent-hover: #2578A8;
      --white: #FFFFFF;
      --gray-bg: #F7F8FA;
      --border: #E5E7EB;
      --slate: #4A5568;
      --slate-light: #718096;
      --charcoal: #2D3748;

      --font-display: 'DM Sans', system-ui, sans-serif;
      --font-body: 'DM Sans', system-ui, sans-serif;

      --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
    }

    html { scroll-behavior: smooth; }

    body {
      font-family: var(--font-body);
      color: var(--charcoal);
      background: var(--white);
      overflow-x: hidden;
      -webkit-font-smoothing: antialiased;
    }

    /* ========================================
       UTILITY
    ======================================== */
    .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 24px;
    }

    .sr-only {
      position: absolute; width: 1px; height: 1px;
      padding: 0; margin: -1px; overflow: hidden;
      clip: rect(0,0,0,0); border: 0;
    }

    /* Elementor reset - strip default widget/container padding */
    .elementor-widget-html .elementor-widget-container {
      padding: 0 !important;
      margin: 0 !important;
    }
    .elementor-element.elementor-widget {
      margin-bottom: 0 !important;
    }
    .elementor-element.e-con.e-parent {
      --padding-top: 0px !important;
      --padding-right: 0px !important;
      --padding-bottom: 0px !important;
      --padding-left: 0px !important;
      padding: 0 !important;
      margin: 0 !important;
    }
    .elementor-element.e-con {
      --widgets-spacing: 0px 0px !important;
      --widgets-spacing-row: 0px !important;
      --widgets-spacing-column: 0px !important;
      gap: 0 !important;
    }
    .elementor-widget:not(:last-child) {
      margin-bottom: 0 !important;
    }

    /* ========================================
       ANIMATIONS
    ======================================== */
    @keyframes fadeUp {
      from { opacity: 0; transform: translateY(40px); }
      to { opacity: 1; transform: translateY(0); }
    }

    .animate-on-scroll {
      opacity: 0;
      transform: translateY(30px);
      transition: opacity 0.7s var(--ease-out-expo), transform 0.7s var(--ease-out-expo);
    }
    .animate-on-scroll.visible {
      opacity: 1;
      transform: translateY(0);
    }

    /* Sticky header wrapper - targets Elementor header container */
    .elementor-location-header {
      position: sticky !important;
      top: 0 !important;
      z-index: 999 !important;
    }

    /* Mobile header overrides */
    .elementor-location-header .elementor-menu-toggle {
      background: transparent !important;
      border: none !important;
      box-shadow: none !important;
    }
    .elementor-location-header .elementor-menu-toggle svg,
    .elementor-location-header .elementor-menu-toggle i {
      color: var(--navy) !important;
      fill: var(--navy) !important;
    }
    /* Mobile CTA button next to burger */
    .header-mobile-cta {
      display: none;
      background: var(--accent);
      color: white !important;
      padding: 8px 18px;
      border-radius: 24px;
      font-size: 13px;
      font-weight: 700;
      text-decoration: none;
      white-space: nowrap;
      font-family: var(--font-body);
    }
    @media (max-width: 1024px) {
      .header-mobile-cta { display: inline-flex; align-items: center; gap: 6px; }
    }
    
    
    /* ========================================
       SERVICE AREA
    ======================================== */
    .service-area {
      padding: 80px 0;
      background: var(--gray-bg);
    }
    .area-wrapper {
      display: grid;
      grid-template-columns: 0.85fr 1.15fr;
      gap: 60px;
      align-items: center;
    }
    .area-text h2 {
      font-family: var(--font-display);
      font-size: clamp(28px, 3.5vw, 40px);
      color: var(--navy);
      line-height: 1.1;
      margin-bottom: 16px;
    }
    .area-text > p {
      font-size: 16px;
      color: var(--slate-light);
      line-height: 1.7;
      margin-bottom: 28px;
    }
    .area-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }
    .area-tag {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: white;
      border: 1px solid var(--border);
      border-radius: 24px;
      padding: 8px 16px;
      font-size: 13px;
      font-weight: 600;
      color: var(--charcoal);
      transition: border-color 0.2s, background 0.2s;
    }
    .area-tag:hover { border-color: var(--accent); background: rgba(48,151,209,0.04); }
    .area-tag svg { width: 12px; height: 12px; color: var(--accent); }
    .area-map-card {
      border-radius: 16px;
      overflow: hidden;
      border: 1px solid var(--border);
      box-shadow: 0 4px 24px rgba(15,43,76,0.06);
      position: relative;
    }
    .area-map-card iframe {
      width: 100%;
      height: 540px;
      display: block;
      border: none;
    }

    /* West End callout — sits between section paragraph and area tags */
    .west-end-callout {
      position: relative;
      display: flex;
      align-items: flex-start;
      gap: 16px;
      background: linear-gradient(135deg, var(--navy) 0%, var(--navy-deep) 100%);
      color: var(--white);
      border-radius: 14px;
      padding: 22px 26px 22px 30px;
      margin: 0 0 28px;
      overflow: hidden;
      box-shadow: 0 10px 30px rgba(15,43,76,0.18), 0 2px 6px rgba(15,43,76,0.12);
    }
    .west-end-callout::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      bottom: 0;
      width: 5px;
      background: var(--accent);
    }
    .west-end-callout::after {
      content: '';
      position: absolute;
      top: -60px;
      right: -60px;
      width: 180px;
      height: 180px;
      background: radial-gradient(circle, rgba(48,151,209,0.18) 0%, rgba(48,151,209,0) 70%);
      pointer-events: none;
    }
    .west-end-callout-dot {
      position: relative;
      width: 12px;
      height: 12px;
      background: var(--accent);
      border-radius: 50%;
      flex-shrink: 0;
      margin-top: 7px;
      box-shadow: 0 0 0 4px rgba(48,151,209,0.22);
    }
    .west-end-callout-pulse {
      position: absolute;
      inset: -4px;
      border-radius: 50%;
      background: var(--accent);
      opacity: 0.5;
      animation: westEndPulse 2s ease-out infinite;
    }
    @keyframes westEndPulse {
      0%   { transform: scale(0.8); opacity: 0.6; }
      80%  { transform: scale(2.6); opacity: 0; }
      100% { transform: scale(2.6); opacity: 0; }
    }
    .west-end-callout-content {
      display: flex;
      flex-direction: column;
      gap: 6px;
      min-width: 0;
      position: relative;
      z-index: 1;
    }
    .west-end-callout-eyebrow {
      font-family: var(--font-display);
      font-size: 11px;
      font-weight: 700;
      color: var(--accent);
      letter-spacing: 0.14em;
      text-transform: uppercase;
    }
    .west-end-callout-text {
      font-size: 15px;
      line-height: 1.55;
      color: rgba(255,255,255,0.82);
      margin: 0;
    }
    .west-end-callout-text strong {
      color: var(--white);
      font-weight: 700;
    }
    @media (max-width: 600px) {
      .west-end-callout {
        padding: 18px 20px 18px 24px;
        gap: 12px;
        border-radius: 12px;
      }
      .west-end-callout-text { font-size: 14px; }
    }
    .area-map-footer {
      background: white;
      padding: 16px 20px;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .area-map-footer-info {
      font-size: 14px;
      color: var(--charcoal);
      font-weight: 600;
    }
    .area-map-footer-info span {
      display: block;
      font-size: 12px;
      color: var(--slate-light);
      font-weight: 400;
      margin-top: 2px;
    }
    .area-map-btn {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: var(--accent);
      color: white !important;
      padding: 10px 18px;
      border-radius: 8px;
      font-size: 13px;
      font-weight: 700;
      text-decoration: none;
      transition: background 0.3s;
    }
    .area-map-btn svg { color: white !important; stroke: white !important; }
    .area-map-btn:hover { background: var(--accent-hover); }

    /* Map footer — mobile: stack address + full-width button below */
    @media (max-width: 600px) {
      .area-map-footer {
        flex-direction: column;
        align-items: stretch;
        gap: 14px;
        padding: 16px;
      }
      .area-map-btn {
        width: 100%;
        justify-content: center;
        padding: 14px 20px;
        font-size: 14px;
        gap: 8px;
      }
      .area-map-btn svg {
        width: 18px !important;
        height: 18px !important;
      }
    }/* End custom CSS */