@charset "utf-8";
/* Simple fluid media
   Note: Fluid media requires that you remove the media's height and width attributes from the HTML
   http://www.alistapart.com/articles/fluid-images/ 
*/
img, object, embed, video {
	max-width: 100%;
}

/* IE 6 does not support max-width so default to width 100% */
.ie6 img {
	width:100%;
}

.fluid {
	clear: both;
	margin-left: 0;
	width: 100%;
	float: left;
	display: block;
}

.fluidList {
    list-style:none;
    list-style-image:none;
    margin:0;
    padding:0;        
}

/* Mobile Layout: 480px and below. */


.en { font-family: 'Roboto', sans-serif; }

/*PC*/
@media print, screen and (min-width: 768px) {

.gridContainer {
width:100%;
min-width: 1340px;
/*padding:0;
clear: none;
float: none;
margin:0 auto;*/
}
#div1 {
}
.zeroMargin_mobile {
margin-left: 0;
}
.hide_mobile {
display: none;
}

.pcBr {
display: inline-block;
}

.spBr {
display: none;
}

.pc {
display: block;
}

.sp {
display: none;
}

body {
	min-width:1100px;
	font-size: 16px;
	line-height: 2.2;
	letter-spacing:3px;
}

/* com
--------------------------------------------*/
#hedImg {
width: 100%;
background-size: cover !important;
height: 450px;
margin: auto;
overflow: hidden;
position: relative;
z-index: -1;
}

.hed_tit {
position: absolute;
left: 15%;
color: #fff;
bottom: 15%;
z-index: 1000;
}

.hed_tit h2 {
text-align: left;
font-family:'Roboto', sans-serif;;
font-size: 40px;
line-height: 1.5;
letter-spacing: 0.12em;
margin-bottom: 20px;
}

.hed_tit h2 span.jp {
display: block;
line-height: 1.8em;
font-size: 16px;
}


.hed_tit p {
text-align: center;
/*font-family: 'Slabo 13px', serif;*/
font-family:'Roboto', sans-serif;;
font-size: 2rem;
letter-spacing: 0.1em;
color: #ae9373;
font-weight: normal;
position: relative;
padding-bottom: 50px;
}

.hed_tit p:after {
width: 1px;
height: 30px;
background: #ae9373;
content: "";
position: absolute;
bottom: 0;
left: 50%;
}

#contents {
width: 100%;
min-width: 1340px;
margin: 100px auto 100px;
overflow: hidden;
}

.contentsIn {
width: 1100px;
margin: 0 auto;
}

.fL {
float: left;
}

.fR {
float: right;
}

.w1100 {
width: 1100px;
min-width: 1100px;
margin-left: auto;
margin-right: auto;
}


.w1340 {
width: 1340px;
min-width: 1340px;
margin: 0 auto;
}

.comPd01 {
padding: 0 0 100px;
}

.comInBox01 {
margin-bottom: 100px;
}

.comInBox01:last-child {
margin-bottom: 0px;
}

.comPd_80 {
padding: 80px 0;
}

.comPd_top80 {
padding: 80px 0 0;
}

.pt100 {
padding-top: 100px;
}

.p_relative {
position: relative;
}


.bnr_contact_img {
	background:url(../images/com/bnr_contact_img.jpg) center center no-repeat;
	background-size:cover;
	padding:60px 0;
	box-sizing:border-box;
	display:block;
}

.bnr_contact_img a {
	color:#1e2a5f;
	text-decoration:none;
	text-align:center;
	display:block;
}

.bnr_contact_img a h5{
	font-size:18px;
	line-height:1;
	margin:0 0 20px;
	letter-spacing:2px;
}

.bnr_contact_img a h3 {
	font-size:26px;
	letter-spacing:2px;
	line-height:1;
	margin:0 0 15px;
}

.bnr_contact_img a h4 {
	font-size:36px;
	line-height:1;
	letter-spacing:2px;
	margin-bottom:10px;
}

.bnr_contact_img a h4 i {
	font-size:20px;
	margin-right:5px;
}

.bnr_contact_img a p {
	font-weight:bold;
}


/*--スクロールトップ---------*/
#totop {
bottom: 20px;
display: block;
position: fixed;
right: 30px;
z-index: 2000;
width: 54px;
}

#totop a {
display: block;
width: 54px;
height: 54px;
text-indent: -1000em;
overflow: hidden;
background: url(../images/com/btn_scroll_top.png) 0 0 no-repeat;
background-size: auto auto;
background-size: 100% auto;
}


/*-----タイトル-----*/
.com_title_c {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 24px;
    font-size: 2.4rem;
    color: #1f2c5c;
    line-height: 1.58333;
    letter-spacing: .14em;
    text-align: center;
    margin: 0 0 60px;
}

.com_title_l {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 24px;
    font-size: 2.4rem;
    color: #1f2c5c;
    line-height: 1.58333;
    letter-spacing: .14em;
    text-align: left;
    margin: 0 0 60px;
}

.com__titleLine {
    display: inline-block;
    border-bottom: 2px solid #202c5c;
}

.com_sub_title {
    text-align: center;
    margin-bottom: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.com_sub_title :nth-child(1) {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 24px;
    font-size: 2.4rem;
    color: 
    #1f2c5c;
    letter-spacing: 0.12em;
    margin-bottom: 20px;
}

.com_sub_title :nth-child(2) {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: 0.07em;
}


.com_sub_tit02 {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: bold;
    letter-spacing: .14em;
    color: #1f2c5c;
    margin: 0 0 30px;
}

.com_sub_tit03 {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: bold;
    color: #1f2c5c;
    line-height: 1.875;
    margin: 0 0 20px;
    padding: 0 0 0 25px;
    position: relative;
}

.com_sub_tit03::before {
    content: "";
    width: 16px;
    height: 2px;
    background: 
    #1f2c5c;
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.com_sub_tit04 {
    margin: 15px 0;
    font-size: 18px;
    color: #00295D;
	border-left: 5px solid #00295D;
    padding-left: 10px;
    line-height: 1.2;
}


/*-----ボタン-----*/
.btnOval {
font-family: 'Roboto', sans-serif;
font-weight: 700;
font-size: 15px;
font-size: 1.5rem;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
cursor: pointer;
letter-spacing: 0.1em;
background-color: #1f2c5c;
-webkit-box-sizing: border-box;
box-sizing: border-box;
border-radius: 32px;
border: 0;
color:#fff !important;
height: 64px;
width: 248px;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
position: relative;
text-decoration: none !important;
-webkit-transition: letter-spacing 0.3s cubic-bezier(0.215, 0.61, 0.355, 1),opacity 0.3s;
transition: letter-spacing 0.3s cubic-bezier(0.215, 0.61, 0.355, 1),opacity 0.3s;
margin:auto;
}

.btnOval_w {
font-family: 'Roboto', sans-serif;
font-weight: 700;
font-size: 15px;
font-size: 1.5rem;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
cursor: pointer;
letter-spacing: 0.1em;
background-color: #FFF;
-webkit-box-sizing: border-box;
box-sizing: border-box;
border-radius: 32px;
border: 0;
color:#1f2c5c !important;
height: 64px;
width: 248px;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
position: relative;
text-decoration: none !important;
-webkit-transition: letter-spacing 0.3s cubic-bezier(0.215, 0.61, 0.355, 1),opacity 0.3s;
transition: letter-spacing 0.3s cubic-bezier(0.215, 0.61, 0.355, 1),opacity 0.3s;
margin:auto;
}

.btnOval:hover,
.btnOval_w:hover {
	letter-spacing: 0.18em;
	opacity: 0.7
}

.btnOval:hover:before,
.btnOval_w:hover:before {
	-webkit-transform: scale(0.95);
	transform: scale(0.95)
}

/*-----テーブル-----*/
.com_table {
border-top: 1px solid #dfdfdf;
width: 100%;
margin:0 0 40px;
}
	
.com_table th {
width:20%;
border-bottom: 1px solid #dfdfdf;
/*border-left: 1px solid #f1f0ee;*/
padding: 30px;
display:table-cell;
vertical-align: middle
}

.com_table td {
border-bottom: 1px solid #dfdfdf;
/*border-left: 1px solid #f1f0ee;*/
padding: 30px;
display:table-cell;
vertical-align: middle;
}

.com_table2 {
width: 100%;
}

.com_table2 th {
color: #FFF;
line-height: 1.1;
padding: 1.0em;
background: #2a2a2a;
text-align: center;
border-bottom: #fff 1px solid;
}

.com_table2 td {
padding: 1.0em;
border-bottom: solid 1px #E4E4E4;
vertical-align: middle;
}



/*-----中ヘッド-----*/
.c-mv {
    height: 640px;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.c-mv__title {
    display: inline-block;
    position: relative;
	font-size:20px;
	font-weight:700;
	color:#FFFFFF;
	text-align:center;
}

.c-mv__title span {
	font-size:36px;
	font-family: 'Roboto', sans-serif;
	display:block;
	letter-spacing:0.14em;
}

.c-mv__title::after {
    background-color: #fff;
    content: '';
    display: block;
    height: 4px;
    width: 100%;
    margin-top: 17px;
}


/* header
--------------------------------------------*/
#header {
width: 100%;
height: 100px;
overflow: hidden;
position: fixed;
top: 0;
z-index: 100;
background-color: rgba(255,255,255,0.7);
-webkit-transition: all 700ms cubic-bezier(0.165, 0.84, 0.44, 1);
-moz-transition: all 700ms cubic-bezier(0.165, 0.84, 0.44, 1);
-o-transition: all 700ms cubic-bezier(0.165, 0.84, 0.44, 1);
transition: all 700ms cubic-bezier(0.165, 0.84, 0.44, 1);
-webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
-moz-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
-o-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1)
}

.logo_Hed {
-moz-transition: all 0.3s;
position: absolute;
top: 30px;
left: 30px;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
width:180px;
z-index:100;
}

.logo_Hed img {
width: 100%;
height: auto;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
}

.logo_Hed a {
display: block;
width: 100%;
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
}

.logo_Hed_smaller {
opacity: 0;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
margin: 15px 0 15px 15px;
}

.logo_Hed_smaller img {
width: 100%;
height: auto;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
}

.logo_Hed_smaller a {
display: block;
width: 160px;
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
}




header.smaller .logo_Hed,
header.smaller .logo_Hed a{
display: none;
}

header.smaller .logo_Hed_smaller {
opacity: 1!important;
width:160px;
}

header.smaller .logo_Hed {
margin: 15px 0 10px 20px;
}

header.smaller .logo_Hed img {
width: 100%;
height: auto;
}

header.smaller #menu { 
margin-top: 0px; 
}

.mainMenuInWrap {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
margin-left: 35px;
box-sizing: border-box;
}

.mainMenu {
width: 100%;
height: 100px;
display: flex;
display: -ms-flexbox;
justify-content: space-between;
-webkit-justify-content: space-between;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
}

.subMenu {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: end;
-ms-flex-pack: end;
justify-content: flex-end;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
margin-top: 15px;
color: #fff!important;
}

.subMenu li {
padding-right: 5px;
margin-right:10px;
}

.subMenu li:last-child {
margin-right: 0px;
}

.subMenu li a {
font-size: 1.2rem;
color: #1f2c5c;
font-weight:bold;
text-decoration:none;
}

#menu {
margin-top: 15px;
display: flex;
display: -ms-flexbox;
justify-content: flex-end;
-ms-flex-pack: end;
white-space:nowrap;
}

#menu li {
font-size: 1.5rem;
margin-right: 10px;
}

#menu li:last-child {
margin-right: 0px;
}

#menu li a {
color: #1f2c5c;
padding: 10px 5px;
/*display: block;*/
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
font-weight: bold;
letter-spacing: 0.08em;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
line-height: 1.2em;
font-size: 14px;
text-decoration:none;
}

header.smaller #menu li a {
color: #000;
text-decoration:none;
}


.mainMenuIn {
    position: absolute;
    top: 0;
	right: 160px;
}

.inqBox {
    width: 140px;
    position: absolute;
    top: 0;
    right: 0;
}

.inqBox ul {
display: table;
height: 100%;
margin-left: auto;
margin-right: 0;
}

.inqBox li {
display: table-cell;
}

.inqBox a {
font-size: 1.5rem;
display: block;
line-height: 80px;
width: 120px;
padding: 10px;
text-align: center;
text-decoration:none;
}

.inq1 a,
.inq2 a {
color: #fff;
font-weight: bold;
letter-spacing: 0.08em;
}

.inq1 a {
background-color: #1f2c5c;
}

.inq2 a {
background-color: #D0121B;
}

.inq1 a:hover,
.inq2 a:hover {
	opacity:0.7;
}

.sp_list {
display: none;
}

header.smaller #header {
height: 70px;
background: rgba(255,255,255,1);
}

header.smaller .subMenu {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: end;
-ms-flex-pack: end;
justify-content: flex-end;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
margin-top: 0;
color: #fff!important;
}

header.smaller .subMenu li {
	padding-right: 5px;
	margin-right:10px;
}

header.smaller .subMenu li:last-child{
	margin-right: 0px;
}

header.smaller .subMenu li a {
	font-size: 1.2rem;
color: #1f2c5c;
font-weight:bold;
}

header.smaller .mainMenu {
height: 70px;
}

header.smaller #menu li a {
padding: 0px 10px;
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
height: 35px;
text-decoration:none;
/*display: table-cell;
line-height: 50px;*/
}

header.smaller .inqBox a {
display: block;
line-height: 50px;
width: 120px;
padding: 10px;
text-align: center;
text-decoration:none;
}


/* footer
--------------------------------------------*/
#footer {
box-sizing: border-box;
width: 100%;
padding: 70px 0 40px;
background: #222;
}

.footerTopIn {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: justify;
-ms-flex-pack: justify;
justify-content: space-between;
padding-bottom: 50px;
margin:0 auto 30px;
border-bottom: #f4f4f4 1px solid;
}



.footerCp__img {
width:160px;
margin-bottom: 15px;
}

.footerCp__img img {
width: 100%;
height: auto;
}

.footerCp h3 {
display: none;
/*font-size: 1.4rem;
margin-bottom: 25px;*/
}

.footerCp p {
color: #fff;
font-size: 1.3rem;
line-height: 1.8;
letter-spacing: 0.05em;
}

.footerMu a {
color: #fff;
font-size: 1.3rem;
display: block;
text-decoration:none;
} 

.footerMuList {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
margin-bottom: 45px;
}

.footerMuList li {
margin-right:30px;
}

.footerMuList li:last-child {
margin-right: 0px;
}

.footerMuBtnWrap {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: end;
-ms-flex-pack: end;
justify-content: flex-end;
margin:auto;
}

.footerMuBtn02 {
margin-left: 50px;
}

.footerMuBtn01 a,
.footerMuBtn02 a {
padding: 8px 60px;
border: #ffffff 1px solid;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
}

.footerMuBtn01 a:hover {
background-color: #ff0048;
color:#FFFFFF;
}

.footerMuBtn02 a:hover {
background-color: #1f2c5c;
color:#FFFFFF;
}

.footerBottomIn {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: justify;
-ms-flex-pack: justify;
justify-content: space-between;
}

.footerBottomIn p,
.footerBottomIn p a {
font-size: 1.3rem;
color: #fff;
text-decoration:none;
}

.footerBottomIn p.copy {
font-size: 1.2rem;
color: #fff;
}



/* contents
--------------------------------------------*/
.comBtnWrap {
padding-top: 50px;
}

.comBtn01,
.comBtn02 {
width: 100%;
max-width: 250px;
margin:50px auto 0;
}

.comBtn01 a {
border: #fff 1px solid;
color: #fff;
background-color: #393939;
}

.comBtn02 a {
border: #393939 1px solid;
color: #393939 !important;
background-color: #fff;
}

.comBtn01 a,
.comBtn02 a {
font-size: 1.5rem;
font-weight: 500;
text-align: center;
display: block;
color: #fff;
padding: 10px;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
transition: 0.5s;
position: relative;
overflow: hidden;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
}

.comBtn02 a:hover {
color: #fff !important;
box-shadow:0px 0px 0px 0px #393939;
transform: translate(3px,3px);
background-color: #ad5011;
}

.btnR {
margin-left: auto;
margin-right: 0; 
}

.btnC {
margin-left: auto;
margin-right: auto;
}

.com_LedeBox{
position: relative;
border:1px solid #E5E5E5;
margin-bottom: 80px;
}
.com_LedeBox_In{
position: relative;
padding: 65px 70px;
}
.com_LedeBox::before,
.com_LedeBox::after,
.com_LedeBox_In::before,
.com_LedeBox_In::after{
position: absolute;
display:block;
content:"";
width: 101px;
height: 101px;
pointer-events: none;		
}
.com_LedeBox::before,
.com_LedeBox::after{
top:-1px;
}
.com_LedeBox_In::before,
.com_LedeBox_In::after{
bottom:-1px;	
}
.com_LedeBox::before,
.com_LedeBox_In::before{
left:-1px;	
}
.com_LedeBox::after,
.com_LedeBox_In::after{
right:-1px;
}
.com_LedeBox::before{ background: url(../images/com/waku01.png) no-repeat; }
.com_LedeBox::after{ background:url(../images/com/waku02.png) no-repeat; }
.com_LedeBox_In::before{ background:url(../images/com/waku03.png) no-repeat; }
.com_LedeBox_In::after{ background:url(../images/com/waku04.png) no-repeat; }

.com_LedeBox_In h4 {
font-size: 3rem;
font-weight: bold;
font-family: "游ゴシック",YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,Osaka,"MS Pゴシック","MS PGothic",sans-serif;
text-align: center;
margin-bottom: 40px;
color:#D0121B;
}

.com_Lede01 {
	font-weight:bold;
font-size: 1.7rem;
line-height: 2em;
letter-spacing:2px;
text-align:center;
}

.com_Lede01 span {
font-weight: bold;
background:rgba(0, 0, 0, 0) linear-gradient(transparent 80%, #ffff7f 0%) repeat scroll 0 0;
}



}




/*pcとsp共通*/
/*----------------------------*/
.gridContainer {
overflow: hidden;
}




.imgSlide {
width: 100%;
height: 100%;
overflow: hidden;
}
.imgSlide .imgSlideIn {
width: inherit;
height: inherit;
opacity: 0;
}
.isPlay {
animation-name: play;
animation-duration: .5s;
animation-fill-mode: forwards;
animation-timing-function: cubic-bezier(.8,0,.5,1);
position: relative;
opacity: 1 !important;
}
.isPlay:before {
animation-name: maskOut;
animation-duration: .5s;
animation-delay: .5s;
animation-fill-mode: forwards;
animation-timing-function: cubic-bezier(.8,0,.5,1);
content: '';
position: absolute;
top: 0;
left: 0;
z-index: 1;
width: 100%;
height: 100%;
background-color: #202020;
}
@keyframes play {
from {
transform: translateX(-100%);
}
to {
transform: translateX(0);
}
}
@keyframes maskOut {
from {
transform: translateX(0);
}
to {
transform: translateX(100%);
}
}
/*----------------------------------------------------------------------*/







/*sp*/
@media only screen and (max-width: 767px) {

.gridContainer {
width:100%;
padding:0;
clear: none;
float: none;
margin:0 auto;
}
#div1 {
}
.zeroMargin_desktop {
margin-left: 0;
}
.hide_desktop {
display: none;
}

.pcBr {
display: none;
}

.spBr {
display: inline-block;
}

.pc {
display: none;
}

.sp {
display: block;
}

.w80p {
width: 100%;
margin-left: auto;
margin-right: auto;
}

.lH2 {
line-height: 2em;
}

.w48_l {
width: 100%;
float: left;
}

.w48_r {
width: 100%;
float: right;
}

.w48_l img,.w48_r img {
width: 100%;
height: auto;
}

body {
	font-size:14px;
	line-height: 2;
}

#contents {
    width: 100%;
    margin: 30px auto 30px;
    overflow: hidden;
}


/* com
--------------------------------------------*/
.w1100 {
width: 96%;
margin-left: auto;
margin-right: auto;
}

.w1340 {
width: 96%;
margin-left: auto;
margin-right: auto;
}

.comPd01 {
padding: 0 0 40px;
}

.comInBox01 {
margin-bottom: 60px;
}

.comInBox01:last-child {
margin-bottom: 0px;
}

.comPd_80 {
padding: 40px 0;
}

.comPd_top80 {
padding: 40px 0 0;
}

.p_relative {
position: relative;
}






/*中ページのヘッド*/
.c-mv {
    height: 85.33333vw;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.c-mv__title {
    display: inline-block;
    position: relative;
	font-size:16px;
	font-weight:700;
	color:#FFFFFF;
	text-align:center;
}

.c-mv__title span {
	font-size:24px;
	font-family: 'Roboto', sans-serif;
	display:block;
	letter-spacing:0.16em;
}

.c-mv__title::after {
    background-color: #fff;
    content: '';
    display: block;
    height: .33333vw;
	margin-top: 2.8vw;
    width: 100%;
}


.bnr_contact_img {
	background:url(../images/com/bnr_contact_img.jpg) center center no-repeat;
	background-size:cover;
	padding:30px 0;
	box-sizing:border-box;
	display:block;
}

.bnr_contact_img a {
	color:#1e2a5f;
	text-decoration:none;
	text-align:center;
	display:block;
}

.bnr_contact_img a h5{
	font-size:14px;
	line-height:1;
	margin:0 0 20px;
	letter-spacing:2px;
}

.bnr_contact_img a h3 {
	font-size:20px;
	letter-spacing:2px;
	line-height:1;
	margin:0 0 15px;
}

.bnr_contact_img a h4 {
	font-size:26px;
	line-height:1;
	letter-spacing:2px;
	margin-bottom:10px;
}

.bnr_contact_img a h4 i {
	font-size:16px;
	margin-right:5px;
}

.bnr_contact_img a p {
	font-weight:bold;
}

/*--スクロールトップ---------*/
#totop {
bottom: 20px;
display: block;
position: fixed;
right: 30px;
z-index: 2000;
width: 54px;
}

#totop a {
display: block;
width: 54px;
height: 54px;
text-indent: -1000em;
overflow: hidden;
background: url(../images/com/btn_scroll_top.png) 0 0 no-repeat;
background-size: auto auto;
background-size: 100% auto;
}


/*-----タイトル-----*/
.com_title_c {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 18px;
    color: #1f2c5c;
    line-height: 1.58333;
    letter-spacing: .1em;
    text-align: center;
    margin: 0 0 60px;
}

.com_title_l {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 18px;
    font-size: 1.8rem;
    color: #1f2c5c;
    line-height: 1.58333;
    letter-spacing: .14em;
    text-align: left;
    margin: 0 0 30px;
}

.com__titleLine {
    display: inline-block;
    border-bottom: 2px solid #202c5c;
	padding-bottom:10px;
}

.com_sub_title {
    text-align: center;
    margin-bottom: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.com_sub_title :nth-child(1) {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 24px;
    font-size: 2.4rem;
    color: 
    #1f2c5c;
    letter-spacing: 0.12em;
    margin-bottom: 20px;
}

.com_sub_title :nth-child(2) {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: 0.07em;
}

.com_sub_tit02 {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    letter-spacing: .14em;
    color: #1f2c5c;
    margin: 0 0 20px;
}

.com_sub_tit03 {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    color: 
    #1f2c5c;
    line-height: 1.875;
    margin: 0 0 20px;
    padding: 0 0 0 25px;
    position: relative;
}

.com_sub_tit03::before {
    content: "";
    width: 14px;
    height: 2px;
    background: 
    #1f2c5c;
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.com_sub_tit04 {
    margin: 15px 0;
    font-size: 14px;
    color: #00295D;
	border-left: 5px solid #00295D;
    padding-left: 10px;
    line-height: 1.2;
}


/*-----ボタン-----*/
.btnOval {
font-family: 'Roboto', sans-serif;
font-weight: 700;
font-size: 15px;
font-size: 1.5rem;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
cursor: pointer;
letter-spacing: 0.1em;
background-color: #1f2c5c;
-webkit-box-sizing: border-box;
box-sizing: border-box;
border-radius: 32px;
border: 0;
color:#fff !important;
height: 50px;
width: 210px;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
position: relative;
text-decoration: none !important;
-webkit-transition: letter-spacing 0.3s cubic-bezier(0.215, 0.61, 0.355, 1),opacity 0.3s;
transition: letter-spacing 0.3s cubic-bezier(0.215, 0.61, 0.355, 1),opacity 0.3s;
margin:0 auto;
}

.btnOval_w {
font-family: 'Roboto', sans-serif;
font-weight: 700;
font-size: 15px;
font-size: 1.5rem;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
cursor: pointer;
letter-spacing: 0.1em;
background-color: #FFF;
-webkit-box-sizing: border-box;
box-sizing: border-box;
border-radius: 32px;
border: 0;
color:#1f2c5c !important;
height: 50px;
width: 210px;
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
position: relative;
text-decoration: none !important;
-webkit-transition: letter-spacing 0.3s cubic-bezier(0.215, 0.61, 0.355, 1),opacity 0.3s;
transition: letter-spacing 0.3s cubic-bezier(0.215, 0.61, 0.355, 1),opacity 0.3s;
margin:0 auto;
}

.btnOval:hover,
.btnOval_w:hover {
	letter-spacing: 0.18em;
	opacity: 0.7
}

.btnOval:hover:before,
.btnOval_w:hover:before {
	-webkit-transform: scale(0.95);
	transform: scale(0.95)
}




/*-----テーブル-----*/
.com_table {
border-top: 1px solid #dfdfdf;
width: 100%;
margin:0 0 40px;
}
	
.com_table th {
background:#F0F0F0;
width:96%;
background:none;
border-bottom:none;
padding: 4% 2%;
text-align: center;
display: block;
position: relative;
border-bottom: #dfdfdf dashed 1px;
}


.com_table td {
border-bottom: 1px solid #dfdfdf;
border-left: none;
padding: 4% 2%;
display: block;
}

.com_table2 {
width: 100%;
}

.com_table2 th {
display: block;
color: #FFF;
line-height: 1.1;
padding: 1.0em;
background: #2a2a2a;
text-align: center;
}

.com_table2 td {
display: block;
padding: 1.0em;
border-bottom: solid 1px #E4E4E4;
vertical-align: middle;
}



/*背景色*/
.comBg01 {
background-color: #f3f2e9;
}


/* header
--------------------------------------------*/
#header {
	background:#FFF;
width: 100%;
overflow: hidden;
position: fixed;
top: 0;
z-index: 100;
-webkit-transition: all 700ms cubic-bezier(0.165, 0.84, 0.44, 1);
-moz-transition: all 700ms cubic-bezier(0.165, 0.84, 0.44, 1);
-o-transition: all 700ms cubic-bezier(0.165, 0.84, 0.44, 1);
transition: all 700ms cubic-bezier(0.165, 0.84, 0.44, 1);
-webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
-moz-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
-o-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1)
}

.mainMenu {
box-sizing: border-box;
width: 100%;
align-items: center;
height: 60px;
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: justify;
-ms-flex-pack: justify;
justify-content: space-between;
}

.logo_Hed {
display: none;
}

.logo_Hed_smaller {
width: 160px;
margin-left: 5px;
}

.logo_Hed_smaller img {
width: 100%;
height: auto;
}

.logo_Hed_smaller a {
display: block;
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
}

.mainMenuInWrap,
.mainMenuIn {
display: none;
}

.inqBox {
display: none;
}

.sp_list {
display: block;
width: 40px;
height:60px;
float: right;
margin: 0px 5px 0 0;
padding: 0;
list-style-type: none;
}

.sp_list li {
width: 40px;
height: 40px;
float: left;
margin: 0;
padding: 0px;
text-align: center;
font-weight: bold;
}

.sp_list li a {
display: block;
color: #1f2c5c;
padding-top: 15px;

}

.sp_list li i {
font-size: 30px;
line-height: 30px;
}



/* footer
--------------------------------------------*/
#footer {
box-sizing: border-box;
width: 100%;
padding: 30px 0 20px;
background: #222;
}

.footerTopIn {
	width:96%;
	margin:0 auto 15px;
padding-bottom: 15px;
border-bottom: #ccc 1px solid;
}

.footerCp__img {
width: 120px;
margin: 0 auto 15px;
}

.footerCp__img img {
width: 100%;
height: auto;
}

.footerCp h3 {
display: none;
/*font-size: 1.4rem;
margin-bottom: 10px;
color: #fff;
text-align: center;*/
}

.footerCp p {
color: #fff;
font-size: 1.3rem;
line-height: 1.8;
letter-spacing: 0.05em;
text-align: center;
}

.footerMu {
display: none;
}

.footerMu a {
color: #fff;
font-size: 1.3rem;
display: block;
color: #fff;
} 

.footerMuList {
display:-webkit-box;
display:-ms-flexbox;
display:flex;
margin-bottom: 45px;
}

.footerMuList li {
margin-right: 60px;
}

.footerMuList li:last-child {
margin-right: 0px;
}

.footerMuBtnWrap {
	width:96%;
	margin:auto;
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-pack: end;
-ms-flex-pack: end;
justify-content: flex-end;
}

.footerMuBtn02 {
margin-left: 50px;
}

.footerMuBtn01 a,
.footerMuBtn02 a {
padding: 8px 60px;
border: #fff 1px solid;
background-color: #333333;
-moz-transition: all 0.3s;
-o-transition: all 0.3s;
-webkit-transition: all 0.3s;
transition: all 0.3s;
}

.footerMuBtn01 a:hover {
background-color: #ff0048;
}

.footerMuBtn02 a:hover {
background-color: #cd4a38;
}

.footerBottomIn {
width: 100%;
}

.footerBottomIn p:first-child {
display: none;
}

.footerBottomIn p,
.footerBottomIn p a {
font-size: 1.3rem;
}

.footerBottomIn p.copy {
font-size: 1.2rem;
text-align: center;
color: #fff;
}









/* contents
--------------------------------------------*/
.comBtnWrap {
padding-top: 30px;
}

.comBtn01,
.comBtn02 {
width: 100%;
max-width: 200px;
margin:0 auto;
}

.comBtn01 a {
border: #fff 1px solid;
color: #fff;
background-color: #393939;
}

.comBtn02 a {
border: #393939 1px solid;
color: #393939 !important;
background-color: #fff;
}

.comBtn01 a,
.comBtn02 a {
font-size: 1.5rem;
font-weight: 500;
text-align: center;
display: block;
color: #fff;
padding: 10px;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
transition: 0.5s;
position: relative;
overflow: hidden;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
}

.comBtn02 a:hover {
color: #fff !important;
box-shadow:0px 0px 0px 0px #393939;
transform: translate(3px,3px);
background-color: #ad5011;
}

.btnR {
margin-left: auto;
margin-right: 0; 
}

.btnC {
margin-left: auto;
margin-right: auto;
}

.com_LedeBox{
position: relative;
border:1px solid #E5E5E5;
margin-bottom: 80px;
}
.com_LedeBox_In{
position: relative;
padding: 30px 15px;
}
.com_LedeBox::before,
.com_LedeBox::after,
.com_LedeBox_In::before,
.com_LedeBox_In::after{
position: absolute;
display:block;
content:"";
width: 50px;
height: 50px;
}
.com_LedeBox::before,
.com_LedeBox::after{
top:-1px;
}
.com_LedeBox_In::before,
.com_LedeBox_In::after{
bottom:-1px;	
}
.com_LedeBox::before,
.com_LedeBox_In::before{
left:-1px;	
}
.com_LedeBox::after,
.com_LedeBox_In::after{
right:-1px;
}
.com_LedeBox::before{ background: url(../images/com/waku01.png) no-repeat;background-size:50px auto; }
.com_LedeBox::after{ background:url(../images/com/waku02.png) no-repeat;background-size:50px auto; }
.com_LedeBox_In::before{ background:url(../images/com/waku03.png) no-repeat;background-size:50px auto; }
.com_LedeBox_In::after{ background:url(../images/com/waku04.png) no-repeat;background-size:50px auto; }

.com_LedeBox_In h4 {
font-size: 2rem;
line-height: 1.8;
font-weight: bold;
font-family: "游ゴシック",YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,Osaka,"MS Pゴシック","MS PGothic",sans-serif;
text-align: center;
margin-bottom: 30px;
color:#D0121B;
}


.com_Lede01 {
font-size: 1.4rem;
line-height: 1.6em;
text-align:left;
}

.com_Lede01 span {
font-weight: bold;
background:rgba(0, 0, 0, 0) linear-gradient(transparent 80%, #ffff7f 0%) repeat scroll 0 0;
}

}