@charset "UTF-8";
/*初期化
-----------------------------------------------------------------------------------*/
*,
*::before,
*::after {
  box-sizing: border-box;
}

ul[class],
ol[class] {
  padding: 0;
}

body,
h1,
h2,
h3,
h4,
p,
figure,
figcaption,
blockquote,
dl,
dd {
  margin: 0;
}

body {
  min-height: 100vh;
  scroll-behavior: smooth;
  text-rendering: optimizeSpeed;
}

ul,
ol {
	list-style: none;
	margin: 0;
	padding: 0;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

article > * + * {
  margin-top: 1em;
}

input,
button,
textarea,
select {
  font: inherit;
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}


/* 共通スタイル */
a {	text-decoration:none;	-webkit-transition: 0.3s; -moz-transition: 0.3s;	-o-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s; }


/* 余白 */
/* -------------------------------------------------------- */
.ml5 { margin-left:5px; }			.ml10 { margin-left:10px; }		.ml15 { margin-left:15px; }		.ml20 { margin-left:20px; }
.ml25 { margin-left:25px; }		.ml30 { margin-left:30px; }		.ml35 { margin-left:35px; }		.ml40 { margin-left:40px; }
.ml45 { margin-left:45px; }		.ml50 { margin-left:50px; }		.ml55 { margin-left:55px; }		.ml60 { margin-left:60px; }
.ml70 { margin-left:70px; }		.ml80 { margin-left:80px; }		.ml90 { margin-left:90px; }		

.mt5 { margin-top:5px; }			.mt10 { margin-top:10px; }		.mt15 { margin-top:15px; }		.mt20 { margin-top:20px; }
.mt25 { margin-top:25px; }		.mt30 { margin-top:30px; }		.mt35 { margin-top:35px; }		.mt40 { margin-top:40px; }
.mt45 { margin-top:45px; }		.mt50 { margin-top:50px; }		.mt55 { margin-top:55px; }		.mt60 { margin-top:60px; }
.mt70 { margin-top:60px; }		.mt80 { margin-top:80px; }		.mt95 { margin-top:95px; }		.mt100 { margin-top:100px; }

.mb5 { margin-bottom:5px; }		.mb10 { margin-bottom:10px; }	.mb15 { margin-bottom:15px; }	.mb20 { margin-bottom:20px; }
.mb25 { margin-bottom:25px; }	.mb30 { margin-bottom:30px; }	.mb35 { margin-bottom:35px; }	.mb40 { margin-bottom:40px; }
.mb45 { margin-bottom:45px; }	.mb50 { margin-bottom:50px; }

.mr5 { margin-right:5px; }		.mr10 { margin-right:10px; }	.mr15 { margin-right:15px; }	.mr20 { margin-right:20px; }
.mr25 { margin-right:25px; }	.mr30 { margin-right:30px; }	.mr35 { margin-right:35px; }	.mr40 { margin-right:40px; }
.mr45 { margin-right:45px; }	.mr50 { margin-right:50px; }


/* 配置 */
/* -------------------------------------------------------- */
.alignce { text-align:center; }	.alignle { text-align:left; }	.alignri { text-align:right; }


/* ロールオーバー */
/* -------------------------------------------------------- */
a:hover img {
	opacity:0.7;
	filter:alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
}

.fz14 { font-size: 1.4rem; }
.fz25 { font-size: 2.5rem; }
.fz30 { font-size: 3rem; }
.fz40 { font-size: 4rem; } 
@media screen and (max-width: 768px) {
	.fz25 { font-size: 1.65em; }
	.fz30 { font-size: 1.85rem; }
	.fz40 { font-size: 2rem; }
	.pa10 { padding: 10px; }
}

.large {
	font-size: 120%;
}


.orange { color: #F39800; }
.block { color: #000; }

@media screen and (max-width: 768px) {
	.inner {
		width:100%;
	}
}

.pc_disp { display:block; }
.sp_disp { display:none; }
@media screen and (max-width: 768px) {
	.pc_disp { display:none; }
	.sp_disp { display:block; }
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

img.imgFit {
	width: 100%;
}

html {
	font-size: 62.5%;
}


#container {
	padding-bottom:30px;
}

.top_copy {
	background: #00A7D9;
	padding: 30px 0;
	text-align: center;
}

#5min {
	background: #c1e4e9;
	padding: 30px 0;
	text-align: center;
}
@media screen and (max-width: 768px) {
	.top_copy {
		padding: 10px;
	}
}

.flexbox {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.flexbox.col2 li {
	width: calc(100% / 2);
}
.flexbox.top {
	padding: 20px 0;
	width: 100%;
	margin: 0 auto;
}
.flexbox.bottom li:first-child {
  margin-top: 20px;
  width: 400px;
}
.flexbox.bottom li:last-child {
  margin-top: 20px;
  padding-right: 20px;
  width: calc(100% - 400px);
}
@media screen and (max-width: 768px) {
	.flexbox {
		display: block;
	}
	.flexbox.top {
		width: 100%;
	}
	.flexbox.col2 li {
		width: 100%;
  }
  .flexbox.bottom li:first-child {
    width: 100%;
  }
  .flexbox.col2 li:last-child {
    width: 100%;
    margin-top: 20px;
  }
  .flexbox.col2.bottom li:last-child {
    padding: 0 10px;
	}
}

.block01 {
	background: linear-gradient( -45deg, #194990 25%, #0B428B 25%, #0B428B 50%, #194990 50%, #194990 75%, #0B428B 75%, #0B428B );
  background-size: 40px 40px;
	padding: 30px 0;
	text-align: center;
	color: #FFF;
}
.block01.top {
	background: #033067;
}
@media screen and (max-width: 768px) {
	.block01 {
		padding: 20px 10px;
	}
}

.block01 .tour {
	width: 90%;
	margin: 0 auto;
	text-align: left;
}

.block01 .tour ul {
	margin-top: 20px;
}
@media screen and (max-width: 768px) {
	.block01 .tour ul li {
		margin-bottom: 20px;
	}
}

.block02 {
	background: linear-gradient(
    -45deg,
    #43AFD4 25%, #2AAAD1 25%,
    #2AAAD1 50%, #43AFD4 50%,
    #43AFD4 75%, #2AAAD1 75%,
    #2AAAD1
  );
  background-size: 40px 40px;
	padding: 50px 0;
	text-align: center;
	color: #FFF;
	margin: 50px 0 0 0;
}
.block02 .txt {
	padding: 20px 80px;
	text-align: left;
}
.block02 .txt .block {
	text-align: center;
}
.block02 .txt .block p {
	background-color: #FFF;
	display: inline-block;
	font-size: 3rem;
	padding: 5px 30px;
	color: #1A2E66;
	font-weight: bold;
}
@media screen and (max-width: 768px) {
	.block02,
	.block02 .txt {
		padding: 20px 10px;
  }
  .block02 .txt .block p {
    font-size: 2rem;
  }
}

.txt_area {
	margin-top: 0;
}
.txt_area p {
	display: inline-block;
	border-bottom-right-radius: 10px;
	border-bottom-left-radius: 10px;
	background: #0B428B;
	padding: 15px 70px;
	color: #FFF;
	text-align: center;
	font-size: 3.75rem;
	font-weight: bold;
}
@media screen and (max-width: 768px) {
	.txt_area p {
		padding: 15px 10px;
		font-size: 1.75rem;
		display: block;
	}
}
@media screen and (max-width: 900px) {
  header .logo img {
    width: 100px;
  }
}
@media screen and (max-width: 1250px) {
  header .logo a::after {
    font-size: 12px;
  }
}