@charset "UTF-8";

body {
	text-align:center;
	font-family: source-han-sans-japanese,"Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
	font-weight: 400;	/* Normal/Bold 使用可 */
	font-style: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-size: 17px;
	letter-spacing: .07em;
	line-height: 1.7em;
	padding: 0;
	margin: 0;
	background:#b1dab8;
	color: #000000;
	-webkit-text-size-adjust: 100%;
}

div,
dl,dt,dd,ul,ol,li,
h1,h2,h3,h4,h5,h6,
pre,form,fildset,p,blockquote{
	margin:0;
	padding:0;
	border:0;
	font-size:100%;
	font-style:normal;
}

img{
    max-width: 100%;
    height: auto;
    width: auto\9; /* ie8 */
	border-top-style: none;
	border-right-style: none;
	border-bottom-style: none;
	border-left-style: none;
	vertical-align: top;
}
table {
    font-size:inherit;
    font:100%;
	border-collapse: collapse;
}

address{
	font-style:normal;
}

ul{
	list-style:none;
}
ul img{
	vertical-align: top;
	margin:0;
}

a{
	color:#000000;
	text-decoration:none;
	outline:0;
	-webkit-transition: color 0.7s, background-color 1.0s;
	-moz-transition: color 0.7s, background-color 1.0s;
	transition: color 0.7s, background-color 1.0s;
}
a:hover{
	-webkit-transition: color 0.7s, background-color 0.4s;
	-moz-transition: color 0.7s, background-color 0.4s;
	transition: color 0.7s, background-color 0.4s;
}

.clearfix:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix {
  min-height: 1px;
}

* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}

/*<group=style>*/
.fw_bold{font-weight: bold;}
.fw_normal{font-weight: normal;}	
/*</group>*/

/*<group=text_align>*/
.txt_al_l{text-align:left;}
.txt_al_r{text-align:right;}
.txt_al_c{text-align:center;}	
/*</group>*/

/*<group=float>*/
.flt_l{float:left;}
.flt_r{float:right;}	
/*</group>*/

.blocklink,
.blocklink_out {
	cursor:pointer;
}

.red {
	color: #c1272d;
}

/* スマホで電話をかけるボタン：画像対応 */
.sp_tel_btn {
	position: relative;
}
.sp_tel_btn img {
	position: relative;
	z-index: 0;
}
.sp_tel_btn span,
.sp_tel_btn a {
	display: block;
}
.sp_tel_btn a {
	content: "";
	position: absolute;
	z-index: 1;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}

.ank_adjust {
    padding-top: 150px;
    margin-top: -150px;
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {	
/* スマホのときはビューポートを基準にサイズ調節する */
/* スマホ時：emまたは%で指定する */
/* スマホ以外でビューポート基準にするときは、その都度「vw」で指定する */
body {
	font-size: 2.5vw;
	letter-spacing: normal;
	line-height: 2em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 600px) {	
/* スマホのときはビューポートを基準にサイズ調節する */
/* スマホ時：emまたは%で指定する */
/* スマホ以外でビューポート基準にするときは、その都度「vw」で指定する */
body {
	font-size: 3.5vw;
	letter-spacing: normal;
	line-height: 2em;
}
}




/*
---------------------------------------------------------*/

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
}





/*共通
---------------------------------------------------------*/
.pagebody{
	overflow:hidden;
}
.w1100 {
	width: 94%;
	padding: 0 3%;
	max-width: 1100px;
	margin: 0 auto;
	text-align: left;
}
.w1250 {
	width: 94%;
	padding: 0 3%;
	max-width: 1250px;
	margin: 0 auto;
	text-align: left;
}
.mgn_b_120{
	margin-bottom:120px;
}

/*fade*/
.fade.anime{
	opacity: 0;
}
.fade.anime_on{
	opacity: 1;
    -webkit-transition: all 2s;
    -moz-transition: all 2s;
    transition: all 2s;
}

/*fade_up*/
.fade_up.anime{
	opacity: 0;
	-webkit-transform: translateY(100px);
	transform: translateY(100px);
}
.fade_up.anime_on{
	opacity: 1;
	-webkit-transform: translateY(0);
	transform: translateY(0);
    -webkit-transition: all 2s;
    -moz-transition: all 2s;
    transition: all 2s;
}


/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.mgn_b_120{
	margin-bottom:80px;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.mgn_b_120{
	margin-bottom:13%;
}
}





/* header
---------------------------------------------------------*/
#header{
	position:sticky;
  top: 0;
	background: #00848a;
	padding: 0 3%;
	z-index: 999;
}
#header .m_nav{
	max-width: 1335px;
	margin: 0 auto;
	display: table;
	width: 100%;
}
#header .m_nav .m_nav_logo{
	display: table-cell;
	vertical-align: middle;
	max-width: 90px;
	width: 20%;
	text-align: left;
	padding:5px 0;
}
#header .m_nav .m_nav_list{
	display: table-cell;
	vertical-align: middle;
	width: 80%;
	max-width: 1000px;
}
#header .m_nav .m_nav_list li{
	float: left;
	font-weight: bold;
	font-size:110%;
	letter-spacing: 0.2em;
	padding:2em 2em 2em 2em;
}
#header .m_nav .m_nav_list li a{
	display: block;
	color:#ffffff;
}
#header .m_nav .m_nav_list li:hover a{
	color:#FFE300;
}

/* PC調整
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 1200px) { 
#header .m_nav .m_nav_list li{
	font-size:1.7vw;
	letter-spacing: 0.1em;
}
#header .m_nav .m_nav_list li:last-child{
	padding-right: 0;}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
#header .m_nav .m_nav_logo{
	width: 10%;
}
#header .m_nav .m_nav_list{
	width: 80%;
	padding-left: 3%;
}
#header .m_nav .m_nav_list li{
	font-size:1.8vw;}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
#header{
	padding: 4% 2% 2% 2%;
}
#header .m_nav .m_nav_logo{
	width: 15%;
}
#header .m_nav .m_nav_list{
	width: 82%;
	padding-left: 5%;
}
#header .m_nav .m_nav_list li{
	font-size:3.5vw;
	letter-spacing: 0.05em;
	padding:0;
	padding-right: 1.3em;
	line-height: 1.5em;
	margin-bottom: 3%;
}
#header .m_nav .m_nav_list li:nth-child(4){
	padding-right: 0;
}
}







/* 
---------------------------------------------------------*/

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
}





/*pagebody
---------------------------------------------------------*/
#pagebody {
	overflow: hidden;
	max-height: 100%;
}







/* page_top
---------------------------------------------------------*/
#page_top {
	max-width: 140px;
	position:fixed;
	z-index:500;
	right:30px;
    transition: all .3s;
	-webkit-transform: translateY(0);
	transform: translateY(0);
	width: 13%;
}
#page_top:hover{
	-webkit-transform: translateY(-10px);
	transform: translateY(-10px);
}


/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
#page_top {
	right:20px;
	width: 10%;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
#page_top {
	right:2%;
	width: 18%;
}
}







/* 
---------------------------------------------------------*/

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) { 
}





/* PC
------------------------------------------*/
@media only screen and (min-width: 768px)  {
.tb_only{display:none !important;}
.sp_only{display:none !important;}
.sp_tb{display:none !important;}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.pc_only{display:none !important;}
.tb_only{display:inherit !important;}
.sp_only{display:none !important;}
.tb_pc{display:inherit !important;}
.sp_tb{display:inherit !important;}

/*body{background:#ccc;}*/
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.pc_only{display:none;}
.tb_only{display:none;}
.sp_only{display:inherit;}
.tb_pc{display:none;}
.sp_tb{display:inherit;}
}

/* Mobile (Landscape)
------------------------------------------*/
@media only screen and (min-width: 480px) and (max-width: 767px) {}
