
.rs-faq-wrap {
  width: min(1280px, calc(100% - 32px));
  margin: -70px auto 42px;
  color: #1f2e43;
  font-family: Arial, Helvetica, sans-serif;
}

.rs-faq-hero img {
  display: block;
  width: 100%;
  height: auto;
}

.rs-faq-intro,
.rs-faq-section,
.rs-faq-links {
  background: #fff;
  border: 1px solid #d9dfeb;
  border-radius: 18px;
  box-shadow: 0 10px 28px rgba(14, 28, 54, 0.08);
}

.rs-faq-intro {
  margin-top: 28px;
  padding: 30px 34px;
}

.rs-faq-title {
  margin: 0 0 18px;
  color: #123f82;
  font-size: clamp(34px, 4.2vw, 62px);
  line-height: 1.02;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.rs-faq-jumps {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.rs-faq-jumps a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 10px 16px;
  text-align: center;
  text-decoration: none;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 700;
  color: #123f82;
  background: linear-gradient(180deg, #ffffff 0%, #eef3fb 100%);
  border: 2px solid #c9d6ea;
  border-radius: 999px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.rs-faq-jumps a:hover,
.rs-faq-jumps a:focus,
.rs-faq-links-grid a:hover,
.rs-faq-links-grid a:focus {
  transform: translateY(-2px);
  border-color: #123f82;
  box-shadow: 0 8px 18px rgba(18, 63, 130, 0.16);
}

.rs-faq-section {
  margin-top: 28px;
  padding: 24px 28px;
}

.rs-faq-section-title {
  margin: 0 0 16px;
  color: #123f82;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.rs-faq-item {
  border: 1px solid #d8e1ef;
  border-radius: 16px;
  overflow: hidden;
  background: #f9fbfe;
}

.rs-faq-item + .rs-faq-item {
  margin-top: 14px;
}

.rs-faq-item summary {
  position: relative;
  list-style: none;
  cursor: pointer;
  padding: 18px 56px 18px 18px;
  color: #123f82;
  font-size: 22px;
  line-height: 1.28;
  font-weight: 800;
}

.rs-faq-item summary::-webkit-details-marker {
  display: none;
}

.rs-faq-item summary::after {
  content: '+';
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #fff;
  background: #123f82;
  font-size: 22px;
  font-weight: 700;
}

.rs-faq-item[open] summary {
  background: linear-gradient(180deg, #ffffff 0%, #f0f5fd 100%);
}

.rs-faq-item[open] summary::after {
  content: '–';
}

.rs-faq-answer {
  padding: 0 18px 18px;
}

.rs-faq-answer p {
  margin: 0 0 14px;
  color: #1c2939;
  font-size: 20px;
  line-height: 1.58;
}

.rs-faq-answer p:last-child {
  margin-bottom: 0;
}

.rs-faq-answer .qa-label {
  color: #123f82;
  font-weight: 800;
}

.rs-faq-answer a {
  color: #c62828;
  font-weight: 700;
}

.rs-faq-links {
  margin-top: 28px;
  padding: 22px;
}

.rs-faq-links-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.rs-faq-links-grid a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 68px;
  padding: 12px 14px;
  text-align: center;
  text-decoration: none;
  font-size: 22px;
  line-height: 1.15;
  font-weight: 700;
  color: #123f82;
  background: linear-gradient(180deg, #ffffff 0%, #eef3fb 100%);
  border: 2px solid #c9d6ea;
  border-radius: 16px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

@media (max-width: 980px) {
  .rs-faq-wrap {
    width: min(100%, calc(100% - 20px));
    margin: -54px auto 34px;
  }

  .rs-faq-intro { padding: 24px 22px; }
  .rs-faq-section { padding: 20px; }
  .rs-faq-item summary { font-size: 20px; }
  .rs-faq-answer p { font-size: 18px; }
}

@media (max-width: 700px) {
  .rs-faq-wrap {
    margin: -34px auto 28px;
  }

  .rs-faq-intro,
  .rs-faq-section,
  .rs-faq-links {
    border-radius: 14px;
  }

  .rs-faq-intro { padding: 20px 16px; }
  .rs-faq-section { padding: 16px; }
  .rs-faq-title { margin-bottom: 12px; }
  .rs-faq-item summary {
    font-size: 18px;
    padding: 16px 48px 16px 14px;
  }
  .rs-faq-answer { padding: 0 14px 14px; }
  .rs-faq-answer p { font-size: 17px; line-height: 1.52; }
  .rs-faq-jumps a { width: 100%; font-size: 17px; min-height: 48px; }
  .rs-faq-links-grid { grid-template-columns: 1fr; }
  .rs-faq-links-grid a { min-height: 56px; font-size: 18px; }
}
