html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  margin-bottom: 60px;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}

/* Support Page FAQ Accordion Styles - Exact Design Match */

/* Main FAQ Section */
.support-faq-section {
  position: relative;
  background-color: #ffffff;
  padding: 80px 0;
  margin-top:100px;
}

/* Main Title Styling */
.support-faq-section h2.fs-heading {
  color: #1B1B1B;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 60px;
}

/* Section Title Styling (e.g., "OPERATION & TRAINING") */
/* Base: 40px for 1440px and above (1920px and below) */
.support-faq-section .faq-section-wrapper h3 {
  color: #3261BB;
  font-weight: 700;
  font-size: 40px;
  line-height: 1.3;
  margin-bottom: 30px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

/* Range 3 - 1440px to 1920px - Keep 40px */
@media only screen and (min-width: 1440px) and (max-width: 1920px) {
  .support-faq-section .faq-section-wrapper h3 {
    font-size: 40px;
  }
}

/* Range 2 - 1200px to 1439px */
@media only screen and (min-width: 1200px) and (max-width: 1439px) {
  .support-faq-section .faq-section-wrapper h3 {
    font-size: 36px;
  }

    .support-faq-section {
        margin-top: 80px;
    }

}

/* Range 1 - 992px to 1199px */
@media only screen and (min-width: 992px) and (max-width: 1199px) {
  .support-faq-section .faq-section-wrapper h3 {
    font-size: 32px;
  }

    .support-faq-section {
        margin-top: 80px;
    }

}

/* Tablet Range - 768px to 991px */
@media only screen and (min-width: 768px) and (max-width: 991px) {
  .support-faq-section .faq-section-wrapper h3 {
    font-size: 28px;

    margin-bottom: 20px;
  }

    .support-faq-section {
        margin-top: 60px;
    }

}

/* Mobile - up to 767px */
@media (max-width: 767px) {
  .support-faq-section .faq-section-wrapper h3 {
    font-size: 24px;
    margin-bottom: 20px;
  }


    .support-faq-section {
        margin-top: 40px;
    }

}

/* FAQ Accordion Container */
.support-faq-section .tp-faq-ai-tab-content {
  background: transparent;
}

/* Accordion Item Styling */
.support-faq-section .tp-faq-ai-tab-content .accordion-item {
  background-color: #ffffff;
  border: none;
  border-bottom: 1px solid #E5E5E5;
  padding: 24px 0;
  margin: 0;
}

.support-faq-section .tp-faq-ai-tab-content .accordion-item:last-child {
  border-bottom: none;
  margin-bottom: 0;
}

/* Add margin-bottom after last accordion item in each section */
/* Range 3 - 1440px to 1920px - 50px margin */
@media only screen and (min-width: 1440px) and (max-width: 1920px) {
  .support-faq-section .tp-faq-ai-tab-content .accordion-item:last-child {
    margin-bottom: 50px;
  }
}

/* Range 2 - 1200px to 1439px - 40px margin */
@media only screen and (min-width: 1200px) and (max-width: 1439px) {
  .support-faq-section .tp-faq-ai-tab-content .accordion-item:last-child {
    margin-bottom: 40px;
  }
}

/* Range 1 - 992px to 1199px - 35px margin */
@media only screen and (min-width: 992px) and (max-width: 1199px) {
  .support-faq-section .tp-faq-ai-tab-content .accordion-item:last-child {
    margin-bottom: 35px;
  }
}

/* Tablet Range - 768px to 991px - 30px margin */
@media only screen and (min-width: 768px) and (max-width: 991px) {
  .support-faq-section .tp-faq-ai-tab-content .accordion-item:last-child {
    margin-bottom: 30px;
  }
}

/* Mobile - up to 767px - 25px margin */
@media (max-width: 767px) {
  .support-faq-section .tp-faq-ai-tab-content .accordion-item:last-child {
    margin-bottom: 25px;
  }
}

/* Accordion Button (Question) Styling */
.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn {
  position: relative;
  color: #1B1B1B;
  font-family: 'Geist Sans', sans-serif !important;
  font-weight: 600;
  font-size: 20px;
  line-height: 1.4;
  letter-spacing: -0.01em;
  padding: 0;
  padding-right: 0;
  text-align: left;
  background: transparent;
  border: none;
  box-shadow: none;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* Question text wrapper */
.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn .question-text {
  flex: 1;
  padding-right: 20px;
}

.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn:hover,
.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn:focus {
  color: #1B1B1B;
  background: transparent;
  box-shadow: none;
  border: none;
}

.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn:not(.collapsed) {
  color: #1B1B1B;
  background: transparent;
  box-shadow: none;
}

/* Question Number Styling (01, 02, etc.) - Removed */

/* Range 3 - 1441px to 1920px - Question font size 28px */
@media only screen and (min-width: 1441px) and (max-width: 1920px) {
  .support-faq-section .tp-faq-ai-tab-content .tp-faq-btn {
    font-size: 28px;
  }
}

/* Mobile - Question font size 18px */
@media (max-width: 767px) {
  .support-faq-section .tp-faq-ai-tab-content .tp-faq-btn {
    font-size: 18px;
  }
  
  .support-faq-section .tp-faq-ai-tab-content .tp-faq-btn .question-text {
    padding-right: 15px;
  }
}

/* Accordion Button Icon (Plus/Minus) - Positioned at the end */
.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn .accordion-btn {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-left: auto;
}

/* Create the plus icon structure */
.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn .accordion-btn::before {
  position: absolute;
  content: "";
  width: 2px;
  height: 100%;
  left: 50%;
  top: 0;
  background-color: #1B1B1B;
  transform: translateX(-50%);
  border-radius: 1px;
  transition: all 0.3s ease;
}

.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn .accordion-btn::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 2px;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background-color: #1B1B1B;
  border-radius: 1px;
  transition: all 0.3s ease;
}

/* Rotate to create minus when expanded */
.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn:not(.collapsed) .accordion-btn::before {
  transform: translateX(-50%) rotate(90deg);
  opacity: 0;
}

.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn:not(.collapsed) .accordion-btn::after {
  transform: translateY(-50%);
  opacity: 1;
}

/* Accordion Body (Answer) Styling */
.support-faq-section .tp-faq-ai-tab-content .accordion-body {
  padding: 20px 0 0 0;
  padding-left: 0;
}

.support-faq-section .tp-faq-ai-tab-content .tp-faq-details-para {
  padding: 0;
}

.support-faq-section .tp-faq-ai-tab-content .tp-faq-details-para p {
  color: #495A73;
  font-family: 'Geist Sans', sans-serif !important;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 0;
  padding-left: 0;
}

/* Ensure utility classes apply Geist Sans */
.support-faq-section .tp-faq-ai-tab-content .tp-faq-details-para .fs-para-font-fm {
  font-family: 'Geist Sans', sans-serif !important;
}

/* Answer text stays 16px on all screens - no media query needed */

/* Remove default Bootstrap accordion icon */
.support-faq-section .tp-faq-ai-tab-content .tp-faq-btn::after {
  display: none !important;
}

.support-faq-section .tp-faq-ai-tab-content .accordion-button::after {
  display: none !important;
}

/* FAQ Section Wrapper Spacing */
.support-faq-section .faq-section-wrapper {
  margin-bottom: 60px;
}

.support-faq-section .faq-section-wrapper:last-child {
  margin-bottom: 0;
}

@media (max-width: 991px) {
  .support-faq-section {
    padding: 60px 0;
  }
  
  .support-faq-section h2.fs-heading {
    margin-bottom: 40px;
  }
  
  .support-faq-section .faq-section-wrapper {
    margin-bottom: 40px;
  }
}

@media (max-width: 767px) {
  .support-faq-section {
    padding: 40px 0;
  }
  
  .support-faq-section h2.fs-heading {
    margin-bottom: 30px;
  }
  
  .support-faq-section .faq-section-wrapper {
    margin-bottom: 30px;
  }
  
  .support-faq-section .tp-faq-ai-tab-content .accordion-item {
    padding: 20px 0;
  }
}