@charset "UTF-8";
/* ===============================================
	RESET
=============================================== */
html, body, div, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, p, blockquote, fieldset, input, abbr, article, aside, command, details, figcaption, figure, footer, header, mark, meter, nav, output, progress, section, summary, time {
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

li, h1, h2, h3, h4, h5, h6, span, pre, code, address, caption, cite, code, em, strong, b, th, figcaption {
	font-size: 1em;
	font-weight: normal;
	font-style: normal;
}

fieldset, iframe {
	border: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

article, aside, footer, header, nav, section, figure, figcaption {
	display: block;
}

img, abbr, acronym, fieldset {
	border: 0;
	font-size: 0;
	line-height: 0;
	vertical-align: bottom;
}

li {
	list-style: none;
}

body {
	line-height: 1;
}

dl, menu, ol, ul {
	margin: 1em 0;
}

/* ==========================================================================
   
   module
   
   ========================================================================== */
/* ---------------------------------------------
	font Style
--------------------------------------------- */
.fBold {
	font-weight: bold;
}

.fItalic {
	font-style: italic;
}

.fnormal {
	font-weight: normal;
}

.f10 {
	font-size: 10px;
}

.f12 {
	font-size: 12px;
}

.f14 {
	font-size: 14px;
}

.f16 {
	font-size: 16px;
}

.f18 {
	font-size: 18px;
}

.red {
	color: #e32e29;
}

/* ---------------------------------------------
	float
--------------------------------------------- */
.f_l {
	float: left;
}

.f_r {
	float: right;
}

/* ---------------------------------------------
	preset margin
--------------------------------------------- */
.mt05 {
	margin-top: 5px !important;
}

.mt10 {
	margin-top: 10px !important;
}

.mt12 {
	margin-top: 12px !important;
}

.mt15 {
	margin-top: 15px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mt25 {
	margin-top: 25px !important;
}

.mt30 {
	margin-top: 30px !important;
}

.mt35 {
	margin-top: 35px !important;
}

.mt40 {
	margin-top: 40px !important;
}

.mt45 {
	margin-top: 45px !important;
}

.mt50 {
	margin-top: 50px !important;
}

.mb01 {
	margin-bottom: 1px !important;
}

.mb03 {
	margin-bottom: 3px !important;
}

.mb05 {
	margin-bottom: 5px !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mb12 {
	margin-bottom: 12px !important;
}

.mb15 {
	margin-bottom: 15px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb25 {
	margin-bottom: 25px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}

.mb35 {
	margin-bottom: 35px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb45 {
	margin-bottom: 45px !important;
}

.mb50 {
	margin-bottom: 50px !important;
}

.mr05 {
	margin-right: 5px !important;
}

.mr10 {
	margin-right: 10px !important;
}

.mr12 {
	margin-right: 12px !important;
}

.mr15 {
	margin-right: 15px !important;
}

.mr20 {
	margin-right: 20px !important;
}

.mr25 {
	margin-right: 25px !important;
}

.mr30 {
	margin-right: 30px !important;
}

.mr35 {
	margin-right: 35px !important;
}

.mr40 {
	margin-right: 40px !important;
}

.mr45 {
	margin-right: 45px !important;
}

.mr50 {
	margin-right: 50px !important;
}

.ml05 {
	margin-left: 5px !important;
}

.ml10 {
	margin-left: 10px !important;
}

.ml12 {
	margin-left: 12px !important;
}

.ml15 {
	margin-left: 15px !important;
}

.ml20 {
	margin-left: 20px !important;
}

.ml25 {
	margin-left: 25px !important;
}

.ml30 {
	margin-left: 30px !important;
}

.ml35 {
	margin-left: 35px !important;
}

.ml40 {
	margin-left: 40px !important;
}

.ml45 {
	margin-left: 45px !important;
}

.ml50 {
	margin-left: 50px !important;
}

.mlmr05 {
	margin-left: 5px !important;
	margin-right: 5px !important;
}

.mlmr10 {
	margin-left: 10px !important;
	margin-right: 10px !important;
}

.mlmr20 {
	margin-left: 20px !important;
	margin-right: 20px !important;
}

.mcenter {
	margin-left: auto !important;
	margin-right: auto !important;
}

/* ---------------------------------------------
	preset padding
--------------------------------------------- */
.pt05 {
	padding-top: 5px !important;
}

.pt10 {
	padding-top: 10px !important;
}

.pt12 {
	padding-top: 12px !important;
}

.pt15 {
	padding-top: 15px !important;
}

.pt20 {
	padding-top: 20px !important;
}

.pt25 {
	padding-top: 25px !important;
}

.pt30 {
	padding-top: 30px !important;
}

.pt35 {
	padding-top: 35px !important;
}

.pt40 {
	padding-top: 40px !important;
}

.pt45 {
	padding-top: 45px !important;
}

.pt50 {
	padding-top: 50px !important;
}

.pb05 {
	padding-bottom: 5px !important;
}

.pb10 {
	padding-bottom: 10px !important;
}

.pb12 {
	padding-bottom: 12px !important;
}

.pb15 {
	padding-bottom: 15px !important;
}

.pb20 {
	padding-bottom: 20px !important;
}

.pb25 {
	padding-bottom: 25px !important;
}

.pb30 {
	padding-bottom: 30px !important;
}

.pb35 {
	padding-bottom: 35px !important;
}

.pb40 {
	padding-bottom: 40px !important;
}

.pb45 {
	padding-bottom: 45px !important;
}

.pb50 {
	padding-bottom: 50px !important;
}

.pr05 {
	padding-right: 5px !important;
}

.pr10 {
	padding-right: 10px !important;
}

.pr12 {
	padding-right: 12px !important;
}

.pr15 {
	padding-right: 15px !important;
}

.pr20 {
	padding-right: 20px !important;
}

.pr25 {
	padding-right: 25px !important;
}

.pr30 {
	padding-right: 30px !important;
}

.pr35 {
	padding-right: 35px !important;
}

.pr40 {
	padding-right: 40px !important;
}

.pr45 {
	padding-right: 45px !important;
}

.pr50 {
	padding-right: 50px !important;
}

.pl05 {
	padding-left: 5px !important;
}

.pl10 {
	padding-left: 10px !important;
}

.pl12 {
	padding-left: 12px !important;
}

.pl15 {
	padding-left: 15px !important;
}

.pl20 {
	padding-left: 20px !important;
}

.pl25 {
	padding-left: 25px !important;
}

.pl30 {
	padding-left: 30px !important;
}

.pl35 {
	padding-left: 35px !important;
}

.pl40 {
	padding-left: 40px !important;
}

.pl45 {
	padding-left: 45px !important;
}

.pl50 {
	padding-left: 50px !important;
}

/* ---------------------------------------------
	inline align
--------------------------------------------- */
.t_align_l {
	text-align: left !important;
}

.t_align_c {
	text-align: center !important;
}

.t_align_r {
	text-align: right !important;
}

.pre {
	white-space: pre;
}

/* ---------------------------------------------
	other
--------------------------------------------- */
.imgRep {
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
}

.fade {
	-webkit-transition-duration: 0.3s;
	-moz-transition-duration: 0.3s;
	-o-transition-duration: 0.3s;
	transition-duration: 0.3s;
	-webkit-transition-timing-function: ease-in-out;
	-moz-transition-timing-function: ease-in-out;
	-o-transition-timing-function: ease-in-out;
	transition-timing-function: ease-in-out;
}
.fade:hover {
	filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=60);
	opacity: 0.6;
}

a img:hover {
	filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
	opacity: 0.7;
}

/* ==========================================================================
   Helper classes
   ========================================================================== */
.hidden {
	display: none !important;
	visibility: hidden;
}

.visuallyhidden {
	border: 0;
	clip: rect(0 0 0 0);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
	clip: auto;
	height: auto;
	margin: 0;
	overflow: visible;
	position: static;
	width: auto;
}

.invisible {
	visibility: hidden;
}

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

.clearfix:after {
	clear: both;
}

.clearfix {
	*zoom: 1;
}

/* ==========================================================================
	
   Variable
   
   ========================================================================== */
/* ==========================================================================
	
   base
   
   ========================================================================== */
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

img {
	vertical-align: top;
}

a {
	color: #4470d2;
}
a:hover {
	text-decoration: none;
}

html, body {
	text-align: left;
	width: 100%;
}

body {
	width: 100%;
	color: #3f6a84;
	font-size: 12px;
	line-height: 1.7;
	font-family: Arial, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
	text-align: left;
}

#wrapper {
	width: 100%;
	margin: 0 auto;
	position: relative;
	min-width: 1200px;
	overflow: hidden;
}

/* ==========================================================================
	
   contents
   
   ========================================================================== */
#header {
	width: 100%;
	border-top: 7px solid #0058aa;
}
#header .inner {
	text-align: center;
}

#mainVisual {
	background: url(../images/main_bg.png) no-repeat center center;
	position: relative;
	height: 320px;
	width: 100%;
	background-color: #0C4Aa5;
}
#mainVisual .inner {
	width: 900px;
	height: 320px;
	margin: 0 auto;
	position: relative;
}
#mainVisual .inner .text {
	position: absolute;
	left: 50%;
	top: 50%;
	margin-left: -165px;
	margin-top: -91px;
}

#gnavi {
	width: 100%;
	background-color: #D9EBF9;
}
#gnavi ul {
	width: 901px;
	margin: 0 auto;
	overflow: hidden;
	background: url(../images/gnavi_line.png) left top no-repeat;
	padding-left: 1px;
}
#gnavi ul li {
	float: left;
	background: url(../images/gnavi_line.png) right top no-repeat;
	padding-right: 1px;
}
#gnavi ul li a {
	display: block;
}
#gnavi ul li a img:hover {
	filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=30);
	opacity: 0.3;
}

section .inner {
	width: 900px;
	margin: 0 auto;
}

.secfb{display: flex;justify-content: space-between;}
.secfb .info-fb{width: 39%;}
.secfb .bnrright{width: 60%;}
.secfb .bnrright img{max-width: 100%;}


section h2 {
	text-align: center;
}
section h2.h2_txt {
}
section h2.h2_txt .h2_txt_in {
	font-size: 19px;
	font-weight: bold;
	letter-spacing: 0.5em;
	text-indent: 0.5em;
	color: #00607E;
	position: relative;
	display: inline-block;
	padding-left: 24px;
	padding-right: 24px;
}
section h2.h2_txt .h2_txt_in::before,
section h2.h2_txt .h2_txt_in::after {
	display: block;
	content: "";
	position: absolute;
	width: 22px;
	height: 22px;
	background-image: url("../images/head-side.png");
	top: -2px;
	bottom: 0;
	margin: auto;
}
section h2.h2_txt .h2_txt_in::before {
	left: 0;
}
section h2.h2_txt .h2_txt_in::after {
	right: 0;
}

section .pagetop {
	text-align: right;
	margin: 10px 0;
}
section .pagetop a img:hover {
	filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
	opacity: 1;
}

#sec01 h2 {
	margin: 45px 0 25px;
}
/*#sec01 .left {
	float: left;
}*/
/*#sec01 .right {
	float: right;
}*/

#sec02 h2 {
	margin: 25px 0 25px;
}
#sec02 .layout01 {
	padding: 30px 48px;
	background-color: #F0F7FC;
	margin-bottom: 20px;
}
#sec02 .layout01 .left {
	float: left;
	width: 300px;
}
#sec02 .layout01 .right {
	margin-left: 330px;
}
#sec02 .layout01 .right h3 {
	margin: 20px 0;
}
#sec02 .layout01 .right p {
	font-size: 14px;
	font-weight: bold;
	line-height: 2;
	letter-spacing: 2px;
}
#sec02 .layout02 {
	padding: 30px 48px;
	background-color: #F0F7FC;
	margin-bottom: 20px;
}
#sec02 .layout02 .clearfix {
	width: 700px;
	margin: 0 auto;
}
#sec02 .layout02 h3 {
	text-align: center;
}
#sec02 .layout02 dl {
	overflow: hidden;
	line-height: 2;
	font-size: 13px;
}
#sec02 .layout02 dl dt {
	width: 1.5em;
	float: left;
}
#sec02 .layout02 dl dd {
	margin-left: 1.5em;
}
#sec02 .layout02 .left {
	float: left;
	width: 48%;
}
#sec02 .layout02 .right {
	float: right;
	width: 48%;
}
#sec02 .layout03 {
	padding: 30px 48px;
	background-color: #F0F7FC;
	margin-bottom: 20px;
}
#sec02 .layout03 .clearfix {
	width: 670px;
	margin: 0 auto;
}
#sec02 .layout03 h3 {
	text-align: center;
	margin-bottom: 20px;
}
#sec02 .layout03 h4 {
	font-size: 22px;
}
#sec02 .layout03 h4 span {
	font-size: 14px;
	margin-right: 20px;
}
#sec02 .layout03 .left {
	float: left;
	width: 42%;
	letter-spacing: 2px;
}
#sec02 .layout03 .left dl {
	overflow: hidden;
	line-height: 2;
	font-size: 13px;
}
#sec02 .layout03 .left dl dt {
	width: 4em;
	float: left;
}
#sec02 .layout03 .left dl dd {
	margin-left: 5em;
}
#sec02 .layout03 .right {
	float: right;
	width: 54%;
	letter-spacing: 2px;
}
#sec02 .layout03 .right dl {
	overflow: hidden;
	line-height: 2;
	font-size: 13px;
}
#sec02 .layout03 .right dl dt {
	width: 6em;
	float: left;
}
#sec02 .layout03 .right dl dd {
	margin-left: 7em;
}

#sec03 h2 {
	margin: 25px 0 25px;
}
#sec03 table {
	border-collapse: collapse;
	width: 100%;
}
#sec03 table tr th {
	font-weight: bold;
	padding: 7px 30px;
	text-align: left;
	background-color: #F0F7FC;
	border-bottom: 1px solid #fff;
}
#sec03 table tr th.cellC {
	text-align: center;
}
#sec03 table tr th.cellD {
	text-align: center;
}
#sec03 table tr td {
	padding: 7px 30px;
	text-align: left;
	background-color: #F0F7FC;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
}
#sec03 table tr td.cellC {
	text-align: center;
}
#sec03 table tr td.cellD {
	text-align: center;
}

#sec04 h2 {
	margin: 25px 0 25px;
}
#sec04 table {
	border-collapse: collapse;
	width: 100%;
}
#sec04 table tr th {
	font-weight: bold;
	padding: 7px 0px;
	text-align: left;
	border-bottom: 1px solid #fff;
}
#sec04 table tr th.cellC {
	text-align: center;
}
#sec04 table tr th.cellD {
	text-align: center;
}
#sec04 table tr td {
	padding: 7px 0px;
	text-align: left;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
}
#sec04 table tr td.cellC {
	text-align: center;
}
#sec04 table tr td.cellD {
	text-align: center;
}

#sec05 h2 {
	margin: 25px 0 25px;
}
#sec05 .layout01 ul {
	overflow: hidden;
	margin-right: -20px;
}
#sec05 .layout01 ul li {
	width: 440px;
	padding: 18px 20px;
	background-color: #F0F7FC;
	float: left;
	margin-right: 20px;
	margin-bottom: 20px;
}
#sec05 .layout01 ul li .pic {
	float: left;
	margin-right: 20px;
}
#sec05 .layout01 ul li .text .stitle {
	margin: 10px 0;
}

#sec06 h2 {
	margin: 25px 0 25px;
}
#sec06 table {
	border-collapse: collapse;
	width: 100%;
}
#sec06 table tr th {
	font-weight: bold;
	padding: 7px 30px;
	text-align: left;
	background-color: #F0F7FC;
	border-bottom: 1px solid #fff;
}
#sec06 table tr th.cellA {
	text-align: right;
	width: 200px;
}
#sec06 table tr th.cellB {
	text-align: center;
}
#sec06 table tr td {
	padding: 7px 30px;
	text-align: left;
	background-color: #F0F7FC;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
}
#sec06 table tr td.cellA {
	text-align: right;
	width: 200px;
}
#sec06 table tr td.cellB {
	text-align: left;
}

#sec07 h2 {
	margin: 25px 0 25px;
}
#sec07 .layout01 {
	width: 800px;
	margin: 0 auto;
}
#sec07 .layout01 ul {
	overflow: hidden;
	margin-right: -70px;
}
#sec07 .layout01 ul li {
	width: 220px;
	height: 285px;
	float: left;
	margin-right: 70px;
	margin-bottom: 25px;
	position: relative;
}
#sec07 .layout01 ul li .text {
	margin-top: 170px;
	text-align: center;
}
#sec07 .layout01 ul li .text .stitle {
	margin: 10px 0;
	font-weight: bold;
}
#sec07 .layout01 ul li .text .price {
	text-align: right;
	margin-right: 50px;
}
#sec07 .layout01 ul li.p01 {
	background: url(../images/pic_book01.png) no-repeat left top;
}
#sec07 .layout01 ul li.p02 {
	background: url(../images/pic_book02.png) no-repeat left top;
}
#sec07 .layout01 ul li.p03 {
	background: url(../images/pic_book03.png) no-repeat left top;
}
#sec07 .layout01 ul li.p04 {
	background: url(../images/pic_book04.png) no-repeat left top;
}
#sec07 .layout01 ul li.p05 {
	background: url(../images/pic_book05.png) no-repeat left top;
}
#sec07 .layout01 ul li.p06 {
	background: url(../images/pic_book06.png) no-repeat left top;
}
#sec07 .caption {
	text-align: center;
}

#footer {
	background-color: #D9EBF9;
	text-align: center;
	padding: 30px 0;
}

/* ==========================================================================
	
  追加CSS
   
   ========================================================================== */
.info-fb {
	margin-right: 13px;
}

.info-img {
	margin: 0 13px;
}

.info-slo {
	margin-left: 13px;
}