/*========================================
mixin
==========================================*/
/*========================================
header
==========================================*/
.header-inner {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 150px;
  padding: 0 60px;
  background-color: #fff;
  z-index: 1000;
}
.header-logo a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.header-logo a:hover {
  opacity: 0.8;
}
.header-content {
  max-width: 862px;
  width: 100%;
}
.header-info {
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-bottom: 20px;
}
.header-tel {
  font-size: 4rem;
  font-weight: 700;
  line-height: 1;
  position: relative;
  letter-spacing: 0.06em;
  margin-right: 18px;
  padding-bottom: 18px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  position: relative;
}
.header-tel::before {
  content: "";
  width: 30px;
  height: 30px;
  margin-right: 7px;
  background: center/cover no-repeat url(../../images/common/header-tel-icon.png);
}
.header-tel .accent {
  font-size: 2rem;
}
.header-tel-txt {
  position: absolute;
  left: 0;
  bottom: 0;
}
.header-tel-txt img {
  display: block;
}
.header-contact {
  margin-right: 20px;
}
.header-contact:hover {
  opacity: 0.8;
}
.header-insta:hover {
  opacity: 0.8;
}
.header .global-nav {
  width: 100%;
}
.header .global-nav-list {
  width: 100%;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.header .global-nav-list-item {
  line-height: 1;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.header .global-nav-list-item:not(:last-child) {
  margin-right: 15px;
}
.header .global-nav-list-item:not(:last-child)::after {
  content: "";
  width: 5px;
  height: 5px;
  margin-left: 15px;
  background-color: #8ac3de;
  border-radius: 50%;
}
.header .global-nav-list-item a {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.06em;
}
.header .global-nav-list-item a:hover {
  color: #008acd;
}
.header .global-nav-list-item a.current {
  color: #008acd;
}
.header .main-visual {
  width: 100%;
  height: 780px;
  margin-top: 150px;
  position: relative;
  z-index: 10;
}
.header .main-visual::after {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 726px;
  height: 848px;
  background: center/cover no-repeat url(../../images/common/main-visual-bg-l.png);
  z-index: -1;
}
.header .main-visual-img {
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  max-width: 1150px;
  width: 100%;
  height: 780px;
  z-index: 1;
  border-radius: 390px 0 0 390px;
  overflow: hidden;
}
.header .main-visual-textbox {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  max-width: 1600px;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  z-index: 1;
}
.header .sub-visual {
  width: 100%;
  height: 380px;
  margin-top: 150px;
  position: relative;
  z-index: 10;
}
.header .sub-visual-textbox {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  max-width: 1080px;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding-bottom: 55px;
  z-index: 1;
}
.header .fix-line {
  position: fixed;
  right: 60px;
  bottom: 150px;
  z-index: 100;
}
.header .fix-line:hover {
  opacity: 0.7;
}
.header .fix-btn {
  position: fixed;
  right: 96px;
  bottom: 50px;
  z-index: 100;
}
.header .fix-btn:hover {
  opacity: 0.7;
  -webkit-transform: translateY(-10px);
          transform: translateY(-10px);
}

/*========================================
mixin
==========================================*/
/*========================================
main
==========================================*/
.top-about {
  position: relative;
  z-index: 1;
}
.top-about::before {
  position: absolute;
  content: "";
  top: -130px;
  left: 0;
  width: 786px;
  height: 942px;
  background: center/cover no-repeat url(../../images/top/top-about-bg-l.png);
  z-index: -1;
}
.top-about::after {
  position: absolute;
  content: "";
  top: 340px;
  right: 0;
  width: 763px;
  height: 1071px;
  background: center/cover no-repeat url(../../images/top/top-about-bg-r.png);
  z-index: -1;
}
.top-about-inner {
  padding: 150px 0;
  position: relative;
}
.top-about-inner::before {
  position: absolute;
  content: "";
  left: -260px;
  bottom: 0;
  width: 1232px;
  height: 157px;
  background: center/cover no-repeat url(../../images/top/top-about-en02.png);
}
.top-about-content {
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.top-about-img {
  margin-left: -346px;
}
.top-about-textbox {
  max-width: 683px;
  width: 100%;
  margin-right: -30px;
  margin-top: 105px;
}
.top-about-title {
  font-size: 5rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1.4;
  margin-bottom: 55px;
}
.top-about-title-en {
  display: block;
  margin-bottom: 25px;
}
.top-about-text {
  font-size: 1.8rem;
  line-height: 2.222;
  letter-spacing: 0.06em;
  margin-bottom: 60px;
}

.top-service {
  position: relative;
  z-index: 2;
}
.top-service-inner {
  padding: 150px 0;
}
.top-service-title {
  font-size: 5rem;
  font-weight: 600;
  text-align: center;
  letter-spacing: 0.06em;
  line-height: 1;
  margin-bottom: 100px;
}
.top-service-title-en {
  display: block;
  margin-bottom: 40px;
}
.top-service-list {
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  margin-bottom: 100px;
}
.top-service-list-item {
  max-width: 510px;
  width: 100%;
  padding: 60px 28px 50px 28px;
  background-color: #eef9fe;
  border-radius: 60px;
}
.top-service-list-item:not(:nth-last-child(-n+2)) {
  margin-bottom: 60px;
}
.top-service-list-title {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1;
  color: #008acd;
  text-align: center;
  padding-bottom: 10px;
  margin-bottom: 20px;
  border-bottom: 1px solid #cccccc;
}
.top-service-icon {
  text-align: center;
  margin-bottom: 20px;
}
.top-service-text {
  font-size: 1.8rem;
  line-height: 2.222;
  letter-spacing: 0.05em;
  text-align: center;
}
.top-service-flex {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.top-service-flex .cmn-btn:not(:last-of-type) {
  margin-right: 60px;
}

.link-banner {
  position: relative;
  z-index: 1;
}
.link-banner::before {
  position: absolute;
  content: "";
  left: 0;
  bottom: 324px;
  width: 777px;
  height: 942px;
  background: center/cover no-repeat url(../../images/top/link-banner-bg-l.png);
  z-index: -1;
}
.link-banner::after {
  position: absolute;
  content: "";
  right: 0;
  bottom: 0;
  width: 832px;
  height: 1071px;
  background: center/cover no-repeat url(../../images/top/link-banner-bg-r.png);
  z-index: -1;
}
.link-banner-inner {
  padding-top: 0;
  padding-bottom: 168px;
}
.link-banner-list {
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.link-banner-list-item {
  max-width: 500px;
  width: 100%;
}
.link-banner-list-item:nth-child(1) {
  margin-top: 90px;
}
.link-banner-list-item a {
  width: 100%;
  height: 100%;
}
.link-banner-list-item a:hover {
  opacity: 0.8;
}
.link-banner-list-item a:hover .link-banner-title::after {
  -webkit-transform: translateX(8px);
          transform: translateX(8px);
}
.link-banner-img {
  margin-bottom: 60px;
}
.link-banner-en {
  margin-bottom: 10px;
}
.link-banner-title {
  font-size: 4rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  margin-bottom: 34px;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.link-banner-title::after {
  content: "";
  -webkit-box-flex: 0;
  -webkit-flex: none;
      -ms-flex: none;
          flex: none;
  width: 50px;
  height: 50px;
  margin-left: 24px;
  background: center/cover no-repeat url(../../images/top/link-banner-arrow.png);
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.link-banner-text {
  font-size: 1.8rem;
  line-height: 2.22;
}

.top-info {
  background: center top/cover no-repeat url(../../images/top/top-info-bg.png);
}
.top-info-inner {
  padding: 200px 0 150px 0;
  position: relative;
}
.top-info-inner::before {
  position: absolute;
  content: "";
  top: -36px;
  right: 61px;
  width: 561px;
  height: 177px;
  background: center/cover no-repeat url(../../images/top/top-info-en.png);
}
.top-info-table {
  max-width: 580px;
  width: 100%;
}
.top-info-table tr {
  border-bottom: 1px solid #cccccc;
}
.top-info-table tr th {
  width: 125px;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
  color: #008acd;
  padding: 28px 0 28px 22px;
}
.top-info-table tr td {
  font-size: 1.8rem;
  font-weight: 500;
  padding: 12px 0;
  vertical-align: middle;
}
.top-info-title {
  font-size: 5rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.06em;
  margin-bottom: 60px;
}
.top-info-map {
  max-width: 450px;
  width: 100%;
  height: 560px;
  border-radius: 40px;
  overflow: hidden;
}
.top-info-map iframe {
  width: 100%;
  height: 100%;
  border: none;
}

.reserve {
  max-width: 1800px;
  width: 100%;
  margin: 0 auto;
  background: center/cover no-repeat url(../../images/top/reserve-bg.png);
  border-radius: 312px;
}
.reserve-inner {
  padding: 167px 0 100px 0;
  position: relative;
  z-index: 1;
}
.reserve-inner::before {
  position: absolute;
  content: "";
  top: 100px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 488px;
  height: 92px;
  background: center/cover no-repeat url(../../images/top/reserve-en.png);
  z-index: -1;
}
.reserve-title {
  font-size: 5rem;
  font-weight: 600;
  line-height: 1;
  color: #fff;
  letter-spacing: 0.06em;
  text-align: center;
  margin-bottom: 60px;
}
.reserve-textbox {
  max-width: 520px;
  width: 100%;
  padding: 39px 0;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  background-color: #fff;
  border-radius: 40px;
}
.reserve-tel {
  font-size: 4.8rem;
  font-weight: 700;
  line-height: 1;
  position: relative;
  letter-spacing: 0.06em;
  margin-bottom: 29px;
  padding-bottom: 24px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  position: relative;
}
.reserve-tel::before {
  content: "";
  width: 37px;
  height: 36px;
  margin-right: 7px;
  background: center/cover no-repeat url(../../images/top/reserve-tel-icon.png);
}
.reserve-tel .accent {
  font-size: 2rem;
}
.reserve-tel-txt {
  position: absolute;
  left: 0;
  bottom: 0;
}
.reserve-tel-txt img {
  display: block;
}
.reserve-contact:hover {
  opacity: 0.8;
}
.reserve-line {
  max-width: 520px;
  width: 100%;
  min-height: 250px;
  padding: 20px 67px;
  background: center/cover no-repeat url(../../images/top/reserve-line-bg.png);
  border-radius: 40px;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-flow: row-reverse;
      -ms-flex-flow: row-reverse;
          flex-flow: row-reverse;
  border: 3px solid #ffffff;
  position: relative;
}
.reserve-line::before {
  position: absolute;
  content: "";
  right: 27px;
  bottom: 27px;
  width: 14px;
  height: 14px;
  background: center/cover no-repeat url(../../images/top/reserve-line-arrow.png);
}
.reserve-line:hover {
  opacity: 0.8;
  -webkit-transform: translateY(-8px);
          transform: translateY(-8px);
}
.reserve-sub-textbox {
  max-width: 260px;
  width: 100%;
  text-align: center;
}
.reserve-sub-title {
  text-align: center;
  margin-bottom: 20px;
}
.reserve-text {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1;
  color: #fff;
}

.news {
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.news-inner {
  padding: 150px 0;
  position: relative;
}
.news-inner .cmn-title {
  text-align: left;
}
.news-section-title {
  font-size: 5rem;
  font-weight: 600;
  line-height: 1;
  margin-bottom: 100px;
}
.news-section-title-en {
  display: block;
  margin-bottom: 20px;
}
.news-list {
  width: 100%;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.news-list-item {
  max-width: 320px;
  width: 100%;
  margin-bottom: 20px;
}
.news-list-item:not(:nth-child(3n)) {
  margin-right: 60px;
}
.news-list-item a {
  width: 100%;
}
.news-list-item a:hover .news-visual::before {
  right: 2px;
}
.news-list-item a:hover .news-visual img {
  -webkit-transform: scale(1.08);
          transform: scale(1.08);
}
.news-list-item a time {
  display: block;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  color: #008acd;
  margin-bottom: 15px;
  letter-spacing: 0.1em;
}
.news-visual {
  width: 100%;
  height: 200px;
  margin-bottom: 21px;
  overflow: hidden;
  position: relative;
  border-radius: 15px;
}
.news-visual img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.news-title {
  width: 100%;
  display: block;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.3;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  margin-bottom: 27px;
}
.news-accent {
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-bottom: 5px;
}
.news-accent-tag {
  font-size: 1.2rem;
  font-weight: 500;
  color: #fff;
  line-height: 1;
  padding: 5px 10px;
  background: -webkit-gradient(linear, left top, right top, from(#008acd), to(#8ac3de));
  background: -webkit-linear-gradient(left, #008acd, #8ac3de);
  background: linear-gradient(to right, #008acd, #8ac3de);
  margin-bottom: 10px;
  border-radius: 10px;
}
.news-accent-tag:not(:last-child) {
  margin-right: 9px;
}
.news .cmn-btn {
  position: absolute;
  top: 207px;
  right: 0;
}
.news-tag-list {
  max-width: 350px;
  width: 100%;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  text-overflow: ellipsis;
  margin: 0 0 30px auto;
  cursor: pointer;
  color: #008acd;
  border: 2px solid #008acd;
}
.news-tag-list-item {
  width: 100%;
  margin-bottom: 15px;
  margin-right: 10px;
}
.news-tag-list-item a {
  font-size: 1.6rem;
  color: #fff !important;
  padding: 5px 10px;
  background-color: #008acd;
}
.news-tag-list-item a:hover {
  opacity: 0.6;
}
.news-detail-inner {
  text-align: center;
}
.news-detail-content {
  width: 100%;
  margin: 0 auto;
}
.news-detail-info-list {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-bottom: 30px;
}
.news-detail-info-list-item {
  line-height: 1;
  color: #aaa;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-bottom: 10px;
}
.news-detail-info-list-item:not(:last-child) {
  padding-right: 10px;
  margin-right: 10px;
  border-right: 1px solid #aaa;
}
.news-detail-title {
  font-size: 2.5rem;
  line-height: 1.4;
  text-align: left;
  padding-bottom: 10px;
}
.news-detail-textbox {
  min-height: 200px;
  text-align: left;
  padding: 20px 0;
  margin-bottom: 30px;
  border-top: 1px solid #008acd;
  border-bottom: 1px solid #008acd;
}
.news-detail-textbox time {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1;
}
.news-detail-text {
  line-height: 1.75;
}
.news-detail-text img {
  max-width: 100%;
}
.news-detail .paginated-link {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.news-detail .paginated-link .prev-link {
  width: 187px;
  text-align: center;
  margin-right: 5px;
}
.news-detail .paginated-link .back-link {
  padding: 0 20px;
  border-left: 1px solid #008acd;
  border-right: 1px solid #008acd;
}
.news-detail .paginated-link .next-link {
  width: 187px;
  text-align: center;
  margin-left: 5px;
}
.news-detail .paginated-link a {
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: 0;
  color: #008acd !important;
}
.news-detail .paginated-link a:hover {
  opacity: 0.8;
}

/*========================================
worry
==========================================*/
.worry {
  position: relative;
  z-index: 1;
}
.worry::before {
  position: absolute;
  content: "";
  right: 0;
  bottom: 340px;
  width: 762px;
  height: 1071px;
  background: center/cover no-repeat url(../../images/service/worry-bg-r.png);
  z-index: -1;
}
.worry-inner {
  padding: 60px 0 150px 0;
}
.worry-list {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.worry-list-item {
  max-width: 280px;
  width: 100%;
  height: 280px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 50px;
  background: center/cover no-repeat url(../../images/service/worry-box.png);
  -webkit-box-shadow: 0 0 20px 2px rgba(17, 17, 17, 0.1);
          box-shadow: 0 0 20px 2px rgba(17, 17, 17, 0.1);
  border-radius: 50%;
  font-size: 2rem;
  font-weight: 500;
  text-align: center;
  line-height: 2;
}
.worry-list-item:not(:nth-child(3n)) {
  margin-right: 120px;
}
.worry-list-item .border {
  display: inline-block;
  line-height: 1;
  font-size: 2.2rem;
  font-weight: 700;
  position: relative;
  z-index: 1;
}
.worry-list-item .border::before {
  position: absolute;
  content: "";
  left: 0;
  bottom: -3px;
  width: 102%;
  height: 14.9px;
  background-color: #c5f495;
  z-index: -1;
}

.service {
  background-color: #eef9fe;
  position: relative;
  z-index: 1;
}
.service::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 599px;
  background: center/cover no-repeat url(../../images/service/service-bg-top.png);
  z-index: -1;
}
.service-inner {
  padding-top: 0;
  padding-bottom: 198px;
}
.service-content:nth-of-type(even) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-flow: row-reverse;
      -ms-flex-flow: row-reverse;
          flex-flow: row-reverse;
}
.service-content:nth-of-type(even) .service-img {
  margin-left: auto;
  margin-right: -100px;
}
.service-content:nth-of-type(2) .service-title::after {
  width: 92px;
  height: 48px;
  background: center/cover no-repeat url(../../images/other/service-icon02.png);
}
.service-content:nth-of-type(3) .service-title::after {
  width: 67px;
  height: 67px;
  background: center/cover no-repeat url(../../images/other/service-icon03.png);
}
.service-content:not(:last-of-type) {
  margin-bottom: 40px;
}
.service-img {
  margin-left: -100px;
}
.service-textbox {
  max-width: 603px;
  width: 100%;
}
.service-title {
  font-family: "Shippori Mincho", serif;
  font-size: 3.2rem;
  font-weight: 600;
  line-height: 1;
  -webkit-flex-wrap: nowrap;
      -ms-flex-wrap: nowrap;
          flex-wrap: nowrap;
  margin-bottom: 22px;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.service-title::after {
  content: "";
  -webkit-box-flex: 0;
  -webkit-flex: none;
      -ms-flex: none;
          flex: none;
  width: 59px;
  height: 50px;
  margin-left: 29px;
  background: center/cover no-repeat url(../../images/other/service-icon01.png);
}
.service-text {
  font-size: 1.8rem;
  line-height: 2.222;
  letter-spacing: 0.06em;
}
.service-text:not(:last-of-type) {
  margin-bottom: 40px;
}

.strength {
  background-color: #eef9fe;
  position: relative;
  z-index: 1;
}
.strength::before {
  position: absolute;
  content: "";
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  max-width: 1600px;
  width: 90%;
  height: calc(100% - 150px);
  background-color: #fff;
  z-index: -1;
  border-radius: 50px;
}
.strength-inner {
  padding: 188px 0 275px 0;
  position: relative;
}
.strength .cmn-title {
  position: absolute;
  right: 0;
  top: -80px;
  text-align: right;
}
.strength-content {
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.strength-content:nth-of-type(even) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-flow: row-reverse;
      -ms-flex-flow: row-reverse;
          flex-flow: row-reverse;
}
.strength-content:nth-of-type(even) .strength-img {
  margin-right: -60px;
}
.strength-content:not(:last-of-type) {
  margin-bottom: 50px;
}
.strength-img {
  position: relative;
  z-index: 2;
}
.strength-textbox {
  max-width: 600px;
  width: 100%;
  margin-top: 45px;
  position: relative;
  z-index: 1;
}
.strength-textbox::before {
  position: absolute;
  content: "";
  top: -55px;
  left: -111px;
  width: 220px;
  height: 220px;
  background-color: #eef9fe;
  z-index: -1;
  border-radius: 50%;
}
.strength-title {
  font-family: "Shippori Mincho", serif;
  font-size: 3.2rem;
  font-weight: 600;
  line-height: 1;
  margin-bottom: 33px;
}
.strength-text {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2.2222;
}

.menu-inner {
  padding: 150px 0 128px 0;
}
.menu-link {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-bottom: 60px;
}
.menu-btn {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 24px 30px;
  font-size: 1.8rem;
  font-weight: 500;
  margin-bottom: 20px;
  background: -webkit-gradient(linear, left top, right top, from(#c5f495), to(#b4eec8));
  background: -webkit-linear-gradient(left, #c5f495, #b4eec8);
  background: linear-gradient(to right, #c5f495, #b4eec8);
  border: 1px solid #c5f495;
  border-radius: 10px;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.menu-btn:not(:last-of-type) {
  margin-right: 30px;
}
.menu-btn:hover {
  background: #fff;
}
.menu-list {
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
.menu-list-item {
  max-width: 500px;
  width: 100%;
  padding-bottom: 30px;
  margin-bottom: 25px;
  border-bottom: 1px solid #111111;
}
.menu-title {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.05em;
  margin-bottom: 20px;
}
.menu-price {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.1em;
  text-align: right;
}

/*========================================
case
==========================================*/
.case-inner {
  max-width: 1280px;
}
.case-content {
  max-width: 1080px;
  width: 100%;
  margin: 0 auto;
  margin-bottom: 65px;
}
.case-list {
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.case-list-item {
  max-width: 500px;
  width: 100%;
  margin-bottom: 70px;
}
.case-list-item a {
  width: 100%;
  height: 100%;
}
.case-list-item a:hover {
  opacity: 0.8;
  -webkit-transform: translateY(-8px);
          transform: translateY(-8px);
}
.case-img {
  width: 100%;
  height: 312px;
  margin-bottom: 33px;
  overflow: hidden;
  position: relative;
  border-radius: 15px;
}
.case-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.case-title {
  width: 100%;
  display: block;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.3;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  margin-bottom: 28px;
}
.case-accent {
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-bottom: 5px;
}
.case-accent-tag {
  font-size: 1.2rem;
  font-weight: 500;
  color: #fff;
  line-height: 1;
  padding: 5px 10px;
  background: -webkit-gradient(linear, left top, right top, from(#008acd), to(#8ac3de));
  background: -webkit-linear-gradient(left, #008acd, #8ac3de);
  background: linear-gradient(to right, #008acd, #8ac3de);
  margin-bottom: 10px;
  border-radius: 10px;
}
.case-accent-tag:not(:last-child) {
  margin-right: 9px;
}
.case-detail-accent {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-bottom: 5px;
}
.case-detail-accent-tag {
  font-size: 1.8rem;
  font-weight: 500;
  color: #fff;
  line-height: 1;
  padding: 7px 16px;
  background: -webkit-gradient(linear, left top, right top, from(#008acd), to(#8ac3de));
  background: -webkit-linear-gradient(left, #008acd, #8ac3de);
  background: linear-gradient(to right, #008acd, #8ac3de);
  margin-bottom: 10px;
  border-radius: 15px;
}
.case-detail-accent-tag:not(:last-child) {
  margin-right: 9px;
}
.case-detail-title {
  font-size: 4rem;
  font-weight: 600;
  margin-bottom: 85px;
}
.case-detail-flex {
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-bottom: 46px;
}
.case-detail-img {
  max-width: 400px;
  width: 100%;
  height: 250px;
  overflow: hidden;
  position: relative;
  border-radius: 30px;
}
.case-detail-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.case-detail-after .case-detail-img {
  max-width: 590px;
  width: 100%;
  height: 368px;
}
.case-detail-en {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  font-family: "Shippori Mincho", serif;
  font-size: 2.6rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.06em;
  margin-bottom: 17px;
  background: -webkit-gradient(linear, left top, right top, from(#008acd), to(#8ac3de));
  background: -webkit-linear-gradient(left, #008acd, #8ac3de);
  background: linear-gradient(90deg, #008acd, #8ac3de);
  background: -webkit-linear-gradient(0deg, #008acd, #8ac3de);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.case-detail-body {
  font-size: 1.8rem;
  line-height: 2.2222;
  margin-bottom: 65px;
}
.case-detail-body img {
  max-width: 100%;
}
.case-detail-img-list {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding: 90px 100px 20px 100px;
  background-color: #eef9fe;
  border-radius: 50px;
}
.case-detail-img-list-item {
  max-width: 320px;
  width: 100%;
  height: 200px;
  overflow: hidden;
  border-radius: 30px;
  margin-bottom: 70px;
}
.case-detail-img-list-item:not(:nth-child(3n)) {
  margin-right: 60px;
}
.case-detail-img-list-item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}

/*========================================
question
==========================================*/
.guide-link {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-top: 60px;
}
.guide-link-btn {
  max-width: 320px;
  width: 100%;
  height: 70px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 1.8rem;
  font-weight: 500;
  margin-bottom: 20px;
  background: -webkit-gradient(linear, left top, right top, from(#c5f495), to(#b4eec8));
  background: -webkit-linear-gradient(left, #c5f495, #b4eec8);
  background: linear-gradient(to right, #c5f495, #b4eec8);
  border-radius: 10px;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.guide-link-btn:not(:last-of-type) {
  margin-right: 60px;
}
.guide-link-btn:hover {
  opacity: 0.7;
}

.question-list-item {
  width: 100%;
  padding: 35px 40px;
  background-color: #eef9fe;
  -webkit-box-shadow: 0 0 20px 2px rgba(17, 17, 17, 0.1);
          box-shadow: 0 0 20px 2px rgba(17, 17, 17, 0.1);
  border-radius: 30px;
  border: 6px solid #ffffff;
}
.question-list-item:not(:last-child) {
  margin-bottom: 50px;
}
.question-title {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.08em;
  margin-bottom: 30px;
  border-radius: 10px;
  -webkit-flex-wrap: nowrap;
      -ms-flex-wrap: nowrap;
          flex-wrap: nowrap;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.question-title::before {
  content: "";
  width: 48px;
  height: 36px;
  margin-right: 17px;
  background: center/cover no-repeat url(../../images/question/Q..png);
}
.question-textbox {
  -webkit-flex-wrap: nowrap;
      -ms-flex-wrap: nowrap;
          flex-wrap: nowrap;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.question-textbox::before {
  content: "";
  -webkit-box-flex: 0;
  -webkit-flex: none;
      -ms-flex: none;
          flex: none;
  width: 44px;
  height: 35px;
  margin-right: 15px;
  background: center/cover no-repeat url(../../images/question/A..png);
}
.question-body {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0.06em;
  margin-top: 15px;
}
.question-body img {
  max-width: 100%;
}

.voice {
  background-color: #eef9fe;
  position: relative;
  z-index: 1;
}
.voice::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 599px;
  background: center/cover no-repeat url(../../images/service/service-bg-top.png);
  z-index: -1;
}
.voice-inner {
  padding-top: 0;
  padding-bottom: 130px;
}
.voice-list-item {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.voice-list-item:nth-child(even) {
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.voice-list-item:not(:last-child) {
  margin-bottom: 40px;
}
.voice-left {
  max-width: 178px;
  width: 100%;
  margin-right: 50px;
  text-align: center;
}
.voice-icon {
  max-width: 178px;
  width: 100%;
  height: 178px;
  margin-bottom: 18px;
  -webkit-box-shadow: 0 0 20px 2px rgba(17, 17, 17, 0.1);
          box-shadow: 0 0 20px 2px rgba(17, 17, 17, 0.1);
  border-radius: 50%;
}
.voice-textbox {
  max-width: 700px;
  width: 100%;
  padding: 38px;
  margin-top: 30px;
  background-color: #fff;
  border-radius: 20px;
  -webkit-box-shadow: 0 0 20px 2px rgba(17, 17, 17, 0.1);
          box-shadow: 0 0 20px 2px rgba(17, 17, 17, 0.1);
  position: relative;
}
.voice-textbox::before {
  position: absolute;
  content: "";
  top: 40px;
  left: -22px;
  width: 23px;
  height: 33px;
  background: center/cover no-repeat url(../../images/question/voice-arrow.png);
}
.voice-info {
  display: block;
  width: 100%;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.07em;
  margin-bottom: 30px;
}
.voice-info .accent {
  color: #008acd;
}

/*========================================
contact
==========================================*/
.contact-form-table tr {
  border: none;
}
.contact-form-table tr th {
  font-size: 1.6rem;
  font-weight: 500;
  color: #fff;
  background-color: #008acd;
}
.contact-form-table tr td a {
  text-decoration: underline;
}
.contact-submits-wrap input {
  color: #fff;
  background-color: #008acd;
}
.contact-submits-wrap button {
  color: #fff;
  background-color: #008acd;
}

/*========================================
privacy
==========================================*/
.privacy-content {
  padding: 25px;
  text-align: left;
  background-color: #fff;
  border: 1px solid #008acd;
  border-radius: 5px;
}
.privacy-content:not(:last-child) {
  margin-bottom: 30px;
}
.privacy-title {
  font-size: 1.8rem;
  font-weight: 500;
  margin: 0 0 15px;
  padding: 0 0 0 20px;
  border-left: 2px solid #008acd;
}
.privacy-text {
  font-weight: 500;
}
.privacy-list {
  font-weight: 500;
  margin-top: 15px;
  list-style-type: square;
  list-style-position: inside;
}

/*========================================
site
==========================================*/
.site-list-item {
  width: 48%;
  border-bottom: 1px solid #008acd;
}
.site-list-item a {
  width: 100%;
  padding: 20px 0 20px 10px;
  color: #008acd;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.site-list-item a::before {
  content: "";
  width: 7px;
  height: 7px;
  margin-right: 20px;
  border-top: 1px solid #008acd;
  border-right: 1px solid #008acd;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.site-list-item a:hover {
  color: #000 !important;
}
.site-list-item a:hover::before {
  -webkit-transform: rotate(45deg) translate(8px, -8px);
          transform: rotate(45deg) translate(8px, -8px);
}

/*========================================
mixin
==========================================*/
/*========================================
footer
==========================================*/
.footer {
  background: center/cover no-repeat url(../../images/top/footer-bg.png);
}
.footer-left {
  max-width: 500px;
  width: 100%;
}
.footer-logo {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 35px;
}
.footer-logo:hover {
  opacity: 0.8;
}
.footer-link {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-bottom: 38px;
}
.footer-tel {
  font-size: 4rem;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  position: relative;
  letter-spacing: 0.06em;
  margin-right: 29px;
  padding-bottom: 18px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  position: relative;
}
.footer-tel::before {
  content: "";
  width: 30px;
  height: 30px;
  margin-right: 7px;
  background: center/cover no-repeat url(../../images/top/footer-tel-icon.png);
}
.footer-tel .accent {
  font-size: 2rem;
}
.footer-tel-txt {
  position: absolute;
  left: 0;
  bottom: 0;
}
.footer-tel-txt img {
  display: block;
}
.footer-line {
  margin-right: 29px;
}
.footer-line:hover {
  opacity: 0.8;
  -webkit-transform: translateY(-8px);
          transform: translateY(-8px);
}
.footer-insta:hover {
  opacity: 0.8;
  -webkit-transform: translateY(-8px);
          transform: translateY(-8px);
}
.footer-info {
  padding-top: 35px;
  border-top: 1px dotted #fff;
}
.footer-text {
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: #fff;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-flex-wrap: nowrap;
      -ms-flex-wrap: nowrap;
          flex-wrap: nowrap;
}
.footer-text:not(:last-of-type) {
  margin-bottom: 10px;
}
.footer-text .accent {
  -webkit-box-flex: 0;
  -webkit-flex: none;
      -ms-flex: none;
          flex: none;
  width: 90px;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1;
  color: #008acd;
  letter-spacing: 0.08em;
  padding: 13px 0;
  text-align: center;
  margin-right: 8px;
  background-color: #fff;
  border-radius: 20px;
}
.footer-right {
  max-width: 375px;
  width: 100%;
}
.footer-contact {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-bottom: 40px;
}
.footer-contact:hover {
  opacity: 0.8;
}
.footer-nav {
  margin-bottom: 60px;
}
.footer-nav-list {
  width: 100%;
  height: 217px;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-align-content: space-between;
      -ms-flex-line-pack: justify;
          align-content: space-between;
}
.footer-nav-list-item {
  line-height: 1;
}
.footer-nav-list-item:not(:nth-child(5)) {
  margin-bottom: 27px;
}
.footer-nav-list-item a {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #fff;
  position: relative;
}
.footer-nav-list-item a::before {
  position: absolute;
  content: "";
  top: 50%;
  left: -13px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 5px;
  height: 8px;
  background: center/cover no-repeat url(../../images/top/footer-nav-arrow.png);
  opacity: 0;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.footer-nav-list-item a:hover::before {
  opacity: 1;
}
.footer-nav-list-item.current a::before {
  opacity: 1;
}
.footer-bottom {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: #fff;
  line-height: 1;
  text-align: right;
}