#header::before,
.haad-back::before {
	display: none;
}
@media print, screen and ( min-width : 911px ) {
    #header {
        height: 80px;
        background: linear-gradient(to right, rgba(30,68,163,0), rgba(17,44,113,0));
		transition: background .3s, height .3s;
    }
	.haad-back {
		height: 80px;
		background: linear-gradient(to right, rgba(30,68,163,0), rgba(17,44,113,0));
		transition: background .3s, height .3s;
	}
	/* ------------- */
	#header.is-animation {
		background: linear-gradient(to right, rgba(30,68,163,1), rgba(17,44,113,1)) !important;
		transition: .3s;
		height: 80px;
	}
	.haad-back.is-animation2 {
		background: linear-gradient(to right, rgba(30,68,163,1), rgba(17,44,113,1)) !important;
		transition: .3s;
		height: 80px;
	}
	.haad-back.is-animation2::before {
        display: block;
    }
}
@media screen and (max-width: 910px) {
}
@media screen and (max-width: 680px) {
}
/* --------------------------------------------------- */
@media print, screen and ( min-width : 769px ) {
}
/* --------------------------------------------------- */
.bg-slider {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    z-index: -1;
    overflow: hidden;
	background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
	
	background: url("../images/top/mv4.jpg") no-repeat center;
	background-size: cover;
}
.bg-slider .ami {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-color: rgba(0,0,0,.2);
}
@media screen and (max-width: 680px) {
	.bg-slider {
	}
}
/* --------------------------------------------------- */
.gap {
    height: 100vh;
	position: relative;
}
.gap .mv-ttl {
	position: absolute;
	right: 0;
	top: 60%;
	transform: translate(0%, -50%);
	color: #fff;
}
.gap .mv-ttl .en {
	font-family: "Barlow Condensed", sans-serif;
	font-weight: 600;
	font-size: 10em;
	line-height: 1.8em;
	text-align: right;
}
.gap .mv-ttl .en span {
	display: block;
	text-align: right;
	font-size: 3.3em;
	letter-spacing: 0;
}
.gap .jp {
	font-size: 1.8em;
	font-weight: 600;
	position: absolute;
	top: 50%;
	right: 500px;
	text-align: right;
	transform: translate(0%, -50%);
	color: #fff;
	letter-spacing: 10px;
}
@media screen and (max-width: 910px) {
	.gap .mv-ttl {
		top: 55%;
	}
	.gap .mv-ttl .en {
		font-size: 7em;
	}
	.gap .mv-ttl .en span {
		font-size: 3.4em;
	}
	.gap .jp {
		font-size: 1.5em;
		right: auto;
		left: 5%;
	}
}
@media screen and (max-width: 680px) {
	.gap {
		height: 600px;
		margin-bottom: 0;
	}
	.gap .mv-ttl {
		width: 100%;
		right: auto;
		left: 50%;
		top: 50%;
		transform: translate(-50%, -50%);
	}
	.gap .mv-ttl .en {
		text-align: center;
		font-size: 5em;
		width: 100%;
	}
	.gap .mv-ttl .en span {
		text-align: center;
	}
	.gap .jp {
		left: 8%;
		right: 0;
		top: auto;
		bottom: 80px;
		font-size: 1.3em;
		transform: translate(0%, 0%);
		letter-spacing: 5px;
	}
}
/* --------------------------------------------------- */
#sec01 {
	width: 100%;
	position: relative;
	z-index: 2;
}
#sec01 .arrow-img-outer .ami {
	display: block;
	width: 100%;
	height: auto;
	position: absolute;
	z-index: 0;
	left: 0;
	bottom: 0;
	top: 60%;
	background: linear-gradient(to right, rgba(30,68,163,1), rgba(17,44,113,1));
}
#sec01 .arrow-img {
	width: 130%;
	z-index: 1;
	margin-left: -10%;
}
#sec01 .inner {
	width: 100%;
	background: linear-gradient(to right, rgba(30,68,163,1), rgba(17,44,113,1));
	position: relative;
	z-index: 2;
	padding: 100px 5% 80px;
	margin-top: -300px;
}
#sec01 .intro {
	max-width: 650px;
	width: 90%;
	color: #fff;
	margin: -300px 5% 100px auto;
}
#sec01 .intro dt {
	font-size: 1.5em;
	font-weight: 700;
	letter-spacing: 3px;
	margin-bottom: 20px;
}
#sec01 .intro dt span {
	display: block;
	font-size: 1.4em;
}
#sec01 .intro dd {
}
#sec01 .info {
	max-width: 1000px;
	width: 95%;
	margin: 0 auto 150px;
}
#sec01 .ttl-style01 {
	color: #fff;
}
#sec01 .info dl {
	width: 100%;
	display: table;
	background-color: #fff;
	padding: 30px;
	margin-bottom: 15px;
	border-radius: 4px;
	box-shadow: 0px 10px 10px -6px rgba(0, 0, 0, 0.3);
}
#sec01 .info dd,
#sec01 .info dt {
	display: table-cell;
	vertical-align: top;
}
#sec01 .info dd {
	width: 130px;
	font-size: 12px;
	letter-spacing: 2px;
	color: #aaa;
	padding-top: 3px;
}
#sec01 .info dt {
}
#sec01 .info dt a {
}
#sec01 .info dt a:hover {
	color: #3C96F1;
}
#sec01 .info .btn-style01 {
    color: #fff;
    border: 1px solid #fff;
}
#sec01 .info .btn-style01::after {
  background: #fff;
}
#sec01 .txt-style01 {
	color: #fff;
}
@media print, screen and ( max-width : 1300px ) {
	#sec01 .arrow-img-outer .ami {
        top: 40%;
    }
	#sec01 .inner {
        padding: 0px 5% 80px;
        margin-top: 0px;
    }
	#sec01 .intro {
		position: absolute;
		top: -80px;
		right: 5%;
    }
}
@media screen and (max-width: 910px) {
	#sec01 .arrow-img-outer {
		margin-top: -200px;
		margin-bottom: 300px;
	}
	#sec01 .arrow-img {
	}
	#sec01 .arrow-img-outer .ami {
		top: 40%;
	}
	#sec01 .inner {
        padding: 60px 5% 20px;
        margin-top: -300px;
    }
	#sec01 .info {
        width: 90%;
        margin: 0 auto 100px;
    }
	#sec01 .intro {
        margin: 0;
		top: -350px;
		left: 5%;
		padding: 40px 0;
    }
}
@media screen and (max-width: 680px) {
	#sec01 {
		background: linear-gradient(to right, rgba(30,68,163,1), rgba(17,44,113,1));
		position: relative;
	}
	#sec01 .arrow-img-outer {
		margin-top: 0px;
		margin-bottom: -100px;
		top: -100px;
	}
	#sec01 .inner {
        padding: 0px 5% 10px;
        margin-top: 0px;
    }
	#sec01 .info {
        width: 90%;
        margin: 0px auto 0px;
    }
	#sec01 .info dl {
        width: 100%;
        display: block;
        padding: 15px 20px;
        margin-bottom: 10px;
    }
    #sec01 .info dd,
    #sec01 .info dt {
        display: block;
    }
    #sec01 .info dd {
        width: 100%;
        font-size: 11px;
        padding-top: 0;
		margin-bottom: 4px;
    }
	#sec01 .intro {
		position: static;
        margin: 0px 5% 0;
    }
	#sec01 .intro dt {
        font-size: 1.1em;
        letter-spacing: 2px;
        margin-bottom: 20px;
    }
    #sec01 .intro dt span {
        font-size: 1.3em;
		line-height: 150%;
    }
}
/* --------------------------------------------------- */
#sec02 {
	background: linear-gradient(to right, rgba(30,68,163,1), rgba(17,44,113,1));
}
#sec02 .block {
	width: 100%;
	height: 700px;
	position: relative;
	color: #fff;
}
#sec02 .block.ph1 {
	background: url("../images/top/ph01.jpg") no-repeat center;
	background-size: cover;
}
#sec02 .block.ph2 {
	background: url("../images/top/ph02.jpg") no-repeat center;
	background-size: cover;
}
#sec02 .block.ph3 {
	background: url("../images/top/ph03.jpg") no-repeat center;
	background-size: cover;
}
#sec02 .block.ph4 {
	background: url("../images/top/ph04_2.jpg") no-repeat center;
	background-size: cover;
}
#sec02 .block::before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-color: rgba(0,0,0,.2);
	z-index: 0;
}
#sec02 .block .box {
	max-width: 550px;
	width: 90%;
	position: absolute;
	top: 50%;
	transform: translate(0%, -50%);
	z-index: 2;
}
#sec02 .block.ph1 .box,
#sec02 .block.ph3 .box {
	right: 5%;
}
#sec02 .block.ph2 .box,
#sec02 .block.ph4 .box {
	left: 5%;
}
#sec02 .block .arrow {
	width: 743px;
	position: absolute;
	z-index: 0;
	top: 1;
}
#sec02 .block.ph1 .arrow,
#sec02 .block.ph3 .arrow {
	right: 0;
}
#sec02 .block.ph2 .arrow,
#sec02 .block.ph4 .arrow {
	left: 0;
	margin-left: -20%;
}
#sec02 .block .box .ttl {
	font-size: 1.6em;
	font-weight: 700;
	letter-spacing: 4px;
	margin-bottom: 25px;
	line-height: 1em;
}
#sec02 .block .box .ttl span {
	display: block;
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 1px;
}
#sec02 .block .box p {
	margin-bottom: 50px;
}
#sec02 .block .box .btn-style01 {
    color: #fff;
    border: 1px solid #fff;
}
#sec02 .block .box .btn-style01::after {
  background: #fff;
}
@media print, screen and ( max-width : 1160px ) {
}
@media screen and (max-width: 910px) {
	#sec02 .block {
        height: 500px;
		overflow: hidden;
    }
}
@media screen and (max-width: 680px) {
	#sec02 .block {
        height: auto;
		padding-top: 160px;
    }
	#sec02 .block.ph1,
	#sec02 .block.ph2,
	#sec02 .block.ph3,
	#sec02 .block.ph4 {
		background-position: center top;
		background-size: 100%;
	}
	#sec02 .block .arrow {
		display: none;
	}
	#sec02 .block::before {
        background-color: rgba(0,0,0,.5);
		display: none;
    }
	#sec02 .block .box {
		background-color: #0D296F;
		position: static;
		max-width: none;
        width: 100%;
        transform: translate(0%, 0%);
		padding: 25px;
	}
	#sec02 .block .box .ttl {
        font-size: 1.3em;
		margin-bottom: 15px;
    }
	#sec02 .block .box .ttl span {
        font-size: 8px;
        font-weight: 400;
    }
	#sec02 .block .box p {
        margin-bottom: 0px;
    }
}
/* --------------------------------------------------- */
#sec03 {
	background: linear-gradient(to right, rgba(30,68,163,1), rgba(17,44,113,1));
	padding: 100px 5% 50px;
	color: #fff;
}
#sec03 .ttl-style01 {
	color: #fff;
}
#sec03 .inner {
	max-width: 1300px;
	width: 100%;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#sec03 .inner li {
	width: 30%;
	margin-bottom: 5%;
}
#sec03 .inner li a {
	color: #fff;
}
#sec03 .inner li a .ph {
	display: block;
	margin-bottom: 7px;
	position: relative;
}
#sec03 .inner li a .ph::after {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	border: rgba(255,255,255,.5) 1px solid;
	transition: .3s;
}
#sec03 .inner li a:hover .ph::after {
	border: rgba(255,255,255,.7) 5px solid;
}
#sec03 .inner li a h3 {
	padding-left: 35px;
	position: relative;
	font-size: 1.2em;
	font-weight: 600;
	letter-spacing: 3px;
}
#sec03 .inner li a .arrow {
	position: absolute;
	top: 15px;
	left: 0;
    display: inline-block;
    width: 20px;
    height: 2px;
    margin-top: 6.4px;
    border-radius: 9999px;
    background-color: #fff;
	transition: .3s;
}
#sec03 .inner li a .arrow::before {
	content: "";
    position: absolute;
    top: calc(50% - 1px);
    right: 0;
    width: 10px;
    height: 3px;
    border-radius: 9999px;
    background-color: #fff;
    transform: rotate(45deg);
    transform-origin: calc(100% - 0px) 50%;
	transition: .3s;
}
#sec03 .inner li a:hover .arrow {
	width: 28px;
}
@media print, screen and ( max-width : 1160px ) {
}
@media screen and (max-width: 910px) {
}
@media screen and (max-width: 680px) {
	#sec03 {
        padding: 30px 5% 20px;
    }
	#sec03 .inner {
    }
    #sec03 .inner li {
        width: 48%;
    }
	#sec03 .inner li a h3 {
        padding-left: 22px;
        font-size: 1em;
		text-align: center;
		letter-spacing: 1px;
    }
	#sec03 .inner li a .arrow {
        top: 7px;
        width: 15px;
        height: 1px;
        margin-top: 6.4px;
    }
    #sec03 .inner li a .arrow::before {
        right: 0;
        width: 6px;
        height: 2px;
    }
    #sec03 .inner li a:hover .arrow {
        width: 22px;
    }
}
/* --------------------------------------------------- */
#sec04 {
	background-color: #fff;
	position: relative;
}
#sec04 .arrow-img-outer {
	position: relative;
	z-index: 0;
	overflow: hidden;
}
#sec04 .arrow-img {
	width: 130%;
	z-index: 1;
	margin-left: -10%;
}
#sec04 .ttl-style01 {
	position: absolute;
	top: 80px;
	left: 5%;
	color: #163584;
	z-index: 1;
}
#sec04 ul {
	position: absolute;
	top: 400px;
	left: 50%;
	transform: translate(-50%, 0%);
	max-width: 1300px;
	width: 92%;
	display: flex;
	justify-content: space-between;
	z-index: 1;
}
#sec04 li {
	width: 29%;
	margin-bottom: 4%;
}
#sec04 li a {
	display: block;
	position: relative;
	padding-top: 100%;
}
#sec04 li a img {
	position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    object-fit: cover;
	transition: transform 0.3s ease;
	 box-shadow: 0px 1px 10px -6px rgba(0, 0, 0, 0.3);
}
#sec04 li a h4 {
	position: absolute;
	left: 50%;
	top: 50%;
	text-align: center;
	color: #fff;
	transform: translate(-50%, -50%);
	z-index: 2;
	font-size: 1.3em;
	font-weight: 500;
	width: 90%;
	border-top: #0D296F 1px solid;
	border-bottom: #0D296F 1px solid;
	padding: 15px 0 17px;
	background-color: rgba(13,41,111,.8);
	text-shadow: 0px 1px 5px rgba(0, 0, 0, 0.4);
	transition: .3s;
}
#sec04 li a:hover {
	opacity: 1;
}
#sec04 li a:hover img {
	transform: scale(1.06);
	 box-shadow: 0px 10px 10px -6px rgba(0, 0, 0, 0.3);
}
#sec04 li a:hover h4 {
	border-top: #fff 1px solid;
	border-bottom: #fff 1px solid;
	background-color: rgba(13,41,111,0);
}
@media print, screen and ( max-width : 1160px ) {
	#sec04 {
	}
	#sec04 .ttl-style01 {
		position: relative;
		margin-bottom: 0;
		top: 30px;
	}
	#sec04 .arrow-img-outer {
	}
}
@media screen and (max-width: 910px) {
	#sec04 ul {
		flex-wrap: wrap;
		top: 200px;
        left: 50%;
        width: 90%;
	}
	#sec04 li {
        width: 48%;
        margin-bottom: 4%;
    }
	#sec04 li a {
        padding-top: 60%;
    }
}
@media screen and (max-width: 680px) {
	#sec04 {
		padding-bottom: 0px;
	}
	#sec04 .arrow-img-outer {
		z-index: 0;
	}
	#sec04 ul {
		display: block;
		max-width: 480px;
		width: 85%;
		margin: 50px auto -200px;
		position: relative;
		top: auto;
		left: auto;
		transform: translate(0%, 0%);
	}
	#sec04 li {
        width: 100%;
        margin-bottom: 4%;
    }
	#sec04 li a {
        padding-top: 50%;
    }
	#sec04 li a h4 {
        font-size: 1.2em;
        width: 200px;
        padding: 10px 0 12px;
    }
}
/* --------------------------------------------------- */

/* --------------------------------------------------- */


