@charset "UTF-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP');
body {
	font-family: 'Noto Sans JP', sans-serif;
	color: #161853;
}
figcaption {
	font-size: 1.4rem;
   max-width: auto;
}
figure{
	max-width: 600px;
	margin: auto;
   margin-top: 24px;
}
img{
  max-width: 100%;
  height: auto;
  display: block;
}
a {
	transition: .2s;
	cursor: pointer;
}
a:hover {
	color: #faa44e !important;
}
p {
   line-height: 1.8;
}
/* header 
.headerのbackground指定は"header-image.css"
-----------------------------------------------*/
.header {
	background-repeat: no-repeat;
	background-size: auto 100%, 100% auto;
	background-position: right, left;
}
.header-container {
	width: min(90%, 1080px);
	margin-inline: auto;
}
.header-inner {
	padding-top: 50px;
	padding-bottom: 50px;
}
.header-logo img {
	max-height: 60px;
}
/* main ---------------------------------------*/
.main {
	background: #fafafa;
}
.main-container {
	width: min(90%, 1080px);
	margin-inline: auto;
	background: #fff;
}
.main-inner {
	padding: 30px 5.7% 70px;
}
.bread {
	width: 100%;
	margin-bottom: 25px;
	font-size: 1.4rem;
}
.bread-list {
	display: flex;
	flex-wrap: wrap;
}
.bread-list li {
	position: relative;
}
.bread-list li:not(:last-child)::after {
	content: '>';
	padding: 0 5px;
}
.bread-list a {
	text-decoration: underline;
	color: #697FAA;
}
/*main- index---------------------------------------*/
.index {
	margin-bottom: 40px;
}
.index-tag {
	margin-bottom: 25px;
}
.index-tag a {
	display: inline-block;
	padding: 5px 25px;
	background: #161853;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1;
}
.index-title {
	padding-left: 3%;
	padding-right: 3%;
	font-size: 3rem;
	font-weight: 600;
   letter-spacing: 0.1em;
	line-height: 110%;

}
/*main- point---------------------------------------*/
.point {
	max-width: 740px;
	padding: 30px 12%;
	margin-inline: auto;
	background: #F0F1FF;
}

.point-tag {
	display: inline-block;
	padding: 3px 15px;
	margin-bottom: 15px;
	background: #1C239B;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1;
}

.point-link a {
	font-weight: 600;
	color: #1C239B;
	text-decoration: underline;
}

/*footer---------------------------------------*/
.footer {
	background: #fafafa;
}

.footer-container {
	width: min(90%, 560px);
	margin-inline: auto;
}

.footer-inner {
	padding-top: 40px;
	padding-bottom: 50px;
}

.sns {
	margin-bottom: 30px;
}

.sns-list {
	display: flex;
	justify-content: center;
}

.sns-list li {
	margin-right: 7.5px;
	margin-left: 7.5px;
}

.sns-list img {
	width: 30px;
}

.footer-content {
	display: flex;
	justify-content: center;
	font-size: 1.2rem;
}

.footer-content-index {
	display: flex;
	align-items: center;
}

.footer-content-index-01 {
	margin-right: 5px;
}

.footer-content-index-02 {
	display: flex;
	align-items: center;
	font-weight: 600;
}

.footer-content-index-02>*:nth-child(1) {
	margin-right: 10px;
	font-size: 1.8rem;
}

.footer-content-link a {
	text-decoration: underline;
	color: #23254D;
}


/*main- news (記事用パーツ)---------------------------------------*/
.news>* {
	margin-bottom: 35px;
}

.news section>*:not(:last-child) {
	margin-bottom: 1em;
}

.news {
	text-align: justify;
}

.news img {
	width: 100%;
}

.title-01,
.title-02 {
	position: relative;
	margin-bottom: 10px !important;
	font-size: 2rem;
	line-height: 120%;
	z-index: 1;
}

.title-01 {
	width: 100%;
   margin-top: 72px;
}

.title-02 {
	display: inline-block;
}

.title-01::before,
.title-02::before {
	width: 100%;
	height: 2px;
}

.title-01::after,
.title-02::after {
	width: 30px;
	height: 30px;
	border-radius: 50px;
}

.title-01 span,
.title-02 span {
	display: inline-block;
	padding-right: 10px;
	margin-right: 50px;
	background: #fff;
   margin-top: px;
   padding: 1rem 2rem;
  border-left: 4px solid #6E93cc;
}

.img-01 img {
	width: auto;
	max-height: 350px;
	margin-right: auto;
	margin-left: auto;
}

.grid-layout-01,
.grid-layout-02 {
	display:grid;
   gap: 1em 25px;
}

.grid-layout-03,
.grid-layout-04{
   display: grid;
   gap: 1em 8px;
}

.grid-layout-01 *>*:not(:last-child),
.grid-layout-02 *>*:not(:last-child) {
   margin-top: 0.4em;;
	margin-bottom: 0em;
}

/* media ---------------------------------------*/
@media screen and (max-width:1080px) {
	.main {
		background: #fff;
	}

	.main-inner {
		padding: 20px 0 40px;
	}
}

@media screen and (min-width:769px) {

	.title-01 span,
	.title-02 span {
		margin-right: 20px;
	}

	.float-layout-01::after,
	.float-layout-02::after {
		content: '';
		display: block;
		clear: both;
	}

	.float-layout-01 figure {
		float: left;
		width: 42%;
		margin-right: 21px;
		margin-bottom: 16px;
	}

	.float-layout-02 figure {
		float: right;
		width: 42%;
		margin-bottom: 21px;
		margin-left: 16px;
	}

	.grid-layout-01 {
		grid-template-columns: 1.5fr 2fr;
	}
   
	.grid-layout-02 {
		grid-template-columns: 2fr 1.5fr;
	}
   
   .grid-layout-03 {
		grid-template-columns: 1fr 1fr;
	}
   
   .grid-layout-04 {
		grid-template-columns: 1fr 1fr 1fr;
	}
}

@media screen and (max-width:768px) {

	.float-layout-01 figure+*,
	.float-layout-02 figure+* {
		clear: both;
	}

	.float-layout-01 figure,
	.float-layout-02 figure {
		margin-bottom: 1em;
	}
}

u{
   color:#1C239B;
}

.btn_1,
a.btn_1 {
  color: #000149;
  background-color: #D7D8FD;
  border-radius: 16px;    /* 角丸の指定 */
  padding: 0.4em;           /* 内側の余白 */
}
.btn_1:hover,
a.btn_1:hover {
  color: #fff;
  background: #161853;
}
a.btn_1 {
   border-radius: 100vh;
}

.info_1{
   padding: 40px 32px 48px;
   background: #f8f8f8;
}

.syousai a span{
   color:#fff;
   background-color: #161853;
   border-radius: 16px;
   height: 8px;
   padding: 8px;
}

.box_text{
   max-width: 1000px;
	padding: 16px 8%;
}

h3{
   margin-top: 48px;
   padding: 1rem 2rem;
   border-left: 4px solid #6E93CC;
}

.grid-layout-01> figure,
.grid-layout-02> figure,
.grid-layout-03> figure,
.grid-layout-04> figure{
   margin-top: 4px;
}
.float-layout-01> figure,
.float-layout-02> figure{
   margin-top: 4px;
}
.emphasis{
 -webkit-text-emphasis: dot #333;
   text-emphasis: dot #333;
}
table.table-272 th{
 padding: 1px 4px 1px 4px;
 background: #EDEEFF;
 border: solid 1px #778ca3;
}
table.table-272 td{
 padding: 4px;
 border: solid 1px #778ca3;
}
.fig-table-272{
	max-width: 800px;
	margin: auto;
   margin-top: 24px;
}
