* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: 0;
  font-family: 'Poppins', sans-serif;
  text-align: left;
  text-decoration: none;
  color: #000000;
  background-color: transparent;
  cursor: default;
}

/* Ensure percentage heights work so sidebar can fill the full page height */
html, body {
  height: 100%;
}

body {
  min-height: 100vh;
  min-width: 100%;
  background-color: #ffffff;
  display: flex;
  flex-direction: row;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}

.sidebar {
  /* make sidebar fixed to the left so it always extends to the bottom */
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 250px;
  background-color: #3b90ae;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.logo {
  font-size: 24px;
  font-weight: bold;
  color: #000000;
  text-align: center;
  margin-bottom: 30px;
}

.i-home {
  color: #000000;
  margin: 0px;
  border-radius: 10px;
  padding: 10px;
}

.i-contact {
  color: #000000;
  margin: 0px;
  border-radius: 10px;
  padding: 10px;
}

.i-privacy {
  color: #000000;
  margin: 0px;
  border-radius: 10px;
  padding: 10px;
}

.i-home:hover a,
.i-contact:hover a,
.i-privacy:hover a,
.accordion-header:hover {
  background-color: #34495e;
  color: #ffffff;
}

/* Make links inside nav items turn white on hover */
.i-home:hover,
.i-contact:hover,
.i-privacy:hover {
  background-color: #34495e;
}

/* Make nav links inherit parent color */
.i-home a,
.i-contact a,
.i-privacy a {
  color: inherit;
}

/* Accordion: collapsed by default, smooth expand/collapse */
.accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.28s ease;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-left: 8px;
}

.accordion-header {
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #000000;
  margin: 0px;
  border-radius: 10px;
  background-color: #3b90ae;
  padding: 10px;
}

.accordion-header.active {
  background: rgba(255,255,255,0.03);
}

.main-content {
  flex: 1;
  /* remove top padding so the hero can sit flush at the top like a banner */
  padding: 0;
  margin: 0px;
  overflow-y: auto;
  /* allow the main content to fill the available flex space; remove hard max-width */
  min-width: 0; /* allow flex children to shrink properly in some browsers */
}

.content-wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  flex: 1;
  min-width: 0; /* allow the wrapper to shrink so .main-content can use full space */
}

/* when sidebar is fixed, offset the right column so it doesn't sit under the sidebar */
.content-wrapper {
  margin-left: 250px;
}

.hero {
  color: #fff;
  text-align: center;
  padding: 0;
  margin: 0 0 40px 0; /* no top margin so it starts at the top of .main-content */
  height:70vh; /* responsive banner height */
  min-height: 260px;
  width: 100%;
  background-image: url(../Assets/hero-bg.jpg);
  background-size: cover;
  background-position: center;
  /* keep rounded corners on the right side only so the banner aligns with the sidebar edge */
  border-radius: 0 10px 0 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.hero h1 {
  font-size: 48px;
  color: #ffffff;
  margin-bottom: 10px;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
}
.hero p {
  font-size: 18px;
  font-weight: 800;
  margin-bottom: 20px;
  margin-top: 90px;
  color: #000000;
  text-shadow: 1px 1px 2px rgba(255, 255, 255, 0.5);
}

.btn {
  background: #f4a261;
  color: #fff;
  padding: 12px 32px;
  margin: 100px 0;
  border-radius: 30px;
  text-decoration: none;
  font-weight: 600;
  display: inline-block;
}

.h-quote-btn1 a {
  margin-top: 5px;
  background: #f4a261;
  text-decoration: none;
}

.h-quote-btn2 a {
  margin-top: 5px;

}

.h-quote-btn3 a {
  margin-top: 5px;
}

.btn:hover {
  background: #e76f51;
  color: #fff;
}

.section {
  padding: 60px 20px;
  background: #f8f9fa;
}

.hqb-section {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
  align-items: center;
  padding-left: 7%;
  background-color: lightblue;
}

.section h2 {
  text-align: center;
  margin-bottom: 40px;
  font-size: 32px;
}

.card {
  display: inline-block;
  width: 300px;
  height: 300px;
  background: #3b90ae;
  border: 1px solid #eee;
  border-radius: 10px;
  padding: 20px;
  margin: 25px;
  text-align: center;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.card#card1 {
  background-image: url(../Assets/card1-bg.jpg);
  background-size: cover;
  background-position: center;
}

.card#card2 {
  background-image: url(../Assets/card2-bg.jpg);
  background-size: cover;
  background-position: center;
}

.card#card3 {
  background-image: url(../Assets/card3-bg.jpg);
  background-size: cover;
  background-position: center;

}

.card#card4 {
  background-image: url(../Assets/card4-bg.jpg);
  background-size: cover;
  background-position: center;

}

.card#card5 {
  background-image: url(../Assets/card5-bg.jpg);
  background-size: cover;
  background-position: center;

}

.card#card6 {
  background-image: url(../Assets/card6-bg.jpg);
  background-size: cover;
  background-position: center;

}

.card i {
  font-size: 50px;
  color: #000000;
  font-weight: 800;
  padding-bottom: 5px;
  padding-top: 5%;
}

.card h3 {
  margin-top: 15px;
  margin-bottom: 10px;
  font-size: 22px;
  text-align: center;
}

.card p {
  font-size: 16px;
  text-align: center;
}

.card#card3 p {
  color: #000000;
  font-weight: 600;
}

.card#card2 p {
  color: #000000;
  font-weight: 600;
}

.card#card1 p {
  color: #000000;
  font-weight: 600;
}

.footer {
  flex-shrink: 0;
  padding: 10px;
  color: #000000;
  width: 100%;
}

.social-icons {
  display: flex;
  gap: 20px;
  justify-content: center;
  text-align: center;
  margin: 0px 0;
  padding: 0px 0px;
}

.social-link {
  font-size: 36px;
  padding: 0px 0px 15px 0px;
  border-radius: 10%;
}

.fab.fa-facebook-f {
  color: #3b5998;
  border-radius: 20%;
}

.fab.fa-x {
  color: #ffffff;
  background-color: #000000;
  border-radius: 20%;
}

.fab.fa-linkedin {
  color: #0077b5;
  border-radius: 20%;
}

.fab.fa-instagram {
  background-color: #e1306c;
  color: #ffffff;
  background-position: fill;
  border-radius: 20%;
}

.social-link:hover {
  transform: scale(1.5);
  transition: .02s .02s ease;
}

/* ============ Form Container ============ */
.contact-form {
  max-width: 750px;
  margin: 3rem auto;
  padding: 2rem;
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.contact-form h2 {
  text-align: center;
  color: var(--primary);
  margin-bottom: 0.5rem;
}

.contact-form .form-intro {
  text-align: center;
  color: #666;
  margin-bottom: 2rem;
}

/* ============ Flex Layout ============ */
.form-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

.form-group {
  flex: 1;
  display: flex;
  flex-direction: column;
}

label {
  font-weight: 600;
  margin-bottom: 0.4rem;
}

label span {
  color: red;
}

input,
textarea,
select {
  padding: 0.75rem 1rem;
  border: 1px solid #ccc;
  border-radius: var(--radius);
  font-size: 1rem;
  transition: var(--transition);
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--secondary);
  outline: none;
  box-shadow: 0 0 0 2px rgba(0, 74, 173, 0.1);
}

/* ============ Checkbox Grid ============ */
.checkbox-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  padding: 0.25rem 0;
}

.checkbox-grid label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 500;
}

/* ============ Button ============ */
.form-submit {
  text-align: center;
  margin-top: 2rem;
}

/*.btn {
  background: var(--primary);
  color: #fff;
  padding: 0.9rem 2rem;
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 1.1rem;
  transition: var(--transition);
}

.btn:hover {
  background: var(--secondary);
  transform: translateY(-2px);
}*/