@charset "UTF-8";
/*-----------------------------------------------------------------------------
	global modifier
-----------------------------------------------------------------------------*/
.pcmt0 {
  margin-top: 0px !important;
}

.pcmb0 {
  margin-bottom: 0px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb0 {
    margin-bottom: 0px !important;
  }
}

.pcpt0 {
  padding-top: 0px !important;
}

.pcpb0 {
  padding-bottom: 0px !important;
}

.pcmt5 {
  margin-top: 5px !important;
}

.pcmb5 {
  margin-bottom: 5px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb5 {
    margin-bottom: 2.5px !important;
  }
}

.pcpt5 {
  padding-top: 5px !important;
}

.pcpb5 {
  padding-bottom: 5px !important;
}

.pcmt10 {
  margin-top: 10px !important;
}

.pcmb10 {
  margin-bottom: 10px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb10 {
    margin-bottom: 5px !important;
  }
}

.pcpt10 {
  padding-top: 10px !important;
}

.pcpb10 {
  padding-bottom: 10px !important;
}

.pcmt15 {
  margin-top: 15px !important;
}

.pcmb15 {
  margin-bottom: 15px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb15 {
    margin-bottom: 7.5px !important;
  }
}

.pcpt15 {
  padding-top: 15px !important;
}

.pcpb15 {
  padding-bottom: 15px !important;
}

.pcmt20 {
  margin-top: 20px !important;
}

.pcmb20 {
  margin-bottom: 20px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb20 {
    margin-bottom: 10px !important;
  }
}

.pcpt20 {
  padding-top: 20px !important;
}

.pcpb20 {
  padding-bottom: 20px !important;
}

.pcmt25 {
  margin-top: 25px !important;
}

.pcmb25 {
  margin-bottom: 25px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb25 {
    margin-bottom: 12.5px !important;
  }
}

.pcpt25 {
  padding-top: 25px !important;
}

.pcpb25 {
  padding-bottom: 25px !important;
}

.pcmt30 {
  margin-top: 30px !important;
}

.pcmb30 {
  margin-bottom: 30px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb30 {
    margin-bottom: 15px !important;
  }
}

.pcpt30 {
  padding-top: 30px !important;
}

.pcpb30 {
  padding-bottom: 30px !important;
}

.pcmt35 {
  margin-top: 35px !important;
}

.pcmb35 {
  margin-bottom: 35px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb35 {
    margin-bottom: 17.5px !important;
  }
}

.pcpt35 {
  padding-top: 35px !important;
}

.pcpb35 {
  padding-bottom: 35px !important;
}

.pcmt40 {
  margin-top: 40px !important;
}

.pcmb40 {
  margin-bottom: 40px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb40 {
    margin-bottom: 20px !important;
  }
}

.pcpt40 {
  padding-top: 40px !important;
}

.pcpb40 {
  padding-bottom: 40px !important;
}

.pcmt45 {
  margin-top: 45px !important;
}

.pcmb45 {
  margin-bottom: 45px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb45 {
    margin-bottom: 22.5px !important;
  }
}

.pcpt45 {
  padding-top: 45px !important;
}

.pcpb45 {
  padding-bottom: 45px !important;
}

.pcmt50 {
  margin-top: 50px !important;
}

.pcmb50 {
  margin-bottom: 50px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb50 {
    margin-bottom: 25px !important;
  }
}

.pcpt50 {
  padding-top: 50px !important;
}

.pcpb50 {
  padding-bottom: 50px !important;
}

.pcmt55 {
  margin-top: 55px !important;
}

.pcmb55 {
  margin-bottom: 55px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb55 {
    margin-bottom: 27.5px !important;
  }
}

.pcpt55 {
  padding-top: 55px !important;
}

.pcpb55 {
  padding-bottom: 55px !important;
}

.pcmt60 {
  margin-top: 60px !important;
}

.pcmb60 {
  margin-bottom: 60px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb60 {
    margin-bottom: 30px !important;
  }
}

.pcpt60 {
  padding-top: 60px !important;
}

.pcpb60 {
  padding-bottom: 60px !important;
}

.pcmt65 {
  margin-top: 65px !important;
}

.pcmb65 {
  margin-bottom: 65px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb65 {
    margin-bottom: 32.5px !important;
  }
}

.pcpt65 {
  padding-top: 65px !important;
}

.pcpb65 {
  padding-bottom: 65px !important;
}

.pcmt70 {
  margin-top: 70px !important;
}

.pcmb70 {
  margin-bottom: 70px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb70 {
    margin-bottom: 35px !important;
  }
}

.pcpt70 {
  padding-top: 70px !important;
}

.pcpb70 {
  padding-bottom: 70px !important;
}

.pcmt75 {
  margin-top: 75px !important;
}

.pcmb75 {
  margin-bottom: 75px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb75 {
    margin-bottom: 37.5px !important;
  }
}

.pcpt75 {
  padding-top: 75px !important;
}

.pcpb75 {
  padding-bottom: 75px !important;
}

.pcmt80 {
  margin-top: 80px !important;
}

.pcmb80 {
  margin-bottom: 80px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb80 {
    margin-bottom: 40px !important;
  }
}

.pcpt80 {
  padding-top: 80px !important;
}

.pcpb80 {
  padding-bottom: 80px !important;
}

.pcmt85 {
  margin-top: 85px !important;
}

.pcmb85 {
  margin-bottom: 85px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb85 {
    margin-bottom: 42.5px !important;
  }
}

.pcpt85 {
  padding-top: 85px !important;
}

.pcpb85 {
  padding-bottom: 85px !important;
}

.pcmt90 {
  margin-top: 90px !important;
}

.pcmb90 {
  margin-bottom: 90px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb90 {
    margin-bottom: 45px !important;
  }
}

.pcpt90 {
  padding-top: 90px !important;
}

.pcpb90 {
  padding-bottom: 90px !important;
}

.pcmt95 {
  margin-top: 95px !important;
}

.pcmb95 {
  margin-bottom: 95px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb95 {
    margin-bottom: 47.5px !important;
  }
}

.pcpt95 {
  padding-top: 95px !important;
}

.pcpb95 {
  padding-bottom: 95px !important;
}

.pcmt100 {
  margin-top: 100px !important;
}

.pcmb100 {
  margin-bottom: 100px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb100 {
    margin-bottom: 50px !important;
  }
}

.pcpt100 {
  padding-top: 100px !important;
}

.pcpb100 {
  padding-bottom: 100px !important;
}

.pcmt110 {
  margin-top: 110px !important;
}

.pcmb110 {
  margin-bottom: 110px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb110 {
    margin-bottom: 55px !important;
  }
}

.pcpt110 {
  padding-top: 110px !important;
}

.pcpb110 {
  padding-bottom: 110px !important;
}

.pcmt120 {
  margin-top: 120px !important;
}

.pcmb120 {
  margin-bottom: 120px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb120 {
    margin-bottom: 60px !important;
  }
}

.pcpt120 {
  padding-top: 120px !important;
}

.pcpb120 {
  padding-bottom: 120px !important;
}

.pcmt130 {
  margin-top: 130px !important;
}

.pcmb130 {
  margin-bottom: 130px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb130 {
    margin-bottom: 65px !important;
  }
}

.pcpt130 {
  padding-top: 130px !important;
}

.pcpb130 {
  padding-bottom: 130px !important;
}

.pcmt140 {
  margin-top: 140px !important;
}

.pcmb140 {
  margin-bottom: 140px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb140 {
    margin-bottom: 70px !important;
  }
}

.pcpt140 {
  padding-top: 140px !important;
}

.pcpb140 {
  padding-bottom: 140px !important;
}

.pcmt150 {
  margin-top: 150px !important;
}

.pcmb150 {
  margin-bottom: 150px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb150 {
    margin-bottom: 75px !important;
  }
}

.pcpt150 {
  padding-top: 150px !important;
}

.pcpb150 {
  padding-bottom: 150px !important;
}

.pcmt160 {
  margin-top: 160px !important;
}

.pcmb160 {
  margin-bottom: 160px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb160 {
    margin-bottom: 80px !important;
  }
}

.pcpt160 {
  padding-top: 160px !important;
}

.pcpb160 {
  padding-bottom: 160px !important;
}

.pcmt170 {
  margin-top: 170px !important;
}

.pcmb170 {
  margin-bottom: 170px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb170 {
    margin-bottom: 85px !important;
  }
}

.pcpt170 {
  padding-top: 170px !important;
}

.pcpb170 {
  padding-bottom: 170px !important;
}

.pcmt180 {
  margin-top: 180px !important;
}

.pcmb180 {
  margin-bottom: 180px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb180 {
    margin-bottom: 90px !important;
  }
}

.pcpt180 {
  padding-top: 180px !important;
}

.pcpb180 {
  padding-bottom: 180px !important;
}

.pcmt190 {
  margin-top: 190px !important;
}

.pcmb190 {
  margin-bottom: 190px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb190 {
    margin-bottom: 95px !important;
  }
}

.pcpt190 {
  padding-top: 190px !important;
}

.pcpb190 {
  padding-bottom: 190px !important;
}

.pcmt200 {
  margin-top: 200px !important;
}

.pcmb200 {
  margin-bottom: 200px !important;
}
@media only screen and (max-width: 639px) {
  .pcmb200 {
    margin-bottom: 100px !important;
  }
}

.pcpt200 {
  padding-top: 200px !important;
}

.pcpb200 {
  padding-bottom: 200px !important;
}

.pcnls5 {
  letter-spacing: -0.05em !important;
}

.pcpls5 {
  letter-spacing: 0.05em !important;
}

.pcnls10 {
  letter-spacing: -0.1em !important;
}

.pcpls10 {
  letter-spacing: 0.1em !important;
}

.pcnls15 {
  letter-spacing: -0.15em !important;
}

.pcpls15 {
  letter-spacing: 0.15em !important;
}

.pcnls20 {
  letter-spacing: -0.2em !important;
}

.pcpls20 {
  letter-spacing: 0.2em !important;
}

.pcnls25 {
  letter-spacing: -0.25em !important;
}

.pcpls25 {
  letter-spacing: 0.25em !important;
}

.pcnls30 {
  letter-spacing: -0.3em !important;
}

.pcpls30 {
  letter-spacing: 0.3em !important;
}

.pcnls35 {
  letter-spacing: -0.35em !important;
}

.pcpls35 {
  letter-spacing: 0.35em !important;
}

.pcnls40 {
  letter-spacing: -0.4em !important;
}

.pcpls40 {
  letter-spacing: 0.4em !important;
}

.pcnls45 {
  letter-spacing: -0.45em !important;
}

.pcpls45 {
  letter-spacing: 0.45em !important;
}

.pcnls50 {
  letter-spacing: -0.5em !important;
}

.pcpls50 {
  letter-spacing: 0.5em !important;
}

/*-----------------------------------------------------------------------------
   Eric Meyer's "Reset CSS" 2.0
   http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
-----------------------------------------------------------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/*-----------------------------------------------------------------------------
  global, common
-----------------------------------------------------------------------------*/
.clearfix {
  zoom: 1;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

html {
  color: #000;
}

body {
  font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  font-size: 12px;
  line-height: 1.5;
}

em {
  font-style: italic;
}

strong {
  font-weight: bold;
}

:link {
  text-decoration: none;
}

:link:hover {
  text-decoration: none;
}

:link:active,
:link:hover {
  outline: 0;
}

li {
  list-style: none;
}

img {
  border: 0;
}

a {
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

.lo-container-outer {
  width: 100%;
}

.lo-container {
  width: 100%;
}

.lo-header-outer-ex {
  width: 100%;
}

.lo-header-outer {
  width: 100%;
  height: 105px;
  box-sizing: border-box;
  position: fixed;
  z-index: 100;
}
@media only screen and (max-width: 639px) {
  .lo-header-outer {
    height: 55px;
  }
}

.lo-header {
  max-width: 768px;
  min-width: 320px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 0 24px;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 767px) {
  .lo-header {
    padding: 0 3.125%;
  }
}

.lo-header-price-outer {
  width: 100%;
}

.lo-header-price {
  max-width: 768px;
  min-width: 320px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 0 3.125%;
}

.lo-main-outer {
  max-width: 768px;
  min-width: 320px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 130px 3.125% 0;
}
.home .lo-main-outer {
  padding-top: 30px;
}
.ios-app-browser .lo-main-outer {
  padding-top: 30px;
}
@media only screen and (max-width: 639px) {
  .lo-main-outer {
    padding: 70px 3.125% 0;
  }
  .login .lo-main-outer {
    padding-top: 20px;
  }
  .home .lo-main-outer {
    padding-top: 15px;
  }
  .ios-app-browser .lo-main-outer {
    padding-top: 15px;
  }
}

.lo-main {
  width: 100%;
  box-sizing: border-box;
}

.one-col .lo-primary {
  width: 100%;
}

.lo-section-outer {
  width: 100%;
  overflow: hidden;
  box-sizing: border-box;
}
.home .lo-section-outer {
  padding: 0 3.33%;
}

.lo-section {
  width: 100%;
  box-sizing: border-box;
}
.home .lo-section {
  margin-bottom: 5.357%;
}

.lo-customer-info-outer {
  width: 100%;
}

.lo-customer-info {
  max-width: 768px;
  min-width: 320px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 0 3.125%;
}

/*-----------------------------------------------------------------------------
  home
-----------------------------------------------------------------------------*/
.lo-main-visual {
  width: 100%;
}

.lo-main-visual-inner {
  width: 100%;
}

/*-----------------------------------------------------------------------------
  menu-category
-----------------------------------------------------------------------------*/
.lo-cat-outer {
  width: 100%;
  padding: 4.67% 3.33%;
  margin-bottom: 5%;
}

.lo-cat-inner {
  width: 100%;
}

/*-----------------------------------------------------------------------------
  menu-list
-----------------------------------------------------------------------------*/
.home .lo-selectmenu-outer-ex {
  padding: 0 3.33%;
}

.lo-selectmenu-outer {
  width: 100%;
  padding: 3.33% 3.33% 5%;
  margin-bottom: 5%;
  box-sizing: border-box;
}
.login .lo-selectmenu-outer {
  padding: 0;
}

.lo-menu-list-outer {
  width: 100%;
  margin-bottom: 5%;
}

/*-----------------------------------------------------------------------------
  seach-result
-----------------------------------------------------------------------------*/
.lo-search-result {
  width: 100%;
  padding: 6.66% 3.33%;
  margin-bottom: 5%;
  box-sizing: border-box;
}

/*-----------------------------------------------------------------------------
  box-outer
-----------------------------------------------------------------------------*/
.lo-box-outer {
  width: 100%;
  padding: 5% 3.33% 8.33%;
  margin-bottom: 5%;
  box-sizing: border-box;
}

/*-----------------------------------------------------------------------------
  background
-----------------------------------------------------------------------------*/
body {
  background-color: #000;
}
body:before {
  background: url("../../img/sp/body-bg.jpg") no-repeat center top;
  background-size: 100% auto;
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  z-index: -1;
}

/*-----------------------------------------------------------------------------
  header
-----------------------------------------------------------------------------*/
.header-outer {
  background-color: rgba(0, 0, 0, 0.7);
  margin-bottom: 24px;
}
@media only screen and (max-width: 639px) {
  .header-outer {
    margin-bottom: 12px;
  }
}

.header {
  position: relative;
  z-index: 1;
}

.btn-top-outer {
  width: 80px;
  height: 90px;
  display: inline-block;
  position: absolute;
  top: 0;
  left: 24px;
  z-index: 10;
}
@media only screen and (max-width: 767px) {
  .btn-top-outer {
    left: 3.125%;
  }
}
@media only screen and (max-width: 639px) {
  .btn-top-outer {
    width: 40px;
    height: 45px;
  }
}

.btn-top {
  background-color: #b80101;
  border-radius: 0 0 5px 5px;
  display: inline-block;
  width: 104px;
  height: 117px;
  padding: 10px 18px 0;
  box-sizing: border-box;
  color: #fff;
  font-family: Futura, "Helvetica Neue", Helvetica, Arial, sans-serif;
  text-align: center;
  font-size: 26px;
  line-height: 1.3;
}
@media only screen and (max-width: 639px) {
  .btn-top {
    width: 52px;
    height: 58.5px;
    padding: 5px 9px 0;
    font-size: 13px;
  }
}
.btn-top .icn-top {
  fill: #fff;
  width: 100%;
}

.btn-order-history-outer {
  display: inline-block;
  margin: 20px 0 0 130px;
  position: relative;
  z-index: 20;
}
@media only screen and (max-width: 639px) {
  .btn-order-history-outer {
    margin: 10px 0 0 60px;
  }
}

.header-btn-container {
  padding: 8px 0 2px 0;
  box-sizing: border-box;
  color: #fff;
  display: inline-block;
  border-radius: 5px;
  width: 200px;
  background: #80b215;
  background: -webkit-linear-gradient(#80b215 0%, #578f00 100%);
  background: -o-linear-gradient(#80b215 0%, #578f00 100%);
  background: linear-gradient(#80b215 0%, #578f00 100%);
  border-top: 4px solid #9dc34b;
}
.header-btn-container.btn-order-history {
  padding-left: 10px;
}
@media only screen and (max-width: 639px) {
  .header-btn-container {
    padding: 2px 0 1px 0;
    font-size: 13px;
    width: 100px;
  }
  .header-btn-container.btn-order-history {
    padding-left: 8px;
  }
}
.header-btn-container .icn-order-history {
  fill: #fff;
  width: 28px;
  height: 37px;
}
@media only screen and (max-width: 639px) {
  .header-btn-container .icn-order-history {
    width: 14px;
    height: 18px;
  }
}
.header-btn-container .header-btn-txt {
  font-size: 26px;
  position: absolute;
}
.header-btn-container .header-btn-txt.btn-order-history-txt {
  left: 50px;
}
@media only screen and (max-width: 639px) {
  .header-btn-container .header-btn-txt {
    font-size: 13px;
  }
  .header-btn-container .header-btn-txt.btn-order-history-txt {
    left: 25px;
  }
}

@media only screen and (max-width: 639px) {
  .lang-en .header-btn-container.btn-order-history {
    padding-left: 5px;
  }
}
.lang-en .header-btn-container .header-btn-txt {
  font-size: 20px;
}
.lang-en .header-btn-container .header-btn-txt.btn-order-history-txt {
  top: 12px;
}
@media only screen and (max-width: 639px) {
  .lang-en .header-btn-container .header-btn-txt {
    font-size: 11px;
  }
  .lang-en .header-btn-container .header-btn-txt.btn-order-history-txt {
    left: 22px;
    top: 8px;
  }
}

.header-search-outer {
  position: absolute;
  top: 20px;
  right: 20px;
}
.header-search-outer .search .search-button-outer {
  float: right;
  width: 60px;
  height: 60px;
  margin-left: 3px;
}
@media only screen and (max-width: 639px) {
  .header-search-outer .search .search-button-outer {
    width: 30px;
    height: 30px;
  }
}
.header-search-outer .search .search-input-outer {
  width: 47%;
  padding: 0;
  float: right;
}
@media only screen and (max-width: 767px) {
  .header-search-outer .search .search-input-outer {
    width: 200px;
  }
}
@media only screen and (max-width: 639px) {
  .header-search-outer {
    top: 10px;
    right: 10px;
  }
  .header-search-outer .search .search-input-outer {
    width: 180px;
  }
  .header-search-outer .search .search-input-outer .search-input {
    padding: 6px 5px;
  }
}
@media only screen and (max-width: 413px) {
  .header-search-outer .search .search-input-outer {
    width: 150px;
  }
}
@media only screen and (max-width: 374px) {
  .header-search-outer .search .search-input-outer {
    width: 140px;
  }
}
@media only screen and (max-width: 359px) {
  .header-search-outer .search .search-input-outer {
    width: 100px;
  }
}

.header-price {
  color: #fff;
  font-size: 22px;
  text-align: center;
  padding-bottom: 24px;
}
@media only screen and (max-width: 639px) {
  .header-price {
    font-size: 11px;
    padding-bottom: 12px;
  }
}

.set-menu-info {
  color: #fff;
  font-size: 22px;
  text-align: center;
  padding-bottom: 24px;
}
.set-menu-info .set-menu-over {
  color: #e03628;
  font-weight: bold;
  font-size: 25px;
}
@media only screen and (max-width: 639px) {
  .set-menu-info {
    font-size: 11px;
    padding-bottom: 12px;
  }
  .set-menu-info .set-menu-over {
    font-size: 14px;
  }
}

/*-----------------------------------------------------------------------------
  main-visual
-----------------------------------------------------------------------------*/
.main-visual-inner {
  display: table;
  box-sizing: border-box;
}
.main-visual-inner .side,
.main-visual-inner .center {
  display: table-cell;
}
.main-visual-inner .side {
  width: 33.66%;
}
.main-visual-inner .center {
  width: 32.68%;
}
.main-visual-inner img {
  width: 100%;
}

.mv-info {
  color: #fff;
  width: 100%;
  text-align: center;
  padding-bottom: 5%;
  font-size: 28px;
}
.mv-info .shop-name {
  font-size: 32px;
}
@media only screen and (max-width: 639px) {
  .mv-info {
    font-size: 14px;
  }
  .mv-info .shop-name {
    font-size: 16px;
  }
}

/*-----------------------------------------------------------------------------
  login
-----------------------------------------------------------------------------*/
.login-outer {
  padding: 6.25%;
}
.login-outer .logo-outer {
  padding: 0;
}

.pw-outer .search-input {
  width: 100%;
  height: 80px;
  border-radius: 5px;
  box-sizing: border-box;
  border: none;
  display: block;
  padding: 10px;
  font-size: 26px;
  box-shadow: 0 3px 7px rgba(0, 0, 0, 0.35) inset;
  font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
}
@media only screen and (max-width: 639px) {
  .pw-outer .search-input {
    height: 40px;
    font-size: 13px;
  }
}

.login-btn-outer {
  width: 100%;
  text-align: center;
}
.login-btn-outer .login-btn {
  display: inline-block;
  margin: 0 auto;
  width: 35.7%;
  height: 80px;
  line-height: 80px;
  background-color: #b80101;
  border-radius: 10px;
}
.login-btn-outer a.login-btn {
  color: #fff;
}
@media only screen and (max-width: 639px) {
  .login-btn-outer .login-btn {
    height: 40px;
    line-height: 40px;
    border-radius: 5px;
  }
}

/*-----------------------------------------------------------------------------
  home
-----------------------------------------------------------------------------*/
.search-outer {
  background-color: #000;
  border-radius: 5px;
  box-sizing: border-box;
  padding: 4.46% 5.36% 3.93%;
  text-align: center;
  border-top: 7px solid #b80101;
}
.search-outer span {
  color: #fff;
  font-size: 28px;
  padding-bottom: 4.46%;
  display: block;
}
@media only screen and (max-width: 639px) {
  .search-outer span {
    font-size: 14px;
  }
}

.search {
  display: table;
  width: 100%;
}
.search .search-input-outer {
  display: table-cell;
  width: 88%;
  padding: 0 5% 0 0;
  vertical-align: middle;
}
.search .search-input-outer .search-input {
  width: 100%;
  height: 60px;
  border-radius: 5px;
  box-sizing: border-box;
  border: none;
  display: block;
  padding: 10px;
  font-size: 26px;
  box-shadow: 0 3px 7px rgba(0, 0, 0, 0.35) inset;
  font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
}
@media only screen and (max-width: 639px) {
  .search .search-input-outer .search-input {
    height: 30px;
    font-size: 13px;
  }
}
.search .search-button-outer {
  display: table-cell;
  width: 12%;
  text-align: right;
}
.search .search-button-outer .search-button {
  padding: 13px 14px;
  width: 60px;
  height: 60px;
  box-sizing: border-box;
  background-color: #b80101;
  border-radius: 5px;
  display: inline-block;
}
.search .search-button-outer .search-button .icn-search {
  fill: #fff;
  width: 100%;
}
@media only screen and (max-width: 639px) {
  .search .search-button-outer .search-button {
    padding: 6px 7px;
    width: 30px;
    height: 30px;
  }
}

.home-btn-container1 {
  margin-bottom: 8.93%;
}

.home-btn-container2 {
  margin-bottom: 8.93%;
}

.home-btn-left {
  width: 46.43%;
  float: left;
}

.home-btn-right {
  width: 46.43%;
  float: right;
}

/*-----------------------------------------------------------------------------
  menu-category
-----------------------------------------------------------------------------*/
.cat-outer {
  box-sizing: border-box;
  background-color: #000;
  border: 1px solid #888;
}

.cat-inner {
  background: url(../../img/sp/red-arrow-l.png) no-repeat bottom right;
}
@media only screen and (max-width: 639px) {
  .cat-inner {
    background: url(../../img/sp/red-arrow-m.png) no-repeat bottom right;
  }
}

.cat-img {
  margin-bottom: 2%;
}
.cat-img img {
  width: 100%;
}

.cat-name-en {
  display: block;
  color: #fff;
  text-align: center;
}

.cat-name-ja {
  display: block;
  color: #fff;
  text-align: center;
}

/*-----------------------------------------------------------------------------
  menu-list
-----------------------------------------------------------------------------*/
.selectmenu-outer {
  background-color: #000;
  border-top: 7px solid #b80101;
}
.login .selectmenu-outer {
  background-color: transparent;
  border-top: none;
}
.home .selectmenu-outer {
  border-radius: 5px;
}

.selectmenu-title {
  color: #fff;
  text-align: center;
  margin-bottom: 20px;
}
.login .selectmenu-title {
  font-size: 30px;
}
@media only screen and (max-width: 639px) {
  .selectmenu-title {
    margin-bottom: 10px;
  }
  .login .selectmenu-title {
    font-size: 16px;
    margin-bottom: 5px;
  }
}

.selectmenu {
  background: #c5c5c5;
  border: none;
  border-radius: 10px;
}
@media only screen and (max-width: 639px) {
  .selectmenu {
    border-radius: 5px;
  }
}

.selectmenu select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  padding: 0 20px;
  background: #c5c5c5;
  background: url(../../img/sp/red-arrow-down.png) right 50% no-repeat, linear-gradient(to bottom, #f3f3f3 0%, #c5c5c5 100%);
  background-size: 40px, 13px, 100%;
  font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  border: none;
  border-radius: 10px;
}
.login .selectmenu select {
  padding: 8px 20px;
  background: url(../../img/sp/red-arrow-down.png) right 50% no-repeat, linear-gradient(to bottom, #fff 0%, #fff 100%);
  box-shadow: 0 3px 7px rgba(0, 0, 0, 0.35) inset;
}
.selectmenu select option {
  padding: 10px 20px;
}
@media only screen and (max-width: 639px) {
  .selectmenu select {
    border-radius: 5px;
    padding: 0 10px;
    background-size: 20px, 7px, 100%;
  }
  .login .selectmenu select {
    background-size: 20px, 7px, 100%;
    padding: 8px 10px;
  }
  .selectmenu select option {
    padding: 8px;
  }
}

.menu-list-outer {
  position: relative;
}

.menu-list-style-title {
  margin-bottom: 5%;
  text-align: center;
  color: #fff;
}

.menu-list-row {
  margin-bottom: 5%;
}

.menu-list-item-outer {
  float: left;
  box-sizing: border-box;
  border: 1px solid #888;
  background-color: #000;
  width: 48.33%;
  padding: 3.33%;
}
.menu-list-item-outer:nth-of-type(1) {
  margin-right: 3.33%;
}
.menu-list-item-outer a {
  display: inline-block;
}
.menu-list-item-outer.menu-list-item-outer-span2 {
  width: 100%;
}

.menu-list-item {
  background: url(../../img/sp/red-arrow-m.png) no-repeat bottom right;
}
@media only screen and (max-width: 639px) {
  .menu-list-item {
    background-size: 8px;
  }
}

.menu-list-item-img {
  margin-bottom: 10px;
}
.menu-list-item-img img {
  width: 100%;
}
@media only screen and (max-width: 639px) {
  .menu-list-item-img {
    margin-bottom: 5px;
  }
}

.menu-list-item-txt .item-no {
  display: block;
  text-align: center;
  color: #fce471;
  font-family: "Libre Baskerville", serif;
  font-weight: bold;
}
.menu-list-item-txt .item-no .icn-moon-outer {
  display: inline-block;
  width: 20px;
  height: auto;
  margin-right: 5px;
}
@media only screen and (max-width: 639px) {
  .menu-list-item-txt .item-no {
    font-size: 10px;
  }
  .menu-list-item-txt .item-no .icn-moon-outer {
    width: 10px;
    margin-right: 3px;
  }
}
.menu-list-item-txt .item-name-en {
  display: block;
  text-align: center;
  color: #fff;
}
.menu-list-item-txt .item-name-ja {
  display: block;
  text-align: center;
  color: #fff;
}
.menu-list-item-txt .item-free-icon {
  display: block;
  text-align: center;
  color: #fff;
}

/*-----------------------------------------------------------------------------
  search-result
-----------------------------------------------------------------------------*/
.search-result {
  background-color: #000;
  color: #fff;
  text-align: center;
}

.search-keyword {
  color: #fce471;
}

/*-----------------------------------------------------------------------------
  menu-detail
-----------------------------------------------------------------------------*/
.menu-detail-item-title {
  color: #fff;
  text-align: center;
  margin-bottom: 3.58%;
}
.menu-detail-item-title .item-name-ja {
  padding-right: 20px;
}
@media only screen and (max-width: 639px) {
  .menu-detail-item-title .item-name-ja {
    padding-right: 10px;
  }
}
.menu-detail-item-title .item-no {
  color: #fce471;
  font-weight: bold;
}
.menu-detail-item-title .icn-moon-outer {
  display: inline-block;
  width: 20px;
  height: auto;
  margin-right: 5px;
}
@media only screen and (max-width: 639px) {
  .menu-detail-item-title {
    font-size: 10px;
  }
  .menu-detail-item-title .icn-moon-outer {
    width: 10px;
    margin-right: 3px;
  }
}

.menu-detail-item-img .bx-wrapper {
  margin-bottom: 5.38%;
}
.menu-detail-item-img .bx-wrapper .bx-viewport {
  z-moz-box-shadow: none;
  -webkit-box-shadow: none;
  box-shadow: none;
  border: none;
  left: 0;
  background: none;
}
.menu-detail-item-img .bx-wrapper .bx-controls-direction a {
  position: absolute;
  top: 50%;
  margin-top: -27px;
  outline: 0;
  width: 32px;
  height: 55px;
  text-indent: -9999px;
  z-index: 9999;
}
.menu-detail-item-img .bx-wrapper .bx-prev {
  left: 10px;
  background: url(../../img/sp/prev.png) no-repeat top left;
}
.menu-detail-item-img .bx-wrapper .bx-next {
  right: 10px;
  background: url(../../img/sp/next.png) no-repeat top right;
}
.menu-detail-item-img .bx-wrapper .bx-prev:hover {
  background-position: top left;
}
.menu-detail-item-img .bx-wrapper .bx-next:hover {
  background-position: top right;
}
.menu-detail-item-img .bx-wrapper img {
  max-width: none;
  width: 100%;
}
.menu-detail-item-img .bx-wrapper .bx-pager {
  display: none;
}
@media only screen and (max-width: 639px) {
  .menu-detail-item-img .bx-wrapper .bx-controls-direction a {
    margin-top: -14px;
    outline: 0;
    width: 16px;
    height: 28px;
    text-indent: -9999px;
    z-index: 9999;
  }
  .menu-detail-item-img .bx-wrapper .bx-prev {
    left: 5px;
    background-size: 50%;
  }
  .menu-detail-item-img .bx-wrapper .bx-next {
    right: 5px;
    background-size: 50%;
  }
}

.heading-blue-bg {
  background-color: #2d8dbf;
  border-radius: 10px;
  padding: 8px 15px;
}
@media only screen and (max-width: 639px) {
  .heading-blue-bg {
    border-radius: 5px;
    padding: 4px 8px;
  }
}

.circle-o {
  color: rgba(255, 255, 255, 0.5);
}

.menu-detail .mfp-container {
  position: relative;
  top: auto;
  left: auto;
  max-width: 768px;
  padding-left: 20px;
  padding-right: 20px;
  margin: 0 auto;
}
.menu-detail .mfp-content {
  background-color: #fff;
  border-radius: 10px;
}
.menu-detail .mfp-close {
  font-size: 60px;
  font-weight: bold;
  right: 15px;
  top: 15px;
}
.menu-detail .mfp-close-btn-in .mfp-close {
  color: #000;
}
.menu-detail .inline-wrap {
  padding: 60px 20px 10px;
  text-align: center;
}
@media only screen and (max-width: 639px) {
  .menu-detail .mfp-container {
    padding-left: 10px;
    padding-right: 10px;
  }
  .menu-detail .mfp-content {
    border-radius: 5px;
  }
  .menu-detail .mfp-close {
    font-size: 30px;
    right: 0;
    top: 3px;
  }
  .menu-detail .inline-wrap {
    padding: 30px 10px 5px;
  }
}

/*-----------------------------------------------------------------------------
  box-outer, logo-outer
-----------------------------------------------------------------------------*/
.box-outer {
  background: rgba(0, 0, 0, 0.6);
  border: 1px solid #888;
}

.logo-outer {
  padding-top: 7.5%;
}

/*-----------------------------------------------------------------------------
  menu-thanks
-----------------------------------------------------------------------------*/
.sns-btn-outer {
  width: 100%;
  height: 20px;
  text-align: center;
}

.fb_iframe_widget {
  margin-right: 20px;
}

.twitter-tweet-button {
  vertical-align: bottom;
}

.ad-txt {
  text-align: center;
}
.ad-txt a {
  color: #fff;
  text-decoration: underline;
}

.ad-img img {
  width: 100%;
}

/*-----------------------------------------------------------------------------
  tab (order-history, cashier)
-----------------------------------------------------------------------------*/
.tabs-outer .panel-radios {
  display: none;
}
.tabs-outer #tabs-list li {
  display: inline-block;
  float: left;
  text-align: center;
}
.tabs-outer .panel-label {
  position: relative;
  padding: 20px 0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  display: block;
  width: 100%;
  cursor: pointer;
  background-color: #6e6e6e;
  transition-property: background-color, color;
  transition-duration: 200ms;
  border-radius: 10px 10px 0 0;
}
@media only screen and (max-width: 639px) {
  .tabs-outer .panel-label {
    padding: 10px 0;
  }
}

#panel-1-ctrl:checked ~ #tabs-list #li-for-panel-1 {
  pointer-events: none;
  cursor: default;
}

#panel-1-ctrl:checked ~ #tabs-list #li-for-panel-1 label.panel-label {
  background-color: #2d8dbf;
}

#panel-2-ctrl:checked ~ #tabs-list #li-for-panel-2 {
  pointer-events: none;
  cursor: default;
}

#panel-2-ctrl:checked ~ #tabs-list #li-for-panel-2 label.panel-label {
  background-color: #2d8dbf;
}

/* panels */
#panel-1-ctrl:checked ~ .panels #panel-1 .panel-content {
  max-height: initial;
  max-height: 650px;
  opacity: 1;
  overflow-y: scroll;
}
@media only screen and (max-width: 639px) {
  #panel-1-ctrl:checked ~ .panels #panel-1 .panel-content {
    max-height: 325px;
  }
}

#panel-2-ctrl:checked ~ .panels #panel-2 .panel-content {
  max-height: initial;
  max-height: 650px;
  opacity: 1;
  overflow-y: scroll;
}
@media only screen and (max-width: 639px) {
  #panel-2-ctrl:checked ~ .panels #panel-2 .panel-content {
    max-height: 325px;
  }
}

.tabs-outer .panels {
  padding: 15% 0 6% 0;
}
.tabs-outer .panels .panel-content {
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
  max-height: 0;
  opacity: 0;
  transition: opacity 600ms;
  overflow-y: hidden;
}
.tabs-outer .panels .panel-content::-webkit-scrollbar {
  width: 10px;
  border-radius: 5px;
}
@media only screen and (max-width: 639px) {
  .tabs-outer .panels .panel-content::-webkit-scrollbar {
    width: 5px;
    border-radius: 3px;
  }
}
.tabs-outer .panels .panel-content::-webkit-scrollbar-thumb {
  background: #f9fbfb;
  border-radius: 5px;
}
@media only screen and (max-width: 639px) {
  .tabs-outer .panels .panel-content::-webkit-scrollbar-thumb {
    border-radius: 3px;
  }
}
.tabs-outer .panels .panel-content::-webkit-scrollbar-track-piece:start {
  background: #6e6e6e;
}
.tabs-outer .panels .panel-content::-webkit-scrollbar-track-piece:end {
  background: #6e6e6e;
}

.panel-content .order-item-outer,
.panel-content .total-amount-outer {
  margin: 2.69% 6.27% 2.69% 3.58%;
  padding-bottom: 2.69%;
  border-bottom: 1px solid #888;
}
.panel-content .total-amount-outer {
  border-bottom: none;
}
.panel-content .order-item-name {
  margin-left: 1em;
  text-indent: -1em;
}
.panel-content .order-item-price-outer,
.panel-content .total-amount {
  display: block;
  width: 100%;
}
.panel-content .order-item-quantity,
.panel-content .total-amount-left {
  display: inline-block;
  width: 60%;
  float: left;
  margin-left: 1em;
}
.panel-content .total-amount-left {
  margin-left: 0;
}
.panel-content .order-item-price,
.panel-content .total-amount-right {
  display: inline-block;
  width: 30%;
  float: right;
  text-align: right;
}
.panel-content .cancel {
  display: inline-block;
  border-radius: 3px;
  background-color: #e03628;
  margin-left: 1em;
  padding: 0 5px;
}
.panel-content .cancel i {
  font-weight: bold;
  margin-right: 3px;
}

.panel-content.order-sp .order-item-outer:last-of-type,
.panel-content.order-table .order-item-outer:last-of-type {
  border-bottom: none;
}

.panel-content.order-all .order-item-outer.last {
  border-bottom: 4px solid #fff;
}

/*-----------------------------------------------------------------------------
  button & link
-----------------------------------------------------------------------------*/
.btn-outer {
  padding: 0 7.35%;
  box-sizing: border-box;
}

.btn-inner {
  position: relative;
}
.btn-inner a {
  display: block;
}
.btn-inner img {
  width: 100%;
}
.btn-inner.btn-inner-cashier input {
  display: inline-block;
  width: 100%;
  text-align: center;
  vertical-align: middle;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border-left: 1px solid transparent;
  border-right: 1px solid transparent;
  border-top: 5px solid #9264c6;
  border-bottom: 5px solid #4a117f;
  background: linear-gradient(#7034b2, #5f2793);
  padding: .375rem .5rem;
  font-size: 1.1rem;
  line-height: 1.5;
  border-radius: .4rem;
  color: #fff;
  cursor: pointer;
}

.link-txt {
  text-align: center;
}

a.color-blue {
  color: #00a0e9;
  text-decoration: underline;
}

.icn-return-outer {
  display: inline-block;
  width: 20px;
  vertical-align: middle;
}
@media only screen and (max-width: 639px) {
  .icn-return-outer {
    width: 10px;
  }
}

/*-----------------------------------------------------------------------------
  credit-button
-----------------------------------------------------------------------------*/
.btn-codepay {
  margin: 0;
  padding-top: 10px;
  width: 49%;
  display: inline-block;
  postion: relative;
}

.btn-credit {
  padding-top: 8px;
}

/*-----------------------------------------------------------------------------
  dl
-----------------------------------------------------------------------------*/
.dl-style {
  width: 100%;
}
.dl-style dt {
  display: block;
  clear: left;
  float: left;
  padding: 0 3px 10px 0;
  box-sizing: border-box;
  text-align: left;
}
.dl-style dd {
  display: block;
  float: left;
  padding: 0 0 5px 0;
  box-sizing: border-box;
  text-align: right;
}

/*-----------------------------------------------------------------------------
  table
-----------------------------------------------------------------------------*/
.table-style1 {
  border-collapse: collapse;
  border-top: 1px solid #fff;
  border-left: 1px solid #fff;
  width: 100%;
}
.table-style1 th, .table-style1 td {
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
  padding: 10px;
  text-align: left;
}
@media only screen and (max-width: 639px) {
  .table-style1 th, .table-style1 td {
    padding: 8px;
  }
}
.table-style1 th {
  width: 38%;
}

/*-----------------------------------------------------------------------------
  Information
-----------------------------------------------------------------------------*/
.section-info {
  border-top: 1px solid #fff;
  box-sizing: border-box;
  padding: 4.17% 0 6.67%;
  font-size: 26px;
  color: #fff;
}
.section-info:last-of-type {
  padding-bottom: 0;
}
.section-info h2 {
  color: #fce471;
}
.section-info p {
  margin-bottom: 30px;
}
.section-info p:last-child {
  margin-bottom: 0;
}
.section-info a {
  color: #00a0e9;
  text-decoration: underline;
}
@media only screen and (max-width: 639px) {
  .section-info {
    font-size: 13px;
  }
  .section-info p {
    margin-bottom: 15px;
  }
}

/*-----------------------------------------------------------------------------
  notes
-----------------------------------------------------------------------------*/
.notes {
  width: 100%;
  padding-bottom: 3.33%;
}
.notes p {
  color: #fff;
  font-size: 20px;
  line-height: 1.8;
}
.notes p .icn-moon-outer {
  display: inline-block;
  width: 20px;
  height: auto;
  margin-right: 5px;
}
@media only screen and (max-width: 639px) {
  .notes p {
    font-size: 10px;
  }
  .notes p .icn-moon-outer {
    width: 10px;
    margin-right: 3px;
  }
}

/*-----------------------------------------------------------------------------
  error ios-app-browser
-----------------------------------------------------------------------------*/
.ios-app-browser .section-info {
  border-top: none;
}
.ios-app-browser .section-info p {
  font-size: 15px;
}
.ios-app-browser .btn-share-outer {
  display: inline-block;
  width: 13px;
  height: 18px;
}
.ios-app-browser .emp {
  color: #e03628;
  font-weight: bold;
}

/*-----------------------------------------------------------------------------
  pagetop
-----------------------------------------------------------------------------*/
.pagetop {
  position: fixed;
  bottom: 0px;
  right: 0px;
  display: block;
  width: 35px;
  height: 35px;
  z-index: 999;
}
.pagetop img {
  max-width: 100%;
}
@media only screen and (max-width: 639px) {
  .pagetop {
    bottom: 0px;
  }
}

/*-----------------------------------------------------------------------------
  footer
-----------------------------------------------------------------------------*/
.customer-info-outer {
  background: rgba(255, 255, 255, 0.2);
  box-sizing: border-box;
  padding: 3.125% 0;
}

.customer-info {
  text-align: center;
  color: #fff;
  font-size: 26px;
  line-height: 1.58;
}
@media only screen and (max-width: 639px) {
  .customer-info {
    font-size: 13px;
  }
}

.entry-date-time,
.table-no,
.customer-ns {
  display: block;
}

/*-----------------------------------------------------------------------------
  font
-----------------------------------------------------------------------------*/
.font-en {
  font-family: "Libre Baskerville", serif;
}

.fs44px {
  font-size: 44px;
}

.fs42px {
  font-size: 42px;
}

.fs40px {
  font-size: 40px;
}

.fs36px {
  font-size: 36px;
}

.fs32px {
  font-size: 32px;
}

.fs30px {
  font-size: 30px;
}

.fs28px {
  font-size: 28px;
}

.fs26px {
  font-size: 26px;
}

.fs24px {
  font-size: 24px;
}

.fs22px {
  font-size: 22px;
}

.fs20px {
  font-size: 20px;
}

.fs16px {
  font-size: 16px;
}

@media only screen and (max-width: 639px) {
  .fs44px {
    font-size: 22px;
  }

  .fs42px {
    font-size: 21px;
  }

  .fs40px {
    font-size: 20px;
  }

  .fs36px {
    font-size: 18px;
  }

  .fs32px {
    font-size: 16px;
  }

  .fs30px {
    font-size: 15px;
  }

  .fs28px {
    font-size: 14px;
  }

  .fs26px {
    font-size: 13px;
  }

  .fs24px {
    font-size: 12px;
  }

  .fs22px {
    font-size: 11px;
  }

  .fs20px {
    font-size: 10px;
  }

  .fs16px {
    font-size: 10px;
  }
}
/*-----------------------------------------------------------------------------
  misc.
-----------------------------------------------------------------------------*/
.w100per {
  width: 100%;
}

.w90per {
  width: 90%;
}

.w80per {
  width: 80%;
}

.w70per {
  width: 70%;
}

.w60per {
  width: 60%;
}

.w50per {
  width: 50%;
}

.w45per {
  width: 45%;
}

.w40per {
  width: 40%;
}

.w30per {
  width: 30%;
}

.w20per {
  width: 20%;
}

.w15per {
  width: 15%;
}

.w10per {
  width: 10%;
}

.h100per {
  height: 100%;
}

.italic {
  font-style: italic;
}

.icn-moon {
  stroke-width: 0;
  fill: #fce471;
}

.icn-return {
  stroke-width: 0;
  fill: #00a0e9;
}

.display-block {
  display: block;
}

.display-table {
  display: table;
}

.display-table-cell {
  display: table-cell;
}

.color-blue {
  color: #00a0e9;
}

.color-yellow {
  color: #fce471;
}

.color-white {
  color: #fff;
}

.color-white2 {
  color: #fefefe;
}

.color-red {
  color: #b80101;
}

.hr-black {
  border-width: 1px 0px 0px 0px;
  border-style: solid;
  border-color: #616161;
}

.txt-center {
  text-align: center;
}

.txt-right {
  text-align: right;
}

.vmiddle {
  vertical-align: middle;
}

.font-baskerville {
  font-family: "Libre Baskerville", serif;
}

/*-----------------------------------------------------------------------------
  loading
-----------------------------------------------------------------------------*/
.loading-image {
  position: absolute;
  width: 100%;
  text-align: center;
  bottom: 80px;
}

.loading-trigger {
  height: 20px;
}
