@charset "UTF-8";
/* CSS Document */
html {
  -webkit-text-size-adjust: 100%;
}

body {
  color: #333333;
  font-size: 16px;
  line-height: 1.6;
  font-weight: 500;
  font-family: "Noto Sans JP", "Yu Gothic", "Meiryo", "Hiragino Kaku Gothic ProN", sans-serif;
  margin: 0 auto;
  height: 100%;
  overflow-x: hidden;
}

* {
  font-family: inherit;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

.josef {
  font-family: "Josefin Sans", sans-serif;
}

.sipp {
  font-family: "Shippori Mincho", serif;
}

img {
  max-width: 100%;
  border: none;
  vertical-align: bottom;
}

address,
em {
  font-style: normal;
}

a {
  color: #333;
  text-decoration: none;
}

a:hover,
input[type=submit]:hover,
input[type=reset]:hover {
  opacity: 0.9;
  filter: alpha(opacity=90);
  -ms-filter: "alpha( opacity=90 )";
}

.position_r {
  position: relative;
}

.position_a {
  position: absolute;
  z-index: 0;
}

/*********** class ****************************************/
/********** float ************/
.c-both {
  clear: both;
}

.clearfix:after {
  content: "";
  clear: both;
  display: block;
}

.left {
  float: left;
}

.right {
  float: right;
}

.center {
  display: block;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.txt_right {
  text-align: right;
}

/******* end float **********/
/******* flex box ***********/
.flex {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
}

.height {
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: stretch;
}

/* image parent cover *******/
.fit {
  object-fit: cover;
  font-family: "object-fit: cover;";
  max-width: 100%;
}

.inner {
  width: 96%;
  max-width: 1700px;
  margin: 0 auto;
}

.middle_inner {
  width: 96%;
  max-width: 1380px;
  margin: 0 auto;
  z-index: 1;
}

.low_inner {
  width: 96%;
  max-width: 1000px;
  margin: 0 auto;
  z-index: 1;
}

/**** dl table layout ************/
dl.table {
  display: table;
  width: 100%;
}

dl.table dt,
dl.table dd {
  display: table-cell;
}

/****** display ********/
.pc {
  display: unset;
}

.sp {
  display: none;
}

/****** class ********/
.indent {
  text-indent: -1em;
  padding-left: 1em;
}

span.indent {
  display: block;
}

.red {
  color: #FF3737;
}

hr {
  background-color: #BBBBBB;
  height: 1px;
  width: 100%;
  border: none;
}

span.caution {
  margin-top: 7px;
  margin-bottom: 10px;
}

.strapline {
  font-size: 18px;
  font-weight: 700;
}

.sub_heading2 {
  font-size: 20px;
  color: #289DD6;
  font-weight: bold;
  margin-bottom: 5px;
  margin-left: 2em;
  text-indent: -1em;
}

.sub_heading2 i {
  color: #00B2F0;
  margin-right: 5px;
}

header#header {
  position: fixed;
  z-index: 99;
  width: 100%;
  height: 140px;
  background-color: #FFF;
}

header#header #header_logo {
  width: 420px;
}

header#header #header_logo p {
  margin: 12px 0 12px 0;
}

header#header .glob1 {
  width: 890px;
  padding-top: 68px;
}

header#header .glob1 a.prepared {
  position: relative;
  pointer-events: none;
}

header#header .glob1 a.prepared::after {
  content: "準備中";
  pointer-events: none;
  position: absolute;
  bottom: -21px;
  left: 27px;
}

header#header #menu_btn {
  position: relative;
  z-index: 9999;
  top: 0;
  right: 0;
  caret-color: transparent;
  cursor: pointer;
  background-color: #16a6a7;
  color: #FFF;
  width: 200px;
  height: 140px;
  text-align: center;
  padding: 26px;
  margin-left: 3.6458333333vw;
}

header#header #menu_btn:hoever {
  caret-color: transparent;
  cursor: pointer;
}

header#header #menu_btn i {
  font-size: 48px;
}

header#header #menu_btn span {
  display: block;
  margin-top: 10px;
}

#menu_btn .initial {
  display: block;
}

#menu_btn .change {
  display: none;
}

#menu_btn.active .initial {
  display: none;
}

#menu_btn.active .change {
  display: block;
}

.zdo_drawer_bg {
  display: none;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9998;
  overflow-y: scroll;
  background-color: rgba(22, 166, 167, 0.8);
}

.zdo_drawer_bg .inner {
  background-color: #FFF;
  margin: 140px auto 24px auto;
  padding: 54px min(8.3333333333vw, 160px) 54px min(8.3333333333vw, 160px);
}

.zdo_drawer_bg .inner ul.first {
  margin: 0;
  padding: 0;
  list-style-type: none;
}

.zdo_drawer_bg .inner ul.first li {
  margin: 0 0 16px 0;
  padding: 0;
  list-style-type: none;
  width: 31.5%;
}

.zdo_drawer_bg .inner ul.first li a {
  position: relative;
  font-size: 18px;
  background-color: #FCF1F4;
  display: block;
  padding: 16px;
}

.zdo_drawer_bg .inner ul.first li a i {
  position: absolute;
  top: 16px;
  right: 16px;
  color: #E16374;
  font-size: 24px;
}

.zdo_drawer_bg .inner ul.first li a.prepared::after {
  content: "準備中";
  pointer-events: none;
  position: absolute;
  left: 146px;
}

.zdo_drawer_bg .inner ul.first::after {
  display: block;
  content: "";
  width: 31.5%;
}

.zdo_drawer_bg .inner p.cat {
  font-size: 18px;
  color: #279DD6;
  margin: 20px 0 12px 0;
}

.zdo_drawer_bg .inner p.cat i {
  font-size: 21px;
}

.zdo_drawer_bg .inner ul.resort {
  margin: 0;
  padding: 16px;
  list-style-type: none;
  background-color: #FCF1F4;
}

.zdo_drawer_bg .inner ul.resort li {
  display: inline-block;
  margin: 6px 25px 6px 0;
}

.zdo_drawer_bg .inner ul.information {
  margin: 0;
  padding: 0 0 40px 0;
  list-style-type: none;
  border-bottom: solid 1px #BBBBBB;
}

.zdo_drawer_bg .inner ul.information li {
  width: 320px;
  margin: 0 0 16px 0;
}

.zdo_drawer_bg .inner ul.information li a {
  position: relative;
  font-size: 18px;
  background-color: #FCF1F4;
  display: block;
  padding: 16px;
}

.zdo_drawer_bg .inner ul.information li a i {
  position: absolute;
  top: 16px;
  right: 16px;
  color: #E16374;
  font-size: 24px;
}

.zdo_drawer_bg .inner ul.information.flex::after {
  display: block;
  content: "";
  width: 320px;
}

.zdo_drawer_bg .inner .logo {
  mmargin-top: 40px;
  padding-top: 25px;
  border-top: solid 1px #BBBBBB;
}

.zdo_drawer_bg .inner .glob3 {
  padding: 20px 0 5px 0;
}

.zdo_drawer_bg .inner .glob3 ul {
  margin: 0;
  padding: 0;
}

.zdo_drawer_bg .inner .glob3 ul li {
  display: inline-block;
  padding: 0 20px 0 20px;
  border-right: solid 1px #333;
}

.zdo_drawer_bg .inner .glob3 ul li:last-child {
  border: none;
}

main {
  padding-top: 140px;
}

main.page {
  background-color: #FDF4F7;
  padding-bottom: 140px;
}

section#fv {
  position: relative;
  height: min(48.9583333333vw, 940px);
}

section#fv .swiper-slide {
  background-position: center;
  background-size: cover;
  width: 100%;
  height: 100%;
}

section#fv #fv_slider1 {
  background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/1.webp);
  background-size: cover;
  width: 100%;
  height: min(48.9583333333vw, 940px);
}

section#fv #fv_slider2 {
  background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/2.webp);
  background-size: cover;
  width: 100%;
  height: min(48.9583333333vw, 940px);
}

section#fv #fv_slider3 {
  background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/3.webp);
  background-size: cover;
  width: 100%;
  height: min(48.9583333333vw, 940px);
}

section#fv #fv_slider4 {
  background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/4.webp);
  background-size: cover;
  width: 100%;
  height: min(48.9583333333vw, 940px);
}

section#fv #fv_slider5 {
  background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/5.webp);
  background-size: cover;
  width: 100%;
  height: min(48.9583333333vw, 940px);
}

section#fv #fv_slider6 {
  background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/6.webp);
  background-size: cover;
  width: 100%;
  height: min(48.9583333333vw, 940px);
}

section#fv .circle {
  position: absolute;
  top: 15%;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 10;
  text-align: center;
  border-radius: 50%;
  background-color: rgba(22, 166, 167, 0.8);
  width: min(16.6666666667vw, 320px);
  height: min(16.6666666667vw, 320px);
}

section#fv .circle img.sum {
  width: min(8.8020833333vw, 169px);
  margin: min(4.1666666667vw, 80px) auto auto auto;
}

section#top_service {
  width: 96%;
  margin: 160px 0 110px 4%;
  padding: 50px 0 0 0;
  background-image: linear-gradient(to bottom, #FDDDDE 0%, #FFF 100%);
}

section#top_service .catch {
  font-size: 40px;
}

section#top_service .description {
  font-size: 18px;
  margin: 18px auto 80px auto;
}

.dot {
  background-image: radial-gradient(circle at center, #EC6D8D 20%, transparent 20%);
  background-position: top right;
  background-repeat: repeat-x;
  background-size: 1em 0.3em;
  padding-top: 0.3em;
}

section#top_service .middle_inner {
  margin: 0;
  max-width: 1620px;
}

section#top_service a.service_link {
  position: relative;
  width: min(40.4255319149vw, 760px);
  height: min(23.9361702128vw, 450px);
  background-size: 100%;
  background-position: center;
}

section#top_service a.service_link.bus {
  background-image: url(../img/top/top_service_bus_sum.jpg);
}

section#top_service a.service_link.ski {
  background-image: url(../img/top/top_service_ski_sum.jpg);
}

section#top_service a.service_link.green {
  background-image: url(../img/top/top_service_green_sum.jpg);
}

section#top_service a.service_link .icon {
  position: absolute;
  top: -20px;
  left: -5px;
}

section#top_service a.service_link.service_lower {
  margin-top: 5.5em;
}

section#top_service a.service_link .link_title {
  position: absolute;
  bottom: -15px;
  left: 0;
  display: block;
  background-color: #FFF;
  width: 580px;
  padding: 10px;
  font-size: 32px;
}

section#top_service a.service_link .link_title img.arrow {
  position: absolute;
  top: 42%;
  right: 5%;
}

section#top_service a.service_link:hover {
  background-size: 110%;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}

section#top_service a.service_link:hover img.arrow {
  right: 3%;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}

section#loop_slider {
  background-image: linear-gradient(to bottom, #FFF 0%, #FFF 25%, #FDDDDE 25.1%, #FDDDDE 100%);
  padding: 0 0 50px 0;
}

section#loop_slider .inner {
  position: relative;
}

section#loop_slider .middle_inner {
  overflow: hidden;
  width: 92%;
  max-width: 1620px;
}

section#loop_slider .swiper-wrapper {
  transition-timing-function: linear;
}

.swiper-backface-hidden .swiper-slide {
  width: 25%;
}

section#loop_slider .swiper-slide img {
  height: auto;
  width: 100%;
}

section#loop_slider .swiper-button-next,
section#loop_slider .swiper-button-prev {
  color: #EB6587;
}

section#top_company {
  background-image: url(../img/top/top_company_bg.jpg);
  background-repeat: no-repeat;
  width: 100%;
  background-position: top center;
  padding: 264px 0 130px 0;
}

section#top_company .middle_inner {
  width: 92%;
  max-width: 1620px;
}

section#top_company .box {
  position: relative;
  background-color: #FDF7FA;
  width: min(40.4255319149vw, 760px);
}

section#top_company .box span.icon {
  position: absolute;
  top: -55px;
  left: 0;
  right: 0;
  margin: auto;
  display: block;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background-color: #FFF;
}

section#top_company .box span.icon i {
  font-size: 48px;
  color: #16a6a7;
  line-height: 110px;
}

section#top_company .box dt {
  margin: 0;
  padding: 110px 0 10px 0;
}

section#top_company .box dt a {
  margin: 0;
  font-size: 30px;
}

section#top_company .box dd {
  margin: 0;
  padding: 10px min(19%, 160px) 60px min(19%, 160px);
}

section#top_company .box dd p {
  min-height: 130px;
}

section#top_company .box dd a.more {
  position: relative;
  display: block;
  text-align: center;
  margin: 15px auto 15px auto;
  padding: 11px;
  width: 210px;
  background-color: #16a6a7;
  font-size: 18px;
  color: #FFF;
}

section#top_company .box dd a.more::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  right: 0;
  margin: auto;
  width: 41px;
  height: 2px;
  background-color: #444444;
}

header.page_global {
  background-size: cover;
  height: 340px;
}

header.page_global.company {
  background-image: url(../img/company/page_header_bg.jpg);
}

header.page_global.about {
  background-image: url(../img/about/page_header_bg.jpg);
}

header.page_global.terms {
  background-image: url(../img/terms/page_header_bg.jpg);
}

header.page_global .middle_inner {
  position: relative;
}

header.page_global .middle_inner .slug {
  position: absolute;
  top: 30px;
  left: 0;
  border-radius: 50%;
  background-color: rgba(22, 166, 167, 0.8);
  color: #FFF;
  text-align: center;
  display: block;
  font-size: 34px;
  width: 280px;
  height: 280px;
  margin: 0;
  padding: 116px 0 0 0;
}

header.page_global .middle_inner .slug.lines {
  padding: 84px 0 0 0;
}

header.page_global .middle_inner .slug.lines3 {
  padding: 1.75em 0 0 0;
}

aside.pan {
  padding: 40px 0 40px 0;
}

aside.pan p {
  margin: 0;
}

section.page_content {
  padding: 40px 0 40px 0;
}

section.page_content .inner {
  background-color: #FFF;
  padding: 40px 0 40px 0;
}

.subttl {
  position: relative;
  font-size: 40px;
  margin: 45px auto 55px auto;
}

.subttl::before {
  position: absolute;
  top: -20px;
  left: 0;
  right: 0;
  margin: auto;
  content: "";
  width: 120px;
  height: 2px;
  background-color: #16a6a7;
}

.subttl2 {
  font-size: 26px;
  margin: 15px auto 30px auto;
}

.subttl2 span {
  display: inline-block;
  position: relative;
}

.subttl2 span::before {
  content: "";
  position: absolute;
  top: 21px;
  left: -62px;
  width: 35px;
  height: 1px;
  background-color: #EB6587;
}

.subttl2 span::after {
  content: "";
  position: absolute;
  top: 21px;
  right: -62px;
  width: 35px;
  height: 1px;
  background-color: #EB6587;
}

.subttl3 {
  margin-top: 2em;
}

section#company_detail .box {
  margin: 0 0 15px 0;
  padding: 0;
}

section#company_detail .box dt {
  background-color: #FDDDDE;
  margin: 0 0 0 0;
  padding: 14px 20px 14px 20px;
  width: 195px;
  border-right: solid 5px #FFF;
}

section#company_detail .box dd {
  background-color: #FDF4F7;
  margin: 0 0 0 0;
  padding: 14px 20px 14px 20px;
  width: calc(100% - 195px);
}

section#access {
  padding: 120px 0 40px 0;
}

section#access .map_wrapper {
  background-color: #FDF4F7;
  padding: 40px;
}

section#access #gmap {
  width: 100%;
  height: 460px;
}

section#about_detail .middle_inner {
  width: 92%;
  max-width: 1620px;
}

section#about_detail p.summary {
  max-width: 950px;
  font-size: 18px;
  line-height: 2.4;
  margin: auto;
  margin-bottom: 50px;
}

section#about_detail .one_two .box {
  position: relative;
  width: min(39.5833333333vw, 760px);
  max-width: 760px;
  margin: 0 0 80px 0;
}

section#about_detail .three_four_five .box {
  position: relative;
  width: min(26.5625vw, 510px);
  max-width: 510px;
  margin: 0 0 80px 0;
}

section#about_detail .box img.sum {
  width: 100%;
}

section#about_detail .box img.num {
  position: absolute;
  top: -24px;
  left: 0;
  right: 0;
  margin: auto;
  filter: drop-shadow(0 0 5px #FFC8CD);
}

section#about_detail .box p.title {
  font-size: 26px;
  margin: 15px 0 15px 0;
  text-align: center;
}

section#about_detail .box p.title img.icon {
  vertical-align: baseline;
  margin-right: 5px;
}

section.terms_detail dl.box dt {
  background-color: #FDF4F7;
  margin: 0;
  padding: 10px 10px 10px 10px;
  font-size: 26px;
  font-weight: bold;
}

section.terms_detail dl.box dt img.icon {
  vertical-align: baseline;
  margin-right: 12px;
}

section.terms_detail dl.box dd {
  margin: 0;
  padding: 16px 0 16px 0;
}

div.border_line {
  background-color: #BBBBBB;
  width: 100%;
  height: 1px;
  margin: 16px auto 16px auto;
}

section.travel_detail ol,
section.travel_detail ul,
section.terms_detail dl.box dd ol,
section.terms_detail dl.box dd ul {
  margin: 16px 0 16px 0;
  padding: 0 0 0 24px;
}

section.travel_detail ol li,
section.travel_detail ul li,
section.terms_detail dl.box dd ol li {
  margin: 8px 0 8px 0;
}

section.terms_detail dl.box dd ul li {
  margin: 8px 0 8px 0;
}

section.terms_detail dl.box dd a {
  text-decoration: underline;
}

section.terms_detail .device {
  font-size: 20px;
}

section.terms_detail .device i {
  color: #E06373;
}

section.terms_detail strong.os {
  font-size: 18px;
}

section.terms_detail .registration_summary {
  margin: 16px auto 48px auto;
}

section.travel_detail strong.travel_subttl {
  display: block;
  font-size: 18px;
  padding: 18px 0 8px 0;
}

section.travel_detail table.calcel_table {
  border: none;
  border-collapse: collapse;
  width: 100%;
  margin: 16px 0 16px 0;
}

section.travel_detail table.calcel_table th {
  background-color: #FDDDDE;
  text-align: center;
  padding: 12px;
}

section.travel_detail table.calcel_table th.left_txt {
  width: 63.047%;
}

section.travel_detail table.calcel_table th.right_txt {
  width: 18.115%;
}

section.travel_detail table.calcel_table tr {
  border-bottom: solid 5px #FFF;
}

section.travel_detail table.calcel_table .border-right {
  border-right: solid 5px #FFF;
}

section.travel_detail table.calcel_table th.border-right {
  border-right: solid 5px #FFF;
}

section.travel_detail table.calcel_table tr.len1 td {
  padding: 10px;
  background-color: #FEF9FB;
  vertical-align: top;
}

section.travel_detail table.calcel_table tr.len2 td {
  padding: 10px;
  background-color: #FBEAEF;
  vertical-align: top;
}

section.travel_detail table.calcel_table .text_center {
  text-align: center;
}

section.travel_detail table.calcel_table span.indent {
  display: block;
  text-indent: -1.5em;
  padding-left: 1.5em;
}

/* conditions */
.terms_navi {
  margin-bottom: 100px;
}

.terms_content {
  border: solid 3px #EC6D8D;
  padding: 40px 0 20px 0;
}

.terms_content .lower_inner {
  width: 96%;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}

.terms_content .terms_btn {
  display: block;
  box-sizing: border-box;
  width: 48%;
  max-width: 480px;
  position: relative;
  margin-bottom: 20px;
  padding: 7px 27px 7px 15px;
  background-color: #16a6a7;
  color: #FFF;
  font-size: 18px;
}

.terms_content .terms_btn:nth-of-type(2n+1) {
  clear: both;
}

.terms_content .terms_btn .fa-file-lines {
  font-size: 24px;
  margin-right: 7px;
  vertical-align: middle;
}

.terms_content .terms_btn .fa-angle-right {
  position: absolute;
  top: 12px;
  right: 10px;
  font-size: 20px;
}

.terms_article .chapter {
  margin-top: 60px;
}

.terms_article .sub_heading {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 0;
}

.terms_article .sub_heading2 {
  font-size: 20px;
  color: #289DD6;
  font-weight: bold;
  margin-bottom: 5px;
  margin-left: 2em;
  text-indent: -1em;
}

.terms_article .sub_heading2 i {
  color: #00B2F0;
  margin-right: 5px;
}

.terms_article .clause dt {
  font-weight: 700;
}

.terms_article .clause dd {
  margin-left: 0;
}

.terms_article .clause a {
  text-decoration: underline;
}

.terms_article .clause .frame {
  box-sizing: border-box;
  border: 1px solid #F2C4D0;
  margin-top: 10px;
  padding: 0.75em 2% 1em 2%;
}

.terms_article .clause .frame ol {
  margin-top: 0;
  margin-bottom: 0;
}

.terms_article .clause .frame ol li ol li {
  margin-right: 2%;
}

.terms_article .clause .i_block {
  padding: 0;
  margin: 0;
}

.terms_article .clause .i_block li {
  display: inline-block;
  padding: 0;
  margin: 0 1.5em 0 0;
}

.terms_article .s_table {
  margin-top: 50px;
}

.terms_article .s_table dd {
  margin-bottom: 30px;
}

.terms_article .complaint dt {
  text-align: center;
}

.terms_article .complaint dd {
  border: 1px solid #F2C4D0;
  padding: 10px 4% 20px 4%;
}

.terms_article .complaint dd p {
  width: 100%;
  max-width: 740px;
  margin-left: auto;
  margin-right: auto;
}

.terms_article .complaint dd p.summary {
  margin-top: 1.5em;
  margin-bottom: 1.5em;
}

section.travel_detail ol.s_num {
  counter-reset: count 1;
  padding-left: 0;
}

section.travel_detail ol.cjk_num,
section.travel_detail ol.kana_iroha,
section.travel_detail ol.bracket,
section.travel_detail ol.caution {
  counter-reset: count 0;
  padding-left: 0;
}

section.travel_detail ol.bracket {
  margin-top: 0;
}

section.travel_detail ol.s_num li ol.cjk_num li ol.kana_iroha {
  margin-left: 1em;
}

section.travel_detail ol.s_num li,
section.travel_detail ol.cjk_num li,
section.travel_detail ol.kana_iroha li,
section.travel_detail ol.bracket li,
section.travel_detail ol.caution li {
  list-style-type: none;
  counter-increment: count;
  margin: 0 0 20px 1.5em;
  text-indent: -1.5em;
}

section.travel_detail ol.kana_iroha li {
  margin-right: 2%;
}

section.travel_detail ol.s_num li::before {
  content: counter(count) "　";
}

section.travel_detail ol.cjk_num li::before,
section.travel_detail ol.s_num li ol.cjk_num li::before {
  content: counter(count, cjk-ideographic) "　";
}

section.travel_detail ol.kana_iroha li::before,
section.travel_detail ol.s_num li ol.cjk_num li ol.kana_iroha li::before {
  content: counter(count, katakana-iroha) "　";
}

section.travel_detail ol.bracket li::before {
  content: "(" counter(count) ") ";
}

section.travel_detail ol.caution li::before {
  content: "注" counter(count) "　";
}

section.travel_detail ol.s_num li ol.cjk_num li {
  margin-left: 0;
}

section.travel_detail .calcel_table ol.bracket li {
  margin-bottom: 5px;
}

section.travel_detail ol.caution li {
  margin: 0 0 10px 2.5em;
  text-indent: -2.5em;
}

section.travel_detail ol.s_num li::before {
  content: counter(count) "　";
}

section.travel_detail ol .price {
  padding-left: 1em;
}

section.travel_detail .table_ttl {
  font-weight: 700;
}

section.travel_detail .complaint {
  margin-top: 60px;
}

section.travel_detail p.separate {
  margin: -0.35em 0 50px 0;
}

/* footer */
footer#footer {
  padding-bottom: 20px;
}

footer#footer .glob_menu {
  background-color: #16a6a7;
  color: #FFF;
  padding: 64px 0 70px 0;
}

footer#footer .glob_menu a {
  color: #FFF;
}

footer#footer .glob_menu ul {
  list-style-type: none;
}

footer#footer .glob_menu ul.glob2 {
  display: flex;
  width: fit-content;
  margin: 50px auto 0 auto;
  padding: 0;
}

footer#footer .glob_menu ul.glob2 li {
  display: inline-block;
  padding: 0 20px 0 20px;
  border-right: solid 1px #FFF;
  font-size: 20px;
}

footer#footer .glob_menu ul.glob2 li:last-child {
  border: none;
}

footer#footer .glob_menu ul.glob2 li a.prepared {
  position: relative;
  pointer-events: none;
}

footer#footer .glob_menu ul.glob2 li a.prepared::after {
  content: "準備中";
  position: absolute;
  bottom: -27px;
  left: 27px;
}

footer#footer #glob_footer .company_box.flex {
  justify-content: space-evenly;
  padding: 40px 0 40px 0;
  border-bottom: solid 1px #BBBBBB;
}

footer#footer #glob_footer .glob3 {
  padding: 45px 0 45px 0;
}

footer#footer #glob_footer .glob3 ul {
  margin: 0;
  padding: 0;
}

footer#footer #glob_footer .glob3 ul li {
  display: inline-block;
  padding: 0 20px 0 20px;
  border-right: solid 1px #333;
  font-size: 18px;
}

footer#footer #glob_footer .glob3 ul li:last-child {
  border: none;
}

footer#footer dl.information dt {
  margin: 0;
  width: 190px;
  border-right: solid 1px #FFF;
  font-size: 18px;
}

footer#footer .glob_menu dl.information dd {
  margin: 0;
  padding: 0 0 0 50px;
}

footer#footer .glob_menu dl.information ul {
  margin: 0;
  padding: 0;
}

footer#footer .glob_menu dl.information ul li {
  display: inline-block;
  margin: 7px 30px 7px 0;
  font-size: 18px;
}

footer#footer .glob_menu dl.information ul li i {
  font-size: 20px;
  margin-right: 10px;
}

.ptop {
  cursor: pointer;
  position: fixed;
  z-index: 100;
  bottom: 22%;
  right: 2%;
  text-align: center;
  color: #FFF;
  background-color: #16a6a7;
  border-radius: 50%;
  width: 90px;
  height: 90px;
  line-height: 100px;
}

.ptop i {
  font-size: 40px;
}

@media (min-width: 1368px) and (max-width: 1669px) {
  header#header .middle_inner {
    max-width: none;
    width: calc(94% - 180px);
  }
  header#header #menu_btn {
    width: 180px;
  }
  header#header #header_logo {
    width: 380px;
    font-size: 15px;
  }
  header#header .glob1 {
    width: 700px;
  }
  .zdo_drawer_bg .inner ul.information li {
    width: 31.5%;
  }
  .zdo_drawer_bg .inner ul.information.flex::after {
    width: 31.5%;
  }
  section#top_service a.service_link .link_title {
    width: 500px;
    font-size: 30px;
  }
  footer#footer .glob_menu ul.glob2 li {
    font-size: 18px;
  }
  section#about_detail .box p.title {
    font-size: 24px;
  }
}
@media (min-width: 1080px) and (max-width: 1367px) {
  header#header .middle_inner {
    max-width: none;
    width: calc(96% - 160px);
  }
  header#header #menu_btn {
    width: 160px;
    margin-left: 3.125vw;
  }
  header#header #header_logo {
    width: 300px;
    font-size: 13px;
  }
  header#header .glob1 {
    width: 550px;
    font-size: 13px;
  }
  .zdo_drawer_bg .inner ul.first li a {
    font-size: 16px;
  }
  .zdo_drawer_bg .inner ul.information li {
    width: 31.5%;
  }
  .zdo_drawer_bg .inner ul.information li a {
    font-size: 16px;
  }
  .zdo_drawer_bg .inner ul.information.flex::after {
    width: 31.5%;
  }
  .zdo_drawer_bg .inner {
    padding: 54px min(5.2083333333vw, 160px) 54px min(5.2083333333vw, 160px);
  }
  section#top_service a.service_link .link_title {
    width: 410px;
    font-size: 25px;
  }
  section#about_detail .box p.title {
    font-size: 22px;
  }
  footer#footer .glob_menu ul.glob2 li {
    font-size: 16px;
    padding: 0 10px 0 10px;
  }
  .ptop {
    width: 80px;
    height: 80px;
    line-height: 90px;
  }
  .ptop i {
    font-size: 36px;
  }
}
@media (min-width: 1080px) and (max-width: 1259px) {
  section#about_detail .box p.title {
    font-size: 18px;
  }
}
/*202405　改修*/
em.accent {
  background: linear-gradient(transparent 70%, #FFEB1F 70%, #FFEB1F 100%);
  font-weight: 700;
}

a.my_page {
  display: block;
  position: relative;
  background-color: #16a6a7;
  color: #FFF;
  font-weight: bold;
  padding: 6px 20px;
  width: 240px;
  border-radius: 3px;
}

section.terms_detail dl.box dd a.my_page {
  text-decoration: none;
}

a.my_page i.fa-circle-user {
  font-size: 20px;
  margin-right: 4px;
  vertical-align: middle;
}

a.my_page i.fa-angle-right {
  font-size: 20px;
  position: absolute;
  top: 9px;
  right: 10px;
}

div.call {
  border: solid 3px #EC6D8D;
  margin: 25px 0;
  padding: 5px 4% 12.5px 4%;
}

div.call .call_ttl {
  font-size: 24px;
  font-weight: 700;
  margin: 5px auto;
}

div.call .call_ttl em {
  background: linear-gradient(transparent 75%, #FFEB1F 75%, #FFEB1F 100%);
}

div.call .flex {
  width: 96%;
  max-width: 580px;
  margin: 0 auto;
  align-items: center;
}

div.call a.tel i.fa-headset {
  font-size: 40px;
  margin-right: 8px;
  color: #EB6C8C;
}

div.call a.tel {
  font-size: 30px;
  font-weight: 700;
}

section.terms_detail dl.box dd a.tel {
  text-decoration: none;
}

section.terms_detail .item_list .b_hour {
  list-style: disc;
}

section.terms_detail .item_list .b_hour li {
  margin-bottom: 0.5em;
}

section.terms_detail .card,
section.terms_detail .combini {
  margin: 0 15px 0 0;
}

section.terms_detail .card img,
section.info_detail .combini img {
  display: block;
  margin: 0 auto;
}

section.terms_detail .card figcaption,
section.info_detail .combini figcaption {
  text-align: center;
}

section.terms_detail .card .visa {
  width: 100px;
  margin: 9px auto;
}

section.terms_detail .card .mc {
  width: 56px;
  margin: 8px auto;
}

section.terms_detail .card .jcb {
  width: 60px;
  margin: 3px auto;
}

section.terms_detail .card .amex {
  width: 50px;
  margin: 0.5px auto;
}

section.terms_detail .card .dc {
  width: 70px;
}

section.terms_detail .combini .lawson {
  width: 140px;
}

section.terms_detail .combini .minist {
  width: 60px;
}

section.terms_detail .combini .famima {
  width: 150px;
}

section.terms_detail .combini .d_yamazaki {
  width: 100px;
}

section.terms_detail .combini .secoma {
  width: 150px;
}

section.terms_detail .combini .seven {
  width: 42px;
}

section.terms_detail .consent_form {
  margin: 40px 0;
  padding: 30px 0 50px 0;
  background-color: #FDF4F7;
}

section.terms_detail .consent_img {
  width: 94%;
  max-width: 600px;
}

section.terms_detail .form_dl {
  color: #FFF;
  background-color: #16a6a7;
  width: 90%;
  max-width: calc(480px - 4%);
  margin-top: 30px;
  padding: 5px 2%;
  text-align: center;
  font-sze: 20px;
}

section.terms_detail .form_dl i {
  font-size: 24px;
  margin-right: 4px;
}

section.terms_detail dl.box dd a.form_dl {
  text-decoration: none;
}

section.terms_detail dl.box hr {
  margin: 30px 0;
}

section.terms_detail dt span.small {
  font-size: 20px;
}

section.terms_detail .next {
  margin: 0 auto;
  line-height: 0.7;
}

section.terms_detail .next .tri {
  display: inline-block;
  font-size: 100px;
  color: #E67A8A;
  transform: scale(1, 0.5);
}

section.terms_detail a.link {
  color: #289DD6;
  font-weight: 700;
}

/*faq*/
.item_box {
  margin-left: 0;
}

.faq_item,
section.terms_detail dl.faq_item {
  margin-top: 35px;
}

.faq_item dt,
.faq_item dd,
section.terms_detail dl.faq_item dt,
section.terms_detail dl.faq_item dd {
  border: solid 2px #EB919E;
  position: relative;
}

.faq_item dt,
section.terms_detail dl.faq_item dt {
  font-size: 20px;
  font-weight: 700;
  padding: 8px 60px 8px 55px;
}

.faq_item dt:hover,
section.terms_detail dl.faq_item dt:hover {
  cursor: pointer;
  caret-color: transparent;
}

.faq_item dd,
section.terms_detail dl.faq_item dd {
  border-top: none;
  margin-left: 0;
  padding: 25px 20px 30px 55px;
}

.faq_item dt .fa-circle-q,
.faq_item dd .fa-circle-a,
section.terms_detail dl.faq_item dt .fa-circle-a,
section.terms_detail dl.faq_item dd .fa-circle-a {
  font-size: 26px;
  position: absolute;
  left: 20px;
}

.faq_item dt .fa-circle-q,
section.terms_detail dl.faq_item .fa-circle-q {
  color: #00B2F0;
  top: 12px;
}

.faq_item dd .fa-circle-a,
section.terms_detail dl.faq_item dd .fa-circle-a {
  color: #EB6C8C;
}

.faq_item dt .fa-circle-chevron-down,
.section.terms_detail dl.faq_item dt .fa-circle-chevron-down {
  font-size: 32px;
  color: #E06373;
  position: absolute;
  top: 24px;
  right: 20px;
  transform: translateY(-50%);
  transition: all 0.5s;
}

.faq_item dt.active .fa-circle-chevron-down,
.section.terms_detail dl.faq_item dt.active .fa-circle-chevron-down {
  transform: translateY(-50%) rotate(180deg);
}

section.terms_detail dl.box dt.item_ttl {
  margin-top: 1.75em;
}

/* faq_navi */
.faq_navi {
  border: solid 3px #EC6D8D;
  padding: 40px 0 20px 0;
  margin-bottom: 4em;
}

.faq_navi .faq_btn {
  display: block;
  box-sizing: border-box;
  width: 48%;
  max-width: 480px;
  position: relative;
  margin-bottom: 20px;
  padding: 7px 27px 7px 15px;
  background-color: #16a6a7;
  color: #FFF;
  font-size: 18px;
}

.faq_navi .faq_btn:nth-of-type(2n+1) {
  clear: both;
}

.faq_navi .faq_btn .fa-circle-q {
  font-size: 24px;
  margin-right: 7px;
  vertical-align: middle;
}

.faq_navi .faq_btn .fa-angle-right {
  position: absolute;
  top: 12px;
  right: 10px;
  font-size: 20px;
}

/* top_bnr */
#top_bnr {
  padding-block: 0 4em;
}

#top_bnr .lower_inner {
  inline-size: min(1000px, 70%);
}

#top_bnr .bnr_box .bnr_txt {
  font-size: 0.89em;
  color: #1d1d1f;
  text-decoration: underline;
  margin-top: 0.45em;
}

#top_bnr .bnr_box {
  margin-bottom: 2em;
}

#top_bnr .bnr_img img {
  width: 100%;
  max-width: 100%;
}

@media screen and (max-width: 1079px) {
  /* CSS Document */
  .pc {
    display: none;
  }
  .sp {
    display: unset;
  }
  .sp_left {
    text-align: left;
  }
  header#header {
    height: 90px;
  }
  header#header .middle_inner {
    width: 68%;
    float: left;
    margin-left: 10px;
  }
  header#header #header_logo {
    width: 100%;
  }
  header#header #header_logo p {
    margin: 9px 0 9px 0;
    font-size: 9px;
  }
  header#header #header_logo img {
    width: 160px;
  }
  header#header .glob1 {
    display: none;
  }
  header#header #menu_btn {
    width: 100px;
    height: 90px;
    padding: 15px;
    margin-left: 0;
  }
  header#header #menu_btn i {
    font-size: 36px;
  }
  header#header #menu_btn span {
    margin-top: 5px;
  }
  header.page_global .middle_inner .slug.lines3 {
    padding: 1.25em 0 0 0;
    letter-spacing: -0.04em;
  }
  .zdo_drawer_bg .inner {
    margin: 92px auto 24px auto;
    padding: 20px 15px 20px 15px;
  }
  .zdo_drawer_bg .inner ul.first li {
    width: 100%;
    margin: 0 0 10px 0;
  }
  .zdo_drawer_bg .inner ul.first li.mypage {
    width: 100%;
  }
  .zdo_drawer_bg .inner ul.first li a {
    font-size: 14px;
    padding: 10px;
  }
  .zdo_drawer_bg .inner ul.first li a i {
    font-size: 16px;
    top: 13px;
    right: 8px;
  }
  .zdo_drawer_bg .inner ul.first li a.prepared::after {
    left: 100px;
  }
  .zdo_drawer_bg .inner ul.resort {
    padding: 12px;
    font-size: 12px;
  }
  .zdo_drawer_bg .inner ul.information li {
    width: 100%;
  }
  .zdo_drawer_bg .inner ul.information li.sp_half {
    width: 48.5%;
  }
  .zdo_drawer_bg .inner ul.information li a {
    font-size: 13px;
    padding: 12px;
  }
  .zdo_drawer_bg .inner ul.information li a i {
    font-size: 16px;
    top: 13px;
    right: 8px;
  }
  .zdo_drawer_bg .inner .logo {
    margin-top: 25px;
  }
  .zdo_drawer_bg .inner .glob3 ul {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: stretch;
  }
  .zdo_drawer_bg .inner .glob3 ul li {
    width: 48.5%;
    border-right: none;
    border-bottom: solid 1px #333 !important;
    padding: 0;
  }
  .zdo_drawer_bg .inner .glob3 ul li a {
    position: relative;
    display: block;
    text-align: left;
    font-size: 12px;
    padding: 12px 5px 12px 5px;
  }
  .zdo_drawer_bg .inner .glob3 ul li i {
    position: absolute;
    color: #E16374;
    font-size: 16px;
    top: 13px;
    right: 5px;
  }
  .zdo_drawer_bg .inner .logo a img {
    width: 60%;
    max-width: 239px;
  }
  main {
    padding-top: 90px;
  }
  main.page {
    padding-bottom: 90px;
  }
  section#fv {
    position: relative;
    height: min(88.5416666667vw, 680px);
  }
  section#fv #fv_slider1 {
    background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/sp_1.webp);
    background-size: 100%;
    width: 100%;
    height: min(88.5416666667vw, 680px);
  }
  section#fv #fv_slider2 {
    background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/sp_2.webp);
    background-size: 100%;
    width: 100%;
    height: min(88.5416666667vw, 680px);
  }
  section#fv #fv_slider3 {
    background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/sp_3.webp);
    background-size: 100%;
    width: 100%;
    height: min(88.5416666667vw, 680px);
  }
  section#fv #fv_slider4 {
    background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/sp_4.webp);
    background-size: 100%;
    width: 100%;
    height: min(88.5416666667vw, 680px);
  }
  section#fv #fv_slider5 {
    background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/sp_5.webp);
    background-size: 100%;
    width: 100%;
    height: min(88.5416666667vw, 680px);
  }
  section#fv #fv_slider6 {
    background-image: linear-gradient(rgba(0, 20, 40, 0.3), rgba(0, 20, 40, 0.3)), url(../img/kamikochi/top/fv_slider/sp_6.webp);
    background-size: 100%;
    width: 100%;
    height: min(88.5416666667vw, 680px);
  }
  section#fv .circle {
    width: min(29.6296296296vw, 320px);
    height: min(29.6296296296vw, 320px);
  }
  section#fv .circle img.sum {
    width: min(15.6481481481vw, 169px);
    margin: min(7.4074074074vw, 80px) auto auto auto;
  }
  section#fv::after {
    height: 82px;
    bottom: -41px;
  }
  section#top_service {
    margin: 80px 0 60px 0;
    padding: 25px 0 0 0;
    width: 100%;
  }
  section#top_service .middle_inner {
    width: 100%;
  }
  section#top_service .catch {
    font-size: 20px;
  }
  section#top_service .description {
    font-size: 14px;
    margin: 18px auto 80px auto;
    text-align: left;
  }
  section#top_service a.service_link {
    width: 100%;
    height: min(57.5vw, 460px);
    margin: 0 0 50px 0;
  }
  section#top_service a.service_link.service_lower {
    margin-top: 0;
  }
  section#top_service a.service_link .link_title {
    width: 300px;
    padding: 5px 10px 5px 10px;
    font-size: 18px;
  }
  section#top_service a.service_link .link_title img.arrow {
    width: 20px;
  }
  .swiper-button-next,
  .swiper-rtl .swiper-button-prev {
    right: 0;
    left: auto;
  }
  .swiper-button-prev,
  .swiper-rtl .swiper-button-next {
    left: 0;
    right: auto;
  }
  section#top_company {
    background-image: url(../img/top/top_company_bg_sp.jpg);
    padding: 120px 0 20px 0;
  }
  section#top_company .middle_inner.flex {
    width: 100%;
    display: block;
  }
  section#top_company .box {
    width: 100%;
    margin: 0 0 50px 0;
  }
  section#top_company .box span.icon {
    top: -40px;
    width: 80px;
    height: 80px;
  }
  section#top_company .box span.icon i {
    font-size: 34px;
    line-height: 80px;
  }
  section#top_company .box dt {
    padding: 60px 0 0 0;
  }
  section#top_company .box dt a {
    font-size: 22px;
  }
  section#top_company .box dd {
    padding: 10px 20px 60px 20px;
  }
  section#top_company .box dd p {
    min-height: 80px;
  }
  header.page_global {
    height: 160px;
    background-position: center;
  }
  header.page_global .middle_inner .slug {
    top: 25px;
    font-size: 18px;
    width: 120px;
    height: 120px;
    padding: 42px 0 0 0;
  }
  header.page_global .middle_inner .slug.lines {
    padding: 29px 0 0 0;
  }
  aside.pan {
    padding: 20px 0 20px 0;
  }
  section.page_content {
    padding: 10px 0 10px 0;
  }
  .subttl {
    font-size: 24px;
    margin: 15px auto 30px auto;
  }
  .subttl::before {
    top: -15px;
    width: 60px;
  }
  .subttl2 {
    font-size: 20px;
    margin: 15px auto 30px auto;
  }
  .subttl2 span::before {
    top: 17px;
    left: -42px;
    width: 25px;
  }
  .subttl2 span::after {
    top: 17px;
    right: -42px;
    width: 25px;
  }
  section#company_detail dl.box {
    display: block;
  }
  section#company_detail dl.box dt {
    display: block;
    border: none;
    width: 100%;
  }
  section#company_detail dl.box dd {
    display: block;
    width: 100%;
  }
  section#access {
    padding: 60px 0 10px 0;
  }
  section#access .map_wrapper {
    padding: 10px;
  }
  section#access #gmap {
    height: 300px;
  }
  section#about_detail p.summary {
    font-size: 14px;
  }
  section#about_detail .flex {
    display: block;
  }
  section#about_detail .one_two .box,
  section#about_detail .three_four_five .box {
    width: 100%;
  }
  section#about_detail .box p.title {
    font-size: 20px;
  }
  section#about_detail .three_four_five {
    padding: 40px 0 0 0;
  }
  section#about_detail .inner {
    padding: 40px 0 10px 0;
  }
  section.terms_detail dl.box dt {
    font-size: 20px;
  }
  section.travel_detail table.calcel_table th {
    padding: 5px;
  }
  /* conditions */
  .terms_navi {
    margin-bottom: 60px;
  }
  .terms_content {
    padding: 20px 0 10px 0;
    margin-bottom: 40px;
  }
  .terms_content .terms_btn {
    width: 96%;
    max-width: 96%;
    margin: 0 auto 15px auto;
    padding: 7px 15px 7px 5px;
    font-size: 14px;
    float: none;
  }
  .terms_content .terms_btn .fa-circle-q {
    font-size: 18px;
    margin-right: 3px;
  }
  .terms_content .terms_btn .fa-angle-right {
    top: 12px;
    right: 5px;
    font-size: 16px;
  }
  .terms_article .chapter {
    margin-top: 40px;
  }
  .terms_article .clause .i_block li {
    margin: 0 0.5em 0 0;
  }
  .terms_article .s_table {
    margin-top: 25px;
  }
  .terms_article .s_table dd {
    margin-bottom: 20px;
  }
  .terms_article .complaint dd {
    padding: 5px 4% 10px 4%;
  }
  section.travel_detail .complaint {
    margin-top: 30px;
  }
  section.travel_detail ol .price {
    padding-left: 0;
  }
  section.travel_detail ol .price::before {
    content: "\a";
    white-space: pre;
  }
  section.travel_detail p.separate {
    margin-bottom: 30px;
  }
  footer#footer .glob_menu {
    padding: 50px 0 40px 0;
  }
  footer#footer .glob_menu ul.glob2 {
    flex-direction: column;
    padding: 0;
    margin: 0 auto;
  }
  footer#footer .glob_menu ul.glob2 li {
    display: block;
    font-size: 18px;
    padding: 0 20px 20px 20px;
    border-right: none;
  }
  footer#footer .glob_menu ul.glob2 li a.prepared {
    display: inline-block;
    margin: 0 0 20px 0;
  }
  footer#footer .glob_menu dl.information {
    display: block;
  }
  footer#footer .glob_menu dl.information dt {
    display: block;
    width: 100%;
    border: none;
    border-bottom: solid 1px #FFF;
    padding: 0 0 5px 0;
  }
  footer#footer .glob_menu dl.information dd {
    display: block;
    margin: 0;
    padding: 16px;
  }
  footer#footer .glob_menu dl.information ul li {
    font-size: 1em;
  }
  footer#footer #glob_footer .company_box.flex {
    display: block;
    text-align: center;
  }
  footer#footer #glob_footer .company_box.flex address {
    margin: 0 0 32px 0;
  }
  footer#footer #glob_footer .glob3 ul li {
    padding: 0 12px 0 12px;
    margin-bottom: 12px;
    font-size: 12px;
    line-height: 12px;
  }
  footer#footer .copy {
    font-size: 12px;
  }
  .ptop {
    width: 60px;
    height: 60px;
    line-height: 60px;
  }
  .ptop i {
    font-size: 24px;
  }
}
@media screen and (max-width: 1079px) and (min-width: 768px) and (max-width: 1079px) {
  section#about_detail .one_two .box,
  section#about_detail .three_four_five .box {
    margin-left: auto;
    margin-right: auto;
    width: 70%;
  }
}
@media screen and (max-width: 1079px) {
  /*202405　改修*/
  .sub_heading2 {
    font-size: 16px;
    margin-bottom: 0;
    margin-left: 1.5em;
    text-indent: -0.75em;
  }
  .strapline {
    font-size: 14px;
  }
  span.caution {
    margin-top: 5px;
    margin-bottom: 5px;
  }
  section.terms_detail .item_list {
    padding-left: 1.5em;
  }
  div.call {
    margin: 15px 0;
    padding: 3.5px 4% 7px 4%;
  }
  div.call .call_ttl {
    font-size: 17px;
    margin: 5px auto;
  }
  div.call .flex {
    flex-direction: column;
  }
  div.call a.tel i.fa-headset {
    font-size: 24px;
    margin-right: 6px;
  }
  div.call a.tel {
    font-size: 20px;
    margin-bottom: 0.5em;
  }
  section.terms_detail .info_item .b_hour {
    margin-top: 0;
    padding-left: 0;
  }
  section.terms_detail .consent_form {
    margin: 30px 0;
    padding: 30px 0;
  }
  section.terms_detail .form_dl {
    margin-top: 20px;
    font-sze: 16px;
  }
  section.terms_detail .form_dl i {
    font-size: 17px;
  }
  section.terms_detail dl.info_item hr {
    margin: 15px 0;
  }
  section.terms_detail dt span.small {
    font-size: 14px;
  }
  section.terms_detail .next .tri {
    font-size: 60px;
  }
  /*faq*/
  .faq_item,
  section.terms_detail dl.faq_item {
    margin-top: 15px;
  }
  .faq_item dt,
  section.terms_detail dl.faq_item dt {
    font-size: 15px;
    padding: 5px 30px 5px 35px;
  }
  .faq_item dd,
  section.terms_detail dl.faq_item dd {
    border-top: none;
    margin-left: 0;
    padding: 10px 10px 15px 35px;
  }
  .faq_item dt .fa-circle-q,
  .faq_item dd .fa-circle-a,
  section.terms_detail dl.faq_item dt .fa-circle-a,
  section.terms_detail dl.faq_item dd .fa-circle-a {
    font-size: 18px;
    position: absolute;
    left: 10px;
  }
  .faq_item dt .fa-circle-q,
  section.terms_detail dl.faq_item .fa-circle-q {
    top: 10px;
  }
  .faq_item dd .fa-circle-a,
  section.terms_detail dl.faq_item dd .fa-circle-a {
    top: 15px;
  }
  .faq_item dt .fa-circle-chevron-down,
  .section.terms_detail dl.faq_item dt.active .fa-circle-chevron-down {
    font-size: 20px;
    color: #E06373;
    position: absolute;
    top: 18px;
    right: 10px;
  }
  /* faq_navi */
  .faq_navi {
    padding: 20px 0 10px 0;
    margin-bottom: 40px;
  }
  .faq_navi .faq_btn {
    width: 96%;
    max-width: 96%;
    margin: 0 auto 15px auto;
    padding: 7px 15px 7px 5px;
    font-size: 14px;
    float: none;
  }
  .faq_navi .faq_btn .fa-circle-q {
    font-size: 18px;
    margin-right: 3px;
  }
  .faq_navi .faq_btn .fa-angle-right {
    top: 12px;
    right: 5px;
    font-size: 16px;
  }
  /* top_bnr */
  #top_bnr {
    padding-block: 0 2em;
  }
  #top_bnr .lower_inner {
    inline-size: min(1000px, 90%);
  }
}
/* color */
/* function（関数） */
/* 段落 */
/* mixin */
.p-crs-point {
  width: 90%;
  max-width: 1090px;
  min-width: 320px;
  margin: 0 auto;
  padding: 5rem 0;
}
.p-crs-point small {
  display: block;
}
.p-crs-point_tit2 span {
  display: block;
  font-size: 70%;
}
.p-crs-point_tit3 {
  position: relative;
  width: fit-content;
  margin-bottom: 0;
  padding: 0 1em;
  background-color: #16a6a7;
  color: #ffffff;
}
.p-crs-point_tit3::after {
  content: "";
  margin-left: -10px;
  position: absolute;
  bottom: -12px;
  left: 2em;
  border-top: 12px solid #16a6a7;
  border-right: 12px solid transparent;
  border-left: 12px solid transparent;
}
.p-crs-point_list {
  padding-left: 1.5em;
}
.p-crs-point_txt strong {
  color: #e06a1b;
}

.p-crs-sche {
  padding: 5rem 0;
  background-color: #f5f5f5;
}
.p-crs-sche a {
  text-decoration: underline;
  color: #16a6a7;
}
.p-crs-sche a:hover {
  text-decoration: none;
}
.p-crs-sche_inner {
  width: 90%;
  max-width: 1090px;
  min-width: 320px;
  margin: 0 auto;
}
.p-crs-sche_tit2 span {
  display: block;
  font-size: 70%;
}
.p-crs-sche_table {
  border-collapse: collapse;
}
.p-crs-sche_tdata {
  padding-top: 0.5em;
  padding-right: clamp(0.5em, 2vw, 2em);
  padding-bottom: 0.5em;
  padding-left: clamp(0.5em, 2vw, 2em);
}
.p-crs-sche_tdata:first-of-type {
  padding-left: 0;
  white-space: nowrap;
  writing-mode: vertical-rl;
  text-orientation: upright;
  text-align: center;
  border-right: 1px solid #d3d3d3;
}
.p-crs-sche_tdata._day2 {
  border-top: 1px solid #d3d3d3;
}
.p-crs-sche_list {
  display: grid;
  gap: 0.5em;
  margin: 0;
  padding: 0;
}
.p-crs-sche_item {
  list-style: none;
}
.p-crs-sche_item._spot {
  margin: 1em 0;
  padding: 0.5em;
  background-color: #ffffff;
  border: 1px solid #16a6a7;
  color: #16a6a7;
}
.p-crs-sche_item small {
  color: #333333;
}
.p-crs-sche_item strong {
  color: #16a6a7;
}

.p-crs-price {
  width: 90%;
  max-width: 1090px;
  min-width: 320px;
  margin: 0 auto;
  padding: 5rem 0;
}
.p-crs-price_wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1.5rem 5rem;
}
@media screen and (min-width: 768px) {
  .p-crs-price_wrap {
    flex-direction: row;
  }
}
.p-crs-price_tit3 {
  text-align: center;
  color: #16a6a7;
}
.p-crs-price_txt {
  width: fit-content;
  margin-top: 0;
  margin-right: auto;
  margin-left: auto;
  text-align: right;
  font-size: clamp(16px, 2vw, 24px);
}
.p-crs-price_txt span {
  margin-left: 1em;
  font-size: 150%;
  font-weight: bold;
  color: #e06a1b;
}
.p-crs-price_btn {
  width: fit-content;
  margin: 1.5rem auto 0;
  font-size: clamp(16px, 14.07px + 0.49vw, 20px);
}
.p-crs-price_note {
  margin-top: 1.5rem;
}
.p-crs-price_item {
  list-style-type: "※";
  padding-left: 0.5em;
}

.p-crs-link_list {
  max-width: 500px;
  margin-top: 3.75rem;
  margin-right: auto;
  margin-left: auto;
  padding-left: 0;
  display: grid;
  gap: 1.5rem;
}
.p-crs-link_item {
  text-align: center;
  list-style: none;
  border: 2px solid #16a6a7;
  background-color: #efffff;
}
.p-crs-link_item a {
  display: block;
  padding: 0.5em;
  color: #16a6a7;
}

.p-crs-note {
  padding: 5rem 0;
  background-color: #f5f5f5;
}
.p-crs-note_inner {
  width: 90%;
  max-width: 1090px;
  min-width: 320px;
  margin: 0 auto;
}

.p-faq-list {
  padding: 5rem 0;
}
.p-faq-list_inner {
  width: 90%;
  max-width: 1090px;
  min-width: 320px;
  margin: 0 auto;
}
.p-faq-list_details {
  transition: all ease-in-out 0.3s;
}
.p-faq-list_details summary {
  display: grid;
  grid-template-columns: 1em 1fr 24px;
  gap: 6px;
  padding: 0.5em 0;
  font-weight: bold;
  cursor: pointer;
  list-style-type: none;
}
.p-faq-list_details summary::before {
  content: "Q.";
}
.p-faq-list_details span {
  display: block;
  align-self: center;
  position: relative;
  width: 24px;
  transform-origin: center 43%;
  transition: transform 0.4s;
}
.p-faq-list_details span::before, .p-faq-list_details span::after {
  content: "";
  position: absolute;
  display: block;
  width: 15px;
  height: 2px;
  background-color: #16a6a7;
}
.p-faq-list_details span::before {
  left: 0;
  transform: rotate(45deg);
}
.p-faq-list_details span::after {
  right: 0;
  transform: rotate(-45deg);
}
.p-faq-list_details {
  /* アコーディオンが開いた時のスタイル */
}
.p-faq-list_details[open] span {
  transform: rotate(180deg);
}
.p-faq-list_details[open] p {
  animation: fadeIn 0.3s ease;
}
@keyframes fadeIn {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    transform: none;
  }
}
.p-faq-list_txt {
  margin-left: calc(1em + 6px);
  text-indent: calc(-1em - 6px);
}
.p-faq-list_txt::before {
  content: "A.";
  margin-right: 6px;
}

.p-top-fv {
  font-family: "Shippori Mincho", serif;
  color: #ffffff;
}
.p-top-fv_tit1 {
  position: absolute;
  z-index: 10;
  text-align: center;
  top: 35%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  font-size: clamp(40px, 5.45vw + 19.5px, 80px);
  text-shadow: 0 4px 10px rgba(0, 0, 0, 0.5);
}
.p-top-fv_tit1 span {
  display: block;
  width: fit-content;
  margin: 0 auto;
  padding: 0 1em;
  font-size: clamp(16px, 1.94vw + 8.7px, 32px);
  border-bottom: 2px solid #ffffff;
  backdrop-filter: blur(4px);
}
.p-top-fv_tit1 strong {
  display: block;
  width: fit-content;
  margin: 1em auto 0;
  padding: 0.2em 0.5em;
  background-color: #e06a1b;
  border-radius: 0 15px;
  font-size: clamp(20px, 10.37px + 2.47vw, 40px);
  font-weight: normal;
  font-family: initial;
  text-shadow: none;
}
.p-top-fv_lead {
  position: absolute;
  top: 2%;
  width: 100%;
  background-color: rgba(22, 166, 167, 0.8);
  z-index: 10;
  text-align: center;
  white-space: nowrap;
  font-size: clamp(16px, 1.94vw + 8.7px, 32px);
}

.p-top-about {
  background-color: #f5f5f5;
  font-family: "Shippori Mincho", serif;
}
.p-top-about_inner {
  width: 90%;
  max-width: 1090px;
  min-width: 320px;
  margin: 0 auto;
  display: grid;
  gap: 1.5rem 3.75rem;
  padding: 5rem 0;
}
@media screen and (min-width: 768px) {
  .p-top-about_inner {
    grid-template-columns: 1fr 1fr;
  }
}
.p-top-about_tit2 {
  margin-top: 0;
  grid-column: 1/-1;
}
.p-top-about_pic {
  grid-row: 2;
}
.p-top-about_pic img {
  aspect-ratio: 3/2;
  object-fit: cover;
}
.p-top-about_txt {
  margin: 0;
}

.p-top-crs_inner {
  width: 90%;
  max-width: 1090px;
  min-width: 320px;
  margin: 0 auto;
  padding: 5rem 0;
}
.p-top-crs_tit2 {
  margin-top: 0;
}
.p-top-crs_cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: clamp(16px, 4vw, 32px);
}
.p-top-crs_card {
  position: relative;
  background-color: #efffff;
  border: 2px solid #16a6a7;
  border-radius: 10px;
  text-align: center;
}
.p-top-crs_label {
  position: absolute;
  padding: 0.1em 1em;
  background-color: #16a6a7;
  color: #ffffff;
  border-radius: 0 15px;
}
.p-top-crs_pic {
  height: 200px;
}
.p-top-crs_pic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px 8px 0 0;
}
.p-top-crs_txtarea {
  padding: 0 0.5em 1.5em;
}
.p-top-crs_tit3 {
  font-size: 20px;
  font-weight: bold;
}
.p-top-crs strong {
  font-weight: bold;
}
.p-top-crs_time {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1em;
  line-height: 1.2;
}
.p-top-crs_time > * {
  margin: 0;
}
.p-top-crs_term {
  padding: 0.3em 0.5em;
  background-color: #e06a1b;
  border-radius: 10px;
  color: #ffffff;
  white-space: nowrap;
  font-size: 16px;
}
.p-top-crs_term strong {
  font-size: 24px;
}
.p-top-crs_price {
  color: #e06a1b;
}
.p-top-crs_price strong {
  font-size: 24px;
  font-weight: bold;
}
.p-top-crs_btn {
  display: block;
  margin: 0 auto;
}

.c-btn {
  display: inline-block;
  width: fit-content;
  padding: 0.7em 2.5em;
  border-radius: 50px;
  text-align: center;
}
.c-btn._primary {
  background-color: #16a6a7;
  color: #ffffff;
}

.c-heading._primary {
  margin-bottom: 3.75rem;
  text-align: center;
  font-size: clamp(24px, 20.15px + 0.99vw, 32px);
}
.c-heading._primary::after {
  content: "";
  display: block;
  width: 40px;
  height: 2px;
  margin-top: 10px;
  margin-right: auto;
  margin-left: auto;
  background-color: #16a6a7;
}