@charset "utf-8";

/*
============================================================
基本レイアウト設定
============================================================
*/
.sp{display: none;}
.tb{display: none;}
.pc{display: block;}
/* ---------------------------------------------------------
■ デフォルトリセット
--------------------------------------------------------- */
h1, h2, h3, h4, h5, h6, p, address,
ul, ol, li, dl, dt, dd,
table, th, td, img, form {
	margin: 0;
	padding: 0;
	font-weight: normal;
	font-style: normal;
	font-size: 100%;
	line-height: 1.6;
	border: none;
	list-style-type: none;
}

noscript p{
    text-align: center;
    width: 100%;
    position: fixed;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1000;
}
/* ---------------------------------------------------------
■ ローディング
--------------------------------------------------------- */
/*#index_wrap {
	display: none;
}*/

#loading {
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background:#b5c0f0;
	z-index: 500;
	color: #FFF;
	text-align: center;
}

#loading .load_wrap{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%)
}

/* ---------------------------------------------------------
■ floatクリア
--------------------------------------------------------- */
span.clear {
	height: 0;
	margin: 0;
	padding: 0;
	font-size: 1px;
	line-height: 1px;
	display: block;
	clear: both;
}

.clearfix:after{
	content: "";
	clear: both;
	display: block;
}

/* ---------------------------------------------------------
■ スクロール
--------------------------------------------------------- */
body {
	scrollbar-arrow-color:#82a2e4;
	scrollbar-face-color:#82a2e4;
	scrollbar-3dlight-color:#82a2e4;
	scrollbar-darkshadow-color:#82a2e4;
	scrollbar-highlight-color:#82a2e4;
	scrollbar-shadow-color:#82a2e4;
	scrollbar-track-color:#002b69;
}

/*スクロールバーの横幅指定*/
body::-webkit-scrollbar {
    width: 10px;
}
/*スクロールバーの背景色・角丸指定*/
body::-webkit-scrollbar-track {
	background: #002b69;
}
/*スクロールバーの色・角丸指定*/
body::-webkit-scrollbar-thumb {
	border-radius: 10px;
	background:#82a2e4;
}

/* ---------------------------------------------------------
■ リンク
--------------------------------------------------------- */
a:link    { color: inherit; text-decoration: underline; }
a:visited { color: inherit; text-decoration: underline; }
a:hover   { color: #82a2e4; text-decoration: underline; transition: 0.2s;}
a:active  { color: #82a2e4; text-decoration: underline;}

a img:hover   { opacity: 0.8; transition: 0.2s;}

/* ---------------------------------------------------------
■ レイアウトベース
--------------------------------------------------------- */
body {
	margin: 0;
	padding: 0;
	text-align: center; /* 中央レイアウト */
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	color: #333;
	font-size: 14px;
}

#content_base {
	width: 100%;
	height: 100%;
	margin: 0 auto; /* 中央レイアウト */
	text-align: center;
	position: relative;
	overflow: hidden;
    background: #fff;
    margin-bottom: 200px;/* 隠しフッター用 */
    z-index: 1;
}

.layout_box{
	margin: 0 auto; /* 中央レイアウト */
}

.layout_box:after{
	content: "";
	clear: both;
	display: block;
}

.layout_box .left{
	float: left;
}

.layout_box .right{
	float: right;
}

/* ---------------------------------------------------------
■ ヘッダー
--------------------------------------------------------- */
header {
	width: 100%;
	height: auto;
	margin: 0 auto;
	text-align: center;
	position: relative;
}

header:after {
    content: "";
	width: 100%;
	height: 80px;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 30;
    opacity: 0.4;
/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#00154b+0,00154b+100&1+0,0+100 */
background: -moz-linear-gradient(top, rgba(0,21,75,1) 0%, rgba(0,21,75,0) 90%); /* FF3.6-15 */
background: -webkit-linear-gradient(top, rgba(0,21,75,1) 0%,rgba(0,21,75,0) 90%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, rgba(0,21,75,1) 0%,rgba(0,21,75,0) 90%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00154b', endColorstr='#0000154b',GradientType=0 ); /* IE6-9 */
}

/*ヘッダーボックス*/
header #head_box{
	position: fixed;
	height: 60px;
    top: 0;
	width: 100%;
	z-index: 500;
}

header .head_hide{
	width: 100%;
	height: 100%;
	background: rgba(255,255,255,0.9);
	position: absolute;
	top: 0;
	left: 0;
    -webkit-box-shadow: 0px 7px 18px 0px rgba(50, 50, 50, 0.15);
    -moz-box-shadow:    0px 7px 18px 0px rgba(50, 50, 50, 0.15);
    box-shadow:         0px 7px 18px 0px rgba(50, 50, 50, 0.15);
}

/*ヘッダーロゴ*/
header #head_logo{
	position: fixed;
    top: 10px;
    left: 20px;
	z-index: 1000;
	width: 274px;
    height: 60px;
    text-indent:100%;
    white-space:nowrap;
    overflow:hidden;
}

header #head_logo:hover{
    opacity: 0.7;
    transition-duration: 0.2s;
}

header .logo_w{
    width: 100%;
    height: 100%;
    background: url(../images/logo_main.png) no-repeat;
    background-size: 100% auto;
    opacity: 1;
}

header .logo_b{
    width: 100%;
    height: 100%;
    background: url(../images/logo_main_black.png) no-repeat;
    background-size: 100% auto;
    opacity: 0;
}

header #head_logo a{
    display: block;
    height: 100%;
}

/*ヘッダーリンク*/
header #head_link{
    position: fixed;
    top :20px;
    right: 40px;
    z-index: 1000;
    color: #fff;
}
header #head_link ul li{
    float: left;
    margin-left: 30px;
    padding-bottom: 4px;
    font-weight: bold;
    font-family: 'Kosugi', sans-serif;
    position: relative;
}

header #head_link ul li:before{
    content: "";
    position: absolute;
    width: 0;
    height: 3px;
    background: #c9d5ed;
    bottom: -3px;
    left: 0;
}

header #head_link ul li:hover:before{
    width: 100%;
    transition-duration: 0.2s;
}

/* ---------------------------------------------------------
■ 汎用パーツ
--------------------------------------------------------- */
.small {font-size: 70%;}
.small_80 {font-size: 80%;}
.small_90 {font-size: 90%;}

.big {font-size: 110%;}
.big_120 {font-size: 120%;}
.big_130 {font-size: 130%;}
.big_200 {font-size: 200%;}

.tx_center{text-align: center;}
.tx_right{text-align: right;}
.tx_left{text-align: left;}

.tx_red{color: #D80003;}
.bold{font-weight: bold;}

.under_yellow {background:linear-gradient(transparent 40%,#ffcc00 0%); display: inline; padding: 0 2px 8px;}

.bg_yellow {background: yellow;}
.bg_blue {background: #cdeef2;}

.mgt_10{margin-top: 10px;}
.mgt_20{margin-top: 20px;}
.mgt_30{margin-top: 30px;}

.mgr_10{margin-right: 10px;}
.mgr_20{margin-right: 20px;}
.mgr_30{margin-right: 30px;}

.mgb_10{margin-bottom: 10px;}
.mgb_20{margin-bottom: 20px;}
.mgb_30{margin-bottom: 30px;}

.mgl_10{margin-left: 10px;}
.mgl_20{margin-left: 20px;}
.mgl_30{margin-left: 30px;}

.pdt_10{padding-top: 10px;}
.pdt_20{padding-top: 20px;}
.pdt_30{padding-top: 30px;}

.pdb_10{padding-bottom: 10px;}
.pdb_20{padding-bottom: 20px;}
.pdb_30{padding-bottom: 30px;}

.right{float: right;}
.left{float: left;}

.pdf{
	background: url(../images/ic_pdf.png) no-repeat 0 6px;
	background-size: 16px auto;
	font-size: 12px;
	font-weight: bold;
	line-height: 21px;
	padding: 7px 0 0 20px;
	height: 26px;
	display: block;
}

.tel{
    background: url(../images/ic_tel.png) no-repeat;
    background-size: 28px 48px;
    font-size: 30px;
    padding-left: 40px;
    height: 48px;
    display: inline-block;
    margin: 5px 0;
}

.tel a{
    text-decoration: none;
}

p {
	text-align: justify;
	text-justify: inter-ideograph;
}

.get_reader{
    padding: 10px;
    border: 1px solid #ccc;
    box-sizing: border-box;
}

.get_reader img{
    margin: 0 10px 2px 0;
}


/* ---------------------------------------------------------
■ リスト
--------------------------------------------------------- */
/*テキストリンク*/
ul.tx_link li{
    float: left;
    font-size: 14px;
    background: url(../images/ic_arrow_mini.png) no-repeat 0 3px;
    background-size: 8px 12px;
    margin-right: 20px;
    padding-left: 15px;
    transition-duration: 0.3s;
    text-decoration: underline;
    cursor: pointer;
}

ul.tx_link li:hover{
    background-position: 3px 3px;
}

/*リストリンク*/
dl.link_list{
    text-align: left;
}

dl.link_list dd{
    background: url(../images/ic_arrow_mini.png) no-repeat 0 2px;
    font-size: 12px;
    padding-left: 15px;
    background-size: 8px 12px;
    margin-bottom: 5px;
}

.foot_navi dl.link_list dd{
    background: url(../images/ic_arrow_mini02.png) no-repeat 0 2px;
    background-size: 8px 12px;
}

dl.link_list dt{
    font-size: 14px;
    font-weight: bold;
    padding-left: 0;
    margin-bottom: 10px;
}

dl.link_list dt.list_sub{
    background: none;
    font-size: 12px;
    padding: 14px 0 0 0;
}


/* ---------------------------------------------------------
■ ボタン
--------------------------------------------------------- */
/*青いボタン*/
.btn_main{
    width: 100%;
    height: 68px;
    border-radius: 34px;
    font-family: 'Kosugi', sans-serif;
    position: relative;
    overflow:hidden;
/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#2c3fce+0,2c3fce+50,000099+51,000099+100 */
background: rgb(44,63,206); /* Old browsers */
background: -moz-linear-gradient(-45deg, rgba(44,63,206,1) 0%, rgba(44,63,206,1) 50%, rgba(0,0,153,1) 50.1%, rgba(0,0,153,1) 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(-45deg, rgba(44,63,206,1) 0%,rgba(44,63,206,1) 50%,rgba(0,0,153,1) 50.1%,rgba(0,0,153,1) 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(135deg, rgba(44,63,206,1) 0%,rgba(44,63,206,1) 50%,rgba(0,0,153,1) 50.1%,rgba(0,0,153,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#2c3fce', endColorstr='#000099',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
    background-size: 210% auto;
    background-position: 100% 0;
    transition-duration: 0.2s;
}

@media screen\0{
    .btn_main {
    background-size: 260% auto;
    transition-duration: 0.5s;
}
}     

@supports (-ms-ime-align: auto) {
  .btn_main {
    background-size: 260% auto;
    transition-duration: 0.5s;
}
}

.btn_main:hover {
    background-position: 0 0;
}

.btn_main p{
    width: 100%;
    display: inline-block;
    text-align: center;
    font-size: 22px;
    color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}

.btn_main:after{
    content: "";
    position: absolute;
    width: 26px;
    height: 20px; 
    background: url(../images/ic_arrow_02.png) no-repeat;
    background-size: 100% auto;
    top: 50%;
    right: 7.6%;
    transform: translateY(-50%);
    transition-duration: 0.3s;
}

.btn_main:hover:after{
    right: 6.8%;
    transition-duration: 0.3s;
    background: url(../images/ic_arrow_02_wh.png) no-repeat;
    background-size: 100% auto;
}

.btn_main a{
    width: 100%;
    height: 100%;
    display: block;
    cursor: pointer;
}

/*白いボタン*/
.btn_sub{
    width: 100%;
    height: 60px;
    font-family: 'Kosugi', sans-serif;
    position: relative;
/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#2c3fce+0,2c3fce+50,ffffff+51,ffffff+100 */
background: rgb(44,63,206); /* Old browsers */
background: -moz-linear-gradient(-45deg, rgba(201,213,237,1) 0%, rgba(201,213,237,1) 50%, rgba(255,255,255,1) 50.1%, rgba(255,255,255,1) 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(-45deg, rgba(201,213,237,1) 0%,rgba(201,213,237,1) 50%,rgba(255,255,255,1) 50.1%,rgba(255,255,255,1) 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(135deg, rgba(201,213,237,1) 0%,rgba(201,213,237,1) 50%,rgba(255,255,255,1) 50.1%,rgba(255,255,255,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c9d5ed', endColorstr='#ffffff',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
    background-size: 240% auto;
    background-position: 100% 0;
    transition-duration: 0.3s;
}

@media screen\0{
.btn_sub {
    background-size: 350% auto;
    transition-duration: 0.5s;
}
}

@supports (-ms-ime-align: auto) {
.btn_sub {
    background-size: 350% auto;
    transition-duration: 0.5s;
}
}

.btn_sub:hover {
    background-position: 0 0;
}

.btn_sub p{
    display: inline-block;
    text-align: center;
    font-size: 18px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);  
}

.btn_sub:after{
    content: "";
    position: absolute;
    width: 12px;
    height: 20px; 
    background: url(../images/ic_arrow_01.png) no-repeat;
    background-size: 100% auto;
    top: 50%;
    right: 7.6%;
    transform: translateY(-50%);
    transition-duration: 0.3s;
}

.btn_sub:hover:after{
    right: 6.8%;
    background: url(../images/ic_arrow_01_wh.png) no-repeat;
    background-size: 100% auto;
}

.btn_sub a{
    width: 100%;
    height: 100%;
    display: block;
    color: #333;
}

/* ---------------------------------------------------------
■ サイドボタン
--------------------------------------------------------- */
.side_btn {
    width: 60px;
    position: fixed;
    right: 0;
    font-size: 12px;
	z-index: 100;
    border-radius: 5px 0 0 5px;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#000099+0,000099+50,2c3fce+51,2c3fce+76,2c3fce+100 */
    background: rgb(0,0,153); /* Old browsers */
    background: -moz-linear-gradient(top, rgba(0,0,153,1) 0%, rgba(0,0,153,1) 50%, rgba(44,63,206,1) 50.1%, rgba(44,63,206,1) 76%, rgba(44,63,206,1) 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(top, rgba(0,0,153,1) 0%,rgba(0,0,153,1) 50%,rgba(44,63,206,1) 50.1%,rgba(44,63,206,1) 76%,rgba(44,63,206,1) 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to bottom, rgba(0,0,153,1) 0%,rgba(0,0,153,1) 50%,rgba(44,63,206,1) 50.1%,rgba(44,63,206,1) 76%,rgba(44,63,206,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000099', endColorstr='#2c3fce',GradientType=0 ); /* IE6-9 */
    background-size: 100% 200%;
    background-position: 0 -100%;
    transition-duration: 0.2s;    
}

.side_btn:hover {
	background-position: 0 0;
}

.side_btn a {
    width: 100%;
    height: 100%;
    display: block;
    text-decoration: none;
    color: #fff;
    text-align: center;
}

/*トップへ戻る*/
#page_top {
    bottom: 100px; 
}

#page_top:after {
    content: "";
    position: absolute;
    width: 20px;
    height: 26px;
    background: url(../images/ic_arrow_gotop.png) no-repeat;
    background-size: 100% auto;
    top :20px;
    left: 50%;
    transform: translateX(-50%);
    transition-duration: 0.2s;
    pointer-events: none;
}

#page_top:hover:after {
	top :17px;
}

#page_top a {
    padding: 60px 0 20px;
}

/* ■ フェイスブックボタン */
#facebook {
    bottom: 115px;
    height: 80px;  
}

#facebook:after {
    content: "";
    position: absolute;
    width: 40px;
    height: 63px;
    background: url(../images/logo_facebook.png) no-repeat;
    background-size: 100% auto;
    top :50%;
    left: 52%;
    transform: translate(-50%,-50%);
    transition-duration: 0.2s;
    pointer-events: none;
}

#facebook a {
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
}

/* ---------------------------------------------------------
■ フェードイン
--------------------------------------------------------- */
.fadein {
  visibility: hidden; }

.fadein_delay {
	-webkit-animation-delay: 0.8s;
	-ms-animation-delay: 0.8s;
	animation-delay: 0.8s;
}

.fadeInDown {
  visibility: visible !important;
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 0.5s;
  -ms-animation-duration: 0.5s;
  animation-duration: 0.5s;
  -webkit-animation-name: fadeInDown;
  animation-name: fadeInDown; }

@-webkit-keyframes fadeInDown {
  0% {
    opacity: 0;
    -webkit-transform: translateY(30px); }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0); } }
@keyframes fadeInDown {
  0% {
    opacity: 0;
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px); }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0); } }

/* ---------------------------------------------------------
■ ライトボックス
--------------------------------------------------------- */
.featherlight{ padding: 2%}

.lightbox { 
	display: none;
	max-width: none;
	width: 100%;
	height: 100%;
	overflow: auto;
	text-align: left;
	font-size: 13px;
    padding: 15px;
    box-sizing: border-box;
}

.lightbox .layout_box .left,.lightbox .layout_box .right{ 
	width: 49%;
    margin: 0 auto;
}

.lightbox .layout_box img{ 
	width: 100%;
    height: auto;
    float: left;
    background: #fff;/*ブレ対策*/
}

/* ---------------------------------------------------------
■ リンクボタンエリア
--------------------------------------------------------- */
#linkbtn_area{
    width: 100%;
    background: #e6e9ef;
    padding: 40px 0;
}

#linkbtn_area .layout_box{
    width: 95%;
    max-width: 1060px;
}

#linkbtn_area .left,#linkbtn_area .right{
    width: 47.16%;
}

#linkbtn_area .btn_sub{
    height: 120px;
}

#linkbtn_area .btn_sub:before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 120px;
    height: 120px;
    background: url(../../sample/images/linkbtn_area_pht01.jpg) no-repeat;
    background-size: 100% auto;
    pointer-events: none;
}

#linkbtn_area .right .btn_sub:before{
    background: url(../../sample/images/linkbtn_area_pht01.jpg) no-repeat;
    background-size: 100% auto;
}

#linkbtn_area .btn_sub p{
    padding-left: 100px;
    box-sizing: border-box;
}

/* ---------------------------------------------------------
■ フッター
--------------------------------------------------------- */
footer {
	width: 100%;
	background: #00154b;
    color: #fff;
    z-index: 0;
	position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
}

footer img{
    width: 100%;
    height: auto;
}

footer a:link{text-decoration: none;}
footer a:hover{text-decoration: underline;}

.foot_contents{
    width: 95%;
	max-width: 900px;
	margin: 0 auto;
	text-align: center;
    padding: 50px 0;
}

/* Firefox */
@-moz-document url-prefix() {
.foot_contents{
       padding:100px 0 50px;
}
}

.foot_contents .layout_box{
    margin-bottom: 40px;
}

#foot_logo{
    width: 33%;
    max-width: 274px;
    min-width: 220px;
}

#foot_logo img{
    background: #00154b;
}

/*フッターナビ*/
.foot_navi {
    margin-top: 10px;
}

.foot_navi dl{
    float: left;
    margin-right: 40px;
}

.foot_navi dl:nth-child(2){
    margin-right: 20px;
}

.foot_navi dl:last-child{
    margin-right: 0;
}

/*フッターバナー*/
footer .bnr_area{
    border-top: 1px solid #536b96;
    border-bottom: 1px solid #536b96;
    padding: 40px 0
}

footer .bnr_area .group_tit{
    width: 34.44%;
    max-width: 310px;
    min-width: 250px;
    height: auto;
    margin-bottom: 20px;
}

footer .bnr_area ul{
    width: 88%;
    margin: 0 auto;
}

footer .bnr_area ul li{
    width: 22%;
    display: inline-block;
    margin-right: 3%;
    box-sizing: border-box;
}

footer .bnr_area ul li:nth-of-type(4){
    margin-right: 0;
}

footer .bnr_area ul li:last-child{
    margin-right: 0;
}

footer .bnr_area ul li img{
    border: 1px solid #536b96;
    max-width: 186px;
    background: #fff;
}


/*コピーライト*/
footer .copy{
    padding-top: 20px;
    font-size: 11px;
}

footer .copy span{
    display: inline-block;
}

footer .copy img{
    float: right;
    width: 120px;
}
/* ---------------------------------------------------------
■ 会社概要テーブル内レイアウト調整
--------------------------------------------------------- */
.company_info tr {
}
.company_info th {
  font-weight: normal;
  background-color: #ffffff;
  border: none;
  text-align: left;
  padding: 0;
  /*border-bottom: 1px #e6e9ef solid;*/
  width: auto;
  word-break: keep-all;
}
.company_info td {
  background-color: #ffffff;
  padding-top: 0;
  padding-bottom: 0;
  border: none;
  /*border-bottom: 1px #e6e9ef solid;*/
  text-align: left;
}
