@charset "utf-8";

/**
 *
 *  ページ用CSS
 *　trait
 * 
 */

/*--------------------------------------------------------------------------
   Overwright
---------------------------------------------------------------------------*/
.content{
	position: relative;
}
.breadcrumb{
	margin: 20px 0 130px;
}


/*--------------------------------------------------------------------------
   Content
---------------------------------------------------------------------------*/
.side-ttl{
	position: absolute;
	left: 0;
	top: 0;
	width: 22.92vw;
	height: 100%;
	background: url(../img/outline/trait/txt_side.svg) repeat-y left top var(--beige);
	background-size: 9.96vw auto;
	font-size: 0;
}


/* kv
-----------------------------------------------------------------*/
.kv{
	padding: 60px 5.53vw 30px 1.95vw;
	background: var(--green);
}
.kv .layout-box{
	position: relative;
	z-index: 6000;
	align-items: center;;
}
.kv .pic{
	width: 42.32vw;
	transition-delay: 2s;
}
.kv .txt-area{
	width: 42.06vw;
	transition-delay: 1.5s;
}
.kv h1{
	margin-bottom: 5.21vw;
}
.kv .page-nav{
	justify-content: space-between;
	width: 32.55vw;
	margin-left: auto;
}
.kv .page-nav li{
	width: 47%;
}
.kv .page-nav li:nth-child(n+3){
	margin-top: 30px;	
}


/* sec-about
-----------------------------------------------------------------*/
.sec-about {
	scroll-margin-top: 82px;
}
.sec-about-inner{
	position: relative;
	margin: 0 4.88vw;
	padding: 60px 0 160px 22.92vw;
}
.about01 .sec-about-inner{
	position: relative;
	margin: 0 4.88vw;
	padding: 60px 0 130px 22.92vw;
}
.sec-about .sec-hd{
	position: relative;
	margin-bottom: 80px;
}

.ico-about{
	position: absolute;
	left: -3.26vw;
	top: min(-3.91vw,-60px);
	transform: translateX(-100%);
	width: min(12.7vw,195px);
	line-height: 1;
}
.ico-about .en{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	font-size: min(5.21vw,8rem);
	letter-spacing: -.05em;
}
.ico-about .circle{
	display: inline-block;
	animation: rotation 18s linear infinite running;
}
.sec-about .sec-hd h2{
	margin-bottom: 20px;
    font-size: min(2.28vw, 3.5rem);
    line-height: 1.3;
}
.sec-about .sec-hd h3 {
    font-size: 1.6rem;
    line-height: 1.6;
}
.sec-about .sec-hd .txt-lead{
	font-size: min(1.5vw,2.3rem);
	
	line-height: 1.3;
	text-align: left;
}
.sec-about .sec-hd .txt{
	margin-top: 30px;	
}
.sec-about .pic-main{
	margin: 0 -4.88vw 60px -12.11vw;
}
.sec-about .pic-main img{
	width: 100%;
	height: 420px;
	object-fit: cover;
	border-radius: 100px 0 0 10px;
}
.sec-about .layout-box .txt-area h3,
.sec-about .layout-box .cont-area h3{
	margin-bottom: 45px;
	font-size:min(1.76vw,2.7rem);
	line-height: 1.5;
}
.sec-about .txt-area .btn-list{
	display: flex;
	justify-content: space-between;
	margin-top: 35px;
}
.sec-about .txt-area .btn-list li{
	width: 47%;
}
.sec-about .txt-area .btn-list .btn-highlight a{
	font-size:min(1.04vw,1.6rem);
	border-bottom-color: #ccc;
}
.sec-about.national-qualifications_wrap .sec-about-inner {
	padding: 0px 0 160px 22.92vw;
}

/* about01
-----------------------------------------------------------------*/
.about01 .layout-box + .layout-box{
	flex-direction: row-reverse;
	margin-top: 90px;
}
.about01 .pic-ttl{
	width: 19.86vw;
	margin: 0 2.6vw;
}
.about01 .layout-box .cont-area{
	width: 50.3%;
}
.about01 .layout-box .cont-area .pic{
	margin-top: 50px;
}


/* about02
-----------------------------------------------------------------*/
.about02 .layout-box + .layout-box{
	flex-direction: row-reverse;
	margin-top: 90px;
}
.about02 .layout-box .pic{
	width: 42.14%;
}
.about02 .layout-box .txt-area{
	width: 50.3%;
}

/* about03
-----------------------------------------------------------------*/
.about03 .layout-box .txt-area{
	width: 32.55vw;
}

.about03 .layout-box .pic-area{
		width: 33.46vw;
		margin-right: -4.88vw;
}
.about03 .layout-box .pic-area p:nth-child(1){
	width: 22.14vw;
	margin: 0 0 20px auto;
}
.about03 .layout-box .pic-area p:nth-child(2){
	width: 15.3vw;
}
.about03 .union{
	margin: 50px -4.88vw 0 0;
	padding: 70px 6.51vw 70px 4.56vw;
	background: var(--beige);
}
.about03 .union .txt-area{
	width: 49.8%;
}
.about03 .union .txt-area h3{
	margin-bottom: 30px;
}
.about03 .union .pic{
	width: 43.8%;
}

/* national-qualifications_wrap
-----------------------------------------------------------------*/
.national-qualifications_wrap .national-qualifications{
	display: flex;
	margin-bottom: 70px;
}
.national-qualifications_wrap .national-qualifications h3{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 10.55vw;
	text-align: center;
	background: var(--beige);
	font-size: min(1.17vw,1.8rem);
	line-height: 1.5;
}
.national-qualifications_wrap .national-qualifications h3 .ico{
	display: block;
}
.national-qualifications_wrap .national-qualifications h3 small{
	display: block;
	font-size: 1.1rem;
}
.national-qualifications_wrap .national-qualifications dl{
	padding: 20px 0;
	margin-left: 3.65vw;
}
.national-qualifications_wrap .national-qualifications dl > div:nth-child(n+2){
	margin-top: 15px;
}
.national-qualifications_wrap .national-qualifications dl dt{
	margin-bottom: 15px;
	font-size:min(1.04vw,1.6rem);
}
.national-qualifications_wrap .national-qualifications dl dt::before {
    margin-right: 0.5vw;
    color: #AFDCDD;
    line-height: 1.3vw;
}
.national-qualifications_wrap .national-qualifications dd ul{
	display: flex;
	flex-wrap: wrap;
}
.national-qualifications_wrap .national-qualifications dd ul li{
	width: 165px;
	margin: 0 15px 15px 0;
}

.national-qualifications_wrap .pic-main{
	margin-bottom: 100px;
}
.national-qualifications_wrap .layout-box + .layout-box{
	flex-direction: row-reverse;
	margin-top: 130px;
}
.national-qualifications_wrap .layout-box .pic{
	width: 42.14%;
}
.national-qualifications_wrap .layout-box .txt-area{
	width: 50.3%;
}

.national-qualifications_wrap .layout-box .txt-area .layout-box-ttl {
	font-size: 1rem;
    font-weight: 600;
    margin: 10px 0 0;
    display: inline-block;
}
.national-qualifications_wrap .layout-box .txt-area .txt01 {
    margin: 5px 0 0;
}





















/*--------------------------------------------------------------------------
   mobile
---------------------------------------------------------------------------*/
@media screen and (max-width: 768px) {
	.header-inner{
		background: transparent;
	}
	header.scroll .header-inner{
		background: var(--light);
	}
	.content{
		margin-top: 0;
	}

	.side-ttl{
		width: 30vw;
		background-position: left -3vw top;
		background-size: 30vw auto;
	}


/* kv
-----------------------------------------------------------------*/
	.kv{
		padding: 110px 6.25vw 40px 9.38vw;
	}
	.kv .layout-box{
		display: block;
	}
	.kv .pic{
		width: auto;
		margin-bottom: 40px;
	}
	.kv .pic img{
		border-radius: 10px;
	}
	.kv .txt-area{
		width: auto;
	}
	.kv h1{
		margin-bottom: 40px;
	}
	.kv .page-nav{
		justify-content: space-between;
		width: auto;
		margin-left: 0;
	}
	.kv .page-nav li{
		width: 47%;
	}
	.kv .page-nav li:nth-child(n+3){
		margin-top: 30px;	
	}


/* sec-about
-----------------------------------------------------------------*/
	.sec-about-inner{
		margin: 0; 
		padding: 60px 6.25vw 50px;
	}
	.sec-about{
		scroll-margin-top: 53px;
	}
	.sec-about .sec-hd{
		margin-bottom: 50px;
	}
	
	.ico-about{
		position: relative;
		left: auto;
		top: auto;
		transform: none;
		width: 146px;
		margin: 0 auto 50px;
	}
	.ico-about .en{
		font-size: 6rem;
	}
	.sec-about .sec-hd h2{
		margin-bottom: 10px;
		font-size: 2.4rem;
		line-height: 1.3;
		text-align: center;
	}
	.sec-about .sec-hd .txt-lead{
		font-size: 2rem;
		text-align: justify;
		line-height: 1.5;
	}
	.sec-about .sec-hd .txt{
		margin-top: 25px;
		text-align: justify;
		line-height: 2;
	}
	.sec-about .pic-main{
		margin: 0 -6.25vw 50px 0;
	}
	.sec-about .pic-main img{
		height: 200px;
		border-radius: 80px 0 0 8px;
	}
	.sec-about .layout-box{
		display: block;
	}
	.sec-about .layout-box .txt-area h3,
	.sec-about .layout-box .cont-area h3{
		margin-bottom: 25px;
		font-size: 2.3rem;
	}
	.sec-about .layout-box .txt-area .txt,
	.sec-about .layout-box .cont-area .txt{
		line-height: 2;
		text-align: justify;
	}
	.sec-about .txt-area .btn-list{
		display: block;
		margin-top: 40px;
	}
	.sec-about .txt-area .btn-list li{
		width: 100%;
	}
	.sec-about .txt-area .btn-list li:nth-child(n+2){
		margin-top: 20px;
	}
	.sec-about .txt-area .btn-list .btn-highlight a{
		font-size: 1.2rem;
	}
	.sec-about.national-qualifications_wrap .sec-about-inner {
		padding: 60px 6.25vw 50px;
	}


/* about01
-----------------------------------------------------------------*/
	.about01 .sec-about-inner{
		margin: 0;
        padding: 60px 6.25vw 0px;
	}
	.about01 .layout-box + .layout-box{
		flex-direction: row-reverse;
		margin-top: 90px;
	}
	.about01 .pic-ttl{
		width: 230px;
		margin: 0 auto 40px;
	}
	.about01 .layout-box .cont-area{
		width: 100%;
	}
	.about01 .layout-box .cont-area .pic{
		margin-top: 40px;
	}


/* about02
-----------------------------------------------------------------*/
	.about02 .layout-box + .layout-box{
		margin-top: 50px;
	}
	.about02 .layout-box .pic{
		margin-top: 30px;
		width: 100%;
	}
	.about02 .layout-box .txt-area{
		width: 100%;
	}

/* about03
-----------------------------------------------------------------*/
.about03 .sec-about-inner{
	padding-top: 110px;
}
.about03 .layout-box .txt-area{
	width: 100%;
	margin-bottom: 40px;
}

.about03 .layout-box .pic-area{
		width: 100%;
		margin-right: 0;
}
.about03 .layout-box .pic-area p:nth-child(1){
	width: 61.88vw;
	margin: 0 -6.25vw 10px auto;
}
.about03 .layout-box .pic-area p:nth-child(2){
	width: 42.81vw;
}
.about03 .union{
	margin: 50px -6.25vw 0 0;
	padding: 50px 6.25vw 50px 12.5vw;
}
.about03 .union .txt-area{
	width: 100%;
	margin-bottom: 30px;
}
.about03 .union .txt-area h3{
	margin-bottom: 25px;
	font-size: 1.8rem;
}
.about03 .union .pic{
	width: 100%;
}


/* about04
-----------------------------------------------------------------*/
	.national-qualifications_wrap .national-qualifications{
		display: block;
		margin-bottom: 50px;
	}
	.national-qualifications_wrap .national-qualifications h3{
		width: 100%;
		height: 60px;
		margin-bottom: 20px;
		font-size: 1.3rem;
		line-height: 1;
	}
	.national-qualifications_wrap .national-qualifications h3 .ico{
		display: inline-block;
		margin-right: 5px;
		width: 18px;
	}
	.national-qualifications_wrap .national-qualifications h3 small{
		display: inline;
		font-size: 1rem;
	}
	.national-qualifications_wrap .national-qualifications dl{
		padding: 0 6.25vw;
		margin-left: 0;
	}
	.national-qualifications_wrap .national-qualifications dl > div:nth-child(n+2){
		margin-top: 20px;
	}
	.national-qualifications_wrap .national-qualifications dl dt{
		margin-bottom: 15px;
		font-size: 1.3rem;
	}
	.national-qualifications_wrap .national-qualifications dl dt::before {
			margin-right: 5px;
			line-height: 2;
	}
	.national-qualifications_wrap .national-qualifications dd ul{
		justify-content: space-between;
		padding-inline: 10px;
	}
	.national-qualifications_wrap .national-qualifications dd ul li{
		width: 46.2%;
		margin: 0;
	}
	.national-qualifications_wrap .national-qualifications dd ul li:nth-child(n+3){
		margin-top: 15px;
	}
	.national-qualifications_wrap .national-qualifications dd ul img{
		width: 100%;
	}
	
	.national-qualifications_wrap .pic-main{
		margin-bottom: 50px;
	}
	.national-qualifications_wrap .layout-box + .layout-box{
		margin-top: 50px;
	}
	.national-qualifications_wrap .layout-box .pic{
		width: 100%;
		margin-top: 40px;
	}
	.national-qualifications_wrap .layout-box .txt-area{
		width: 100%;
	}


}