@charset "UTF-8";

div.main-img-wrap {
    width: 100%;
    position: relative;
}

.main-img-wrap:after {
    content: "";
    /*	width: 32.3%;*/
    height: 100%;
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    background: url(../img/common/headd-bg.png) 50% 100% no-repeat;
    background-size: 100% auto;
}

div.main-img-wrap img {
    width: 100%;
    vertical-align: bottom;
}

div.cap-wrap {
    width: 100%;
    background: #ffffff;
    position: relative;
    box-sizing: border-box;
}

.cap-wrap:before {
    content: "";
    display: block;
    padding-top: 13.3%;
}

.cap-wrap div {
    /*	width: 18.1%;*/
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    /*
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	*/
}

.cap-wrap div img {
    display: block;
    /*
	margin: -10% auto 14%;
	width: 23.3%;
	*/
    height: auto;
}

.cap-wrap h2 {
    width: 100%;
    margin: auto;
    padding-bottom: 5%;
    /*	border-bottom: 1px solid #0061b1;*/
}

.cap-wrap h2:before {
    /*
	content: "";
	display: block;
	padding-top: 50%;
	*/
}

.cap-wrap h2 span {
    color: #0061b1;
    letter-spacing: .5rem;
    text-indent: .5rem;
    display: block;
    text-align: center;
    line-height: 1;
}

.cap-wrap p {
    text-align: center;
    width: 100%;
    letter-spacing: .1rem;
    text-indent: .1rem;
}

/*
div.main-img-wrap {
	width: 100%;
	position: relative;
}
div.main-img-wrap img {
	width: 100%;
	vertical-align: bottom;
}
div.main-img-wrap div.cap-wrap {
	width: 100%;
	background: #ffffff;
	position: relative;
	box-sizing: border-box;
}
.cap-wrap h2 {
	background: url(../img/common/headd-bg.svg) 50% 0 no-repeat;
	background-size: 100% auto;
	position: absolute;
	right: 0;
	left: 0;
	margin: auto;
	bottom: 0;
}
.cap-wrap h2:before {
	content: "";
	display: block;
	padding-top: 50%;
}
.cap-wrap h2 span {
	color: #004DA1;
	font-weight: normal;
	letter-spacing: .5rem;
	text-indent: .5rem;
	display: block;
	text-align: center;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	background: url(../img/about/about-icon.svg) no-repeat;
	background-size: auto 29%;
	padding-top: 32%;
	background-position: 50% 40%;

}
.cap-wrap p {
	border-top: 1px solid #004DA1;
	text-align: center;
	position: absolute;
	width: 100%;
	letter-spacing: .1rem;
	text-indent: .1rem;
}
*/
div.anklink-wrap {
    margin: auto;
    max-width: 96%;
}

.anklink-wrap ul li {
    position: relative;
}

.anklink-wrap ul li a {
    color: #ffffff;
    background: #004DA1;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 50px;
    letter-spacing: 1.5
}

.greeting-wrap,
.policy-wrap,
.about-wrap,
.history-wrap,
.access-wrap {
    text-align: center;
}

.policy-wrap,
.history-wrap {
    background: #f7f7f7;
    /*	background: url(../img/about/about-bg.gif) 0 0 repeat;*/
}

.greeting-wrap h1,
.policy-wrap h1,
.about-wrap h1,
.history-wrap h1,
.access-wrap h1 {
    display: inline-block;
    border-bottom: 4px solid #221814;
    font-weight: bold;
    letter-spacing: .25rem;
    text-indent: .5rem;
    text-align: center;
}

/* greeting */
.greeting-wrap div {
    margin: auto;
}

.greeting-wrap div.img-wrap {
    text-align: right;
    margin-bottom: 5.3%;
}

.greeting-wrap div.img-wrap img {
    display: block;
}

/*
.greeting-wrap div.img-wrap img {
	float: right;
}
*/
.greeting-wrap div.cf p {
    text-align: left;
}

.greeting-wrap div.cf p.sign {
    font-size: 20px;
    text-align: right;
}

/* policy */
.policy-wrap dl {
    border: 1px solid #004DA1;
    background: #ffffff;
    margin: auto;
}

.policy-wrap dl dt {
    color: #004da1;
    border-bottom: 4px solid #004DA1;
}

.policy-wrap dl dd {
    text-align: left;
}

.policy-wrap dl dd ul {
    text-indent: -1em;
    margin-left: 1em;
}

.bnr_sdgs a:hover {
    opacity: 0.8;
}

table {
    border-top: 1px solid #9F9FA0;
    border-right: 1px solid #9F9FA0;
    border-left: 1px solid #9F9FA0;
}

table tr {
    border-bottom: 1px solid #9F9FA0;
}

table th {
    background: #EEEFEF;
}

table td {
    text-align: left;
    border-left: 1px solid #9F9FA0;
    line-height: 1.9;
}

table td strong {
    display: block;
}

table td img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
}

/* access */
ul.access-list {
    text-align: left;
}

.access-list li {
    background: #f7f7f7;
}

.access-list li img {
    vertical-align: bottom;
}







/*
@media all and (max-width:321px){
.waiting-wrap p {
font-size: 1.2rem;
}
}
*/
/*
@media all and (min-width: 322px) and (max-width: 600px) {
.waiting-wrap p {
font-size: 1.3rem;
}
}
@media all and (min-width: 601px) and (max-width: 1289px) {
.waiting-wrap p {
font-size: 28px;
}
}
@media all and (min-width: 1290px) {
.waiting-wrap p {
font-size: 34px;
}
}
*/


/**==============================================**/
/**==============================================**/
/*
/*
/*			SP
/*
/*
/**==============================================**/
/**==============================================**/
@media all and (max-width:599px) {

    .main-img-wrap::after {
        width: 52.3%;
    }

    .cap-wrap::before {
        padding-top: 19.3%;
    }

    .cap-wrap div {
        width: 38.1%;
    }

    .cap-wrap div img {
        margin: -14% auto 10%;
        width: 23.3%;
    }

    .content-wrap .inner-wrap {
        width: 94%;
        margin: auto;
    }

    .greeting-wrap h1,
    .policy-wrap h1,
    .about-wrap h1,
    .history-wrap h1,
    .access-wrap h1 {
        margin: 8% auto 5%;
    }

    .policy-wrap h1 {
        font-size: 20px;
        letter-spacing: -0.2rem;
    }

    div.anklink-wrap {
        width: 96%;
        margin-bottom: 5%;
    }

    .anklink-wrap ul li {
        width: 50%;
        float: left;
    }

    .anklink-wrap ul li a {
        display: flex;
        width: 100%;
        line-height: 1.5;
        justify-content: center;
        align-items: center;
        height: 50px;
        border: 1px solid #ffffff;
        box-sizing: border-box;
    }

    /* tab~ greeting */
    .greeting-wrap>div.cf {
        padding: 0;
        width: 94%;
    }

    .greeting-wrap div.img-wrap {
        margin-bottom: 3%;
        /*
		margin: 0 0 0 1em;
		width: 40%;
		height: auto;
*/
    }

    .greeting-wrap div.img-wrap img {
        margin: 0 0 5%;
    }

    .greeting-wrap div.img-wrap img:first-child {
        margin: 0 auto 5%;
        width: 70%;
    }

    .greeting-wrap div.img-wrap img:nth-child(2) {
        display: inline;
        width: 40%;
    }

    .greeting-wrap div.cf p {
        font-size: 1.4rem;
        line-height: 1.8;
    }

    .greeting-wrap div.cf p.sign {
        font-size: 1.7rem;
        margin-top: 1em;
        padding-right: 2%;
        margin-bottom: 10%;
    }

    .greeting-wrap div.cf p.sign img {
        width: 65%;
        height: auto;
    }

    /* tab~ policy */
    div.policy-wrap {
        padding-bottom: 5%;
    }

    .policy-wrap h1 {}

    .policy-wrap dl {
        width: 100%;
        margin-bottom: 5%;
        padding: 5% 0;
    }

    .policy-wrap dl dt {
        letter-spacing: .2rem;
        text-indent: .2rem;
        width: 90%;
        font-size: 1.8rem;
        margin: 0 5%;
        font-weight: bold;
        padding-bottom: 4%;
    }

    .policy-wrap dl dd {
        width: 90%;
        font-size: 1.4rem;
        line-height: 1.8;
        margin: 3% auto;
    }

    .policy-wrap dl dd ul {
        margin-bottom: 2em;
    }

    /* about */
    .about-wrap h1 {}

    .about-wrap table th,
    .about-wrap table td {
        display: block;
        width: 100%;
        text-align: left;
        border: 0;
        font-size: 1.4rem;
        padding: 1% 0.5em;
        box-sizing: border-box;
    }

    .about-wrap table td {
        padding-left: 1em;
        padding-bottom: .5em;
    }

    /* history */
    .history-wrap h1 {}

    .history-wrap table {
        background: #ffffff;
    }

    .history-wrap table th,
    .history-wrap table td {
        display: block;
        width: 100%;
        text-align: left;
        border: 0;
        font-size: 1.4rem;
        padding: 1% 0.5em;
        box-sizing: border-box;
    }

    .history-wrap table td {
        padding-left: 1em;
        padding-bottom: .5em;
    }

    /* access */
    .access-wrap {
        padding-bottom: 8%;
    }

    .access-wrap h1 {}

    .access-list li {
        padding: 3%;
        margin-bottom: 5%;
    }

    .access-list li div.cap {
        width: 100%;
        position: relative;
        line-height: 1.6;
    }

    .access-list li div.cap h2 {
        font-size: 1.8rem;
    }

    .access-list li div.cap p {
        font-size: 1.4rem;
    }

    .access-list li div.cap a {
        font-size: 1.4rem;
        color: #004DA1;
        font-weight: bold;
    }

    .access-list li div.cap a:hover {
        text-decoration: underline;
    }

    .access-list li div.cap img {
        width: 100%;
        height: auto;
        margin: 2% auto;
    }

    .access-list li div.map {
        width: 100%;
        height: auto;
    }




    .access-list li div.map {
        position: relative;
        padding-bottom: 56.25%;
        padding-top: 30px;
        height: 0;
        overflow: hidden;
    }

    .access-list li div.map iframe,
    .access-list li div.map object,
    .access-list li div.map embed {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

    .bnr_sdgs a img {
        width: 90%;
    }







}









/**==============================================**/
/**==============================================**/
/*
/*
/*			tab 〜
/*
/*
/**==============================================**/
/**==============================================**/

@media all and (min-width: 600px) {

    .main-img-wrap::after {
        width: 52.3%;
    }

    .cap-wrap::before {
        padding-top: 19.3%;
    }

    .cap-wrap div {
        width: 38.1%;
    }

    .cap-wrap div img {
        margin: -14% auto 8%;
        width: 23.3%;
    }

    .cap-wrap h2 {
        padding-bottom: 3%;
    }

    div.anklink-wrap {
        max-width: 96%;
        margin-bottom: 30px;
    }

    .anklink-wrap ul li {
        width: 20%;
        float: left;
    }

    .anklink-wrap ul li:after {
        content: "";
        position: absolute;
        top: 0;
        right: .5px;
        width: 1px;
        height: 100%;
        background: #ffffff;
    }

    .anklink-wrap ul li:last-child:after {
        content: none;
    }

    .anklink-wrap ul li a {
        display: flex;
        width: 100%;
        justify-content: center;
        align-items: center;
        height: 50px;
        letter-spacing: 1.5;
    }

    .anklink-wrap ul li a:hover {
        background: #003172;
    }

    .greeting-wrap h1,
    .policy-wrap h1,
    .about-wrap h1,
    .history-wrap h1,
    .access-wrap h1 {
        margin: 20px auto 35px;
        font-size: 35px;
    }

    /* tab~ greeting */
    .greeting-wrap>div.cf {
        padding: 0 6%;
    }

    .greeting-wrap div.img-wrap img {
        margin: 0 0 25px;
    }

    .greeting-wrap div.img-wrap img:first-child {
        margin: 0 auto 30px;
    }

    .greeting-wrap div.img-wrap img:nth-child(2) {
        margin: auto 0 auto auto;
    }

    .greeting-wrap div.cf p {
        font-size: 16px;
        line-height: 2;
    }

    .greeting-wrap div.cf p.sign {
        font-size: 20px;
        margin-top: 1em;
        margin-bottom: 60px;
    }

    /* tab~ policy */
    div.policy-wrap {
        padding-bottom: 5px;
    }

    .policy-wrap h1 {
        margin: 70px auto 60px;
    }

    .policy-wrap dl {
        max-width: 826px;
        margin-bottom: 55px;
        padding: 60px 0 58px;
    }

    .bnr_sdgs {
        margin-bottom: 55px;
    }

    .policy-wrap dl dt {
        letter-spacing: .5rem;
        text-indent: .5rem;
        width: 25%;
        float: left;
        margin: 0 5.4%;
        font-weight: bold;
    }

    .policy-wrap .sh {
        letter-spacing: .02rem;
        text-indent: .05rem;
    }

    .policy-wrap dl dd {
        width: 62.2%;
        float: right;
        font-size: 14px;
        padding-right: 3%;
        box-sizing: border-box;
        line-height: 2;
    }

    /* about */
    .about-wrap {
        padding-bottom: 60px;
    }

    .about-wrap h1 {
        margin: 70px auto 60px;
    }

    .about-wrap table td {
        width: 80%;
        padding: 5px 20px;

    }

    /* history */
    .history-wrap {
        padding-bottom: 60px;
    }

    .history-wrap h1 {
        margin: 70px auto 60px;
    }

    .history-wrap table {
        background: #ffffff;
        width: 100%;
    }

    .history-wrap table td {
        width: 80%;
        padding: 5px 20px;
    }

    /* access */
    .access-wrap {
        padding-bottom: 60px;
    }

    .access-wrap h1 {
        margin: 70px auto 60px;
    }

    .access-list li {
        padding: 2px 2px 2px 0;
        margin-bottom: 30px;
    }

    .access-list li div.cap {
        float: left;
        width: 53.2%;
        position: relative;
        line-height: 1.6;
        max-height: 375px !important;
    }

    .access-list li div.cap h2 {
        font-size: 20px;
        margin: 3% 0 0 10%;
    }

    .access-list li div.cap p {
        font-size: 15px;
        margin: 0 0 0 10%;
    }

    .access-list li div.cap a {
        font-size: 15px;
        color: #004DA1;
        margin: 0 0 0 10%;
    }

    .access-list li div.cap a:hover {
        text-decoration: underline;
    }

    .access-list li div.cap img {
        width: 100%;
        height: auto;
        position: absolute;
        bottom: 0;
        left: 0;
    }

    .access-list li div.map {
        float: right;
        width: 46.8%;
        max-width: 385px;
        max-height: 375px !important;
    }



}









/**==============================================**/
/**==============================================**/
/*
/*
/*			tab 〜 PC
/*
/*
/**==============================================**/
/**==============================================**/

@media all and (min-width: 600px) and (max-width: 959px) {

    /* tab~pc policy */
    .policy-wrap dl dt {
        font-size: 20px;
        width: 25%;
        margin: 0 2.4%;
    }

    .access-list li div.map {
        position: relative;
        padding-bottom: 41.1%;
        padding-top: 30px;
        height: 0;
        overflow: hidden;
    }

    .access-list li div.map iframe,
    .access-list li div.map object,
    .access-list li div.map embed {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }







}



/*
@media all and (min-width: 960px) and (max-width: 1280px){}
*/









/**==============================================**/
/**==============================================**/
/*
/*
/*			PC
/*
/*
/**==============================================**/
/**==============================================**/
@media print,
screen and (min-width:960px) {

    .main-img-wrap:after {
        width: 32.3%;
    }

    .cap-wrap::before {
        padding-top: 13.3%;
    }

    .cap-wrap div {
        width: 18.1%;

    }

    .cap-wrap div img {
        margin: -10% auto 20%;
        width: 35.5%;
    }

    /* pc .cap-wrap */
    .cap-wrap h2 {
        font-size: 38px;
    }

    .content-wrap .inner-wrap {
        max-width: 826px !important;
    }

    div.anklink-wrap {
        max-width: 1040px;
    }

    .anklink-wrap ul li {
        width: 20%;
        float: left;
    }

    .anklink-wrap ul li:after {
        content: "";
        position: absolute;
        top: 0;
        right: .5px;
        width: 1px;
        height: 100%;
        background: #ffffff;
    }

    .anklink-wrap ul li a {
        display: flex;
        width: 100%;
        line-height: 1.5;
        justify-content: center;
        align-items: center;
        height: 50px;
    }

    .anklink-wrap ul li a:hover {
        background: #003172;
    }

    /* pc~ greeting */
    .greeting-wrap>div.cf {
        max-width: 780px;
    }

    .greeting-wrap div.img-wrap img:first-child {
        margin: 0 auto 30px;
    }

    .greeting-wrap div.img-wrap img:nth-child(2) {
        margin: auto 0 auto auto;
    }

    .greeting-wrap div.cf p {
        line-height: 2.2;
    }

    .greeting-wrap div.cf p.sign {}

    /* pc~ policy */
    .policy-wrap dl dt {
        font-size: 26px !important;
    }

    table {
        font-size: 14px;
    }

    table th {
        width: 183px;
    }

    table td {
        width: 604px;
        padding: 5px 20px;
    }

    /* pc~ about */
    .about-wrap {
        padding-bottom: 120px;
    }

    /* pc~ history */
    .history-wrap {
        padding-bottom: 70px;
    }


}

@media all and (-ms-high-contrast: none) {
    .anklink-wrap ul li a {
        padding-top: 6px;
    }
}