/* ============================================================
   wcag-s0088-haute.css
   WCAG 2.1 Level AA override for the S0088-Haute Kentico template.

   Selectors verified against the live base CSS pulled from
   https://ascendatelevon.com on 2026-05-07.

   Audit findings:
   - Base CSS (~52KB / 572 rules). No outline-suppression in
     template CSS; Bootstrap still removes them.
   - Form controls — TWO real failures:
       1. .neighborhood-widget .form-control { border:1px solid #999 }
          #999 ≈ 2.85:1 — fails 3:1.
       2. #contactUsEnhancedContainer .form-control
          { background:#f1f1f1; border-bottom:none }
          No visible border at all. Visual cue absent.
   - Sticky elements: .header-menu and #menu-screen-overlay are
     position:fixed; height not declared in those rules.
   - Footer link hover: ul.footer-links li a:hover { color:#999 }
     If footer is dark, that's fine; if light, fails. Verify.

   Specificity strategy:
   Every selector is prefixed with `body #form` to lift above
   widget CSS load order. The form-control fix for
   #contactUsEnhancedContainer keeps its !important because the
   base rule explicitly sets `border-bottom:none` (without a color
   value to override).
   ============================================================ */


/* ------------------------------------------------------------
   WCAG 2.4.7 Focus Visible
   Bootstrap suppressors plus general fallback.
   ------------------------------------------------------------ */
body #form .navbar-toggle:focus-visible,
body #form .dropdown-toggle:focus-visible,
body #form .btn:focus-visible,
body #form .btn-primary:focus-visible,
body #form .form-control:focus-visible,
body #form .header-menu:focus-visible,
body #form a:focus-visible,
body #form button:focus-visible,
body #form input:focus-visible,
body #form select:focus-visible,
body #form textarea:focus-visible,
body #form [tabindex]:focus-visible,
body #form [role="button"]:focus-visible,
body #form .footer-widget footer a:focus-visible {
  /* Webkit-style two-ring halo: blue inner ring + white outer ring
     gives focus visibility on both light AND dark backgrounds.
     The `outline` declaration is intentionally omitted — outline
     paints on top of box-shadow and would cover the white ring. */
  outline-offset: 2px;
  box-shadow: 0 0 0 2px #005fcc, 0 0 0 3px #fff;
}


/* ------------------------------------------------------------
   WCAG 2.4.11 Focus Not Obscured
   .header-menu is position:fixed. Default 80px scroll-padding;
   adjust after measuring on the live site.
   ------------------------------------------------------------ */
html {
  scroll-padding-top: 80px;
}

body #form :focus-visible {
  scroll-margin-top: 80px;
}


/* ------------------------------------------------------------
   WCAG 1.4.11 Non-text Contrast (form controls)
   Two confirmed failures from base CSS.
   ------------------------------------------------------------ */
body #form .neighborhood-widget .neighborhood-widget__search .form-group .form-control {
  border-color: #595959;
}

body #form #contactUsEnhancedContainer .form-control {
  border-bottom: 1px solid #595959 !important;
}

body #form input.form-control,
body #form select.form-control,
body #form textarea.form-control {
  border-color: #595959;
}

body #form input::placeholder,
body #form textarea::placeholder {
  color: #595959;
  opacity: 1;
}


/* ------------------------------------------------------------
   WCAG 1.4.3 Contrast Minimum (footer disclosure)
   ------------------------------------------------------------ */
body #form .footer-widget footer .footer-disclosure {
  opacity: 0.85;
}


/* ------------------------------------------------------------
   WCAG 1.4.1 Use of Color (inline links)
   ------------------------------------------------------------ */
body #form .main-content-text a,
body #form .inner-page-main-content a,
body #form .mainContent a,
body #form main p a,
body #form article p a,
body #form .content p a {
  text-decoration: underline;
  text-underline-offset: 2px;
}

body #form .btn,
body #form .button,
body #form header a,
body #form nav a,
body #form .navbar a,
body #form footer a,
body #form .footer-widget footer a,
body #form .footer-CTA-Button,
body #form .header-CTA-button,
body #form a.more-link,
body #form a.less-link {
  text-decoration: none;
}


/* ------------------------------------------------------------
   TFS 2870264 — WCAG 1.4.1 (homepage inline links)
   Haute's homepage is `<section id="home">` containing
   `.content-home .content-row` and a series of
   `.home-main-content-wrapper` rows. Each row's text content
   lives in `.home-content-sub-content` and `.home-column`.
   The hero/welcome blurb sits in `.content-right.home-column`
   and `.content-left.home-column`. Background captions use
   `.bg-caption`. Homepage CTA buttons use `.button.cta1` /
   `.button.cta2` — opted out.
   ------------------------------------------------------------ */
body #form #home .content-home a,
body #form #home .home-main-content-wrapper a,
body #form #home .home-content-sub-content a,
body #form #home .home-column a,
body #form #home .bg-caption a {
  text-decoration: underline;
  text-underline-offset: 2px;
}

body #form #home a.button,
body #form #home a.cta1,
body #form #home a.cta2,
body #form #home .button.cta1,
body #form #home .button.cta2,
body #form #home .header-ctas a,
body #form #home .homeNav a {
  text-decoration: none;
}


/** ------------------------------------------------------------
   WCAG 2.2 AA 2.5.8 Target Size (Pointer)
   ------------------------------------------------------------ */
body #form header .header-social a {
    width: 24px;
    line-height: 24px;
    margin: 0 5px;
}
body .contact-mobile-form input[type="checkbox"] {
    padding: 20px;
    margin: 4px;
}