@charset "utf-8";

#wrapper{
	width: 100%;
	padding: 0;
	overflow: hidden;
}
.link {
	cursor: pointer;
}

/* header */
.header {
	background: #fff;
	width: 100%;
	padding: 15px 0 13px;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 11;
}
.header .inner {
	/*max-width: 1120px;*/
	max-width: 98%;
	margin: 0 auto;
}
.header .inner h1 {
	display: inline-block;
}
.header .inner ul {
	position: absolute;
	top: 16px;
	right: 385px;
}
.header .inner ul li {
	display: inline-block;
	font-size: 13px;
}
.header .inner ul li:after {
	content: "|";
	margin: 0 15px;
}
.header .inner ul li:last-child:after {
	display: none;
}
.header .inner ul li a {
	color: #2838a9;
}
.header .inner ul li a:hover {
	color: #96c0c0;
}
.header .inner .failure-info a{
	position: absolute;
	top: 16px;
	right: 230px;
	background-color: #E01717;
	color: #fff;
	display: inline-flex;
	width: 130px;
	height: 36px;
	justify-content: center;
	align-items: center;
}
.gnavi {
	background: #2a5bbe;
	width: 200px;
	height: 100%;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 20;
    transition: all .4s ease-in-out;
    -moz-transition: all .4s ease-in-out;
    -webkit-transition: all .4s ease-in-out;
}
.gnavi ul {
	padding: 0 30px 0 30px;
}
.gnavi ul li a,
.gnavi ul li div {
	color: #fff;
	display: block;
	padding: 8px 0;
	line-height: 2;
	position: relative;
	cursor: pointer;
	transition: all .2s ease-in-out;
	-moz-transition: all .2s ease-in-out;
	-webkit-transition: all .2s ease-in-out;
}
.gnavi ul li a:after,
.gnavi ul li div:after {
	content: "";
	width: 100%;
	display: block;
	border-bottom: 1px solid #2a5bbe;
	position: absolute;
	bottom: 5px;
	left: -5px;
	transition: all .2s ease-in-out;
	-moz-transition: all .2s ease-in-out;
	-webkit-transition: all .2s ease-in-out;
}
.gnavi ul li.current {
}
.gnavi ul li.current a,
.gnavi ul li a:hover,
.gnavi ul li.current div,
.gnavi ul li div:hover {
	color: #feeb16;
}
.gnavi ul li.current a:after,
.gnavi ul li a:hover:after,
.gnavi ul li.current div:after,
.gnavi ul li div:hover:after {
	border-bottom: 1px solid #feeb16;
}
.gnavi ul li span {
	display: block;
	font-size: 11px;
}
.gnavi ul li ul.sub {
	padding: 0 0 0 10px;
	display: none;
}
.gnavi ul li ul.sub li {
	font-size: 14px;
}
.gnavi ul li ul.sub li a {
	color: #fff;
	position: relative;
}
.gnavi ul li ul.sub li a:after {
	display: none;
}
.gnavi ul li ul.sub li a:hover {
	color: #feeb16;
}
.gnavi ul li ul.sub li a:hover:after {
	content: "";
	width: 100%;
	display: block;
	border-bottom: 1px solid #feeb16;
	position: absolute;
	bottom: 5px;
	left: -5px;
}

.header .sp_btn {
	display: none;
	position: absolute;
	top: 0;
	right: -68px;
	width: 68px;
	height: 68px;
	cursor: pointer;
	background: #2a5bbe;
	transition: all .2s ease-in-out;
	-moz-transition: all .2s ease-in-out;
	-webkit-transition: all .2s ease-in-out;
}
.header .sp_btn > div {
	position: relative;
	height: 53px;
	margin: 15px 15px 0 15px;
}
.header .sp_btn div span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 1px;
	background: #fff;
	transition: all .4s;
}
.header .sp_btn div span.top {
	top: 0px;
}
.header .sp_btn div span.middle {
	top: 11px;
}
.header .sp_btn div span.bottom {
	top: 22px;
}
.header .sp_btn div span.bottom:after {
	content: "MENU";
	display: block;
	width: 100%;
	position: absolute;
	bottom: -19px;
    line-height: normal;
	text-align: center;
	font-size: 10px;
	color: #fff;
}
.open .header .sp_btn div span.top {
    top: -5px;
    -webkit-transform: translateY(20px) rotate(-45deg);
    transform: translateY(20px) rotate(-45deg);
}
.open .header .sp_btn div span.middle {
    opacity: 0;
}
.open .header .sp_btn div span.bottom {
    top: 35px;
    -webkit-transform: translateY(-20px) rotate(45deg);
    transform: translateY(-20px) rotate(45deg);
}
.open .header .sp_btn div span.bottom:after {
    opacity: 0;
}
.header .sp_gnavi{
    display: block;
    position: absolute;
    top: 68px;
    right: -300px;
    width: 300px;
    height: auto;
    background: #2a5bbe;
    z-index: 998;
}

.header .sp_gnavi .head-navi,
.header .sp_gnavi .foot-navi {
    display: block;
    position: relative;
}
.header .sp_gnavi .head-navi ul {
    height: auto;
    padding-right: 0;
}
.header .sp_gnavi .head-navi ul li {
    font-size: 13px;
    margin: 0;
    padding: 0 0 0 10px;
    border-bottom: 1px solid #fff;
    display: block;
    line-height: 52px;
    text-align: left;
}
.header .sp_gnavi .head-navi ul li a {
    display: block;
    color: #fff;
}
.header .sp_gnavi .foot-navi {
	padding: 10px;
}
.header .sp_gnavi .foot-navi ul {
	letter-spacing: -.40em;
}
.header .sp_gnavi .foot-navi ul li {
	letter-spacing: normal;
	width: 50%;
	display: inline-block;
}
.header .sp_gnavi .foot-navi ul li a {
	display: block;
	color: #fff;
	text-align: center;
	padding: 10px;
	font-size: .875rem;
	line-height: 1rem;
}
.header .sp_gnavi .foot-navi ul li a.btn-tel {
	background: #50a0f0;
	margin-right: 10px;
}
.header .sp_gnavi .foot-navi ul li a.btn-tel:before {
	content: "";
	display: block;
	background: url(../images/common/ico_tel.png) no-repeat;
	background-size: cover;
	width: 27px;
	height: 27px;
	margin: 14px auto 18px;
}
.header .sp_gnavi .foot-navi ul li a.btn-email {
	background: #17c9bb;
}
.header .sp_gnavi .foot-navi ul li a.btn-email:before {
	content: "";
	display: block;
	background: url(../images/common/ico_mail.png) no-repeat;
	background-size: cover;
	width: 31px;
	height: 24.5px;
	margin: 20px auto 14px;
}
/* .header .sp_gnavi .foot-navi ul li a.btn-telemail {
	background: #17c9bb;
}
.header .sp_gnavi .foot-navi ul li a.btn-telemail:before {
	content: "";
	display: block;
	background: url(../images/common/ico_tel-mail.png) no-repeat;
	background-size: cover;
	width: 58px;
	height: 25px;
	margin: 0 auto 12px;
} */
.header .sp_gnavi .foot-navi ul li.p-head-navi-list_tool {
	width: 100%;
	display: block;
	margin: 10px 0 20px;
}
.header .sp_gnavi .foot-navi ul li a.btn-tool {
	background: #FFF;
	color: #3664c1;
	padding: 20px 0;
	font-size: 1rem;
}
.header .sp_gnavi .foot-navi ul li a.btn-tool:before {
	content: "";
	display: inline-block;
	vertical-align: middle;
	background: url(../images/common/ico_tool.png) no-repeat;
	background-size: cover;
	width: 40px;
	height: 42px;
	margin-right: 6px;
}

.overlay{
    position: fixed;
    top: 0;
    z-index: 10;
    display: none;
    width: 100%;
    height: 100%;
    background-color: #000;
    opacity: 0.5;
}


/* footer */
.footer {
	width: 100%;
	padding-top: 71px;
}
.footer .footer-top {
	background: url(../images/common/footer-top_bg.gif) repeat-y center center;
}
.footer .footer-top .inner {
	max-width: 1200px;
	margin: 0 auto;
	color: #fff;
}
.footer .footer-top .inner a {
	color: #fff;
}
.footer .footer-top .tel-area {
	background: #50a0f0;
	float: left;
	width: 80%;
	padding: 60px 0;
}
.footer .footer-top .tel-area > .left p {
	font-size: 24px;
	padding-left: 59px;
	/*margin-top: 60px;*/
	margin-top: 30px;
	position: relative;
}
.footer .footer-top .tel-area > .left .p-contact_tel-icon:before {
	content: "";
	background: url(../images/common/ico_tel.png) no-repeat;
	display: block;
	width: 49px;
	height: 50px;
	position: absolute;
	top: -10px;
	left: 0;
}
.footer .footer-top .tel-area > .left p span {
	font-size: 18px;
}
/* .footer .footer-top .tel-area > .right .name {
	font-size: 20px;
	line-height: 20px;
	margin-bottom: 10px;
	padding-left: 18px;
}
.footer .footer-top .tel-area > .right {
	margin-right: 35px;

	margin-top: 20px;
}
.footer .footer-top .tel-area > .right .tel {
	font-size: 48px;
	border-bottom: 1px solid #fff;
	padding: 0 18px 10px;
	margin-bottom: 20px;
	line-height: 38px;
}
.footer .footer-top .tel-area > .right .tel span {
	font-size: 22px;
	display: inline-block;
	vertical-align: middle;
	margin-left: 20px;
}
.footer .footer-top .tel-area > .right .left:first-child {
	border-right: 1px solid #fff;
	padding-right: 40px;
	margin-right: 40px;
	padding-left: 18px;
}
.footer .footer-top .tel-area > .right .left p {
	font-size: 15px;
	line-height: normal;
}
.footer .footer-top .tel-area > .right .left p.service-tel,
.footer .footer-top .tel-area > .right .left p.facility-tel {
	font-size: 30px;
} */


/* .contact-tel-area .p-contact-information, */
.footer-top .tel-area .p-contact-information {
	margin: 2% 4% 0 0;
}
/* .contact-tel-area .p-contact-information_wrap, */
.footer-top .tel-area .p-contact-information_wrap {
	border-bottom: 1px solid #fff;
	margin-bottom: 8%;
}
/* .contact-tel-area .p-contact-information_wrap:last-child, */
.footer-top .tel-area .p-contact-information_wrap:last-child {
	border: none;
}
/* .contact-tel-area .p-contact-information_txt, */
.footer-top .tel-area .p-contact-information_txt {
		font-size: 1.25rem;
		line-height: 20px;
}
/* .contact-tel-area .p-contact-information_tel, */
.footer-top .tel-area .p-contact-information_tel {
		font-size: 1.875rem;
}
/* .contact-tel-area .p-contact-information_txt {
		letter-spacing: 0;
}
.contact-tel-area .p-contact-information_small,
.contact-tel-area .p-contact-information_time {
		font-size: 1rem;
}
.contact-tel-area .p-contact-information_tel {
		padding: 0 2.25rem;
} */
.footer-top .tel-area .p-contact-information_txt {
	padding-left: 18px;
	letter-spacing: -.4px;
	margin-bottom: 2px;
}
.footer-top .tel-area .p-contact-information_small {
	font-size: 0.937rem;
	letter-spacing: 0;
}
.footer-top .tel-area .p-contact-information_tel {
	display: inline-block;
	padding: 0 10px 0 18px;
	margin-bottom: 20px;
	line-height: 38px;
}
.footer-top .tel-area .p-contact-information_time {
	display: inline-block;
	vertical-align: middle;
	margin-bottom: 12px;
	font-size: 0.937rem;
	padding-left: 10px;
}

.footer .footer-top .mail-area {
	background: #17c9bb;
	float: right;
	width: 20%;
}
.footer .footer-top .mail-area p {
	font-size: 24px;
	text-align: center;
	margin-top: 100%;
}
.footer .footer-top .mail-area a:before {
	content: "";
	display: block;
	background: url(../images/common/ico_mail.png) no-repeat;
	width: 55px;
	height: 43px;
	margin: 0 auto 10px;
}
.footer .footer-bottom {
	padding: 90px 0 15px;
}
.footer .footer-bottom .inner {
	max-width: 1120px;
	margin: 0 auto;
}
.footer .footer-bottom .f-logo {
	margin-bottom: 90px;
}
.footer .footer-bottom article {
	float: left;
	width: 265px;
	font-size: 11px;
}
.footer .footer-bottom article .f-ttl {
	font-size: 14px;
	color: #00b9aa;
	margin-bottom: 15px;
}
.footer .footer-bottom article ul li {
	line-height: 16px;
	margin-bottom: 10px;
	padding-left: 15px;
	position: relative;
}
.footer .footer-bottom article ul li:before {
	content: "";
	display: block;
	background: #00c4b4;
	width: 10px;
	height: 1px;
	position: absolute;
	top: 50%;
	left: 0;
}
.footer .footer-bottom .f-link01 {
	text-align: left;
	margin-bottom: 35px;
	line-height: normal;
}
.footer .footer-bottom .f-link01 li {
	display: inline-block;
	margin-right: 25px;
	font-size: 16px;
	font-weight: 700;
}
.footer .footer-bottom .f-link01 li a {
	color: #00b9aa;
}
.footer .footer-bottom .f-link01 li a:hover {
	text-decoration: underline;
}
.footer .footer-bottom .f-link02 {
	border-top: 1px solid #c8c8c8;
	border-bottom: 1px solid #c8c8c8;
	padding: 14px 13px 13px;
}
.footer .footer-bottom .f-link02 li {
	margin-right: 14px;/*20220712*/
	vertical-align: middle;
	display: inline-block;
}
.footer .footer-bottom .f-link02 li.last {
	font-size: 14px;
	line-height: 36px;
	border-left: 1px solid #c8c8c8;
	padding-left: 12px;
	margin-left: 12px;
	margin-right: 0;
}
.footer .copyright {
	text-align: center;
	color: #afafaf;
	font-size: 14px;
	padding-top: 15px;
}

/* ftrequirement */
.ftrequirement {
	padding: 10px;
	text-align: center;
}
.ftrequirement-lists li {
	display: inline-block;
	vertical-align: middle;
	padding: 0 10px;
	font-size: 13px;
	line-height: 1;
}
.ftrequirement-lists li:not(:first-child) {
	border-left: 1px solid #2838a9;
}
.ftrequirement-lists li a {
	color: #2838a9;
}

/* pagetop */


/* ttl */


/* bread */


/* table */
.tb01 {
	width: 100%;
	border: 1px solid #d5d5d5;
}
.tb01 th,
.tb01 td {
	font-weight: normal;
	border: 1px solid #d5d5d5;
	padding: 5px 15px;
	text-align: center;
	vertical-align: middle;
	word-wrap: break-word;
}
.tb01.text-left td {
	text-align: left;
}
.tb01 th {
	background: #f0f4fb;
}
.tb01 th span {
	font-size: 13px;
}

.tb02 {
	width: 100%;
	border-top: 1px solid #d5d5d5;
}
.tb02 th,
.tb02 td {
	border-bottom: 1px solid #d5d5d5;
	padding: 15px;
	text-align: left;
	vertical-align: top;
	word-wrap: break-word;
}
.tb02 th {
	border-right: 1px solid #d5d5d5;
	font-weight: 700;
	background: #f7f7f7;
}

.tb03 {
	width: 100%;
}
.tb03 th,
.tb03 td {
	border-bottom: 1px solid #d5d5d5;
	padding: 10px 15px;
	text-align: left;
	vertical-align: top;
	word-wrap: break-word;
}

.tb-form {
	width: 100%;
	margin-bottom: 60px;
}
.tb-form th,
.tb-form td {
	text-align: left;
	vertical-align: top;
	font-size: 15px;
	font-weight: normal;
	line-height: 20px;
	padding-bottom: 30px;
}
.tb-form th {
	padding-left: 30px;
	padding-right: 30px;
	position: relative;
}
.tb-form th.mark:before {
	content: "";
	display: inline-block;
	background: #17c9bb;
	width: 9px;
	height: 4px;
	position: absolute;
	top: 8px;
	left: 10px;
}
.tb-form th span.required:after {
	content: "";
	display: inline-block;
	background: url(../images/contact/ico_required.png) no-repeat;
	width: 47px;
	height: 18px;
	position: relative;
	top: 4px;
}


/* button */
.btn-normal,
.btn-normal_contact {
	display: inline-block;
	width: 100%;
	font-size: 20px;
	text-align: center;
	padding: 15px 0;
	background: #2a5bbe;
	color: #fff;
	opacity: 1;
	transition: opacity .2s ease-in-out;
	-moz-transition: opacity .2s ease-in-out;
	-webkit-transition: opacity .2s ease-in-out;
	position: relative;
}
.btn-normal02 {
	display: inline-block;
	font-size: 20px;
	text-align: center;
	padding: 10px 20px;
	border:2px solid #2a5bbe;
	color: #2a5bbe;
	opacity: 1;
	transition: opacity .2s ease-in-out;
	-moz-transition: opacity .2s ease-in-out;
	-webkit-transition: opacity .2s ease-in-out;
	position: relative;
	border-radius:3px;
        -webkit-border-radius:3px;
        -moz-border-radius:3px;
}
.btn-normal:hover {
	opacity: 0.6;
}
.btn-normal span {
	display: block;
	font-size: 16px;
}

.btn-primary {
	display: inline-block;
	width: 100%;
	font-size: 18px;
	text-align: center;
	padding: 15px 0;
	background: #e8f0ff;
	color: #2a5bbe;
	opacity: 1;
	transition: opacity .2s ease-in-out;
	-moz-transition: opacity .2s ease-in-out;
	-webkit-transition: opacity .2s ease-in-out;
	position: relative;
}
.btn-primary02 {
	display: inline-block;
	width: 100%;
	font-size: 20px;
	text-align: center;
	padding: 15px 0;
	background: #e8f0ff;
	color: #2a5bbe;
	opacity: 1;
	transition: opacity .2s ease-in-out;
	-moz-transition: opacity .2s ease-in-out;
	-webkit-transition: opacity .2s ease-in-out;
	position: relative;
}

.underline {
	text-decoration: underline;
}
.bold {
	font-weight: 700;
}
.normal {
	font-weight: normal;
}

.imgA { width: 100%; }

.inline-list {
	text-align: center;
	letter-spacing: -.40em;
}
.inline-list li {
	letter-spacing: normal;
	display: inline-block;
}


/* --------------------------------------------------------------
  お知らせ詳細のスタイル　エディタ共通
-------------------------------------------------------------- */

.detail .news-list dl dd div h1 {
	font-size: 48px;
	text-align: center;
	/* border-bottom: 1px solid #3a3a3a; */
	/* padding-bottom: 50px; */
	margin-bottom: 50px;
}

.detail .news-list dl dd div h2 {
	font-size: 24px;
	margin-bottom: 50px;
}

.detail .news-list dl dd div h3 {
	font-size: 24px;
	font-weight: 400;
	color: #2a5bbe;
	border-bottom: 1px solid #c1c1c1;
	padding-bottom: 20px;
	margin-bottom: 40px;
	text-align: center;
}

.detail .news-list dl dd div h4 {
	font-size: 20px;
	margin-bottom: 20px;
}

.detail .news-list dl dd div h5 {
	border-bottom: 1px solid #3a3a3a;
	padding-bottom: 20px;
	margin-bottom: 20px;
}

.detail .news-list dl dd div h6 {
	font-size: 100%;
	font-weight: bold;
	margin: 0px 0px 0.5em 0px;
}

.detail .news-list dl dd div p {
	margin: 0 0 20px;
}

.detail .news-list dl dd div ol,
.detail .news-list dl dd div ul {
	margin-left: 24px;
	margin-bottom: 20px;
}

.detail .news-list dl dd div ul li {
	list-style: disc;
}
.detail .news-list dl dd div ol li {
	list-style: decimal;
}

.detail .news-list dl dd div table {
width: 100%;
border: 1px solid #d5d5d5;
}
.detail .news-list dl dd div table th,
.detail .news-list dl dd div table td {
font-weight: normal;
border: 1px solid #d5d5d5;
padding: 5px 15px;
text-align: center;
vertical-align: middle;
word-wrap: break-word;
}
.detail .news-list dl dd div table th {
background: #f0f4fb;
}
