@charset "UTF-8";

/* common
------------------------------------------------------------ */
article {
	padding-top: 0;
}
figure {
  margin: 0;
}
#maincontents {
  font-family: 'Noto sans JP', sans-serif;
  font-weight: 500;
}
.serif {
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
}
.go-taxi-main * {
  line-height: 1.7!important;
  box-sizing: border-box;
}
.go-taxi-main .sub h2 {
  margin-bottom: 2em;
  font-size: 2.1rem;
}
#toyako .sub h2 {
  color: #008b45;
  position: relative;
}
p {
  margin-bottom: 1.2rem;
}
#maincontents a {
  transition: opacity .5s;
}
#maincontents a:hover {
  opacity: .8;
}
figure {
  margin-bottom: 1em;
}
.bg-gray {
	background-color: #e6e6e6;
}
.bg-blue {
	background-color: #edf2f5;
}
/* mv
------------------------------------------------------------ */
#mv {
	height: auto;
}
/* scene
------------------------------------------------------------ */
#scene h2 {
	color: #071d57;
	text-align: center;
	font-weight: bold;
}
#scene h2 span {
	background: url("../images/ttl-left.svg") no-repeat left bottom, url("../images/ttl-right.svg") no-repeat right bottom;
	line-height: 1 !important;
	display: inline-block;
	padding: 0 2em;
}
.scene-wrap {
	display: flex;
	flex-wrap: wrap;
}
.scene-wrap .scene-box {
	text-align: center;
	font-weight: 500;
}
.scene-wrap .scene-box figcaption {
	margin-top: 1em;
}
/* step
------------------------------------------------------------ */
#step h2 {
	color: #071d57;
	font-weight: bold;
	text-align: center;
	line-height: 1;
	margin-bottom: 2em;
}
.step-wrap {
	position: relative;
}
.step-wrap:before,
.step-wrap:after {
	content: "";
	width: 0;
  height: 0;
	display: inline-block;
	position: absolute;
}
.step-in-wrap,
.step-box {
	border-radius: 15px;
}
.step-in-wrap {
	background: #fff;
	display: flex;
	align-items: center;
	position: relative;
	overflow: hidden;
}
.step-box {
	font-size: 20px;
}

.step-box p {
	width: 100%;
	text-align: center;
	margin-bottom: 0;
}
.step-in-wrap mark {
	background: #58a0c5;
	border-radius: 100%;
	position: absolute;
	display: inline-block;
}
.step-in-wrap mark span {
	color: #fff;
	font-weight: bold;
	display: inline-block;
}
.step-wrap .step-in-wrap .step-image {
	margin-bottom: 20px;
}
.step-wrap #step-image1 {
	width: 80px;
}
.step-wrap #step-image2 {
	width: 150px;
}
.step-wrap #step-image3 {
	width: 230px;
}
/* plan-content
------------------------------------------------------------ */
#area-Content {
	display: flex;
	flex-wrap: wrap;
}
#area-Content a {
	background: #071d57;
	display: block;
	position: relative;
}
#area-Content a p {
	margin-bottom: 0;
}
#area-Content a img {
	opacity: .7;
}
#area-Content a span {
	width: 100%;
	height: 100%;
	font-weight: bold;
	color: #fff;
	text-shadow: 3px 3px 10px #000;
	line-height: 1em !important;
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	justify-content: center;
	align-items: center;
}
#plan-content h2 {
	font-weight: bold;
	text-align: center;
	margin-bottom: .5em;
}
#plan-content h2 span {
  position: relative;
  padding: 0 1em;
  border-top: solid 2px black;
  border-bottom: solid 2px black;
	display: inline-block;
}
#plan-content h2 span:before, #plan-content h2 span:after {
  content: '';
  position: absolute;
  top: -7px;
  width: 2px;
  height: -webkit-calc(100% + 14px);
  height: calc(100% + 14px);
  background-color: black;
}
#plan-content h2 span:before {
  left: 7px;
}
#plan-content h2 span:after {
  right: 7px;
}
#plan-content .mainw > p {
	text-align: center;
	font-size: 20px;
	margin-bottom: 3.5em;
}
.plan-box {
	background: #e9eef1;
	border: 1px solid #589cc1;
	margin-bottom: 3em;
}
.bg-blue .plan-box {
	background: #fff;
}
.plan-box h3 {
	background: #589cc1;
	color: #fff;
	font-weight: bold !important;
	text-align: center;
	padding: .2em .5em;
}
.plan-box .plan-txt {
	padding: 25px 25px 15px;
	font-size: 1.25em;
}
.plan-box dl {
	margin-bottom: 1em;
}
.plan-box dt {
	font-weight: bold;
}
.plan-box dd {
	text-indent: -1em;
	margin-left: 1.01em;
}
.plan-box dd:before {
	content: "・";
}
.plan-list a, 
.plan-list a:hover {
  color: #fff !important;
  text-decoration: none;
}
.plan-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.plan-list .slide-items p {
	margin-bottom: 0;
}
.plan-list ul.btn-list li {
  margin-bottom: 1em;
}
.plan-list ul.btn-list li a {
  display: block;
  color: #fff;
  text-align: center;
  font-size: 1.1em;
  font-weight: 700;
  padding: .5em 1em;
  position: relative;
  text-decoration: none;
}
.plan-list ul.btn-list li:first-of-type a {
  background: #f7931e;
}
.plan-list ul.btn-list li:nth-of-type(2) a {
  background: #006837;
}
.plan-list ul.btn-list li:nth-of-type(3) a {
  background: #0071bc;
}
.plan-list ul.btn-list li a::after {
  content: '';
  display: inline-block;
  width: .7em;
  height: .7em;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  rotate: -45deg;
  position: absolute;
  top: 50%;
  translate: 0 -50%;
  right: 2em;
}
.plan-list ul.btn-list li a::before {
  content: '';
  width: 2em;
  height: 2em;
  position: absolute;
  top: 50%;
  translate: 0 -50%;
  left: 10px;
  background-size: contain;
  background-repeat: no-repeat;
}
.plan-list ul.btn-list li:first-of-type a::before {
  background-image: url(../images/icon-hotel.png);
}
.plan-list ul.btn-list li:nth-of-type(2) a::before {
  background-image: url(../images/icon-train.png);
}
.plan-list ul.btn-list li:nth-of-type(3) a::before {
  background-image: url(../images/icon-plane.png);
}
@media screen and (min-width: 760px), print {
	p {
		font-size: 12px;
	}
}
@media screen and (min-width: 751px) {
	/* common
	------------------------------------------------------------ */
	#maincontents section {
		padding: 100px 0;
	}
	#maincontents figure {
		margin-bottom: 0;
	}
	/* scene
	------------------------------------------------------------ */
	#scene h2 {
		margin-bottom: 1.5em;
		font-size: 48px;
	}
	.scene-wrap {
		margin-top: 220px;
		justify-content: space-between;
	}
	.scene-wrap:last-child {
		margin-top: 150px;
	}
	.scene-wrap .scene-box {
		width: 49%;
		font-size: 24px;
	}
	.scene-wrap .scene-box:nth-of-type(odd) {
		margin-top: -150px;
	}
	/* step
	------------------------------------------------------------ */
	#step h2 {
		font-size: 48px;
	}
	.step-wrap {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.step-in-wrap {
		width: 30%;
	}
	.step-wrap:before,
	.step-wrap:after {
		border-left: 16px solid #589cc1;
		border-top: 16px solid transparent;
		border-bottom: 16px solid transparent;
		top: 0;
		bottom: 0;
		margin: auto;
	}
	.step-wrap:before {
		left: 32%;
	}
	.step-wrap:after {
		left: 67%;
	}
	.step-in-wrap:last-child:after {
		display: none;
	}
	.step-box {
		padding: 3em 1em;
		display: flex;
		flex-wrap: wrap;
	}
	.step-box p {
		font-size: 20px;
	}
	.step-in-wrap mark {
		width: 120px;
		height: 120px;
		top: -60px;
		left: -60px;
	}
	.step-in-wrap mark span {
		margin: 61px 0 0 75px;
		font-size: 26px;
	}
	/* plan-content
	------------------------------------------------------------ */
	#area-Content a {
		width: calc(100%/3)
	}
	#area-Content a:hover img,
	#area-Content a:hover {
		opacity: 1 !important;
	}
	#area-Content a span {
		font-size: 40px;
	}
	#plan-content .mainw {
		width: 1100px;
	}
	#plan-content h2 {
		font-size: 44px;
		padding-top: 100px;
	}
	.plan-box h3 {
		font-size: 32px;
	}
	.plan-list .plan-box {
		width: 47.4%;
	}
}/* end (min-width: 751px) and (max-width: 1200px) ------------------ */
@media screen and (min-width: 751px) and (max-width: 1200px) {
	/* scene
	------------------------------------------------------------ */
	.scene-wrap .scene-box {
		font-size: 2.6vw;
	}
	/* step
	------------------------------------------------------------ */
	.step-box p {
		font-size: 1.7vw;
	}
	/* plan-content
	------------------------------------------------------------ */
	#plan-content .mainw {
		width: 96%;
	}
	#plan-content .mainw > p {
		font-size: 1.8vw;
	}
}/* end (min-width: 751px) and (max-width: 1200px) ------------------ */
@media screen and (max-width: 750px) {
	/* common
	------------------------------------------------------------ */
  #maincontents  h3 {
    margin-bottom: .5em;
    font-size: 1.45rem;
  }
	#maincontents section {
		padding: 12vw 0;
	}
  .sub h2 {
    font-size: 6vw;
    margin-bottom: 1em;
  }
	/* scene
	------------------------------------------------------------ */
	#scene h2 {
		margin-bottom: 1.5em;
		font-size: 7vw;
	}
	#scene h2 span {
		width: 100%;
	}
	#scene figure {
		margin-bottom: 10vw;
	}
	#scene .scene-wrap:last-child figure:last-child {
		margin-bottom: 0;
	}
	.scene-wrap .scene-box figcaption {
		font-size: 4.8vw;
	}
	.scene-wrap {
		justify-content: center;
	}
	/* step
	------------------------------------------------------------ */
	#step h2 {
		font-size: 7vw;
		margin-bottom: 1.2em;
	}
	.step-arrow {
		width: 5vw;
		border-top: 5vw solid #589cc1;
		border-left: 5vw solid transparent;
		border-right: 5vw solid transparent;
		left: 0;
		right: 0;
		margin: auto;
	}
	.step-in-wrap:last-child:after {
		display: none;
	}
	.step-box {
		padding: 16vw 1em;
		display: flex;
		flex-wrap: wrap;
	}
	.step-box p {
		font-size: 4.5vw;
	}
	.step-in-wrap {
		justify-content: center;
		margin: 1em 0;
	}
	.step-in-wrap:first-child {
		margin-top: 0;
	}
	.step-in-wrap:last-child {
		margin-bottom: 0;
	}
	.step-in-wrap mark {
		width: 120px;
		height: 120px;
		top: -60px;
		left: -60px;
	}
	.step-in-wrap mark span {
		margin: 61px 0 0 75px;
		font-size: 26px;
	}
	.step-wrap #step-image1 {
    width: 21vw;
	}
	.step-wrap #step-image2 {
    width: 39vw;
	}
	.step-wrap #step-image3 {
    width: 60vw;
	}
	/* plan-content
	------------------------------------------------------------ */
	#area-Content a {
		width: calc(100%/2)
	}
	#area-Content a span {
		font-size: 6vw;
	}
	#plan-content h2 {
		font-size: 7vw;
		padding-top: 12vw;
	}
	#plan-content .mainw > p {
		text-align: left;
		text-indent: -1em;
		margin-left: 1em;
    font-size: 3.5vw;
    margin: 2em 0;
	}
	#plan-content .plan-box h3 {
		font-size: 6vw !important;
		margin-bottom: 0;
	}
	.plan-list .plan-box {
		width: 100%;
	}
	.plan-box .plan-txt {
    padding: 5vw 5vw 2vw;
    font-size: 3.6vw;
}
}/* end (max-width: 750px) ------------------ */

