:root {
  --text-main: #fbe5b2;
  --ink: #051821;
  --teal-700: #1A4645;
  --teal-clear700: rgba(26,70,69,0.43);
  --teal-600: #266867;
  --accent-1: #F58800;
  --accent-2: #F8BC24;
  --white: #ffffff;
  --card-bg: rgba(255,255,255,0.0);
  --card-border: rgba(248,188,36,0.55);
  --font-serif: 'Playfair Display',serif;
  --font-sans: 'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}

body, html {
  height: 100%;
}

body {
  font-family: var(--font-sans);
  color: var(--text-main);
  background: linear-gradient(180deg,var(--teal-700),var(--teal-600)) fixed;
}

.display-1, .display-2, .display-3, h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  color: var(--accent-2);
  line-height: 1.2;
}

a {
  text-underline-offset: 2px;
}

a:hover {
  text-decoration: none;
}

.section-spacer {
  padding-block: clamp(1rem,2.5vw,2.5rem);
}

.container-narrow {
  max-width: 1024px;
}

.navbar {
  background: 0 0!important;
  border: 0!important;
  box-shadow: none!important;
}

.navbar .navbar-brand {
  font-family: var(--font-serif);
  color: var(--accent-1)!important;
}

.navbar .nav-link:focus, .navbar .nav-link:hover, .navbar .navbar-brand:hover {
  color: var(--accent-1)!important;
}

.navbar .nav-link {
  color: var(--text-main)!important;
  font-weight: 500;
}

.navbar .navbar-toggler {
  border: 0;
}

.navbar .navbar-toggler-icon {
  filter: invert(1);
}

.hero {
  padding-block: clamp(2rem,5vw,4rem);
  color: var(--white);
  position: relative;
}

.hero h1 {
  font-family: var(--font-serif);
  line-height: 1.15;
}

.hero.hero-has-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('../../../../assets/img/hero_bg_2.jpg') center/cover no-repeat;
  opacity: .3;
  z-index: 0;
}

.hero-actions {
  gap: 1rem;
}

.btn-cta {
  background: var(--teal-700);
  border-color: var(--accent-1);
  color: var(--accent-2);
  font-weight: 700;
  border-radius: 9999px;
  padding: .6rem 1.2rem;
  transition: .28s;
}

.btn-cta:hover {
  background: var(--accent-2);
  border-color: var(--accent-2);
  color: var(--ink);
}

.btn-outline-accent {
  border: 2px solid var(--accent-2);
  color: var(--accent-2);
  background: 0 0;
  border-radius: 9999px;
  font-weight: 600;
  padding: .6rem 1.2rem;
}

.btn-outline-accent:hover {
  background: var(--accent-2);
  color: var(--ink);
}

.section-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 1.25rem;
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
  padding: clamp(1rem,2vw,2rem);
}

.form-label {
  font-weight: 600;
}

#quoteAlert {
  margin-bottom: .75rem;
}

.display-5 {
  font-size: calc(1.425rem + 2.1vw);
}

@media (min-width:1200px) {
  .display-5 {
    font-size: 3rem;
  }
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('AI_hero_2_bottomdivider_temp1.png') center/cover no-repeat;
  opacity: .6;
  z-index: 0;
}

.hero .container {
  position: relative;
  z-index: 1;
}

.section-spacer {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}

@media (min-width:576px) {
  .section-spacer {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
}

@media (min-width:768px) {
  .section-spacer {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
  }
}

#quote, .bio {
  position: relative;
  z-index: 1;
  margin-top: 2rem;
  margin-bottom: 2rem;
}

@media (max-width:991px) {
  .bio {
    margin-bottom: 3rem;
  }
}

.mobile-logo {
  display: none;
}

@media (max-width:991.98px) {
  .mobile-logo {
    display: block;
  }
}

@media (min-width:576px) and (max-width:991.98px) {
  .mobile-logo-img {
    width: 22vw;
    max-width: 150px;
  }
}

#quote .form-text, #quote h2, #quote label, #quote p, #quote small {
  color: var(--text-main);
}

#quote input, #quote textarea {
  color: var(--text-main);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.25);
}

#quote ::placeholder {
  color: rgba(255,234,181,.6);
}

#faq h1 {
  color: var(--accent-2)!important;
}

#faqAcc .accordion-button {
  background: 0 0;
  color: var(--accent-2);
}

#faqAcc .accordion-item {
  background: 0 0!important;
  border: none!important;
}

#faqAcc .accordion-body {
  color: var(--text-main)!important;
}

#faqAcc .accordion-body * {
  color: inherit;
}

#faqAcc .accordion-button::after {
  filter: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' viewBox='0 0 16 16'%3E%3Cpath d='M8 4a.5.5 0 0 1 .5.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3A.5.5 0 0 1 8 4z'/%3E%3C/svg%3E");
}

#faqAcc .accordion-button:not(.collapsed)::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' viewBox='0 0 16 16'%3E%3Cpath d='M4 8a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7A.5.5 0 0 1 4 8z'/%3E%3C/svg%3E");
}

