#web_service .pane-topic-path {
  background-color: #fff;
}
.web_service {
  font-weight: 700;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #2f0721;
  /* letter-spacing: 1px; */
  box-sizing: border-box;
}
.web_service h2 {
  margin: 0;
}
.web_service * {
  font-weight: 700;
  box-sizing: border-box;
}
.web_service .btn_red,
.web_service .btn_white {
  text-align: center;
}
.web_service .btn_red a,
.web_service .btn_white a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 430px;
  height: 65px;
  margin: 0 auto;
  border: 2px solid #ab0047;
  border-radius: 50px;
  transition: .3s;
}
.web_service .btn_red a span,
.web_service .btn_white a span {
  display: inline-block;
  font-size: 20px;
}
.web_service .btn_red a:hover,
.web_service .btn_white a:hover {
  text-decoration: none;
  filter: brightness(1.2);
}
.web_service ul + .btn_red {
  margin-top: 60px;
}
.web_service .btn_red a {
  background-color: #ab0047;
}
.web_service .btn_red a span {
  padding: 0 50px;
  background-image: url(/cms/template/default/reserve/introduction/images/icon_arrow_btn01.png);
  background-repeat: no-repeat;
  background-size: 8px 12px;
  background-position: right center;
  color: #fff;
}
.web_service .btn_white a {
  background-color: #fff;
}
.web_service .btn_white a span {
  padding: 0 25px;
  background-image: url(/cms/template/default/reserve/introduction/images/icon_arrow_btn02.png);
  background-repeat: no-repeat;
  background-size: 8px 12px;
  background-position: right center;
  color: #ab0047;
  letter-spacing: 0;
}
.web_service .btn_red + .btn_white {
  margin-top: 26px;
}
#web_service_mv {
  padding: 48px 0 30px;
  background-image: url(/cms/template/default/reserve/introduction/images/bg_mv.jpg);
  background-position: center;
  background-repeat: repeat;
}
#web_service_mv .web_service_mv_ttl {
  margin: 0;
  padding: 0;
  line-height: 1.0;
}
#web_service_mv .web_service_mv_ttl img {
  display: block;
  margin: 0 auto;
}
#web_service_mv .img img {
  display: block;
  margin: 0 auto;
}
#web_service_mv .notes {
  padding-top: 25px;
  font-weight: 600;
  font-size: 13px;
  color: #2f0721;
  text-align: center;
}
#web_service_about {
  padding: 40px 0 50px;
  background-image: url(/cms/template/default/reserve/introduction/images/bg_about.jpg);
  background-position: center;
  text-align: center;
}
#web_service_about .inner {
  width: 621px;
  margin: 0 auto;
  padding: 40px 0 38px;
  background-color: #fff;
  border-radius: 5px;
}
#web_service_about h2 {
  display: inline-block;
  padding: 0 5px;
  font-size: 26px;
  background: linear-gradient(transparent 60%, rgba(210, 232, 229, 0.5) 60%);
}
#web_service_about p {
  padding-top: 20px;
  font-size: 17px;
  line-height: 2.0;
}
#web_service_about p img {
  display: block;
  margin: 25px auto 0;
}
#web_service_point {
  padding: 70px 0 80px;
  background-color: #f9e7e3;
  text-align: center;
}
#web_service_point h3 {
  display: inline-block;
  margin: 10px 0;
  padding: 0 5px;
  background: linear-gradient(transparent 60%, #ffffff 60%);
  font-size: 27px;
  line-height: 1.3;
}
#web_service_point ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 780px;
  margin: 40px auto 0;
}
#web_service_point li {
  width: 372px;
}
#web_service_point li p {
  margin-top: 5px;
  font-size: 15px;
  text-align: left;
  line-height: 1.8;
}
#web_service_point li img {
  display: block;
  width: 100%;
}
#web_service_point li h4 {
  display: inline-block;
  background: linear-gradient(transparent 83%, #ffffff 83%);
  margin-top: 20px;
  font-size: 21px;
  line-height: 1.1;
  letter-spacing: 0;
}
#web_service_point li:nth-child(n+3) {
  margin-top: 40px;
}
#web_service_howto {
  padding: 70px 0 120px;
  background-color: #fff;
  text-align: center;
}
#web_service_howto .container {
  width: 1125px;
  margin: 0 auto;
}
#web_service_howto .container .img {
  margin-top: 50px;
}
#web_service_howto .container .img img {
  display: block;
  margin: 0 auto;
}
#web_service_howto h2 {
  display: inline-block;
  padding: 0 5px;
  background: linear-gradient(transparent 60%, #f9f1db 60%);
  letter-spacing: 2px;
  font-size: 30px;
}
#web_service_howto h3 {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 20px;
  font-size: 27px;
}
#web_service_howto h3 em {
  display: inline-block;
  margin-left: 23px;
  border-bottom: 1px solid #2f0721;
  line-height: 1.45;
  letter-spacing: 4px;
}
#web_service_howto ul {
  margin-top: 40px;
}
#web_service_howto li {
  font-size: 20px;
}
#web_service_howto li a {
  display: inline-block;
}
#web_service_howto li a span {
  display: inline-block;
  min-height: 12px;
  padding-right: 10px;
  border-bottom: 1px solid #ab0047;
  background-image: url(/cms/template/default/reserve/introduction/images/icon_arrow_btn02.png);
  background-repeat: no-repeat;
  background-size: 8px 12px;
  background-position: right center;
  color: #ab0047;
  line-height: 1.3;
}
#web_service_howto li p {
  line-height: 1.9;
}
#web_service_howto li + li {
  margin-top: 70px;
}
#web_service_howto a + .notes_txt {
  margin-top: 15px;
}
#web_service_howto .notes_txt {
  display: block;
  font-size: 15px;
  line-height: 1.7;
}
#web_service_howto .notes_txt.mt {
  margin-top: 10px;
}
#web_service_qa {
  padding: 80px 0 120px;
  background-color: #f9e7e3;
}
#web_service_qa h2 {
  text-align: center;
}
#web_service_qa .web_service_qa {
  width: 923px;
  margin: 0 auto;
  padding-top: 20px;
}
#web_service_qa .web_service_qa dl {
  border-radius: 10px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
  overflow: hidden;
}
#web_service_qa .web_service_qa dl + dl {
  margin-top: 18px;
}
#web_service_qa .web_service_qa dt,
#web_service_qa .web_service_qa dd {
  display: flex;
  min-height: 78px;
  padding-bottom: 20px;
  font-size: 18px;
  line-height: 1.8;
}
#web_service_qa .web_service_qa dt .icon,
#web_service_qa .web_service_qa dd .icon {
  display: block;
  width: 80px;
}
#web_service_qa .web_service_qa dt .icon img,
#web_service_qa .web_service_qa dd .icon img {
  display: block;
  margin-left: auto;
}
#web_service_qa .web_service_qa dt > div,
#web_service_qa .web_service_qa dd > div {
  width: calc(100% - 80px);
  padding-left: 20px;
}
#web_service_qa .web_service_qa dt {
  position: relative;
  padding-top: 22px;
  padding-right: 60px;
  background-color: #fff;
  cursor: pointer;
}
#web_service_qa .web_service_qa dt:after {
  position: absolute;
  top: 30px;
  right: 30px;
  transform: rotate(180deg);
  width: 25px;
  height: 25px;
  background-image: url(/cms/template/default/reserve/introduction/images/icon_arrow.png);
  background-repeat: no-repeat;
  background-size: 25px 25px;
  content: '';
  pointer-events: none;
  transition: .15s;
  transform: rotate(0deg);
}
#web_service_qa .web_service_qa dt:hover {
  background-color: #fdfdfd;
}
#web_service_qa .web_service_qa dd {
  position: relative;
  padding-top: 22px;
  padding-right: 25px;
  background-color: #f6f6f6;
  color: #ab0146;
}
#web_service_qa .web_service_qa dl.active dt:after {
  transform: rotate(180deg);
}
#web_service_qa .web_service_qa .img img {
  display: block;
}
#web_service_qa .web_service_qa .img_qa01 {
  margin: 15px 0;
}
.sp_only,
.sp_s_only {
  display: none !important;
}
