@charset "UTF-8";

/* ---------------------
  - Heading
  - Button
  - List
  - Table
  - Modal
  - Miscellaneous
--------------------- */
*:focus {
  border: 2px solid #0060df !important;
  outline: none;
}

[tabindex="-1"]:focus {
  border: 0 !important;
}

/* Heading
------------------------------ */
/* -- 左側に●がつく見出し -- */
.headingDot {
  position: relative;
  font-size: 20px;
  line-height: 1.4;
  padding-left: 30px;
  margin-bottom: 5px;
  margin-bottom: 25px;
}

.headingDot small {
  font-size: 89%;
}

.headingDot::before {
  content: "●";
  position: absolute;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-left: -30px;
}

.headingDot-yellow::before {
  color: #FFB900;
}

.headingDot-blue::before {
  color: #00ADDC;
}

.headingDot-red::before {
  color: #D50057;
}

.headingDot-pink::before {
  color: #e5156c;
}

@media screen and (max-width: 767px) {
  .headingDot {
    font-size: 17px;
  }
}

/* -- 左側にボーダーがつく見出し -- */
.headingBorderLeft {
  border-left: 4px solid;
  font-size: 17px;
  line-height: 1;
  margin-bottom: 15px;
  padding-left: 26px;
}

.headingBorderLeft-blue {
  border-color: #00ADDC;
}

.headingBorderLeft-blue2 {
  border-left: 8px solid;
  border-color: #001c71;
}

.headingBorderLeft-blue3 {
  border-color: #001C71;
}

.headingBorderLeft-red {
  border-color: #D50057;
}

.headingBorderLeft-yellow {
  border-color: #FFB900;
}

.headingBorderLeft-pink {
  border-color: #e5156c;
}

.headingBorderLeft-yellow2 {
  border-color: #FEC558;
}

.headingBorderLeft-big {
  border-left-width: 5px;
  font-size: 20px;
  margin-bottom: 19px;
  padding-left: 15px;
}

.headingBorderLeft-small {
  font-size: 16px;
  padding-left: 12px;
}

.headingBorderLeft-narrow {
  padding-left: 12px;
}

.headingBorderLeft::before {
  content: none !important;
}

@media screen and (max-width: 767px) {
  .headingBorderLeft {
    font-size: 18px;
  }
}

/* -- 下線がつく見出し -- */
.headingUnderline {
  border-bottom: 1px solid;
  font-size: 20px;
  line-height: 1.1;
  margin-bottom: 15px;
  padding: 5px 0 10px;
}

.headingUnderline-blue {
  border-color: #00ADDC;
}

.headingUnderline-pink {
  border-color: #e5156c;
}

@media screen and (max-width: 767px) {
  .headingUnderline {
    font-size: 16px;
    line-height: 1.75;
    margin-bottom: 18px;
    padding: 5px 0;
  }
}

/* -- 太い下線がつく見出し -- */
.headingUnderlineBold {
  border-bottom: 5px solid;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.285;
  margin-bottom: 35px;
  padding-bottom: 12px;
}

.headingUnderlineBold-navy {
  border-color: #001C71;
}

.headingUnderlineBold-red {
  border-color: #D50057;
}

.headingUnderlineBold-yellow {
  border-color: #ffb900;
}

/* -- べたぬりがつく見出し -- */
.headingFilled {
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.56;
  margin-bottom: 18px;
  padding: 6px 10px;
}

.headingFilled:not(:first-of-type) {
  margin-top: 25px;
}

.headingFilled-red {
  background: #D50057;
}

.headingFilled-blue {
  background: #001C71;
}

.headingFilled-blue2 {
  background: #00ADDC;
}

.headingFilled-lightblue {
  background: #f2f4f8;
  color: #001C71;
}

.headingFilled-lightblue2 {
  background: #dcf0f2;
  color: #001C71;
}

.headingFilled-yellow {
  background: #FEC558;
  color: #000;
}

.headingFilled-yellow2 {
  background: #FEE2AB;
  color: #000;
}

.headingFilled-gray {
  background: #E5E5E5;
  color: #000;
}

@media screen and (max-width: 767px) {
  .headingFilled {
    font-size: 16px;
    line-height: 1.75;
    margin-bottom: 5px;
    padding: 0 6px;
  }

  .headingFilled:not(:first-of-type) {
    margin-top: 25px;
  }
}

/* -- 背景中央線がつく見出し -- */
.contentBorderlr {
  position: relative;
  padding: 0 65px;
  text-align: center;
}

.contentBorderlr::before {
  position: absolute;
  top: calc(50% - 1px);
  left: 0;
  width: 100%;
  height: 1px;
  content: "";
  background: #000;
}

.contentBorderlr-pink::before {
  background: #e5156c;
}

.contentBorderlr span {
  position: relative;
  padding: 0 1em;
  background: #fff;
}

.contentBorderlr span.bgbaseR {
  display: inline-block;
  border-radius: 30px;
  padding: 5px 80px;
}

.contentBorderlr span.bgbaseR-pink {
  color: #fff;
  background: #e5156c;
}

.contentBorderlr-yellow::before {
  background: #ffb900;
}

.contentBorderlr span.bgbaseR.bgbaseR-yellow {
  color: #333;
  background: #ffb900 !important;
}

@media screen and (max-width: 767px) {
  .contentBorderlr {
    position: relative;
    padding: 0 20px;
    text-align: center;
  }

  .contentBorderlr span.bgbaseR {
    border-radius: 30px;
    padding: 5px 10px;
  }
}

/* Button
------------------------------ */
/* -- ページ内リンクに使われるべたぬりのアコーディオンつきのボタン -- */
.btnRectangle {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin-left: -6px;
  margin-right: -6px;
}

.btnRectangle .btnRectangle_item {
  margin: 0 6px 14px 6px;
  position: relative;
  width: calc(25% - 12px);
}

.btnRectangle .btnRectangle_item-3 {
  width: calc(33.3333333333% - 12px);
}

.btnRectangle .btnRectangle_item-3-1 {
  width: calc(33.3333333333% - 12px);
}

.btnRectangle .btnRectangle_link {
  align-items: center;
  border-radius: 5px;
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
  display: flex;
  font-size: 14px;
  justify-content: center;
  line-height: 1.2;
  min-height: 65px;
  padding: 10px;
  position: relative;
  text-align: center;
  text-decoration: none;
}

.btnRectangle .btnRectangle_link>div {
  margin-top: -5%;
  width: 100%;
}

.btnRectangle .btnRectangle_link-blue {
  background: #e5f7fb;
  border: 2px solid #001c71;
  color: #001c71;
}

.btnRectangle .btnRectangle_link-blue>div {
  color: #001c71;
}

.btnRectangle .btnRectangle_link-red {
  background: #D50057;
  color: #fff;
}

.btnRectangle .btnRectangle_link-red>div {
  color: #fff;
}

.btnRectangle .btnRectangle_link-yellow {
  background: #ffb900;
}

.btnRectangle .btnRectangle_link-yellowLight {
  background: #ffe49c;
  border: 2px solid #ffb900;
}

.btnRectangle .btnRectangle_link-yellowGhost {
  background: #fff;
  border: solid 2px #ffb900;
}

.btnRectangle .btnRectangle_link-blueGhost {
  background: #fff;
  border: solid 2px #001C71;
}

.btnRectangle .btnRectangle_link-3line {
  min-height: 83px;
}

.btnRectangle .btnRectangle_link-largest {
  min-height: 110px;
  padding: 4px 27px;
}

.btnRectangle .btnRectangle_link-withtn>div {
  margin-top: 0%;
  width: 100%;
}

.btnRectangle .btnRectangle_link-withtn {
  min-height: 110px;
  padding: 0px 10px 10px;
}

.btnRectangle .btnRectangle_link::after {
  bottom: 3px;
  content: "▾";
  display: block;
  font-size: 24px;
  height: 24px;
  left: 0px;
  margin: 0 auto;
  position: absolute;
  right: 0px;
  text-align: center;
  width: 24px;
}

.btnRectangle .btnRectangle_title {
  border-bottom: 5px solid #001C71;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.06;
  padding: 10px 0;
}

.btnRectangle .btnRectangle_caption {
  font-size: 14px;
  line-height: 1.21;
  padding: 8px 0;
}

.qandaindex.btnRectangle .btnRectangle_title {
  font-size: 18px;
  line-height: 1.6;
  padding: 14px 0;
}

.qandaindex.btnRectangle .btnRectangle_caption {
  font-size: 14px;
  line-height: 1.21;
  padding: 8px 0 0;
}

.qandaindex.btnRectangle .btnRectangle_link::after {
  display: none !important;
}

@media screen and (max-width: 1023px) {
  .btnRectangle .btnRectangle_item {
    width: calc(33.3333333333% - 12px);
  }

  .btnRectangle .btnRectangle_link {
    min-height: 83px;
    padding: 0;
  }

  .btnRectangle .btnRectangle_link-largest {
    min-height: 131px;
    padding: 4px 27px;
  }

  .btnRectangle .btnRectangle_link-withtn {
    min-height: 131px;
    padding: 4px 4px;
  }

  .btnRectangle .btnRectangle_link-food {
    min-height: 60px;
    padding: 0;
  }
}

@media screen and (max-width: 820px) {
  .btnRectangle .btnRectangle_caption {
    font-size: 11px;
    line-height: 1.36;
    padding: 10px 0 14px;
  }
}

@media screen and (max-width: 767px) {
  .btnRectangle .btnRectangle_item {
    width: calc(50% - 12px);
  }

  .btnRectangle .btnRectangle_item-3-1 {
    width: calc(100% - 12px);
  }

  .btnRectangle .btnRectangle_link-largest {
    padding: 4px 9px;
  }

  .btnRectangle .btnRectangle_link-withtn {
    padding: 0px 10px 10px;
  }

  .btnRectangle .btnRectangle_title {
    font-size: 14px;
    line-height: 1.21;
    padding: 14px 0;
  }

  .qandaindex.btnRectangle .btnRectangle_title {
    font-size: 16px;
    line-height: 1.6;
    padding: 10px 0;
  }

  .qandaindex.btnRectangle .btnRectangle_caption {
    font-size: 14px;
    line-height: 1.36;
    padding: 10px 0 0;
  }

}

.btnRectangle_ch {
  display: none;
  z-index: 99;
  background: white;
  position: absolute;
  bottom: 0;
  transform: translateY(100%);
  left: 0;
  border: solid 1px #B2B2B2;
  width: 100%;
}

.btnRectangle_ch .btnRectangle_ch_link {
  display: block;
  text-decoration: none;
  text-align: center;
  font-size: 13px;
  padding: 15px 10px;
  transition: background-color 0.3s;
}

.btnRectangle_ch .btnRectangle_ch_link:not(:first-of-type) {
  border-top: solid 1px #B2B2B2;
}

.btnRectangle_ch .btnRectangle_ch_link:hover {
  background: #ebebeb;
}

/* -- /glossary/などで使われるべたぬりボタン -- */
.glossaryBtnList {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -4px;
}

.glossaryBtnList .glossaryBtnList_item {
  margin: 0 4px 10px;
}

.btnSquare {
  background: #FFB900;
  border-radius: 5px;
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
  display: inline-block;
  font-size: 22px;
  padding: 7px 0 12px;
  text-align: center;
  width: 95px;
}

@media screen and (max-width: 767px) {
  .btnSquare {
    font-size: 18px;
    padding: 12px 0;
    width: 52px;
  }
}

/* -- link/index.htmlなどにある画像が含まれたボタン -- */
.btnSquareImgList {
  display: flex;
  margin: 0 15px;
}

.btnSquareImgList .btnSquareImgList_item {
  padding: 0 30px;
  width: 50%;
}

.btnSquareImgList .btnSquareImg {
  background: white;
  border: solid 2px;
  border-radius: 5px;
  box-shadow: 0 3px 10px 0 rgba(0, 0, 0, 0.2);
  display: block;
  padding: 15px;
  text-decoration: none;
}

.btnSquareImgList .btnSquareImg .btnSquareImg_img img {
  width: 100%;
}

.btnSquareImgList .btnSquareImg .btnSquareImg_txt {
  align-items: center;
  display: flex;
  height: 72px;
  justify-content: center;
}

.btnSquareImgList .btnSquareImg .btnSquareImg_txt p {
  border-bottom: solid 5px;
  font-size: 22px;
  font-weight: bold;
  padding: 6px 0;
  text-align: center;
}

.btnSquareImgList .btnSquareImg-yellow {
  border-color: #FFB900;
}

.btnSquareImgList .btnSquareImg-yellow .btnSquareImg_txt p {
  border-color: #FFB900;
}

.btnSquareImgList .btnSquareImg-blue {
  border-color: #001C71;
}

.btnSquareImgList .btnSquareImg-blue .btnSquareImg_txt p {
  border-color: #001C71;
  font-size: 20px;
}

.btnSquareImgList .btnSquareImg-red {
  border-color: #D50057;
}

.btnSquareImgList .btnSquareImg-red .btnSquareImg_txt p {
  border-color: #D50057;
}

.btnSquareImgList-3 {
  margin: 0 -15px;
}

.btnSquareImgList-3 .btnSquareImgList_item {
  margin: 0 15px;
  margin-bottom: 30px;
  padding: 0;
  width: calc(33% - 30px);
}

.btnSquareImgList-3 .btnSquareImg {
  padding: 9px;
}

.btnSquareImgList-3 .btnSquareImg .btnSquareImg_img {
  margin-bottom: 13px;
}

.btnSquareImgList-3 .btnSquareImg .btnSquareImg_txt {
  margin-bottom: 18px;
}

.btnSquareImgList-3 .btnSquareImg .btnSquareImg_txt p {
  line-height: 1.2;
  padding: 8px 0;
}

@media screen and (max-width: 1183px) {
  .btnSquareImgList {
    margin: 0 -15px;
  }

  .btnSquareImgList .btnSquareImgList_item {
    padding: 0 15px;
  }

  .btnSquareImgList .btnSquareImg {
    padding: 10px;
  }

  .btnSquareImgList .btnSquareImg .btnSquareImg_txt {
    height: 60px;
  }

  .btnSquareImgList .btnSquareImg .btnSquareImg_txt p {
    font-size: 18px;
    line-height: 1.39;
  }

  .btnSquareImgList-3 .btnSquareImgList_item {
    padding: 0;
  }

  .btnSquareImgList-3 .btnSquareImg {
    padding: 9px;
  }
}

@media screen and (max-width: 767px) {
  .btnSquareImgList {
    display: block;
    margin: 0;
  }

  .btnSquareImgList .btnSquareImgList_item {
    margin-bottom: 15px;
    padding: 0;
    width: 100%;
  }

  .btnSquareImgList-3 .btnSquareImgList_item {
    margin: 0;
    margin-bottom: 15px;
    padding: 0;
  }

  .btnSquareImgList-3 .btnSquareImg {
    padding: 9px;
  }

  .btnSquareImgList-3 .btnSquareImg .btnSquareImg_img {
    margin-bottom: 13px;
  }
}

/* -- about-sma/diagnosis.htmlなどで使われる矢印付きのゴーストボタン -- */
.btnArrowRight {
  background: #fff;
  border: 1px solid #B2B2B2;
  border-radius: 5px;
  box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.2);
  display: inline-block;
  font-size: 16px;
  padding: 11px;
  position: relative;
  text-align: center;
  transition: 0.2s background-color;
  max-width: 311px;
  width: 100%;
}

.btnArrowRight::after {
  content: "▶";
  position: absolute;
  right: 15px;
}

.content.blue .btnArrowRight:hover {
  background-color: #CCEFF8;
}

.btnArrowLeft {
  background: #fff;
  border: 1px solid #B2B2B2;
  border-radius: 5px;
  box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.2);
  font-size: 16px;
  display: inline-block;
  max-width: 311px;
  padding: 11px;
  position: relative;
  text-align: center;
  transition: 0.2s background-color;
  width: 100%;
}

.btnArrowLeft::after {
  content: "▶";
  left: 15px;
  position: absolute;
  transform: rotate(-180deg);
}

@media screen and (max-width: 767px) {

  .btnArrowRight,
  .btnArrowLeft {
    font-size: 14px;
    max-width: 100%;
  }
}

.btnArrownone {
  background: #fff;
  border: 1px solid #B2B2B2;
  border-radius: 5px;
  box-shadow: 0 2px 3px 0 rgba(0, 0, 0, 0.2);
  font-size: 16px;
  display: inline-block;
  max-width: 350px;
  padding: 11px;
  position: relative;
  text-align: center;
  transition: 0.2s background-color;
  width: 100%;
}

/* -- about-sma/treatment.htmlで使われている矢印型ボタン -- */
.btnArrowBig {
  border-bottom: 1px solid #001C71;
  color: #001C71;
  display: inline-block;
  font-weight: bold;
  padding-bottom: 7px;
  padding-right: 35px;
  position: relative;
}

.btnArrowBig::after {
  border-right: 1px solid #001C71;
  content: "";
  display: inline-block;
  height: 35px;
  position: absolute;
  transform: rotate(-44deg);
  right: 13px;
  bottom: -6px;
}

/* -- モーダルで使われている立体感のあるボタン -- */
.btnSkeumo {
  background: linear-gradient(#F8F8F8 70%, #ccc 100%);
  border-radius: 50px;
  display: inline-block;
  font-size: 22px;
  font-weight: bold;
  padding: 7px 0;
  position: relative;
  text-align: center;
  max-width: 266px;
  width: 100%;
}

.btnSkeumo::before {
  background: linear-gradient(#d9d9d9, #f8f8f8);
  border-radius: 50px;
  content: "";
  display: block;
  height: 100%;
  left: -3px;
  padding: 3px;
  position: absolute;
  top: -3px;
  width: 100%;
  z-index: -1;
}

/* -- PDFダウンロードなどのボタン -- */
.btnDownload {
  background: white;
  border-radius: 3px;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.2);
  display: inline-block;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.25;
  max-width: 284px;
  max-width: 320px;
  padding: 15px 30px 15px 15px;
  position: relative;
  text-align: center;
  text-decoration: none;
  width: 100%;
}

.btnDownload img {
  display: block;
  height: 26px;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
}

.btnDownload-blue {
  background: #E5F7FB;
  border: 2px solid #001C71;
  color: #001C71;
}

@media screen and (max-width: 767px) {
  .btnDownload-blue {
    max-width: 100%;
  }
}

/* List
------------------------------ */
/* -- 中黒リスト -- */
.listDot .listDot_item {
  line-height: 1.75;
  padding-left: 1em;
}

.listDot .listDot_item::before {
  content: "・";
  margin-left: -1em;
}

.listDot-blue .listDot_item::before {
  color: #00ADDC;
}

/* -- glossary/などで使用されているストライプ状リスト -- */
.listStripe {
  border-top: 2px solid #333333;
}

.listStripe:not(:last-of-type) {
  margin-bottom: 65px;
}

.listStripe:last-of-type {
  margin-bottom: 30px;
}

.listStripe .listStripe_item {
  border-bottom: 1px solid #B2B2B2;
}


.listStripe .listStripe_item:nth-of-type(odd) {
  background: #F2F2F2;
}

.listStripe .listStripe_heading {
  font-size: 18px;
  line-height: 1.39;
  margin-bottom: 10px;
  padding-left: 20px;
}

.listStripe .listStripe_heading::before {
  margin-left: -20px;
}

.listStripe .listStripe_url {
  color: #001C71;
  font-weight: bold;
  line-height: 1.5625;
  margin-bottom: 10px;
  margin-left: 25px;
  text-decoration: underline;
  word-wrap: break-word;
}

.listStripe .listStripe_text {
  line-height: 1.5625;
  margin-left: 25px;
}

.listStripe .listStripe_link {
  display: block;
  opacity: 1;
  padding: 15px 20px;
  transition: 0.1s opacity;
}

.listStripe .listStripe_link:hover {
  opacity: 0.7;
}

.listStripe .listStripe_dl {
  display: table;
  width: 100%;
  position: relative;
}

.listStripe .listStripe_dl a::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  pointer-events: auto;
  content: "";
  background-color: rgba(0, 0, 0, 0)
}

.listStripe .listStripe_dt {
  border-right: 1px dashed #B2B2B2;
  display: table-cell;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.375;
  padding: 15px 20px;
  vertical-align: middle;
  width: 210px;
}

.listStripe .listStripe_dd {
  display: table-cell;
  font-size: 16px;
  line-height: 1.375;
  padding: 15px 20px;
  vertical-align: middle;
}

.listStripe .listStripe_dd1 {
  width: 590px;
}

@media screen and (max-width: 820px) {
  .listStripe .listStripe_dd1 {
    width: 30%;
  }

  .listStripe .listStripe_dd1 {
    width: 50%;
  }

  .listStripe .listStripe_dd2 {
    width: 20%;
  }

}

@media screen and (max-width: 767px) {
  .listStripe:not(:last-of-type) {
    margin-bottom: 45px;
  }

  .listStripe .listStripe_item:nth-of-type(odd) {
    background: transparent;
  }

  .listStripe .listStripe_heading {
    font-size: 16px;
  }

  .listStripe .listStripe_link {
    padding: 15px 0;
  }

  .listStripe .listStripe_dl {
    display: block;
    padding: 17px 0;
  }

  .listStripe .listStripe_dt {
    border: 0;
    display: block;
    font-size: 16px;
    line-height: 1.375;
    margin-bottom: 12px;
    padding: 0;
    width: 100%;
  }

  .listStripe .listStripe_dd {
    display: block;
    font-size: 14px;
    line-height: 1.57;
    padding: 0;
  }

  .listStripe .listStripe_dd1 {
    width: 100%;
  }

  .listStripe .listStripe_dd2 {
    width: 100%;
    text-align: right;
  }
}

/* -- link/support.htmlのリンクリスト -- */
.listLinkSupport .listLinkSupport_item {
  margin-bottom: 26px;
}

.listLinkSupport .listLinkSupport_heading {
  font-size: 18px;
  line-height: 1.39;
  margin-bottom: 7px;
  padding-left: 20px;
}

.listLinkSupport .listLinkSupport_heading::before {
  margin-left: -20px;
}

.listLinkSupport .listLinkSupport_link {
  line-height: 1.5625;
  word-wrap: break-word;
}

.listLinkSupport .listLinkSupport_link-pc {
  margin-left: 40px;
}

.listLinkSupport .listLinkSupport_link-pc a {
  color: #001C71;
  font-weight: bold;
  text-decoration: underline;
}

.listLinkSupport .listLinkSupport_link-sp {
  margin-left: calc(23px + 1em);
  text-indent: -1em;
}

.listLinkSupport .listLinkSupport_text {
  font-size: 16px;
  line-height: 1.5625;
  margin-left: 40px;
  margin-top: 5px;
}

.listLinkSupport .listLinkSupport_note {
  font-size: 12px;
  margin-left: 40px;
  margin-top: 5px;
}

.listLinkSupport .listLinkSupportLinkRow .listLinkSupportLinkRow_link {
  display: inline-block;
  line-height: 1.5625;
  word-wrap: break-word;
}

.listLinkSupport .listLinkSupportLinkRow .listLinkSupportLinkRow_link-sp {
  margin-left: 23px;
  max-width: 272px;
  width: 100%;
}

.listLinkSupport .listLinkSupportLinkRow .listLinkSupportLinkRow_link-pc a {
  color: #001C71;
  font-weight: bold;
  text-decoration: underline;
}

@media screen and (min-width: 1024px) {
  .listLinkSupport .listLinkSupport_link-sp a {
    cursor: text;
    pointer-events: none;
  }

  .listLinkSupport .listLinkSupport_link-sp .link-external::after {
    content: none;
  }

  .listLinkSupport .listLinkSupportLinkRow .listLinkSupportLinkRow_link-sp a {
    cursor: text;
    pointer-events: none;
  }

  .listLinkSupport .listLinkSupportLinkRow .listLinkSupportLinkRow_link-sp .link-external::after {
    content: none;
  }
}

@media screen and (max-width: 1023px) {
  .listLinkSupport .listLinkSupport_item {
    border-bottom: 1px solid #B2B2B2;
    margin-bottom: 0;
    padding: 16px 0;
  }

  .listLinkSupport .listLinkSupport_heading {
    font-size: 16px;
    line-height: 1.375;
  }

  .listLinkSupport .listLinkSupport_link-pc {
    display: none;
  }

  .listLinkSupport .listLinkSupport_link-pc .link-external::after {
    content: none;
  }

  .listLinkSupport .listLinkSupport_link-sp a {
    color: #001C71;
    text-decoration: underline;
  }

  .listLinkSupport .listLinkSupportLinkRow .listLinkSupportLinkRow_link-sp a {
    color: #001C71;
    text-decoration: underline;
  }

  .listLinkSupport .listLinkSupportLinkRow .listLinkSupportLinkRow_link-pc {
    display: none;
  }

  .listLinkSupport .listLinkSupportLinkRow .listLinkSupportLinkRow_link-pc .link-external::after {
    content: none;
  }
}

/* -- patient/materials.htmlのリスト -- */
.patientsMaterialList {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -20px;
}

.patientsMaterialList .patientsMaterialList_item {
  flex: 1;
  margin: 0 20px 25px;
  max-width: calc(33% - 40px);
}

.patientsMaterialList .patientsMaterialList_title {
  font-size: 18px;
  font-weight: bold;
  display: table-cell;
  min-height: 5.76em;
  line-height: 1.44;
  vertical-align: bottom;
}

.patientsMaterialList .patientsMaterialList_img {
  margin: 15px 0;
}

.patientsMaterialList .patientsMaterialList_img img {
  width: 100%;
}

.patientsMaterialList .patientsMaterialList_txt {
  font-size: 16px;
  line-height: 1.625;
  min-height: 9.7em;
  margin-bottom: 12px;
}

.patientsMaterialList .patientsMaterialList_btn {
  margin-bottom: 10px;
}

.patientsMaterialList .patientsMaterialList_btn a {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .patientsMaterialList {
    display: block;
    margin: 0;
  }

  .patientsMaterialList .patientsMaterialList_item {
    margin: 0 0 25px;
    max-width: 100%;
  }

  .patientsMaterialList .patientsMaterialList_title {
    font-size: 16px;
    display: block;
    min-height: auto;
    line-height: 1.4375;
  }

  .patientsMaterialList .patientsMaterialList_txt {
    font-size: 14px;
    line-height: 1.64;
    min-height: auto;
  }

  .patientsMaterialList .patientsMaterialList_btn {
    font-size: 12.3px;
    line-height: 1.22;
    text-align: center;
  }
}

/* -- Q & A List -- */
.qanda {
  width: 100%;
}

.qanda.qandalist {
  width: 100%;
  border-top: solid 3px #001c71;
  border-bottom: solid 3px #001c71;
}

.qanda.qandalist dt:nth-of-type(odd),
.qanda.qandalist dd:nth-of-type(odd) {
  background: #f7f8fb;
}

.qanda-toggle .qanda_q {
  cursor: pointer;
  padding-right: 40px !important;
}

.qanda-toggle .qanda_q .btn_ac {
  position: absolute;
  width: 15px;
  height: 15px;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  z-index: 100;
}

.qanda-toggle .qanda_q .btn_ac:before {
  content: "";
  display: block;
  height: 15px;
  width: 1px;
  background: #333;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  transition: transform 0.3s;
}

.qanda-toggle .qanda_q .btn_ac:after {
  content: "";
  display: block;
  height: 1px;
  width: 15px;
  background: #333;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  transition: transform 0.3s;
}

.qanda-toggle .qanda_q .btn_ac.opened:before {
  transform: translateX(-50%) rotate(45deg);
}

.qanda-toggle .qanda_q .btn_ac.opened:after {
  transform: translateY(-50%) rotate(45deg);
}

.qanda-toggle .qanda_a {
  display: none;
}

.qanda .qanda_q {
  border-bottom: solid 1px #001C71;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.75;
  padding: 16px 0 10px;
  margin-left: 58px;
  position: relative;
}

.qanda.qandalist .qanda_q {
  border-bottom: none;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.75;
  padding: 16px 20px 10px;
  padding-left: 68px;
  margin-left: 0px;
  position: relative;
  cursor: pointer;
  cursor: pointer;
}


.qanda .qanda_q::before {
  background: #E5F7FB;
  border: 1px solid #001C71;
  border-radius: 100%;
  color: #001C71;
  content: "Q";
  display: block;
  font-size: 36px;
  font-weight: 300;
  height: 46px;
  margin-left: -58px;
  line-height: 40px;
  padding-right: 1px;
  position: absolute;
  text-align: center;
  top: 30px;
  transform: translateY(-50%);
  width: 46px;
}

.qanda.qandalist .qanda_q::after {
  content: " ";
  display: block;
  height: 1px;
  width: 100%;
  margin-top: 20px;
  background: #b2bbd4;
}

.qanda .qanda_a {
  font-size: 16px;
  line-height: 1.75;
  margin-bottom: 43px;
  margin-left: 58px;
  padding: 10px 0 16px;
  position: relative;
}

.qanda .qanda_a.buttom-img {
  margin-bottom: 6px;
}

.qanda.qandalist .qanda_a {
  font-size: 16px;
  line-height: 1.75;
  margin-bottom: 0px;
  margin-left: 0px;
  padding: 10px 20px 16px;
  padding-left: 68px;
  position: relative;
}

.qanda.qandalist .qanda_a {
  border-bottom: solid 1px #001C71;
}

.qanda .qanda_a::before {
  color: #001C71;
  content: "A";
  display: block;
  font-size: 40px;
  font-weight: 400;
  height: 40px;
  margin-left: -54px;
  margin-top: -9px;
  line-height: 1;
  overflow: hidden;
  position: absolute;
  text-align: center;
  top: 30px;
  transform: translateY(-50%);
  width: 40px;
}

.qanda .qanda_a p {
  line-height: 1.75;
}

.qanda_detail {
  width: 100%;
  border-top: none;
  border-bottom: none;
}

.qanda_detail dt:nth-of-type(odd),
.qanda_detail dd:nth-of-type(odd) {
  background: #fff;
}

.qanda_detail .qanda_q {
  padding-bottom: 20px;
  margin-bottom: 0px;
}

.qanda_detail .qanda_a {

  border-bottom: none;
}

.qanda {
  display: table;
  width: 100%;
  position: relative;
}

.qanda a::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  pointer-events: auto;
  content: "";
  background-color: rgba(0, 0, 0, 0)
}

@media screen and (max-width: 767px) {

  .qanda .qanda_q {
    font-size: 14px;
    line-height: 1.785;
    margin-left: 42px;
    padding: 12px 0 14px;
    text-align: left;
  }

  .qanda.qandalist .qanda_q {
    font-size: 14px;
    line-height: 1.785;
    margin-left: 0px;
    padding: 12px 10px 0px 47px;
    text-align: left;
  }

  .qanda .qanda_q::before {
    font-size: 26px;
    height: 35px;
    margin-left: -42px;
    line-height: 28px;
    top: 24px;
    width: 35px;
  }

  .qanda .qanda_a {
    font-size: 14px;
    line-height: 1.57;
    margin-left: 42px;
    padding: 14px 0 12px;
    text-align: left;
  }

  .qanda.qandalist .qanda_a {
    font-size: 14px;
    line-height: 1.57;
    margin-left: 0px;
    padding: 14px 10px 12px 42px;
    text-align: left;
  }

  .qanda .qanda_a::before {
    font-size: 30px;
    height: 30px;
    margin-left: -35px;
    line-height: 1;
    top: 33px;
    transform: translateY(-50%);
    width: 30px;
  }
}

/* Table
------------------------------ */
/* -- 基本のtable -- */
.tableBasic {
  border-collapse: collapse;
  width: 100%;
}

.tableBasic tr th,
.tableBasic tr td {
  border: 1px solid #000;
  font-size: 15px;
  font-weight: normal;
  line-height: 1.47;
  padding: 4px 12px;
}

.tableBasic-orange thead tr th {
  background: #FFB900;
}

@media screen and (max-width: 767px) {

  .tableBasic tr th,
  .tableBasic tr td {
    border: 0;
  }

  .tableBasic tr th p,
  .tableBasic tr td p {
    line-height: 1.43;
  }

  .tableBasic tr th:first-child,
  .tableBasic tr td:first-child {
    width: 100%;
  }

  .tableBasic thead tr th {
    padding: 5px 14px;
    text-align: left;
  }

  .tableBasic tbody tr td {
    padding: 9px 14px;
  }

  .tableBasic .tableBasicList .tableBasicList_item {
    padding-left: 1em;
  }

  .tableBasic .tableBasicList .tableBasicList_item:not(:last-of-type) {
    margin-bottom: 8px;
  }

  .tableBasic .tableBasicList .tableBasicList_item::before {
    content: "■";
    float: left;
    margin-left: -1em;
    width: 1em;
  }

  .tableBasic .tableBasicList .tableBasicList_heading {
    margin-bottom: 6px;
  }

  .tableBasic-orange .tableBasicList .tableBasicList_item::before {
    color: #FFB900;
  }
}

/* -- 横スクロール可能なtable -- */
.scroll-table {
  overflow: auto;
  white-space: nowrap;
  border: solid 1px #ddd;
}

.scroll-table table {
  margin: 0;
  border: none;
}

/* Modal
------------------------------ */
/* -- 外部リンクをクリックしたときの確認モーダル -- */
.modalExternal {
  display: none;
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 9999;
}

.modalExternalBG {
  background: rgba(0, 0, 0, 0.3);
  height: 100%;
  width: 100%;
}

.modalExternalContent {
  background: #fff;
  border: 15px solid #e5e5e5;
  left: 50%;
  max-width: 840px;
  padding: 50px;
  position: fixed;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: calc(100% - 1em);
  z-index: 100;
}

.modalExternalContent .modalExternalContent_close {
  background: transparent;
  color: #333;
  cursor: pointer;
  display: inline-block;
  height: 45px;
  line-height: 1;
  position: absolute;
  right: 9px;
  top: 11px;
  vertical-align: middle;
  width: 45px;
}

.modalExternalContent .modalExternalContent_close::before,
.modalExternalContent .modalExternalContent_close::after {
  background: currentColor;
  border-radius: 0.1em;
  content: "";
  height: 0.1em;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
}

.modalExternalContent .modalExternalContent_close::before {
  transform: rotate(135deg);
}

.modalExternalContent .modalExternalContent_close::after {
  transform: rotate(45deg);
}

.modalExternalContent .modalExternalContent_heading {
  font-size: 32px;
  line-height: 1.75;
  margin: 0 auto 25px;
  padding-bottom: 5px;
}

.modalExternalContent .modalExternalContent_txt {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.55;
  margin-bottom: 48px;
  text-align: center;
}

.modalExternalContent .modalExternalContent_btn {
  margin-bottom: 25px;
  text-align: center;
  position: relative;
  z-index: 0;
}

@media screen and (max-width: 767px) {
  .modalExternalContent {
    border-width: 10px;
    padding: 45px 28px;
    width: calc(100% - 2em);
  }

  .modalExternalContent .modalExternalContent_heading {
    font-size: 24px;
    margin: 0 auto 20px;
    padding-bottom: 2px;
  }

  .modalExternalContent .modalExternalContent_txt {
    font-size: 18px;
    line-height: 1.67;
    margin-bottom: 43px;
  }

  .modalExternalContent .modalExternalContent_btn {
    margin-bottom: 15px;
  }

  .modalExternalContent .modalExternalContent_btn .btnSkeumo {
    font-size: 20px;
  }

  .modalExternalContent .modalExternalContent_close {
    top: 23px;
    width: 28px;
  }
}

/* Miscellaneous
------------------------------ */
/* -- 隠しテキスト -- */
.text-hide {
  clip: rect(0, 0, 0, 0);
  display: block;
  height: 0;
  overflow: hidden;
  width: 0;
}

/* -- 上付き／下付き文字 -- */
.sup {
  font-size: 70%;
  vertical-align: super;
}

.sub {
  font-size: 70%;
  vertical-align: sub;
}

/* -- 動画プレイヤーレスポンシブ -- */
.video {
  margin-left: auto;
  margin-right: auto;
  max-width: 770px;
  padding-top: 56.25%;
  position: relative;
  width: 100%;
}

.video iframe {
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
}

.video_tn {
  margin-left: auto;
  margin-right: auto;
  max-width: 770px;
  position: relative;
  width: 100%;
}

/* -- 注釈 -- */
.note {
  font-size: 12px;
  font-weight: normal;
  line-height: 1.42;
  word-break: break-word;
  margin-top: 11px;
}

.note+.note {
  margin-top: 0;
}

.supervision {
  display: flex;
  font-size: 12px;
  font-weight: normal;
  justify-content: flex-end;
  margin-top: 11px;
  word-break: break-word;
}

.supervision p {
  font-size: 12px;
}

.supervision ul {
  margin-left: 5px;
}

.supervision li {
  font-size: 12px;
  line-height: 1.42;
}

/* -- 外部リンク -- */
.link-external::after {
  content: url(../img_mr/common/icon_external.svg);
  display: inline-block;
  height: 15px;
  margin-left: 0.3125em;
  text-align: right;
  vertical-align: -2px;
  width: 15px;
}

a[target=_blank] img[src$="icon_external.svg"] {
  height: 15px;
  margin-left: 0.3125em;
  vertical-align: -2px;
  width: 15px;
}

/* -- 吹き出し -- */
.balloon {
  background: #fff;
  border: solid 4px #ffb900;
  border-radius: 5px;
  display: inline-block;
  font-size: 18px;
  margin: 46px 0;
  padding: 20px 10px;
  position: relative;
  text-align: center;
  width: 100%;
}

.balloon::before {
  border: 18px solid transparent;
  border-top: 18px solid #fff;
  bottom: -33px;
  content: "";
  left: 50%;
  margin-left: -15px;
  position: absolute;
  z-index: 2;
}

.balloon::after {
  border: 20px solid transparent;
  border-top: 20px solid #ffb900;
  bottom: -40px;
  content: "";
  left: 50%;
  margin-left: -17px;
  position: absolute;
  z-index: 1;
}

.blue .balloon {
  border-color: #00ADDC;
  border-width: 2px;
  font-size: 14px;
  margin: 0 0 20px;
}

.blue .balloon::before {
  bottom: -35px;
}

.blue .balloon::after {
  border-top-color: #00ADDC;
}

@media screen and (min-width: 768px) {
  .blue .balloon {
    display: none;
  }
}

.pink .balloon {
  border-color: #e5156c;
  border-width: 2px;
  color: #e5156c;
}

.pink .balloon::before {
  bottom: -35px;
}

.pink .balloon::after {
  border-top-color: #e5156c;
}

/* --  -- */
.link_box_wide {
  border-radius: 5px;
  padding: 17px;
}

.link_box_wide p {
  font-size: 18px;
  line-height: 1.22;
}

.link_box_wide-blue {
  background: #CCEFF8;
}

.link_box_wide-red {
  background: #F9D9E6;
}

.link_box_wide-yellow {
  background: #fbedc4;
}

.link_box_wide-l-yellow {
  background: #fff8e5;
}

.link_box_wide-pink {
  background: #fbdce9;
}

@media screen and (max-width: 767px) {
  .link_box_wide p {
    font-size: 16px;
    line-height: 1.375;
  }
}

/* -- mars finder -- */

.header .mf_finder_container {
  margin-left: 1rem;
  margin-right: 1rem;
}

/*  mars finderのinput デフォルトCSS reset */
.header .mf-search-box .mf-search-bar .mf-search-bar_input {
  width: 260px !important;
  height: 35px !important;
  box-sizing: inherit !important;
  padding: 0 !important;
  border: none !important;
  font-size: 13px !important;
  font-family: inherit !important;
  line-height: inherit !important;
  background-color: none !important;

  border-top: solid 1px #ccc !important;
  border-left: solid 1px #ccc !important;
  border-bottom: solid 1px #ccc !important;
  padding: 0 10px !important;
}



.header .mf-search-box {
  height: 30px;
  padding-right: 20px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.header .mf-search-box .mf-search-bar {
  display: flex;

}

.header .mf-search-box .mf-search-bar_input {
  border-top: solid 1px #ccc !important;
  border-left: solid 1px #ccc !important;
  border-bottom: solid 1px #ccc !important;
  border-right: none !important;
  border-radius: 5px 0px 0 5px !important;
  background: white !important;
  height: 100% !important;
  width: 260px !important;
  font-size: 13px !important;
  padding: 0 10px !important;
  appearance: none;
  min-height: 34px;

}

.header .mf-search-box .mf-search-bar_input::-moz-placeholder {
  color: #707070;
  opacity: 1;
}

.header .mf-search-box .mf-search-bar_input:-ms-input-placeholder {
  color: #707070;
  opacity: 1;
}

.header .mf-search-box .mf-search-bar_input::placeholder {
  color: #707070;
  opacity: 1;
}


/*  mars button デフォルトCSS reset */
.header .mf-search-box .mf-search-bar .mf-search-bar_button {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  height: 34px !important;
  white-space: nowrap;
  font-family: inherit !important;
  color: #fff;
  font-size: 100%;
  cursor: pointer;
}


.header .mf-search-box .mf-search-bar .mf-search-bar_button .mf-search-bar_button_icon {
  display: none;
}


.header .mf-search-box .mf-search-bar_button {
  min-width: 60px;
  border-radius: 0 5px 5px 0 !important;
  background: #E5E5E5 url(../img/icon_search.png) center center/21px auto no-repeat !important;
  border: solid 1px #ccc !important;
}


.header .mf-search-box .mf-search-bar_button::before {
  content: none;
}

.header .mf-search-box .mf-search-bar_button span {
  clip: rect(0, 0, 0, 0);
  display: block;
  height: 0;
  overflow: hidden;
  width: 0;
}



@media screen and (max-width: 1023px) {
  .header .mf-search-box .mf-search-bar .mf-search-bar_input {
    width: 100% !important;
  }

  .header .mf_finder_container {
    background: #F7F9F9;
    padding: 5px 20px;
    margin: 0 1rem;
  }

  .header .mf-search-box {
    height: auto;
    justify-content: flex-start;
    width: 100%;
    padding-right: 0px;
    padding: 1rem 0px !important;
  }

  .header .mf-search-box .mf_finder_searchBox_items_wrapper,
  .header .mf-search-box .mf_finder_searchBox_query_wrap,
  .header .mf-search-box .mf_finder_searchBox_items {
    width: 100%;
  }

  .header .mf-search-box .mf-search-bar {
    width: 100%;
  }

  .header .mf-search-box .mf-search-bar_input {
    width: 100% !important;
    height: 30px;
  }
}


/* 検索結果の画面　*/

.content_body .mf_finder_searchBox {
  background: #efefef;
  margin-bottom: 0.75rem;
  padding: 0.5em 1em;
}

.content_body .mf_finder_searchBox_doctype_select {
  border-right: 0;
  height: 100%;
}

.content_body .mf-search-box .mf-search-bar {
  display: flex;
  -ms-flex-align: stretch;
  align-items: stretch;
  padding: 1rem 0 0.5rem 0;
}

/* select box　*/

/*デフォルト*/
.mf-search-box .mf-search-bar .mf-search-bar_doc-type .mf-search-bar_doc-type_select {
  height: 45px !important;
  padding: 2px 5px;
  white-space: nowrap;
  border-radius: 3px 0 0 3px !important;
}

.mf-custom-select-wrapper .mf-custom-select-wrapper_custom-select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: .5rem 1.5rem .5rem .5rem !important;
  border: 1px solid #ccc !important;
  background-color: #fff;
  cursor: pointer;
  font-size: 100%;
  font-family: unset;
  width: max-content;
  line-height: 1.2 !important;
}

.mf-custom-select-wrapper .mf-custom-select-wrapper_custom-select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: .5rem 1.5rem .5rem .5rem !important;
  border: 1px solid #333;

  cursor: pointer;
  font-size: 100%;
  font-family: unset;
  width: max-content;
  line-height: 1;
}


.mf-search-box .mf-search-bar .mf-search-bar_input {
  width: 100%;
  height: 45px !important;
  box-sizing: border-box;
  padding: .5rem 1.5rem .5rem .5rem !important;
  border: 1px solid #ccc !important;
  border-left: none !important;
  font-size: 100%;
  font-family: inherit !important;
  line-height: 1.2 !important;
  background-color: #fff;
}



.content_body .mf-search-bar_doc-type_select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  font-size: 1rem;
  border: 1px solid #ccc;
  border-radius: 3px 0 0 3px;
  padding: .5rem 1.5rem .5rem .5rem;
  border-right: 0;
  height: 100%;
}




.content_body .mf-search-box .mf-search-bar .mf-search-bar_button {

  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  height: 45px !important;
  padding: 0 .75rem !important;
  white-space: nowrap;
  font-family: unset;
  border-radius: 0 3px 3px 0 !important;
  background-color: #222 !important;
  color: #eee !important;
  border: none;
  font-size: 16px !important;
  cursor: pointer;
}



.content_body .mf-search-box {
  background: #efefef;
  margin-bottom: 0.75rem;
  padding: 0.5em 1em 1em 1em;
}

.content_body .mf_finder_searchBox_doctype_select {
  border-right: 0;
  height: 100%;
}

@media screen and (max-width: 767px) {
  .mf_finder_organic_doc {
    display: block;
  }

  .mf_finder_organic_doc_contents_wrapper {
    margin-left: 0;
  }
}

.frame-view #mf_overlay {
  z-index: 999 !important;
}


.content_body .mf-search-results .mf-search-results_header {}


.content_body .mf-search-results .mf-search-results_body .mf-search-results_body_result {
  display: -ms-flexbox;
  display: flex;
  padding: 1.5rem 1rem !important;
  border-bottom: 1px solid #ddd;
  list-style: none;
}

.content_body .mf-pagination .mf-pagination_button.active-page {
  background-color: #222 !important;
  color: #fff;
  border: none !important;
}

.content_body .mf-search-results .mf-search-results_body .mf-search-results_body_result .mf-search-results_body_result_texts .mf-search-results_body_result_texts_title .mf-search-results_body_result_texts_title_link {
  color: #111 !important;
  line-height: 1.45;
  margin-bottom: 10px;

}

.content_body .mf-search-results .mf-search-results_body .mf-search-results_body_result .mf-search-results_body_result_texts .mf-search-results_body_result_texts_title .mf-search-results_body_result_texts_title_link:visited {
  color: #a086b7 !important;
}



.content_body .mf-search-results_body_result_texts_url_text:before {
  content: "URL";
  background-color: #111;
  color: #fff;
  font-size: 9px;
  font-family: Arial, sans-serif;
  vertical-align: middle;
  padding: 2px 6px;
  margin-right: .5rem;
}


.content_body .mf-search-results .mf-search-results_body .mf-search-results_body_result .mf-search-results_body_result_texts .mf-search-results_body_result_texts_description {
  font-size: 14px;
  margin: 0 0 10px;
  line-height: 1.45;
  !important overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;

  height: 3.7rem !important;
  margin-bottom: 0;
  overflow: hidden;
  word-break: break-word;
  margin-bottom: 10px;
}

.content_body .mf-search-box .mf-filters .mf-filters_selects .mf-filters_selects_other .mf-filters_selects_other_item .mf-filters_selects_other_item_icon {
  color: #777;
}

@media (max-width: 576px) {
  .content_body .mf-search-results .mf_imgsize-2 {
    width: 55vw !important;

  }
}

.content_body .mf-search-results_header strong {
  color: #333333 !important;
}



.content_body .mf-search-results_header strong:nth-child(2):before {
  content: "";
  display: inline-block;
}






/* Navigation
------------------------------ */
.nav_block {
  margin-right: 1em;
  width: 250px;
}

.nav_block.full {
  width: 720px;
}

@media screen and (max-width: 1023px) {
  .nav_block {
    width: 100%;
    margin-bottom: 5px;
  }
}

@media screen and (max-width: 1130px) {
  .nav_block.full {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .nav_block.full {
    width: 100%;
  }
}

.nav_top {
  padding: 2px;
}

@media screen and (max-width: 1023px) {
  .nav_top {
    padding: 0;
  }
}

.nav_bottom {
  overflow: hidden;
  padding: 2px;
}

.nav_bottom .nav_block {
  float: left;
}

.nav_bottom .nav_block:nth-of-type(1),
.nav_bottom .nav_block:nth-of-type(2) {
  margin-right: 80px;
}

@media screen and (max-width: 1023px) {
  .nav_bottom {
    padding: 0;
  }

  .nav_bottom .nav_block {
    float: none;
  }
}

@media screen and (max-width: 1790px) {
  .nav_bottom .nav_block:nth-of-type(2) {
    margin-right: 0;
  }

  .nav_bottom .nav_block:nth-of-type(1),
  .nav_bottom .nav_block:nth-of-type(3),
  .nav_bottom .nav_block:nth-of-type(4) {
    margin-right: 80px;
  }
}

@media screen and (-ms-high-contrast: active) and (max-width: 1800px),
screen and (-ms-high-contrast: none) and (max-width: 1800px) {
  .nav_bottom .nav_block:nth-of-type(2) {
    margin-right: 0;
  }

  .nav_bottom .nav_block:nth-of-type(1),
  .nav_bottom .nav_block:nth-of-type(3) {
    margin-right: 80px;
  }
}

@media screen and (max-width: 1460px) {
  .nav_bottom .nav_block:nth-of-type(1) .nav_category_body {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-wrap: wrap;
  }
}

@media screen and (max-width: 1460px) and (max-width: 1023px) {
  .nav_bottom .nav_block:nth-of-type(1) .nav_category_body {
    display: none;
  }
}

@media screen and (max-width: 1460px) {
  .nav_bottom .nav_block:nth-of-type(1) .nav_category_body li {
    width: 33.3333333333%;
  }

  .nav_bottom .nav_block:nth-of-type(1),
  .nav_bottom .nav_block:nth-of-type(2) {
    width: 100%;
  }
}

@media screen and (max-width: 1090px) {
  .nav_bottom .nav_block:nth-of-type(1) .nav_category_body li {
    width: 50%;
  }
}

@media screen and (max-width: 1023px) {
  .nav_bottom .nav_block {
    margin-right: 0;
  }

  .nav_bottom .nav_block:nth-of-type(1) .nav_category_body {
    flex-direction: column;
  }

  .nav_bottom .nav_block:nth-of-type(1) .nav_category_body li {
    width: 100%;
  }
}

.nav_layout-col2 .nav_layout-col2_item {
  width: 50%;
}

.nav_layout-col2 .nav_layout-col2_item:nth-child(1) {
  float: left;
  margin-bottom: 20px;
}

.nav_layout-col2 .nav_layout-col2_item:nth-child(2) {
  float: right;
}

.nav_layout-col2 .nav_layout-col2_item:nth-child(3) {
  float: right;
}

@media screen and (max-width: 1023px) {
  .nav_layout-col2 .nav_layout-col2_item {
    width: 100%;
  }

  .nav_layout-col2 .nav_layout-col2_item .nav_heading-primary {
    margin-bottom: 5px;
  }

  .nav_layout-col2 .nav_layout-col2_item:nth-child(1) {
    float: none;
    margin-bottom: 0;
  }

  .nav_layout-col2 .nav_layout-col2_item:nth-child(2) {
    float: none;
  }

  .nav_layout-col2 .nav_layout-col2_item:nth-child(3) {
    float: none;
  }
}

.nav_category {
  background: transparent;
  padding-bottom: 5px;
  display: block;
  font-size: 15px;
  width: 100%;
  font-weight: 700;
  border-bottom: solid 1px #B2B2B2;
  margin-bottom: 20px;
  padding-top: 20px;
  position: relative;
  text-align: left;
}

.nav_category-sp {
  display: none;
}

@media screen and (max-width: 1023px) {
  .nav_category {
    background: #F7F9F9;
    border: none;
    padding: 10px 20px;
    margin-bottom: 0;
  }

  .nav_category-pc {
    display: none;
  }

  .nav_category-sp {
    display: block;
  }

  .nav_category_body {
    background: #F7F9F9;
    display: none;
  }
}

.nav_heading-primary {
  background: transparent;
  display: block;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 10px;
  position: relative;
  padding-left: 15px;
  text-align: left;
  width: 100%;
}

.nav_heading-primary:not(:first-of-type) {
  margin-top: 20px;
}

.nav_heading-primary:before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #B2B2B2;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.nav_heading-primary-sp {
  display: none;
}

@media screen and (max-width: 1023px) {
  .nav_heading-primary {
    background: white;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-right: 10px;
    margin-bottom: 0px;
    padding-left: 40px;
  }

  .nav_heading-primary:not(:first-child) {
    margin-top: 0;
  }

  .nav_heading-primary:not(:last-child) {
    margin-bottom: 5px;
  }

  .nav_heading-primary:before {
    margin-left: 20px;
  }

  .nav_heading-primary-pc {
    display: none;
  }

  .nav_heading-primary-sp {
    display: block;
  }
}

.nav_heading-primary_body {
  padding-left: 15px;
}

@media screen and (max-width: 1023px) {
  .nav_heading-primary_body {
    padding-left: 0;
    display: none;
  }

  .nav_heading-primary_body .nav_link {
    padding-left: 50px;
    padding-left: 70px;
  }

  .nav_heading-primary_body .nav_link::before {
    margin-left: 60px;
  }
}

.nav_heading-secondary {
  display: block;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 10px;
}

.nav_heading-secondary:not(:first-of-type) {
  margin-top: 10px;
}

@media screen and (max-width: 1023px) {
  .nav_heading-secondary {
    background: white;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-right: 10px;
    margin-bottom: 5px;
    padding-left: 40px;
    position: relative;
  }

  .nav_heading-secondary:before {
    content: none;
    display: block;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: #333;
    position: absolute;
    top: 19px;
    left: 40px;
  }

  .nav_heading-secondary:not(:first-of-type) {
    margin-top: 0;
  }
}

.nav_link {
  display: block;
  font-size: 14px;
  font-weight: 400;
  margin-bottom: 5px;
  position: relative;
  padding-left: 8px;
  padding-left: 28px;
}

.nav_link:before {
  content: "";
  display: block;
  width: 2px;
  height: 2px;
  border-radius: 50%;
  background: #333;
  position: absolute;
  top: 10px;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  margin-left: 18px;
}

.nav_link:hover {
  text-decoration: underline;
}

@media screen and (max-width: 1023px) {
  .nav_link {
    background: white;
    padding: 10px 10px 10px 35px;
  }

  .nav_link:before {
    margin-left: 25px;
  }
}

.nav_info {
  margin-top: 10px;
  width: 350px;
  display: block;
  margin-left: auto;
  transition: opacity 0.3s;
}

.nav_info:hover {
  opacity: 0.5;
}

.nav_info .nav_info_banner {
  width: 100%;
}

@media screen and (max-width: 1023px) {
  .nav_info {
    width: calc(100% - 40px);
    max-width: 400px;
    margin-right: auto;
    margin-left: auto;
    margin-top: 20px;
  }
}

.btn_ac {
  position: absolute;
  width: 15px;
  height: 15px;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  z-index: 100;
}

@media screen and (max-width: 1023px) {
  .btn_ac:before {
    content: "";
    display: block;
    height: 15px;
    width: 1px;
    background: #333;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    transition: transform 0.3s;
  }

  .btn_ac:after {
    content: "";
    display: block;
    height: 1px;
    width: 15px;
    background: #333;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    transition: transform 0.3s;
  }

  .btn_ac.opened:before {
    transform: translateX(-50%) rotate(45deg);
  }

  .btn_ac.opened:after {
    transform: translateY(-50%) rotate(45deg);
  }
}

.wrapper .side .sidenav_filter {
  align-items: center;
  background: white;
  display: none;
  font-size: 13px;
  font-weight: 700;
  justify-content: center;
  padding: 15px 10px;
  position: relative;
  text-decoration: none;
  transition: background-color 0.4s;
  width: 100%;
}

.wrapper .side .sidenav-body {
  display: none;
}

@media screen and (max-width: 1023px) {
  .wrapper .side .sidenav_filter {
    display: flex;
  }
}

.sidenav_ac {
  position: relative;
}

.sidenav_ac::before,
.sidenav_ac::after {
  content: "";
  display: block;
  left: 10px;
  position: absolute;
  transform: rotate(-45deg) translateY(-50%);
  transition: 0.2s all;
}

.sidenav_ac::before {
  border-bottom: #000 2px solid;
  border-left: #000 2px solid;
  bottom: calc(50% - 5px);
  height: 8px;
  opacity: 1;
  width: 8px;
}

.sidenav_ac::after {
  border-right: #000 2px solid;
  border-top: #000 2px solid;
  top: 50%;
  height: 0;
  opacity: 0;
  width: 0;
}

.sidenav_ac.opened::before {
  height: 0;
  opacity: 0;
  width: 0;
}

.sidenav_ac.opened::after {
  height: 8px;
  opacity: 1;
  width: 8px;
}

.pink {
  color: #e5156c;
}

.content_body_prof {
  max-width: 1030px;
  margin: 0 auto;
  background: white;
  box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.2);
  border-radius: 5px 5px 5px 5px;
  padding: 20px 50px 20px;
}

.content_body_prof a {
  font-size: 12px;
  color: #000 !important;
}

.content_prof_header_txt {
  font-size: 14px !important;
  line-height: 1.2;
}

.content_prof_header_txt .fs10 {
  font-size: 10px !important;
}

.content_prof_header_txt .fs12 {
  font-size: 12px !important;
}

.create {
  position: absolute;
  bottom: 10px;
  right: 10px;
  font-size: 12px;
}

@media screen and (max-width: 767px) {

  .content_body_prof {
    padding: 20px;
    width: 100%;
  }

  .content_prof_header_txt {
    font-size: 14px !important;
    line-height: 1.2;
  }

  .content_prof_header_txt .fs10 {
    font-size: 12px !important;
  }

  .content_prof_header_txt .fs12 {
    font-size: 14px !important;
  }
}

.f-black {
  color: #333;
}

/*# sourceMappingURL=parts.css.map */