@charset "utf-8";
@import "html5reset-1.6.1.css";
@import url('https://fonts.googleapis.com/css?family=M+PLUS+Rounded+1c:500&display=swap');
body {
	font-family: "Hiragino Kaku Gothic ProN", YuGothic,"Yu Gothic", Meiryo, sans-serif;
	color:#333;
	font-size: 16px;
	height: 100%;
	letter-spacing:0.1em;
	word-wrap: break-word;
	background-color: rgba(244,133,161,0.05);
}
html{
	height: 100%;
}
a{
	color:#333;
}
#wrapper{
  min-height: 100%;
	position: relative;
}
@media (min-width: 1024px) {
a:hover{
	transition: 0.5s;
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
}
}
@media (min-width: 768px) {
br.sp{
display: none;
}
}
@media (max-width: 767px) {
body {
	font-size: 14px;
}
br.pc{
display: none;
}
}
/*---------------------- Loading ------------------------*/
.loading {
width: 100%;
height: 100%;
background: rgba(255,255,255,1.0);
position: fixed;
top: 0;
left: 0;
z-index: 999999;
}
.loading img.loadingLogo {
position: absolute;
top: 50%;
left: 50%;
margin-top: -150px;
margin-left: -280px;
}
.loading img.loadingIcon {
position: absolute;
top: 50%;
left: 50%;
margin-top: -60px;
margin-left: -60px;
}
@media (max-width: 767px) {
.loading img.loadingLogo {
width:300px;
height: auto;
margin-top: -100px;
margin-left: -150px;
}
}
/*---------------------- Header ------------------------*/
@media (min-width: 768px) {
#header{
	border-top: 5px solid #f485a1;
	height:190px;
}
#header .logo{
	padding:16px 0 5px;
	text-align: center;
}
}
@media (max-width: 767px) {
#header .logo{
	padding:8px 0 0 50px;
	text-align: center;
	position:fixed;
	top:0;
	left:0;
	width:100%;
	box-sizing: border-box;
	height:60px;
	z-index: 99998;
	background-color: #FFF;
	box-shadow: 0 0 10px 5px rgba(0,0,0,0.2);
}
#header .logo img{
	width: auto;
	height:44px;
}
}
@media (max-width: 320px) {
#header .logo{
	padding:10px 0 0 50px;
}
#header .logo img{
	height:40px;
}
}
/*---------------------- Global Navi Button ------------------------*/
@media (min-width: 768px) {
#gNaviBtn {
display: none;
}
}
@media (max-width: 767px) {
#gNaviBtn {
    display: block;
    top: 0;
		left:0;
    width: 60px;
    height: 60px;
    cursor: pointer;
    z-index: 99999;
    background-color:#f485a1;
    text-align: center;
		position: fixed;
		transition: all 0.5s ease-in-out 0.0s;
}
#gNaviBtn span {
    display: block;
    position: absolute;
    width: 30px;
    border-bottom: solid 2px #FFFFFF;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    left: 15px;
		letter-spacing: normal;
}
#gNaviBtn span:nth-child(1) {
    top: 19px;
}
#gNaviBtn span:nth-child(2) {
    top: 29px;
}
#gNaviBtn span:nth-child(3) {
    top: 39px;
}
/* 最初のspanをマイナス45度に */
#gNaviBtn.active span:nth-child(1) {
    top: 29px;
    left: 15px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
/* 2番目と3番目のspanを45度に */
#gNaviBtn.active span:nth-child(2),
#gNaviBtn.active span:nth-child(3) {
    top: 29px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}
}
/*---------------------- Global Navi ------------------------*/
@media (min-width: 768px) {
#gNavi{
	width:100%;
	padding:10px 0;
	-moz-transition: all 0.5s;
  -o-transition: all 0.5s;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
#gNavi.scrolled {
    background: rgba(254, 247, 249, 0.95);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
    -webkit-box-shadow: 0 5px 5px 0 rgba(0,0,0,0.2);
    -moz-box-shadow: 0 5px 5px 0 rgba(0,0,0,0.2);
    box-shadow: 0 5px 5px 0 rgba(0,0,0,0.2);
}
#gNaviMenu{
	width:980px;
	margin: auto;
}
#gNaviMenu ul{
	display: table;
	width:100%;
	border-left: 1px solid #f485a1;
}
#gNaviMenu li{
	display: table-cell;
	width:calc(100% / 5);
}
#gNaviMenu li a {
	display: block;
	padding:10px 0;
	text-align: center;
	text-decoration: none;
	box-sizing: border-box;
	border-right: 1px solid #f485a1;
}
}
@media (min-width: 1024px) {
#gNaviMenu li a:hover {
	color:#f485a1;
}
}
@media (max-width: 767px) {
#gNaviMenu {
  width: 75%;
	height: 100%;
  background: rgba(254, 247, 249, 0.95);
  transition: all 0.5s ease-in-out 0.0s;
  position: fixed;
	z-index: 9999;
  top: 60px;
  left: -75%;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
	box-sizing: border-box;
	padding:20px;
}
#gNaviMenu.active {
  box-shadow: 0 0 10px 5px rgba(0,0,0,0.3);
	left: 0px;
}
#gNaviMenu ul{
	border-top: 1px solid #f485a1;
}
#gNaviMenu ul li{
	border-bottom: 1px solid #f485a1;
	text-align:left;
}
#gNaviMenu li a {
	display: block;
	text-decoration: none;
	line-height:150%;
	box-sizing: border-box;
	padding:15px 0 15px 30px;
	position: relative;
}
#gNaviMenu li a::before{
position: absolute;
top: 0;
bottom: 0;
left: 0;
margin: auto;
content: "";
vertical-align: middle;
left: 10px;
width: 6px;
height: 6px;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
border-top: 1px solid #f485a1;
border-right: 1px solid #f485a1;
}
}
/*---------------------- Contents ------------------------*/
@media (min-width: 768px) {
#contents{
	padding: 0 0 120px;
}
}
@media (max-width: 767px) {
#contents{
	padding: 60px 0 110px;
}
}
/*---------------------- Footer ------------------------*/
#footer{
	text-align: center;
	padding: 30px 0 30px;
	background: rgba(244,133,161,0.5);
	width:100%;
	box-sizing: border-box;
	position: absolute;
	left:0;
	bottom:0;
}
#footerMenu{
margin:0 0 30px;
}
#footerMenu li{
display: inline-block;
margin:0 10px;
}
#footerMenu li a{
color: #FFFFFF;
text-decoration: none;
}
#footer .copy{
	font-size:0.7em;
	color:#FFFFFF;
}
@media (max-width: 767px) {
#footer{
	padding: 10px 0 10;
}
}
/*---------------------- Clearfix ------------------------*/
.clearfix:after {
 content: ".";
 display: block;
 height: 0;
 clear: both;
 visibility: hidden;
}
.clearfix {
 display: inline-block;
}
* html .clearfix {
 height: 1%;
}
.clearfix {
 display: block;
}