* {margin: 0; padding: 0;}
body,html {height: 100%;}
body{
	font-family: "Noto Sans Japanese","Hiragino Kaku Gothic ProN", "メイリオ", meiryo, sans-serif;
	color: #000000;
}
.h1, h1 {
    font-size: 26px;
}
a {  transition: color 0.2s, background-color 0.2s, border-color 0.2s, text-decoratin 0.2s; }

a:link,a:visited{
	color:#0064d1;
}
.entry .h3,.entry h3{
   font-size: 20px;
	color:#37A9CD;
	text-align:center;
	margin-bottom:20px;
}
.navbar-default .navbar-nav>li>a{
	color:#fff;
}
.navbar-default .navbar-nav>li>a:hover,.navbar-default .navbar-nav>li>a:focus{
	color:#fff !important;
}
.sub-page-contents .container {width: 600px; margin: 0 auto;}

#header{
	position:relative; width:100%; 
	background-color:#4073AD;
	padding-top:0 !important;
	padding-bottom:0 !important;
	height: 70px;
}
#contents{ 
	padding-top:0px;
	min-height:500px;
}
.navbar-brand {
	margin-left: 0px;
	background: url(img/logo.png) no-repeat;
	background-size: auto 100%;
	text-indent:150%;
	overflow:hidden;
	white-space:nowrap;
	height: 70px;
	width: 402px;
	transition: 0.2s;
	display: block;
}


.contactmenu a {
		text-decoration: none;
		padding:0px;
		height: 70px;
		line-height: 70px;
		color: #fff;
		width: 75px;
		font-size: 14px;
		background-color: #222;
		display: block;
		margin-left: auto;
		text-align: center;
		padding-right: 5px;
		position: relative;
}
.contactmenu a:after{
	content: url(img/arrow07.png);
	position: absolute;
	right: 10px;
}
.contactmenu a:hover:after{
	content: url(img/arrow08.png);
}
.header .inner{ width: 1024px; margin: 0 auto;}
.headline{display: table; width: 100%;height: 70px;transition: 0.2s;}

.header__logo {
  margin-top: 10px;
  white-space: nowrap;
	color: #fff;
    height: 70px;
}
.header__logo:after {
  content: '';
  display: block;
  clear: both;
}
.header__logo a{
	color: #fff;
	display: block;
	text-decoration: none;
}

.header__logo--img {
  width: 60px;
  float: left;
  margin-right: 10px;
}
.header__logo--img img {
  width: 100%;
  height: auto;
}

.header__name {
  margin: 0;
  font-size: 22px;
  font-weight: 500;
	color: #fff;
	line-height: 1;
}
.header__name span {
  font-size: 12px;
  font-weight: 200;
  display: block;
  padding-top: 5px;
  margin-bottom: 5px;
}
.headline .logo{
	display: table-cell; vertical-align: top; padding: 0;
}

.headline .logo .copy{
	font-size: 11px;
	font-weight: normal;
	display: table-cell;
	vertical-align: top;
	padding-left: 15px;
	padding-top: 20px;
}
.headline .contactmenu{ display: table-cell;margin-left: auto;vertical-align: top; text-align: right; padding: 0px 0 0 0;}

/*==================================================
 * layout
 *================================================*/
#container {
  /*overflow: hidden;*/
  position: relative;
  min-height: 100%;
}
.sub-page-contents {
 	padding-top: 0px;
	min-height: 550px;
}
#main {
  margin-bottom: 0px; }
  .page-template-front-page #main,
  .page-template-rich-front-page #main {
    margin-bottom: 0; }
.article{
	margin-bottom:20px;
	padding-right:0px;
}
.entry{
	margin:60px 0 0;
}

.entry:before,
.entry:after {
  content: " ";
  display: table; }

.entry:after {
  clear: both; }


/*==================================================
 * header
 *================================================*/
.header {
  position: relative;
  z-index: 3;
 }

/*==================================================
 * footer
 *================================================*/

.footer {
	text-align: center;
	padding: 0;
}
.footer .row{
	padding: 0 130px;
}

.footer .footbanner{
	display: inline-block;
	letter-spacing: -.4em;
	margin-bottom: 20px;
}
.footer .footbanner li{
	text-align: left;
	display: inline-block;
	vertical-align: top;
	letter-spacing:normal;
}
.footer .footbanner li:first-child span{
	border: 1px solid #000;
	display: block;
	width: 135px;
	height: 72px;
	text-align: center;
	font-size: 16px;
	padding-top: 10px;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
.footer .footbanner li:nth-child(2) a{
	display: block;
	width: 290px;
	height: 72px;
	background: url(img/banner-tel.png) 20px center no-repeat;
	background-size: 230px auto;
	text-indent: 150%;
	white-space: nowrap;
	overflow: hidden;
}
.footer .footbanner li:last-child a{
	display: block;
	width: 275px;
	height: 72px;
	text-align: center;
}
.footer .footbanner li:last-child a:hover{
	opacity: .8;
}
.footer .footbanner li:last-child a img{
	width: 100%;
	height: auto;
}
.footer .container {width: 600px; margin: 0 auto;}
.footer .corp{
	background-color: #CCCCCC;
	text-align: left;
	line-height: 1.5;
	padding: 20px 0;
	font-size: 16px;
}
.footer .corp strong{
	display: block;
	font-size: 18px;
	color: #333333;
}
.footer .footer-globalmenu{
	padding: 20px 0;
	text-align: center;
	font-size: 10px;
	background-color: #fff;
	position: relative;
	line-height: 1.3;
}


/**
 * .copyright
 */
.copyright {
  padding: 10px 0 0 0;
	text-align: center;
	padding-bottom: 0px;
	background-color: #4073AD;
	color: #fff;
	height: 36px;
 }
.copyright .copy{
  font-size: 9px;
}
/*==================================================
 * contents
 *================================================*/

.entry__content{
	line-height:1.5;
}

.entry__content h3 + p{
	margin-bottom:30px;
}

.section dl{
	width:100%;
	display:table;
	padding:15px 0;
	border-bottom:1px dotted #ccc;
	margin-bottom:0;
}
.section dl:last-child{
	border-bottom:none;
}
.section dt{
	display:table-cell;
	width:25%;
}
.section dd{
	display:table-cell;
	width:75%;
	line-height:1.5;
}
.section dd span{
	padding-left:1em;
}
.section dd p{
	line-height:1.5;
}


/*-------------------------------
 page
------------------------------- */
.h4, .h5, .h6, h4, h5, h6 {
    margin-top: 0px !important;
    margin-bottom: 10px;
}
.entry__content section {
	    margin-bottom: 50px
}
.entry__content section:last-child {
	    margin-bottom: 0px
}
.entry__content p{
	text-align: left;
	font-size: 16px;
	line-height: 2;
	color: #333;
}

.entry__content h2{
	text-align: center;
	font-size: 24px;
	line-height: 32px;
	padding: 7px 0;
	color: #1e3b9c;
	font-weight: bold;
	margin-bottom: 32px;
}

.entry__content h3{
	text-align: center;
	font-size: 24px;
	line-height: 32px;
	color: #2987e2;
	font-weight: normal;
	margin-bottom: 24px;
}
.entry__content h4{
	text-align: left;
	font-size: 18px;
	line-height: 24px;
	color: #06294b;
	font-weight: bold;
	margin-bottom: 14px;
}
.entry__content h5{
	font-size: 24px;
	line-height:1.2;
	color: #1c6dd5;
	font-weight: normal;
	margin-bottom: 14px;
	text-align: center;
}


/*contact */

.contactform {
	box-sizing: border-box;
}
.contactform .page_title,
.page-thanks .page_title{
  display: block;
  font-size: 32px;
  padding-bottom: 15px;
  margin-bottom: 26px;
	font-weight: normal;
	text-align: center;
}
.contactform .page_title:after,
.page-thanks .page_title:after{
	margin: 0 auto 30px;
	content: "";
	display: block;
	width: 80px;
	height: 24px;
	border-bottom: 2px solid #39A6F5;
}
.contactform .lead,
.page-thanks .lead {
    font-size: 16px;
		text-align: left;
		margin-bottom: 20px;
		color: #4073AD;
		line-height: 1.8;
}
.contactform .notes {
	color: #ff0000;
	font-size: 15px;
	margin-bottom: 20px;
}
.contactform .title{
	color: #333333;
	font-size: 20px;
	height: 36px;
	line-height: 34px;
	background-color: #FFFF00;
	border: 1px solid #FCEE21;
	text-align: center;
	font-weight: bold;
	margin-bottom: 24px;
}

.contactform .form input[type=text],
.contactform .form input[type=email]{
	height: 40px;
	width: 145px;
	line-height: 38px;
	border:none;
	font-size: 14px;
	padding: 0 10px;
	box-sizing: border-box;
	font-weight: normal;
}
.contactform .form textarea{
	padding: 5px 10px;
	border:1px solid #000;
	height: 240px;
	width: 100%;
}

.form .btnarea .sendbtn,.form .btnarea .backbtn{
	position: relative;
	color: #fff;
	line-height: 48px;
}
.form .btnarea .sendbtn{
	margin-left: 32px;
}

.contactform .form{
    width: 100%;
    display: inline-block;
    text-align: left;
    letter-spacing: normal;
    margin: 0 0 50px 0;
    position: relative;
		padding: 20px 0px 0;
		background-color: #eee;
}
.contactform dl{
	width: 100%;
	padding: 0;
	margin: 0;
	display: table;
}
.contactform dd{
	display: table-cell;
	vertical-align: top;
	font-size: 16px;
	line-height: 	1.5;
	padding: 40px 0 20px 0px;
	position: relative;
	font-size: 14px;
	text-align: right;
}

.contactform dl dd:last-child{
	padding: 40px 30px 20px 0px;
}
.contactform .form dl dd:last-child input[type=text],
.contactform .form dl dd:last-child input[type=email]{
			width: 345px;
}
.contactform dl dd:nth-child(3){
	padding: 40px 30px 20px 0px;
	width: 230px;
	box-sizing: border-box;
}
.contactform .form dl dd:nth-child(3) input[type=text],
.contactform .form dl dd:nth-child(3) input[type=email]{
		width: 145px;
}
.contactform dt{
	padding: 40px 0 20px 30px;
	width: 175px;
	font-size: 16px;
	font-weight:normal;
	box-sizing: border-box;
}
.contactform dd > span{
	font-weight: bold;
	font-size: 14px;
}
.contactform dd .note{
	position: absolute;
	top:18px;
	right: 0;
	font-weight: normal;
	font-size: 12px;
	color: #666666;
}
.contactform dd:last-child .note{
	right: 30px;
}
.contactform dl.onecolumn dt{
	width: 100%;
	display: block;
	padding: 40px 0 0px 30px;
}
.contactform dl.onecolumn dd{
	width: auto;
	display: block;
	padding: 40px 30px 20px 30px
}
.contactform .form dl.onecolumn dd:last-child input[type=text],
.contactform .form dl.onecolumn dd:last-child input[type=email]{
	width: 100%;
	display: block;
}
.contactform dl.onecolumn dd .fr{
	background-color: #fff;
	padding-top: 20px;
	padding-bottom: 20px;
}

.contactform .form label{
	font-weight: normal;
}

.contactform dl.onecolumn dd .fr .txt{
	width: 440px;
	height: 135px;
	margin: 0 auto;
	overflow:auto;
	padding: 30px;
	text-align: left;
	background-color: #BEE1FA;
	box-sizing: border-box;
}
.contactform dl.onecolumn dd .fr .txt+span{
	display: block;
	margin: 30px auto 10px;
	text-align: center;
	font-size: 16px;
}
.contactform dl.onecolumn dd .fr .txt div{
	font-weight: bold;
	font-size: 14px;
	margin-bottom: 12px;
}
.contactform dl.onecolumn dd .fr .txt .ttl{
	text-align: center;
	font-weight: bold;
	font-size: 16px;
	margin-bottom: 12px;

}
.contactform dl.onecolumn dd .fr .txt p{
	line-height: 1.8;
	font-size: 14px;
	margin-bottom: 30px;
}
.contactform dl.onecolumn dd .fr .txt .subttl{
	font-weight: bold;
	font-size: 16px;
	margin-bottom: 12px;
}
.contactform dl.onecolumn dd .fr .txt ul{
	line-height: 1.5;
	font-size: 14px;
	margin-bottom: 30px;
	margin-left: 1.5em;
}
/* 各ベンダープレフィックスが取れた標準版！！(http://caniuse.com/#search=placeholder-shown) */
:placeholder-shown {
    color: #999; }

/* Google Chrome, Safari, Opera 15+, Android, iOS */
::-webkit-input-placeholder {
    color: #999; }

/* Firefox 18- */
:-moz-placeholder {
    color: #999; opacity: 1; }

/* Firefox 19+ */
::-moz-placeholder {
    color: #999; opacity: 1; }

/* IE 10+ */
:-ms-input-placeholder {
    color: #999; }


/*contact*/

.form dl{
	border-top: 1px solid #fff;
	width:100%;
	display:table;
	margin-bottom:0;
}
.form dl:first-child{
	border-top: none;
}
.form dt{
	display:table-cell;
	vertical-align:top;
	position: relative;
	box-sizing: border-box;
	font-size: 16px;
	line-height: 40px;
}
.form dt span{
	border: 1px solid #666666;
	color: #666666;
	padding: 3px 5px;
	line-height: 20px;
	font-size: 12px;
	margin-right: 8px;
}
.form dt span.require{
	background-color: #FF0000;
	color: #fff;
	border: none;
}
.form dd{
	vertical-align:top;
	position: relative;
	display:table-cell;
	font-size: 14px;
}
.form dd.name-style{
	width: 195px;
}
.contactform dl.onecolumn dd.cbox{
	padding: 10px 30px 20px 30px
}
.contactform .btnarea {
	text-align: center;
	padding-top: 45px;
	padding-bottom: 40px;
}
.contactform .btnarea input{
	text-align: center;
	width: 320px;
	height: 60px;
	color: #fff;
	font-size: 18px;
	background-color: #FF0000;
	border: none;
	-webkit-appearance: none;
}
.contactform .btnarea input:hover{
	background-color: #C60000;
}
.contactform dl dd span.error{
	position: absolute;
	background-color: #DD0000;
	color: #fff;
	display: block;
	width: 160px;
	height: 30px;
	font-size: 12px;
	font-weight: normal;
	line-height: 30px;
	text-align: center;
	left: 40px;
	bottom:-18px;

}
.contactform dl dd span.error:after{
	position: absolute;
	left: 50%;
	display: block;
	top:-5px;
	margin-left: -5px;
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 4.5px 6px 4.5px;
	border-color: transparent transparent #DD0000 transparent;
}
.contactform dl.onecolumn dd span.error{
	width: 240px !important;
	left: 180px !important;
}
.contactform dl dd:last-child span.error{
	width: 240px;
	left: 100px;
}
.contactform dl dd:nth-child(3) span.error{
	width: 160px;
	left: 45px;
}

.contactform dl dd input.error{
	background-color: #FFBBBB;
}
.contactform dl.onecolumn dd.cbox span.error{
	left: 57px !important;
	bottom:auto;
	top:230px;
}

/*確認画面*/
.mw_wp_form_confirm dl dd{
	text-align: left;
	padding: 20px 30px 20px 0px;
}
.mw_wp_form_confirm dl dd span{
	text-align: left;
	line-height: 40px;
	font-size: 16px;
	font-weight: normal;
}
.mw_wp_form_confirm dl dt {
	width: 237px;
	padding: 20px 0 20px 30px;
}
.mw_wp_form_confirm dl.onecolumn dt{
	padding: 20px 0 0px 30px;
}
.mw_wp_form_confirm dl dd:last-child{
	padding: 20px 30px 20px 0px;
}
.mw_wp_form_confirm dl dd:nth-child(3) {
	padding: 20px 30px 20px 0px;
    width: auto;
}
.mw_wp_form_confirm dl.onecolumn dd {
	padding: 0px 30px 20px 237px;
    width: auto;
}
.mw_wp_form_confirm .btnarea {
	text-align: center;
	padding-top: 45px;
	padding-bottom: 40px;
}
.mw_wp_form_confirm .btnarea>span{
	display: inline-block;
}

.mw_wp_form_confirm .btnarea #submit{
	width: 310px;
	outline: none;
}
.mw_wp_form_confirm .btnarea .history-back-button{
	width: 170px;
	color: #fff;
	font-size: 18px;
	background-color: #888888;
	border: none;
	margin-right: 20px;
}
.mw_wp_form_confirm .btnarea .history-back-button:hover{
	background-color: #666;
}
.mw_wp_form_complete .inner{
	padding: 15px 40px 35px;
}
.mw_wp_form_complete .inner .ttl{
	text-align: center;
	margin-bottom: 30px;
	color: #4073AD;
	font-size: 24px;
}
.mw_wp_form_complete .inner .txt{
	font-size: 16px;
	color: #333333;
	line-height: 1.8;
	margin-bottom: 20px;
}
.mw_wp_form_complete .inner .txt2{
border: 1px solid #000;
	padding: 30px 40px 30px;
	font-size: 16px;
}


/*foot*/
#page-top {
		position: absolute;
    z-index: 9999;
    bottom: 8px;
    right: 20px;
    font-size: 12px;
}

#page-top a {
    width: 50px;
    height: 50px;
    text-decoration: none;
    color: #000;
    padding: 0px;
    text-align: center;
    display: block;
    -moz-opacity: 0.8;
    opacity: 0.8;
		font-size:30px;
		line-height: 48px;
		font-weight: bold;
		border: 1px solid #000;
		background: url(img/arrow-up.png) center center no-repeat;
}

#page-top a .fa-angle-up:before {
    font-weight: normal;
}

