@charset "utf-8";
/* CSS Document */
*{
    margin: 0;
    padding: 0;
    font-size: 100%;
    font-weight: normal;
    font-style: normal;
    text-decoration: none;
}
*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
body {
	width: 100%;
	line-height: 1.6;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Verdana, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #181818;
}
hr {
	display: none;	
}
h2 {
	background: #edeff1;
	color: #164088;
	text-align: left;
	padding:24px 24px 24px 0;
	margin-top: 40px;
	margin-bottom: 20px;
	line-height: 1;
}
h2 p {
	font-weight: bold;
	border-left: 5px solid #164088;
	font-size: 24px;
	padding-left: 20px;
}
h3 {
	color: #164088;
	font-size: 20px;
	font-weight: bold;
	border-bottom: 7px solid #e6e6e6;
	margin: 30px 0 30px;
	line-height: 2.5;
}
ul,ul li {
	-webkit-padding-start: 0;	
}
/* リンク
----------------------------------------------- */
a:link,
a:active,
a:visited {
	color: #fc534c;
	text-decoration: none;
}
a:hover {
	text-decoration: none;
	border-bottom: 1px dotted #fc534c;
}

header a:link,
header a:active,
header a:visited,
footer a:link,
footer a:active,
footer a:visited {
	color: #fff;
	text-decoration: none;
}
footer a:hover,
.logo a:hover,
#pagetop a:hover {
	border-bottom: 0;	
}
#right ul li a:hover {
	border-bottom: 0;
	opacity: 0.8;
}
.toggle ul li a:link,
.toggle ul li a:active,
.toggle ul li a:visited {
	color: #fff;
}
#right a:link,
#right a:active,
#right a:visited {
	color: #383838;
}

/* レイアウト
----------------------------------------------- */
header {
	width: 100%;
}
#wrapper {
	width: 1100px;
	margin: 0 auto;
	text-align: center;
}
#content {
	text-align: left;
}
#left {
	float: left;
	width: 70.6%;
	margin-bottom: 120px;
}
#right {
	float: right;
	width: 26%;
	margin-top: 45px;
	margin-bottom: 120px;
}
#main_top {
	margin-bottom: 120px;
}
#main_front {
	margin: 40px 0 55px;
}
#pagetop {
	clear: both;
	float: right;
	padding-bottom: 40px;	
}
footer {
	clear: both;
	width: 100%;
	background: #121212;
	color: #6b6b6b;
	font-size: 14px;
}
.sp {
	display: none;	
}

/* header
----------------------------------------------- */
header #wrapper {
	display: table;
	table-layout: fixed;
	padding: 10px 0;
}
header .company_name {
	display: table-cell;
	text-align: left;
	width: 50%;
	vertical-align: middle;
}
header .company_name a {
	color: #164088;
	font-size: 27px;
	font-weight: bold;
}
header .company_name a:hover {
	border-bottom: 0;
}

header .company_name span {
	color: #a1a1a1;
	font-size: 16px;
}
header .h_contact {
	display: table-cell;
	text-align: right;
	width: 50%;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 15px;
}
.h_tel {
	font-weight: bold;
	color: #164088;
	font-size: 27px;
	line-height: 1.1;	
}
.h_tel span {
	font-size: 14px;
	font-weight: bold;
}
.h_nav {
	clear: both;
	width: 100%;
	background: #edeff1;
	border-top: 1px solid #c5c5c5;
	border-bottom: 1px solid #c5c5c5;
}
ul.gnav {
	display: table;
	width: 1100px;
	margin: -1px auto;
	text-align: center;
	table-layout: fixed;
	list-style: none;
	border-right: 1px solid #c5c5c5;
	position: relative;
}
ul.gnav li {
	display: table-cell;
	border-left: 1px solid #c5c5c5;
}
ul.gnav li a {
	display: block;
	border-top: 1px solid #c5c5c5;
	border-bottom: 1px solid #c5c5c5;
	padding: 12px 0 10px;
}
ul.gnav li a:hover {
	text-decoration: none;
	background: #164088;
	border-bottom: 0;
	border-top: 1px solid #164088;
	border-bottom: 1px solid #164088;
	color: #fff;
}

ul.gnav li a p {
	color: #181818;
	font-size: 18px;
	font-weight: bold;
}
ul.gnav li a:hover p {	
	color: #fff;
}

ul.gnav li a span {
	color: #c3c4c5;
	font-size: 14px;
	font-family: "Times New Roman", Times, serif;
}
ul.gnav li a:hover span {	
	color: #738cb8;
}
ul.gnav li.down {
    position: relative;
}
ul.gnav li.down ul{
  list-style: none;
  position: absolute;
  z-index: 9999;
  top: 100%;
  left: 0;
  margin: 0;
  padding: 0;
  display: block;
}
ul.gnav li.down ul li{
  width: 100%;
  border-left: 0;
  display: block;
}
ul.gnav li.down ul li a{
  background: #164088;
  color: #fff;
  border-left: 0;
  border-right: 0;
  border-bottom: 0;
  border-top: 1px solid #4784b8;
  width: 100%;
}
ul.gnav li.down:hover > a{
  background: #164088;
}
ul.gnav li.down a:hover{
  background: #052b6c;
}
#normal li ul{
  display: none;
}
#normal li:hover ul{
  display: block;
  width: 100%;
  text-align: center;
}
/* toggle */
.toggle,
.child {
    display: none;
}
/* トップページ
----------------------------------------------- */
ul.front_menu {
	display: table;
	table-layout: fixed;
	width: 100%;
	list-style: none;
	margin: 44px 0 20px;
}
ul.front_menu li {
	display: table-cell;
}
ul.front_menu li a {
	vertical-align: middle;
	color: #fff;
	display: block;
	text-align: center;
	padding: 22px;
}
ul.front_menu li a img {
	border-radius: 50%;	
}
ul.front_menu li a p {
	font-size: 26px;
	font-weight: bold;
	padding-top: 20px;
}
ul.front_menu li a span {
	font-size: 16px;
	opacity:0.4;
}
ul.front_menu li a:hover {
	border-bottom: 0;
}
ul.front_menu li.menu_01 a {
	background: #0094b9;
}
ul.front_menu li.menu_02 a {
	background: #076eb0;
}
ul.front_menu li.menu_03 a {
	background: #503887;
}
ul.front_menu li.menu_01 a:hover,
ul.front_menu li.menu_02 a:hover,
ul.front_menu li.menu_03 a:hover {
	background: #3a3a3a;
}
dl.news {
	float: left;
	width: 49%;
	background: #fff;
	border: 1px solid #c5c5c5;
}
dl.news dt {
	padding: 19px 20px;
	border-bottom: 1px solid #c5c5c5;
}
dl.news dt span {
	position: relative;
	top: 2px;
	font-weight: bold;
}
dl.news dt:before {
    margin:0 10px 0 0;
    content:" ";
    display:inline-block;
    width:30px;
    height:30px;
    background:url(images/icon_news.png);    
    background-size:contain;
    vertical-align:middle;
}
dl.news dd {
	height: 182px;	
}
dl.news .news_list {
	float: right;
	font-size: 80%;	
}
dl.news .news_list a:before {
	content: "\f105";
	font-family: FontAwesome;
	position: absolute;
	top: 50%;
	right: 0;
	margin-top: -10px;
}
dl.front_contact {
	float: right;
	width: 49%;
	background: #ededec;
	border: 1px solid #c5c5c5;
}
dl.front_contact dt {
	padding: 19px 0;
	border-bottom: 1px solid #c5c5c5;
	text-align: center;
	color: #164088;
	font-size: 25px;
	line-height: 1;
}
dl.front_contact dt span {
	position: relative;
	top: 2px;
	font-weight: bold;
}
dl.front_contact dt:before {
    margin:0 10px 0 0;
    content:" ";
    display:inline-block;
    width:30px;
    height:30px;
    background:url(images/icon_tel_large.png);    
    background-size:contain;
    vertical-align:middle;
}
dl.front_contact dd {
	padding: 14px 26px;
    background:url(images/women.png) no-repeat 95% 100%;
	height: 182px;
	text-align: left;
}
.tel {
	color: #164088;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.1;
	font-family: Arial, Helvetica, sans-serif;
}
.tel span {
	font-size: 51px;
	font-weight: bold;
}
.fax {
	font-size: 20px;
	font-weight: bold;
	line-height: 1.1;
	font-family: Arial, Helvetica, sans-serif;
}
.fax span {
	font-size: 40px;
	font-weight: bold;
}
table.address {
    margin-left: -10px;
    margin-top: 5px;
	border: 0;   
}
table.address th {
    background: transparent !important;
    border-bottom: 0 !important;
    padding: 0 !important;
    white-space: nowrap;
    width: 50px;
}
table.address td {
    background: transparent !important;
    border-bottom: 0 !important;
    padding: 0 !important;
}

/* #left
----------------------------------------------- */
ul.breadcrumb {
	font-size: 12px;
	list-style: none;
	padding: 16px 0 40px;	
}
ul.breadcrumb_pbnone {
	font-size: 12px;
	list-style: none;
	padding: 16px 0 0;	
}
ul.breadcrumb li,
ul.breadcrumb_pbnone li {
	display: inline-block;
	padding-left: 18px;
	position: relative;
}
ul.breadcrumb li:before,
ul.breadcrumb_pbnone li:before {
	content: "\f105";
	font-family: FontAwesome;
	position: absolute;
	top: 50%;
	left: 7px;
	margin-top: -10px;
}
ul.breadcrumb li.bread_home,
ul.breadcrumb_pbnone li.bread_home {
	padding-left: 0;
}
ul.breadcrumb li.bread_home:before,
ul.breadcrumb_pbnone li.bread_home:before {
	display: none;
}
dl.main_contact {
	width: 100%;
	background: #ededec;
	border: 1px solid #c5c5c5;
	margin-top: 60px;
}
dl.main_contact dt {
	padding: 19px 0;
	border-bottom: 1px solid #c5c5c5;
	text-align: center;
	color: #164088;
	font-size: 25px;
	line-height: 1;
}
dl.main_contact dt span {
	position: relative;
	top: 2px;
	font-weight: bold;
}
dl.main_contact dt:before {
    margin:0 10px 0 0;
    content:" ";
    display:inline-block;
    width:30px;
    height:30px;
    background:url(images/icon_tel_large.png);    
    background-size:contain;
    vertical-align:middle;
}
dl.main_contact dd {
	padding: 8px 26px;
    background:url(images/women.png) no-repeat 97% 100%;
	height: 182px;
	line-height: 1.2;
	text-align: left;
}
dl.main_contact dd .tel span {
	font-size: 70px;
}
dl.main_contact dd .fax {
	padding-bottom: 10px;
}

/* #right
----------------------------------------------- */
#right .parent_ttl {
	text-align: center;
	font-weight: bold;
	color: #fff;
	background: #121212;
	padding: 16px 0 12px;
	position: relative;
}
#right .parent_ttl:after {
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(18, 18, 18, 0);
	border-top-color: #121212;
	border-width: 7px;
	margin-left: -7px;
}
#right .parent_ttl p {
	font-size: 12px;
	opacity: 0.5;
}
#right ul {
	list-style: none;
	margin-top: 10px;
}
#right ul li {
	border-bottom: 1px solid #d2d2d2;
	position: relative;
	font-size: 16px;
}
#right ul li a {
	display: block;
	padding: 3% 5% 3% 5px;
	font-weight: bold;
}
#right ul.qa_nav a {
	font-size: 90%;
}
#right ul li li {
	padding-left: 28px;
	border-bottom: 0;
}
#right ul li li a:before {
	content: "\f0da";
	font-family: FontAwesome;
	display: block;
	color: #fc534c;
	position: absolute;
	top: 50%;
	left: 16px;
	font-size: 18px;
	margin-top: -14px;
}

/* content
----------------------------------------------- */
.inner {
	padding: 0 5%;
}
.head_ttl {
	margin: 20px 0 40px;
	font-size: 30px;
	line-height: 1em;
	display: block;
	position: relative;
}
.head_ttl span {
	padding-left: 50px;
	font-weight: bold;
}
.head_ttl p.company:before {
	display:inline-block;
	content: "";
	background: url(images/icon_ttl_biz.gif) no-repeat;
	background-size: contain;
	width: 40px;
	height: 40px;
	position: absolute;
	top: 50%;
	margin-top: -20px;
}
table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	border: 1px solid #d2d2d2;
}
table th {
	background: #ebebeb;
	border-bottom: 1px dashed #d2d2d2;
	padding: 1% 2%;
	vertical-align: top;
}
table td {
	background: #fff;
	border-bottom: 1px dashed #d2d2d2;
	padding: 1% 2%;
}
table td.last,
table th.last {
	border-bottom: 0;
}
.dd dl {
	display: inline-block;
	width: 45%;
	margin: 2.5% 2% 4%;
}
#map {
	position: relative;
	width: 100%;
	padding-top: 55%;	
}
#map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
table.tbl {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	border: 1px solid #d2d2d2;
	font-size: 12px;
}
table.tbl th {
	background: #dfebff;
	border-bottom: 1px solid #d2d2d2;
	border-right: 1px solid #d2d2d2;
	padding: 0.5% 2%;
	vertical-align: top;
	text-align: center;
	font-weight: bold;
}
table.tbl td {
	background: #fff;
	border-bottom: 1px dashed #d2d2d2;
	border-right: 1px solid #d2d2d2;
	padding: 0.5% 2%;
}

/* Q&A */
ul.qa_index {
	list-style: none;
	margin: 20px 0 0 0;
}
ul.qa_index li {
	position: relative;
	padding: 0 24px;
}
ul.qa_index li:before {
	content: "Q.";
	position: absolute;
	top: 4px;
	left: 0;
	font-weight: bold;
	font-size: 16px;
	line-height: 1;
	color: #fc534c;
}
dl.qa {
	margin-top: 30px;	
}
dl.qa dt {
	background: #edeff1;
	color: #164088;
	font-weight: bold;
	font-size: 20px;
	margin-bottom: 30px;
	position: relative;
	padding: 10px 50px;
}
dl.qa dt:before {
	content: "Q.";
	position: absolute;
	top: 16px;
	left: 20px;
	font-weight: bold;
	font-size: 20px;
	line-height: 1;	
}

dl.qa dd {
	padding: 0 0 0 50px;
	position: relative;
}
dl.qa dd.a {
	color: #fc534c;
	margin-bottom: 20px;
}
dl.qa dd.a:before {
	content: "A.";
	position: absolute;
	top: 0;
	left: 20px;
	font-weight: bold;
	font-size: 20px;
	line-height: 1;	
}
dl.qa dd .f_right img {
	padding: 0 0 20px 20px;
}
dl.qa dd .f_left img {
	padding: 10px 20px 20px 0;
}
.pagetop_s {
	text-align: right;
	padding-top: 20px;
	font-size: 14px;	
}
.pagetop_s a {
	color: #164088;
	position: relative;
}
.pagetop_s a:hover {
	border-bottom: 1px dotted #164088;
}
.pagetop_s a:before {
	content: "\f0d8";
	font-family: FontAwesome;
	display: block;
	color: #164088;
	position: absolute;
	top: 50%;
	left: -14px;
	font-size: 18px;
	margin-top: -14px;
}
/* お問い合わせ */
#contact_form {
	border: 1px solid #c5c5c5;
	padding: 5%;
	margin-top: 40px;	
	list-style: none;
}
#contact_form ul {
	border-top: 1px dotted #e3e3e3;
	margin-top: 1em;
}
#contact_form ul li {
	border-bottom: 1px dotted #e3e3e3;
	padding: 15px;
	display: table;
	table-layout: fixed;
	width: 100%;	
}
#contact_form ul li p {
	display: table-cell;
	width: 35%;
	vertical-align: middle;
	font-weight: bold;
}
#contact_form ul li div {
	display: table-cell;
	width: 65%;
}
#contact_form form input,
#contact_form form textarea {
	padding: 3px;
	border-radius: 3px;        /* CSS3草案 */  
    -webkit-border-radius: 3px;    /* Safari,Google Chrome用 */  
    -moz-border-radius: 3px;   /* Firefox用 */
	border: 1px solid #939393;
}
#contact_form form input.form_text {
	width: 70% !important;	
}
#contact_form form textarea.form_textarea {
	width: 100% !important;	
}

input[type="submit"] {
	border: 0 !important;
	background: #04287e;
	color: #fff;
	font-size: 20px;
	padding: 14px !important;
	width: 40%;
	cursor: pointer;
	margin-top: 20px;	
}

/* footer */
footer #wrapper {
	display: table;
	padding: 24px 0 30px;
}
footer .fnav {
	text-align: left;
	display: table-cell;
}
footer .fnav ul {
	list-style: none;
}
footer .fnav ul li {
	display: inline-block;
}
footer .fnav ul li:after {
	content: "/";
	padding: 0 10px 0 15px;
}
footer .fnav ul li.fnav_last:after {
	display: none;
}
footer #f_right {
	text-align: right;
	display: table-cell;
	vertical-align: top;
}
footer #f_right p {
	color: #fff;
	font-size: 19px;
	font-weight: bold;
}
footer p.copy {
	opacity: 0.5;
	font-size: 12px !important;
	font-weight: normal !important;
	font-family: Arial, Helvetica, sans-serif;
}
/* 共通 */
.t_bold {
	font-weight: bold;	
}
.t_center {
	text-align: center;	
}
.t_normal {
	font-weight: normal;	
}
.t_sub {
	font-size: 90%;
	padding: 20px 0 10px;	
}
.t_blue {
	color: #529acc;	
}
.t_red {
	color: #fc534c;	
}
.t_large {
	font-size: 125%;
	font-weight: bold;	
}
.t_small {
	font-size: 90%;
}
.t_smaller {
	font-size: 70%;
}

ul.inside {
	margin-left: 2.4em;
}
ul.answer {
	list-style: none;
	margin-bottom: 20px;	
}
.f_right {
	float: right;	
}
.f_left {
	float: left;	
}
/* 回り込み解除 */
.front_bottom:after {
	content: "";
    clear: both;
    height: 0;
    display: block;
    visibility: hidden;
}

@media screen and (max-width:640px){
.sp { display: block; }
.pc { display: none; }

.toggle {
	display: block;
}
body {
	font-size: 16px;	
}
header {
    position: fixed;
    top: 0;
    left:0;
	height:65px;
	background: #fff;
	z-index: 100000;
	border-bottom: 1px solid #164088;
}
header .h_contact,
ul.gnav,
#right {
	display: none;	
}
nav {
	border: 0;	
}
#gnavi_sp,
#content {
	margin-top: 63px;
}
.menu {
    display:block;
    position:absolute;
    top:19px;
    right:15px;
    width:30px;
    height:22px;
    background:#000b25;
    border-top:10px solid #fff;
    border-bottom:10px solid #fff;
    -moz-box-sizing:border-box;
    -webkit-box-sizing:border-box;
    box-sizing:border-box;
    -moz-transition:all 0.3s;
    -webkit-transition:all 0.3s;
    transition:all 0.3s;
}
.menu:before {
    content:'';
    position:absolute;
    width:30px;
    height:2px;
    background:#000b25;
    top:-9px;
    right:0;
    -moz-transition:all 0.3s;
    -webkit-transition:all 0.3s;
    transition:all 0.3s;
}
.menu:after {
    content:'';
    position:absolute;
    width:30px;
    height:2px;
    background:#000b25;
    bottom:-9px;
    right:0;
    -moz-transition:all 0.3s;
    -webkit-transition:all 0.3s;
    transition:all 0.3s;
}
.menu.active {
    background:#fff;
}
.menu.active:before {
    -moz-transform:rotate(-135deg);
    -webkit-transform:rotate(-135deg);
    transform:rotate(-135deg);
    top:0;
    right:0;
}
.menu.active:after {
    -moz-transform:rotate(135deg);
    -webkit-transform:rotate(135deg);
    transform:rotate(135deg);
    bottom:0;
    right:0;
}
#gnavi_sp {
    position: fixed;
    top: 0;
    left:0;
	height:100%;
	width: 100%;
	z-index: 2000;
	background: #164088;
}
#gnavi_sp li a {
	display: block;
	text-decoration: none;
	border-bottom: 1px solid #738cb8;
	padding: 10px 20px;
	background: #164088;
}
header #wrapper {
    padding: 10px 0;
}
header .company_name {
	display: table-cell;
	text-align: left;
	width: 90%;
	vertical-align: middle;
}
header .company_name a {
    font-size: 16px;
}
header .company_name span {
    font-size: 12px;
}
#wrapper {
	width: 96%;
	margin: 0 2%;
}
.cover img {
	width: 100%;
	height: auto;	
}
#left {
	width: 100%;
}
table{
width:100%;
}
.scroll{
overflow: auto;　　　　/*tableをスクロールさせる*/
white-space: nowrap;　　/*tableのセル内にある文字の折り返しを禁止*/
}
.scroll::-webkit-scrollbar{　　/*tableにスクロールバーを追加*/
 height: 5px;
}
.scroll::-webkit-scrollbar-track{　　/*tableにスクロールバーを追加*/
 background: #F1F1F1;
}
.scroll::-webkit-scrollbar-thumb {　　/*tableにスクロールバーを追加*/
 background: #BCBCBC;
}
footer .fnav {
	display: none;
}
ul.breadcrumb {
	padding: 16px 0;	
}
ul.breadcrumb li {
	display: inline-block;
	padding-left: 18px;
	position: relative;
}

/* トップページ */
.home_top {
	margin: 0 -2%;	
}
ul.front_menu {
	display: table;
	table-layout: fixed;
	width: 100%;
	list-style: none;
	margin-top: 23px;
}
ul.front_menu li {
	display: block;
	width : 100%;
	margin-bottom: 0;
}
ul.front_menu li a {
	padding: 10px;	
}
ul.front_menu li a p {
	padding-top: 0;	
	font-size: 18px;
}
ul.front_menu li div{
	display: none;
}
dl.news {
	float: none;
	width: 100%;
	height: auto;
	margin-bottom: 20px;
}
dl.front_contact {
    float: none;
    width: 100%;
}
dl.front_contact dt,
dl.main_contact dt {
	font-size: 16px;
}
dl.front_contact dt:before,
dl.main_contact dt:before {
    display: none;
}
dl.front_contact dd,
dl.main_contact dd {
    background: none;
    height: auto;
}
.tel span,
dl.main_contact dd .tel span {
    font-size: 30px;
}
.fax span,
dl.main_contact .fax span {
    font-size: 30px;
    font-weight: bold;
}
table.address {
    font-size: 12px;
}

h2 p,h3 {
	font-size: 18px;
}



.dd dl {
	display: block;
	width: 100%;
	margin: 2.5% 0 4%;
}

table.tbl td.tbl_head {
	min-width: 200px;	
}
.f_left,.f_right {
	float: none;	
}
.f_left img,.f_right img {
	width: 100%;
	padding: 10px 0 !important;
}
dl.qa dt {
	font-size: 16px;
}
dl.qa dd {
	padding: 0 0 0 40px;
	margin-bottom: 10px;
}
dl.qa dd.q:before {
	font-size: 26px;
	top: -6px;
	left: 0;
}
dl.qa dd.a:before {
	font-size: 20px;
	top: 2px;
	left: 0;
}
/* お問い合わせ */
#contact_form {
	font-size: 16px;	
}
#contact_form ul li p {
	display: block;
	width: 100%;
}
#contact_form ul li div {
	display: block;
	width: 100%;
}
input[type="submit"] {
	width: 90%;
}


}