
/* ============================================================
PC
==============================================================*/

@media (min-width: 762px) {

	
	/* ============================================================
 	main_wrap2
	==============================================================*/

	
	
	.scroll_v{
			z-index: 9;
			width: 50px;
			position: absolute;
			bottom: -38px;
			right: 94%;
			transform:translate(-50%, -50%);
	}
	
    .cover{
		width:100%;
		height:100vh;
		left:0;
		top:0;
		background:#fff;
		position:absolute;
		z-index:20;
		transition: all 1.5s cubic-bezier(0, 0, 0, 0) 0.25s;
	}
	.cover_act{
		opacity:0
	}
    
	#main_wrap2{
		width: 100%;
		height: calc(100vh - 170px);
		position: relative;
		overflow: hidden;
		background:url("/guidance/icd/img/mv_bg_pc.jpg") no-repeat center;
		background-size: cover;
	}

	#main_wrap2:before{
		display:block;
		content:"";
		width: 100%;
		height: 100vh;
		position: absolute;
		top:0;
		left:0;
		background:url("/guidance/icd/img/mv_bg_txt_pc.svg") no-repeat center;
		background-size: cover;
	}
	
	#main_wrap2 .txt_wrap{
		width: 27vw;
		max-width: 400px;
		position: absolute;
		top: 10%;
		left: calc(50% + 310px);
		transform: translate(-50%, 0);
		z-index: 30;
	}

	#main_wrap2 h1{
		line-height: 0;
	}

	#new_point{
		position:absolute;
		bottom: 40px;
		right:-10px;
		border-radius:40px 0 0 40px;
	}

	#new_point a{
		display:block;
		background: linear-gradient( to right,  #df9937 10%, #d67f94 40%, #6998c6 80% );
		padding:15px 66px 13px 50px;
		border-radius:40px 0 0 40px;
		color:#fff;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight:600;
		line-height:1.2;
		position:relative;
	}

	#new_point a:before{
		content: "";
		display: block;
		width:24px;
		height:24px;
		border:1px solid #ffffff8c;
		background:#ffffff2b;
		border-radius:50%;
		position: absolute;
		top: 50%;
		right:30px;
		transform:translate(0, -50%);
		animation: p_loop 1.5s infinite cubic-bezier(0.13, 0.38, 0.43, 0.99);
	}
	#new_point a:after{
		content: "+";
		display: block;
		font-size:2.2rem;
		font-weight:300;
		color:#ffffffc9;
		line-height:1;
		position: absolute;
		top: 48%;
		right:37px;
		transform:translate(0, -50%);
	}

	#new_point a .sa{
		display:inline-block;
		font-size:1.6rem;
		letter-spacing:0rem;
	}
	#new_point a .sb{
		display:inline-block;
		font-size:1.4rem;
		letter-spacing:0rem;
		padding:0 0 0 2px;
	}

	#new_point a .sc{
		display:inline-block;
		font-size:2.3rem;
		letter-spacing:0rem;
		font-weight:400;
		margin:0 0 0 -2px;
	}

	#new_point a .sd{
		display:inline-block;
		font-size:1.8rem;
		letter-spacing:0rem;
		padding:0 4px 0 3px;
	}

	#new_point a .se{
		display:inline-block;
		font-size:2.3rem;
		letter-spacing:0rem;
	}

	#new_point a{
		transition: all 0.5s cubic-bezier(0.12, 0.51, 0.3, 0.98);
	}

	#new_point a:hover{
		opacity:0.7;
	}

	#new_point{
		transition: all 0.5s cubic-bezier(0.12, 0.51, 0.3, 0.98);
	}

	#new_point:hover{
		transform:translate(-10px,0);
		background:#fff;
	}
	

	
	/* ============================================================
 	Modal CSS
	==============================================================*/
	
	#modal_win {
		position: fixed;
		top: 0;
		left: 0;
		background: rgba(0,0,0);
		width: 100vw;
		height: 100vh;
		z-index: 10000;
		display: none;
		cursor: pointer;
	}

	#modal_win .m_n_wrap {
		position: relative;
		width: 100%;
		height: 100vh;
	}

	#modal_win .m_n_box,#modal_win .m_n_box_teach {
		display:none;
		position: absolute;
		top: 48%;
		left: 50%;
		transform:translate(-50%, -50%);
		opacity:0;
		width: 60vw;
		transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
	}

	#modal_win .m_n_box_mov {
		display:none;
		position: absolute;
		top: 48%;
		left: 50%;
		transform:translate(-50%, -50%);
		opacity:0;
		width: 70vw;
		transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
	}

	#modal_win .m_n_box_act{
		display:block;
		opacity:1;
		transform:translate(-50%, -50%);
	}

	#modal_win iframe{
		display:none;
		width:calc(70vw);
		height:calc(70vw*315/560);
		max-height:680px;
	}

	#modal_win .m_n_box_act iframe{
		display:block;
	}

	
    
   #modal_win h2{
	   display:block;
	   font-family: 'Noto Sans JP', sans-serif;
	   font-weight:500;
	   font-size: 2.8rem;
	   text-align:center;
	   color:#fff;
	   padding: 0 0 5px;
	   font-feature-settings: 'palt';
	  }

	#modal_win h3{
	   display:block;
	   font-family: 'Noto Sans JP', sans-serif;
	   font-weight:500;
	   font-size: 2.4rem;
	   line-height: 1.4;
	   text-align:center;
	   color:#000;
	   padding: 0 0 8px;
	   font-feature-settings: 'palt';
	  }

	#modal_win p{
	   display:block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight:400;
		font-size: 1.5rem;
		color:#000;
	   padding:0 0 10px;
		font-feature-settings: 'palt';
   }
	
	#modal_win .btn_list_a{
		display:flex;
		justify-content:center;
		gap:0 8px;
		padding: 0 0 20px;
	}

	#modal_win .btn_list_a a{
		display:block;
		box-sizing:border-box;
		width:50px;
		height:50px;
		font-family: 'Barlow', sans-serif;
		font-weight:400;
		font-size: 2.6rem;
		line-height:1;
		text-align:center;
		color:#fff;
		border-radius:50%;
		border:2px solid #fff;
		padding:9px 2px 0 0;
		transform:scale(0.9);
	}

	#modal_win .btn_list_a a.act{
		background:#fff;
		color:#000;
		transform:scale(1.05);
	}

	#modal_win .w_con_wrap{
		background:#fff;
		box-sizing: border-box;
		min-height: 352px;
		border-radius: 30px;
		padding: 5px 100px 40px;
		position:relative;
	}

	#modal_win .w_con_wrap .num{
		display:block;
		font-family: 'Barlow', sans-serif;
		font-weight:600;
		font-size: 4.6rem;
		color: #000;
		text-align:center;
		position:relative;
	}

	#modal_win .w_con_wrap:before{
		content: "";
		display: block;
		width:50px;
		height:10px;
		background:#fff100;
		position: absolute;
		top: 58px;
		left: 50%;
		transform:translate(-50%,0);
	}
	
	#modal_win .m_n_wrap > ul > li{
		position:fixed;
		top: 20px;
		right: 20px;
	}

	#modal_win .m_n_box_teach {
		background: url("/guidance/icd/img/sec_teach_bg.gif");
		border-radius: 30px;
		overflow:hidden;
		width: 1060px;
	}

	#modal_win .w_con_wrap_teach{
		display:none;
		justify-content:space-between;
		box-sizing: border-box;
		max-height: 70vh;
		overflow-y: auto;
		margin:30px;
		padding: 20px 30px 0 20px;
		gap: 0 20px;
	}

	#modal_win .m_n_box_act .w_con_wrap_teach{
		display:flex;
	}

	#modal_win .w_con_wrap_teach .photo_box{
		width: 256px;
		height: 250px;
		line-height: 0;
		border-radius: 20px;
		overflow: hidden;
	}

	#modal_win .w_con_wrap_teach h2{
	   display:block;
	   font-family: 'Noto Sans JP', sans-serif;
	   font-weight:500;
	   font-size: 2.4rem;
	   text-align:left;
	   color:#fff;
	   padding: 0 0 5px;
	   letter-spacing: 0.2rem;
	   border-bottom:1px solid #fff;
	   margin: 0 0 30px;
	   font-feature-settings: 'palt';
	  }

	#modal_win .w_con_wrap_teach h2 span{
		font-size: 1.5rem;
		padding:0 0 0 20px;
	}

	#modal_win .w_con_wrap_teach li{
		display:flex;
		justify-content: space-between;
		flex-wrap:wrap;
		margin: 0 0 20px;
	}

	#modal_win .w_con_wrap_teach h3{
	   display:block;
	   width: 80px;
	   font-family: 'Noto Sans JP', sans-serif;
	   font-weight:600;
	   font-size: 1.5rem;
	   line-height: 1.4;
	   text-align:left;
	   color:#fff;
	   padding: 4px 0 0 14px;
	   position: relative;
	   font-feature-settings: 'palt';
	  }
	#modal_win .w_con_wrap_teach h3:before{
		content: "";
		display: block;
		width: 6px;
		height: 6px;
		background:#c2c2c2;
		position: absolute;
		top: 13px;
		left:0;
	}

	#modal_win .w_con_wrap_teach h3.f_ttl{
		width:100%;
		padding: 4px 0 10px 14px;
		margin: 10px 0 0;
	}

	#modal_win .w_con_wrap_teach p{
	   width: 520px;
	   display:block;
	   font-family: 'Noto Sans JP', sans-serif;
	   font-weight: 300;
	   font-size: 1.5rem;
	   letter-spacing: 0.1rem;
	   color:#fff;
	   padding: 0;
	   font-feature-settings: 'palt';
	  }

	#modal_win .w_con_wrap_teach p.f_body{
		width:100%;
		padding: 0 0 10px 13px;
	}

	#modal_win .w_con_wrap_teach .photo_box img{
		transform:scale(1.1) translate(0,10px);
	}

	#modal_win .w_con_wrap_teach .txt_wrap{
		width:620px;
	}
	
	
	#modal_win a.xClose{
		display:block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight:400;
		font-size: 1.6rem;
		text-align:center;
		color:#fff;
		position: relative;
	}

	#modal_win a.xClose span{
		display:block;
		width:50px;
		line-height:0;
		border-radius:50%;
		border:2px solid #fff;
	}

	#modal_win a.xClose span{
		transition: all 0.4s cubic-bezier(0.12, 0.74, 0.36, 1);
	}

	#modal_win a.xClose:hover span{
		transform: scale(1.1);
	}

	#modal_win .btn_list_a a{
		transition: all 0.4s cubic-bezier(0.12, 0.74, 0.36, 1);
	}

	#modal_win .btn_list_a a:hover{
		background:#fff;
		color:#000;
	}



	/* ============================================================
 	sec01
	==============================================================*/
	
	#sec01{
		width: 100%;
		padding: 120px 0 140px;
		overflow:hidden;
	}

	#sec01 .wrapper{
		position:relative;
	}

	#sec01 .ttl_wrap{
		display:flex;
		justify-content:space-between;
		padding: 0 0 50px;
	}
	
	#sec01 h2{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 600;
		font-size: 7.3rem;
		line-height:1.2;
		color: #000;
		font-feature-settings: 'palt';
		letter-spacing:0.2rem;
		padding: 10px 0 0;
	}

	#sec01 h2 span.eng_txt{
		display:block;
		font-family: 'Barlow', sans-serif;
		font-weight: 600;
		font-size:2.4rem;
		padding:0 0 5px 5px;
	}

	#sec01 h2 span.sa{
		display:inline-block;
		font-size:5.2rem;
	}

	#sec01 .ttl_wrap p{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		font-size: 1.5rem;
		color:#000;
		line-height:2.2;
		font-feature-settings: 'palt';
		letter-spacing: 0.1rem;
		padding: 47px 0 0;
	}


	#sec01 .img_box{
		line-height:0;
		width:464px;
		margin:0 auto;
	}

	#sec01 .swiper-slide h3{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 600;
		font-size: 1.8rem;
		line-height:1.2;
		color: #fff;
		background: #8ab3d8;
		border-radius: 20px;
		text-align: center;
		font-feature-settings: 'palt';
		letter-spacing:0.2rem;
		padding: 6px 0 6px;
	}

	#sec01 .swiper-slide h3 span{
		display:inline-block;
		font-size: 1.4rem;
		padding:0 0 0 5px;
	}

	#sec01 .swiper-slide p{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		font-size: 1.4rem;
		line-height:1.6;
		color: #000;
		font-feature-settings: 'palt';
		letter-spacing:0.2rem;
		padding: 10px 18px;
	}

	#sec01 .ttl_a{
		display: block;
		width:376px;
		position:absolute;
		top: -444px;
		left:0;
	}

	#sec01 .ttl_b{
		display: block;
		width: 304px;
		position:absolute;
		top: -258px;
		left:0;
	}

	#sec01 .ttl_c{
		display: block;
		width: 330px;
		position:absolute;
		top: -444px;
		right:0;
	}

	#sec01 .ttl_b h3{
		background:#e39db0;
	}

	#sec01 .ttl_c h3{
		background:#df9937;
	}

	


	/* ============================================================
 	sec02
	==============================================================*/
	
	#sec02{
		width: 100%;
		padding: 70px 0 120px;
		position:relative;
	}
	
	#sec02:before{
		content: "";
		display: block;
		width: 100%;
		height: 250px;
		background: #333333;
		position: absolute;
		bottom:0;
		left:0;
	}

	
	#sec02 .wrapper{
	text-align: center;
	}
	
	#sec02 h2{
		display:inline-block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size: 2.8rem;
		color: #333333;
		font-feature-settings: 'palt';
		margin: 0 0 30px;
		letter-spacing:0.2rem;
		position:relative;
	}

	#sec02 h2 span.gakubu{
		font-family: 'Noto Sans JP', sans-serif;
		font-size: 1.8rem;
		color:#fff;
		background:#599A5C;
		padding: 0px 14px 2px;
		border-radius: 4px;
		vertical-align: text-top;
		margin: 4px 5px 0 0;
		display: inline-block;
		font-weight: 500;
		letter-spacing: 0.1rem;
	}

	#sec02 h2 span.sb1{
		font-weight: 600;
		font-size: 3.6rem;
	}


	#sec02 ul{
		display: flex;
		justify-content: space-between;
		/* align-items: center; */
		flex-wrap: wrap;
		gap: 26px 0;
	}

	#sec02 ul li{
		width: 350px;
	}

	#sec02 ul li a{
		display: block;
		position: relative;
		height: 100%;
		border-radius: 10px;
		overflow: hidden;
	}

	#sec02 .img_box_01 {
		line-height: 0;
	}


	#sec02 .img_box_02 {
		position: absolute;
		line-height: 0;
		top: 0;
		left: 0;
		width: 100%;
	}

	#sec02 ul li a img {
		transition: all 0.5s ease 0s;
	}
	
	#sec02 ul li a:hover img {
		transform: scale(1.1);
	}

	#sec02 ul li a {
		transition: all 0.5s ease 0s;
	}
	
	#sec02 ul li a:hover {
		transform: scale(1);
	}

	/* ============================================================
 	sec_c_nav
	==============================================================*/
	
	#sec_c_nav{
		width: 100%;
		background: #fff;
		padding: 0 0 40px;
	}
	
	#sec_c_nav .wrapper{
		text-align:center;
		position:relative;
	}

	#sec_c_nav .wrapper:before{
		content: "";
		display: block;
		width: 100%;
		height: 250px;
		border-radius:10px;
		background: linear-gradient(to right, #ebebeb 50%, #ffffff00 100%);
		position: absolute;
		bottom:0;
		left:0;
	}
	
	#sec_c_nav h2{
		display:inline-block;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size: 2.8rem;
		color: #333333;
		font-feature-settings: 'palt';
		margin: 0 0 30px;
		letter-spacing:0.2rem;
		position:relative;
	}

	#sec_c_nav h2 span.gakubu{
		font-family: 'Noto Sans JP', sans-serif;
		font-size: 1.8rem;
		color:#fff;
		background:#599A5C;
		padding: 0px 14px 2px;
		border-radius: 4px;
		vertical-align: text-top;
		margin: 2px 5px 0 0;
		display: inline-block;
		font-weight: 500;
		letter-spacing: 0.1rem;
	}

	#sec_c_nav h2 span.sb1{
		font-weight: 600;
		font-size: 3.6rem;
	}

	
	#sec_c_nav ul{;
		padding:0 200px 80px;
	}

	#sec_c_nav ul li{
		width:100%;
	}

	#sec_c_nav ul li a{
		display:block;
		border-radius: 10px;
		padding: 0;
		overflow: hidden;
		border: 2px solid #599A5C;
		position: relative;
	}

	#sec_c_nav ul li a .img_box{
		line-height:0;
	}

	#sec_c_nav ul li a h3{
		width:105%;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 300;
		font-size: 2.8rem;
		line-height: 1.3;
		text-align:center;
		color:#fff;
		font-feature-settings: 'palt';
		letter-spacing: 0.1rem;
		background: #599a5ccc;
		padding: 0 0 14px;
		position:absolute;
		left:0;
		bottom:0;
	}

	#sec_c_nav ul li a h3 span.gakubu{
		font-size:1.2rem;
		display: inline-block;
		border:1px solid #fff;
		padding: 1px 10px 0;
	}

	#sec_c_nav ul li a h3 span.sb{
		font-weight: 500;
	}

	#sec_c_nav ul li a p{
		font-family: 'Barlow', sans-serif;
		font-weight: 500;
		font-size: 1.6rem;
		line-height:1;
		text-align: center;
		color:#ce93b9;
		font-feature-settings: 'palt';
		letter-spacing: 0.1rem;
		padding: 8px 0 0 9px;
	}

	#sec_c_nav ul li a p:after{
		content: '\3009';
		display:inline-block;
		padding:0 0 0 7px;
		font-weight: 600;
		font-size: 1.4rem;
	}

	#sec_c_nav ul  a img{
		transition: all 0.5s cubic-bezier(0.08, 0.64, 0.25, 1) 0s;
	}

	#sec_c_nav ul  a:hover img {
		transform: scale(1.1);
	}


	#sec_c_nav ul  a {
		transition: all 0.5s cubic-bezier(0.08, 0.64, 0.25, 1) 0s;
	}
	
	#sec_c_nav ul  a:hover {
		transform: scale(1.05);
		background:#fff;
	}

	
	

	/* ============================================================
 	section other
	==============================================================*/
	
	#sec_other{
		width: 100%;
		padding: 70px 0 120px;
		background:#fff;
	}
	
	#sec_other .wrapper{
	text-align: center;
	}
	
	#sec_other h2{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 300;
		font-size: 3.2rem;
		line-height: 1.4;
		color: #000000;
		margin: 0 auto 40px;
		display: inline-block;
		position: relative;
		padding: 0 8px 3px 8px;
		letter-spacing: 0.03em;
	}

	#sec_other h2 span.sa{
		font-family: 'Barlow', sans-serif;
		font-weight:600;
		font-size: 3.4rem;
	}

	#sec_other h2 span.sb{
		display:block;
	}
	#sec_other h2 span.sc{
		display:inline-block;
		font-family: 'Barlow', sans-serif;
		font-weight:600;
		font-size: 3.6rem;
		vertical-align:text-top;
		margin: 0px 3px 0 0;
	}
	#sec_other h2 span.sd{
		display:inline-block;
		font-weight:400;
		font-size: 2.2rem;
	}

	#sec_other h2::before{
		content: '';
		display: block;
		width: 100%;
		height: 1px;
		background: #000000;
		position: absolute;
		top: 45px;
		left: 0;
	}


	#sec_other ul{
		display: flex;
		justify-content: center;
		align-items: center;
		gap: 20px;
	}

	#sec_other ul li{
		width: 340px;
	}

	#sec_other ul li a{
		display: block;
		position: relative;
		height: 100%;
		border-radius: 10px;
		overflow: hidden;
	}

	#sec_other .img_box_01 {
		line-height: 0;
	}


	#sec_other .img_box_02 {
		position: absolute;
		line-height: 0;
		top: 0;
		left: 0;
		width: 100%;
	}

	#sec_other ul li a img {
		transition: all 0.5s ease 0s;
	}
	
	#sec_other ul li a:hover img {
		transform: scale(1.1);
	}

	#sec_other ul li a {
		transition: all 0.5s ease 0s;
	}
	
	#sec_other ul li a:hover {
		transform: scale(1);
	}

	/* ============================================================
 	sec_nav_other
	==============================================================*/
	
	#sec_nav_other{
		width: 100%;
		padding: 70px 0 80px;
		background:#069aa1;
	}

	#sec_nav_other h2{
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 400;
		font-size: 2.2rem;
		line-height: 1.4;
		color: #ffffff;
		text-align:center;
	}

	#sec_nav_other h2 span{
		display:inline-block;
		font-size: 2.8rem;
		padding:0 5px 0 0;
	}

	#sec_nav_other .more_btn a{
		width: 499px;
		margin: 15px auto 0;
		padding: 12px 38px 14px 60px;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 500;
		font-size: 2.0rem;
		display: block;
		letter-spacing: 0.1em;
		text-align: center;
		color: #069aa1;
		background: #fff;
		border-radius: 50px;
		position: relative;
	}

	#sec_nav_other .more_btn a span{
		display:inline-block;
		font-size: 1.6rem;
		vertical-align: text-bottom;
	}

	#sec_nav_other .more_btn a::before{
		content: '';
		display: block;
		width: 22px;
		height: 22px;
		background-image: url(/global/img/icon_win_green.svg);
		background-repeat: no-repeat;
		background-position: center;
		position: absolute;
		top: 51%;
		left: 34px;
		transform: translate(0, -50%);
	}

	#sec_nav_other ul.more_btn a {
		transition: all 0.5s cubic-bezier(0.08, 0.64, 0.25, 1) 0s;
	}

	#sec_nav_other .more_btn a:hover{
		background:#000;
	}
	

	
}


/* ============================================================
keyframe
==============================================================*/
	
@keyframes p_loop {
  			0% {
    			transform:translate(0,-50%) scale(1);
  			}
  			30% {
    			transform:translate(0,-50%) scale(1.1);
  			}
  			70% {
    			transform:translate(0,-50%) scale(1.1);
  			}
			100% {
    			transform:translate(0,-50%) scale(1);
  			}
		}




