﻿@charset "utf-8";

/*
////////////////////////////////////////////////////////////////////////

	◆ General 共通

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

html {
	font-size: 62.5%; /* 10px = 1rem */
	height: 100%;
	scroll-behavior: smooth;
}
body {
	color: #6a6a6a;
	font-family: 'NotoSansCJKjp', "Hiragino Kaku Gothic ProN","ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, sans-serif;
	font-size: 16px; /* IE対応 */
	font-size: 1.6rem;
	text-align: justify;
	line-height: 1.6;
	-webkit-text-size-adjust: 100%;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	margin: 0;
	padding: 0;
	animation: fadeIn 3s ease 0s 1 normal;
	-webkit-animation: fadeIn 3s ease 0s 1 normal;
}
@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}
p {
	line-height: 1.6;
}
a {
	text-decoration: none;
	color: #6a6a6a;
}
a:hover {
	text-decoration: none;
	opacity: 0.8;
}
a.window::after {
	font-family: "fontawesome";
	content: "\f08e";
	margin-left: 0.5rem;
}
/*a[href$=".pdf"]::after {
	font-family: "fontawesome";
	content: "\f1c1";
	color: red;
	margin-left: 0.5rem;
}*/
.center {
	text-align: center;
}
.right {
	float: right;
}
.eng {
	font-family: 'Oswald', sans-serif;
}
.eng2 {
	font-family: 'Satisfy', cursive;
}
.pcHide {
	display: none;
}
.spHide {
	display: block;
}
/* pagetop */
.pagetop {
	position: fixed;
	right: 0;
	bottom: 0;
	margin: 0;
}
.pagetop a {
	position: relative;
	display: flex;
	height: 50px;
	width: 50px;
	justify-content: center;
	background: #454545;
	transition: opacity .6s ease;
	color: #fff;
	align-items: center;
	text-decoration: none;
	font-size: 2rem;
	opacity: 0.8;
}
.pagetop a:hover {
    opacity: 0.5;
}

/* テキスト */
.txtXS {
	font-size: 1.2rem;
}
.txtS {
	font-size: 1.4rem;
}
a.txtLink {
	text-decoration: underline;
	color: #D95D1D;
}
.highLight {
	color: #D95D1D;
}
.marker_yellow {
  background: linear-gradient(transparent 50%, #ffff66 0);
	padding-bottom: 0.3rem;
}

/*----------------------------------------------------
  space
----------------------------------------------------*/
.m-1{margin:1rem}.mt-1{margin-top:1rem}.mb-1{margin-bottom:1rem}.ml-1{margin-left:1rem}.mr-1{margin-right:1rem}.mv-1{margin:1rem 0}.mh-1{margin:0 1rem}.m-2{margin:2rem}.mt-2{margin-top:2rem}.mb-2{margin-bottom:2rem}.ml-2{margin-left:2rem}.mr-2{margin-right:2rem}.mv-2{margin:2rem 0}.mh-2{margin:0 2rem}.m-3{margin:3rem}.mt-3{margin-top:3rem}.mb-3{margin-bottom:3rem}.ml-3{margin-left:3rem}.mr-3{margin-right:3rem}.mv-3{margin:3rem 0}.mh-3{margin:0 3rem}.m-4{margin:4rem}.mt-4{margin-top:4rem}.mb-4{margin-bottom:4rem}.ml-4{margin-left:4rem}.mr-4{margin-right:4rem}.mv-4{margin:4rem 0}.mh-4{margin:0 4rem}.mt-5{margin-top:5rem}.mb-5{margin-bottom:5rem}.ml-5{margin-left:5rem}.mr-5{margin-right:5rem}.mv-5{margin:5rem 0}.mh-5{margin:0 5rem}.mt-6{margin-top:5rem}.mb-6{margin-bottom:6rem}.mt-7{margin-top:7rem}.mb-7{margin-bottom:7rem}

/*
////////////////////////////////////////////////////////////////////////

	◆ TOP / header ヘッダー

------------------------------------------------------------------------
*/
header .inner {
	width: 960px;
	margin: 0 auto;
	padding: 2rem 0;
	display: flex;
	justify-content: space-between;
	vertical-align: middle;
}
header .inner a {
	width: 30%;
	height: auto;
	margin-right: 1.5rem;
}
header .inner h1 {
	font-size: 1.4rem;
	font-weight: 500;
	display: flex;
	align-items: center;
}
header .inner img {
	height: auto;
}
/* 問合せボタン */
header .inner div {
	background-image: linear-gradient( 135deg, #f6c216 10%, #ff66a7 100%);
	border-radius: 30px;
}
header .inner div a {
	width: 100%;
	height: 100%;
	color: #fff;
	padding: 0.5rem 3rem;
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 500;
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
	letter-spacing: 1px;
}

/*
////////////////////////////////////////////////////////////////////////

	◆ TOP / nav ナビ

------------------------------------------------------------------------
*/
#gNav {
	background-image: linear-gradient( 135deg, #ffb84c 10%, #fb6870 100%);
	position: -webkit-sticky;
  position: sticky;
  top: 0;
	z-index: 999;
}
#gNav .inner {
	width: 960px;
	margin: 0 auto;
	padding: 2rem 0;
}
#gNav li a {
  font-size: 1.4rem;
	font-weight: 400;
	color: #fff;
}
#gNav .sub-menu, .mean-container .mean-nav ul ul {
	background-color: #fff;
	background-image: linear-gradient(to right, #ffecd2 0%, #fcb69f 100%);
	box-shadow: rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px;
}
.sub2 {
	background-color: #fff;
	background-image: linear-gradient(to right, #ffecd2 0%, #feda9a 100%);
	box-shadow: rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px;
}
#gNav > ul {
	position: relative;
	display: flex;
	justify-content: center;
	list-style-type: none;
}
#gNav > ul > li {
	list-style-type: none;
	text-align: center;
	font-size: 1.6rem;
	padding: 2rem;
}
#gNav > ul > li span {
	font-size: 1.3rem;
}
#gNav > ul > li i {
	font-size: 1.2rem;
	margin-left: 5px;
}
#gNav > ul > li a {
	position: relative;
	display: block;
	letter-spacing: 1px;
}
#gNav .sub-menu {
	visibility: hidden;
	opacity: 0;
	z-index: 1;
	display: block;
	position: absolute;
	margin-left: -5rem;
	width: 23rem;
	-webkit-transition: all .2s ease;
	transition: all .2s ease;
}
#gNav .sub-menu a {
	display: block;
	border-bottom: none;
	padding: 2rem 1rem;
	line-height: 1.2;
	font-weight: 400;
}
#gNav .sub-menu a:hover:after {
	content: none;
}
#gNav .sub-menu li {
	display: block;
	font-size: 1.6rem;
	padding: 0;
	margin: 0;
	border-bottom: 1px solid #fff;
}
#gNav .sub-menu li:last-child {
	border-bottom: none;
}
#gNav ul > li:hover {
	-webkit-transition: all .5s;
	transition: all .5s;
}
#gNav li:hover ul.sub-menu {
	top: 60px;
	visibility: visible;
	opacity: 1;
	z-index: 9999;
}
#gNav .sub-menu span {
	font-size: 1.2rem;
	margin-left: 0.5rem;
}
#gNav li ul li:after {
	content: none;
}
#gNav li:hover ul.sub-menu a {
	color: #111;
}
#gNav .sub-menu li a:hover {
	background-image: linear-gradient(to right, #fa709a 0%, #fee140 100%);
	background-size: 200% auto;
	color: #fff !important;
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.4);
}
#gNav .sub-menu li.sub2 a:hover {
	background-image: linear-gradient(to right, #ffb32f 0%, #fee140 100%);
	background-size: 200% auto;
	color: #fff !important;
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.4);
}
.spMenu, .bottomMenu {
	display: none;
}


/*
////////////////////////////////////////////////////////////////////////

	◆ TOP / bnSpace バナー

------------------------------------------------------------------------
*/
.bnSpace {
	background: #fff;
	padding: 5rem 0;
	margin: 0 auto;
	display: flex;
	justify-content: center;
}
.bnSpace a {
	display: inline-block;
}

/*
////////////////////////////////////////////////////////////////////////

	◆ TOP / bnLink リンク

------------------------------------------------------------------------
*/
.bnLink {
	background: #f6f7f9;
	padding: 5rem 0;
	margin: 0 auto;
}
.bnLink .inner {
	width: 960px;
	margin: 0 auto;
}
.bnLink ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	list-style-type: none;
}
.bnLink .hp li {
	width: 31%;
	margin-bottom: 3rem;
}
.bnLink .sns li {
	width: 31%;
}

/*
////////////////////////////////////////////////////////////////////////

	◆ TOP / footer フッター

------------------------------------------------------------------------
*/
footer {
	background-image: linear-gradient( 135deg, #ffb84c 10%, #fb6870 100%);
}
footer .inner {
	width: 960px;
	margin: 0 auto;
	padding: 4rem 0;
	display: flex;
	justify-content: space-between;
	vertical-align: middle;
	color: #fff;
}
footer img {
	width: 100px;
	height: auto;
	margin-bottom: 1rem;
}
footer .address {
	width: 40%;
}
footer .map {
	width: 55%;
}
footer .address div {
	display: flex;
	margin-bottom: 1rem;
}
footer .address p {
	font-size: 1.4rem;
	margin-left: 1rem;
	line-height: 3;
}
footer ul {
	list-style-type: none;
}
footer li {
	line-height: 1.6;
}
footer ul i {
	font-size: 3rem;
	margin: 1rem 2rem 0 0;
	color: #fff;
}
footer iframe {
	width: 100%;
	height: 200px;
}
footer small {
	display: block;
	text-align: center;
	color: #fff;
	padding: 2rem 0;
}