@charset "UTF-8";
html {
  font-family: sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  text-rendering: optimizeLegibility;
  font-feature-settings: "kern";
  -webkit-font-feature-settings: "kern";
  -moz-font-feature-settings: "kern";
  -moz-font-feature-settings: "kern=1";
  -webkit-font-smoothing: antialiased;
}

* {
  margin: 0;
  padding: 0;
}

/* ---------------------------------------- */
button::-moz-focus-inner {
  border: 0;
}

/* ---------------------------------------- */
a {
  background: transparent;
}

a:focus {
  outline: none;
  border: 0;
}

a:active,
a:hover {
  outline: 0;
}

/* ---------------------------------------- */
h1, h2, h3, h4, h5 {
  font-weight: normal;
  font-size: 100%;
}

b,
strong {
  font-weight: bold;
}

mark {
  background: #ff0;
  color: #000;
}

small {
  font-size: 80%;
}

li {
  list-style: none;
}

/* ---------------------------------------- */
img {
  border: 0;
  vertical-align: bottom;
}

/* ---------------------------------------- */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

/* ---------------------------------------- */
.cf, .clearfix:before,
.cf, .clearfix:after {
  content: " ";
  display: table;
}

.cf, .clearfix:after {
  clear: both;
}

.cf, .clearfix {
  *zoom: 1;
}

/* ---------------------------------------- */
.mb0 {
  margin-bottom: 0px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.mb110 {
  margin-bottom: 110px !important;
}

.mb120 {
  margin-bottom: 120px !important;
}

.mb130 {
  margin-bottom: 130px !important;
}

.mb140 {
  margin-bottom: 140px !important;
}

.mb150 {
  margin-bottom: 150px !important;
}

.mb160 {
  margin-bottom: 160px !important;
}

.mb170 {
  margin-bottom: 170px !important;
}

.mb180 {
  margin-bottom: 180px !important;
}

.mb190 {
  margin-bottom: 190px !important;
}

.mb200 {
  margin-bottom: 200px !important;
}

.mt0 {
  margin-top: 0px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mt70 {
  margin-top: 70px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mt90 {
  margin-top: 90px !important;
}

.mt100 {
  margin-top: 100px !important;
}

.mt110 {
  margin-top: 110px !important;
}

.mt120 {
  margin-top: 120px !important;
}

.mt130 {
  margin-top: 130px !important;
}

.mt140 {
  margin-top: 140px !important;
}

.mt150 {
  margin-top: 150px !important;
}

.mt160 {
  margin-top: 160px !important;
}

.mt170 {
  margin-top: 170px !important;
}

.mt180 {
  margin-top: 180px !important;
}

.mt190 {
  margin-top: 190px !important;
}

.mt200 {
  margin-top: 200px !important;
}

.mr0 {
  margin-right: 0px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.mr60 {
  margin-right: 60px !important;
}

.mr70 {
  margin-right: 70px !important;
}

.mr80 {
  margin-right: 80px !important;
}

.mr90 {
  margin-right: 90px !important;
}

.mr100 {
  margin-right: 100px !important;
}

.ml0 {
  margin-left: 0px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.ml60 {
  margin-left: 60px !important;
}

.ml70 {
  margin-left: 70px !important;
}

.ml80 {
  margin-left: 80px !important;
}

.ml90 {
  margin-left: 90px !important;
}

.ml100 {
  margin-left: 100px !important;
}

.pd0 {
  padding-top: 0;
}

.pd10 {
  padding: 10px !important;
}

.pd20 {
  padding: 20px !important;
}

.pd30 {
  padding: 30px !important;
}

.pd40 {
  padding: 40px !important;
}

.pd50 {
  padding: 50px !important;
}

.pd60 {
  padding: 60px !important;
}

.pd70 {
  padding: 70px !important;
}

.pd80 {
  padding: 80px !important;
}

.pd90 {
  padding: 90px !important;
}

.pd100 {
  padding: 100px !important;
}

.pt0 {
  padding-top: 0;
}

.pt10 {
  padding-top: 10px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pt60 {
  padding-top: 60px !important;
}

.pt70 {
  padding-top: 70px !important;
}

.pt80 {
  padding-top: 80px !important;
}

.pt90 {
  padding-top: 90px !important;
}

.pt100 {
  padding-top: 100px !important;
}

.pb0 {
  padding-bottom: 0;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.pb60 {
  padding-bottom: 60px !important;
}

.pb70 {
  padding-bottom: 70px !important;
}

.pb80 {
  padding-bottom: 80px !important;
}

.pb90 {
  padding-bottom: 90px !important;
}

.pb100 {
  padding-bottom: 100px !important;
}

.pr0 {
  padding-right: 0;
}

.pr10 {
  padding-right: 10px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.pr60 {
  padding-right: 60px !important;
}

.pr70 {
  padding-right: 70px !important;
}

.pr80 {
  padding-right: 80px !important;
}

.pr90 {
  padding-right: 90px !important;
}

.pr100 {
  padding-right: 100px !important;
}

.pl0 {
  padding-left: 0;
}

.pl10 {
  padding-left: 10px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.pl60 {
  padding-left: 60px !important;
}

.pl70 {
  padding-left: 70px !important;
}

.pl80 {
  padding-left: 80px !important;
}

.pl90 {
  padding-left: 90px !important;
}

.pl100 {
  padding-left: 100px !important;
}

@media screen and (max-width: 991px) {
  .mb10 {
    margin-bottom: 5px !important;
  }
  .mb20 {
    margin-bottom: 10px !important;
  }
  .mb30 {
    margin-bottom: 15px !important;
  }
  .mb40 {
    margin-bottom: 20px !important;
  }
  .mb50 {
    margin-bottom: 25px !important;
  }
  .mb60 {
    margin-bottom: 30px !important;
  }
  .mb70 {
    margin-bottom: 35px !important;
  }
  .mb80 {
    margin-bottom: 40px !important;
  }
  .mb90 {
    margin-bottom: 45px !important;
  }
  .mb100 {
    margin-bottom: 50px !important;
  }
  .mb110 {
    margin-bottom: 55px !important;
  }
  .mb120 {
    margin-bottom: 60px !important;
  }
  .mb130 {
    margin-bottom: 65px !important;
  }
  .mb140 {
    margin-bottom: 70px !important;
  }
  .mb150 {
    margin-bottom: 75px !important;
  }
  .mb160 {
    margin-bottom: 80px !important;
  }
  .mb170 {
    margin-bottom: 85px !important;
  }
  .mb180 {
    margin-bottom: 90px !important;
  }
  .mb190 {
    margin-bottom: 95px !important;
  }
  .mb200 {
    margin-bottom: 100px !important;
  }
  .mt10 {
    margin-top: 5px !important;
  }
  .mt20 {
    margin-top: 10px !important;
  }
  .mt30 {
    margin-top: 15px !important;
  }
  .mt40 {
    margin-top: 20px !important;
  }
  .mt50 {
    margin-top: 25px !important;
  }
  .mt60 {
    margin-top: 30px !important;
  }
  .mt70 {
    margin-top: 35px !important;
  }
  .mt80 {
    margin-top: 40px !important;
  }
  .mt90 {
    margin-top: 45px !important;
  }
  .mt100 {
    margin-top: 50px !important;
  }
  .mt110 {
    margin-top: 55px !important;
  }
  .mt120 {
    margin-top: 60px !important;
  }
  .mt130 {
    margin-top: 65px !important;
  }
  .mt140 {
    margin-top: 70px !important;
  }
  .mt150 {
    margin-top: 75px !important;
  }
  .mt160 {
    margin-top: 80px !important;
  }
  .mt170 {
    margin-top: 85px !important;
  }
  .mt180 {
    margin-top: 90px !important;
  }
  .mt190 {
    margin-top: 95px !important;
  }
  .mt200 {
    margin-top: 100px !important;
  }
  .mr20 {
    margin-right: 10px !important;
  }
  .mr30 {
    margin-right: 15px !important;
  }
  .mr40 {
    margin-right: 20px !important;
  }
  .mr50 {
    margin-right: 25px !important;
  }
  .mr60 {
    margin-right: 30px !important;
  }
  .mr70 {
    margin-right: 35px !important;
  }
  .mr80 {
    margin-right: 40px !important;
  }
  .mr90 {
    margin-right: 45px !important;
  }
  .mr100 {
    margin-right: 50px !important;
  }
  .ml20 {
    margin-left: 10px !important;
  }
  .ml30 {
    margin-left: 15px !important;
  }
  .ml40 {
    margin-left: 20px !important;
  }
  .ml50 {
    margin-left: 25px !important;
  }
  .ml60 {
    margin-left: 30px !important;
  }
  .ml70 {
    margin-left: 35px !important;
  }
  .ml80 {
    margin-left: 40px !important;
  }
  .ml90 {
    margin-left: 45px !important;
  }
  .ml100 {
    margin-left: 50px !important;
  }
  .pd0 {
    padding-top: 0;
  }
  .pd10 {
    padding: 5px !important;
  }
  .pd20 {
    padding: 10px !important;
  }
  .pd30 {
    padding: 15px !important;
  }
  .pd40 {
    padding: 20px !important;
  }
  .pd50 {
    padding: 25px !important;
  }
  .pd60 {
    padding: 30px !important;
  }
  .pd70 {
    padding: 35px !important;
  }
  .pd80 {
    padding: 40px !important;
  }
  .pd90 {
    padding: 45px !important;
  }
  .pd100 {
    padding: 50px !important;
  }
  .pt0 {
    padding-top: 0;
  }
  .pt10 {
    padding-top: 10px !important;
  }
  .pt20 {
    padding-top: 10px !important;
  }
  .pt30 {
    padding-top: 15px !important;
  }
  .pt40 {
    padding-top: 20px !important;
  }
  .pt50 {
    padding-top: 25px !important;
  }
  .pt60 {
    padding-top: 30px !important;
  }
  .pt70 {
    padding-top: 35px !important;
  }
  .pt80 {
    padding-top: 40px !important;
  }
  .pt90 {
    padding-top: 45px !important;
  }
  .pt100 {
    padding-top: 50px !important;
  }
  .pb0 {
    padding-bottom: 0;
  }
  .pb10 {
    padding-bottom: 10px !important;
  }
  .pb20 {
    padding-bottom: 10px !important;
  }
  .pb30 {
    padding-bottom: 15px !important;
  }
  .pb40 {
    padding-bottom: 20px !important;
  }
  .pb50 {
    padding-bottom: 25px !important;
  }
  .pb60 {
    padding-bottom: 30px !important;
  }
  .pb70 {
    padding-bottom: 35px !important;
  }
  .pb80 {
    padding-bottom: 40px !important;
  }
  .pb90 {
    padding-bottom: 45px !important;
  }
  .pb100 {
    padding-bottom: 50px !important;
  }
  .pr0 {
    padding-right: 0;
  }
  .pr10 {
    padding-right: 10px !important;
  }
  .pr20 {
    padding-right: 10px !important;
  }
  .pr30 {
    padding-right: 15px !important;
  }
  .pr40 {
    padding-right: 20px !important;
  }
  .pr50 {
    padding-right: 25px !important;
  }
  .pr60 {
    padding-right: 30px !important;
  }
  .pr70 {
    padding-right: 35px !important;
  }
  .pr80 {
    padding-right: 40px !important;
  }
  .pr90 {
    padding-right: 45px !important;
  }
  .pr100 {
    padding-right: 50px !important;
  }
  .pl0 {
    padding-left: 0;
  }
  .pl10 {
    padding-left: 10px !important;
  }
  .pl20 {
    padding-left: 10px !important;
  }
  .pl30 {
    padding-left: 15px !important;
  }
  .pl40 {
    padding-left: 20px !important;
  }
  .pl50 {
    padding-left: 25px !important;
  }
  .pl60 {
    padding-left: 30px !important;
  }
  .pl70 {
    padding-left: 35px !important;
  }
  .pl80 {
    padding-left: 40px !important;
  }
  .pl90 {
    padding-left: 45px !important;
  }
  .pl100 {
    padding-left: 50px !important;
  }
}

@media screen and (max-width: 599px) {
  .xs-mb0 {
    margin-bottom: 0px !important;
  }
  .xs-mb10 {
    margin-bottom: 10px !important;
  }
  .xs-mb20 {
    margin-bottom: 20px !important;
  }
  .xs-mb30 {
    margin-bottom: 30px !important;
  }
  .xs-mb40 {
    margin-bottom: 40px !important;
  }
  .xs-mb50 {
    margin-bottom: 50px !important;
  }
  .xs-mb60 {
    margin-bottom: 60px !important;
  }
  .xs-mb70 {
    margin-bottom: 70px !important;
  }
  .xs-mb80 {
    margin-bottom: 80px !important;
  }
  .xs-mb90 {
    margin-bottom: 90px !important;
  }
  .xs-mb100 {
    margin-bottom: 100px !important;
  }
  .xs-mt0 {
    margin-top: 0px !important;
  }
  .xs-mt5 {
    margin-top: 5px !important;
  }
  .xs-mt10 {
    margin-top: 10px !important;
  }
  .xs-mt20 {
    margin-top: 20px !important;
  }
  .xs-mt30 {
    margin-top: 30px !important;
  }
  .xs-mt40 {
    margin-top: 40px !important;
  }
  .xs-mt50 {
    margin-top: 50px !important;
  }
  .xs-mt60 {
    margin-top: 60px !important;
  }
  .xs-mt70 {
    margin-top: 70px !important;
  }
  .xs-mt80 {
    margin-top: 80px !important;
  }
  .xs-mt90 {
    margin-top: 90px !important;
  }
  .xs-mt100 {
    margin-top: 100px !important;
  }
  .xs-center {
    text-align: center;
  }
  .xs-left {
    text-align: left;
  }
  .xs-right {
    text-align: right;
  }
}

@media screen and (min-width: 600px) and (max-width: 991px) {
  .sm-mb0 {
    margin-bottom: 0px !important;
  }
  .sm-mb10 {
    margin-bottom: 10px !important;
  }
  .sm-mb20 {
    margin-bottom: 20px !important;
  }
  .sm-mb30 {
    margin-bottom: 30px !important;
  }
  .sm-mb40 {
    margin-bottom: 40px !important;
  }
  .sm-mb50 {
    margin-bottom: 50px !important;
  }
  .sm-mb60 {
    margin-bottom: 60px !important;
  }
  .sm-mb70 {
    margin-bottom: 70px !important;
  }
  .sm-mb80 {
    margin-bottom: 80px !important;
  }
  .sm-mb90 {
    margin-bottom: 90px !important;
  }
  .sm-mb100 {
    margin-bottom: 100px !important;
  }
  .sm-mt0 {
    margin-top: 0px !important;
  }
  .sm-mt10 {
    margin-top: 10px !important;
  }
  .sm-mt20 {
    margin-top: 20px !important;
  }
  .sm-mt30 {
    margin-top: 30px !important;
  }
  .sm-mt40 {
    margin-top: 40px !important;
  }
  .sm-mt50 {
    margin-top: 50px !important;
  }
  .sm-mt60 {
    margin-top: 60px !important;
  }
  .sm-mt70 {
    margin-top: 70px !important;
  }
  .sm-mt80 {
    margin-top: 80px !important;
  }
  .sm-mt90 {
    margin-top: 90px !important;
  }
  .sm-mt100 {
    margin-top: 100px !important;
  }
  .sm-center {
    text-align: center;
  }
  .sm-left {
    text-align: left;
  }
  .sm-right {
    text-align: right;
  }
}

@media screen and (min-width: 992px) and (max-width: 992px) {
  .md-mb0 {
    margin-bottom: 0px !important;
  }
  .md-mb10 {
    margin-bottom: 10px !important;
  }
  .md-mb20 {
    margin-bottom: 20px !important;
  }
  .md-mb30 {
    margin-bottom: 30px !important;
  }
  .md-mb40 {
    margin-bottom: 40px !important;
  }
  .md-mb50 {
    margin-bottom: 50px !important;
  }
  .md-mb60 {
    margin-bottom: 60px !important;
  }
  .md-mb70 {
    margin-bottom: 70px !important;
  }
  .md-mb80 {
    margin-bottom: 80px !important;
  }
  .md-mb90 {
    margin-bottom: 90px !important;
  }
  .md-mb100 {
    margin-bottom: 100px !important;
  }
  .md-mt0 {
    margin-top: 0px !important;
  }
  .md-mt10 {
    margin-top: 10px !important;
  }
  .md-mt20 {
    margin-top: 20px !important;
  }
  .md-mt30 {
    margin-top: 30px !important;
  }
  .md-mt40 {
    margin-top: 40px !important;
  }
  .md-mt50 {
    margin-top: 50px !important;
  }
  .md-mt60 {
    margin-top: 60px !important;
  }
  .md-mt70 {
    margin-top: 70px !important;
  }
  .md-mt80 {
    margin-top: 80px !important;
  }
  .md-mt90 {
    margin-top: 90px !important;
  }
  .md-mt100 {
    margin-top: 100px !important;
  }
  .md-center {
    text-align: center;
  }
  .md-left {
    text-align: left;
  }
  .md-right {
    text-align: right;
  }
}

@media screen and (min-width: 1200px) {
  .lg-mb0 {
    margin-bottom: 0px !important;
  }
  .lg-mb10 {
    margin-bottom: 10px !important;
  }
  .lg-mb20 {
    margin-bottom: 20px !important;
  }
  .lg-mb30 {
    margin-bottom: 30px !important;
  }
  .lg-mb40 {
    margin-bottom: 40px !important;
  }
  .lg-mb50 {
    margin-bottom: 50px !important;
  }
  .lg-mb60 {
    margin-bottom: 60px !important;
  }
  .lg-mb70 {
    margin-bottom: 70px !important;
  }
  .lg-mb80 {
    margin-bottom: 80px !important;
  }
  .lg-mb90 {
    margin-bottom: 90px !important;
  }
  .lg-mb100 {
    margin-bottom: 100px !important;
  }
  .lg-mt0 {
    margin-top: 0px !important;
  }
  .lg-mt10 {
    margin-top: 10px !important;
  }
  .lg-mt20 {
    margin-top: 20px !important;
  }
  .lg-mt30 {
    margin-top: 30px !important;
  }
  .lg-mt40 {
    margin-top: 40px !important;
  }
  .lg-mt50 {
    margin-top: 50px !important;
  }
  .lg-mt60 {
    margin-top: 60px !important;
  }
  .lg-mt70 {
    margin-top: 70px !important;
  }
  .lg-mt80 {
    margin-top: 80px !important;
  }
  .lg-mt90 {
    margin-top: 90px !important;
  }
  .lg-mt100 {
    margin-top: 100px !important;
  }
  .lg-center {
    text-align: center;
  }
  .lg-left {
    text-align: left;
  }
  .lg-right {
    text-align: right;
  }
}

@media screen and (min-width: 768px) {
  .row-0 {
    margin-left: 0px;
    margin-right: 0px;
  }
  .row-0 > div {
    padding-right: 0px;
    padding-left: 0px;
  }
  .row-10 {
    margin-left: -5px;
    margin-right: -5px;
  }
  .row-10 > div {
    padding-right: 5px;
    padding-left: 5px;
  }
  .row-20 {
    margin-left: -10px;
    margin-right: -10px;
  }
  .row-20 > div {
    padding-right: 10px;
    padding-left: 10px;
  }
  .row-30 {
    margin-left: -15px;
    margin-right: -15px;
  }
  .row-30 > div {
    padding-right: 15px;
    padding-left: 15px;
  }
  .row-40 {
    margin-left: -20px;
    margin-right: -20px;
  }
  .row-40 > div {
    padding-right: 20px;
    padding-left: 20px;
  }
  .row-50 {
    margin-left: -25px;
    margin-right: -25px;
  }
  .row-50 > div {
    padding-right: 25px;
    padding-left: 25px;
  }
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

img.full {
  width: 100%;
  height: auto;
}

img.round {
  border-radius: 3px;
}

a:hover img {
  opacity: 0.8;
}

/*
Phones (768px未満)
Tablets (768px〜991px)
Desktops (992px〜1199px)
Desktops (1200px以上)
*/
/* ---------------------------------------- */
body {
  line-height: 1.8;
  font-size: 15px;
  text-align: left;
  color: #262626;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  -webkit-text-size-adjust: none;
}

/* ---------------------------------------- */
a {
  color: #262626;
}

a:hover {
  color: #333;
}

/* ---------------------------------------- */
header {
  padding: 25px 0 25px 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  header img {
    max-height: 140px;
    width: auto;
  }
}

@media screen and (min-width: 768px) {
  header {
    padding: 50px 0 50px 0;
  }
}

/* ---------------------------------------- */
@media screen and (max-width: 767px) {
  .container {
    margin: 0 15px;
  }
}

@media screen and (min-width: 1200px) {
  .container {
    width: 1200px;
    margin: 0 auto;
  }
}

/* ---------------------------------------- */
.h1 {
  font-size: 160%;
  text-align: center;
  letter-spacing: 1px;
}

.h2 {
  font-weight: bold;
  font-size: 116%;
}

.h3 {
  font-weight: bold;
  font-size: 115%;
}

.h3-en {
  font-size: 76%;
  color: #b07f2a;
}

.h4 {
  font-weight: bold;
  font-size: 108%;
}

@media screen and (min-width: 768px) {
  .h1 {
    font-size: 180%;
    letter-spacing: 2px;
  }
  .h2 {
    font-size: 128%;
  }
  .h3 {
    font-size: 118%;
  }
  .h4 {
    font-size: 105%;
  }
  br.forsp {
    display: none;
  }
}

@media screen and (min-width: 992px) {
  .h1 {
    font-size: 200%;
    letter-spacing: 2px;
  }
  .h2 {
    font-size: 125%;
  }
  .h3 {
    font-size: 120%;
  }
  .h4 {
    font-size: 110%;
  }
  br.forsp {
    display: none;
  }
}

.h-ic {
  padding-left: 24px;
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 14px 14px;
  background-image: url(../images/common/ic_ensou.png);
}

@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx) {
  .h-ic {
    background-image: url(../images/common/ic_ensou@2x.png);
  }
}

strong {
  font-weight: bold;
}

.price {
  color: #a33333;
}

.center {
  text-align: center;
}

.small {
  font-size: 86%;
}

/* ---------------------------------------- */
#philosophy nav.pc ul li.philosophy img,
#menu nav.pc ul li.menu img,
#sobayazake nav.pc ul li.sobayazake img,
#gift nav.pc ul li.gift img,
#recipe nav.pc ul li.recipe img,
#color nav.pc ul li.color img,
#restaurant nav.pc ul li.restaurant img,
#diary nav.pc ul li.diary img,
#news nav.pc ul li.news img {
  border-bottom: solid 1px #b07f2a;
}

#restaurant nav.pc ul li.restaurant div img {
  border: none;
}

/* ---------------------------------------- */
nav.pc {
  margin-bottom: 30px;
  text-align: center;
}

nav.pc ul.gnav li {
  display: inline-block;
  margin: 0 25px;
}

nav.pc ul.social {
  position: absolute;
  top: 30px;
  right: 30px;
  width: 90px;
  height: 20px;
}

nav.pc ul.social li {
  float: left;
  width: 20px;
  margin-left: 25px;
}

/* ---------------------------------------- */
.btn-menu {
  position: absolute;
  top: 25px;
  right: 25px;
  background-image: url(../images/common/btn_menu.svg);
  background-position: center center;
  background-repeat: no-repeat;
  width: 30px;
  height: 30px;
}

@media screen and (min-width: 768px) {
  .btn-menu {
    display: none;
  }
}

.btn-menu-close {
  position: absolute;
  top: 25px;
  right: 25px;
  background-image: url(../images/common/btn_menu_close.svg);
  background-position: center center;
  background-repeat: no-repeat;
  width: 30px;
  height: 30px;
}

/* ---------------------------------------- */
nav.sp {
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 5;
  width: 100%;
  height: 100%;
}

nav.sp .bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  opacity: 1;
}

nav.sp ul.gnav {
  position: absolute;
  z-index: 10;
  margin: 80px 10% 0 10%;
  width: 80%;
}

nav.sp ul.gnav li {
  display: block;
  float: left;
  width: 50%;
  height: 70px;
  padding: 10px 0;
  text-align: center;
}

nav.sp ul.gnav li img {
  max-height: 32px;
  width: auto;
}

nav.sp ul.social {
  position: absolute;
  top: 430px;
  left: 0;
  width: 100%;
  height: 20px;
  text-align: center;
}

nav.sp ul.social li {
  display: inline-block;
}

nav.sp ul.social li a {
  display: block;
  padding: 20px;
}

/* ---------------------------------------- */
@media screen and (max-width: 767px) {
  nav.sp,
  nav.pc {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  nav.sp {
    display: none;
  }
}

/* ---------------------------------------- */
footer .info {
  background: url(../images/common/bg_02.gif);
  text-align: left;
  font-size: 93%;
}

footer h2 {
  font-weight: bold;
  font-size: 116%;
  letter-spacing: 1.2;
}

footer table th {
  white-space: nowrap;
}

footer table th,
footer table td {
  vertical-align: top;
}

footer .number {
  font-size: 180%;
}

#copyright {
  padding: 30px 0;
  text-align: center;
  line-height: 6px;
}

/* ---------------------------------------- */
#food {
  background: url(../images/restaurant/bg_01.jpg);
  border-radius: 5px;
  padding: 20px;
  margin-bottom: 30px;
}

#food h3 {
  font-weight: normal;
  font-size: 135%;
  margin-bottom: 10px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  #food p br {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  #food p {
    text-align: center;
  }
}

/* ---------------------------------------- */
#misoka {
  border-radius: 5px;
  border: solid 1px #eee;
  padding: 20px;
}

#misoka h3 {
  color: #b07f2a;
  font-weight: normal;
  font-size: 135%;
  margin-bottom: 10px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  #misoka p br {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  #misoka p {
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  #food,
  #misoka {
    padding: 15px;
  }
  #food h3,
  #misoka h3 {
    font-size: 116%;
  }
}

/* ---------------------------------------- */
#calendar .xo-month-wrap table.xo-month {
  border-top: solid 1px #ddd;
  border-left: solid 1px #ddd;
  background-color: #fff;
}

@media screen and (max-width: 599px) {
  #calendar .xo-month-wrap table.xo-month {
    width: 100%;
    margin-bottom: 20px;
  }
}

@media screen and (min-width: 600px) {
  #calendar .xo-month-wrap table.xo-month {
    width: 220px;
    float: left;
    margin-right: 30px;
  }
}

@media screen and (min-width: 992px) {
  #calendar .xo-month-wrap table.xo-month {
    width: 292px;
    float: left;
    margin-right: 30px;
  }
}

@media screen and (min-width: 1200px) {
  #calendar .xo-month-wrap table.xo-month {
    width: 370px;
    float: left;
    margin-right: 30px;
  }
}

#calendar .xo-month-wrap table.xo-month caption {
  text-align: center;
  font-weight: 600;
}

#calendar .xo-month-wrap table.xo-month caption button {
  display: none;
}

#calendar .xo-month-wrap table.xo-month tr th,
#calendar .xo-month-wrap table.xo-month tr td {
  width: 14.2857%;
  height: 30px;
  line-height: 30px;
  text-align: center;
  border-right: solid 1px #ddd;
  border-bottom: solid 1px #ddd;
}

#calendar .xo-month-wrap table.xo-month tr th {
  border-right: none;
}

#calendar .xo-month-wrap table.xo-month tr th:last-child {
  border-right: solid 1px #ddd;
}

#calendar .xo-month-wrap table.xo-month tr td table {
  width: 100%;
}

#calendar .xo-month-wrap table.xo-month tr td table tr th,
#calendar .xo-month-wrap table.xo-month tr td table tr td {
  border-right: none;
  border-bottom: none;
}

#calendar .xo-month-wrap table.xo-month tr td .month-dayname-space,
#calendar .xo-month-wrap table.xo-month tr td .month-event-space {
  display: none;
}

#calendar .holiday-titles,
#calendar .loading-animation {
  display: none;
}

.holiday {
  height: 16px;
  line-height: 16px;
}

.holiday-color {
  color: #eedebf;
  margin-right: 6px;
  font-weight: 600;
}
