@charset "UTF-8";
/*--------------------------------------------
faqHead
---------------------------------------------*/
#faqHead {
  background: #dda3d7;
}
#faqHead .ttl:before {
  content: "";
  background: url(/faq/img/icon_faq.png) no-repeat 0 0;
  background-size: 100% auto;
  display: inline-block;
  vertical-align: text-top;
}
@media screen and (max-width: 768px) {
  #faqHead {
    padding: calc(101 * 100vw / 750) 0 calc(108 * 100vw / 750) calc(40 * 100vw / 750);
  }
  #faqHead .ttl {
    font-size: calc(56 * 100vw / 750);
    font-weight: 700;
  }
  #faqHead .ttl:before {
    width: calc(90 * 100vw / 750);
    height: calc(90 * 100vw / 750);
    margin-right: calc(23 * 100vw / 750);
  }
}
@media print, screen and (min-width: 769px) {
  #faqHead {
    padding: calc(83 * 100vw / 1366) calc(40 * 100vw / 1366) calc(73 * 100vw / 1366);
  }
  #faqHead .ttl {
    font-size: calc(36 * 100vw / 1366);
    font-weight: 700;
  }
  #faqHead .ttl:before {
    width: calc(54 * 100vw / 1366);
    height: calc(54 * 100vw / 1366);
    margin-right: calc(17 * 100vw / 1366);
  }
}

/*--------------------------------------------
faqPage
---------------------------------------------*/
.faqPage .faq-title {
  text-align: center;
  color: #802077;
  font-weight: 700;
  line-height: 1;
}
.faqPage .faq-item {
  border-top: 1px solid #333;
}
.faqPage .faq-item:last-of-type {
  border-bottom: 1px solid #333;
}
.faqPage .faq-item .que {
  position: relative;
  background-image: url(/faq/img/icon_q.png);
  background-position: 0 50%;
  background-repeat: no-repeat;
  font-weight: 700;
}
.faqPage .faq-item .que .trigger {
  position: absolute;
}
.faqPage .faq-item .que .trigger::before,
.faqPage .faq-item .que .trigger::after {
  display: block;
  content: '';
  position: absolute;
  background: #000;
}
.faqPage .faq-item .que .trigger::after {
  transition: transform 0.3s ease-in;
}
.faqPage .faq-item .que.open .trigger::after {
  transform: rotate(270deg);
}
.faqPage .faq-item .ans {
  display: none;
  background-image: url(/faq/img/icon_a.png);
  background-position: 0 0;
  background-repeat: no-repeat;
}
.faqPage .faq-item .ans .btn {
  background-color: #ffbf00;
  background-image: url(/faq/img/arrow_black.svg);
  background-repeat: no-repeat;
  box-shadow: 3px 3px 3px rgb(0 0 0 / 30%);
  font-weight: 700;
  display: flex;
  align-items: center;
  backface-visibility: hidden;
  will-change: opacity;
  transition: opacity 0.6s ease-in;
  margin: auto;
}
.faqPage .faq-item .ans .btn.search {
  background-image: url(/faq/img/search_icon.svg);
}
.faqPage .link-contact {
  display: block;
  background: #802077;
  text-align: center;
  color: #fff;
  font-weight: 700; 
  background-image: url(/faq/img/arrow_white.svg);
  background-repeat: no-repeat;
}

/* 2303 医師の推奨意向 */
.faqPage .faq-item .doctor img {
  max-width: 100%;
}
.faqPage .faq-item .doctor .doctor-hd {
  background-color: #802077;
  text-align: center;
  color: #fff;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .faqPage {
    padding: calc(60 * 100vw / 750) 0 calc(250 * 100vw / 750);
  }
  .faqPage .faq-group {
    margin: 0 calc(40 * 100vw / 750) calc(120 * 100vw / 750);
  }
  .faqPage .faq-title {
    margin-bottom: calc(60 * 100vw / 750);
    font-size: calc(48 * 100vw / 750);
  }
  .faqPage .faq-item {
    padding: 0 calc(20 * 100vw / 750) 0;
  }
  .faqPage .faq-item .que {
    padding: calc(40 * 100vw / 750) calc(80 * 100vw / 750);
    background-size: calc(60 * 100vw / 750) calc(60 * 100vw / 750);
    font-size: calc(32 * 100vw / 750);
    line-height: calc(56 * 100vw / 750);
  }
  .faqPage .faq-item .que .trigger {
    top: calc(50% - calc(25 * 100vw / 750));
    right: calc(20 * 100vw / 750);
    width: calc(50 * 100vw / 750);
    height: calc(50 * 100vw / 750);
  }
  .faqPage .faq-item .que .trigger::before {
    top: calc(50% - calc(3 * 100vw / 750));
    left: 0;
    width: 100%;
    height: calc(6 * 100vw / 750);
  }
  .faqPage .faq-item .que .trigger::after {
    top: 0;
    left: calc(50% - calc(3 * 100vw / 750));
    width: calc(6 * 100vw / 750);
    height: 100%;
  }
  .faqPage .faq-item .ans {
    padding-left: calc(80 * 100vw / 750);
    background-size: calc(60 * 100vw / 750) calc(60 * 100vw / 750);
  }
  .faqPage .faq-item .ans p {
    margin-bottom: calc(20 * 100vw / 750);
    font-size: calc(28 * 100vw / 750);
    line-height: calc(45 * 100vw / 750);
  }
  .faqPage .faq-item .ans .btn {
    background-size: calc(15 * 100vw / 750) calc(25 * 100vw / 750);
    background-position: left calc(30 * 100vw / 750) center;
    border-radius: calc(45 * 100vw / 750);
    font-size: calc(30 * 100vw / 750);
    width: calc(550 * 100vw / 750);
    height: calc(90 * 100vw / 750);
    margin-bottom: calc(20 * 100vw / 750);
    justify-content: center;
    text-align: center;
  }
  .faqPage .faq-item .ans .btn.search {
    background-size: calc(26 * 100vw / 750) calc(26 * 100vw / 750);
    background-position-x: calc(84 * 100vw / 750);
  }
  .faqPage .link-contact {
    margin: 0 calc(40 * 100vw / 750);
    padding: calc(26 * 100vw / 750) 0 calc(28 * 100vw / 750);
    background-position: right calc(30 * 100vw / 750) center;
    background-size: calc(16 * 100vw / 750) auto;
    border-radius: calc(45 * 100vw / 750);
    font-size: calc(36 * 100vw / 750);
  }

  /* 2303 医師の推奨意向 */
  .faqPage .faq-item .doctor .doctor-hd {
    padding: calc(31 * 100vw / 750) 0 calc(32 * 100vw / 750);
    font-size: calc(34 * 100vw / 750);
    line-height: calc(51 * 100vw / 750);
  }
  .faqPage .faq-item .doctor .doctor-hd .big {
    font-size: calc(54 * 100vw / 750);
    line-height: calc(62 * 100vw / 750);
  }
  .faqPage .faq-item .doctor .doctor-txt {
    font-size: calc(30 * 100vw / 750);
    line-height: 1;
  }
  .faqPage .faq-item .doctor .doctor-banner li + li {
    margin: calc(10 * 100vw / 750) 0 0 0;
  }
  .faqPage .faq-item .doctor .doctor-recommend-img {
    width: calc(430 * 100vw / 750);
    margin-right: auto;
    margin-left: auto;
  }
  .faqPage .faq-item .doctor .doctor-recommend-txt {
    margin-bottom: calc(37 * 100vw / 750);
    font-size: calc(26 * 100vw / 750);
    line-height: calc(35 * 100vw / 750);
  }
}
@media print, screen and (min-width: 769px) {
  .faqPage {
    width: calc(980 * 100vw / 1366);
    margin: 0 auto;
    padding: calc(60 * 100vw / 1366) 0 calc(80 * 100vw / 1366);
  }
  .faqPage .faq-group {
    margin: 0 0 calc(80 * 100vw / 1366);
  }
  .faqPage .faq-title {
    margin-bottom: calc(40 * 100vw / 1366);
    font-size: calc(30 * 100vw / 1366);
  }
  .faqPage .faq-item {
    padding: 0 0 0 calc(20 * 100vw / 1366);
  }
  .faqPage .faq-item .que {
    padding: calc(15 * 100vw / 1366) 0 calc(20 * 100vw / 1366) calc(64 * 100vw / 1366);
    background-size: calc(40 * 100vw / 1366) calc(40 * 100vw / 1366);
    font-size: calc(20 * 100vw / 1366);
    line-height: calc(34 * 100vw / 1366);
  }
  .faqPage .faq-item .que .trigger {
    top: calc(50% - calc(15 * 100vw / 1366));
    right: calc(20 * 100vw / 1366);
    width: calc(30 * 100vw / 1366);
    height: calc(30 * 100vw / 1366);
  }
  .faqPage .faq-item .que .trigger::before {
    top: calc(50% - calc(2 * 100vw / 1366));
    left: 0;
    width: 100%;
    height: calc(4 * 100vw / 1366);
  }
  .faqPage .faq-item .que .trigger::after {
    top: 0;
    left: calc(50% - calc(2 * 100vw / 1366));
    width: calc(4 * 100vw / 1366);
    height: 100%;
  }
  .faqPage .faq-item .ans {
    padding-left: calc(60 * 100vw / 1366);
    background-size: calc(40 * 100vw / 1366) calc(40 * 100vw / 1366);
  }
  .faqPage .faq-item .ans p {
    margin-bottom: calc(20 * 100vw / 1366);
    font-size: calc(16 * 100vw / 1366);
    line-height: calc(24 * 100vw / 1366);
  }
  .faqPage .faq-item .ans .btn {
    background-size: calc(8 * 100vw / 1366) calc(12 * 100vw / 1366);
    background-position: right calc(30 * 100vw / 1366) center;
    border-radius: calc(35 * 100vw / 1366);
    font-size: calc(24 * 100vw / 1366);
    width: calc(500 * 100vw / 1366);
    height: calc(70 * 100vw / 1366);
    margin-bottom: calc(20 * 100vw / 1366);
    justify-content: center;
    text-align: center;
  }
  .faqPage .faq-item .ans .btn.search {
    background-size: calc(19 * 100vw / 1366) calc(19 * 100vw / 1366);
    background-position-x: calc(102 * 100vw / 1366);
  }
  .faqPage .link-contact {
    width: calc(500 * 100vw / 1366);
    margin: 0 auto;
    padding: calc(32 * 100vw / 1366) 0 calc(34 * 100vw / 1366);
    background-position: right calc(30 * 100vw / 1366) center;
    background-size: calc(8 * 100vw / 1366) auto;
    border-radius: calc(45 * 100vw / 1366);
    font-size: calc(24 * 100vw / 1366);
  }

  /* 2303 医師の推奨意向 */
  .faqPage .faq-item .doctor .doctor-hd {
    padding: calc(18 * 100vw / 1366) 0 calc(18 * 100vw / 1366);
    font-size: calc(22 * 100vw / 1366);
    line-height: calc(27 * 100vw / 1366);
  }
  .faqPage .faq-item .doctor .doctor-hd .big {
    font-size: calc(36 * 100vw / 1366);
    line-height: calc(51 * 100vw / 1366);
  }
  .faqPage .faq-item .doctor .doctor-txt {
    font-size: calc(17 * 100vw / 1366);
    line-height: 1;
  }
  .faqPage .faq-item .doctor .doctor-banner {
    display: flex;
    flex-wrap: wrap;
  }
  .faqPage .faq-item .doctor .doctor-banner li {
    width: calc((100% - calc(40 * 100vw / 1366)) / 3);
  }
  .faqPage .faq-item .doctor .doctor-banner li + li {
    margin: 0 0 0 calc(20 * 100vw / 1366);
  }
  .faqPage .faq-item .doctor .doctor-recommend-img {
    width: calc(270 * 100vw / 1366);
    margin-right: auto;
    margin-left: auto;
  }
  .faqPage .faq-item .doctor .doctor-recommend-txt {
    margin-bottom: calc(4 * 100vw / 1366);
    font-size: calc(13 * 100vw / 1366);
    line-height: calc(24 * 100vw / 1366);
  }
}

.faqPage .faqAnchorBtns {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
.faqPage .faqAnchorBtns a {
  background-color: #ffd800;
  background-repeat: no-repeat;
  background-position-y: center;
  box-shadow: 3px 3px 3px rgb(0 0 0 / 30%);
  font-weight: 700;
  display: flex;
  align-items: center;
  backface-visibility: hidden;
  will-change: opacity;
  transition: opacity 0.3s ease-in;
  margin: auto;
}

@media screen and (max-width: 768px) {
  .faqPage .faqNav {
    padding: calc(80 * 100vw / 750) 0 calc(118 * 100vw / 750);
  }
  .faqPage .faqAnchorBtns {
    padding: 0 calc(40 * 100vw / 750);
  }
  .faqPage .faqAnchorBtns li {
    margin-bottom: calc(40 * 100vw / 750);
  }
  .faqPage .faqAnchorBtns a {
    background-size: calc(30 * 100vw / 750) calc(19 * 100vw / 750);
    background-position-x: calc(145 * 100vw / 750);
    border-radius: calc(45 * 100vw / 750);
    font-size: calc(28 * 100vw / 750);
    width: calc(210 * 100vw / 750);
    height: calc(90 * 100vw / 750);
    justify-content: center;
  }
}

@media print, screen and (min-width: 769px) {
  .faqPage .faqNav {
    padding: 0 0 calc(80 * 100vw / 1366);
  }
  .faqPage .faqAnchorBtns {
    width: calc(800 * 100vw / 1366);
    margin: 0 auto;
  }
  .faqPage .faqAnchorBtns li {
    margin-bottom: calc(20 * 100vw / 1366);
  }
  .faqPage .faqAnchorBtns a {
    background-size: calc(20 * 100vw / 1366) calc(13 * 100vw / 1366);
    background-position-x: calc(190 * 100vw / 1366);
    border-radius: 35px;
    border-radius: calc(35 * 100vw / 1366);
    font-size: calc(24 * 100vw / 1366);
    width: calc(240 * 100vw / 1366);
    height: calc(70 * 100vw / 1366);
    justify-content: center;
    text-align: center;
  }
}

.bnr {
  display: block;
  margin: 0 auto 1em;
  text-align: center;
}
.bnr img {
  /*width: 100%;*/
  width: auto;
}

@media screen and (max-width: 768px) {
/*  .bnr {
    width: calc(550 * 100vw / 750);
  }*/
  .bnr img {
    height: calc(200 * 100vw / 750);
  }
}

@media print, screen and (min-width: 769px) {
/*  .bnr {
    width: calc(600 * 100vw / 1366);
  }*/
  .bnr img {
    height: 190px;
  }
}

.t-right {
  text-align: right;
}

@media screen and (max-width: 768px) {
  .sp-mt-10 {
    margin-top: calc(10 * 100vw / 750);
  }
  .sp-mt-16 {
    margin-top: calc(16 * 100vw / 750);
  }
  .sp-mt-20 {
    margin-top: calc(20 * 100vw / 750);
  }
  .sp-mt-24 {
    margin-top: calc(24 * 100vw / 750);
  }
  .sp-mt-38 {
    margin-top: calc(38 * 100vw / 750);
  }
  .sp-mt-40 {
    margin-top: calc(40 * 100vw / 750);
  }
  .sp-mt-42 {
    margin-top: calc(42 * 100vw / 750);
  }
}
@media print, screen and (min-width: 769px) {
  .pc-mt-10 {
    margin-top: calc(10 * 100vw / 1366);
  }
  .pc-mt-20 {
    margin-top: calc(20 * 100vw / 1366);
  }
  .pc-mt-25 {
    margin-top: calc(25 * 100vw / 1366);
  }
  .pc-mt-27 {
    margin-top: calc(27 * 100vw / 1366);
  }
  .pc-mt-52 {
    margin-top: calc(52 * 100vw / 1366)
  }
}