/*********************************************************
全体
*********************************************************/
body {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    background: #FFF8E8;
    font-size: 14px;
    color: #5B5B5B;
}
.clearfix:after{
    content: "";
    clear: both;
    display: block;
    visibility: hidden;
}
li {
    list-style: none;
}
img {
    width: 100%;
    max-width: 100%;
}
a {
    text-decoration: none;
    color: #5B5B5B;
    font-size: 16px;
}
a:hover {
    color: #FF7A07;
}
.sp {
    display: inline;
}
/*********************************************************
ヘッダー
*********************************************************/
#slide_menu {
    display: none;
}
#panel-btn {
    display: none;
}
div.top-header {
    background: url(image.php?id=004) rgba(0,0,0,0.7);
    position: static;
    width: 100%;
    z-index: 999;
    padding: 1.5% 0;
    transition: .5s;
    box-shadow: 1px 1px 1px #000;
    box-shadow: 0 1px 5px #666;
}
header {
    background: url(image.php?id=004) rgba(0,0,0,0.7);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 999;
    padding: 1.5% 0;
    transition: .5s;
    box-shadow: 1px 1px 1px #000;
    box-shadow: 0 1px 5px #666;
}
div.top-header .contents {
    padding: 0;
}
header .contents {
    padding: 0;
}
div.top-header a {
    font-weight: bold;
    color: #FFF;
    font-size: 14px;
}
header a {
    font-weight: bold;
    color: #FFF;
    font-size: 14px;
}
header.scroll {
    position: fixed;
    background: url(image.php?id=005) rgba(255,255,255,0.7);
    padding: 1% 0;
}
header.scroll a {
    font-weight: normal;
    color: #000;
    font-size: 14px;
}
.header {
    display: table;
    width: 100%;
}
.logo {
    display: table-cell;
    width: 15%;
    vertical-align: middle;
}
.header nav {
    display: table-cell;
    padding: 0 0 0 5%;
    vertical-align: middle;
}
.header nav li {
    float: left;
    margin: 0 0 0 3%;
}
/*********************************************************
トップページ
*********************************************************/
#top-visual {
    line-height: 0;
    position: relative;
}
.top-vsp {
    display: none;
}
#index {
	background:#363636;
}
.top-message {
    position: absolute;
    max-width: 200px;
    top: 50%;
    left: 50%;
    margin: -100px 0 0 -100px;
}
/*-----------------------
メイン画像
-----------------------*/
.it {
	width: 100%;
	height: 100%;
}
.it a {
	display: block;
	padding: 45% 0 0 0;
	position: relative;
}
@media screen and (min-height: 800px) {
	.it a {
	padding: 67% 0 0 0;
}
}
.it div {
	float: left;
	width: 50%;
}
.kairis a {
	background: url(image.php?id=052);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.kairit a {
	background: url(image.php?id=053);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.kairik a {
	background: url(image.php?id=054);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.kairie a {
	background: url(image.php?id=055);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
/*-----------------------
フォント
-----------------------*/
.it a p {
	position: absolute;
	top: 50%;
	left: 2%;
}
.it a p span {
	opacity: 0;
	transition-duration: .6s;
	display: inline-block;
	color:#FFF;
	font-weight: bold;
	font-size: 36px;
    -webkit-transform: translate3d(0,16px,0);
    transform: translate3d(0,16px,0);
    letter-spacing: 1px;
    text-shadow: 1px 1px 1px #666;
}
.it a p span.f1 {
}
.it a p span.f2 {
	padding: 2% 0 0 0;
}
.it a p span.f3 {
	padding: 2% 0 0 0;
}
.it a p span.f4 {
	padding: 2% 0 0 0;
}
.it a p span.f5 {
	padding: 2% 0 0 0;
}
.it a p span.f6 {
	padding: 2% 0 0 0;
}
.it a p span.f7 {
	padding: 2% 0 0 0;
}
.it a p span.f8 {
	padding: 2% 0 0 0;
}
.it a p span.f9 {
	padding: 2% 0 0 0;
}
.it a p span.f10 {
	padding: 2% 0 0 0;
}
.it a p span.f11 {
	padding: 2% 0 0 0;
}
.changed .it a p span.f1 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: .4s;
}
.changed .it a p span.f2 {
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: .6s;
}
.changed .it a p span.f3 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: .8s;
}
.changed .it a p span.f4 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: 1s;
}
.changed .it a p span.f5 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: 1.2s;
}
.changed .it a p span.f6 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: 1.4s;
}
.changed .it a p span.f7 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: 1.6s;
}
.changed .it a p span.f8 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: 1.8s;
}
.changed .it a p span.f9 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: 2s;
}
.changed .it a p span.f10 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: 2.2s;
}
.changed .it a p span.f11 {
	-webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
	opacity: 1;
	transition-delay: 2.4s;
}
/*********************************************************
メイン
*********************************************************/
.contents {
    max-width: 940px;
    margin: 0 auto;
    padding: 5% 0;
}
.contents p {
    line-height: 2;
}
.title {
    background: url(image.php?id=004) rgba(0,0,0,0.8);
    padding: 2% 0;
}
.top-sekibg .title {
    padding: 2.95% 0;
}
.title h1,
.title h2,
.title h3 {
    font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
    max-width: 940px;
    margin: 0 auto;
    font-weight: bold;
    font-size: 24px;
    color: #FFF;
}
.bg {
    background-attachment: fixed;
    background-size: 100%;
    background-repeat: no-repeat;
    background-color: #DBDBDB;
}
.top-menubg {
    background-image: url(image.php?id=015);
}
.top-sekibg {
    background-image: url(image.php?id=016);
}
.kairi-t .top-menubg {
    background-image: url(image.php?id=031);
    background-color: #FFF8E8;
    background-size: cover;
}
.kairi-t .top-sekibg {
    background-image: url(image.php?id=034);
    background-color: #FFF8E8;
    background-size: cover;
}
.bg .contents {
    padding: 10% 0;
}
.top-menubg .contents {
    padding: 13% 0;
}
.mask {
    background: url(image.php?id=004);
}
.mask .contents h4 {
    color: #FFF;
    font-size: 18px;
    font-weight: bold;
    line-height: 2;
}
.mask .contents li {
    color: #FFF;
    line-height: 1.5;
    font-size: 16px;
    font-weight: bold;
}
/*-----------------------
index ○画像フェードイン
-----------------------*/
.circle li {
    float: left;
    width: 30%;
    text-align: center;
    margin: 2% 0 0 3%;
}
.menu-contents .circle li {

    opacity: 0;
    transition: 1s;
}
.menu-contents .circle li.fadeInUp {
    opacity: 1;
}

.menu-contents .circle li:nth-child(n) {
    animation-duration: .4s;
}
.menu-contents .circle li:nth-child(2n) {
    animation-duration: .6s;
}
.menu-contents .circle li:nth-child(3n) {
    animation-duration: .8s;
}
.menu-contents .circle li:nth-child(4n) {
    animation-duration: 1s;
}
.menu-contents .circle li:nth-child(5n) {
    animation-duration: 1.2s;
}
.top-seki .circle li {
    opacity: 0;
    transition: 1s;
}
.top-seki .circle li.fadeInUp {
    opacity: 1;
}
.top-seki .circle li:nth-child(n) {
    animation-duration: .4s;
}
.top-seki .circle li:nth-child(2n) {
    animation-duration: .6s;
}
.top-seki .circle li:nth-child(3n) {
    animation-duration: .8s;
}
.circle a {
    transition: .4s;
}
.circle img {
    transition: .4s;
    padding: 0 0 3% 0;
}
.circle li a:hover img {
    -webkit-transform: scale(1.05);
    -moz-transform: scale(1.05);
    -ms-transform: scale(1.05);
    -o-transform: scale(1.05);
    transform: scale(1.05);
}
/*-----------------------
index お知らせ
-----------------------*/
.info-title {
    border-bottom: 1px solid #000;
    padding: 0 0 3px 3px;
    font-size: 18px;
    font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
    margin: 0 0 3% 0;
}
.news li {
    line-height: 1.7;
}
.news a {
    padding: 0 0 0 3%;
}
/*-----------------------
共通 マップ
-----------------------*/
.map {
    display: table;
    width: 100%;
}
.ggmap {
    display: table-cell;
    width: 70%;
    vertical-align: middle;
}
.map-r {
    display: table-cell;
    background: #131313;
    color: #FFF;
    padding: 2%;
    box-sizing: border-box;
    vertical-align: middle;
}
.map-r li {
    line-height: 2;
}
.map-r li span{
    font-size: 12px;
}
.map-r li div {
    font-weight: bold;
    font-size: 16px;
}
/*-----------------------
menu.html
-----------------------*/
#menu section {
    padding: 3%;
    box-sizing: border-box;
    background: #FFF;
    border-radius: 3px;
    box-shadow: 0px 0px 3px #AAAAAA;
    margin: 3% 0 0 0;
}
#menu span {
    font-size: 24px;
    text-align: center;
}
#menu h3 {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.3;
    margin: 0 0 3% 0;
}
.menu-table {
    display: block;
    width: 100%;
}
.menu-img {
    display: none;
}
.menu-text {
    display: block;
    width: 100%;
    vertical-align: middle;
}
#menu .contents p {
    line-height: 1.5;
    margin: 3% 0;
}
#menu .contents p:first-child {
    margin: 0 0 3% 0;
}
#menu .price span {
    font-size: 18px;
    font-weight: bold;
}
.course {
    background: #E4E4E4;
    padding: 2%;
    box-sizing: border-box;
    font-size: 12px;
}
.course h4 {
    font-weight: bold;
    font-size: 16px;
}
.course table {
    margin: 2% 0 1%;
}
.course table td {
    padding: 2% 0;
}
.course li {
    line-height: 2;
}
.course .attention {
    margin: 2% 0 0 0;
    color: #000;
    line-height: 1.3;
}
#menu .kugiri {
    padding: 0 0 2% 0;
    margin: 3% 0 0 0;
    border-bottom: 1px dotted #AFAFAF;
}
.shousai {
    width: 100%;
}
.shousai td,
.shousai th {
    border-right: 1px solid #CCC;
}
.shousai th {
    background: #000;
    color: #FFF;
    text-align: center;
    font-weight: bold;
    padding: 1% 0;
}
.shousai td {
    background: #FFF;
    text-align: center;
}
.komi {
    font-weight: bold;
    text-align: center;
    margin: 3% 0 3% 0;
}
.menu-table2 {
    display: table;
    width: 100%;
}
.menu-img2 {
    display: none;
}
.menu-text2 {
    display: table-cell;
    width: 70%;
    vertical-align: middle;
}
.menu-price {
    display: table-cell;
    width: 30%;
    line-height: 1.5;
    vertical-align: middle;
    text-align: right;
}
#menu span.osusume {
    font-size: 10px;
    color: #FFF;
    background: #870002;
    padding: 1%;
}
#menu .table1 {
    width: 100%;
}
.table1 .td2 {
    width: 50%;
    text-align: right;
    vertical-align: middle;
    line-height: 1.5;
}
/*-----------------------
アコーディオン(menu.html)
-----------------------*/
.qa {
    background: #161841;
    padding: 2% 0;
}
.qa-ac {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    font-size: 14px;
}
.qa-first{
    border-top:#666 1px solid;
}
.qa-ac dt{
    display:table;
    padding: 12px 1%;
    background: #666;
    color: #FFF;
    cursor:pointer;
    position: relative;
    box-sizing: border-box;
    width: 100%;
}
.qa-ac dt span {


    display:table-cell;
    vertical-align: middle;
    line-height: 1.5;
}
.qa-ac dt i {
  display:table-cell;
  width: 10%;
  vertical-align: middle;
  text-align: center;
}
.qa-ac dd{
    display:none;
}
.clicked i {
  -moz-transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  transform: rotate(180deg);
}
.q {
    color: #FF85E4;
    font-weight: bold;
    font-size: 18px;
}
.a {
    color: #56B3FF;
    font-weight: bold;
    font-size: 18px;
}
/*-----------------------
koshitsu.html(seki/kashikiri共通)
-----------------------*/
.padding {
    padding: 50px 0;
}
#koshitsu section {
    padding: 3%;
    box-sizing: border-box;
    background: #FFF;
    border-radius: 3px;
    box-shadow: 0px 0px 3px #AAAAAA;
    margin: 3% 0 0 0;
}
#koshitsu h2 {
    border-bottom: 1px solid #000;
    font-size: 24px;
    padding: 0 0 2% 0;
    margin: 0 0 3% 0;
    text-align: center;
}
#koshitsu h3 {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.3;
    margin: 0 0 3% 0;
}
#koshitsu .osusume {
    font-size: 10px;
    color: #FFF;
    background: #870002;
    padding: 1%;
}
.omise-table {
    display: table;
    width: 100%;
}
.omise-l {
    display: table-cell;
    vertical-align: middle;
}
.omise-r {
    display: table-cell;
    width: 65%;
    padding: 0 0 0 5%;
}
.omise-r table {
    width: 100%;
}
.omise-r table th {
    text-align: left;
    font-weight: bold;
    width: 30%;
    border-right: 1px solid #ACACAC;
    border-bottom: 1px solid #ACACAC;
    border-top: 1px solid #ACACAC;
    border-left: 1px solid #ACACAC;
    padding: 2%;
    box-sizing: border-box;
    vertical-align: middle;
}
.omise-r table td {
    border-right: 1px solid #ACACAC;
    border-bottom: 1px solid #ACACAC;
    border-top: 1px solid #ACACAC;
    padding: 2%;
    box-sizing: border-box;
}
.omise-r .hito {
    display: block;
    margin: 0 0 3% 0;
    font-size: 12px;
    line-height: 1.5;
}
.omise-r .tel p {
    margin: 2% 0 0 0;
}
.omise-r .tel span {
    font-size: 18px;
    font-weight: bold;
}
.p-link {
    display: table;
    width: 70%;
    margin: 0 auto 3%;
    border-collapse: separate;
    border-spacing: 10px 0;
}
.p-link a {
    display: table-cell;
    width: 33.3%;
    background: #000;
    color: #FFF;
    font-weight: bold;
    border: 1px solid #B7B7B7;
    box-sizing: border-box;
    padding: 2%;
    text-align: center;
}
/*-----------------------
gallery.html
-----------------------*/
.photo .title {
    padding: 9% 0 2%;
}
.gallery-img li {
    float: left;
    width: 16%;
    margin: 2%;
}
/*-----------------------
kodawari.html
-----------------------*/
#kodawari section {
    padding: 3%;
    box-sizing: border-box;
    background: #FFF;
    border-radius: 3px;
    box-shadow: 0px 0px 3px #AAAAAA;
    margin: 3% 0 0 0;
}
.ko1,.ko2,.ko3,.ko4{
    border-bottom: 1px dotted #666;
    margin: 0 0 3% 0;
}
#kodawari .kodawari-t {
    display: table;
    width: 100%;
    font-size: 12px;
    margin: 0 0 3% 0;
}
#kodawari .kodawari-l {
    display: table-cell;
    width: 49%;
    padding: 0 1% 0 0;
    vertical-align: middle;
}
#kodawari .kodawari-r {
    display: table-cell;
    width: 49%;
    padding: 0 0 0 1%;
    vertical-align: middle;
}
#kodawari .ko-t {
    display: table;
    width: 100%;
    font-size: 12px;
    margin: 0 0 3% 0;
}
#kodawari .ko-l {
    display: table-cell;
    width: 49%;
    padding: 0 1% 0 0;
    vertical-align: middle;
}
#kodawari .ko-r {
    display: table-cell;
    width: 49%;
    padding: 0 0 0 1%;
    vertical-align: middle;
}
#kodawari h2 {
    font-size: 24px;
    margin: 0 0 5% 0;
}
#kodawari h2 span {
    display: inline-block;
    border-right: #FFF 1px solid;
    padding: 1%;
    font-weight: bold;
}
#kodawari h2 .s1,
#kodawari h2 .s2,
#kodawari h2 .s3,
#kodawari h2 .s4 {
    background: #000;
    color: #FFF;
}
#kodawari h2 .s5 {
    background: #A20002;
    color: #FFF;
}
#kodawari div.ft {
   margin: 0 0 5% 0;
}
#kodawari .red {
    color: #AD0002;
    font-size: 16px;
    font-weight: bold;
}
#kodawari h3 {
    font-size: 18px;
    font-weight: bold;
    margin: 2% 0;
}
/*-----------------------
access.html
-----------------------*/
#access section {
    padding: 3%;
    box-sizing: border-box;
    background: #FFF;
    border-radius: 3px;
    box-shadow: 0px 0px 3px #AAAAAA;
    margin: 3% 0 0 0;
}
#access table {
    width: 100%;
    font-size: 12px;
}
#access tr {
    border-bottom: 1px dotted #E8E8E8;
}
#access th {
    background: #868686;
    color: #FFF;
    font-weight: bold;
    vertical-align: middle;
}
#access td {
    padding: 2% 0 2% 2%;
}
#access td li {
    padding: 1% 0;
    line-height: 1.3;
}
/*********************************************************
フッター
*********************************************************/
footer {
    background:#363636;
    color: #FFF;
}
footer .contents {
    padding: 2% 0;
}
footer p {
    float: left;
}
.copy {
    width: 50%;
}
.page-top {
    width: 50%;
    text-align: right;
}
.page-top a {
    color: #FFF;
}
.page-top a:hover {
    color: #FF7A07;
}
/*********************************************************
                        マップ
*********************************************************/
.ggmap {
    position: relative;
    padding-bottom: 40%;
    height: 0;
    overflow: hidden;
}
.ggmap iframe,
.ggmapr object,
.ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.h-ggmap {
    position: relative;
    padding-bottom: 36.14014251781473%;
    height: 0;
    overflow: hidden;
}
.h-ggmap iframe,
.ggmapr object,
.h-ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
/*********************************************************
ローディング
*********************************************************/
#loading {
 width: 100%;
 height: 100%;
 margin: 0;
 background: #FFF;/*背景*/
 opacity: 1.0;
 position: fixed;
 top: 0;
 left: 0;
 z-index: 9999;
}
#loading img {
 max-width: 32px;
 position:absolute;
 top:50%;
 left:50%;
 margin-top:-16px;/*画像の高さの半分マイナス*/
 margin-left:-16px;/*画像の幅の半分マイナス*/
}