@charset "utf-8";

/* ================================================================================


fv fv-inn


*  ================================================================================ */

.fv {
	width: 100vw;
}

.fv .fv-inn {
	background-image: url(../img/home/fv-bg.jpg);
	background-position: right top;
	background-repeat: no-repeat;
	background-size: contain;
	height: 560px;
	margin: 0 auto;
	position: relative;
	max-width: 1200px;
}

@media screen and (max-width: 1023px) {
	.fv .fv-inn {
		background-position: center bottom 4%;
		background-size: 100vw;
		height: 100%;
		padding-bottom: 68vw;
		max-width: 100%;
	}
}

/* ============================================================

inn-conts

*  ============================================================ */

.fv .fv-inn .inn-conts {
	background-color: rgba( 255, 255, 255, 0.8 );
	padding-bottom: 20px;
	padding-top: 40px;
	position: absolute;
		top: 40px;
		left: 0;
	width: 500px;
}

@media screen and (max-width: 1023px) {
	.fv .fv-inn .inn-conts {
		margin: 0 auto;
		padding-top: 4vw;
		position: initial;
		width: 80vw;
	}
}

/* ------------------------------------------------------------
p.conts-ttl-upper
*  ------------------------------------------------------------ */

.fv .fv-inn .inn-conts p.conts-ttl-upper {
  width: 300px;
}

@media screen and (max-width: 1023px) {
	.fv .fv-inn .inn-conts p.conts-ttl-upper {
	  width: 72vw;
	}
}

/* ------------------------------------------------------------
p.conts-ttl-lower
*  ------------------------------------------------------------ */

.fv .fv-inn .inn-conts p.conts-ttl-lower {
	font-size: 4.4rem;
	font-weight: 700;
	line-height: 1.2;
	padding-left: 12px;
	padding-top: 24px;
	text-shadow: 1px 2px 0 #fff;
}

@media screen and (max-width: 1023px) {
	.fv .fv-inn .inn-conts p.conts-ttl-lower {
		font-size: clamp(28px, 5.6vw, 36px);
		line-height: 1.4;
	}
}

/* ------------------------------------------------------------
ul.conts-list
*  ------------------------------------------------------------ */

.fv .fv-inn .inn-conts ul.conts-list {
	margin-left: 20px;
	margin-top: 30px;
}

@media screen and (max-width: 1023px) {
	.fv .fv-inn .inn-conts ul.conts-list {
		margin-top: 20px;
		width: 90%;
	}
}

.fv .fv-inn .inn-conts ul.conts-list li {
	color: #0380cb;
 	font-size: 2rem;
 	font-weight: 700;
	line-height: 1.2;
 	padding: 4px 0 4px 32px;
 	position: relative;
}

.fv .fv-inn .inn-conts ul.conts-list li::before {
	content: '';
	background: url(../img/home/conts-list-icon.svg) no-repeat;
	background-size: contain;
	height: 24px;
	position: absolute;
		top: 8px;
		left: 0;
	width: 20px;
}

/* ============================================================

ul.inn-btn

*  ============================================================ */

.fv .fv-inn ul.inn-btn {
	display: flex;
	align-items: center;
	position: absolute;
		bottom: 30px;
		left: 20px;
}

@media screen and (max-width: 1023px) {
	.fv .fv-inn ul.inn-btn {
		margin: 0 auto;
	  position: absolute;
	  bottom: 40px;
	  left: 50%;
	  transform: translateX(-50%);
	}
}

/* ------------------------------------------------------------
ul.inn-btn li
*  ------------------------------------------------------------ */

.fv .fv-inn ul.inn-btn li {
	margin-left: 20px;
}

.fv .fv-inn ul.inn-btn li:first-of-type {
	margin-left: 0;
}

.fv .fv-inn ul.inn-btn li a {
	display: flex;
	justify-content: center;
	align-items: center;
	border: 1px solid #ff9d00;
	background-color: #ff9d00;
	border-radius: 40px;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 500;
	height: 48px;
	transition: all 0.3s;
	width: 180px;
}

.fv .fv-inn ul.inn-btn li a.white {
	display: flex;
	justify-content: center;
	align-items: center;
	border: 1px solid #ff9d00;
	background-color: #fff;
	border-radius: 40px;
	color: #ff9300;
	font-size: 1.5rem;
	font-weight: 500;
	height: 48px;
	transition: all 0.3s;
	width: 180px;
}

.fv .fv-inn ul.inn-btn li a:hover {
	opacity: 0.5;
}

@media screen and (max-width: 1023px) {
	.fv .fv-inn ul.inn-btn li {
		margin-left: 10px;
	}
	.fv .fv-inn ul.inn-btn li a,
	.fv .fv-inn ul.inn-btn li a.white {
		font-size: 3.6vw;
		width: 38vw;
	}
}

/* ================================================================================


section01 section01-inn


*  ================================================================================ */

.section01 {
  background: linear-gradient(180deg, #F5F5F5 0%, #F5F5F5 80%, #fff 80%, #fff 100%);
	margin-top: 80px;
	padding-top: 80px;
	position: relative;
	width: 100vw;
	z-index: 1;
}

.section01 .section01-inn {
	display: flex;
	justify-content: space-between;
	align-items: end;
	margin: 0 auto;
	max-width: 1200px;
}

@media screen and (max-width: 1023px) {
	.section01 .section01-inn {
		flex-direction: column;
		width: 84vw;
	}
}

/* ============================================================

inn-left

*  ============================================================ */

.section01 .section01-inn .inn-left {
	width: 64%;
}

@media screen and (max-width: 1023px) {
	.section01 .section01-inn .inn-left {
		width: 100%;
	}
}

/* ------------------------------------------------------------
left-video
*  ------------------------------------------------------------ */

.section01 .section01-inn .inn-left .left-video {
	padding-top: 56.25%;
	position: relative;
	width: 100%;
}

.section01 .section01-inn .inn-left .left-video iframe {
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

/* ============================================================

inn-right

*  ============================================================ */

.section01 .section01-inn .inn-right {
	width: 32%;
}

@media screen and (max-width: 1023px) {
	.section01 .section01-inn .inn-right {
		margin: 0 auto;
		width: 100%;
	}
}

/* ------------------------------------------------------------
right-profile
*  ------------------------------------------------------------ */

.section01 .section01-inn .inn-right .right-profile {
	display: flex;
	align-items: end;
}

/* ----------------------------------------
h2.profile-ttl
*  ---------------------------------------- */

.section01 .section01-inn .inn-right .right-profile h2.profile-ttl {
	width: 36%;
}

@media screen and (max-width: 1023px) {
	.section01 .section01-inn .inn-right .right-profile h2.profile-ttl {
		margin-top: 20px;
	}
}

/* ----------------------------------------
p.profile-txt
*  ---------------------------------------- */

.section01 .section01-inn .inn-right .right-profile p.profile-txt {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.6;
	margin-left: 20px;
}

/* ------------------------------------------------------------
right-txt
*  ------------------------------------------------------------ */

.section01 .section01-inn .inn-right p.right-txt {
	font-size: 1.3rem;
	font-weight: 500;
	line-height: 2;
	margin-top: 20px;
}

/* ================================================================================


section02 section02-inn


*  ================================================================================ */

.section02 {
	background-image: linear-gradient(0deg, rgba(255, 255, 255, 1), rgba(181, 174, 190, 1));
	margin-top: 80px;
	padding-top: 200px;
	position: relative;
	width: 100vw;
	z-index: 1;
}

.section02 .section02-inn {
	display: flex;
	justify-content: space-between;
  background-color: #fff;
	margin: 0 auto;
	max-width: 1020px;
}

@media screen and (max-width: 1023px) {
	.section02 .section02-inn {
		flex-direction: column;
		width: 84vw;
	}
}

/* ============================================================

inn-left

*  ============================================================ */

.section02 .section02-inn .inn-left {
	margin-top: -100px;
	width: 56%;
}

@media screen and (max-width: 1023px) {
	.section02 .section02-inn .inn-left {
		margin-top: -140px;
		width: 100%;
	}
}

/* ------------------------------------------------------------
left-ttlblk
*  ------------------------------------------------------------ */

.section02 .section02-inn .inn-left .left-ttlblk {
	background-image: url(../img/home/section02-left-ttlblk-bg.png);
	background-position: left 20px top;
	background-repeat: no-repeat;
	background-size: 16px;
	height: 80px;
	padding-left: 56px;
	padding-top: 20px;
}

@media screen and (max-width: 1023px) {
	.section02 .section02-inn .inn-left .left-ttlblk {
		background-position: left top;
		padding-left: 30px;
	}
}

/* ----------------------------------------
ttlblk-rb
*  ---------------------------------------- */

.section02 .section02-inn .inn-left .left-ttlblk .ttlblk-rb {
	font-size: 1.4rem;
	font-weight: 700;
}

/* ----------------------------------------
h2.ttlblk-ttl
*  ---------------------------------------- */

.section02 .section02-inn .inn-left .left-ttlblk h2.ttlblk-ttl {
	font-size: 2.8rem;
	font-weight: 700;
	padding-top: 8px;
}

@media screen and (max-width: 1023px) {
	.section02 .section02-inn .inn-left .left-ttlblk h2.ttlblk-ttl {
		line-height: 1.2;
	}
}

/* ------------------------------------------------------------
ol.left-list
*  ------------------------------------------------------------ */

.section02 .section02-inn .inn-left ol.left-list {
	padding-left: 60px;
	padding-top: 50px;
}

@media screen and (max-width: 1023px) {
	.section02 .section02-inn .inn-left ol.left-list {
		padding-left: 30px;
		padding-right: 30px;
		padding-top: 80px;
	}
}

.section02 .section02-inn .inn-left ol.left-list li {
	font-size: 2rem;
	font-weight: 500;
	line-height: 1.2;
	padding-bottom: 10px;
	padding-left: 2rem;
	padding-top: 10px;
	text-indent: -2.5rem;
}

.section02 .section02-inn .inn-left ol.left-list li span {
	color: #7520a2;
	font-weight: 700;
}

@media screen and (max-width: 1023px) {
	.section02 .section02-inn .inn-left ol.left-list li {
		font-size: 1.8rem;
		line-height: 1.4;
		text-indent: -2.3rem;
	}
}

/* ============================================================

inn-right

*  ============================================================ */

.section02 .section02-inn .inn-right {
	margin-top: -160px;
	width: 40%;
}

@media screen and (max-width: 1023px) {
	.section02 .section02-inn .inn-right {
		margin-top: 20px;
		width: 100%;
	}
}

/* ================================================================================


section03 section03-inn


*  ================================================================================ */

.section03 {
	margin-top: 160px;
	position: relative;
	width: 100vw;
}

@media screen and (max-width: 1023px) {
	.section03 {
		margin-top: 80px;
	}
}

.section03 .section03-inn {
	margin: 0 auto;
	max-width: 1020px;
}

@media screen and (max-width: 1023px) {
	.section03 .section03-inn {
		width: 84vw;
	}
}

/* ============================================================

h2.inn-ttl

*  ============================================================ */

.section03 .section03-inn h2.inn-ttl {
	background-image: url(../img/home/section03-ttl-bdr.jpg);
	background-position: left bottom;
	background-repeat: no-repeat;
	background-size: 400px;
	font-size: 4.4rem;
	font-weight: 700;
	line-height: 1.2;
  padding-bottom: 20px;
}

@media screen and (max-width: 1023px) {
	.section03 .section03-inn h2.inn-ttl {
		background-size: 56vw;
		font-size: 3.6rem;
	}
}

/* ============================================================

ul.inn-list

*  ============================================================ */

.section03 .section03-inn ul.inn-list {
	margin-top: 60px;
}

/* ------------------------------------------------------------
ul.inn-list li
*  ------------------------------------------------------------ */

.section03 .section03-inn ul.inn-list li {
	display: flex;
	align-items: center;
	margin-top: 20px;
	position: relative;
}

.section03 .section03-inn ul.inn-list li:nth-child(even) {
	flex-direction: row-reverse;
}

@media screen and (max-width: 1023px) {
	.section03 .section03-inn ul.inn-list li {
		flex-wrap: wrap;
	}
	.section03 .section03-inn ul.inn-list li:nth-child(even) {
		flex-direction: row;
	}
}

/* ----------------------------------------
list-left
*  ---------------------------------------- */

.section03 .section03-inn ul.inn-list li .list-left {
	height: 240px;
	width: 62%;
	z-index: 2;
  position: relative;
}

@media screen and (max-width: 1023px) {
	.section03 .section03-inn ul.inn-list li .list-left {
		height: auto;
		width: 100%;
	}
}

.section03 .section03-inn ul.inn-list li .list-left .number {
	color: #fff;
	font-size: 2.1rem;
	position: absolute;
		top: 15px;
		left: 15px;
	z-index: 3;
}

.section03 .section03-inn ul.inn-list li .list-left .left-ctr {
	background-color: #f5f5f5;
	height: 100%;
	overflow: hidden;
	padding: 64px 0 0 50px;
	position: relative;
	width: 100%;
}

.section03 .section03-inn ul.inn-list li .list-left .left-ctr::before {
	content: '';
	background-color: #0380cb;
	height: 160px;
	position: absolute;
		top: -95px;
		left: -95px;
	transform: rotate(-40deg);
	width: 160px;
}

@media screen and (max-width: 1023px) {
	.section03 .section03-inn ul.inn-list li .list-left .left-ctr {
		padding: 80px 30px 56px;
	}
}

.section03 .section03-inn ul.inn-list li .list-left .left-ctr p.txt-blue {
	color: #00a1e0;
	font-size: 1.6rem;
	font-weight: 500;
	margin-bottom: 5px;
}

.section03 .section03-inn ul.inn-list li .list-left .left-ctr p {
	font-size: 3.2rem;
	font-weight: 700;
	line-height: 1.5;
}

.section03 .section03-inn ul.inn-list li .list-left .left-ctr p span {
	color: #00a1e0;
}

@media screen and (max-width: 1023px) {
	.section03 .section03-inn ul.inn-list li .list-left .left-ctr p.txt-blue {
		font-size: 1.4rem;
	}
	.section03 .section03-inn ul.inn-list li .list-left .left-ctr p {
		font-size: 2.8rem;
	}
}

/* ----------------------------------------
list-right
*  ---------------------------------------- */

.section03 .section03-inn ul.inn-list li .list-right {
	height: 240px;
	overflow: hidden;
	width: 38%;
}

@media screen and (max-width: 1023px) {
	.section03 .section03-inn ul.inn-list li .list-right {
		height: auto;
		width: 100%;
	}
}

/* ================================================================================


section04 section04-inn


*  ================================================================================ */

.section04 {
  background: linear-gradient(180deg, #F5F5F5 0%, #F5F5F5 80%, #fff 80%, #fff 100%);
	margin-top: 80px;
	padding-top: 60px;
	position: relative;
	width: 100vw;
}

.section04 .section04-inn {
	margin: 0 auto;
	max-width: 1020px;
}

@media screen and (max-width: 1023px) {
	.section04 .section04-inn {
		width: 84vw;
	}
}

/* ============================================================

h2.inn-ttl

*  ============================================================ */

.section04 .section04-inn h2.inn-ttl {
	font-size: 4.4rem;
	font-weight: 700;
}

@media screen and (max-width: 1023px) {
	.section04 .section04-inn h2.inn-ttl {
		font-size: 3.6rem;
	}
}

/* ============================================================

inn-tabs

*  ============================================================ */

.section04 .section04-inn .inn-tabs {
  margin-top: 20px;
  width: 100%;
}

.tab-item {
	background-color: #fff;
	border: 1px solid #e3e3e3;
	border-radius: 6px;
	box-shadow: 0px 2px 12px #0000001a;
	color: #0c133a;
  display: block;
  float: left;
  font-size: 2rem;
  font-weight: 500;
	margin-right: 30px;
	margin-top: 20px;
	padding: 24px 0 32px;
	position: relative;
  text-align: center;
  width: 320px;
}

.tab-item::before {
	content: '';
  display: inline-block;
  height: 8px;
  background: url(../img/home/section04-arrow-blue.png) no-repeat;
  background-size: contain;
	position: absolute;
		bottom: 12px;
		left: 50%;
	transform: translateX(-50%);
  width: 14px;
}

.tab-item:nth-of-type(3n) {
	margin-right: 0;
}

.tab-item:hover {
  background-color: #0380cb;
	border: 1px solid #0380cb;
  color: #fff;
	padding: 28px 0;
}

@media screen and (max-width: 1023px) {
	.tab-item {
	  font-size: 1.6rem;
		margin-right: 4%;
		margin-top: 10px;
		padding: 24px 0 32px;
		position: relative;
	  text-align: center;
	  width: 48%;
	}
	.tab-item:nth-of-type(3n) {
		margin-right: 4%;
	}
	.tab-item:nth-of-type(2n) {
		margin-right: 0;
	}
	.tab-item:hover {
	  background-color: #0380cb;
		border: 1px solid #0380cb;
	  color: #fff;
		padding: 28px 0;
	}
}

input[name="tab-item"] {
  display: none;
}

#theme-01:checked ~ #theme-01-content,
#theme-02:checked ~ #theme-02-content,
#theme-03:checked ~ #theme-03-content,
#theme-04:checked ~ #theme-04-content,
#theme-05:checked ~ #theme-05-content,
#theme-06:checked ~ #theme-06-content {
  display: block;
}

.section04 .section04-inn .inn-tabs input:checked + .tab-item {
  background-color: #0380cb;
	border: 1px solid #0380cb;
  color: #fff;
	padding: 28px 0;
}

/* ------------------------------------------------------------
tab-conts
*  ------------------------------------------------------------ */

.tab-conts {
  clear: both;
  display: none;
  overflow: hidden;
  padding-top: 40px;
}

.tab-conts .tab-conts-desc {
	background-color: #fff;
	border: 2px solid #0380cb;
	border-radius: 6px;
  overflow: hidden;
  padding: 40px;
}

@media screen and (max-width: 1023px) {
	.tab-conts .tab-conts-desc {
		overflow-x: auto;
		white-space: nowrap;
		-webkit-overflow-scrolling: touch;
	}
}

.tab-conts .tab-conts-desc .desc-ttl {
	font-size: 1.8rem;
	font-weight: 500;
}

/* ----------------------------------------
table.desc-table
*  ---------------------------------------- */

.tab-conts .tab-conts-desc table.desc-table {
	border-collapse: collapse;
	border-spacing: 0;
	margin-top: 30px;
	width: 100%;
}

@media screen and (max-width: 1023px) {
	.tab-conts .tab-conts-desc table.desc-table {
		width: 300%;
	}
}

.tab-conts .tab-conts-desc table.desc-table tr {
	border-bottom: 1px solid #0380cb;
}

.tab-conts .tab-conts-desc table.desc-table th {
	background-color: #0380cb;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 500;
	padding: 10px;
}

.tab-conts .tab-conts-desc table.desc-table th.time-theme {
	width: 32%
}

.tab-conts .tab-conts-desc table.desc-table th.time-cell {
	width: 10%
}

.tab-conts .tab-conts-desc table.desc-table td {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.4;
	padding: 20px 10px;
}

.tab-conts .tab-conts-desc table.desc-table td.ttl {
	font-weight: 700;
}

.tab-conts .tab-conts-desc table.desc-table td.time::after {
	content: '分';
  display: inline-block;
	font-size: 1.1rem;
	margin-left: 2px;
}

@media screen and (max-width: 1023px) {
	.tab-conts .tab-conts-desc table.desc-table td {
		font-size: 1.6rem;
	}
}

/* ================================================================================


section05 section05-inn


*  ================================================================================ */

.section05 {
  background-color: #f5f5f5;
	margin-top: 80px;
	padding-bottom: 40px;
	padding-top: 60px;
	position: relative;
	width: 100vw;
}

.section05 .section05-inn {
	margin: 0 auto;
	max-width: 1020px;
}

@media screen and (max-width: 1023px) {
	.section05 .section05-inn {
		width: 84vw;
	}
}

/* ============================================================

h2.inn-ttl

*  ============================================================ */

.section05 .section05-inn h2.inn-ttl {
	color: #0380cb;
	font-size: 3.8rem;
	font-weight: 700;
}

@media screen and (max-width: 1023px) {
	.section05 .section05-inn h2.inn-ttl {
		font-size: 2.8rem;
	}
}

/* ============================================================

inn-price

*  ============================================================ */

.section05 .section05-inn .inn-price {
	box-shadow: 0px 2px 12px #0000001a;
	margin-top: 20px;
	width: 100%;
}

@media screen and (max-width: 1023px) {
	.section05 .section05-inn .inn-price {
		overflow-x: auto;
		white-space: nowrap;
		-webkit-overflow-scrolling: touch;
		width: 100%;
	}
	.section05 .section05-inn .inn-price img {
		width: 240vw;
	}
}

/* ============================================================

inn-inq

*  ============================================================ */

.section05 .section05-inn .inn-inq {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 60px;
}

@media screen and (max-width: 1023px) {
	.section05 .section05-inn .inn-inq {
		flex-direction: column;
		margin-top: 30px;
	}
}

/* ------------------------------------------------------------
inq-ttl
*  ------------------------------------------------------------ */

.section05 .section05-inn .inn-inq .inq-ttl {
	background-image: url(../img/home/section05-img.png);
	background-position: left top;
	background-repeat: no-repeat;
	background-size: 140px;
	padding-left: 150px;
}

@media screen and (max-width: 1023px) {
	.section05 .section05-inn .inn-inq .inq-ttl {
		padding: 120px 20px 0 20px;
	}
}

.section05 .section05-inn .inn-inq .inq-ttl p {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 2.2;
}

@media screen and (max-width: 1023px) {
	.section05 .section05-inn .inn-inq .inq-ttl p {
		line-height: 2;
	}
}

/* ------------------------------------------------------------
inq-btn
*  ------------------------------------------------------------ */

.section05 .section05-inn .inn-inq ul.inq-btn {
	display: flex;
	align-items: center;
}

@media screen and (max-width: 1023px) {
	.section05 .section05-inn .inn-inq ul.inq-btn {
		margin: 20px auto 0;
	}
}

/* ------------------------------------------------------------
ul.inn-btn li
*  ------------------------------------------------------------ */

.section05 .section05-inn .inn-inq ul.inq-btn li {
	margin-left: 20px;
}

.section05 .section05-inn .inn-inq ul.inq-btn li:first-of-type {
	margin-left: 0;
}

.section05 .section05-inn .inn-inq ul.inq-btn li a {
	display: flex;
	justify-content: center;
	align-items: center;
	border: 1px solid #ff9d00;
	background-color: #ff9d00;
	border-radius: 40px;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 500;
	height: 48px;
	transition: all 0.3s;
	width: 180px;
}

.section05 .section05-inn .inn-inq ul.inq-btn li a.white {
	display: flex;
	justify-content: center;
	align-items: center;
	border: 1px solid #ff9d00;
	background-color: #fff;
	border-radius: 40px;
	color: #ff9300;
	font-size: 1.5rem;
	font-weight: 500;
	height: 48px;
	transition: all 0.3s;
	width: 180px;
}

.section05 .section05-inn .inn-inq ul.inq-btn li a:hover {
	opacity: 0.5;
}

@media screen and (max-width: 1023px) {
	.section05 .section05-inn .inn-inq ul.inq-btn li {
		margin-left: 10px;
	}
	.section05 .section05-inn .inn-inq ul.inq-btn li a,
	.section05 .section05-inn .inn-inq ul.inq-btn li a.white {
		font-size: 3.6vw;
		width: 38vw;
	}
}

/* ================================================================================


fade


*  ================================================================================ */

.fadeIn {
  opacity: 0;
  transition-duration: 800ms;
  transition-property: opacity, transform;
}

.fadeIn-up {
  transform: translate(0, 100px);
}

.scrollIn {
  opacity: 1;
  transform: translate(0, 0);
}
