@charset "utf-8";

/* *****************************************************************************
=01 reset style
=02 option style
=03 common style
=04 layout style
***************************************************************************** */

/*---------- =01 reset style ----------*/
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
/*---------- //end reset style ----------*/

/*---------- =02 option style ----------*/
.tal{text-align:left!important;}
.tac{text-align:center!important;}
.tar{text-align:right!important;}
.mbNone{margin-bottom:0!important;}
.mbShort{margin-bottom:1em!important;}
.mbMiddle{margin-bottom:2em!important;}
.mbLong{margin-bottom:3em!important;}
.bold{font-weight:bold;}
.cf{zoom:1;}
.cf:before,.cf:after{content:"";display:table;}
.cf:after{clear:both;}
/*---------- //end option style ----------*/

/*---------- =03 common style ----------*/
*{
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}
html{
	font-size: 62.5%;
}
@font-face{
    font-family: "Yu Gothic";
    src: local("Yu Gothic Medium");
    font-weight: 400;
}
@font-face{
    font-family: "Yu Gothic";
    src: local("Yu Gothic Bold");
    font-weight: bold;
}
body{
    font-family: Helvetica,"Yu Gothic","Yu Gothic Medium","游ゴシック Medium",YuGothic,"游ゴシック体",sans-serif;
    font-style: normal;
    font-weight: 400;
	line-height: 2;
	color: #000000;
	background-color: #ffffff;
	-webkit-text-size-adjust: 100%;
	font-size: 1.6rem;
}
a{
	color: #1a3167;
	text-decoration: none;
}
a:hover,
a:active{
	text-decoration: none;
}
img,a img{
	vertical-align: bottom;
	border: none;
}
strong{
	font-weight: bold;
}
::selection{
	background-color: #3583d1;
	color: #ffffff;
}
::-moz-selection {
	background-color: #3583d1;
	color: #ffffff;
}
@font-face {
    font-family: 'romana_btbold';
    src: url('../font/romanabtbold-webfont.woff2') format('woff2'),
         url('../font/romanabtbold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'twcenmtstd';
    src: url('../font/twcenmtstd-webfont.ttf') format('truetype'),
         url('../font/twcenmtstd-webfont.woff2') format('woff2'),
         url('../font/twcenmtstd-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
.en{
    font-family: 'romana_btbold';
    color: #1a3167;
}
.en-other{
    font-family: 'twcenmtstd';
}

@media print, screen and (max-width: 760px){
    body{
    	line-height: 1.8;
        font-family: Helvetica,"Hiragino Kaku Gothic ProN",sans-serif;
        font-weight: normal;
    }
}

/*---------- //end common style ----------*/

/*---------- =04 layout style ----------*/
/*========================================
header layout
========================================*/
.header{
    width: 100%;
    background-color: #ffffff;
    z-index: 1003;
}
.header-inner{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    justify-content: space-between;
    margin: 0 auto;
    width: 1160px;
    height: 175px;
}

@media print, screen and (max-width: 1200px){
    .header{
        padding: 0 20px;
    }
    .header-inner{
        width: 100%;
    }
}

@media print, screen and (max-width: 1000px){
    .header{
        height: 65px;
        padding: 0;
        padding: 0 0 0 8px;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
    }
    .header-inner{
        height: 65px;
    }
}

/* logo */
.logo{
    width: 258px;
}
.logo a{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.logo a:hover{
    filter: alpha(opacity=60);
	-moz-opacity: 0.6;
	opacity: 0.6;
}
.logo a img:first-child{
    width: 131px;
    margin-right: 16px;
}
.logo a img:last-child{
    width: 110px;
}

@media print, screen and (max-width: 1200px){
    /* logo */
    .logo{
        width: 22.2%;
    }
    .logo a img:first-child{
        width: 50.8%;
        margin-right: 6.6%;
    }
    .logo a img:last-child{
        width: 42.6%;
    }
}

@media print, screen and (max-width: 1000px){
    /* logo */
    .logo a:hover{
        filter: alpha(opacity=100);
	    -moz-opacity: 1;
	    opacity: 1;
    }
    .logo a img:first-child{
        width: 77px;
        margin-right: 12px;
        
    }
    .logo a img:last-child{
        width: 89px;
    }
}

@media print, screen and (max-width: 1200px){
    /* logo */
    .logo{
        width: 180px;
    }
}

/* global-nav */
.global-nav{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    box-pack: justify;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 824px;
}
.global-nav-list{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}
.global-nav-list li{
    font-weight: bold;
    line-height: 16px;
    font-size: 16px;
    padding-right: 28px;
    background: url(../images/line_nav_01.png) right center no-repeat;
    margin-right: 23px;
    white-space: nowrap;
}
.global-nav-list li span{
    padding-bottom: 26px;
    background: url(../images/arrow_nav_01.png) center bottom no-repeat;
}
.global-nav-list li:last-child{
    padding-right: 0;
    margin-right: 0;
    background-image: none;
}
.global-nav-list li a{
    position: relative;
}
.global-nav-list li a:hover::after{
    content: "";
    width: 11px;
    height: 4px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -26px;
    margin: auto;
    background: url(../images/arrow_nav_01.png) center top no-repeat;
}
.global-nav-list li span a:hover::after{
    display: none;
}

@media print, screen and (max-width: 1200px){
    /* global-nav */
    .global-nav{
        width: 73%;
        overflow: hidden;
    }
    .global-nav-list li{
        font-size: 1.4vw;
        padding-right: 5.7%;
        margin-right: 4.7%;        
    }
}

@media print, screen and (max-width: 1000px){
    /* global-nav */
    .global-nav{
        display: none;
    }
}

/* nav-list-entry */
.nav-list-entry{
    letter-spacing: -.4em;
    white-space: nowrap;
}
.nav-list-entry li{
    display: inline-block;
}
.nav-list-entry li a{
    font-size: 1.45rem;
    color: #ffffff;
    background-color: #47d5c0;
    background-image: url(../images/gradation_01.png);
    background-position: left center;
    background-repeat: repeat-x;
    background-size: auto 100%;
    border-bottom: 1px solid #43cab5;
	-webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    font-weight: bold;
    letter-spacing: 1px;
    line-height: 46px;
    display: block;
}
.nav-list-entry li:first-child a{
    padding-left: 25px;
    border-top-left-radius: 24px;
    border-bottom-left-radius: 24px;
}
.nav-list-entry li:last-child a{
    padding-right: 25px;
    border-top-right-radius: 24px;
    border-bottom-right-radius: 24px;
}
.nav-list-entry li a:hover{
	background: url(../images/gradation_01_on.png) left center repeat-x;
    background-size: auto 100%;
    border-bottom: 1px solid #43ccb3;
}
.nav-list-entry li:first-child a span{
    padding-right: 20px;
    border-right: 1px solid #1abb9a;
}
.nav-list-entry li:last-child a span{
    padding-left: 20px;
}

@media print, screen and (max-width: 1200px){
    /* nav-list-entry */
    .nav-list-entry{
        width: 260px;
    }
    .nav-list-entry li a{
        font-size: 1.35rem;
    }
    .nav-list-entry li:first-child a{
        padding-left: 22px;
    }
    .nav-list-entry li:last-child a{
        padding-right: 22px;
    }
    .nav-list-entry li:first-child a span{
        padding-right: 16px;
    }
    .nav-list-entry li:last-child a span{
        padding-left: 16px;
    }
}

/* hamburger-button */
.hamburger-button{
    display: none;
}

@media print, screen and (max-width: 1000px){
    /* hamburger-button */
    .hamburger-button{
        display: block;
        position: relative;
        width: 65px;
        height: 65px;
        cursor: pointer;
    }
    .hamburger-button span{
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        background-color: #1a3167;
        display: block;
        height: 2px;
        position: absolute;
        width: 26px;
    }
    .hamburger-button span:nth-child(1){
        -webkit-transform: rotate(0);
        transform: rotate(0);
        -webkit-transform-origin: left top;
        transform-origin: left top;
        top: 22px;
        left: 18px;
    }
    .hamburger-button span:nth-child(2){
        -webkit-transform-origin: left bottom;
        transform-origin: left bottom;
        top: 30px;
        left: 18px;
    }
    .hamburger-button span:nth-child(3){
        -webkit-transform-origin: right bottom;
        transform-origin: right bottom;
        top: 38px;
        left: 18px;
    }
    .hamburger-button span:nth-child(4){
        -webkit-transform-origin: right top;
        transform-origin: right top;
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        top: 33px;
        left: 16px;
        width: 0;
    }
    .hamburger-button.is-open span{
        width: 12px;
    }
    .hamburger-button.is-open span:nth-child(1){
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        top: 33px;
        left: 34px;
    }
    .hamburger-button.is-open span:nth-child(2){
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        top: 28px;
        left: 34px;
    }
    .hamburger-button.is-open span:nth-child(3){
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        top: 28px;
        left: 16px;
    }
}

/* hamburger-nav */
.hamburger-nav{
    display: none;
}

@media print, screen and (max-width: 1000px){
    /* hamburger-nav */
    .hamburger-nav{
        background-color: #1a3068;
        -webkit-transition-property: opacity, visibility, top;
        transition-property: opacity, visibility, top;
        -webkit-transition-duration: 0.6s;
        transition-duration: 0.6s;
        -webkit-transition-timing-function: cubic-bezier(0.64, 0.01, 0.39, 0.99);
        transition-timing-function: cubic-bezier(0.64, 0.01, 0.39, 0.99);
        -webkit-transition-delay: 0;
        transition-delay: 0;
        display: block;
        height: 100%;
        opacity: 0;
        overflow: auto;
        padding: 105px 0 40px;
        position: fixed;
        top: -100%;
        left: 0;
        visibility: hidden;
        width: 100%;
        -webkit-overflow-scrolling: touch;
        z-index: 1002;
    }
    .hamburger-nav.is-open{
        display: block;
        opacity: 1;
        top: 0;
        visibility: visible;
    }
    .nav-list-sp{
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
        margin: 0 40px 40px;
    }
    .nav-list-sp li{
        background-color: #ffffff;
        width: 50%;
        text-align: center;
        height: 152px;
        vertical-align: bottom;
        font-size: 16px;
        line-height: 16px;
    }
    .nav-list-sp li:first-child{
        border-right: 1px solid #1a3068;
        border-bottom: 1px solid #1a3068;
    }
    .nav-list-sp li:nth-child(2){
        border-bottom: 1px solid #1a3068;
    }
    .nav-list-sp li:nth-child(3){
        border-right: 1px solid #1a3068;
    }
    .nav-list-sp li a{
        display: block;
        font-weight: bold;
        padding-top: 105px;
    }
    .nav-list-sp li:first-child a{
        background: url(../images/icon_nav_01_sp.png) center 34px no-repeat;
        background-size: 74px 53px;
    }
    .nav-list-sp li:nth-child(2) a{
        background: url(../images/icon_nav_02_sp.png) center 34px no-repeat;
        background-size: 48px 53px;
    }
    .nav-list-sp li:nth-child(3) a{
        background: url(../images/icon_nav_03_sp.png) center 34px no-repeat;
        background-size: 49px 53px;
    }
    .nav-list-sp li:last-child a{
        background: url(../images/icon_nav_04_sp.png) center 34px no-repeat;
        background-size: 58px 53px;
    }
    .nav-list-sub-sp{
        text-align: center;
        line-height: 0;
        width: 100%;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    .nav-list-sub-sp li{
        font-size: 15px;
        line-height: 15px;
    }
    .nav-list-sub-sp li:first-child,
    .nav-list-sub-sp li:nth-child(2){
        width: 50%;
        margin-bottom: 20px;
    }
    .nav-list-sub-sp li:nth-child(3),
    .nav-list-sub-sp li:nth-child(4),
    .nav-list-sub-sp li:last-child{
        width: 33.33%;
    }
    .nav-list-sub-sp li a{
        color: #ffffff;
        padding-right: 22px;
        background: url(../images/arrow_nav_01_sp.png) right center no-repeat;
        background-size: 11px 9px;
    }
    .nav-list-entry-sp{
        border-top: 1px solid #384a7b;
        margin: 40px 40px 0;
        padding-top: 40px;
        letter-spacing: -.4em;
    }
    .nav-list-entry-sp li{
        display: inline-block;
        letter-spacing: normal;
        width: 50%;
    }
    .nav-list-entry-sp li:first-child{
        padding-right: 15px;
    }
    .nav-list-entry-sp li:last-child{
        padding-left: 15px;
    }
    .nav-list-entry-sp li a{
        display: block;
        font-size: 15px;
        font-weight: bold;
        line-height: 15px;
        padding: 25px;
        text-align: center;
        background: #ffffff url(../images/arrow_nav_02_sp.png) right 12px center no-repeat;
        background-size: 13px 10px;
    }
}

@media print, screen and (max-width: 760px){
    /* hamburger-nav */
    .hamburger-nav{
        padding: 85px 0 30px;
    }
    .nav-list-sp{
        margin: 0 20px 30px;
    }
    .nav-list-sp li{
        font-size: 13px;
        line-height: 13px;
        letter-spacing: 0;
    }
    .nav-list-sub-sp li{
        font-size: 1.25rem;
        line-height: 12px;
    }
    .nav-list-sub-sp li a{
        padding-right: 20px;
    }
    .nav-list-entry-sp{
        margin: 30px 20px 0;
        padding-top: 30px;
    }
    .nav-list-entry-sp li:first-child{
        padding-right: 10px;
    }
    .nav-list-entry-sp li:last-child{
        padding-left: 10px;
    }
    .nav-list-entry-sp li a{
        font-size: 12px;
        line-height: 12px;
        padding: 20px;
    }
}

@media print, screen and (max-width: 420px){
    /* hamburger-nav */
    .nav-list-sub-sp li:first-child{
        text-align: right;
        padding-right: 10px;
    }
    .nav-list-sub-sp li:nth-child(2){
        text-align: left;
        padding-left: 10px;
    }
    .nav-list-entry-sp li a{
        text-align: left;
        padding: 20px 15px;
        background: #ffffff url(../images/arrow_nav_02_sp.png) right 10px center no-repeat;
        background-size: 13px 10px;
    }
}

@media print, screen and (max-width: 390px){
    /* hamburger-nav */
    .nav-list-sp li{
        font-size: 3.4vw;
    }
    .nav-list-sub-sp li{
        font-size: 3.2vw;
    }
    .nav-list-sub-sp li:first-child{
        padding-right: 2%;
    }
    .nav-list-sub-sp li:nth-child(2){
        padding-left: 2%;
    }
    .nav-list-entry-sp li a{
        font-size: 3vw;
        padding: 20px 10px;
        background: #ffffff url(../images/arrow_nav_02_sp.png) right 8px center no-repeat;
        background-size: 13px 10px;
    }
}

@media print, screen and (max-width: 350px){
    /* hamburger-nav */
    .nav-list-entry-sp li:first-child{
        padding-right: 6px;
    }
    .nav-list-entry-sp li:last-child{
        padding-left: 6px;
    }
}

/*========================================
contents layout
========================================*/
/* js-anchor */
@media print, screen and (max-width: 1000px){
    .js-anchor{
        padding-top: 65px;
        margin-top: -65px;
    }
}

/* note */
.note{
    margin-left: 1em;
}
.note:before {
	content: '※';
	margin-left: -1em;
}

/* hover-fade */
.hover-fade{
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.hover-fade:hover{
    filter: alpha(opacity=60);
	-moz-opacity: 0.6;
	opacity: 0.6;
}

@media print, screen and (max-width: 760px){
    /* hover-fade */
    .hover-fade:hover{
        filter: alpha(opacity=100);
	    -moz-opacity: 1;
	    opacity: 1;
    }
}

/* text-link */
.text-link a{
    position: relative;
    color: #1a3167;
}
.text-link a::after{
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-duration: .2s;
    transition-duration: .2s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-delay: 0;
    transition-delay: 0;
    background: #1a3167;
    position: absolute;
    left: 0;
    bottom: -6px;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top
}
.text-link a:hover::after{
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    width: 100%;
}

/* button-link */
.button-link a{
    display: inline-block;
    font-weight: bold;
    padding: 0 30px;
    line-height: 60px;
    color: #ffffff;
    background-color: #47d5c0;
    background-image: url(../images/gradation_01.png);
    background-position: left center;
    background-repeat: repeat-x;
    background-size: auto 100%;
    border-radius: 30px;
    border-bottom: 1px solid #43cab5;
	-webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.button-link a:hover{
	background: url(../images/gradation_01_on.png) left center repeat-x;
    background-size: auto 100%;
    border-bottom: 1px solid #43ccb3;
}

/* hover-box */
.hover-box{
    display: block;
    position: relative;
}
.hover-box:hover > .upper::before, .hover-box:hover > .upper::after,
.hover-box:hover > .under::before,
.hover-box:hover > .under::after {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}
.hover-box:hover > .upper::before{
    -webkit-transform-origin: left top;
    transform-origin: left top;
}
.hover-box:hover > .upper::after{
    -webkit-transform-origin: right top;
    transform-origin: right top;
}
.hover-box:hover > .under::before{
    -webkit-transform-origin: right top;
    transform-origin: right top;
}
.hover-box:hover > .under::after{
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
}
.hover-box > .upper::before, .hover-box > .upper::after,
.hover-box > .under::before,
.hover-box > .under::after{
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-duration: 0.6s;
    transition-duration: 0.6s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-delay: 0;
    transition-delay: 0;
    background-color: #1a3068;
}
.hover-box > .upper::before{
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    position: absolute;
    top: -1px;
    right: auto;
    bottom: auto;
    left: 0;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top;
}
.hover-box > .upper::after{
  content: "";
  display: block;
  height: 100%;
  width: 1px;
  position: absolute;
  top: 0;
  right: -1px;
  bottom: auto;
  left: auto;
  -webkit-transform: scale(1, 0);
  transform: scale(1, 0);
  -webkit-transform-origin: right bottom;
  transform-origin: right bottom;
}
.hover-box > .under::before{
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    position: absolute;
    top: auto;
    right: auto;
    bottom: -1px;
    left: 0;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
}
.hover-box > .under::after{
    content: "";
    display: block;
    height: 100%;
    width: 1px;
    position: absolute;
    top: auto;
    right: auto;
    bottom: 0;
    left: -1px;
    -webkit-transform: scale(1, 0);
    transform: scale(1, 0);
    -webkit-transform-origin: right top;
    transform-origin: right top;
}

@media print, screen and (max-width: 760px){
    /* hover-box */
    .hover-box > .upper::before, .hover-box > .upper::after,
    .hover-box > .under::before,
    .hover-box > .under::after{
        display: none;
    }
}

/* title-area */
@media print, screen and (max-width: 1000px){
    .title-area{
        padding: 65px 0 0;
    }
}

/* page-nav */
.page-nav{
    background-color: #f6f6f6;
}
.page-nav-inner{
    width: 1160px;
    margin: 0 auto;
    display: table;
}
.page-nav-title{
    display: table-cell;
    vertical-align: middle;
    font-size: 35px;
    line-height: 35px;
    font-weight: bold;
    color: #1a3068;
    letter-spacing: 4px;
    white-space: nowrap;
    padding-right: 40px;
    padding: 30px 40px 30px 0;
}
.page-nav-list{
    display: table-cell;
    vertical-align: middle;
    letter-spacing: 0;
    text-align: right;
    padding: 15px 0;
    line-height: 1.9;
}
.page-nav-list li{
    display: inline-block;
    letter-spacing: 1px;
    font-weight: bold;
    background: url(../images/line_page_nav_01.png) left top repeat-y;
    font-size: 16px;
    line-height: 16px;
    padding-left: 30px;
    margin-left: 25px;
}
.page-nav-list li:first-child{
    background-image: none;
    padding-left: 0;
    margin-left: 0;
}
.page-nav-list li a{
    padding-right: 22px;
    background: url(../images/arrow_page_nav_01.png) right center no-repeat;
    position: relative;
}
.page-nav-list li a::after{
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-duration: .2s;
    transition-duration: .2s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-delay: 0;
    transition-delay: 0;
    background-color: #1a3167;
    position: absolute;
    left: 0;
    bottom: -6px;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top
}
.page-nav-list li a:hover::after{
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    width: 100%;
}
.page-nav-link{
    display: table-cell;
    vertical-align: middle;
    letter-spacing: 0;
    text-align: right;
    padding: 15px 0;
    line-height: 1.9;
}
.page-nav-link li{
    display: inline-block;
    letter-spacing: 1px;
    font-weight: bold;
    background: url(../images/line_page_nav_01.png) left top repeat-y;
    font-size: 16px;
    line-height: 16px;
    padding-left: 35px;
    margin-left: 35px;
    color: #1a3167;
    margin-top: 12px;
    margin-bottom: 12px;
}
.page-nav-link li:first-child{
    background-image: none;
    padding-left: 0;
    margin-left: 0;
}
.page-nav-link li a,
.page-nav-link li span{
    position: relative;
}
.page-nav-link li a:hover::after,
.page-nav-link li span::after{
    content: "";
    width: 11px;
    height: 4px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -14px;
    margin: auto;
    background: url(../images/arrow_page_nav_02.png) center top no-repeat;
}

@media print, screen and (max-width: 1240px){
    /* page-nav */
    .page-nav{
        padding: 0 30px;
    }
    .page-nav-inner{
        width: 100%;
    }
}

@media print, screen and (max-width: 1000px){
    /* page-nav */
    .page-nav{
        padding: 0 20px;
    }
    .page-nav-title{
        font-size: 24px;
        letter-spacing: 2px;
        padding: 20px 30px 20px 0;
    }
    .page-nav-list{
        padding: 10px 0;
    }
    .page-nav-list li{
        font-size: 14px;
        line-height: 14px;
        padding-left: 20px;
        margin-left: 20px;
        letter-spacing: 0;
    }
    .page-nav-list li a{
        padding-right: 20px;
    }
    .page-nav-link li a:hover::after,
    .page-nav-link li span::after{
        bottom: -13px;
    }
}

@media print, screen and (max-width: 760px){
    /* page-nav */
    .page-nav{
        display: none;
    }
}

/* img-main */
.img-main{
    width: 100%;
    background: url(../images/img_main.jpg) center center no-repeat;
    background-size: cover;
    text-align: center;
    height: 460px;
    display: table;
}
.img-main-inner{
    display: table-cell;
    vertical-align: middle;
}
.img-main-title{
    font-size: 100px;
    color: #ffffff;
    line-height: 100px;
    letter-spacing: 2px;
    margin-bottom: 20px;
}
.img-main-sp-inner div{
    display: none;
}
.img-main-text{
    font-size: 18px;
    color: #ffffff;
    font-weight: bold;
    letter-spacing: 1px;
    line-height: 1.8;
}

@media print, screen and (max-width: 760px){
    /* img-main */
    .img-main{
        background-image: none;
        height: auto;
    }
    .img-main-inner{
        display: block;
    }
    .img-main-sp{
        width: 100%;
        height: 170px;
        background: url(../images/img_main_sp.jpg) center center no-repeat;
        background-size: cover;
        display: table;
    }
    .img-main-title{
        font-size: 38px;
        line-height: 38px;
        margin-bottom: 10px;
    }
    .img-main-sp-inner{
        display: table-cell;
        vertical-align: middle;
        width: 100%;
    }
    .img-main-sp-inner div{
        display: block;
        color: #ffffff;
        letter-spacing: 1px;
        font-weight: bold;
        font-size: 1.65rem;
        line-height: 16px;
    }
    .img-main-text{
        background-color: #f6f6f6;
        color: #000000;
        text-align: left;
        font-weight: normal;
        font-size: 14px;
        line-height: 1.6;
        padding: 20px;
    }
    .img-main-text br{
        display: none;
    }
}

/* img-main-recruit */
.img-main-recruit{
    width: 100%;
    background: url(../images/img_main.jpg) center center no-repeat;
    background-size: cover;
    text-align: center;
    height: 270px;
    display: table;
}
.img-main-recruit-inner{
    display: table-cell;
    vertical-align: middle;
}
.img-main-recruit-title{
    font-size: 80px;
    color: #ffffff;
    line-height: 100px;
    letter-spacing: 2px;
}
.img-main-recruit-sp-inner div{
    display: none;
}

@media print, screen and (max-width: 760px){
    /* img-main */
    .img-main-recruit{
        background-image: none;
        height: auto;
    }
    .img-main-recruit-inner{
        display: block;
    }
    .img-main-recruit-sp{
        width: 100%;
        height: 170px;
        background: url(../images/img_main_sp.jpg) center center no-repeat;
        background-size: cover;
        display: table;
    }
    .img-main-recruit-title{
        font-size: 38px;
        line-height: 38px;
        margin-bottom: 10px;
    }
    .img-main-recruit-sp-inner{
        display: table-cell;
        vertical-align: middle;
        width: 100%;
    }
    .img-main-recruit-sp-inner div{
        display: block;
        color: #ffffff;
        letter-spacing: 1px;
        font-weight: bold;
        font-size: 1.65rem;
        line-height: 16px;
    }
}

/* page-nav-sp */
.page-nav-sp{
    display: none;
}

@media print, screen and (max-width: 760px){
    /* page-nav-sp */
    .page-nav-sp{
        display: block;
        width: 100%;
        border-bottom: 1px solid #dfe2ed;
        padding: 12px 2px;
    }
    .page-nav-sp ul{
        text-align: center;
        letter-spacing: -.4em;
        line-height: 1.4;
    }
    .page-nav-sp ul li{
        display: inline-block;
        letter-spacing: 0;
        font-size: 1.15rem;
        font-weight: bold;
        margin: 0 8px;
    }
    .page-nav-sp ul li a{
        display: inline-block;
        padding-left: 23px;
        background: url(../images/arrow_page_nav_01_sp.png) left 1px no-repeat;
        background-size: 12px 13px;
    }
}

/* page-nav-link-sp */
.page-nav-link-sp{
    display: none;
}

@media print, screen and (max-width: 760px){
    /* page-nav-link-sp */
    .page-nav-link-sp{
        display: block;
        width: 100%;
        border-bottom: 1px solid #dfe2ed;
        padding: 12px 2px;
    }
    .page-nav-link-sp ul{
        text-align: center;
        letter-spacing: -.4em;
        line-height: 1.4;
    }
    .page-nav-link-sp ul li{
        display: inline-block;
        letter-spacing: 0;
        font-size: 1.15rem;
        font-weight: bold;
        padding: 0 52px;
    }
    .page-nav-link-sp ul li:last-child{
        border-left: 1px solid #dfe2ed;
    }
    .page-nav-link-sp ul li span{
        position: relative;
        color: #1a3167;
    }
    .page-nav-link-sp ul li span::after{
        content: "";
        width: 9px;
        height: 4px;
        position: absolute;
        left: 0;
        right: 0;
        bottom: -8px;
        margin: auto;
        background: url(../images/arrow_page_nav_02_sp.png) center top no-repeat;
        background-size: 9px 4px
    }
}

/* page-nav-recruit */
.page-nav-recruit{
    display: none;
}

@media print, screen and (max-width: 760px){
    /* page-nav-recruit */
    .page-nav-recruit{
        display: block;
        width: 100%;
        border-bottom: 1px solid #dfe2ed;
        padding: 12px 2px;
    }
    .page-nav-recruit ul{
        text-align: center;
        letter-spacing: -.4em;
        line-height: 1.4;
    }
    .page-nav-recruit ul li{
        display: inline-block;
        letter-spacing: 0;
        font-size: 1.15rem;
        font-weight: bold;
        padding: 0 10px;
    }
    .page-nav-recruit ul li:not(:first-child){
        border-left: 1px solid #dfe2ed;
    }
    .page-nav-recruit li:first-child img{
        width: 14px;
        height: 14px;
    }
    .page-nav-recruit ul li:last-child{
        border-left: 1px solid #dfe2ed;
    }
    .page-nav-recruit ul li span{
        position: relative;
        color: #1a3167;
    }
    .page-nav-recruit ul li span::after{
        content: "";
        width: 9px;
        height: 4px;
        position: absolute;
        left: 0;
        right: 0;
        bottom: -8px;
        margin: auto;
        background: url(../images/arrow_page_nav_02_sp.png) center top no-repeat;
        background-size: 9px 4px
    }
}

/* base layout */
.base-contents{
    margin-bottom: 130px;
}
.base-title{
    text-align: center;
    padding: 100px 60px 0;
}
.base-title div{
    font-size: 15px;
    line-height: 15px;
    padding-top: 94px;
    margin-bottom: 100px;
    letter-spacing: 1px;
}
.base-title h2{
    font-size: 50px;
    line-height: 50px;
    font-weight: bold;
    color: #1a3167;
    letter-spacing: 6px;
    position: relative;
    padding-bottom: 86px;
}
.base-title h2::after{
    content: "";
    display: block;
    width: 1px;
    height: 30px;
    background-color: #1a3167;
    position: absolute;
    left: 50%;
    bottom: 30px;
}
.base-box{
    width: 960px;
    margin: 0 auto;
}
.base-img{
    text-align: center;
}
.base-img img{
    width: 100%;
}
.base-box h3{
    padding: 80px 0 60px;
    text-align: center;
    font-weight: bold;
    color: #1a3167;
    font-size: 33px;
    line-height: 1.4;
    letter-spacing: 4px;
}
.base-text{
    padding: 0 80px;
}
.base-text p{
    font-size: 19px;
    margin-bottom: 1.2em;
}
.base-text p:last-child{
    margin-bottom: 0;
}
.base-link{
    background-color: #f3f3f5;
    padding: 0 10px 50px;
}
.base-link-inner{
    width: 1180px;
    margin: 0 auto;
}
.base-link-title{
    color: #5d6a92;
    text-align: center;
    padding: 55px 0 45px;
    font-size: 17px;
    letter-spacing: 1px;
}
.base-link-title span{
    padding-left: 28px;
    background: url(../images/icon_base_01.png) left center no-repeat;
}
.base-link-list{
    display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
    width: 1180px;
    margin: 0 auto;
}
.base-link-box{
    background-color: #ffffff;
    width: 25%;
    margin-left: 10px;
    margin-right: 10px;
    text-align: center;
    position: relative;
    height: auto;
    font-size: 21px;
    font-weight: bold;
}
.base-link-box::before{
    content: "";
    display: block;
    padding-top: 100%;
}
.base-link-box-inner{
    position: absolute;
    top: 0; 
    left: 0;
    width: 100%;
    height: 100%;
    padding-top: 65%;
    color: #1a3068;
}
a.base-link-box-inner{
    border: 1px solid #dfe2ed;
    box-shadow:0px 1px 1px 0px #eaebed;
}
a.base-link-box-inner:hover{
    border: 1px solid #dfe2ed;
    box-shadow: none;
}
span.base-link-box-inner{
    border: 1px solid #1a3068;
}
.base-link-box:nth-child(1) .base-link-box-inner{
    background: url(../images/icon_strength.png) center 32% no-repeat;
}
.base-link-box:nth-child(2) .base-link-box-inner{
    background: url(../images/icon_merit.png) center 32% no-repeat;
}
.base-link-box:nth-child(3) .base-link-box-inner{
    background: url(../images/icon_vision.png) center 32% no-repeat;
}
.base-link-box:nth-child(4) .base-link-box-inner{
    background: url(../images/icon_job.png) center 32% no-repeat;
}
.base-link-box a span{
    padding-bottom: 2.75%;
    border-bottom: 1px solid #1a3068;
}
.base-link-box span span{
    background: url(../images/arrow_base_link_01.png) center bottom no-repeat;
    padding-bottom: 30px;
}

@media print, screen and (max-width: 1217px){
    /* base layout */
    .base-link-inner{
        width: 100%;
    }
    .base-link-list{
        width: 100%;
    }
    .base-link-box{
        font-size: 1.8vw;
    }
    .base-link-box:nth-child(1) .base-link-box-inner{
        background: url(../images/icon_strength.png) center 32% no-repeat;
        background-size: 36.4% auto;
    }
    .base-link-box:nth-child(2) .base-link-box-inner{
        background: url(../images/icon_merit.png) center 32% no-repeat;
        background-size: 25% auto;
    }
    .base-link-box:nth-child(3) .base-link-box-inner{
        background: url(../images/icon_vision.png) center 32% no-repeat;
        background-size: 26.2% auto;
    }
    .base-link-box:nth-child(4) .base-link-box-inner{
        background: url(../images/icon_job.png) center 32% no-repeat;
        background-size: 31% auto;
    }
    .base-link-box span span{
        background: url(../images/arrow_base_link_01.png) center bottom no-repeat;
        background-size: 11% auto;
        padding-bottom: 11%;
    }
}

@media print, screen and (max-width: 977px){
    /* base layout */
    .base-title h2{
        font-size: 5.1vw;
        line-height: 1;
    }
    .base-box{
        width: 100%;
    }
    .base-img img{
        width: 100%;
    }
    .base-text{
        padding: 0 60px;
    }
}

@media print, screen and (max-width: 760px){
    /* base layout */
    .base-contents{
        margin-bottom: 50px;
    }
    .base-title{
        padding: 50px 20px 0;
    }
    .base-title div{
        font-size: 13px;
        line-height: 13px;
        padding-top: 65px;
        margin-bottom: 45px;
    }
    .base-title h2{
        font-size: 26px;
        line-height: 1.2;
        letter-spacing: 1px;
        padding-bottom: 55px;
    }
    .base-title h2::after{
        height: 25px;
        bottom: 20px;
    }
    .base-box h3{
        padding: 40px 0 30px;
        font-size: 18px;
        line-height: 1.5;
        letter-spacing: 3px;
    }
    .base-text{
        padding: 0 25px;
    }
    .base-text p{
        font-size: 16px;
        margin-bottom: 1.2em;
        line-height: 1.6;
    }
    .base-link{
        padding: 0 10px 20px;
    }
    .base-link-title{
        padding: 26px 0 22px;
        font-size: 13px;
    }
    .base-link-title span{
        padding-left: 24px;
        background: url(../images/icon_base_01_sp.png) left center no-repeat;
        background-size: 12px 12px;
    }
    .base-link-list{
    	-webkit-flex-wrap: wrap;
    	-ms-flex-wrap: wrap;
    	flex-wrap: wrap;
        width: 335px;
        box-shadow:0px 1px 1px 0px #eaebed;
    }
    .base-link-box{
        width: 50%;
        margin-left: 0;
        margin-right: 0;
        font-size: 13px;
    }
    .base-link-box:nth-child(1) .base-link-box-inner{
        background: url(../images/icon_strength_sp.png) center 30% no-repeat;
        background-size: 40.7% auto;
    }
    .base-link-box:nth-child(2) .base-link-box-inner{
        background: url(../images/icon_merit_sp.png) center 30% no-repeat;
        background-size: 28.1% auto;
        border-left: none;
    }
    .base-link-box:nth-child(3) .base-link-box-inner{
        background: url(../images/icon_vision_sp.png) center 30% no-repeat;
        background-size: 29.3% auto;
        border-top: none;
    }
    .base-link-box:nth-child(4) .base-link-box-inner{
        background: url(../images/icon_job_sp.png) center 30% no-repeat;
        background-size: 34.7% auto;
        border-top: none;
        border-left: none;
    }
    a.base-link-box-inner{
        box-shadow: none;
    }
    .base-link-box span span{
        background: url(../images/arrow_base_link_01.png) center bottom no-repeat;
        background-size: 11% auto;
        padding-bottom: 11%;
    }
    .base-link-box a span{
        padding-bottom: 0;
        border-bottom: none;
    }
    .base-link-box span span{
        background: url(../images/arrow_base_link_01_sp.png) center bottom no-repeat;
        background-size: 11px 4px;
        padding-bottom: 16px;
    }
}

@media print, screen and (max-width: 420px){
    /* base layout */
    .base-title h2{
        font-size: 6vw;
    }
}

@media print, screen and (max-width: 375px){
    /* base layout */
    .base-link-list{
        width: 100%;
    }
    .base-link-box{
        font-size: 3.5vw;
    }
}

/* base-number */
.base-number{
    padding: 90px 80px;
}
.base-number-wrap:nth-child(odd) .base-number{
    background-color: #f5fbff;
}
.base-box .base-number-title{
    padding: 0;
    margin-bottom: 50px;
    text-align: left;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}
.base-number-main{
    width: 45px;
    margin-right: 24px;
}
.base-number-main span{
    background-color: #1a3167;
    border-radius: 50%;
    width: 45px;
    line-height: 43px;
    display: block;
    font-size: 18px;
    text-align: center;
    color: #ffffff;
    letter-spacing: 1px;
    padding: 2px 0 0 3px;
}
.base-number-headline,
.base-box h3.base-number-headline{
    padding: 0;
    text-align: left;
    font-weight: bold;
    color: #1a3167;
    font-size: 33px;
    line-height: 1.4;
    letter-spacing: 4px;
}
.base-number-text p{
    font-size: 19px;
    line-height: 2;
    margin-bottom: 1em;
}
.base-number-text p:last-child{
    margin-bottom: 0;
}
.base-number-section{
    font-weight: bold;
    color: #1a3167;
    font-size: 30px;
    line-height: 1.4;
    letter-spacing: 4px;
    margin-bottom: 30px;
}

@media print, screen and (max-width: 760px){
    /* base-number */
    .base-number-wrap{
        padding-top: 65px;
        margin-top: -65px;
    }
    .base-number{
        padding: 40px 25px;
    }
    .base-box .base-number-title{
        margin-bottom: 20px;
        letter-spacing: 2px;
    }
    .base-number-main{
        width: 34px;
        margin-right: 17px;
    }
    .base-number-main span{
        width: 34px;
        line-height: 34px;
        font-size: 14px;
        letter-spacing: 1px;
        padding: 0 0 0 1px;
        margin-top: -5px;
    }
    .base-number-headline,
    .base-box h3.base-number-headline{
        font-size: 18px;
        line-height: 1.5;
        letter-spacing: 3px;
    }    
    .base-number-text p{
        font-size: 16px;
        line-height: 1.7;
    }
    .base-number-section{
        font-size: 18px;
        line-height: 1.5;
        letter-spacing: 3px;
        margin-bottom: 16px;
    }
}

/* green-marker */
.green-marker{
    background: #13cbb8;
    color: #ffffff;
    display: inline-block;
    line-height: 22px;
    padding: 2px 6px 0;
}

@media print, screen and (max-width: 760px){
    /* green-marker */
    .green-marker{
        line-height: 18px;
        padding: 2px 4px 0;
    }
}

/* entry-entrance */
.entry-entrance{
    width: 100%;
}
.entry-entrance-title{
    padding: 100px 0 60px;
    text-align: center;
    position: relative;
}
.entry-entrance-title h2{
    text-align: center;
}
.entry-entrance-title h2 span{
    display: block;
}
.entry-entrance-title h2 span:first-child{
    font-family: 'romana_btbold';
    color: #1a3167;
    font-size: 70px;
    letter-spacing: 2px;
    line-height: 70px;
    margin-bottom: 20px;
}
.entry-entrance-title h2 span:last-child{
    font-size: 16px;
    line-height: 16px;
    color: #1a3167;
    margin-bottom: 25px;
}
.entry-entrance-title::after{
    content: "";
    display: block;
    width: 1px;
    height: 30px;
    background-color: #1a3167;
    position: absolute;
    left: 50%;
    bottom: 30px;
}
.entry-entrance-main{
    background-color: #1a3068;
    padding: 100px 0;
}
.entry-entrance-inner{
    width: 1060px;
    margin: 0 auto;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    box-pack: justify;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.entry-entrance-graduate,
.entry-entrance-career{
    width: 480px;
}
.entry-entrance-recruit .entry-entrance-graduate,
.entry-entrance-recruit .entry-entrance-career{
    margin: 0 auto;
}
.entry-entrance-main h3{
    color: #ffffff;
    text-align: center;
    font-size: 30px;
    font-weight: bold;
    line-height: 30px;
    letter-spacing: 4px;
    margin-bottom: 35px;
}
.entry-entrance-main p{
    font-size: 17px;
    text-align: center;
    color: #ffffff;
    letter-spacing: 2px;
    margin-bottom: 35px;
}
.entry-entrance-button{
    margin-bottom: 30px;
}
.entry-entrance-button a{
    background: #ffffff url(../images/arrow_entry_01.png) right 25px center no-repeat;
    display: block;
    color: #1a3167;
    font-weight: bold;
    font-size: 20px;
    text-align: center;
    letter-spacing: 1px;
    line-height: 70px;
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.entry-entrance-button a:hover{
    background: #061230 url(../images/arrow_entry_01_on.png) right 25px center no-repeat;
    color: #ffffff;
}
.entry-entrance-main ul{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    box-pack: justify;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.entry-entrance-main li{
    border-right: 1px solid #3f4e7f;
    line-height: 16px;
    width: 33.33%;
}
.entry-entrance-main li:nth-child(2){
    text-align: center;
}
.entry-entrance-main li:last-child{
    border-right: none;
    text-align: right;
}
.entry-entrance-main li a{
    color: #ffffff;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 1px;
    padding-right: 22px;
    background: url(../images/arrow_entry_02.png) right center no-repeat;
    position: relative;
}
.entry-entrance-main li a::after{
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-duration: .2s;
    transition-duration: .2s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-delay: 0;
    transition-delay: 0;
    background: #626d95;
    position: absolute;
    left: 0;
    bottom: -8px;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top
}
.entry-entrance-main li a:hover::after{
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    width: 100%
}

@media print, screen and (max-width: 1180px){
    /* entry-entrance */
    .entry-entrance-inner{
        width: 100%;
        padding: 0 60px;
    }
    .entry-entrance-graduate,
    .entry-entrance-career{
        width: 45.28%;
    }
    .entry-entrance-main p{
        font-size: 17px;
        letter-spacing: 1px;
    }
    .entry-entrance-button a{
        font-size: 19px;
    }
    .entry-entrance-main li{
        line-height: 15px;
    }
    .entry-entrance-main li a{
        font-size: 15px;
    }
}

@media print, screen and (max-width: 1000px){
    /* entry-entrance */
    .entry-entrance-inner{
        padding: 0 40px;
    }
    .entry-entrance-graduate,
    .entry-entrance-career{
        width: 47.5%;
    }
    .entry-entrance-main p{
        font-size: 16px;
    }
}

@media print, screen and (max-width: 900px){
    /* entry-entrance */
    .entry-entrance-inner{
        display: block;
    }
    .entry-entrance-graduate,
    .entry-entrance-career{
        width: 100%;
    }
    .entry-entrance-graduate{
        padding-bottom: 80px;
        border-bottom: 1px solid #3f4e7f;
        margin-bottom: 80px;
    }
    .entry-entrance-recruit .entry-entrance-graduate{
        padding-bottom: 0;
        margin-bottom: 0;
        border-bottom: none;
    }
    .entry-entrance-main li,
    .entry-entrance-main li:last-child{
        text-align: center;
    }
}

@media print, screen and (max-width: 760px){
    /* entry-entrance */
    .entry-entrance-title{
        padding: 50px 0 40px;        
    }
    .entry-entrance-title h2 span:first-child{
        font-size: 50px;
        letter-spacing: 1px;
        line-height: 50px;
        margin-bottom: 12px;
    }
    .entry-entrance-title h2 span:last-child{
        font-size: 13px;
        line-height: 13px;
        margin-bottom: 15px;
    }
    .entry-entrance-title::after{
        height: 25px;
        bottom: 15px;
    }
    .entry-entrance-main{
        padding: 40px 0;
    }
    .entry-entrance-inner{
        padding: 0 20px;
    }
    .entry-entrance-graduate{
        padding-bottom: 40px;
        margin-bottom: 40px;
    }
    .entry-entrance-main h3{
        font-size: 23px;
        line-height: 23px;
        letter-spacing: 3px;
        margin-bottom: 25px;
    }
    .entry-entrance-main p{
        font-size: 13px;
        letter-spacing: 1px;
        margin-bottom: 20px;
    }
    .entry-entrance-button{
        margin-bottom: 20px;
    }
    .entry-entrance-button a,
    .entry-entrance-button a:hover{
        background: #ffffff url(../images/arrow_entry_01_sp.png) right 15px center no-repeat;
        background-size: 17px 14px;
        font-size: 15px;
        letter-spacing: 1px;
        line-height: 55px;
        color: #1a3167;
    }
    .entry-entrance-main li{
        line-height: 13px;
    }
    .entry-entrance-main li a{
        font-size: 13px;
        padding-right: 20px;
        background: url(../images/arrow_entry_02_sp.png) right center no-repeat;
        background-size: 11px 9px;
    }
    .entry-entrance-main li a::after{
        display: none;
    }
}

@media print, screen and (max-width: 450px){
    /* entry-entrance */
    .entry-entrance-main li{
        text-align: left;
        line-height: 12px;
    }
    .entry-entrance-main li:last-child{
        text-align: right;
    }
    .entry-entrance-main li a{
        font-size: 12px;
    }
}

@media print, screen and (max-width: 370px){
    /* entry-entranc */
    .entry-entrance-main p{
        text-align: left;
    }
    .entry-entrance-main li a{
        font-size: 3.2vw;
        letter-spacing: 0;
    }
}

/*========================================
footer layout
========================================*/
.footer{
    width: 100%;
    background-color: #f3f3f5;
    padding: 60px;
}

@media print, screen and (max-width: 1000px){
    .footer{
        padding: 60px 40px;
    }
}

@media print, screen and (max-width: 760px){
    .footer{
        padding: 30px 20px;
    }
}

/* footer-nav */
.footer-nav-main{
    letter-spacing: -.4em;
    text-align: center;
    margin-bottom: 40px;
    line-height: 17px;
}
.footer-nav-main li{
    display: inline-block;
    letter-spacing: 1px;
    font-weight: bold;
    margin-right: 47px;
    padding-right: 48px;
    background: url(../images/line_footer_01.png) right top repeat-y;
    font-size: 1.65rem;
}
.footer-nav-main li:last-child{
    margin-right: 0;
    padding-right: 0;
    background-image: none;
}
.footer-nav-main a{
    position: relative;
    color: #1a3167;
}
.footer-nav-main a::after{
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-duration: .2s;
    transition-duration: .2s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-delay: 0;
    transition-delay: 0;
    background: #1a3167;
    position: absolute;
    left: 0;
    bottom: -8px;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top
}
.footer-nav-main a:hover::after{
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    width: 100%
}
.footer-nav-sub{
    letter-spacing: -.4em;
    text-align: center;
    line-height: 14px;
}
.footer-nav-sub li{
    display: inline-block;
    letter-spacing: 1px;
    margin-right: 30px;
    padding-right: 30px;
    font-size: 14px;
    border-right: 1px solid #d0d1d7;
}
.footer-nav-sub li:last-child{
    margin-right: 0;
    padding-right: 0;
    border-right: none;
}
.footer-nav-sub a{
    position: relative;
    color: #000000;
}
.footer-nav-sub a::after{
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    -webkit-transition-property: -webkit-transform;
    transition-property: -webkit-transform;
    transition-property: transform;
    transition-property: transform, -webkit-transform;
    -webkit-transition-duration: .2s;
    transition-duration: .2s;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
    -webkit-transition-delay: 0;
    transition-delay: 0;
    background: #d0d1d7;
    position: absolute;
    left: 0;
    bottom: -8px;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top
}
.footer-nav-sub a:hover::after{
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    width: 100%;
}

@media print, screen and (max-width: 1100px){
    /* footer-nav */
    .footer-nav-main ul{
        line-height: 15px;
    }
    .footer-nav-main li{
        margin-right: 3.8%;
        padding-right: 3.8%;
        font-size: 15px;
    }
    .footer-nav-sub ul{
        line-height: 13px;
    }
    .footer-nav-sub li{
        margin-right: 3%;
        padding-right: 3%;
        font-size: 13px;
    }
}

@media print, screen and (max-width: 900px){
    /* footer-nav */
    .footer-nav-main ul{
        line-height: 14px;
    }
    .footer-nav-main li{
        margin-right: 3%;
        padding-right: 3%;
        font-size: 14px;
        letter-spacing: 0;
    }
    .footer-nav-sub ul{
        line-height: 12px;
    }
    .footer-nav-sub li{
        margin-right: 2.5%;
        padding-right: 2.5%;
        font-size: 12px;
        letter-spacing: 0;
    }
}

@media print, screen and (max-width: 760px){
    /* footer-nav */
    .footer-nav-main{
        text-align: left;
        margin-bottom: 0;
        line-height: 1.2;
        border-top: 1px solid #dadbe4;
    }
    .footer-nav-main li{
        display: block;
        margin-right: 0;
        padding-right: 0;
        background-image: none;
        font-size: 1.35rem;
        border-bottom: 1px solid #dadbe4;
    }
    .footer-nav-main li a{
        padding: 21px 0 19px;
        display: block;
        background: url(../images/arrow_footer_01_sp.png) right center no-repeat;
        background-size: 17px 14px;
    }
    .footer-nav-main a::after{
        display: none;
    }
    .footer-nav-sub{
        text-align: left;
        line-height: 1.2;
        padding: 30px 0;
    }
    .footer-nav-sub li{
        display: block;
        margin-right: 0;
        padding-right: 0;
        font-size: 1.3rem;
        border-right: none;
        margin-bottom: 15px;
    }
    .footer-nav-sub li:nth-of-type(n+3){
        display: inline-block;
        margin: 0 35px 0 0;
    }
    .footer-nav-sub li:last-child{
        margin: 0;
    }
    .footer-nav-sub li:nth-of-type(n+3) a{
        color: #070d2a;
    }
    .footer-nav-sub a::after{
        display: none;
    }
}

/* footer-credit */
.footer-credit{
    padding-top: 60px;
    width: 100%;
}
.footer-logo{
    text-align: center;
    margin-bottom: 20px;
}
.footer-logo img{
    width: 130px;
}
.copyright{
    color: #1a3068;
    font-size: 1.2rem;
    text-align: center;
    line-height: 12px;
    letter-spacing: 0.04em;
}

@media print, screen and (max-width: 1000px){
    /* footer-credit */
    .copyright{
        font-size: 1.1rem;
        line-height: 11px;
    }
}

@media print, screen and (max-width: 760px){
    /* footer-credit */
    .footer-credit{
        border-top: 1px solid #dadbe4;
        display: table;
        padding-top: 30px;
    }
    .footer-logo{
        margin-bottom: 0;
        text-align: left;
        display: table-cell;
    }
    .footer-logo img{
        width: 83px;
    }
    .copyright{
        text-align: right;
        display: table-cell;
        vertical-align: middle;
    }
}

/*========================================
other layout
========================================*/
.lb-outerContainer{
    background-color: transparent!important;
    
}
.lb-container{
    padding: 0 20px;
    position: absolute!important;
}
.lb-image{
    width: 800px!important;
    height: auto!important;
    
}