/* BASE
-------------------------------------------------- */

:root {
  --bs-font-sans-serif: 游ゴシック体, YuGothic, 游ゴシック, "Yu Gothic", Meiryo, sans-serif;
}

html {
  font-size:16px;
}

body {
  font-family: '游ゴシック体', YuGothic, '游ゴシック', 'Yu Gothic', Meiryo, sans-serif;
  font-weight: 500;
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", "Hiragino Sans", "ヒラギノ角ゴシック", "メイリオ", " Meiryo", "MS Pゴシック", "ＭＳ Ｐゴシック", "sans-serif";
  font-weight: 400;
  padding-top: 86px;
  color: rgb(var(--bs-tertiary-color-rgb));
  letter-spacing: 0.06em;
  line-height: 1.8;
  -webkit-text-size-adjust: 100%;
}

main {
  position: relative;
  overflow: hidden;
}

a,button {
  outline: none;
}

a {
    color: #000000;
    text-decoration: none;
}

.table>:not(caption)>*>* {
    padding: 1.2rem 1.2rem;
    font-size: 0.9rem;
}

.table>:not(caption)>*>th {
    font-weight: 500;
}

.table>:not(caption)>*>td {
    font-weight: 300;
}

.container {
  --bs-gutter-x: 2rem;
}

.navbar-nav {
  padding: 0 0;
  --bs-nav-link-padding-y: 1rem;
}

.nav-link {
  color: #000;
}
@media all and (-ms-high-contrast: none) {
  body,
  tooltip,
  popover {
    font-family: Verdana, Meiryo, sans-serif;
  }
}


.navbar-toggler {
    border: none;
    border-radius: 0;
  outline: none;
}

.fs-7 {
  font-size: 0.9rem !important;
}

.fs-8 {
  font-size: 0.8rem !important;
}

#map_canvas {
	width: 100%;
	height: 100%;
  aspect-ratio: 1 / 1;
}


/* Padding below the footer and lighter body text */

.bd-placeholder-img {
  font-size: 1.125rem;
  text-anchor: middle;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}


.banner_btn {
    list-style: none !important;
    padding: 0;
    margin: 0;
}

.banner_btn_item a {
  display: block;
    position: relative;
    padding: 30px 54px 30px 0;
    color: #212529;
    text-decoration: none;
    font-weight: 600;
    line-height: 1.3;
    -webkit-transition: color .1s linear;
    transition: color .1s linear;
}

.banner_btn_item a:hover {
    color: #21a937;
    -webkit-transition: color .1s linear;
    transition: color .1s linear;
}

.banner_btn_item a:before {
    display: block;
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #dddddd;
    -webkit-transition: color .1s linear;
    transition: color .1s linear;
}

.banner_btn_item a:after {
    display: block;
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    width: 54px;
    height: 3px;
    background-color: #21a937;
}

.banner_btn_arrow {
    content: '';
    position: absolute;
    top: 0;
    right: 19px;
    bottom: 0;
    overflow: hidden;
    width: 18px;
    height: 18px;
    margin: auto;
    font-size: 0;
    line-height: 1;
    color: #21a937;
}

.inner {
    width: 100%;
    margin: 0 auto;
}

.flow .flow_block {
    width: 100%;
}

.flow ul {
  list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    width: 100%;
    padding: 0;
    margin-bottom: 30px;
}

.flow ul li .smaller {
    font-size: 0.8em;
    display: inline-block;
}

.flow ul .flow01 {
    background-color: #dcf4df;
}
.flow ul .flow02 {
    background-color: #adeab8;
}
.flow ul .flow03 {
    background-color: #56cb6a;
}
.flow ul .flow04 {
    background-color: #00aae6;
}
.flow ul .flow_last {
    background-color: #21a937;
}
.flow ul .flow01::before {
    background: linear-gradient(to bottom left, transparent 50%, #dcf4df 50%) top left / 100% 50% no-repeat, linear-gradient(to top left, transparent 50%, #dcf4df 50%) bottom left / 100% 50% no-repeat;
}
.flow ul .flow02::before {
    background: linear-gradient(to bottom left, transparent 50%, #adeab8 50%) top left / 100% 50% no-repeat, linear-gradient(to top left, transparent 50%, #adeab8 50%) bottom left / 100% 50% no-repeat;
}
.flow ul .flow03::before {
    background: linear-gradient(to bottom left, transparent 50%, #56cb6a 50%) top left / 100% 50% no-repeat, linear-gradient(to top left, transparent 50%, #56cb6a 50%) bottom left / 100% 50% no-repeat;
}
.flow ul .flow04::before {
    background: linear-gradient(to bottom left, transparent 50%, #00aae6 50%) top left / 100% 50% no-repeat, linear-gradient(to top left, transparent 50%, #00aae6 50%) bottom left / 100% 50% no-repeat;
}

.flow ul li::before {
    width: 20px;
    height: 100%;
    left: 100%;
    z-index: 3;
}
.flow ul li::after {
    width: 20px;
    left: calc(100% + 3px);
    height: calc(100% + 6px);
    /*
    background: linear-gradient(to bottom left, transparent 50%, #fff 50%) top left / 100% 50% no-repeat, linear-gradient(to top left, transparent 50%, #fff 50%) bottom left / 100% 50% no-repeat;
    */
    z-index: 2;
}

.flow ul li::before, .flow ul li::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}


.flow ul li {
    width: 25%;
    padding-left: 25px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    position: relative;
    height: 160px;
    /*
    border-right: 3px solid #fff;
    */
    text-align: justify;
    text-justify: inter-ideograph;
    line-break: strict;
}

.flow .arrow {
    background-size: 20px 100%;
    text-align: center;
    overflow: hidden;
}

.flow .arrow .period {
    background-color: #dcf4df;
    height: 100%;
    display: block;
    padding: 0.5em 0px 0.5em 80px;
}

.flow .arrow .period {
    width: 100%;
    padding-right: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    position: relative;
    text-align: justify;
    text-justify: inter-ideograph;
    line-break: strict;
    left: -30px;
}

.flow .arrow .period::before {
    background: linear-gradient(to bottom left, transparent 50%, #dcf4df 50%) top left / 100% 50% no-repeat, linear-gradient(to top left, transparent 50%, #dcf4df 50%) bottom left / 100% 50% no-repeat;
}

.flow .arrow .period::before {
    width: 30px;
    height: 100%;
    left: 100%;
    z-index: 3;
}
.flow .arrow .period::after {
    width: 30px;
    left: calc(100% + 3px);
    height: calc(100% + 6px);
    /*
    background: linear-gradient(to bottom left, transparent 50%, #fff 50%) top left / 100% 50% no-repeat, linear-gradient(to top left, transparent 50%, #fff 50%) bottom left / 100% 50% no-repeat;
    */
    z-index: 2;
}

.flow .arrow .period::before, .flow .arrow .period::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
}

.flow ul li p:last-of-type {
    margin-bottom: 0;
}

.flow ul li p {
    text-align: center;
    line-height: 1.3;
    width: 100%;
    margin: 0 auto 0.8em;
    line-break: strict;
    font-size: 1rem;
}

.faq:last-of-type {
    margin-bottom: 0;
}
.faq {
    width: 100%;
    margin-bottom: 80px;
}

.q_faq {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    margin-bottom: 30px;
}

.a_faq {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
}

.q_faq, .a_faq {
    text-align: justify;
    text-justify: inter-ideograph;
    line-break: strict;
    font-size: 1rem;
    line-height: 1.5;
    word-break: break-all;
}

.q_faq .en {
    font-weight: normal;
    background-color: #dcf4df;
    color: #21a937;
}
.a_faq .en {
    background-color: #21a937;
    color: #fff;
}
.en {
    font-size: 1rem;
    width: 52px;
    height: 52px;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1;
}

.en {
    letter-spacing: 0.2em;
    padding-left: 0.2em;
}

.q_ttl {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    flex-basis: calc(100% - 52px);
    background-color: #ffffff;
    padding: 0 30px;
    line-height: 1;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    -ms-grid-row-align: stretch;
    align-self: stretch;
    font-size: 1rem;
}

.a_comm {
    flex-basis: calc(100% - 52px);
    padding: 16px 30px;
}

@media (min-width: 768px) {
  .bd-placeholder-img-lg {
    font-size: 3.5rem;
  }
}

.b-example-divider {
  width: 100%;
  height: 3rem;
  background-color: rgba(0, 0, 0, .1);
  border: solid rgba(0, 0, 0, .15);
  border-width: 1px 0;
  box-shadow: inset 0 .5em 1.5em rgba(0, 0, 0, .1), inset 0 .125em .5em rgba(0, 0, 0, .15);
}

.b-example-vr {
  flex-shrink: 0;
  width: 1.5rem;
  height: 100vh;
}

.bi {
  vertical-align: -.125em;
  fill: currentColor;
}

.nav-scroller {
  position: relative;
  z-index: 2;
  height: 2.75rem;
  overflow-y: hidden;
}

.nav-scroller .nav {
  display: flex;
  flex-wrap: nowrap;
  padding-bottom: 1rem;
  margin-top: -1px;
  overflow-x: auto;
  text-align: center;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
}

.btn-bd-primary {
  --bd-violet-bg: #712cf9;
  --bd-violet-rgb: 112.520718, 44.062154, 249.437846;

  --bs-btn-font-weight: 600;
  --bs-btn-color: var(--bs-white);
  --bs-btn-bg: var(--bd-violet-bg);
  --bs-btn-border-color: var(--bd-violet-bg);
  --bs-btn-hover-color: var(--bs-white);
  --bs-btn-hover-bg: #6528e0;
  --bs-btn-hover-border-color: #6528e0;
  --bs-btn-focus-shadow-rgb: var(--bd-violet-rgb);
  --bs-btn-active-color: var(--bs-btn-hover-color);
  --bs-btn-active-bg: #5a23c8;
  --bs-btn-active-border-color: #5a23c8;
}
.bd-mode-toggle {
  z-index: 1500;
}

/* CUSTOMIZE
-------------------------------------------------- */

/* Carousel base class */
.carousel {
  margin-bottom: 4rem;
}
/* Since positioning the image, we need to help out the caption */
.carousel-caption {
  bottom: 3rem;
  z-index: 10;
  color: #21a937;
}



/* Declare heights because of positioning of img element */
.carousel-item {
  height: 640px;
      background-repeat: no-repeat;
      background-size: cover;
      background-position: center center;
}
.carousel-item h1 {
  font-size: 72px;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}

.text_marker {
  background: linear-gradient(transparent 30%, #ffffff 30%);
}

.title_interview {
  position: relative;
  width: 100%;
  margin-bottom: 20px;
}

.title_interview p {
  font-size: 20px;
  color: #21a937;
  font-weight: 600;
}

.title_interview h2 {
  font-size: 72px;
  font-weight: 600;
  font-style: normal;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  padding-bottom: 10px;
}

.title_interview:after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 10px;
    width: 120px;
    height: 4px;
    background-color: #21a937;
}

.title_pharmacy {
  position: relative;
  width: 100%;
  margin-bottom: 2rem;
}

.title_pharmacy p {
  font-size: 20px;
  color: #21a937;
  font-weight: 500;
}

.title_pharmacy h2 {
  font-size: 48px;
  font-weight: 600;
  font-style: normal;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  padding-bottom: 20px;
}

.title_pharmacy:after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0px;
    width: 60px;
    height: 4px;
    background-color: #21a937;
}

.title_inquiry {
  position: relative;
  width: 100%;
  margin-bottom: 2rem;
}

.title_inquiry p {
  color: #fff;
  font-weight: 500;
}

.title_inquiry h3 {
  color: #fff;
  font-size: 1.75rem;
  font-weight: 600;
  font-style: normal;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  padding-bottom: 20px;
}

.title_inquiry:after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0px;
    width: 60px;
    height: 4px;
    background-color: #fff;
}


.title_entry {
  position: relative;
  width: 100%;
  margin-bottom: 1.5rem;
}

.title_entry p {
  font-size: 1.25rem;
  font-weight: 500;
  color: #21a937;
}

.title_entry h3 {
  font-size: 2.5rem;
  font-weight: 600;
  font-style: normal;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  padding-bottom: 20px;
}


.box_left_border {
    opacity: 0.3;
    width: 50%;
    height: 240px;
    background: repeating-linear-gradient(-125deg, #21a937 0, #21a937 1px, rgba(0, 170, 230, 0) 0, rgba(0, 170, 230, 0) 6px);
    z-index: -1;
    position: absolute;
    top: 200px;
    left: -20%;
}

.box_right_border {
    opacity: 0.3;
    width: 50%;
    height: 240px;
    background: repeating-linear-gradient(-125deg, #21a937 0, #21a937 1px, rgba(0, 170, 230, 0) 0, rgba(0, 170, 230, 0) 6px);
    z-index: -1;
    position: absolute;
    top: 200px;
    right: -20%;
}

.box_container {
  position: relative;
}

.box_right_gray::before {
    content: "";
    display: block;
    width: 70%;
    height: 240px;
    background-color: #f2f2f2;
    position: absolute;
    bottom: -30px;
    right: -20%;
    z-index: -1;
}

.box_left_gray::before {
    content: "";
    display: block;
    width: 70%;
    height: 240px;
    background-color: #f2f2f2;
    position: absolute;
    bottom: -30px;
    left: -20%;
    z-index: -1;
}


.bg-green {
    background-color: #21a937 !important;
}

.bg-white {
    background-color: #ffffff !important;
}

.text-green {
    color: #21a937 !important;
}

.keyvisual1 {
  background-image: url("../img/keyvisual1.jpg"); /* 画像のパスを指定 */
}
.keyvisual2 {
  background-image: url("../img/keyvisual2.jpg"); /* 画像のパスを指定 */
}
.keyvisual3 {
  background-image: url("../img/keyvisual3.jpg"); /* 画像のパスを指定 */
}

/* MARKETING CONTENT
-------------------------------------------------- */
.marketing {
  margin-bottom: 5rem;
}

/*
.marketing .col-lg-4 {
  margin-bottom: 1.5rem;
  text-align: left;
}
.marketing .col-lg-4 p {
  margin-right: .75rem;
  margin-left: .75rem;
}
*/

.marketing h3 {
  letter-spacing: 0.1rem;
  padding: 1rem 0rem;
  font-size: 26px;
  font-weight: 400;
  text-align: center;
  line-height: 1.5;
}

/* COMMON CONTENT
-------------------------------------------------- */
.common {
  margin-top: 5rem;
  margin-bottom: 5rem;
}

.inquiry {
  color: #fff;
}

.inquiry a {
  color: #fff;
  opacity: 1;
  font-size: 1.4rem;
  font-weight: 400;
  -webkit-transition: opacity .1s linear;
  transition: opacity .1s linear;
}

.inquiry a:hover {
  opacity: 0.75;
}

.entry a {
  opacity: 1;
  font-size: 1.4rem;
  font-weight: 400;
  -webkit-transition: opacity .1s linear;
  transition: opacity .1s linear;
}

.entry a:hover {
  opacity: 0.75;
}

.common h3 {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-weight: bolder;
  margin-bottom: 2rem;
}



/* rtl:end:ignore */


/* Featurettes
------------------------- */
.featurette {
  position: relative;
}

.featurette-divider {
  margin: 4rem 0; /* Space out the Bootstrap <hr> more */
  border-top: 1px solid #dee2e6;
  opacity: 1;
}


/* Thin out the marketing headings */
/* rtl:begin:remove */
.featurette-heading {
  letter-spacing: 0.06rem;
}

.featurette-heading {
  margin-top: 5rem;
  margin-bottom: 2rem;
}

/* rtl:end:remove */

/* RESPONSIVE CSS
-------------------------------------------------- */

@media (min-width: 40em) {
  /* Bump up size of carousel content */
  .carousel-caption p {
    margin-bottom: 1.25rem;
    font-size: 1.25rem;
    line-height: 1.4;
  }
  .carousel-item h1 {
    line-height: 1.4;
  }
}

@media (max-width: 768px) {
  body {
    font-family: '游ゴシック体', YuGothic, '游ゴシック', 'Yu Gothic', Meiryo, sans-serif;
    font-weight: 400;
  }
  .table {
    font-size: 0.9rem;
  }
  .table>:not(caption)>*>* {
    padding: 0.9rem 0.5rem;
  }
  .carousel-item {
    height: 420px;
  }
  .carousel-item h1 {
    font-size: 36px;
    line-height: 1.4;
  }
  .carousel-caption {
    padding-bottom: 10px;
  }
  .title_interview h2 {
    font-size: 48px;
    font-weight: 600;
  }

  .featurette-heading {
    margin-top: 4rem;
  }
  .marketing h3 {
    font-size: 22px;
  }

  .title_pharmacy p {
    font-size: 18px;
  }

  .title_pharmacy h2 {
    font-size: 36px;
  }

  .common h3, .title_inquiry h3 {
    font-size: 1.6rem;
  }

  .title_entry p {
    font-size: 1rem;
  }

  .title_entry h3 {
    font-size: 2rem;
  }

  .flow ul li p {
      font-size: 0.8rem;
  }

  .inquiry a {
    font-size: 1rem;
  }

}

