/* FAQ Page Specific Styles - Faithful recreation of the provided design */
    .faq-hero {
      padding: 80px 50px 0;
      text-align: center;
      max-width: 1200px;
      margin: 0 auto;
    }
    .faq-hero h1 {
      font-family: 'Livvic', sans-serif;
      font-weight: 600;
      font-size: 48px;
      line-height: 48px;
      color: #0f3dde;
      margin-bottom: 16px;
    }
    .faq-hero p {
      font-size: 20px;
      line-height: 28px;
      color: #4a5565;
      margin-bottom: 40px;
    }
    .search-box {
      position: relative;
      max-width: 672px;
      margin: 0 auto 64px;
    }
    .search-box input {
      width: 100%;
      height: 56px;
      padding: 16px 24px 16px 48px;
      border-radius: 16px;
      border: none;
      font-size: 16px;
      color: #0a0a0a;
      background: #fff;
      box-shadow: -4px -4px 12px rgba(255,255,255,0.9), 8px 8px 20px rgba(0,0,0,0.08);
    }
    .search-box input::placeholder {
      color: rgba(10,10,10,0.5);
    }
    .search-icon {
      position: absolute;
      left: 16px;
      top: 18px;
      width: 20px;
      height: 20px;
      pointer-events: none;
    }

    .faq-list {
      max-width: 836px;
      margin: 0 auto;
      display: flex;
      flex-direction: column;
      gap: 16px;
      padding-bottom: 80px;
    }
    .faq-item {
      background: #fff;
      border-radius: 16px;
      box-shadow: 4px 4px 12px rgba(0,0,0,0.06);
      overflow: hidden;
    }
    .faq-question {
      height: 80px;
      padding: 20px 24px;
      display: flex;
      align-items: center;
      gap: 12px;
      cursor: pointer;
      position: relative;
    }
    .faq-number {
      width: 40px;
      height: 40px;
      border-radius: 14px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: 'Livvic', sans-serif;
      font-weight: 600;
      font-size: 18px;
      color: #fff;
      flex-shrink: 0;
    }
    /* Colors per the design */
    .faq-item:nth-child(1) .faq-number { background: #e3f2ff; color: #0f3dde; }
    .faq-item:nth-child(2) .faq-number { background: #d1fae5; color: #10b981; }
    .faq-item:nth-child(3) .faq-number { background: #ede9fe; color: #8b5cf6; }
    .faq-item:nth-child(4) .faq-number { background: #fef3c7; color: #f59e0b; }
    .faq-item:nth-child(5) .faq-number { background: #fee2e2; color: #ef4444; }
    .faq-item:nth-child(6) .faq-number { background: #cffafe; color: #06b6d4; }
    .faq-item:nth-child(7) .faq-number { background: #ffe9e3; color: #ff7b72; }
    .faq-item:nth-child(8) .faq-number { background: #f3e8ff; color: #a855f7; }

    .faq-question h3 {
      font-family: 'Livvic', sans-serif;
      font-weight: 600;
      font-size: 20px;
      line-height: 30px;
      color: #0a0a0a;
      flex: 1;
    }
    .faq-toggle {
      width: 16px;
      height: 16px;
      margin-left: auto;
      transition: transform 0.3s ease;
    }
    .faq-item.active .faq-toggle {
      transform: rotate(180deg);
    }

    .faq-answer {
      /* padding: 0 24px 24px 76px; */
      max-height: 0;
      overflow: hidden;
      transition: max-height 0.4s ease, padding 0.4s ease;
    }
    .faq-item.active .faq-answer {
      padding: 24px 24px 24px 76px;
      max-height: 1000px;
    }
    .faq-answer p {
      font-size: 14px;
      line-height: 20px;
      color: #0a0a0a;
      margin-bottom: 16px;
    }
    .faq-answer p strong {
      font-weight: 600;
    }
    .faq-answer ul {
      margin: 8px 0 16px 16px;
      display: flex;
      flex-direction: column;
      gap: 8px;
    }
    .faq-answer ul li {
      font-size: 14px;
      line-height: 20px;
      color: #0a0a0a;
      list-style: disc;
    }
    .highlight-box {
      background: #e3f2ff;
      border-radius: 14px;
      padding: 16px;
      margin: 16px 0;
    }
    .highlight-box p {
      color: #0f3dde;
      font-weight: 600;
    }

    /* New CTA Section */
    .faq-cta {
      background: linear-gradient(180deg, #0f3dde 0%, #4169e1 100%);
      border-radius: 16px;
      height: 256px;
      max-width: 836px;
      margin: 0 auto 80px;
      position: relative;
      box-shadow: 4px 4px 12px rgba(15, 61, 222, 0.2);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center;
      padding: 40px;
    }
    .faq-cta h3 {
      color: #ffffff;
      font-family: 'Livvic', sans-serif;
      font-weight: 600;
      font-size: 30px;
      line-height: 36px;
      margin-bottom: 12px;
    }
    .faq-cta p {
      color: #ffffff;
      opacity: 0.9;
      font-size: 18px;
      line-height: 28px;
      max-width: 686px;
      margin-bottom: 24px;
    }
    .faq-cta .btn {
      background: #ffffff;
      color: #0f3dde;
      font-family: 'Plus Jakarta Sans', sans-serif;
      font-weight: 600;
      font-size: 16px;
      line-height: 24px;
      padding: 12px 32px;
      border-radius: 14px;
      text-decoration: none;
      display: inline-block;
      box-shadow: 0px 4px 6px -4px rgba(0,0,0,0.1), 0px 10px 15px -3px rgba(0,0,0,0.1);
      transition: transform 0.3s ease, box-shadow 0.3s ease;
    }
    .faq-cta .btn:hover {
      transform: translateY(-3px);
      box-shadow: 0px 8px 20px rgba(0,0,0,0.15);
    }

    /* Responsive */
    @media (max-width: 992px) {
      .faq-hero { padding: 60px 30px 0; }
      .faq-hero h1 { font-size: 42px; }
      .faq-cta { max-width: 100%; margin-left: 30px; margin-right: 30px; }
    }
    @media (max-width: 768px) {
      .faq-hero { padding: 40px 20px 0; }
      .faq-hero h1 { font-size: 36px; line-height: 40px; }
      .faq-hero p { font-size: 18px; }
      .search-box { max-width: 100%; }
      .faq-question { height: auto; padding: 16px; flex-wrap: wrap; }
      .faq-question h3 { font-size: 18px; }
      .faq-answer { padding-left: 20px; padding-right: 20px; }
      .faq-item.active .faq-answer { padding: 20px; }
      .faq-cta { height: auto; padding: 40px 20px; margin-left: 20px; margin-right: 20px; }
      .faq-cta h3 { font-size: 26px; }
      .faq-cta p { font-size: 16px; }
    }
    @media (max-width: 640px) {
      .faq-hero, .faq-list, .faq-cta { padding-left: 20px; padding-right: 20px; }
      .faq-cta { margin-left: 20px; margin-right: 20px; }
    }