@charset "UTF-8";

/* Reset Style */
html {
  overflow-y: scroll;
}

body {
  line-height: 1;
  color: #000;
}

/* html5doctor.com Reset Stylesheet v1.6.1
Last Updated: 2010-09-17 Author: Richard Clark - http://richclarkdesign.com Twitter: @rich_clark */
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: transparent;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: '';
  content: none;
}

a {
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  background: transparent;
  outline: none;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

/* YUI 3.4.1 (build 4118) Copyright 2011 Yahoo! Inc. All rights reserved.
Licensed under the BSD License. http://yuilibrary.com/license/ */
body {
  font: 13px/1.231 arial, helvetica, clean, sans-serif;
  *font-size: small;
  *font: x-small;
}

select,
input,
button,
textarea {
  font: 99% arial, helvetica, clean, sans-serif;
}

table {
  font-size: inherit;
  font: 100%;
}

pre,
code,
kbd,
samp,
tt {
  font-family: monospace;
  *font-size: 108%;
  line-height: 100%;
}

/**以下レスポンシブグリッド用**/
.mt0 {
  margin-top: 0px !important;
}

.mb0 {
  margin-bottom: 0px !important;
}

.pt0 {
  padding-top: 0px !important;
}

.pb0 {
  padding-bottom: 0px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.mt45 {
  margin-top: 45px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.mt55 {
  margin-top: 55px !important;
}

.mb55 {
  margin-bottom: 55px !important;
}

.pt55 {
  padding-top: 55px !important;
}

.pb55 {
  padding-bottom: 55px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.pt60 {
  padding-top: 60px !important;
}

.pb60 {
  padding-bottom: 60px !important;
}

.mt65 {
  margin-top: 65px !important;
}

.mb65 {
  margin-bottom: 65px !important;
}

.pt65 {
  padding-top: 65px !important;
}

.pb65 {
  padding-bottom: 65px !important;
}

.mt70 {
  margin-top: 70px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.pt70 {
  padding-top: 70px !important;
}

.pb70 {
  padding-bottom: 70px !important;
}

.mt75 {
  margin-top: 75px !important;
}

.mb75 {
  margin-bottom: 75px !important;
}

.pt75 {
  padding-top: 75px !important;
}

.pb75 {
  padding-bottom: 75px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.pt80 {
  padding-top: 80px !important;
}

.pb80 {
  padding-bottom: 80px !important;
}

.mt85 {
  margin-top: 85px !important;
}

.mb85 {
  margin-bottom: 85px !important;
}

.pt85 {
  padding-top: 85px !important;
}

.pb85 {
  padding-bottom: 85px !important;
}

.mt90 {
  margin-top: 90px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.pt90 {
  padding-top: 90px !important;
}

.pb90 {
  padding-bottom: 90px !important;
}

.mt95 {
  margin-top: 95px !important;
}

.mb95 {
  margin-bottom: 95px !important;
}

.pt95 {
  padding-top: 95px !important;
}

.pb95 {
  padding-bottom: 95px !important;
}

.mt100 {
  margin-top: 100px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.pt100 {
  padding-top: 100px !important;
}

.pb100 {
  padding-bottom: 100px !important;
}

* {
  box-sizing: border-box;
}

.container-fluid {
  margin-right: auto;
  margin-left: auto;
}

.container-fluid:before,
.container-fluid:after {
  content: " ";
  display: table;
}

.container-fluid:after {
  clear: both;
}

.container {
  margin-right: auto;
  margin-left: auto;
}

.container:before,
.container:after {
  content: " ";
  display: table;
}

.container:after {
  clear: both;
}

@media (max-width: 767px) {
  .container {
    max-width: 610px;
    width: auto;
  }
}

@media (min-width: 768px) {
  .container {
    min-width: 960px;
    width: auto;
  }
}

@media (min-width: 960px) {
  .container {
    width: 960px;
  }
}

@media (min-width: 1600px) {
  .container {
    width: 960px;
  }
}

.row:before,
.row:after {
  content: " ";
  display: table;
}

.row:after {
  clear: both;
}

.col-xs-1 {
  float: left;
  width: 5.46875%;
  margin-left: 3.125%;
}

.col-xs-1:first-child {
  margin-left: 0;
}

.col-xs-2 {
  float: left;
  width: 14.0625%;
  margin-left: 3.125%;
}

.col-xs-2:first-child {
  margin-left: 0;
}

.col-xs-3 {
  float: left;
  width: 22.65625%;
  margin-left: 3.125%;
}

.col-xs-3:first-child {
  margin-left: 0;
}

.col-xs-4 {
  float: left;
  width: 31.25%;
  margin-left: 3.125%;
}

.col-xs-4:first-child {
  margin-left: 0;
}

.col-xs-5 {
  float: left;
  width: 39.84375%;
  margin-left: 3.125%;
}

.col-xs-5:first-child {
  margin-left: 0;
}

.col-xs-6 {
  float: left;
  width: 48.4375%;
  margin-left: 3.125%;
}

.col-xs-6:first-child {
  margin-left: 0;
}

.col-xs-7 {
  float: left;
  width: 57.03125%;
  margin-left: 3.125%;
}

.col-xs-7:first-child {
  margin-left: 0;
}

.col-xs-8 {
  float: left;
  width: 65.625%;
  margin-left: 3.125%;
}

.col-xs-8:first-child {
  margin-left: 0;
}

.col-xs-9 {
  float: left;
  width: 74.21875%;
  margin-left: 3.125%;
}

.col-xs-9:first-child {
  margin-left: 0;
}

.col-xs-10 {
  float: left;
  width: 82.8125%;
  margin-left: 3.125%;
}

.col-xs-10:first-child {
  margin-left: 0;
}

.col-xs-11 {
  float: left;
  width: 91.40625%;
  margin-left: 3.125%;
}

.col-xs-11:first-child {
  margin-left: 0;
}

.col-xs-12 {
  width: 100%;
}

@media (max-width: 767px) {
  .col-xs-6:nth-child(odd) {
    margin-left: 0;
  }

  .col-xs-4:nth-child(3n+1) {
    margin-left: 0;
  }

  .col-xs-3:nth-child(4n+1) {
    margin-left: 0;
  }

  .col-xs-2:nth-child(6n+1) {
    margin-left: 0;
  }
}

@media (min-width: 768px) {
  .col-sm-1 {
    float: left;
    width: 5.46875%;
    margin-left: 3.125%;
  }

  .col-sm-1:first-child {
    margin-left: 0;
  }

  .col-sm-2 {
    float: left;
    width: 14.0625%;
    margin-left: 3.125%;
  }

  .col-sm-2:first-child {
    margin-left: 0;
  }

  .col-sm-3 {
    float: left;
    width: 22.65625%;
    margin-left: 3.125%;
  }

  .col-sm-3:first-child {
    margin-left: 0;
  }

  .col-sm-4 {
    float: left;
    width: 31.25%;
    margin-left: 3.125%;
  }

  .col-sm-4:first-child {
    margin-left: 0;
  }

  .col-sm-5 {
    float: left;
    width: 39.84375%;
    margin-left: 3.125%;
  }

  .col-sm-5:first-child {
    margin-left: 0;
  }

  .col-sm-6 {
    float: left;
    width: 48.4375%;
    margin-left: 3.125%;
  }

  .col-sm-6:first-child {
    margin-left: 0;
  }

  .col-sm-7 {
    float: left;
    width: 57.03125%;
    margin-left: 3.125%;
  }

  .col-sm-7:first-child {
    margin-left: 0;
  }

  .col-sm-8 {
    float: left;
    width: 65.625%;
    margin-left: 3.125%;
  }

  .col-sm-8:first-child {
    margin-left: 0;
  }

  .col-sm-9 {
    float: left;
    width: 74.21875%;
    margin-left: 3.125%;
  }

  .col-sm-9:first-child {
    margin-left: 0;
  }

  .col-sm-10 {
    float: left;
    width: 82.8125%;
    margin-left: 3.125%;
  }

  .col-sm-10:first-child {
    margin-left: 0;
  }

  .col-sm-11 {
    float: left;
    width: 91.40625%;
    margin-left: 3.125%;
  }

  .col-sm-11:first-child {
    margin-left: 0;
  }

  .col-sm-12 {
    width: 100%;
  }
}

@media (min-width: 768px) and (max-width: 959px) {
  .col-sm-6:nth-child(odd) {
    margin-left: 0;
  }

  .col-sm-4:nth-child(3n+1) {
    margin-left: 0;
  }

  .col-sm-3:nth-child(4n+1) {
    margin-left: 0;
  }

  .col-sm-2:nth-child(6n+1) {
    margin-left: 0;
  }
}

@media (min-width: 960px) {
  .col-md-1 {
    float: left;
    width: 5.46875%;
    margin-left: 3.125%;
  }

  .col-md-1:first-child {
    margin-left: 0;
  }

  .col-md-2 {
    float: left;
    width: 14.0625%;
    margin-left: 3.125%;
  }

  .col-md-2:first-child {
    margin-left: 0;
  }

  .col-md-3 {
    float: left;
    width: 22.65625%;
    margin-left: 3.125%;
  }

  .col-md-3:first-child {
    margin-left: 0;
  }

  .col-md-4 {
    float: left;
    width: 31.25%;
    margin-left: 3.125%;
  }

  .col-md-4:first-child {
    margin-left: 0;
  }

  .col-md-5 {
    float: left;
    width: 39.84375%;
    margin-left: 3.125%;
  }

  .col-md-5:first-child {
    margin-left: 0;
  }

  .col-md-6 {
    float: left;
    width: 48.4375%;
    margin-left: 3.125%;
  }

  .col-md-6:first-child {
    margin-left: 0;
  }

  .col-md-7 {
    float: left;
    width: 57.03125%;
    margin-left: 3.125%;
  }

  .col-md-7:first-child {
    margin-left: 0;
  }

  .col-md-8 {
    float: left;
    width: 65.625%;
    margin-left: 3.125%;
  }

  .col-md-8:first-child {
    margin-left: 0;
  }

  .col-md-9 {
    float: left;
    width: 74.21875%;
    margin-left: 3.125%;
  }

  .col-md-9:first-child {
    margin-left: 0;
  }

  .col-md-10 {
    float: left;
    width: 82.8125%;
    margin-left: 3.125%;
  }

  .col-md-10:first-child {
    margin-left: 0;
  }

  .col-md-11 {
    float: left;
    width: 91.40625%;
    margin-left: 3.125%;
  }

  .col-md-11:first-child {
    margin-left: 0;
  }

  .col-md-12 {
    width: 100%;
  }
}

@media only screen and (min-width: 960px) and (max-width: 1600px) {
  .col-md-6:nth-child(odd) {
    margin-left: 0;
  }

  .col-md-4:nth-child(3n+1) {
    margin-left: 0;
  }

  .col-md-3:nth-child(4n+1) {
    margin-left: 0;
  }

  .col-md-2:nth-child(6n+1) {
    margin-left: 0;
  }
}

@media (min-width: 1600px) {
  .col-lg-1 {
    float: left;
    width: 5.46875%;
    margin-left: 3.125%;
  }

  .col-lg-1:first-child {
    margin-left: 0;
  }

  .col-lg-2 {
    float: left;
    width: 14.0625%;
    margin-left: 3.125%;
  }

  .col-lg-2:first-child {
    margin-left: 0;
  }

  .col-lg-3 {
    float: left;
    width: 22.65625%;
    margin-left: 3.125%;
  }

  .col-lg-3:first-child {
    margin-left: 0;
  }

  .col-lg-4 {
    float: left;
    width: 31.25%;
    margin-left: 3.125%;
  }

  .col-lg-4:first-child {
    margin-left: 0;
  }

  .col-lg-5 {
    float: left;
    width: 39.84375%;
    margin-left: 3.125%;
  }

  .col-lg-5:first-child {
    margin-left: 0;
  }

  .col-lg-6 {
    float: left;
    width: 48.4375%;
    margin-left: 3.125%;
  }

  .col-lg-6:first-child {
    margin-left: 0;
  }

  .col-lg-7 {
    float: left;
    width: 57.03125%;
    margin-left: 3.125%;
  }

  .col-lg-7:first-child {
    margin-left: 0;
  }

  .col-lg-8 {
    float: left;
    width: 65.625%;
    margin-left: 3.125%;
  }

  .col-lg-8:first-child {
    margin-left: 0;
  }

  .col-lg-9 {
    float: left;
    width: 74.21875%;
    margin-left: 3.125%;
  }

  .col-lg-9:first-child {
    margin-left: 0;
  }

  .col-lg-10 {
    float: left;
    width: 82.8125%;
    margin-left: 3.125%;
  }

  .col-lg-10:first-child {
    margin-left: 0;
  }

  .col-lg-11 {
    float: left;
    width: 91.40625%;
    margin-left: 3.125%;
  }

  .col-lg-11:first-child {
    margin-left: 0;
  }

  .col-lgd-12 {
    width: 100%;
  }

  .col-lg-6:nth-child(odd) {
    margin-left: 0;
  }

  .col-lg-4:nth-child(3n+1) {
    margin-left: 0;
  }

  .col-lg-3:nth-child(4n+1) {
    margin-left: 0;
  }

  .col-lg-2:nth-child(6n+1) {
    margin-left: 0;
  }
}

.visible-xs {
  display: none !important;
}

.visible-sm {
  display: none !important;
}

.visible-md {
  display: none !important;
}

.visible-lg {
  display: none !important;
}

.visible-xs-block,
.visible-xs-inline,
.visible-xs-inline-block,
.visible-sm-block,
.visible-sm-inline,
.visible-sm-inline-block,
.visible-md-block,
.visible-md-inline,
.visible-md-inline-block,
.visible-lg-block,
.visible-lg-inline,
.visible-lg-inline-block {
  display: none !important;
}

@media (max-width: 767px) {
  .visible-xs {
    display: block !important;
  }

  table.visible-xs {
    display: table !important;
  }

  tr.visible-xs {
    display: table-row !important;
  }

  th.visible-xs,
  td.visible-xs {
    display: table-cell !important;
  }
}

@media (max-width: 767px) {
  .visible-xs-block {
    display: block !important;
  }
}

@media (max-width: 767px) {
  .visible-xs-inline {
    display: inline !important;
  }
}

@media (max-width: 767px) {
  .visible-xs-inline-block {
    display: inline-block !important;
  }
}

@media (min-width: 768px) and (max-width: 959px) {
  .visible-sm {
    display: block !important;
  }

  table.visible-sm {
    display: table !important;
  }

  tr.visible-sm {
    display: table-row !important;
  }

  th.visible-sm,
  td.visible-sm {
    display: table-cell !important;
  }
}

@media (min-width: 768px) and (max-width: 959px) {
  .visible-sm-block {
    display: block !important;
  }
}

@media (min-width: 768px) and (max-width: 959px) {
  .visible-sm-inline {
    display: inline !important;
  }
}

@media (min-width: 768px) and (max-width: 959px) {
  .visible-sm-inline-block {
    display: inline-block !important;
  }
}

@media (min-width: 960px) and (max-width: 1600px) {
  .visible-md {
    display: block !important;
  }

  table.visible-md {
    display: table !important;
  }

  tr.visible-md {
    display: table-row !important;
  }

  th.visible-md,
  td.visible-md {
    display: table-cell !important;
  }
}

@media (min-width: 960px) and (max-width: 1600px) {
  .visible-md-block {
    display: block !important;
  }
}

@media (min-width: 960px) and (max-width: 1600px) {
  .visible-md-inline {
    display: inline !important;
  }
}

@media (min-width: 960px) and (max-width: 1600px) {
  .visible-md-inline-block {
    display: inline-block !important;
  }
}

@media (min-width: 1600px) {
  .visible-lg {
    display: block !important;
  }

  table.visible-lg {
    display: table !important;
  }

  tr.visible-lg {
    display: table-row !important;
  }

  th.visible-lg,
  td.visible-lg {
    display: table-cell !important;
  }
}

@media (min-width: 1600px) {
  .visible-lg-block {
    display: block !important;
  }
}

@media (min-width: 1600px) {
  .visible-lg-inline {
    display: inline !important;
  }
}

@media (min-width: 1600px) {
  .visible-lg-inline-block {
    display: inline-block !important;
  }
}

@media (max-width: 767px) {
  .hidden-xs {
    display: none !important;
  }
}

@media (min-width: 768px) and (max-width: 959px) {
  .hidden-sm {
    display: none !important;
  }
}

@media (min-width: 960px) and (max-width: 1600px) {
  .hidden-md {
    display: none !important;
  }
}

@media (min-width: 1600px) {
  .hidden-lg {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .xs-center {
    text-align: center !important;
  }
}

@media (min-width: 768px) and (max-width: 959px) {
  .sm-center {
    text-align: center !important;
  }
}

@media (min-width: 960px) and (max-width: 1600px) {
  .md-center {
    text-align: center !important;
  }
}

@media (min-width: 1600px) {
  .lg-center {
    text-align: center !important;
  }
}

@media (max-width: 767px) {
  .xs-right {
    text-align: right !important;
  }
}

@media (min-width: 768px) and (max-width: 959px) {
  .sm-right {
    text-align: right !important;
  }
}

@media (min-width: 960px) and (max-width: 1600px) {
  .md-right {
    text-align: right !important;
  }
}

@media (min-width: 1600px) {
  .lg-right {
    text-align: right !important;
  }
}

html {
  font-size: 62.5%;
}

body {
  background: #fff;
  color: #000;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Verdana, sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
}

#page {
  width: 100%;
  margin: 0 auto;
}

a:link {
  color: #1b577d;
}

a:visited {
  color: #1b577d;
}

a:hover {
  text-decoration: none;
  color: #1b577d;
}

a:active {
  color: #1b577d;
}

img {
  line-height: 1;
  font-size: 0;
  vertical-align: top;
  height: auto;
  max-width: 100%;
}

img#spf_logo {
  line-height: 1;
  font-size: 0;
  vertical-align: middle;
  height: auto;
  max-width: 70%;
}

table {
  width: 100%;
  border-collapse: collapse;
}

th,
td {
  border-style: none;
}

.font_en01,
.l_nav_tel,
.extend_ttl01,
.tef_plan_ttl,
.tef_menu_ttl,
.tef_gallery_ttl,
.tef_access_ttl,
.tef_ticket_pop_ttl,
.tef_intro_sub,
.tef_menu_thumbnail .en {
  font-family: 'Roboto Slab', 'Courier New', Courier, serif;
  font-weight: normal;
}

.font_ja01,
.gnavi ul li a,
.tef_intro_lead,
.tef_menu_name {
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝", YuMincho, "HG明朝E", "MS P明朝", "MS 明朝", serif;
  font-weight: normal;
}

.inner {
  width: 960px;
  margin: 0 auto;
  padding: 0;
  position: relative;
}

.imgArea {
  overflow: hidden;
}

.inline_block {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}

.table_cell {
  display: table-cell;
  *display: inline;
  *zoom: 1;
  vertical-align: middle;
}

.ovfl {
  overflow: hidden;
}

.fr,
.imgR,
.alignright {
  float: right;
  margin-left: 10px;
}

.fl,
.imgL,
.alignleft {
  float: left;
  margin-right: 10px;
}

.imgC,
.tC,
.btn,
.aligncenter {
  text-align: center;
}

.imgC,
.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.tR,
.sign {
  text-align: right;
}

/* clearfix */
.clearfix,
.l-contents {
  *zoom: 1;
}

.clearfix:after,
.l-contents:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

/*----------------------------------------------------
	#contents
----------------------------------------------------*/
.l-contents {
  line-height: 1.8;
  _zoom: 1;
  word-break: normal;
  word-wrap: break-word;
}

.l-contents h1,
.l-contents h2,
.l-contents h3,
.l-contents h4,
.l-contents h5,
.l-contents h6 {
  line-height: 1.4;
}

/*----------------------------------------------------
	ヘッダー
----------------------------------------------------*/
.l-header {
  width: 100%;
  height: 75px;
}

.l-header .logo {
  padding: 15px 0;
  float: left;
}

.gnavi {
  width: auto;
  margin-right: -15px;
  float: right;
}

.gnavi ul {
  display: table;
  width: auto;
}

.gnavi ul li {
  height: 75px;
  padding: 0 15px;
  display: table-cell;
  text-align: center;
  vertical-align: middle;
  word-wrap: normal;
  font-size: 16px;
}

.gnavi ul li a {
  transition-property: all;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  color: #000;
  text-decoration: none;
}

.gnavi ul li a:hover {
  opacity: .8;
}

.l_nav,
.main_front_nav {
  color: #fff;
  width: 270px;
  height: 180px;
  overflow: hidden;
  position: fixed;
  right: 0;
  top: -210px;
  z-index: 1000;
  transition-property: all;
  transition-duration: 0.4s;
  transition-timing-function: ease;
}

.l_nav.is_active,
.is_active.main_front_nav {
  top: 0;
}

.l_nav ul,
.main_front_nav ul {
  overflow: hidden;
}

.l_nav_tel {
  color: #fff;
  background: #2cad88;
  width: 100%;
  height: 90px;
  padding-top: 30px;
  text-align: center;
  font-weight: 100;
  border-bottom: 1px solid #fff;
  line-height: 1;
}

.l_nav_tel .num {
  display: block;
  font-size: 32px;
}

.l_nav_tel .time {
  display: block;
  font-size: 14px;
  margin-top: 15px;
}

.l_nav_tel a {
  text-decoration: none;
  color: #fff;
}

.l_nav_btn {
  float: left;
  width: 50%;
  height: 90px;
  text-align: center;
  background: #fff;
  font-size: 14px;
}

.l_nav_btn a {
  display: block;
  height: 90px;
  padding-top: 60px;
  text-decoration: none;
  color: #fff;
  background-color: #2cad88;
  background-repeat: no-repeat;
  transition-property: all;
  transition-duration: 0.3s;
  transition-timing-function: ease;
}

.l_nav_btn a:hover {
  opacity: .8;
}

.l_nav_btn.resv a {
  background-image: url(../img/header/ico_env.png);
  background-position: center 25px;
}

.l_nav_btn.access {
  border-left: 1px solid #fff;
}

.l_nav_btn.access a {
  background-image: url(../img/header/ico_pin.png);
  background-position: center 20px;
}

.crumbs {
  color: #000;
  margin: 10px 0;
}

.crumbs li {
  display: inline;
}

/*-----------------------------------------------------
	フッター
-----------------------------------------------------*/
.pagetop {
  text-align: center;
  margin: 40px auto 30px;
}

.l-footer {
  width: 100%;
  background: #524131;
  color: #fff;
}

.l-footer .copyright {
  float: left;
  padding: 30px 0 30px 30px;
  font-size: 13px;
}

.l-footer .potalSecom {
  float: right;
  padding: 15px 30px 15px 0;
}

.f_nav {
  padding: 30px 30px 0;
}

.f_nav ul {
  overflow: hidden;
}

.f_nav li {
  width: 280px;
  float: left;
}

.f_nav li+li {
  margin-left: 30px;
}

.f_nav li a {
  background: #2cad88 url(../img/footer/arw01.png) no-repeat 20px center;
  color: #fff;
  text-decoration: none;
  display: block;
  line-height: 60px;
  padding-left: 56px;
  border-radius: 2px;
  transition-property: all;
  transition-duration: 0.3s;
  transition-timing-function: ease;
}

.f_nav li a:hover {
  opacity: .8;
}

.f_nav li.hotel a {
  background-color: #fff;
  background-image: none;
  text-align: center;
  padding: 0 20px;
}

.f_nav li.hotel a img {
  vertical-align: middle;
}

.f_nav_sp {
  width: 100%;
  height: 60px;
  position: fixed;
  z-index: 1001;
  left: 0;
  bottom: -60px;
}

.f_nav_sp.is_active {
  bottom: 0;
}

.f_nav_sp ul {
  overflow: hidden;
  margin: 0 -1px;
}

.f_nav_sp li {
  width: 25%;
  float: left;
  font-size: 11px;
}

.f_nav_sp li a {
  display: block;
  height: 60px;
  padding-top: 40px;
  text-align: center;
  text-decoration: none;
  color: #fff;
  background-color: #2cad88;
  background-repeat: no-repeat;
  background-position: center 10px;
  background-size: auto 22px;
  border-left: 1px solid #fff;
}

.f_nav_sp li.tel a {
  background-image: url(../img/footer/ico_mobile.png);
}

.f_nav_sp li.access a {
  background-image: url(../img/footer/ico_accese.png);
}

.f_nav_sp li.ticket a {
  background-image: url(../img/footer/ico_ticket.png);
}

.f_nav_sp li.resv {
  font-size: 10px;
}

.f_nav_sp li.resv a {
  background-image: url(../img/footer/ico_resv.png);
}

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
}

.slick-track:before,
.slick-track:after {
  content: "";
  display: table;
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}

[dir="rtl"] .slick-slide {
  float: right;
}

.slick-slide img {
  display: block;
}

.slick-slide.slick-loading img {
  display: none;
}

.slick-slide.dragging img {
  pointer-events: none;
}

.slick-initialized .slick-slide {
  display: block;
}

.slick-loading .slick-slide {
  visibility: hidden;
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

.slick-prev,
.slick-next {
  display: block;
  width: 50%;
  height: 100%;
  position: absolute;
  top: 0;
  margin: 0;
  padding: 0;
  border-radius: 0;
  border-style: none !important;
  border-width: 0 !important;
  border-color: transparent !important;
  outline: none;
  background: url(../img/index/index_bg03.png);
  z-index: 100;
  text-indent: -9999px;
  cursor: pointer;
}

.slick-prev::after,
.slick-next::after {
  content: "";
  display: block;
  width: 18px;
  height: 29px;
  background-repeat: no-repeat;
  background-position: center center;
  position: absolute;
  top: 50%;
  margin-top: -15px;
}

.slick-prev {
  right: 50%;
  margin-right: 400px;
}

.slick-prev::after {
  background-image: url(../img/index/prev.png);
  right: 30px;
}

.slick-next {
  left: 50%;
  margin-left: 400px;
}

.slick-next::after {
  background-image: url(../img/index/next.png);
  left: 30px;
}

.slick-dots {
  position: absolute;
  bottom: 15px;
  width: 100%;
  text-align: center;
}

.slick-dots li {
  display: inline-block;
}

.slick-dots li+li {
  margin-left: 5px;
}

.slick-dots li button {
  display: block;
  text-indent: -9999px;
  width: 30px;
  height: 5px;
  margin: 0;
  padding: 0;
  border-radius: 0;
  border-style: none !important;
  border-width: 0 !important;
  border-color: transparent !important;
  outline: none;
  background: rgba(255, 255, 255, 0.5);
}

.slick-dots li.slick-active button {
  background: white;
}

body.tef .cboxIframe {
  opacity: 0;
  min-width: 675px;
}

/*----------------------------------------------------
	共通スタイル
----------------------------------------------------*/
.extend_ttl01,
.tef_plan_ttl,
.tef_menu_ttl,
.tef_gallery_ttl,
.tef_access_ttl,
.tef_ticket_pop_ttl {
  font-size: 40px;
  font-weight: 300;
  line-height: 1 !important;
  text-align: center;
  color: #000;
}

.extend_sub01,
.tef_plan_ttl_sub,
.tef_menu_ttl_sub,
.tef_gallery_ttl_sub,
.tef_access_ttl_sub,
.tef_ticket_pop_ttl_sub {
  text-align: center;
  line-height: 1;
  margin: 15px auto 30px;
}

.extend_btn01,
.tef_plan_btn a,
.tef_ticket_pop_print a,
.tef_ticket_pop_close a {
  background-color: #2cad88;
  color: #fff;
  text-decoration: none;
  display: inline-block;
  line-height: 1;
  padding: 15px 40px;
  border-radius: 2px;
  transition-property: all;
  transition-duration: 0.3s;
  transition-timing-function: ease;
}

.extend_btn01:hover,
.tef_plan_btn a:hover,
.tef_ticket_pop_print a:hover,
.tef_ticket_pop_close a:hover {
  opacity: .8;
}

/*----------------------------------------------------
	ページのスタイル
----------------------------------------------------*/
.main_visual {
  background: url(../img/index/main01_20250703.jpg) no-repeat center center;
  position: relative;
  opacity: 0;
}

.main_visual .container {
  position: relative;
  min-height: 500px;
}

.main_front {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 270px;
  background: #fff;
}

.main_front_logo {
  text-align: center;
  padding: 47px 0 30px;
}

.main_front_sub {
  text-align: center;
  line-height: 1.4;
  font-size: 14px;
}

.main_front_nav {
  position: absolute;
  right: auto;
  top: auto;
  left: 0;
  bottom: 0;
}

.tef_intro {
  text-align: center;
  background: url(../img/index/index_bg01.jpg) no-repeat center top;
  padding-top: 70px;
  min-height: 353px;
}

.tef_intro_lead {
  font-size: 30px;
  color: #000;
  line-height: 1.2;
}

.tef_intro_sub {
  font-size: 18px;
  font-weight: 300;
  color: #000;
  letter-spacing: 1px;
  margin: 20px auto;
}

.tef_intro_sub::before,
.tef_intro_sub::after {
  content: "";
  display: inline-block;
  width: 72px;
  height: 16px;
  background-repeat: no-repeat;
  vertical-align: middle;
  margin-top: -3px;
}

.tef_intro_sub::before {
  background-image: url(../img/index/line03_01.png);
  margin-right: 15px;
}

.tef_intro_sub::after {
  background-image: url(../img/index/line03_02.png);
  margin-left: 15px;
}

.info_box {
  display: block;
  border: 1px solid #d5d5d5;
  padding: 25px;
  margin: 30px 0 60px;
}

.info_box dl dt {
  display: inline-block;
  margin: 0 10px 0 0;
}

.info_box dl dt.tag {
  background: #000;
  color: #fff;
  font-size: 0.8em;
  padding: 1px 10px;
}

.info_box dl dd {
  display: inline-block;
}

.tef_plan {
  margin: 60px auto;
}

.tef_plan_txt {
  width: 430px;
  float: left;
  text-align: center;
  position: relative;
  padding-top: 25px;
}

.tef_plan_ttl .amp {
  font-size: 32px;
}

.tef_plan_btn {
  margin-top: 20px;
}

.tef_ticket {
  margin-bottom: 20px;
  text-align: left;
}

.tef_plan_img {
  width: 510px;
  float: right;
}

.tef_plan_img ul {
  overflow: hidden;
  margin: -10px 0 0 -10px;
}

.tef_plan_img li {
  float: left;
  margin: 10px 0 0 10px;
}

.tef_menu {
  color: #fff;
  background: url(../img/index/index_bg02.jpg) no-repeat center center;
  padding: 50px 0 60px;
}

.tef_menu .row {
  padding: 0 40px;
}

.tef_menu_ttl {
  position: relative;
  color: #fff;
}

.tef_menu_ttl::before {
  content: "";
  display: block;
  background: url(../img/index/line01.png) no-repeat;
  width: 202px;
  height: 34px;
  margin: 0 auto 15px;
}

.tef_menu_single {
  width: 240px;
  float: left;
}

.tef_menu_single+.tef_menu_single {
  margin-left: 80px;
}

.tef_menu_single a {
  display: block;
  color: #fff;
  text-decoration: none;
  padding-bottom: 20px;
  background: url(../img/index/arw04.png) no-repeat 95% bottom;
  transition-property: all;
  transition-duration: 0.3s;
  transition-timing-function: ease;
}

.tef_menu_single a:hover {
  background-position: 100% bottom;
}

.tef_menu_single a:hover .tef_menu_thumbnail .en {
  top: 0;
}

.tef_menu_single.menu03 .en {
  padding-top: 91px;
}

.tef_menu_single.menu03 .tef_menu_name {
  line-height: 2.8;
}

.tef_menu_thumbnail {
  display: block;
  position: relative;
  overflow: hidden;
  width: 210px;
  height: 210px;
  border-radius: 105px;
  margin: 0 auto 20px;
}

.tef_menu_thumbnail .en {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: -100%;
  color: #fff;
  background: rgba(44, 173, 136, 0.4);
  font-size: 20px;
  font-weight: 300;
  text-align: center;
  padding-top: 75px;
  line-height: 1.4;
  transition-property: all;
  transition-duration: 0.3s;
  transition-timing-function: ease;
}

.tef_menu_name {
  color: #000;
  font-size: 22px;
  text-align: center;
  line-height: 1.2;
}

.tef_menu_content {
  line-height: 1.6;
  margin: 15px -8px 0 8px;
}

.tef_gallery,
.tef_access {
  margin: 60px auto;
}

.tef_gallery_ttl,
.tef_access_ttl {
  position: relative;
}

.tef_gallery_ttl::before,
.tef_access_ttl::before {
  content: "";
  display: block;
  background: url(../img/index/line02.png) no-repeat;
  width: 241px;
  height: 41px;
  margin: 0 auto 15px;
}

.tef_gallery_slide {
  overflow: hidden;
  max-height: 500px;
}

.tef_gallery_slide .slide {
  position: relative;
}

.tef_access_map {
  width: 100%;
  height: 400px;
}

.tef_access_info {
  margin-top: 20px;
}

.tef_access_info th,
.tef_access_info td {
  font-weight: normal;
  text-align: left;
  border-style: none;
  border-bottom: 1px solid #d5d5d5;
  padding: .5em 2em .5em 0;
}

.tef_access_info th {
  width: 6em;
}

.tef_access_info td {
  padding: .5em 0;
}

.tef_access_info td dl {
  overflow: hidden;
}

.tef_access_info td dt {
  float: left;
  clear: left;
  display: block;
  width: 5em;
}

.tef_access_info td dd {
  overflow: hidden;
}

.tef_access_info01,
.tef_access_info02 {
  width: 465px;
  float: left;
}

.tef_access_info02 {
  float: right;
}

.tef_ticket_pop {
  width: auto;
  max-width: 700px;
  padding: 35px;
}

.tef_ticket_pop_content {
  text-align: center;
}

.tef_ticket_pop_head {
  background: #2cad88;
  color: #fff;
  text-align: center;
  font-size: 18px;
  margin: 25px -35px;
  padding: 7px 0;
}

.tef_ticket_pop_ticket {
  text-align: center;
  margin-right: -20px;
}

.tef_ticket_pop_print {
  text-align: center;
  margin-top: 25px;
}

.tef_ticket_pop_print a {
  background: #ea6060;
}

.tef_ticket_pop_close {
  text-align: center;
  margin-top: 25px;
}

.tef_ticket_pop_close a {
  background: #c2baa6;
}

/*-------------------------------------
    メディアクエリ用
--------------------------------------*/
/* スマホ
-------------------------------------------------- */
@media only screen and (max-width: 767px) {
  body.tef .cboxIframe {
    overflow: auto;
    display: block;
    width: 100%;
    height: 100%;
  }

  #page {
    width: 100%;
    overflow: hidden;
    padding-bottom: 60px;
    font-size: 14px;
    font-size: 1.4rem;
  }

  .l-contents {
    line-height: 1.6;
  }

  .l-contents * {
    line-height: 1.6;
  }

  .l-header {
    display: none;
  }

  .l-header-sp {
    position: relative;
    z-index: 1002;
  }

  .l-header-sp .logo {
    height: 70px;
    background: #fff;
    text-align: center;
    position: relative;
    z-index: 2;
  }

  .l-header-sp .logo img {
    max-height: 60px;
    margin: 5px 0;
  }

  .menu_ico {
    cursor: pointer;
    background: url(../img/header/ico_menu.png) no-repeat center center;
    background-size: auto 30%;
    width: 70px;
    height: 70px;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 2;
    transition-property: all;
    transition-duration: 0.3s;
    transition-timing-function: ease;
  }

  .menu_ico.is_active {
    background-image: url(../img/header/ico_close.png);
  }

  .spnavi {
    width: 100%;
    position: absolute;
    left: 0;
    top: -200%;
    background: rgba(255, 255, 255, 0.9);
    z-index: 1;
    transition-property: all;
    transition-duration: 0.3s;
    transition-timing-function: ease;
  }

  .spnavi.is_active {
    top: 70px;
  }

  .spnavi li {
    border-bottom: 1px dotted #000;
  }

  .spnavi li a {
    display: block;
    color: #000;
    text-decoration: none;
    padding: 15px 15px 15px 25px;
    background: url(../img/header/arw05.png) no-repeat 15px center;
  }

  .l_nav,
  .main_front_nav {
    display: none;
    height: 72px;
  }

  .main_visual {
    background-image: url(../img/index/sp_main01_20250703.jpg);
    background-position: center bottom;
    background-size: 100% auto;
    height: 0;
    padding-top: 62.5%;
  }

  .main_front {
    display: none;
  }

  .extend_ttl01,
  .tef_plan_ttl,
  .tef_menu_ttl,
  .tef_gallery_ttl,
  .tef_access_ttl,
  .tef_ticket_pop_ttl {
    font-size: 34px;
  }

  .tef_intro {
    margin: 40px auto;
    padding: 0 15px;
    min-height: 0;
    background: #fff;
  }

  .tef_intro_lead {
    font-size: 21px;
    margin-right: -.25em;
  }

  .tef_intro_sub {
    font-size: 18px;
  }

  .tef_intro_sub::before,
  .tef_intro_sub::after {
    display: none;
  }

  .tef_menu {
    background: #7ac6b1;
    padding: 30px 0 40px;
  }

  .tef_menu .row {
    padding: 0;
  }

  .tef_menu_ttl::before {
    display: none;
  }

  .tef_menu_single {
    width: 100%;
    float: none;
    margin: 0 auto;
  }

  .tef_menu_single+.tef_menu_single {
    margin: 20px auto 0;
  }

  .tef_menu_name {
    line-height: 1.4 !important;
  }

  .tef_menu_thumbnail {
    margin-bottom: 15px;
  }

  .tef_menu_content {
    margin: 7px 15px 0;
  }

  .info_box {
    padding: 20px;
    margin: 30px 0 0;
  }

  .info_box dl dt {
    margin: 0 5px 5px;
  }

  .tef_plan {
    margin: 40px auto;
    padding: 0 15px;
  }

  .tef_plan_ttl .amp {
    font-size: 26px;
  }

  .tef_plan_txt {
    width: 100%;
    margin-right: 0;
    float: none;
  }

  .tef_plan_content {
    margin: 0;
  }

  .tef_ticket {
    margin-left: -15px;
    margin-right: -5px;
    text-align: center;
  }

  .tef_plan_img {
    display: none;
  }

  .tef_gallery_ttl::before,
  .tef_gallery_ttl::after,
  .tef_access_ttl::before,
  .tef_access_ttl::after {
    display: none;
  }

  .tef_access_info {
    padding: 0 15px;
  }

  .tef_access_info01,
  .tef_access_info02 {
    width: auto;
    float: none;
  }

  .l-footer .copyright {
    padding: 15px 0;
    text-align: center;
    float: none;
  }

  .l-footer .potalSecom {
    float: none;
    text-align: center;
    padding: 0 0 15px;
  }

  .f_nav {
    padding: 15px;
  }

  .f_nav ul {
    overflow: hidden;
  }

  .f_nav li {
    width: auto;
    float: none;
  }

  .f_nav li+li {
    margin-left: 0;
    margin-top: 10px;
  }

  .f_nav li a {
    padding-left: 36px;
    background-position: 10px center;
  }

  .slick-prev,
  .slick-next {
    background-image: none;
  }

  .slick-prev {
    right: 95%;
    margin: 0;
  }

  .slick-prev::after {
    right: 0;
  }

  .slick-next {
    left: 95%;
    margin: 0;
  }

  .slick-next::after {
    left: 0;
  }

  .tef_ticket_pop {
    padding: 15px;
  }

  .tef_ticket_pop_content {
    font-size: 14px;
  }

  .tef_ticket_pop_head {
    font-size: 16px;
    margin: 15px -15px;
  }

  .tef_ticket_pop_print {
    margin-top: 15px;
  }

  .tef_ticket_pop_close {
    margin-top: 15px;
  }

  .table-responsive {
    width: 100%;
    margin-bottom: 15px;
    overflow-y: hidden;
    overflow-x: scroll;
  }

  .table-responsive tbody {
    width: auto;
    position: relative;
    overflow-x: auto;
    white-space: nowrap;
  }

  .table-responsive tr {
    vertical-align: top;
  }

  .m-contact .contactForm th,
  .m-contact .contactForm td {
    display: block;
  }

  .m-contact .contactForm td input {
    width: 100%;
  }

  .m-contact .contactForm td textarea {
    width: 100%;
  }

  .m-contact .contactForm td.zip input,
  .m-contact .contactForm td.tel input {
    width: auto;
  }
}

/* タブレット
-------------------------------------------------- */
@media only screen and (min-width: 768px) and (max-width: 959px) {
  body {
    min-width: 960px;
  }
}

/* PC(small)
-------------------------------------------------- */
/* PC(large)
-------------------------------------------------- */
@media only screen and (min-width: 1600px) {
  .main_visual {
    background-size: cover;
  }

  .tef_menu {
    background-size: cover;
  }
}

/* SP
-------------------------------------------------- */
@media only screen and (max-width: 480px) {

  .main_visual .container {
    min-height: 0px;
  }