@charset "utf-8";

/* -----------------------------------------------
 * style.css
 * LastUpdate : 18/6/11
----------------------------------------------- */
@import url('https://fonts.googleapis.com/css?family=Montserrat:400,800');
.font {
  font-family: 'Montserrat', sans-serif;
}
/* RESET
----------------------------------------------------------------------------------------------------*/
a,abbr,acronym,address,applet,article,aside,audio,b,big,blockquote,body,caption,canvas,center,cite,code,dd,del,details,dfn,dialog,div,dl,dt,em,embed,fieldset,figcaption,figure,form,footer,header,hgroup,h1,h2,h3,h4,h5,h6,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,output,p,pre,q,ruby,s,samp,section,main,small,span,strike,strong,sub,summary,sup,tt,table,tbody,tfoot,thead,time,tr,th,td,u,ul,var,video{font-family:inherit;font-size:100%;font-weight:inherit;font-style:inherit;vertical-align:baseline;white-space:normal;margin:0;padding:0;border:0;outline:0;background:transparent;line-height:1.6;text-align:left}textarea{font-family:inherit;font-size:100%;font-weight:inherit;font-style:inherit;vertical-align:baseline;margin:0;padding:0;border:0;outline:0;background:transparent;line-height:1.6;text-align:left}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section,main{display:block}ol,ul{list-style:none}blockquote,q{quotes:none}table{border-collapse:collapse;border-spacing:0}
.clr{zoom:1;display:inline-table}.clr:after{content:".";display:block;height:0;clear:both;visibility:hidden;font-size:0;line-height:0}* html .clr{height:1%;display:inline-table;display:block;height:1%}.clr{display:block}
*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;*behavior:url(/scripts/boxsizing.htc)}.container{margin:0 auto}.clr:after,.col:after,.container:after,.group:after,.row:after{content:"";display:table;clear:both}.row{padding-bottom:0}.col{display:block;float:left;width:100%}@media (min-width:769px),print{.gutters .col{margin-left:2%}.gutters .col:first-child{margin-left:0}.gutters .colR:first-child{margin-right:0}.sp{display:none}}@media(max-width:768px){.sp_none{display:none !important;}}
/* ----------------------------------------------

 * アンカータグの設定

---------------------------------------------- */
a {
	display: block;
	outline:none;
	color: #cc2929;
	cursor: pointer;
	text-decoration: none;
	-webkit-transition: all .5s ease;
    -moz-transition: all .5s ease;
    -o-transition: all .5s ease;
    transition: all .5s ease;
}
input[type="submit"],
input[type="button"],
button {
	font-family: 'Noto Sans', 'Noto Sans CJK JP', 'Noto Sans CJK JP Subset', sans-serif;
	font-weight: 400;
	border-radius: 0;
	-webkit-box-sizing: content-box;
	-webkit-appearance: button;
	appearance: button;
	box-sizing: border-box;
	cursor: pointer;
	outline: none;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
	display: none;
}
input[type="button"],
input[type="text"],
input[type="submit"],
input[type="image"],
textarea {
   -webkit-appearance: none;
   border-radius: 0;
}
select {
	font-family: 'Noto Sans', 'Noto Sans CJK JP', 'Noto Sans CJK JP Subset', sans-serif;
    -webkit-appearance: none;
	 -moz-appearance: none;
    appearance: none;
}
select::-ms-expand{
	font-family: 'Noto Sans', 'Noto Sans CJK JP', 'Noto Sans CJK JP Subset', sans-serif;
	display: none;
}
/* ----------------------------------------------

 * 要素を左右中央寄せ

---------------------------------------------- */
.taC {
  text-align: center !important;
}

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

.taL {
  text-align: left !important;
}

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

　   CONTENTS

--------------------------------------------------------------------------------------------- */
body {
	font-family: 'Noto Sans', 'Noto Sans CJK JP', 'Noto Sans CJK JP Subset', sans-serif;
	font-weight: 500;
	font-size: 16px;
	color: #cc2929;
	margin: 0 auto;
	padding: 0;
	line-height: 1.8;
	-webkit-text-size-adjust: 100%;
}
p,table,th,td,ul,li,select,input,textarea {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.8;
}
button {
	font-family: 'Noto Sans', 'Noto Sans CJK JP', 'Noto Sans CJK JP Subset', sans-serif;
}
h2 {
	font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
	text-align: center;
	font-size: 30px;
	margin-bottom: 75px;
	line-height: 1.4;
	letter-spacing: 2px;
}
h2 img {
	margin-bottom: 10px;
}
img {
    max-width: 100%;
    height: auto;
    width :auto;
	vertical-align: bottom;
	border: none;
}
section {
	padding: 50px 0;
}
.inner {
	max-width: 1360px;
	margin: 0 auto;
	padding: 0 10px;
}
.parenthesis {
	position: relative;
	padding: 15px 30px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.parenthesis::before,
.parenthesis::after {
	position: absolute;
	content: '';
	width: 40px;
	height: 40px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.parenthesis::before {
	top: 0;
	left: 0;
	border-top: 3px solid #ff4d4d;
	border-left: 3px solid #ff4d4d;
}
.parenthesis::after {
	bottom: 0;
	right: 0;
	border-bottom: 3px solid #ff4d4d;
	border-right: 3px solid #ff4d4d;
}
.pc {
	display: block;
}
.sp {
	display: none;
}
@media only screen and ( max-width : 768px ) {
	body::before{
		content: "";
		display: block;
		width: 0;
		height: 100%;
		background: rgba(255, 128, 128, 0);
		z-index: 60;
		position: fixed;
		left: 0;
		top: 0;
		transition: .3s all;
	}
	body.clicked::before {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		background: rgba(255, 128, 128, 0.5);
		z-index: 60;
		position: fixed;
		left: 0;
		top: 0;
	}
	h2 {
		font-size: 24px;
		margin-bottom: 30px;
	}
	.sp_box {
		margin-bottom: 30px;
	}
}
@media only screen and ( max-width : 480px ) {
	body,p,table,th,td,ul,li,select,input,textarea {
		font-size: 13px;
	}
	.pc {
		display: none;
	}
	.sp {
		display: block;
	}
}
@media only screen and ( max-width : 400px ) {
	body,p,table,th,td,ul,li,select,input,textarea {
		font-size: 3.7vw;
	}
}
/*----------------------------------------------------------------------------------

    header

-----------------------------------------------------------------------------------*/
header {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 999;
	background: #fff;
	box-shadow: 0 0 10px rgba(0,0,0,0.4);
}
header .header_box {

	display: flex;
	align-items: center;
	justify-content: space-between;
	margin: 0 auto;
	padding: 0 10px;
	height: 80px;
}
header .h_logo {
	width: 250px;
}
header .h_logo p {
	border: 1px solid #8B8B8B;
	color: #8B8B8B;
	border-radius: 10px;
	text-align: center;
	font-size: 12px;
	margin-top: 5px;
}
header .header_box ul {
	display: flex;
	text-align: center;
	align-items: center;
}
header li {
	margin-right: 30px;
}
header li a:hover {
	color: #ccc;
}
header li:last-child {
	border: 2px solid #ff8080;
	background: #ff8080;
	padding: 10px 20px;
	color: #fff;
	margin-right: 0;
	letter-spacing: 2px;
	transition: .5s;
}
header li:last-child:hover {
	background: #fff;
	color: #ff8080;
}
@media only screen and ( max-width : 1150px ) {
	header .header_box ul li a {
		font-size: 12px;
	}
	header .h_logo {
		width: 23%;
	}
}
@media only screen and ( max-width : 768px ) {
	header{
		box-sizing: border-box;
	}
	header .header_box {
	    height: 60px;
	}
	header .h_logo{
		width: 150px;
		display: block;
	}
	header .h_logo p {
		font-size: 1.5vw;
	}
	header .header_box nav{
		position: fixed;
		top: 60px;
		right: -100%;
		width: 80%;
		background: #fff;
		z-index: 999;
		transition: .3s all;
	}
	header .header_box nav.clicked{
		position: fixed;
		top: 60px;
		right: 0%;
		width: 80%;
		background: #fff;
		z-index: 999;
		box-shadow: -2px 2px 3px rgba(0, 0, 0, 0.2);
	}
	header .header_box ul{
		display: block;
		align-items: center;
		text-align: left;
	}
	header .header_box ul li{
		margin: 0 0 0;
		padding: 0 20px;
		border-bottom: solid 1px #445d6b;
	}
	header .header_box ul li a span{
		font-size: 14px;
		letter-spacing: 0.05em;
		margin-right: 15px;
	}
	header .header_box ul li a{
		letter-spacing: 2px;
		display: block;
		padding: 15px 0;
	}
	header .header_box ul li:last-child {
		background: #ff8080;
		color: #fff;
		border: 1px solid #ff8080;
		transition: all .3s;
		margin: 10px;
		text-align: center;
		padding: 10px 0;
	}
	header .header_box ul li:last-child a{
		color: #fff;
		display: block;
		padding: 6px 40px;
	}
	header .header_box ul li:last-child a span{
		display: block;
		margin: 0 0 5px 0;
	}
	header .header_box ul li:last-child:hover a{
		background: #fff;
		color: #ff8080;
	}
	#sp-menu {
		width: 30px;
		height: 18px;
		position: absolute;
		right: 20px;
		top: 50%;
		z-index: 999999;
		margin: -9px 0 0;
		display: block;
		cursor: pointer;
	}
	#sp-menu span {
		position: absolute;
		width: 100%;
		height: 2px;
		border-radius: 10px;
		background-size: 100% 100%;
		-webkit-transition: 0.3s ease-in-out;
		-moz-transition: 0.3s ease-in-out;
		-o-transition: 0.3s ease-in-out;
		transition: 0.3s ease-in-out;
		left: 0;
		background: #000016;
	}
	#sp-menu span.top-border {
		top: -2px;
	}
	#sp-menu span.middle-border {
		top: 50%;
		margin: -2px 0 0;
	}
	#sp-menu span.bottom-border {
		bottom: 0;
	}
	#sp-menu.clicked span.top-border {
		transform: rotate(-45deg);
		top: 8px;
	}
	#sp-menu.clicked span.middle-border {
		width: 0;
	}
	#sp-menu.clicked span.bottom-border {
		transform: rotate(45deg);
		bottom: 8px;
	}	
}

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

　   FOOTER

--------------------------------------------------------------------------------------------- */
#footer {
	background: #333333;
	color: #fff;
	padding: 30px 0;
	font-size: 14px;
}
#footer a {
	color: #fff;
	text-align: center;
}
#footer .txt {
	text-align: center;
	margin-bottom: 20px;
}
#footer .copy {
	font-size: 12px;
	letter-spacing: 1px;
	font-weight: 100;
}
/* ---------------------------------------------------------------------------------------------

　   FLEX

--------------------------------------------------------------------------------------------- */
.flexbox {
  -js-display : flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}
.space-between {
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.center {
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
}
.flex-end {
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}
.align-center {
  -webkit-box-align:center;
  -ms-flex-align:center;
  -webkit-align-items:center;
  align-items: center;
}
.align-start {
  -webkit-align-items:flex-start;
  align-items: flex-start;
}
.align-stretch {
  -webkit-align-items:stretch;
  align-items: stretch;
 }

@media only screen and ( max-width : 768px ) {
  .flexbox_sp {
    -js-display : flex;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
@media print, screen and ( min-width : 769px ) {
  .flexbox_pc {
    -js-display : flex;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .flexbox_pc .span_4 {
    width: 31%;
  }
  .flex_direction_pc {
    flex-direction: row-reverse;
  }
}
/* ---------------------------------------------------------------------------------------------

　   PAGE TOP

--------------------------------------------------------------------------------------------- */
.back-top {
	display: none;
	position: fixed;
	bottom: 5%;
	right: 35px;
	z-index: 10;
	border: 1px solid #333333;
	width: 40px;
	height: 40px;
	text-align: center;
	line-height: 40px;
	background: #fff;
}
.back-top:hover {
	background-position: right center; 
	filter: alpha(opacity=100);
	-moz-opacity:1.0;
	opacity:1.0;
}
.back-top::before {
	font-family: 'Material Icons';
	content: "expand_less";
	font-size: 20px;
	color: #333333;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings: 'liga';
}
@media only screen and ( max-width : 768px ) {
	.back-top {
		right: 10px;
		width: 30px;
		height: 30px;
		line-height: 30px;
	}
}