@charset "UTF-8";
:root {
  --primarycolor: #008CAF;
  --primary-variant1: #E6F5F9;
  --primary-variant2: #fafafa;
  --secondarycolor: #464646;
  --tertiarycolor: #FF5C00;
  --hovercolor: #ED6D24;
  --quaternarycolor: #464646;
  --black: #222;
  --warning: #E60000;
  --notice:#FFFCD6;
}

html {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  margin: 0;
  padding: 14px 0 0;
  background-color: #FFF;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  color: #231815;
}

h1,
h2,
h3,
h4,
h5,
p,
ul,
li,
dl,
dd {
  margin: 0;
  padding: 0;
}

input[type=submit]:hover {
  cursor: pointer;
}

a:hover {
  opacity: 0.8;
}

/*todo:for test*/
.demo_link {
  text-align: center;
  margin: -17px auto 18px auto;
}

a img {
  border-width: 0;
}

img {
  max-width: 100%;
}

html {
  font-size: 62.5%;
  scroll-padding-top: 19rem;
  /* 固定ヘッダの高さ分 */
}

@media screen and (max-width: 1440px) {
  html {
    font-size: 0.6944444444vw;
  }
}
@media screen and (max-width: 768px) {
  html {
    font-size: 2.6666666667vw;
  }
}
body {
  font-family: sans-serif;
  font-size: 1.6rem;
  margin: 0;
  padding: 0;
  padding-top: 12rem;
  /* header + nav 分 */
  scroll-behavior: smooth;
  line-height: 1.8;
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  color: #464646;
  font-family: var(--unnamed-font-family-hiragino-sans);
}

ul {
  list-style: none;
}

a {
  color: #008CAF;
}

.container {
  max-width: 109.6rem;
  margin: auto;
  padding: 0 2.4rem;
}
.container.w880 {
  max-width: 88rem;
}

img {
  width: 100%;
  height: auto;
}

.sr-only {
  border: 0;
  clip: rect(0, 0, 0, 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.pc {
  display: block;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
}
.sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .sp {
    display: block;
  }
}
.cta {
  background-color: var(--primary-variant1);
}
.cta_inner {
  text-align: center;
  padding: 2.4rem;
}
@media screen and (max-width: 768px) {
  .cta_inner {
    display: flex;
    flex-direction: column;
    gap: 2.4rem;
    padding: 5.6rem 2.4rem;
  }
}
.cta .btn {
  margin: 0 2.4rem;
}
@media screen and (max-width: 768px) {
  .cta .btn {
    margin: auto;
    width: 100%;
  }
}

.btn {
  display: inline-block;
  padding: 1.6rem 3.2rem;
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.1607843137);
  border-radius: 99px;
  font: normal normal normal 16px/22px Hiragino Sans;
  letter-spacing: 0px;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  min-width: 24rem;
  text-align: center;
}
.btn:hover {
  opacity: 1;
}
.btn--primary {
  border: 2px solid var(--tertiarycolor);
  background-color: #FF5C00;
  color: #fff;
}
.btn--primary:hover {
  background-color: var(--hovercolor);
  border: var(--hovercolor) solid 2px;
}
.btn--secondary {
  border: 2px solid var(--primarycolor);
  color: var(--primarycolor);
  background-color: #fff;
}
.btn--secondary::after {
  content: url(../img/icon16_arrowR_bk.svg);
  vertical-align: middle;
  padding-left: 8px;
  width: 1rem;
}
.btn--secondary:hover {
  background-color: var(--primary-variant1);
}
.btn--anchor {
  border: 2px solid var(--primarycolor);
  color: var(--primarycolor);
  background: #fff;
  padding-right: 5.6rem;
  position: relative;
  min-width: unset;
  width: calc((100% - 8rem) / 3);
  box-sizing: border-box;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .btn--anchor {
    width: auto;
  }
}
.btn--anchor::after {
  content: url(../img/icon16_arrowR_bk.svg);
  vertical-align: middle;
  right: 2.2rem;
  position: absolute;
  transform: rotate(90deg);
}
.btn.small {
  min-width: unset;
  padding: 1.2rem 4rem;
}
.btn.large {
  font-size: 2.2rem;
  padding: 2.4rem 3.2rem;
}
.btn.large::after {
  position: relative;
  top: -0.2rem;
}

.list_item {
  margin-top: 2.4rem;
  position: relative;
  padding-left: 1.8rem;
  font-weight: 600;
}
.list_item::before {
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
  background-color: var(--primarycolor);
  position: absolute;
  top: 1rem;
  left: 0;
}
.list_item ul li {
  padding-left: 1.8rem;
  position: relative;
}
.list_item ul li::before {
  content: "";
  width: 0.6rem;
  height: 0.6rem;
  border: solid 2px var(--secondarycolor);
  position: absolute;
  top: 1rem;
  left: 0;
}

.pane {
  margin-top: 10rem;
  margin-bottom: 10rem;
}
@media screen and (max-width: 768px) {
  .pane {
    margin-top: 4rem;
    margin-bottom: 4rem;
  }
}

.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 2rem 3.2rem;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  z-index: 1000;
  display: flex;
  align-items: center;
  padding: 1em;
  box-shadow: 0 0.2rem 0.4rem rgba(0, 0, 0, 0.1);
  height: 12rem;
}

.headerLeft {
  display: flex;
  align-items: center;
  gap: 1em;
}

.headerTitle {
  padding: 20px 0 0 32px;
  letter-spacing: 0px;
  color: #464646;
}

.headerTitle p:first-child {
  line-height: 1.6rem;
}

.headerTitle p:nth-child(2) {
  font-size: 2rem;
  font-weight: 600;
}

.headerRight {
  display: flex;
  gap: 3.2rem;
  align-items: center;
}
.headerRight .btn {
  font-size: 1.6rem;
  padding: 1.6rem 3.2rem;
}

.logoPC {
  display: inline;
  width: 31.5rem;
}

.logoSP {
  display: none;
}

/* ナビゲーション固定 */
.navigation {
  position: fixed;
  top: 11rem;
  left: 0;
  width: 100%;
  background-color: #fff;
  z-index: 999;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.navigation ul {
  display: flex;
  list-style: none;
  justify-content: center;
  letter-spacing: 0.8px;
  margin: 0;
  padding: 0;
}
.navigation li {
  width: 22rem;
  text-align: center;
  font-weight: 600;
  background: var(--secondarycolor) 0% 0% no-repeat padding-box;
}
.navigation li a {
  padding: 2.4rem 0;
  display: block;
}
.navigation li a:hover {
  opacity: 1;
}
.navigation li:hover {
  background: var(--primary-variant1) 0% 0% no-repeat padding-box;
  cursor: pointer;
  color: var(--secondarycolor);
}
.navigation li:has(a) {
  background: #fff 0% 0% no-repeat padding-box;
  color: var(--secondarycolor);
}
.navigation li:has(a) a {
  text-decoration: none;
  color: var(--secondarycolor);
}
@media screen and (max-width: 768px) {
  .navigation li:has(a) a {
    padding: 0;
  }
}
.navigation li:has(a.active) {
  background: var(--secondarycolor) 0% 0% no-repeat padding-box;
  color: #fff;
}
.navigation li:has(a.active) a {
  text-decoration: none;
  color: #fff;
}
.navigation li.current {
  background: var(--secondarycolor) 0% 0% no-repeat padding-box;
}
.navigation li.current a {
  color: #fff;
}

.content {
  margin-top: 6rem;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .content {
    margin-top: 0;
    width: 100%;
  }
}

.section-ttl {
  font-size: 2.8rem;
  text-align: center;
  margin-bottom: 4rem;
}
.section-ttl--faq {
  color: var(--primarycolor);
  text-align: left;
  max-width: 109.6rem;
  margin: auto;
  padding-left: 8.8rem;
  position: relative;
  margin-top: 4rem;
  margin-bottom: 2.4rem;
  font-size: 2.4rem;
}
.section-ttl--faq::before {
  content: "";
  background-image: url(../img/qa-icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  width: 8rem;
  height: 5.5rem;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

.page-ttl-area {
  background-color: var(--primary-variant1);
  height: 15rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.page-ttl-area .page-ttl {
  font-size: 2.8rem;
}
@media screen and (max-width: 768px) {
  .page-ttl-area .page-ttl {
    font-size: 2.4rem;
    line-height: 1.5;
  }
}

.notice-area {
  background-color: var(--notice);
  padding: 3.2rem 2.4rem;
  border: solid 2px var(--secondarycolor);
  margin-top: 6.4rem;
}
.notice-area .list_item::before {
  background-color: var(--warning);
}
.notice-area--oneline {
  background-color: var(--secondarycolor);
  padding: 0.8rem;
  margin: 0;
}
.notice-area--oneline .notice-area_inner {
  background-color: #FFFCD6;
  border-radius: 99px;
  padding: 0;
}
.notice-area--oneline .notice-area_inner a {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 1.2rem 2.4rem;
  text-decoration: none;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .notice-area--oneline .notice-area_inner a {
    justify-content: center;
  }
}
.notice-area--oneline .notice-area_para {
  color: var(--warning);
  font-weight: 600;
  line-height: 1;
  margin: 0;
}
.notice-area--oneline .notice-area_para::before {
  content: url(../img/icon-warning.svg);
  padding-right: 0.8rem;
  vertical-align: middle;
}
.notice-area_ttl {
  font-size: 2.2rem;
}
.notice-area_ttl::before {
  content: url(../img/icon-warning.svg);
  padding-right: 0.8rem;
  vertical-align: middle;
}
.notice-area_para {
  font-weight: 600;
  margin: 1.6rem 0;
}
.notice-area_label {
  font-weight: 600;
}
.notice-area_label::after {
  content: url(../img/icon16_arrowR_black.svg);
  vertical-align: middle;
  padding-left: 8px;
}

.about-area {
  width: 100%;
}
.about-area_info {
  flex: 1;
}
.about-area_mockup {
  width: 50.6rem;
}
@media screen and (max-width: 768px) {
  .about-area_mockup {
    width: auto;
    text-align: right;
  }
}
.about-area_mockup img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .about-area_mockup img {
    width: 70%;
  }
}
.about-area_copy {
  letter-spacing: 0.4rem;
  color: var(--secondarycolor);
  margin-bottom: 1.6rem;
  font-size: 3.2rem;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  .about-area_copy {
    line-height: 1.5;
  }
}
.about-area_copy span {
  font-size: 4.8rem;
  background-color: #fff;
  padding: 0.8rem;
}
@media screen and (max-width: 768px) {
  .about-area_copy span {
    font-size: 4rem;
  }
}
.about-area_subcopy {
  color: var(--primarycolor);
  font-size: 2rem;
  display: block;
}

.aboutMain {
  padding: 6.6rem 8rem;
  background: url(../img/mv.png);
  background-repeat: no-repeat;
  background-position: 30%;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  .aboutMain {
    padding: 4rem 1.6rem;
    background: url(../img/mv-sp.jpg);
    background-size: contain;
  }
}

.aboutContent {
  position: relative;
  max-width: 109.6rem;
  margin: 0 auto;
  display: flex;
  gap: 8rem;
}
@media screen and (max-width: 768px) {
  .aboutContent {
    flex-direction: column;
    gap: 4rem;
  }
}

.mvApp_pcImg {
  position: absolute;
  top: 8.8rem;
  right: 10.4rem;
  object-fit: cover;
  overflow: hidden;
}

.mvApp_spImg {
  display: none;
}

.aboutText {
  margin-bottom: 6.5rem;
  letter-spacing: 0.1rem;
  color: #464646;
  font-size: 2rem;
  font-weight: 600;
  display: block;
  margin-top: 2.4rem;
  line-height: 1.6;
}

.aboutText > p:first-child {
  margin-bottom: 20px;
}

.aboutInfo {
  background: #fff;
  padding: 24px;
  box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.1607843137);
  border-radius: 4px;
  width: 551px;
  font-size: 16px;
}

.aboutInfoTitle {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
  font: normal bold normal 16px Hiragino Sans;
}

.aboutInfoTitle::before {
  content: url(../img/icon24_attention.svg);
  height: 24px;
  padding-right: 4px;
}

.aboutInfoText {
  font: normal normal normal 14px/20px Hiragino Sans;
  letter-spacing: 0px;
  color: #464646;
  margin-bottom: 24px;
}

.aboutInfo > dt.aboutInfoDate {
  font: normal normal normal 14px/20px Hiragino Sans;
  letter-spacing: 0px;
  color: #464646;
}

.aboutInfo > dd.aboutInfoDate {
  position: relative;
  font: normal normal bold 16px/22px SF Pro Text;
  letter-spacing: 0px;
  color: var(--black);
}

.aboutInfo > dd.aboutInfoDateText {
  font: normal normal normal 12px/20px Hiragino Sans;
  letter-spacing: 0px;
  color: #464646;
}

.aboutSubContent,
.preparationContent,
.signinContent,
.qaContent {
  max-width: 1096px;
  margin: 0 auto;
}

.about-sub {
  background-image: url(../img/features-bg.png);
  background-repeat: no-repeat;
  background-position: top 0rem center;
  background-size: 96rem;
}
@media screen and (max-width: 768px) {
  .about-sub {
    background-image: url(../img/features-bg-sp.png);
    background-position: top 17rem center;
    background-size: contain;
  }
}
.about-sub_desc {
  max-width: 60rem;
  margin: auto;
  text-align: center;
  font-size: 2rem;
  letter-spacing: 0.4rem;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .about-sub_desc {
    text-align: left;
    letter-spacing: 0.2rem;
    padding: 0 4rem;
  }
}
.about-sub_box {
  background-color: var(--primary-variant1);
  margin-top: 14rem;
  display: flex;
  justify-content: center;
  padding-top: 6.4rem;
  padding-bottom: 16rem;
  gap: 16rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  .about-sub_box {
    flex-direction: column;
    padding: 8rem 1.6rem 16rem;
    gap: 24rem;
    margin-top: 4rem;
  }
}
.about-sub_box::before {
  content: "";
  background-image: url(../img/arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 12.4rem;
  height: 5.4rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .about-sub_box::before {
    transform: translate(-50%, -50%) rotate(90deg);
    left: calc(50% - 2rem);
    width: 8rem;
    height: 3rem;
    top: calc(50% + 1rem);
  }
}
.about-sub_item {
  border-radius: 50%;
  background-color: #fff;
  width: 37rem;
  height: 37rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  .about-sub_item {
    width: auto;
    height: 31.1rem;
  }
}
.about-sub_item.patient .about-sub-ttl {
  top: 8rem;
  right: 13rem;
}
@media screen and (max-width: 768px) {
  .about-sub_item.patient .about-sub-ttl {
    font-size: 2.2rem;
    right: 9rem;
    top: 7.5rem;
  }
}
.about-sub_item.patient .about-sub-list:before {
  content: "";
  background-image: url(../img/plus.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  width: 4rem;
  height: 4rem;
  top: -5rem;
  left: 4rem;
}
@media screen and (max-width: 768px) {
  .about-sub_item.patient .about-sub-list:before {
    top: -5rem;
    left: 3rem;
  }
}
.about-sub_item.doctor .about-sub-ttl {
  top: 8rem;
  left: 6rem;
}
@media screen and (max-width: 768px) {
  .about-sub_item.doctor .about-sub-ttl {
    font-size: 2rem;
    top: 7rem;
    right: -10.8rem;
  }
}
.about-sub_item.doctor .sub-item-inner {
  text-align: center;
}

.sub-item-inner {
  overflow: hidden;
  height: 100%;
  width: 100%;
  border-radius: 50%;
  text-align: right;
  margin-bottom: 4rem;
}

.patient-tmb {
  position: absolute;
  top: -2rem;
  left: 5rem;
  width: 12rem;
}

.doctor-tmb {
  position: absolute;
  top: -2rem;
  right: 5.8rem;
  width: 21rem;
}

.mockup-sp1-tmb {
  width: 16rem;
  margin-top: 14rem;
  margin-right: 18rem;
}
@media screen and (max-width: 768px) {
  .mockup-sp1-tmb {
    margin-top: 12rem;
    margin-right: 11.5rem;
  }
}

.mockup-pc1 {
  width: 25.4rem;
  margin-top: 15rem;
}
@media screen and (max-width: 768px) {
  .mockup-pc1 {
    width: 18rem;
  }
}

.about-sub-list {
  position: absolute;
  top: 18rem;
  right: 4rem;
  font-size: 2.4rem;
  line-height: 1.3;
  font-weight: 600;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .about-sub-list {
    font-size: 1.8rem;
    left: 18.6rem;
    top: 16rem;
    width: 10rem;
  }
}

.about-sub-ttl {
  position: absolute;
  font-size: 2.8rem;
  line-height: 1;
  font-weight: 600;
}

.aboutNote {
  width: 100%;
  padding: 32px 24px;
  background: #FFFCD6;
  border: 1px solid #464646;
}

.aboutNote p {
  font: normal bold normal 22px Hiragino Sans;
  letter-spacing: 1.1px;
  margin-bottom: 27px;
  line-height: 22px;
}

.aboutNote p::before {
  content: url(../img/icon24_attention.svg);
  padding-right: 8px;
  vertical-align: middle;
}

.aboutNote ul {
  list-style-image: url(../img/icon16_listDot_M_red.svg);
  font: normal normal normal 16px Hiragino Sans;
  letter-spacing: 0px;
  margin-left: 16px;
}

.aboutNote li:first-child span {
  color: #E60000;
}

.aboutNote li:nth-child(2) span {
  color: #008CAF;
}

.point-list_item {
  padding-top: 6.4rem;
  padding-bottom: 6.4rem;
}
@media screen and (max-width: 768px) {
  .point-list_item {
    padding-top: 2.4rem;
    padding-bottom: 2.4rem;
  }
}
.point-list_item .container {
  display: flex;
  justify-content: space-between;
  gap: 6.4rem;
}
@media screen and (max-width: 768px) {
  .point-list_item .container {
    flex-direction: column-reverse;
    gap: 2.4rem;
  }
}
.point-list_item:nth-child(odd) {
  background-color: #FAFAFA;
}
.point-list_item:first-child .point-list_info {
  background-image: url(../img/no1.svg);
  background-position: left 5.6rem top 0;
  background-size: 5.4rem 17.3rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:first-child .point-list_info {
    background-size: 2.4rem 8rem;
    background-position: left 3rem top 0;
  }
}
.point-list_item:first-child .point-list_graphic {
  width: 38rem;
  margin-right: 4rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:first-child .point-list_graphic {
    width: auto;
    margin-right: auto;
  }
}
.point-list_item:nth-child(2) .container {
  background-image: url(../img/list-no2-img.svg);
  background-repeat: no-repeat;
  background-position: bottom 0 right 14.4rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(2) .container {
    background-position: top 8rem right 34px;
    background-size: 90%;
  }
}
.point-list_item:nth-child(2) .point-list_info {
  background-image: url(../img/no2.svg);
  background-position: left 5.6rem top 0;
  background-size: 10.6rem 17.6rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(2) .point-list_info {
    background-size: 6rem 10rem;
    background-position: left 3rem top 0;
  }
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(2) .point-list_graphic {
    margin-left: auto;
    margin-right: 0;
    width: 50%;
  }
}
.point-list_item:nth-child(3) .container {
  gap: 10rem;
}
.point-list_item:nth-child(3) .point-list_info {
  background-image: url(../img/no3.svg);
  background-position: left 5.6rem top 0;
  background-size: 10.6rem 17.6rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(3) .point-list_info {
    background-size: 6rem 10rem;
    background-position: left 3rem top 0;
  }
}
.point-list_item:nth-child(3) .point-list_graphic {
  width: 42.8rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(3) .point-list_graphic {
    width: 80%;
  }
}
.point-list_item:nth-child(4) .container {
  background-image: url(../img/list-no4-img.svg);
  background-repeat: no-repeat;
  background-position: right bottom -10px;
  background-size: 58%;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(4) .container {
    background-position: top 1rem center;
    background-size: 100%;
  }
}
.point-list_item:nth-child(4) .point-list_info {
  background-image: url(../img/no4.svg);
  background-position: left 5.6rem top 0;
  background-size: 10.6rem 17.6rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(4) .point-list_info {
    background-size: 6rem 9rem;
    background-position: left 3rem top 3.6rem;
  }
}
.point-list_item:nth-child(4) .point-list_graphic {
  width: 42.8rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(4) .point-list_graphic {
    width: 80%;
  }
}
.point-list_item:nth-child(5) .point-list_info {
  background-image: url(../img/no5.svg);
  background-position: left 5.6rem top 0;
  background-size: 10.6rem 17.6rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(5) .point-list_info {
    background-size: 6rem 9rem;
    background-position: left 3rem top 0;
  }
}
.point-list_item:nth-child(5) .point-list_graphic {
  width: 42.8rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(5) .point-list_graphic {
    width: 80%;
  }
}
.point-list_item:nth-child(6) {
  padding-bottom: 0;
}
.point-list_item:nth-child(6) .point-list_info {
  background-image: url(../img/no6.svg);
  background-position: left 5.6rem top 0;
  background-size: 10.6rem 17.6rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(6) .point-list_info {
    background-size: 6rem 9rem;
  }
}
.point-list_item:nth-child(6) .point-list_graphic {
  width: 42.8rem;
}
@media screen and (max-width: 768px) {
  .point-list_item:nth-child(6) .point-list_graphic {
    width: 90%;
  }
}
.point-list_info {
  background-repeat: no-repeat;
  flex: 1;
}
.point-list_graphic {
  margin-right: 8rem;
  width: 16.4rem;
}
@media screen and (max-width: 768px) {
  .point-list_graphic {
    margin: auto;
    width: 60%;
  }
}
.point-list_ttl {
  position: relative;
  padding-left: 3.2rem;
  margin-bottom: 3.2rem;
}
.point-list_ttl::before {
  content: "";
  background-image: url(../img/pin.svg);
  background-size: contain;
  width: 2.6rem;
  height: 2.6rem;
  position: absolute;
  left: 0;
  font-size: 2.1rem;
  top: 0.4rem;
}
.point-list_btn-area {
  margin-top: 4rem;
}

.dl-btn-list {
  display: flex;
  gap: 2.4rem;
}
.dl-btn-list_item img {
  height: 5.6rem;
  width: auto;
}
.dl-btn-list a {
  display: block;
}

.data-list_ttl {
  font-weight: 600;
  margin-top: 2.4rem;
}
.data-list_data {
  margin-top: 0.8rem;
}

@media screen and (max-width: 768px) {
  .worried .section-ttl {
    margin-bottom: 0;
  }
}
.worried_inner {
  background-image: url(../img/moyamoya.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  padding: 8rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  .worried_inner {
    margin-bottom: 16rem;
    background-image: url(../img/moyamoya-sp.svg);
    background-size: 95%;
    background-position: center top 1rem;
    padding: 6rem 2.4rem 9rem;
  }
}
.worried_inner::before {
  content: "";
  background-image: url(../img/doctor-02.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 17.2rem;
  height: 20.2rem;
  position: absolute;
  bottom: 0rem;
  left: 23rem;
}
@media screen and (max-width: 768px) {
  .worried_inner::before {
    width: 12rem;
    height: 16rem;
    bottom: -8rem;
    left: 13rem;
  }
}

.worried-list {
  margin: auto;
  width: 44rem;
}
.worried-list_item {
  font-size: 2rem;
  position: relative;
  padding-left: 2.4rem;
  margin-top: 1.6rem;
  left: 4.8rem;
  font-weight: 600;
  letter-spacing: 0.2rem;
}
@media screen and (max-width: 768px) {
  .worried-list_item {
    left: unset;
  }
}
.worried-list_item::before {
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
  background-color: var(--primarycolor);
  position: absolute;
  top: 1.3rem;
  left: 0;
}
.worried-list--sizedown {
  width: 48rem;
}
@media screen and (max-width: 768px) {
  .worried-list--sizedown {
    width: auto;
  }
}
.worried-list--sizedown .worried-list_item {
  font-size: 1.8rem;
}

.functions_tr {
  display: flex;
  border: solid #fff 0.8rem;
  flex-wrap: wrap;
}
.functions_tr.patient {
  border-bottom: none;
}
.functions_tr.patient .functions_th {
  background-color: #FEF4EE;
}
.functions_tr.patient .functions_tmb {
  padding: 4rem 8rem 0;
}
.functions_tr.patient .functions-list_item:before {
  background-color: var(--tertiarycolor);
}
.functions_th {
  width: 25.6rem;
  background-color: var(--primary-variant1);
  border-right: solid #fff 0.6rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .functions_th {
    width: 100%;
  }
}
.functions_td {
  flex: 1;
  background-color: var(--primary-variant2);
  padding: 2.4rem;
}
.functions_tmb {
  padding: 4rem 4rem 0;
}

.functions-list {
  max-width: 37rem;
  margin: auto;
}
.functions-list_item {
  padding-left: 2.4rem;
  position: relative;
  font-size: 1.8rem;
  margin: 1rem 0;
}
.functions-list_item::before {
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
  background-color: var(--primarycolor);
  position: absolute;
  top: 1rem;
  left: 0;
}

.fn-child-list_item {
  margin: 1rem 0;
  position: relative;
  padding-left: 2.4rem;
}
.fn-child-list_item::before {
  content: "";
  width: 0.6rem;
  height: 0.6rem;
  border: solid 2px var(--secondarycolor);
  position: absolute;
  top: 1.2rem;
  left: 0;
}

.daybar_b_spImg {
  display: none;
}

.daybar_a_spImg {
  display: none;
}

.signin {
  text-align: center;
  border-bottom: 12px solid var(--secondarycolor);
}

.signin h1 {
  background: var(--primary-variant1);
  height: 92px;
  line-height: 92px;
  margin-bottom: 80px;
}

.signinNote {
  margin-bottom: 64px;
  font: normal bold normal 28px Hiragino Sans;
  letter-spacing: 1.4px;
}

.signinNote span,
.signinNote ruby {
  color: #008CAF;
}

.signinText--pc {
  display: block;
}

.signinText--sp {
  display: none;
  font: normal normal normal 16px Hiragino Sans;
  letter-spacing: 0px;
}

.signinSupplement {
  font: normal normal normal 14px Hiragino Sans;
  letter-spacing: 0px;
  color: #008CAF;
}

.signinConfirmation {
  margin: 64px 0;
  background: #FAFAFA;
  padding: 32px 40px;
  text-align: left;
}

.signinConfirmation > p {
  position: relative;
  left: -1rem;
  font: normal normal normal 22px Hiragino Sans;
  letter-spacing: 1.1px;
  margin-bottom: 32px;
}

.signinConfirmation > p::before {
  content: url(../img/icon26_pin.svg);
  padding-right: 4px;
  vertical-align: -5px;
}

.signinConfirmationInfo {
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none;
  counter-reset: item;
  margin-bottom: 32px;
}

.signinConfirmationInfo.start-4 {
  counter-reset: item 3;
  width: 620px;
}

.signinConfirmationInfoWrap {
  display: flex;
  justify-content: space-between;
  margin-top: 33px;
  padding-top: 33px;
  border-top: #999 solid 1px;
}

.signinConfirmation li {
  position: relative;
  width: 240px;
  counter-increment: item;
  text-align: center;
  min-height: 504px;
}

.signinConfirmation li::before {
  font: normal normal bold 12px Roboto;
  content: counter(item, decimal-leading-zero);
  position: absolute;
  top: 2px;
  left: 0;
  background: #464646;
  border-radius: 2px;
  color: #fff;
  width: 24px;
  height: 19px;
  line-height: 19px;
  text-align: center;
}

.signinConfirmationInfo li > p {
  padding: 0 0 12px 2em;
  font-size: 16px;
  line-height: 1.5;
  min-height: 108px;
  text-align: left;
}

.signinConfirmationInfo.start-4 li > p {
  min-height: 132px;
  /* 24px × 3 = 72px + 12px */
}

.signinConfirmationInfo li > a {
  font: normal normal normal 12px Hiragino Sans;
  letter-spacing: 0px;
  color: #008CAF;
}

.passwordResetNote {
  background-color: #FFFCD6;
  border: 1px solid #464646;
  padding: 20px 16px 32px;
  max-width: 326px;
  max-height: 464px;
}

.passwordResetNote p:first-child {
  font: normal normal normal 16px Hiragino Sans;
  margin-bottom: 28px;
  line-height: 16px;
}

.passwordResetNote p:first-child::before {
  content: url(../img/icon24_attention.svg);
  vertical-align: -6px;
  padding-right: 4px;
}

.passwordResetNote p:nth-child(2) {
  margin-bottom: 24px;
}

.img_passFollow_pc {
  display: block;
  margin: 0 auto;
}

.img_passFollow_sp {
  display: none;
}

.faq-head {
  margin: auto;
  max-width: 86rem;
  padding: 1.6rem;
}

.index-btn-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 4rem;
}
@media screen and (max-width: 768px) {
  .index-btn-inner {
    flex-direction: column;
  }
}

.faq-bottom {
  margin-top: 8rem;
  margin-bottom: 10rem;
  padding: 1.6rem;
}

.faq-list {
  max-width: 109.6rem;
  margin: auto;
}
.faq-list p {
  margin-top: 1.6rem;
}
.faq-list_item {
  list-style: none;
}
.faq-list_item:first-child .faq-list_q::before {
  content: "01）";
}
.faq-list_item:nth-child(2) .faq-list_q::before {
  content: "02）";
}
.faq-list_item:nth-child(3) .faq-list_q::before {
  content: "03）";
}
.faq-list_item:nth-child(4) .faq-list_q::before {
  content: "04）";
}
.faq-list_item:nth-child(5) .faq-list_q::before {
  content: "05）";
}
.faq-list_item:nth-child(6) .faq-list_q::before {
  content: "06）";
}
.faq-list_item:nth-child(7) .faq-list_q::before {
  content: "08）";
}
.faq-list_item:nth-child(8) .faq-list_q::before {
  content: "08）";
}
.faq-list_item:nth-child(9) .faq-list_q::before {
  content: "09）";
}
.faq-list_item:nth-child(10) .faq-list_q::before {
  content: "10）";
}
.faq-list_item:nth-child(11) .faq-list_q::before {
  content: "11）";
}
.faq-list_item:nth-child(12) .faq-list_q::before {
  content: "12）";
}
.faq-list_item:nth-child(13) .faq-list_q::before {
  content: "13）";
}
.faq-list_item:nth-child(14) .faq-list_q::before {
  content: "02）";
}
.faq-list_item:nth-child(14) .faq-list_q::before {
  content: "14）";
}
.faq-list_item:nth-child(15) .faq-list_q::before {
  content: "15）";
}
.faq-list_item:nth-child(16) .faq-list_q::before {
  content: "17）";
}
.faq-list_item:nth-child(18) .faq-list_q::before {
  content: "18）";
}
.faq-list_item:nth-child(19) .faq-list_q::before {
  content: "19）";
}
.faq-list_item:nth-child(20) .faq-list_q::before {
  content: "20）";
}
.faq-list_q {
  background-color: var(--primary-variant1);
  padding: 2rem 4rem;
}
@media screen and (max-width: 768px) {
  .faq-list_q {
    padding: 1.6rem;
  }
}
.faq-list_a {
  padding: 2rem 4rem;
}
@media screen and (max-width: 768px) {
  .faq-list_a {
    padding: 1.6rem;
  }
}

.customerSupport {
  width: 640px;
  margin: 80px auto 0;
  background: #fff;
  border: 4px solid #008CAF;
  border-radius: 16px;
  margin: 0 auto;
  text-align: left;
  padding: 32px;
}

.customerSupportTitle {
  font: normal normal normal 20px Hiragino Sans;
}

.customerSupportTitle,
.customerSupportMail,
.customerSupportForm {
  display: flex;
  align-items: center;
}

.customerSupportTitle,
.customerSupportMail {
  margin-bottom: 24px;
}

.customerSupportMail {
  margin-top: 24px;
}

.customerSupportMail,
.customerSupportForm {
  font: normal normal normal 16px Hiragino Sans;
  letter-spacing: 0px;
  color: #8C8C8C;
}

.customerSupportTitle::before {
  content: url(../img/icon32_operator.svg);
  width: 32px;
  height: 32px;
  padding-right: 8px;
}

.customerSupportMail::before {
  content: url(../img/icon32_mail.svg);
  width: 32px;
  height: 32px;
  padding-right: 8px;
}

.customerSupportForm::before {
  content: url(../img/icon32_webform.svg);
  width: 32px;
  height: 32px;
  padding-right: 8px;
}

.footer {
  background: var(--secondarycolor);
  padding: 1px 0;
}
.footer_top-navi {
  border-bottom: solid 2px #fff;
}
.footer_top-navi .footer-navi-list {
  display: flex;
  justify-content: center;
  gap: 4rem;
  margin: 2.4rem 0;
}
@media screen and (max-width: 768px) {
  .footer_top-navi .footer-navi-list {
    flex-direction: column;
    gap: 0;
  }
}
.footer_top-navi .footer-navi-list_item a {
  text-decoration: underline;
}
.footer_bottom-navi {
  display: flex;
  gap: 8.8rem;
  justify-content: center;
  margin: 4rem 0;
}
@media screen and (max-width: 768px) {
  .footer_bottom-navi {
    flex-direction: column;
    gap: 1.6rem;
  }
}
.footer_left-side {
  display: flex;
  gap: 5.6rem;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
  .footer_left-side {
    gap: 2.4rem;
  }
}
.footer .copy {
  color: #fff;
  display: block;
  text-align: center;
  margin-bottom: 3.2rem;
}

.footer-navi-list.top {
  position: relative;
}
.footer-navi-list.top::before {
  content: "/";
  color: #fff;
  left: calc(50% + 3rem);
  top: 1rem;
  position: absolute;
}
@media screen and (max-width: 768px) {
  .footer-navi-list.top::before {
    display: none;
  }
}
.footer-navi-list_item {
  margin: 0.8rem 0;
  color: #fff;
  font-weight: 600;
}
.footer-navi-list_item a {
  color: #fff;
  text-decoration: none;
  font-weight: 500;
}

/* ハンバーガーメニューのスタイル */
.menu-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 1.5em;
  padding: 1em;
  cursor: pointer;
}

.menu-toggle:focus {
  outline: none;
}

/* モバイル対応（タブレット含む） */
@media screen and (max-width: 768px) {
  html {
    scroll-padding-top: 68px;
    /* 固定ヘッダの高さ分 */
  }
  body {
    font-family: sans-serif;
    margin: 0;
    padding: 0;
    padding-top: 8.4rem;
    scroll-behavior: smooth;
  }
  .logoPC {
    display: none;
  }
  .logoSP {
    display: inline;
    width: 9.7rem;
  }
  .menu-toggle {
    display: inline;
    padding: 0;
    position: fixed;
    top: 1rem;
    right: 1rem;
    background: #fff;
    box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.1607843137);
    border: 1px solid #ED6D23;
    border-radius: 0.6rem;
    width: 3.6rem;
    height: 3.6rem;
    line-height: 0;
  }
  .menu-icon {
    position: absolute;
    top: 0;
    left: 0;
    transition: opacity 0.5s ease, transform 0.5s ease;
    transform: scale(0.47);
  }
  .menu-icon--close {
    opacity: 0;
    transform: scale(0.47);
  }
  .menu-toggle.menu-toggle--close .menu-icon--open {
    opacity: 0;
    transform: scale(0.47);
  }
  .menu-toggle.menu-toggle--close .menu-icon--close {
    opacity: 1;
  }
  .navigation {
    display: inline;
    top: 68px;
    left: 0px;
    width: 100%;
    padding: 0px;
  }
  .navigation ul {
    display: none;
    flex-direction: column;
    padding: 0;
    margin: 0;
    width: 100%;
  }
  .navigation ul.show {
    display: flex;
  }
  .navigation li {
    border-top: 1px solid #ccc;
    padding: 1em;
    text-align: center;
    width: 100%;
  }
  .navigation li:last-child {
    display: block;
  }
  .header {
    flex-direction: column;
    align-items: flex-start;
    height: auto;
  }
  .headerLeft {
    align-items: flex-start;
  }
  .headerRight {
    display: none;
  }
  .headerTitle {
    padding: 0px 0 0 0px;
    display: inline;
  }
  .headerTitle p:first-child {
    font-size: 1.1rem;
  }
  .headerTitle p:nth-child(2) {
    font-size: 1.1rem;
  }
}/*# sourceMappingURL=index.css.map */