@charset "UTF-8";

.cl {
  display: inline-block;
  min-height: 1%;
  display: block;
  *zoom: 1;
}

.cl:after {
  content: " ";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  font-size: 0;
}

* html .cl {
  height: 1%;
}

/*----------------------------------
Mixins Style
----------------------------------*/
/*----------------------------------
Reset Style
----------------------------------*/
dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, figure, input, textarea, p, blockquote {
  margin: 0;
  padding: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

address, caption, cite, code, dfn, em, th, var {
  font-style: normal;
  font-weight: normal;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}

fieldset, img {
  border: 0;
  vertical-align: top;
}

ol, ul {
  list-style: none;
}

q:before, q:after {
  content: " ";
}

abbr, acronym {
  border: 0;
}

li img,
dt img,
dd img {
  vertical-align: top;
}

article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary {
  display: block;
}

select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 4px;
  border: 0;
  margin: 0;
  padding: 0;
  background: none transparent;
  vertical-align: middle;
  font-size: inherit;
  color: #251b1e;
  box-sizing: content-box;
}

select::-ms-expand {
  display: none;
}

/*----------------------------------
Base Style
----------------------------------*/
* {
  box-sizing: border-box;
}

body {
  position: static;
  margin: 0;
  padding: 0;
  text-align: center;
  font-family: "メイリオ", Meiryo, "Meiryo UI", "游ゴシック" ,"游ゴシック体", YuGothic, "YuGothic M", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: 12px;
  font-size: 1.0rem;
  line-height: 1.5;
  -webkit-tap-highlight-color: transparent;
}

#wrapper {
  min-width:1280px;
}
@media screen and (max-width: 767px){
	body {
		-webkit-text-size-adjust: 100%;
		-webkit-font-smoothing: antialiased;
	}
	#wrapper {
		min-width:auto;
	}
}
/* Image Style */
img {
  max-width: 100%;
  height: auto;
}

a {
  color:#0068B6;
  transition: all .4s;
  text-decoration:none;
}

a:visited {
  color: #0068B6;
}

a:hover {
  color: #0068B6;
  text-decoration: underline;
  cursor: pointer;
}

a:active {
  color: #251b1e;
  text-decoration: none;
}

a:active, a:focus {
  /*outline: none;*/
}

/*----------------------------------
Header Style
----------------------------------*/
.reader {
  font-size: 1px !important;
  position: absolute;
  height: 1px;
  width: 1px;
  text-indent: -9999px;
  overflow: hidden;
}
#main_header {
  border-top:#FF9100 10px solid;
  border-bottom:#FF9100 2px solid;
  background:#FFFFE1;
  position: relative;
  overflow:hidden;
}

#main_header h1 {
  position:absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
#main_header h1 a {
  display: inline-block;
  height:140px;
  overflow: hidden;
}
#main_header #main_navi {
  position: relative;
  left: 50%;
  float: left;
  pointer-events: none;
}
#main_header #main_navi li {
  position: relative;
  left: -50%;
  float:left;
  pointer-events: auto;
}

#main_header #main_navi li img {
  margin: 0.6em 0;
}
#main_header #main_navi li:nth-of-type(3) {
  margin-right:312px;
}
#main_header #main_navi li:nth-of-type(4) img {
  margin: 0;
}

#main_header #main_navi li a {
  display:block;
  color:#FF6500;
  width:210px;
  height:140px;
  font-size: 80%;
  line-height: 1.2;
}
#main_header #main_navi li a span {
  font-weight: bold;
  font-size: 125%;
  display: block;
}
#main_header #main_navi li a.current,
#main_header #main_navi li a:hover,
#main_header h1 a:hover {
  text-decoration:none;
  background:#FF6500;
  color:#FFFFFF;
}
#main_header #main_navi #main_logo {
  width:312px;
}

#header_spmenu {
  display: none;
  position: absolute;
  top: 20px;
  right: 15px;
  text-align: center;
  line-height: 1;
  z-index:200;
}

#header_spmenu small {
  display: block;
  font-size: 10px;
  font-size: 1rem;
  margin-top: 3px;
}
#header_spmenu a {
  text-decoration: none;
}
#header_spmenu a ul {
  display: inline-block;
  position: relative;
  width: 40px;
  height: 35px;
}
#header_spmenu a ul li {
  position: absolute;
  width: 100%;
  height: 6px;
  background: #FF6500;
  transition: all .4s;
  border-radius: 3px;
}
#header_spmenu a ul li:nth-child(1) {
  top: 0;
}
#header_spmenu a ul li:nth-child(2) {
  top: 50%;
  -ms-transform: translateY(-50%);
      transform: translateY(-50%);
}
#header_spmenu a ul li:nth-child(3) {
  bottom: 0;
}

#header_spmenu a.is_open ul li:nth-child(1) {
  -ms-transform: translateY(20px) rotate(-45deg);
      transform: translateY(20px) rotate(-45deg);
}
#header_spmenu a.is_open ul li:nth-child(2) {
  opacity: 0;
}
#header_spmenu a.is_open ul li:nth-child(3) {
  -ms-transform: translateY(-8px) rotate(45deg);
      transform: translateY(-8px) rotate(45deg);
}
#header_spmenu a span {
  display:block;
  color:#FF6500;
  font-size:80%;
  padding-top:5px;
}

@media screen and (max-width: 767px){
  #main_header h1 a {
	height: auto;
	text-align: left;
  }
  #main_header #main_navi {
	display:none;
	left:0;
	width:100%;
    float: none;
  }
  #main_header #main_navi li {
    position:static;
	margin:0;  
    float: none;
	width:100%;
	border-bottom:#FFFFE1 1px solid;
  }
  #main_header #main_navi li img {
    display:none;
  }
  #main_header #main_navi li a {
    height:auto;
	width:auto;
	padding:10px;
	background:#FF6500;
    color:#FFFFFF;
	text-align:left;
  }
	
  #main_header h1 a:hover {
	background: none;
  }
  #main_header #main_navi li a.current,
  #main_header #main_navi li a:hover {
	background:#FF6500;
  }
  #main_header #main_navi li a span {
    display: inline;
  }
  #main_header {
    border:none;
	background:none;
  }
  
  #main_header h1 {
    position:inherit;
	min-height:80px;
  }
  
  #main_header h1 a {
    width: 100%;
  }
  #main_header h1 img {
	width:50%;
	min-width:220px;
  }
  #header_spmenu {
    display:block;
  }
  
  #main_header.sub_page {
    background:#FF9100;
	text-align:left;
  }
  #main_header.sub_page h1 {
    width:40%;
	padding:10px;
  }
  #main_header.sub_page h1 img {
    width:100%;
	min-width:auto;
  }
  .sub_page #main_navi {
	border-top:#FFFFE1 1px solid;
  }
  .sub_page #header_spmenu {
    top: 15px;
  }
  .sub_page #header_spmenu a ul li {
    background: #FFFFFF;
  }
  .sub_page #header_spmenu a span {
    color: #FFFFFF;
  }
}

/*----------------------------------
Footer Style
----------------------------------*/
#main_footer {
  font-size:82%;
}
#main_footer p {
  width:1152px;
  text-align:right;
  margin:0 auto;
}
#main_footer .copy {
  width:100%;
  text-align:center;
  background:#FF9100;
  color:#FFFFFF;
  padding:10px;
  margin-top:10px;
}
	
/*----------------------------------
Content Style
----------------------------------*/
body.is-fix {
  position: fixed;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
#content_wrapper {
  width:1152px;
  margin:auto;
  padding:50px 0 0;
}
.sp_only {
  display:none;
}
.sp_br{
  display:none; 
}
.no_disp {
  display: none;
}
.page_navi {
  width:1152px;
  margin:20px auto 40px;
  position: relative; 
  overflow: hidden;
}
.page_navi p {
	text-align:right;
}
.page_navi ul {
  position: relative;
  left: 50%;
  float: left;
}
.page_navi li {
  position: relative;
  left: -50%;
  float: left;
}
.page_navi li a {
  font-size:150%;
  font-weight:bold;
  color:#000000;
  padding:20px 30px 0;
  display:inline-block;
}
.page_navi li:first-child a {
  background:url(../img/navi_prev.png) no-repeat left 25px;
  background-size: 22px;
}
.page_navi li:last-child a {
  background:url(../img/navi_next.png) no-repeat right 25px;
  background-size: 22px;
}
.page_navi li:first-child:after {
  content: '';
  display: inline-block;
  position:absolute;
  top:28px;
  right:-8px;
  width: 16px;
  height: 16px;
  -webkit-border-radius: 8px;
  -moz-border-radius: 8px;
  border-radius: 8px;
  background-color: #FFCB98;
}
.page_navi a:hover,
.page_navi li a:hover {
  filter:alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
  -moz-opacity:0.7;
  -khtml-opacity: 0.7;
  opacity:0.7;
}

/*----------------------------------
Overlay
----------------------------------*/
#overlay{
	display: none;
	width: 100%;
	height:100%;
	text-align: center;
	position: fixed;
	top: 0;
	z-index: 500;
	background: rgba(0,0,0,0.7);
}
/*----------------------------------
modal
----------------------------------*/
.modal_win {
	display: none;
	position:absolute;
	top:0;
	left: 0;
	right: 0;
	bottom: 0;
	margin:auto;
	width:800px;
	z-index:10000;
	text-align: left;
}
.modal_win .inner {
	font-size: 140%;
	background:#FFFFFF;
	padding: 20px;
}
.modal_win .close {
	text-align: right;
	padding-top: 10px;
}
.modal_win .close a {
	font-size: 120%;
	font-weight: bold;
	color: #FFFFFF;
	position: relative;
	display: inline-block;
	padding-right: 30px;
}

.modal_win .close a:first-child:after {
	content: '×';
	display: inline-block;
	position:absolute;
	top: 0;
	right: 0;
	width: 24px;
	height: 24px;
	-webkit-border-radius: 12px;
	-moz-border-radius: 12px;
	border-radius: 12px;
	background-color: #FFFFFF;
	color: #000000;
	text-align: center;
	line-height: 1.2;
	font-size: 120%;
}


.modal_win dt {
	font-weight: bold;
	margin-bottom: 10px;
	border-bottom: #00A73C 2px solid;
	font-size: 120%;
}
.modal_win dd {
	width: 460px;
	float: left;
}
.modal_win .img {
	width: 288px;
	float: right;
}
@media screen and (max-width: 767px){
  .sp_only {
    display:inherit;
  }
  .sp_br {
    display:block;
  }
  .pc_only {
	display:none;
  }
  #content_wrapper {
    width:auto;
	padding:10px 10px;
	margin:0;
  }
  .page_navi {
    width:auto;
	padding:10px;
	position:static;
  }
  .page_navi p {
    text-align:right;
  }
  .page_navi p a {
    position:absolute;
	text-align:center;
	width:81px;
	top:0;
	right:10px;
  }
  .page_navi ul {
    margin:60px 0 0 0;
  }
	
  .page_navi a:hover,
  .page_navi li a:hover {
	filter:alpha(opacity=100);
	-ms-filter: "alpha(opacity=100)";
	-moz-opacity:1;
	-khtml-opacity: 1;
	opacity:1;
  }
  .modal_win {
    width: 90%;
  }
  .modal_win dd {
	width: auto;
	float: none;
  }
  .modal_win .img {
	width: 100%;
    text-align: center;
  }
  #main_footer p {
    width:auto;
	text-align:center;
  }
}

/*--------- balloon_box ----------*/
.balloon_box p {
	float: left;
	width: 570px;
	padding: 15px;
	background: #FFFFFF;
	text-align: left;
	font-size: 120%;
	font-weight: bold;
	line-height: 1.2;
	color: #184C29;
	border: #184C29 4px solid;
	position: relative;
    border-radius: 20px;   
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
	text-align: justify;
}
.balloon_box p:before{
	content: '';
	position: absolute;
	display: block;
	width: 0;
	height: 0;
	right: -60px;
	top: 30%;
	border: 20px solid transparent;
	border-left: 40px solid #184C29;
}
.balloon_box p:after{
	content: '';
	position: absolute;
	display: block;
	width: 0;
	height: 0;
	right: -52px;
	top: 30%;
	border: 20px solid transparent;
	border-left: 40px solid #FFFFFF;
}
.balloon_box img {
	float: right;
}
.balloon_box.type02 p {
	width: 71%;
}
.balloon_box.type02 img {
	width: 21%;
}
.balloon_box.type03 {
	text-align: center;
}
.balloon_box.type03 p {
	width: 100%;
	margin-bottom: 10px;
}
.balloon_box.type03 p:before{
	left: 50%;
	top: 100%;
	border: 20px solid transparent;
	border-top: 40px solid #184C29;
}
.balloon_box.type03 p:after{
	left: 50%;
	top : -webkit-calc(100% - 8px) ;
	top : calc(100% - 8px) ;
	border: 20px solid transparent;
	border-top: 40px solid #FFFFFF;
}
.balloon_box.type03 img {
	float: none;
	margin-top: 20px;
}
.balloon_box.type04 p {
	float: right;
	width: 68%;
}
.balloon_box.type04 img {
	float: left;
	width: 25%;
}
.balloon_box.type04 p:before{
	right : 100%;
	border: 20px solid transparent;
	border-right: 40px solid #184C29;
}
.balloon_box.type04 p:after{
	right : -webkit-calc(100% - 8px) ;
	right : calc(100% - 8px) ;
	border: 20px solid transparent;
	border-right: 40px solid #FFFFFF;
}
.balloon_box.type05 p {
	width: 73%;
}
.balloon_box.type05 img {
	width: 20%;
}

.balloon_box.type06 p {
	width: 100%;
	margin-bottom: 40px;
}
.balloon_box.type06 p:before{
	left : -webkit-calc(50% - 10px) ;
	left : calc(50% - 10px) ;
	top: 100%;
	border: 20px solid transparent;
	border-top: 40px solid #184C29;
}
.balloon_box.type06 p:after{
	left : -webkit-calc(50% - 10px) ;
	left : calc(50% - 10px) ;
	top : -webkit-calc(100% - 8px) ;
	top : calc(100% - 8px) ;
	border: 20px solid transparent;
	border-top: 40px solid #FFFFFF;
}
.balloon_box.type07 p {
	width: 78%;
}
.balloon_box.type07 img {
	width: 15%;
}
@media screen and (max-width: 767px){
	.balloon_box p {
		width: 100%!important;
		margin: 0 0 20px 0;
		font-size: 110%;
	}
	.balloon_box img {
		float: none!important;
		width: auto!important;
	}
	.balloon_box p:before{
		right: 50%;
		top: 100%;
		border: 15px solid transparent;
		border-top: 20px solid #184C29;
	}
	.balloon_box p:after{
		right: 50%;
		top : -webkit-calc(100% - 8px) ;
		top : calc(100% - 8px) ;
		border: 15px solid transparent;
		border-top: 20px solid #FFFFFF;
	}
	.balloon_box.type03,
	.balloon_box.type04 {
		text-align: center;
	}
	.balloon_box.type03 img {
		margin-top: 20px;
	}
	.balloon_box.type04 p:before{
		right: 50%;
		top: 100%;
		border: 20px solid transparent;
		border-top: 40px solid #184C29;
	}
	.balloon_box.type04 p:after{
		right: 50%;
		top : -webkit-calc(100% - 8px) ;
		top : calc(100% - 8px) ;
		border: 20px solid transparent;
		border-top: 40px solid #FFFFFF;
	}
}