@charset "UTF-8";
@font-face {
  font-family: 'Noto Sans JP';
  font-weight: 400;
  src: url("../fonts/Noto_Sans_JP/static/NotoSansJP-Regular.ttf") format("TrueType");
}
@font-face {
  font-family: 'Noto Sans JP';
  font-weight: 700;
  src: url("../fonts/Noto_Sans_JP/static/NotoSansJP-Bold.ttf") format("TrueType");
}
@font-face {
  font-family: 'Noto Sans JP';
  font-weight: 900;
  src: url("../fonts/Noto_Sans_JP/static/NotoSansJP-Black.ttf") format("TrueType");
}
@font-face {
  font-family: 'Noto Serif JP';
  font-weight: 400;
  src: url("../fonts/Noto_Serif_JP/static/NotoSerifJP-Regular.ttf") format("TrueType");
}
@font-face {
  font-family: 'Noto Serif JP';
  font-weight: 700;
  src: url("../fonts/Noto_Serif_JP/static/NotoSerifJP-Bold.ttf") format("TrueType");
}
@font-face {
  font-family: 'Noto Serif JP';
  font-weight: 900;
  src: url("../fonts/Noto_Serif_JP/static/NotoSerifJP-Black.ttf") format("TrueType");
}
html {
  font-size: 16px;
  overflow-x: hidden; }

body {
  background-color: #fff;
  color: #000;
  margin: 0;
  font-family: "Noto Sans JP", serif;
  font-weight: 400;
  overflow-x: hidden;
  overflow-wrap: break-word;
  font-style: normal;
}
.noto-sans-jp-Regular {
  font-family: "Noto Sans JP", serif;
	font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
.noto-sans-jp-Bold {
  font-family: "Noto Sans JP", serif;
	font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}
.noto-sans-jp-Black {
  font-family: "Noto Sans JP", serif;
	font-optical-sizing: auto;
  font-weight: 900;
  font-style: normal;
}
.noto-serif-jp-Regular {
  font-family: "Noto Serif JP", sans-serif;
	font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
.noto-serif-jp-Bold {
  font-family: "Noto Serif JP", sans-serif;
	font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}
.noto-serif-jp-Black {
  font-family: "Noto Serif JP", sans-serif;
	font-optical-sizing: auto;
  font-weight: 900;
  font-style: normal;
}
img {
  max-width: 100%;
  height: auto; }

a {
  color: #000;
  transition: all 0.3s ease;
  text-decoration: underline; }
  a:hover {
    color: #314d97; }
    a:hover img {
      opacity: .7;
      transition: all 0.3s ease; }

p {
  font-size: 1rem;
  line-height: 1.7rem; }
  p a {
    text-decoration: underline; }

ul,
ol {
  /*padding-inline-start: 0;
    -webkit-padding-start: 0;
    -moz-padding-start: 0;*/
  padding-left: 0;
  list-style-position: outside;
  margin-left: 1rem; }

li a {
  text-decoration: underline; }

figcaption {
  margin-top: 5px;
  margin-bottom: 1rem;
  font-size: .85rem; }

strong {
  font-weight: 700; }

em {
  font-weight: 700;
  font-style: normal;
  background: linear-gradient(transparent 60%, #9ac243 60%); }

strong {
  color: red;
  font-weight: 500; }

.nowrap {
  white-space: nowrap; }

.relative {
  position: relative; }

.clearfix::after {
  content: "";
  display: block;
  clear: both; }

/* common */
.col .no-gutters,
[class*="col-"] .no-gutters {
  padding-right: 0;
  padding-left: 0; }

a[href$='.pdf'] {
    padding-right: 1.5em;
    background: transparent url(../img/icon/icon_pdf.png) no-repeat center right 10px;
}
a[href$='.xls'],
a[href$='.xlsx'] {
  padding-right: 1.5em;
  background: transparent url(../img/icon/icon_xls.png) no-repeat center right; }

a[href$='.ppt'],
a[href$='.pptx'] {
  padding-right: 1.5em;
  background: transparent url(../img/icon/icon_ppt.png) no-repeat center right; }

a[href$='.doc'],
a[href$='.docx'] {
  padding-right: 1.5em;
  background: transparent url(../img/icon/icon_doc.png) no-repeat center right 10px;}

a[href$=".doc"][target="_blank"]::after,
a[href$=".docx"][target="_blank"]::after,
a[href$=".xls"][target="_blank"]::after,
a[href$=".xlsx"][target="_blank"]::after,
a[href$=".ppt"][target="_blank"]::after,
a[href$=".pptx"][target="_blank"]::after {
  content: none !important; }

a.no-icon {
  background: none;
  padding-right: 0; }

.material-icons {
  vertical-align: middle; }

#header{
	margin-top: 40px;
  background:url("../img/bg.jpg?20250204") no-repeat center center;
	background-size: cover;
	height: 550px;
  padding-top: 20px;
	border-bottom: 40px solid #000;
}
#header .container {
	position: relative;
}
#header h1 {
	font-size: 4rem;
  font-family: "Noto Serif JP", sans-serif;
	font-weight: 900;
}
#header h1 span {
	margin-top: .5rem;
	font-family: "Times New Roman", Times, "serif";
	font-size: 2rem;
	display: block;
}
#header .header-textbox {
	position: absolute;
	margin-top: 100px;
	right: 0;
	background: rgba(000,000,000,0.8);
	padding: .5rem 1rem;
	color: #fff;
	border-radius: 10px;
	margin-right: 1rem;
}
#header .header-textbox dl {
	font-size: 1.3rem;
	font-weight: bold;
	margin-bottom: 0
}
#header .header-textbox dl dd {
	margin-bottom: 0
}
#header .header-textbox dl dd small {
	font-size: .9rem;
	display: block;
}
.parent {
	width: auto;
	height: 100vh;
	/* 以下を追加しました */
	position: relative;
}
.child {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
h2 {
	margin-top: 20px;
	margin-bottom: 40px;
	font-size: 3rem;
  position: relative;
  padding: 0 65px;
  text-align: center;
  font-family:"Times New Roman", Times, "Noto Serif JP", sans-serif;
	font-weight: 700;
}
h2:before {
  position: absolute;
  top: calc(50% - 1px);
  left: 0;
  width: 100%;
  height: 1px;
  content: '';
  background: #ccc;
}

h2 span {
  position: relative;
  padding: 0 1em;
  background: #fff;
}
h2.h2_zoom {
	font-size: 2.5rem;
}
h2.h2_zoom b {
	font-weight: 700;
}
h3,
h4 {
  font-family: "Noto Serif JP", sans-serif;
	font-weight: 700;
}
.btn_form {
	text-align: center;
	margin:0 auto 20px auto;
	font-weight: bold;
	background: #666;
	border-radius: 50% ;
	width: 200px;
	height: 200px;
	color: #fff;
	font-size: 1.5rem;
}
.btn_form:before {
  position: absolute;
}
.btn_form span {
  position: relative;
	top: 60px;
	line-height: 1rem;
}
.btn_form span.QA {
	top: 40px;
}
.btn_form span small {
	font-size: 1rem;
	display: block;
	margin-top: 5px;
}
a.btn_form:hover {
	background: rgba(23,49,172,1.00);
}
.form_box {
	padding: 60px 1rem 40px 1rem;
}
.container_news_box,
.container_box {
	min-height: 500px;
	padding: 40px 1rem;
}
.container_news_box .news-box {
  height: 355px;
  overflow-y: scroll;
	padding: 1rem;
	margin: 0 1rem;
}
.container_news_box dl {
  display: block;
  border-bottom: 1px solid #eee;
}
.container_news_box dl dt {
  flex-shrink: 0;
  float: left;
  clear: left;
  width: 9rem;
	font-weight: 400;
  margin-right: 1rem;
  white-space: nowrap;
	font-size: .95rem;
	line-height: 1.8rem;
}
.container_news_box dl dd {
	margin-left: 9rem;
}
footer {
	background: #eee;
	padding: 1rem 0;
}
footer p {
	margin-bottom: 0;
}
footer .f_copy p,
footer p.f_policy {
	font-size: .8rem;
	text-align: center;
}
footer p.f_policy a {
  text-decoration: none;
}
footer p.f_policy a:hover {
  text-decoration: underline;
}
.dl_QA dl {
	margin-bottom: 2rem;
	border: 1px solid #ccc;
	background:rgba(250,250,250,0.5);
	padding: 1rem;
}
.dl_QA dl dt {
	font-size: 1.2rem;
	font-weight: 700;
	margin-bottom: 1rem;
	color: #666;
	margin-left: 3rem;
	text-indent: -3rem;
}
.dl_QA dl dt:before {
	font-size: 2rem;
  content:"Q.";
  color:rgba(23,49,172,1.00);
	margin-right: 1rem;
  font-family:"Times New Roman", Times, "Noto Serif JP", sans-serif;
}
.dl_QA dl dd {
	font-size: 1rem;
	margin-left: 3rem;
	text-indent: -3rem;
}
.dl_QA dl dd:before {
	font-size: 2rem;
  content:"A.";
  color:#FF0004;
	font-weight: 700;
	margin-right: 1rem;
  font-family:"Times New Roman", Times, "Noto Serif JP", sans-serif;
}

a.btn_zoom {
	text-align: center;
	font-weight: bold;
	background: #666;
	width: 600px;
	color: #fff;
	font-size: 1.5rem;
	padding: 1rem;
}
a.btn_zoom:hover {
	background: rgba(23,49,172,1.00);
}
@media screen and (max-width: 991px){
	#header h1 {
		font-size: 3rem;
	}
	#header h1 span {
		font-size: 1.8rem;
	}
	#header .header-textbox {
		margin-top: 100px;
		}
	h2.h2_zoom {
		font-size: 2rem;
	}
}
@media screen and (max-width: 768px){
	#header .header-textbox {
		margin-top: 100px;
	}
	#header h1 {
		font-size: 2.5rem;
	}
	#header h1 span {
		font-size: 1.2rem;
	}
	#header .header-textbox dl {
		font-size: 1.2rem;
	}
	a.btn_zoom {
		width: 90%;
		font-size: 1.2rem;
	}
	h2.h2_zoom span {
		padding: .5rem 1.5rem;
		background: #fff;
		text-align: center;
		margin: auto;
	}
	h2.h2_zoom b {
		margin-left: 2rem;
	}
}
@media screen and (max-width: 576px){
	.container_news_box,
	.container_box {
		width: 95%;
		padding: 40px 0;
	}
	#header {
		height: 600px;
	}
	#header .header-textbox {
		margin-top: 90px;
	}
	h2 {
		font-size: 2rem;
	}
	#header .header-textbox dl {
		font-size: 1rem;
	}
	.container_news_box dl dt {
		width: auto;
		float: none;
		font-size: .9rem;
	}
	.container_news_box dl dd {
		margin-left: 1rem; 
		padding: 0;
	}
}
@media screen and (max-width: 500px){
	#header .header-textbox dl {
		font-size: 0.9rem;
	}
}