body {}

@charset "UTF-8";
/* CSS Document */

/* noto-sans-jp-regular - japanese_latin */
@font-face {
	font-display: swap;
	/* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	src: url('../fonts/noto-sans-jp-v52-japanese_latin-regular.eot');
	/* IE9 Compat Modes */
	src: url('../fonts/noto-sans-jp-v52-japanese_latin-regular.eot?#iefix') format('embedded-opentype'),
		/* IE6-IE8 */
		url('../fonts/noto-sans-jp-v52-japanese_latin-regular.woff2') format('woff2'),
		/* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
		url('../fonts/noto-sans-jp-v52-japanese_latin-regular.woff') format('woff'),
		/* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
		url('../fonts/noto-sans-jp-v52-japanese_latin-regular.ttf') format('truetype'),
		/* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
		url('../fonts/noto-sans-jp-v52-japanese_latin-regular.svg#NotoSansJP') format('svg');
	/* Legacy iOS */
}

/* noto-sans-jp-600 - japanese_latin */
@font-face {
	font-display: swap;
	/* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 600;
	src: url('../fonts/noto-sans-jp-v52-japanese_latin-600.eot');
	/* IE9 Compat Modes */
	src: url('../fonts/noto-sans-jp-v52-japanese_latin-600.eot?#iefix') format('embedded-opentype'),
		/* IE6-IE8 */
		url('../fonts/noto-sans-jp-v52-japanese_latin-600.woff2') format('woff2'),
		/* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
		url('../fonts/noto-sans-jp-v52-japanese_latin-600.woff') format('woff'),
		/* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
		url('../fonts/noto-sans-jp-v52-japanese_latin-600.ttf') format('truetype'),
		/* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
		url('../fonts/noto-sans-jp-v52-japanese_latin-600.svg#NotoSansJP') format('svg');
	/* Legacy iOS */
}

/* noto-sans-jp-800 - japanese_latin */
@font-face {
	font-display: swap;
	/* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 800;
	src: url('../fonts/noto-sans-jp-v52-japanese_latin-800.eot');
	/* IE9 Compat Modes */
	src: url('../fonts/noto-sans-jp-v52-japanese_latin-800.eot?#iefix') format('embedded-opentype'),
		/* IE6-IE8 */
		url('../fonts/noto-sans-jp-v52-japanese_latin-800.woff2') format('woff2'),
		/* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
		url('../fonts/noto-sans-jp-v52-japanese_latin-800.woff') format('woff'),
		/* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
		url('../fonts/noto-sans-jp-v52-japanese_latin-800.ttf') format('truetype'),
		/* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
		url('../fonts/noto-sans-jp-v52-japanese_latin-800.svg#NotoSansJP') format('svg');
	/* Legacy iOS */
}

@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@1,100..900&display=swap');

* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

body {
	width: 100%;
	min-width: 1250px;
	margin: 0;
	padding: 0;
	color: #211614;
	font-family: 'Noto Sans JP', Meiryo, sans-serif;
	font-size: 15px;
	line-height: 1.75;
}

#wrap {
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	background-image: url(../img/bg_main.jpg);
	background-repeat: no-repeat;
	background-size: 2000px auto;
	background-position: center top;
	background-attachment: fixed;
}

.roboto {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: italic;
  font-variation-settings:
    "wdth" 100;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
	padding: 0;
	font-size: 12px;
	font-weight: normal;
}

ul {
	margin: 0;
	list-style: none;
}

.mt5 {
	margin-top: 5px;
}

.mt10 {
	margin-top: 10px;
}

.mt15 {
	margin-top: 15px;
}

.mt20 {
	margin-top: 20px;
}

.mt25 {
	margin-top: 25px;
}

.mt30 {
	margin-top: 30px;
}

.mt35 {
	margin-top: 35px;
}

.mt40 {
	margin-top: 40px;
}

.mb5 {
	margin-bottom: 5px;
}

.mb10 {
	margin-bottom: 10px;
}

.mb15 {
	margin-bottom: 15px;
}

.mb20 {
	margin-bottom: 20px;
}

.mb25 {
	margin-bottom: 25px;
}

.mb30 {
	margin-bottom: 30px;
}

.mb35 {
	margin-bottom: 35px;
}

.mb40 {
	margin-bottom: 40px;
}

.mb60 {
	margin-bottom: 60px;
}

.ml1em {
	margin-left: 1em;
}

.ml5 {
	margin-left: 5px;
}

.ml10 {
	margin-left: 10px;
}

.ml15 {
	margin-left: 15px;
}

.ml20 {
	margin-left: 20px;
}

.mr5 {
	margin-right: 5px;
}

.mr10 {
	margin-right: 10px;
}

.mr15 {
	margin-right: 15px;
}

.mr20 {
	margin-right: 20px;
}

.fs13 {
	font-size: 13px;
}

.fs14 {
	font-size: 14px;
}

.fs15 {
	font-size: 15px;
}

.fs16 {
	font-size: 16px;
}

.fs17 {
	font-size: 17px;
}



.w100 {
	width: 100%;
}

.bold {
	font-weight: bold;
}

.red {
	color: #ef0000;
}

.blue {
	color: #036290;
}


a {
	outline: none;
	color: #0099c2;
	text-decoration: underline;
}

a:hover {
	text-decoration: none;
}

.right {
	text-align: right;
}

.btn1 {
	width: 300px;
	min-height: 50px;
	padding: 5px 25px;
	color: #ed6b04;
	font-size: 17px;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	background: linear-gradient(180deg, #fff, #eaeaea);
	border: solid 2px #ed6b04;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.btn1.pdf {
	padding: 5px 25px 5px 0;
}


a.btn1:hover {
	background: #ed6b04;
	color: #ffffff;
}

a.btn1::before {
	content: "";
	width: 8px;
	height: 8px;
	margin: 0;
	padding: 0;
	border-top: solid 2px #ec6b03;
	border-right: solid 2px #ec6b03;
	transform: rotate(45deg);
	position: absolute;
	top: calc(50% - 4px);
	right: 15px;
}

a.btn1:hover:before {
	border-top: solid 2px #ffffff;
	border-right: solid 2px #ffffff;
}

.btn1.pdf span:before {
	content: "";
	width: 27px;
	height: 32px;
	background-image: url(../img/icon_pdf.svg);
	background-repeat: no-repeat;
	background-size: 100% auto;
	border: none;
	transform: rotate(0);
	position: absolute;
	top: calc(50% - 16px);
	right: 10px;
}

a.btn1.pdf::before,
a.btn1.ppt::before,
a.btn1.word::before {
	content: none;
}

.btn1.ppt span:before {
	content: "";
	width: 26px;
	height: 26px;
	background-image: url(../img/icon_ppt.svg);
	background-repeat: no-repeat;
	background-size: 100% auto;
	border: none;
	transform: rotate(0);
	position: absolute;
	top: calc(50% - 12px);
	right: 12px;
}

.btn1.word span:before {
	content: "";
	width: 27px;
	height: 32px;
	background-image: url(../img/icon_word.svg);
	background-repeat: no-repeat;
	background-size: 100% auto;
	border: none;
	transform: rotate(0);
	position: absolute;
	top: calc(50% - 13px);
	right: 10px;
}


.btn2 {
	width: 300px;
	min-height: 50px;
	padding: 5px 25px 5px 20px;
	color: #fff;
	font-size: 20px;
	font-weight: 500;
	text-align: center;
	text-decoration: none;
	background: linear-gradient(180deg, #f98f39, #ec6b03);
	border: solid 2px #ec6b03;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 0;
}

a.btn2:hover {
	background: linear-gradient(0deg, #f98f39, #ec6b03);
}

a.btn2::before {
	content: "";
	width: 8px;
	height: 8px;
	margin: 0;
	padding: 0;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	transform: rotate(45deg);
	position: absolute;
	top: calc(50% - 4px);
	right: 15px;
}

a.opacity {
	transition: opacity .2s;
}

a.opacity:hover {
	opacity: 0.75;
}

.alignjust {
	text-align: center;
	margin: 150px;
}

.iblock {
	display: inline-block;
}

table {
	border-collapse: collapse;
}

.indent1 {
	padding-left: 1em;
	text-indent: -1em;
}

.strike {
	text-decoration: line-through 1px solid #d71518;
}

.red_strike {
	text-decoration: line-through;
	color: #ef0000;
}

.black {
	color: #211614;
}

.under {
	text-decoration: underline;
}

.marker1 {
	padding: 0 3px;
	font-weight: bold;
	background: linear-gradient(transparent 60%, #f9f924 60%);
}

.marker2 {
	padding: 0 3px;
	font-weight: bold;
	background: linear-gradient(transparent 60%, #a4ff59 60%);
}

.aligncenter {
	text-align: center;
}

.alignright {
	text-align: right;
}

.contents {
	width: 1260px;
	margin: 120px auto 0;
	padding: 0 0 50px;
}


.mds2{
	width: 100%;
    margin: 0 auto 10px;
    padding: 0 5px 6px;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.5;
	border: none;
    border-bottom: 2px solid;
    border-image: linear-gradient(to right, #004098, #009944) 1;
}

.col_content2{
	max-width: 830px;
    padding: 0 5px;
}


/* --------------- header --------------- */

div#header{
	width: 100%;
	height: 100px;
	position: relative;
	margin: 0;
	padding: 0;
	border: none;
	border-bottom: 5px solid; /* placeholder */
	border-image: linear-gradient(to right, #004098, #009944) 1;
}

div#header_sub{
	width: 100%;
	height: 100px;
	position: relative;
	margin: 0 0 60px;
	padding: 0;
	border: none;
	border-bottom: 5px solid; /* placeholder */
	border-image: linear-gradient(to right, #004098, #009944) 1;

}

.header_top{
	max-width: 1148px;
	height: 95px;
	margin: 0 auto;
	padding: 10px 0;
	display: flex;
	align-items: center;
}

h2.logo_sub_header{
	width: 456px;
}



h2.logo_sub_header a:hover{
	opacity: .8;
}

.col_sub_nav{
	width: calc(100% - 456px);
	margin: 0;
	padding: 0;
	position: relative;
    z-index: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    flex-direction: column;
    justify-content: center;
}

.nav{
	width: 100%;
    margin: 0 0 15px;
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.nav li{
	width: auto;
    margin: 0 20px 0 0;
    padding: 0;
    text-align: center;
    line-height: 20px;
    list-style: none;
    position: relative;
    display: flex;
    align-items: center;
}

.nav li:last-of-type{
	margin: 0;
}

.nav li a, .nav li div.nolink{
	display: block;
    margin: 0;
    padding: 2px 0;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.3;
    color: #231815;
    text-decoration: none;
    transition: .2s;
    position: relative;
}

.nav li:hover a::before,
.nav li.active a::before{
	content: "";
	width: 100%;
	height: 4px;
	position: absolute;
	bottom: -8px;
	left: 0;
	background: linear-gradient(to right, rgba(0, 64, 152, 1) 0%, rgba(0, 153, 68, 1) 100%  /* 緑 (100%) */);
}


/* --------------- footer --------------- */

footer{
	text-align: center;
	border: none;
  height: 5px;
  border-top: 5px solid; 
  border-image: linear-gradient(to right, #004098, #009944) 1;
}

.col_footer{
	padding: 20px 0 17px;
	background-color: #EFEFEF;
	font-size: 13px;
	line-height: 1.55;

}

.copy{
	margin: 0;
    padding: 8px 0;
    text-align: center;
    color: #fff;
    font-size: 12px;
    background-color: #231815;
}



/* --------------- main --------------- */

.slideshow {
	margin: 0 0 40px;
    position: relative;
    width: 100%;
    height: 395px;
    overflow: hidden;
  }

  .slideshow .slides {
    display: flex;
    width: 100%;
    height: 100%;
    transition: transform 1s ease;
  }

  .slideshow img {
    width: 100%;      /* 画面幅いっぱい */
    height: 395px;    /* 高さ固定 */
    object-fit: cover; /* 画像の縦横比を維持してトリミング */
    flex-shrink: 0;   /* 幅が縮まらないように固定 */
  }


/* --------------- contents --------------- */

#contents{
	width: 1091px;
    margin: 0 auto 40px;
    padding: 0 0 0;
    display: flex;

}


/* --------------- leftcontents --------------- */

#leftcontents{
	width: 192px;
    margin: 0 59px 0 0;
    padding: 0;
}

.box_mark1{
	width: 100%;
	max-width: 97px;
	margin: 0 auto 48px;
}

.img_mark1{
	max-width: 95px;
	margin: 0 0 20px;
	padding: 0;
}

.img_mark1 img{
	width: 100%;
}


.img_mark2{
	max-width: 97px;
	margin: 0;
	padding: 0;
}

.img_mark2 img{
	width: 100%;
}

#navi{
	width: 192px;
    margin: 0 0 30px 0;
    padding: 0 0 0;
    background-color: #fff;
}

#navi li{
	margin: 0 0 10px;
    padding: 0;
    position: relative;
    z-index: 0;
    border: solid 1px #004386;
    background: linear-gradient(to right, rgba(0, 64, 152, 0.15) 0%, rgba(0, 153, 68, 0.15) 100%);
    transition: background 0.5s ease;
}

#navi li.active, #navi li:hover{
	background: linear-gradient(
    to right,
    rgba(0, 64, 152, 1) 0%,   /* 青 (100%) */
    rgba(0, 153, 68, 1) 100%  /* 緑 (100%) */);
}

#navi li a{
	width: 100%;
    min-height: 37px;
    padding: 8px 10px 9px;
    font-size: 15px;
    line-height: 1.3;
    font-weight: bold;
    color: #231815;
    text-align: center;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
}

#navi li.active a, #navi li:hover a{
	    color: #fff;
}


/* --------------- rightcontents --------------- */

#rightcontents {
    width: 840px;
    margin: 0;
    padding: 0;
}


/* --------------- top --------------- */

.top_info1{
	max-width: 1147px;
	height: 29px;
	margin: 0;
    padding: 0;
    position: absolute;
    top: 7%;
    left: 19.4%;
}

.top_info1 img{
	width: 100%;
	height: auto;
	object-fit: fill;
}

.top_info2{
	max-width: 438px;
	height: 94px;
	margin: 0;
    padding: 0;
    position: absolute;
    bottom: 11%;
    left: 19.6%;
}

.top_info2 img{
	width: 100%;
	height: auto;
	object-fit: fill;
}

@media print,
screen and (max-width: 1900px) {
	.top_info1{
		left: 19%;
	}
	
	.top_info2{
		left: 19.4%;

	}
	
}

@media print,
screen and (max-width: 1800px) {
	.top_info1{
		left: 17%;
	}
	
	.top_info2{
		left: 17.4%;

	}
	
}

@media print,
screen and (max-width: 1600px) {
	.top_info1{
		left: 11%;
	}
	
	.top_info2{
		left: 11.4%;

	}
	
}

@media print,
screen and (max-width: 1400px) {
	.top_info1{
		left: 8%;
	}
	
	.top_info2{
		left: 8.4%;

	}
	
}

@media print,
screen and (max-width: 1260px) {
	.top_info1{
		left: 3%;
	}
	
	.top_info2{
		left: 3.4%;

	}
	
}


.wrap_topnews{
	width: 836px;
	margin: 0 0 20px auto;
	padding: 16px 0 14px;
	box-sizing: border-box;
	background-color: #fff;
}

.box_topnews{
	width: 100%;
	margin: 0 auto;
	padding: 0;
	background-color: #fff;
	display: flex;
	justify-content: center;
}

.box_topnews .mds{
	width: 125px;
    padding: 9px 0 0;
    font-size: 17px;
    font-weight: 600;
    line-height: 1.2;
    text-align: left;
}

.col_topnews{
	width: 711px;
    margin: 0;
    padding: 0;
}

.scroll_topnews{
	max-height: 142px;
    margin: 0;
    padding: 0 15px 0 0;
    overflow: auto;
}

.col_topnews dl{
	width: 100%;
    margin: 0;
    padding: 6px 7px;
    border-bottom: dotted 1px #231815;
    box-sizing: border-box;
    display: flex;
}

.col_topnews dl:first-child{
	border-top: dotted 1px #231815;
}

.col_topnews dl dt{
	width: 160px;
    margin: 0;
    padding: 0 0 0 10px;
    position: relative;
    z-index: 0;
}

.col_topnews dl.new dt:before {
	content: "NEW";
    padding: 1px 6px 2px;
    line-height: 1;
    font-size: 11px;
    font-weight: 300;
    color: #fff;
    background-color: #e60012;
    display: inline-block;
    position: absolute;
    top: 7px;
    right: 18px;
}

.col_topnews dl dd{
	width: calc(100% - 160px);
    margin: 0;
    padding: 0 0 0 15px;
    line-height: 1.4;
}

.box_top1{
	line-height: 1.55;
}

/* --------------- inner --------------- */

.pagettl{
	margin: 0 0 22px;
    padding: 8px 24px;
    color: #fff;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.5;
    background: linear-gradient(to right,rgba(0, 64, 152, 1) 0%,rgba(0, 153, 68, 1) 100%);
    box-sizing: border-box;
}

/* --------------- topic --------------- */

ul.list_topic1{
	margin: 0;
	padding: 0;
}

ul.list_topic1 li{
	margin: 0;
	padding-left: 1em;
	text-indent: -1em;
	line-height: 1.7;
}

/* --------------- committee --------------- */

ul.list_committee1{
	margin: 0;
	padding: 0;
	
}

ul.list_committee1 li{
	margin: 0;
	padding: 0;
}

h3.mds_committee1{
	margin: 20px 0 10px 0;
    padding: 4px 15px 4px 15px;
    color: #211629;
    font-size: 15px;
    line-height: 1.4;
    background-color: #ebe8e8;
    border-left: solid 6px #004c66;
}



