/* =========================================================
   0) RESET / BASE
   ========================================================= */
*,
*::before,
*::after { box-sizing: border-box; }

html {
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  text-rendering: optimizeLegibility;
  font-family: sans-serif;
}

body {
  margin: 0;
  font-family: inherit;
  font-size: 100%;
  background: var(--primary-bg);
  color: var(--dark-text);
}

h1, h2, h3, h4, h5, h6,
p, blockquote, figure, dl, dd { margin: 0; }

ul[role='list'], ol[role='list'] { list-style: none; }

a { text-decoration: none; color: inherit; }

img, svg, video, canvas { display: block; max-width: 100%; height: auto; }

button, input, select, textarea {
  font: inherit; margin: 0; border: none; background: none; padding: 0;
  color: inherit; outline: none;
}

table { border-collapse: collapse; width: 100%; }
textarea { resize: vertical; }

/* =========================================================
   1) NAVIGATION
   ========================================================= */
.navigation-bar-container {
  width: 100%;
  position: absolute; top: 0; left: 0;
  z-index: 1000;
  background: transparent;
  transition: background-color .3s ease, box-shadow .3s ease;
  padding: .75rem 0;
}

/* Dark, slightly translucent on scroll */
.site-header.scrolled .navigation-bar-container {
  background-color: var(--nav-scrolled);
  box-shadow: 0 6px 24px rgba(0,0,0,.35);
  position: fixed; top: 0; left: 0; right: 0;
}

/* Main Navigation */
.main-nav ul {
  display: flex; gap: var(--nav-gap);
  list-style: none; margin: 0; padding: 0;
}
.main-nav a:not(.cta-button) {
  color: var(--light-text);
  font-weight: var(--nav-font-weight);
  text-decoration: none;
  transition: color .25s ease, opacity .25s ease;
  padding: .5em 0; position: relative;
  text-shadow: 1px 1px 2px rgba(0,0,0,.35);
  font-size: .95rem; letter-spacing: .03em;
}

/* Underline accent (purple) */
.main-nav a:not(.cta-button)::after {
  content: '';
  position: absolute; left: 0; bottom: -2px;
  width: 100%; height: 2px;
  background-color: var(--primary-accent);
  transform: scaleX(0); transform-origin: bottom right;
  transition: transform .22s ease-out;
}
.main-nav a:not(.cta-button):hover,
.main-nav a:not(.cta-button):focus {
  color: var(--accent-hover, var(--strong-accent));
  opacity: 1;
}
.main-nav a:not(.cta-button):hover::after,
.main-nav a:not(.cta-button):focus::after {
  transform: scaleX(1); transform-origin: bottom left;
}

/* Current page state = persistent purple */
.main-nav .current-menu-item > a:not(.cta-button) {
  color: var(--accent-hover, var(--primary-accent));
}
.main-nav .current-menu-item > a:not(.cta-button)::after {
  transform: scaleX(1); transform-origin: bottom left;
}

/* Mobile Navigation */
.nav-toggle {
  display: none;
  background: none; border: none;
  color: var(--light-text);
  font-size: 1.8rem;
  cursor: pointer; padding: .5rem;
  z-index: 1005; margin-left: 1rem;
}
.nav-toggle .icon-bar {
  display: block; width: 24px; height: 3px;
  background-color: var(--light-text);
  margin: 5px 0; transition: all .3s ease-in-out; border-radius: 1px;
}
.nav-toggle[aria-expanded="true"] .icon-bar:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .icon-bar:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .icon-bar:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

@media (max-width: 768px) {
  .main-nav ul { display: none; }
  .nav-toggle { display: block; }

  .main-nav {
    display: none;
    flex-direction: column; align-items: center; justify-content: flex-start;
    position: absolute; top: 100%; left: 0; right: 0;
    background: rgba(27,27,35,.98);
    padding: 1rem 0; z-index: 999;
    max-height: 0; opacity: 0; overflow: hidden; visibility: hidden;
    transition: max-height .4s cubic-bezier(.25,.46,.45,.94),
                opacity .3s ease-in-out .1s,
                visibility 0s linear .4s;
  }
  .main-nav.show {
    display: flex;
    max-height: calc(100vh - 150px);
    opacity: 1; visibility: visible;
    transition: max-height .4s cubic-bezier(.25,.46,.45,.94), opacity .2s ease-in-out, visibility 0s linear 0s;
    overflow-y: auto; padding-bottom: 1rem;
  }
  .main-nav.show ul {
    display: flex; flex-direction: column; gap: 0; width: 100%; text-align: center;
  }
  .main-nav.show ul li a {
    display: block; width: 100%;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid rgba(255,255,255,.08);
    color: var(--light-text); background: transparent; text-shadow: none;
  }
  .main-nav.show ul li:last-child a { border-bottom: none; }
  .main-nav.show ul li a:hover,
  .main-nav.show ul li a:focus,
  .main-nav.show .current-menu-item > a {
    background-color: rgba(110,45,145,.18); /* subtle purple wash */
    color: var(--accent-hover, var(--strong-accent));
  }
}

/* =========================================================
   2) FOOTER
   ========================================================= */
.site-footer {
  background-color: var(--footer-bg);
  color: var(--footer-text);
  font-family: var(--font-primary);
  padding-top: 0;
  margin-top: 3rem;
}

/* CTA band with darker overlay */
.footer-cta-section {
  position: relative;
  background-image:
    linear-gradient(rgba(15,15,20,.70), rgba(15,15,20,.60)),
    url('/images/footer-background.webp');
  background-size: cover; background-position: center; background-repeat: no-repeat;
  padding: 5rem 1.5rem; color: var(--light-text);
  text-align: center; z-index: 1; overflow: hidden;
}
.footer-cta-section .container { position: relative; z-index: 2; }
.footer-cta-inner { max-width: 700px; margin: 0 auto; }

.footer-cta-heading {
  font-size: 2.6rem; font-family: var(--font-secondary);
  color: var(--light-text); margin-bottom: 1rem; font-weight: 700; line-height: 1.3;
}
.footer-cta-hours { font-size: 1rem; font-weight: 500; color: var(--light-text); margin-bottom: 1.5rem; }
.footer-contact-info p { font-size: 1.15rem; margin: .3rem 0; }
p.footer-cta-phone {
  font-size: 2.25rem; font-family: var(--font-secondary);
  font-weight: 600; color: var(--light-text); margin-bottom: .5rem;
}
.footer-contact-info a {
  color: var(--primary-accent);
  font-weight: 600; text-decoration: none;
}
.footer-contact-info a:hover { text-decoration: underline; }


/* Footer social row (top of footer) */
.footer-social-media-bar {
  padding: 0.75rem 0;
  background: transparent;
}
.footer-social-media-bar .container {
  display: flex;
  justify-content: center;
}
.social-icons-wrapper {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: clamp(10px, 1.4vw, 18px);
}
.social-icons-wrapper a {
  display: inline-flex;
  width: 32px;
  height: 32px;
  line-height: 0;
  color: var(--footer-social-icon-color);
  transition: color .25s ease, transform .2s ease;
}
.social-icons-wrapper a:hover {
  color: var(--footer-social-icon-hover-color);
  transform: translateY(-1px);
}


/* Copyright */
.site-info {
  background-color: var(--footer-bg);
  font-size: .85rem; line-height: 1.4; text-align: center;
  padding: 1rem 1rem 1.5rem; color: var(--footer-text);
}
.site-info a {
  color: var(--primary-accent);
  text-decoration: none; font-weight: 600;
}
.site-info a:hover { text-decoration: underline; }

/* =========================================================
   3) PLUGINS – NINJA FORMS
   ========================================================= */
.nf-form-cont { text-align: left; }
.nf-form-cont .nf-form-title { display: none; }
.signup-section .nf-form-cont { max-width: 500px; margin: 2rem auto; text-align: center; }

.entry-content .nf-form-cont { margin-top: 2em; margin-bottom: 2em; }
.entry-content .nf-form-cont .nf-form-title { display: block; }
.entry-content .nf-form-cont .nf-form-title h3 {
  font-family: var(--font-secondary);
  font-size: 2.2rem; color: var(--light-text); margin-bottom: 1rem; text-align: left;
}

.nf-form-cont .nf-field-label label {
  font-size: 1rem; font-weight: 600; color: var(--light-text);
  margin-bottom: .5rem; display: block;
}
.nf-form-cont .nf-form-fields-required {
  font-style: italic; font-size: .8em; color: #bbb;
  margin-bottom: 1.5rem; display: block; text-align: left;
}
.signup-section .nf-form-fields-required { text-align: center; }
.nf-form-cont .nf-field-container { margin-bottom: 1.25rem; }

/* Inputs remain light for legibility against dark bg */
.nf-form-cont .nf-field-element input[type="text"],
.nf-form-cont .nf-field-element input[type="email"],
.nf-form-cont .nf-field-element input[type="tel"],
.nf-form-cont .nf-field-element textarea {
  width: 100%; padding: .9rem 1.1rem;
  border: 1px solid var(--input-border-color);
  border-radius: var(--border-radius);
  font-size: 1rem; background-color: #fff; color: #222;
  font-family: var(--font-primary);
  transition: border-color .3s ease, box-shadow .3s ease;
}
.nf-form-cont .nf-field-element textarea { min-height: 120px; resize: vertical; }

/* Styled select wrapper */
.nf-form-cont .list-select-wrap .ninja-forms-field {
  width: 100%; padding: 0;
  border: 1px solid var(--input-border-color);
  border-radius: var(--border-radius);
  background-color: #fff; font-family: var(--font-primary);
  transition: border-color .3s ease, box-shadow .3s ease;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23333333' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat; background-position: right .8rem center; background-size: 1em;
}
.nf-form-cont .list-select-wrap .ninja-forms-field select {
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
  background-image: none !important; border: none !important;
  padding: .9rem 2.5rem .9rem 1.1rem; width: 100%;
  background-color: transparent; font-size: 1rem; color: #222;
  font-family: var(--font-primary); line-height: 1.4;
}
.nf-form-cont .list-select-wrap select { padding: 10px !important; }

/* Focus */
.nf-form-cont .nf-field-element input[type="text"]:focus,
.nf-form-cont .nf-field-element input[type="email"]:focus,
.nf-form-cont .nf-field-element input[type="tel"]:focus,
.nf-form-cont .nf-field-element textarea:focus,
.nf-form-cont .list-select-wrap .ninja-forms-field:focus-within {
  border-color: var(--primary-accent);
  box-shadow: 0 0 0 3px rgba(var(--primary-accent-rgb), .25);
  outline: none;
}

/* Submit */
.nf-form-cont .submit-container input[type="submit"] {
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
  background-color: var(--primary-accent);
  color: var(--light-text);
  padding: .8rem 1.8rem;
  border-radius: var(--border-radius);
  font-weight: 700; border: none; cursor: pointer;
  width: 100%; font-size: 1.05rem; letter-spacing: .05em; text-transform: uppercase;
  transition: background-color .25s ease, transform .2s ease, box-shadow .25s ease;
}
.entry-content .submit-container input[type="submit"] { width: auto; }
.nf-form-cont .submit-container input[type="submit"]:hover {
  background-color: var(--accent-hover, var(--strong-accent));
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(var(--primary-accent-rgb), .25);
}

/* Success (purple, no green) */
.nf-response-msg {
  background-color: #f5f0fa;              /* light lavender */
  border-left: 4px solid var(--primary-accent);
  color: #4c2c66;                          /* deep purple text */
  padding: 1.25rem 1.5rem;
  border-radius: var(--border-radius);
  font-size: 1rem; font-weight: 500;
  margin: 2rem 0;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.nf-response-msg p { margin: 0; }

/* When Ninja Forms is inside a content area, keep light card for readability */
.entry-content .nf-form-cont {
  background-color: #fff;
  padding: .5rem 2rem 1rem 2rem;
  border-radius: var(--border-radius);
  box-shadow: var(--card-shadow);
  margin-top: 2rem; margin-bottom: 3rem;
}







/* CSS to make YouTube embeds responsive and maintain 16:9 ratio */
.video-responsive {
    position: relative;
    padding-bottom: 56.25%; /* Calculates height as 56.25% of the width (9/16 ratio) */
    height: 0;
    overflow: hidden;
    max-width: 100%; /* Ensures it scales down on mobile */
}

.video-responsive iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}