@charset "UTF-8";
@import url("https://use.fontawesome.com/releases/v6.7.2/css/all.css");
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JPwght@400;500;700&display=swap");

* {
      -webkit-box-sizing: border-box;
         -moz-box-sizing: border-box;
           -o-box-sizing: border-box;
          -ms-box-sizing: border-box;
              box-sizing: border-box;
}

/* base
  ========================================================================== */
body {
	min-width: 1200px;
	font-family: 'M PLUS 1p', sans-serif;
	font-weight: 400;
	counter-reset: number 0;
}

	@media screen and (max-width: 768px) {
	  body {
	    min-width: 320px;
	  }
	}

body.is-fixed:after {
	content: '';
	display: block;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
 	width: 100%;
	height: 100%;
	z-index: 999;
	opacity: 0;
	-webkit-transition: opacity .3s ease;
	transition: opacity .3s ease;
}
body.is-fixed.is-covered:after {
	opacity: 1;
}
/* Container
  ========================================================================== */
.page-container {
	overflow: hidden;
}

a:link{
	color: #0098FF;
    text-decoration: none;
}

a:hover{
	color: #0098FF;
    text-decoration: underline;
}

	@media screen and (max-width: 768px) {
		a:hover{
			color: #2874b4;
		    text-decoration:none;
		}
	}

.sub_b{
	font-size:90%;
	vertical-align: bottom;
}

.sub_t{
	font-size: 90%!important;
	vertical-align: top;
}

.underline{
	text-decoration:underline;
}

.img-responsive {
    display: block;
    height: auto;
    max-width: 100%;
}

.bolder{
	font-weight: 700!Important;
}

.smaller {
	font-size: 80%!Important;
	font-family: 'M PLUS 1p', sans-serif;
    font-weight: 400;
    transform: rotate(0.03deg);
}

.larger{
	font-size: 140%!Important;
}

.nowrap{
	white-space: nowrap;
}

.larger2{
	font-size: 120%!Important;
}


/* 横並び　*/
.flex{
	display: flex;
	align-items: flex-start;
}

.al-end{
	align-items: flex-end;
}

.js_bet{
   	justify-content: space-between;
}

	@media screen and (max-width: 768px) {
		.flex_bet {
		    display: flex;
		    justify-content: space-between;
		    flex-direction: column;
		    padding: 5px 0;
		}


	}
/* ==========================================================================
   Layout - Header
   ========================================================================== */
.page-header {
	position: relative;
	min-width: 1200px;
	z-index: 5;
}

/* ヘッダー固定　*/
.fixed {
    position: fixed;
    top: 0;
    background-color: #110E5D;
	border-bottom: 5px double #eee;
    width: 100%;
}

	@media screen and (max-width: 768px) {
		  .page-header {
		    position: fixed;
		    top: 0;
		    left: 0;
		    right: 0;
		    min-width: 320px;
		    z-index: 1000;
		    background-color: #fff;
		  }
	}

.page-header_inner {
	zoom: 1;
	display :flex;
	justify-content: space-between;
	align-items: center;
	width: 90%;
	margin: 5px auto;	
}

@media screen and (max-width: 768px) {
	  .page-header_inner {
	    width: 100%;
	    margin: 0;
	    background: #110E5D;
	    align-items: center;
	    justify-content: space-between;
	  }
}



	@media screen and (max-width: 768px) {
		  .page-header_logo {
				margin-left: 10px;
		  }
		  .page-header_logo .page-header_logo_object img {
		    	width: 90%;
		    	height: auto;
		  }
	}
	
	
.lang_link{
	display: flex;
	justify-content: flex-end;
	margin: 0 0 0 30px;
	font-size: 15px;
	transform: rotate(0.03deg);
}	

.lang_link .white{
	color: #fff;
	display: flex;
	align-items: center;
}

.lang_link a{
	color: #ccc;
	font-weight: 500;	
	text-decoration: none;
}

.lang_link a:hover{
	color: #fff;
	text-decoration: none;
}

.lang_link .active{
	color: #fff;
	font-weight: 500;
}

	@media screen and (max-width: 768px) {
		.lang_link_sp{
			display: flex;
			justify-content: flex-end;
			margin: 8px 10px 5px 0;
			font-size: 15px;
			transform: rotate(0.03deg);
		}	
		
		.lang_link_sp .white{
			color: #fff;
		}
		
		.lang_link_sp a{
			color: #fff;
			font-weight: 500;	
			text-decoration: none;
		}
		
		.lang_link_sp a:hover{
			color: #fff;
			text-decoration: none;
		}
		
		.lang_link_sp .active{
			color: #fff;
			font-weight: 500;
		}

	}

/* selectタイプ　*/
.lang_link select{
	font-size: 14px;
	height: 26px;
}

	@media screen and (max-width: 768px) {
		.lang_link{
			display: none;
		}

	}

.page-header_site-nav_icon {
	float: left;
	display: table;
}
.page-header_site-nav_icon li {
	display: table-cell;
	text-align: center;
	vertical-align: middle;
	-webkit-box-sizing: border-box;
          	box-sizing: border-box;
}
.page-header_site-nav_icon li a {
	display: block;
	overflow: hidden;
}
.page-header_site-nav_icon li a:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
}

.page-header_site-nav_icon li.page-header_nav-button {
	display: none;
}

	@media screen and (max-width: 768px) {
		  .page-header_site-nav_icon {
		    margin: 2px 5px 0 0;
		  }
		  .page-header_site-nav_icon li {
		    width: 49px;
		  }
		  .page-header_site-nav_icon li a {
		    width: 48px;
		    height: 54px;
		    -webkit-transition: all .3s ease;
		    transition: all .3s ease;
		  }
		  .page-header_site-nav_icon li a:hover {
		    opacity: 1;
		    filter: alpha(opacity=100);
		  }

		  .page-header_site-nav_icon li.page-header_nav-button {
		    display: block;
		    float: left;
		    margin: 0;
		  }
		  
		  .page-header_site-nav_icon li.page-header_nav-button a {
		    display: block;
		    width: 44px;
		    height: 54px;
		    white-space: nowrap;
		    text-indent: 100%;
		    overflow: hidden;
		    background: url(../img/header_menu_icon01.png) no-repeat;
		    background-position: 2px;
		    background-size: 44px auto;
		  }
		  .page-header_site-nav_icon li.site-nav_search .is-current,
		  .page-header_site-nav_icon li.page-header_nav-button .is-current {
		    position: relative;
		    z-index: 1001;
		    background-image: url(../img/header_search_close_sp.png);
		  }
	}



/* ==========================================================================
   Global Menu (openのメニュー1件　少な目あり）
   ========================================================================== */
.global-nav-pc {
	display: flex;	
	justify-content: space-between;
	align-items: center;
}

.global-nav-pc ul {
	display: flex;
	justify-content: flex-end; /* 右に寄せたver */
}

.global-nav-pc ul li {
	position: relative;
	padding: 5px 10px;	
	white-space: nowrap;
}

.top .global-nav-pc ul li#top a,
.about .global-nav-pc ul li#about a,
.release .global-nav-pc ul li#release a,
.download .global-nav-pc ul li#download a,
.reference .global-nav-pc ul li#reference a,
.contact .global-nav-pc ul li#contact a{
	color: #ffff00;	
}


.global-nav-pc a {
	display: block;
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	transform: rotate(0.03deg);
	color: #ccc;	
}

.global-nav-pc a:hover {
	color: #fff;
}

	@media screen and (max-width: 768px) {
		.global-nav-pc {
			display: none;
		}
	}


/* ==========================================================================
   smartphone menu
   ========================================================================== */

.page-header_menu-sp {
    display: none;
}

	@media screen and (max-width: 768px) {
	  .page-header_menu-sp {
	    position: absolute;
	    top: 55px; /* smartphone menu位置 */
	    left: 0;
	    right: 0;
	    width: 100%;
	    z-index: 1002;
	    overflow-y: scroll;
	    background: #110E5D;
	  }
	  	  
	}


.global-nav-sp > li {
	line-height: 20px;
}

.global-nav-sp > li:first-child {
	margin-top: 20px;
}

.global-nav-sp > li a {
	display: block;
	position: relative;
	margin: 0 0 20px 10px;
	color: #fff;
	text-decoration: none;
	font-size: 15px;
	font-weight: 500;
	transform: rotate(0.03deg);	
}

.global-nav-sp li#top a:before{
    font-family: "Font Awesome 5 Free";
    content: '\f015';
    font-weight: 900;
  	width: 30px;
  	display: inline-block;
}

.global-nav-sp li#about a:before{
    font-family: "Font Awesome 5 Free";
    content: '\f059';
    font-weight: 900;
  	width: 30px;
  	display: inline-block;
}

.global-nav-sp li#release a:before{
    font-family: "Font Awesome 5 Free";
    content: '\f518';
    font-weight: 900;
  	width: 30px;
  	display: inline-block;
}


.global-nav-sp li#download a:before{
    font-family: "Font Awesome 5 Free";
    content: '\f019';
    font-weight: 900;
  	width: 30px;
  	display: inline-block;

}

.global-nav-sp li#reference a:before{
    font-family: "Font Awesome 5 Free";
    content: '\f02d';
    font-weight: 900;
  	width: 30px;
  	display: inline-block;
}

.global-nav-sp li#board a:before{
    font-family: "Font Awesome 5 Free";
    content: '\f086';
    font-weight: 900;
  	width: 30px;
  	display: inline-block;
}

.global-nav-sp li#contact a:before{
    font-family: "Font Awesome 5 Free";
    content: '\f573';
    font-weight: 900;
  	width: 30px;
  	display: inline-block;
}


	@media screen and (max-width: 768px) {
		.global-nav-sp {
			margin-left:10px;
		}

		.global-nav-sp > li a {
			font-size: 16px;
		}
		
	}

/* Main content
   ========================================================================== */
.content {
    background-color: #fff;
    position: relative;
    top: 30px;
}

/*　下層ページ　*/
.lowercontent {
	margin: 0;
	min-height: 500px;
  	background-color: #ffffff;
}

.title_box{
	width: 100%;
	margin: 55px auto 30px;	
	padding: 30px 0;
	background: #f1f1f1;
}

.title_box h2{
	width: 1160px;
	margin: 0 auto;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: .05em;
    padding: 0 0 0 18px;
	color: #110E5D;
	border-left: 5px solid #110E5D;
}

.lowercontent2 {
	margin: 0;
    background-color: #fff;
	color: #000;
}

.wrapper{
	width: 1160px;
	margin: 0 auto 50px;	
	padding: 0;
	background: #fff;	
}

.wrapper p{
	color: #555;
    font-family: 'M PLUS 1p', sans-serif;
    font-size: 14px;
    font-weight: 400;
    transform: rotate(0.03deg);
}

.wrapper p a{
	text-decoration:underline; 
}


	@media screen and (max-width: 768px) {
		.page-container {
			padding-top: 0;
		}
		
		.lowercontent {
		    padding: 0 2%;
		}
		
		.title_box{
			width: 100%;
			background: #fff;
			margin-bottom: 0;
		}

		.title_box{
			width: 100%;
		}
		
		.wrapper{
			width: 100%;
		}
	}

h2 {
  	font-size: 28px;
  	font-weight: 500;
  	line-height: 44px;
  	margin: 0;
	color: #110E5D;
	transform: rotate(0.03deg);
}

	@media only screen and (max-width: 768px) {
		.title_box h2,
		h2{
			margin: 0;
			font-size: 26px;
			line-height: 34px;	
		}
	}

h3{
	font-family: 'M PLUS 1p', sans-serif;
	font-size: 18px;
	font-weight: 500;
	line-height: 44px;
	transform: rotate(0.03deg);
	color: #000;
	display: inline-block;
}
	@media only screen and (max-width: 480px) {

		h3{
			line-height: 30px;
			margin-bottom: 10px;
		}
	}

	@media only screen and (max-width: 320px) {
		h2{
		    margin: 0;
		    font-size:20px;
			line-height: 32px;			    
		}
		

		#indexContainer,
		#indexContainer2 {
			width: 100%;
			min-width: 320px;
	    	padding: 0 10px;
	  	}
	  	
	}

h3.type01{
	margin-top: 30px;
}

p.mttl {
	font-size: 20px;
	font-weight: 500;
	line-height: 44px;
	transform: rotate(0.03deg);
	color: #110E5D;
}

/* PDFリンク　*/
.lnk-pdf:before{
	font-family: "Font Awesome 5 Free";
    content: '\f1c1';
    font-weight: 900;
    padding-right: 5px;
}

/* ==========================================================================
  　TOP
   ========================================================================== */
.attention {
	margin: 0 auto;
	padding-bottom: 40px;
	width: 1200px;
}	

.attention li{
	font-size: 12px;
	font-family: 'M PLUS 1p', sans-serif;
    font-weight: 400;
    transform: rotate(0.03deg);
}

	@media only screen and (max-width: 768px) {
		.attention {
			width: 90%;
		}
		
	}

/* ==========================================================================
  　main
   ========================================================================== */

.main_block {
	width: 100%;
	height: 220px;
    display: flex;
    justify-content: space-between;
    align-items: center;
	margin: 0 auto;
	background-image: url(../img/mainvisual.jpg);
	background-position: center center;
	background-repeat: no-repeat;
	background-size:cover;
}



	@media only screen and (max-width: 768px) {
		.main_block{
			width:100%;
			margin:0;
			padding: 50px 0 10px; 
			display: block;
		}
		
		.copy {
		    width: 90%;
    		margin: 0 auto 20px;
		    text-align: center;
		}
		
		.copy h2{
			font-size: 36px;
			line-height: 44px;
		}
		
		.thumnail_pc{
			display: none;
		}
		
		.thumnail_sp {
			display: block;
	    	width: 90%;
	    	margin: 20px auto;
		}		
	}	


/* ==========================================================================
  　訴求エリア
   ========================================================================== */ 
.indexContainer{
	width: 100%;
	margin: 0;
	background: #ffffff;
}

.indexContainer2{
	width: 100%;
	margin: 0;
	background: #f3f3ff;
}


.flex_topic {
    width: 1200px;
    margin: 0 auto;
    padding: 40px 0 50px;
    display: flex;
   	justify-content: space-between;
}

.flex_topic .msg{
	width: 70%;	
}

.flex_topic .msg h3{
	font-size: 24px;
	font-weight: 500;
	margin-bottom: 20px;
	color: #110E5D;
}

.flex_topic p{
	margin: 10px 0;
	color: #555;
	font-family: 'M PLUS 1p', sans-serif;
    font-size: 15px;
    font-weight: 400;
    transform: rotate(0.03deg);
}

.flex_topic img{
	height: 230px;
}

.flex_topic .img img{
	height: 200px;
}


.morelink a{
	float: right;
	margin-top: 10px;
	font-family: 'M PLUS 1p', sans-serif;
	font-size: 13px;
	font-weight: 500;
	line-height: 18px;
	transform: rotate(0.03deg);
	color: #2874b4;
}

.morelink a:hover{
	color: #110E5D;	
	text-decoration: none;
}

.morelink a:before{
	color: #2874b4;
	font-family: "Font Awesome 5 Free";
    content: '\f054';
    font-weight: 900;
    padding-right: 5px;
}

	@media only screen and (max-width: 768px) {		
		.indexContainer,
		.indexContainer2 {
			width: 100%;
			min-width: 320px;
	    	padding: 0 10px;
	  	}
	  	
		.indexContainer .flex_topic {
    		width: 90%;
    		padding: 10px 0 30px;
	    	margin: 0 auto;
	    	flex-direction: column;
	    }
	    
	    .indexContainer .flex_topic .msg {
		    width: 100%;
		    padding: 20px 0;
		    margin-bottom: 20px;
		}

		.indexContainer .flex_topic img {
			width: 300px;
			margin: 0 auto 20px;
			height: auto;
		}


		.indexContainer .flex_topic .ph,
		.indexContainer2 .flex_topic .ph {
			width: 300px;
			margin: 0 auto;
			height: auto;
		}
		
		.indexContainer2 .flex_topic {
    		width: 90%;
    		padding: 10px 0 30px;
	    	margin: 0 auto;
	    	flex-direction: column-reverse;
	    }
	    
	    .indexContainer2 .flex_topic .msg {
		    width: 100%;
		    padding: 20px 0 0;
		    margin-bottom: 20px;
		}

		.indexContainer2 .flex_topic img {
			width: 300px;
			margin: 0 auto;
			height: auto;
		}

  } 

.logos {
    width: 600px;
    margin: 20px auto;
    display: flex;
    justify-content: space-between;
}

	@media only screen and (max-width: 768px) {		

		.logos {
			width: 100%;
			display: block;
			margin: 10px auto;
		}
		
		.logos a{
			display: inline-block;
			margin: 0 10px 20px;
		}

	}
 
	@media only screen and (max-width: 320px) {		
		.logos {
			width: 75%;
			display: block;
			margin: 10px auto;
		}
		
		.logos a{
			display: inline-block;
			margin: 0 5px 10px;
		}

	} 
 
/* ==========================================================================
   reference
   ========================================================================== */   
   
table.paper{
	width: 100%;
	margin: 20px auto;
}   

table.paper tr:nth-child(odd) td{
    background-color: #fbfbfd;
}

table.paper th{
	padding: 10px;
    font-family: 'M PLUS 1p', sans-serif;
    font-size: 14px;
    font-weight: 500;
    transform: rotate(0.03deg);	
    text-align: left;
}

table.paper td{
	padding: 10px;
    font-family: 'M PLUS 1p', sans-serif;
    font-size: 14px;
    font-weight: 400;
    transform: rotate(0.03deg);		
}

table.paper td.num {
	padding: 10px 0 10px 10px;
	text-align: right;
	white-space: nowrap;
}

table.paper td.title {
	padding: 10px 10px 10px 5px;
}

   
	@media only screen and (max-width: 768px) {		   
	   table.paper th {
	   		white-space: nowrap;
		    padding: 5px;
		    font-size: 13px;
	   }

	   table.paper td {
		    padding: 5px;
		    font-size: 13px;
		    line-height: 1.6;
	   }
	}	

/* ==========================================================================
   ダウンロード
   ========================================================================== */
.sys-req {
	width: 100%;
	margin-bottom: 5px;
	border-collapse: collapse;
}

.sys-req th{
	background: #555;
	border: 1px solid #ccc;
	padding: 5px 10px;
	width: 20%;
}

.sys-req td {
	background: #f1f1f1;
	border: 1px solid #ccc;
	padding: 5px 10px;
	width: 80%;
}

.sys-req th span {
	display: inline-block; /* font 綺麗に出すため */
	color: #fff;
    font-size: 14px;
    font-weight: 500;
    transform: rotate(0.03deg);
}

.sys-req td span {
	display: inline-block; /* font 綺麗に出すため */
	color: #555;
    font-size: 14px;
    font-weight: 400;
    transform: rotate(0.03deg);
}

.br-sp {
	display: none;
}

	@media only screen and (max-width: 768px){

		.br-sp {
			display: block;
		}
	}

   
/* ==========================================================================
   Layout - Footer
   ========================================================================== */
	
#gFooter {
	border-top: 1px solid #ccc;
    width: 100%;
    margin: 30px auto 0;
}

#gFooter .fContainer {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;	
    width: 1200px;
    margin: 0 auto;
    padding: 10px 0;
}

#gFooter .copyright {
    text-align:left;
    font-family: 'M PLUS 1p', sans-serif;
    font-size: 12px;
    font-weight: 400;
    transform: rotate(0.03deg);
}


	@media only screen and (max-width: 768px) {

		#gFooter{
			width: 100%;
		    padding: 0 5px;
			border-top: 1px solid #ccc;
		}
				
		#gFooter .fContainer {
			display: block;
		    width: 100%;
		    margin-bottom: 10px;
		}	
		
		#gFooter .copyright {
			text-align: center;
		}
		
		.criepi_logo {
		    width: 139px;
			margin: 0 auto 10px;
		}
		
	}

	@media only screen and (max-width: 480px) {						
		
		#gFooter .copyright {
			width: 100%;
			 text-align :center;
		}
		
		.criepi_logo {
		    width: 139px;
		    margin: 10px auto 0;
		}
		
	}


/* 
   ========================================================================== */
.body {
  overflow: hidden;
  zoom: 1;
}


/* pagetop
  ========================================================================== */
#fixedTop {
    right: 10px;
    bottom: 10px;
    width: 50px;
    height: 50px;
    line-height: 50px;
    color: #fff;
    font-size: 20px;
    text-align: center;
    display: none;
    background: #110E5D;
    position: fixed;
    z-index: 9999;
    border-radius: 5px;
    -webkit-transform: translateZ(0);
}
#fixedTop:hover {
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    background: #2b417f;
}

ul.disc {
	margin-left:20px;
}

ul.disc li{
	color: #555;
	list-style-type: disc;
    font-size: 14px;
    font-weight: 400;
    transform: rotate(0.03deg);
}

.honbun {
	margin: 20px auto;
}

.honbun p{
	font-family: 'M PLUS 1p', sans-serif;
    font-size: 15px;
    font-weight: 400;
    transform: rotate(0.03deg);	
}

.add_box{
	margin: 10px auto;
	padding: 20px;
	background: #f1f1f1;
}

h3 i{
	color: #110E5D;
}


/* 　リリースノート
  ========================================================================== */
body.release .lowercontent2 {
    min-height: 500px;
}

.flex_release {
	display: flex;
	align-items: flex-start;
	padding: 20px 0;
}

.flex_release .date {
	display: block;
	color: #000;
	font-weight: 700;
	text-align: center;
	padding: 20px 20px 15px;
	background :#f1f1f1;
	border-radius: 10px;
}

.bg_box {
    width: 100%;
    background: #f1f1f1;
    margin: 30px auto;
    padding: 10px 20px 20px;
}

.new_mark{
	font-size: 12px;
	line-height: 16px;
	border-radius: 3px;
	display: inline-block;
	padding: 0 5px;
	background: #f00;
	color: #fff;	
	margin-left: 10px;
}


	@media only screen and (max-width: 768px){
		.bg_box {
		  margin: 20px auto;
		  padding: 10px;
		}

		.flex_release{
		  display: block;
		}

		.flex_release h3{
		  font-size: 16px;
		  line-height: 24px;
		}

		.sp-small{
		  font-size:85%;
		}
	}


/*
 about
  ========================================================================== */
.fig_box{
	width: 630px;
	margin: 20px auto;
}

.fig_box .caption,
.fig .caption {
	text-align: center;
	font-size: 15px;
	margin-top: 5px;
}

.flex_fig {
	width: 850px;
	margin: 20px auto;
	display: flex;
	justify-content: space-between;
}

.flex_fig img{
	width: 400px;
}

.flex_fig2 {
	width: 550px;
	margin: 20px auto;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}


@media screen and (max-width: 768px) {
	.fig_box{
		width: 80%;
	}

	.flex_fig {
		width: 80%;
		margin: 20px auto;
		display: block;
	}

	.flex_fig img{
		width: 100%;
		margin-bottom: 20px;
	}

	.flex_fig2 {
		width: 80%;
		margin: 20px auto;
	}


}


.msg_box{
	background:#f1f1f1;
	border-radius: 5px;
	margin: 30px auto;
	padding: 20px;
}

.msg_box p{
	color: #555;
	font-size: 14px;
	font-family: 'M PLUS 1p', sans-serif;
    font-weight: 400;
    transform: rotate(0.03deg);	
}

.error_s{
	width: 400px;
	margin: 0 auto;
	color: #f00;
	font-family: 'M PLUS 1p', sans-serif;	
	font-weight: 400;
	font-size: 13px;
    transform: rotate(0.03deg);	
	
}

@media screen and (max-width: 768px) {
	.attent_msg {
	    margin: 50px auto;
	    width: 100%;
	}

}

@media screen and (max-width: 440px) {	
	.msg_box{
		width: 100%;
	}

}


.btn-closewin {
	width: 250px;
 	margin: 60px auto;
}

.btn-closewin a {
	display: inline-block;
  	width: 250px;
  	color: #555;
  	font-size: 14px;
  	font-weight: 400;
  	transform: rotate(0.03deg);
  	background: #f1f1f1;
	border:1px solid #ccc;
  	padding: 0 10px;
  	text-align: center;
  	border-radius: 3px;
}

.btn-closewin a:hover{
	text-decoration: none;
	background: #eee;
}

.btn-closewin a:before {
  	font-family: "Font Awesome 5 Free";
  	content: '\f00d';
  	font-weight: 900;
  	padding-right: 5px;
  	color: #555;
}

.grayicon {
    color: #ccc;
}

.yellowicon {
    color: #ffd700;
}

table.form td.postcode input[type=text] {
    border: 1px solid #ccc;
    font-size: 14px;
    width: 100%;
    height: 24px;
    padding: 0 3px;
}

/* download */
.mheight400 {
	min-height:400px;
}

.dl_box {
	width: 70%;
	margin: 30px auto 10px;
	display: flex;
	justify-content: space-between;
}

.dl_box_v1 {
	width: 350px;
	margin: 30px auto;
}

.recaptcha {
	text-align: center;
	color: #555;
}

.recaptcha input[type=text] {
    border: 1px solid #ccc;
    font-size: 14px;
    padding-left: 5px;
    height: 30px;
}

.agree_box {
	margin-top: 20px;
	font-size: 16px;
	font-weight: 400;
	transform: rotate(0.03deg);
	text-align: center;
}

.btn-lgdownload a {
    display: inline-block;
    width: 350px;
    color: #fff;
    font-size: 18px;
    font-weight: 500;
    line-height: 50px;
    transform: rotate(0.03deg);
    background: #2874b4;
    padding: 1px 0;
    text-align: center;
    border-radius: 3px;
    text-decoration: none;
}

.btn-llarge a {
    display: inline-block;
    width: 350px;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    line-height: 50px;
    transform: rotate(0.03deg);
    background: #2874b4;
    padding: 1px 0;
    text-align: center;
    border-radius: 3px;
    text-decoration: none;
}

.btn-large {
	width: 350px;
}

.btn-large a {
    display: inline-block;
    width: 350px;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
    transform: rotate(0.03deg);
    background: #2874b4;
    padding: 5px 0;
    text-align: center;
    border-radius: 3px;
    text-decoration: none;
	letter-spacing: .05em;
}

.btn-middle a {
    display: inline-block;
    width: 100px;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    line-height: 22px;
    transform: rotate(0.03deg);
    background: #2874b4;
    padding: 1px 0;
    text-align: center;
    border-radius: 3px;
    text-decoration: none;
}

.btn-middle2 a {
    display: inline-block;
    width: 150px;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    line-height: 22px;
    transform: rotate(0.03deg);
    background: #2874b4;
    padding: 1px 0;
    text-align: center;
    border-radius: 3px;
    text-decoration: none;
}

.btn-large a:hover,
.btn-middle a:hover
.btn-middle2 a:hover{
	background: #2b417f;
	text-decoration:none;
}

@media screen and (max-width: 768px) {
	.btn-llarge a,
	.btn-large a {
		width: 100%;
	}	

	.dl_box {
		display: block;
		width: 100%;
	}

	.dl_box div{
		margin: 0 0 20px;
	}


}

.att_dl {
	margin: 5px 0 0;
	display: inline-block;
	width: 340px;
	line-height: 1.4;
}

/** 関連文献 **/

table.report {
	width: 100%;
    margin: 20px 0;
	border: 1px solid #ccc;
}

table.report th {
	padding: 3px 10px 5px;
	font-size: 14px;
    font-weight: 500;
    transform: rotate(0.03deg);
	text-align: left;
	background: #f3f3ff;
	white-space: nowrap;
}

table.report td {
	padding: 5px 10px;
	font-size: 14px;
    font-weight: 400;
    transform: rotate(0.03deg);
	border-bottom: 1px solid #ccc;
}

th.num {
	width: 10%;
}

@media print {
	body {
	    width: 100%; 
		min-width: inherit;
	    -webkit-print-color-adjust: exact;
	    color-adjust: exact;
		page-break-after: always;
	}

	.fixed {
		position: absolute!important;
	}

	.global-nav-pc {
		width: 100%;
	}

	.global-nav-pc {
		display: none;
	}

	.page-header {
		min-width: inherit;
		width: 100%;
	}

	.page-header_logo_object {
		margin-left: -30px;
	}

	.wrapper {
		width: 100%;
	}
}
