@charset "UTF-8";
/* ======================================================
   common style
====================================================== */
/* -------------------------------------
   common
------------------------------------- */
body {
  -webkit-text-size-adjust: none;
  /* フォントサイズ自動調整 */
  -webkit-font-smoothing: antialiased;
  /*フォント太くなるのを解消 */
  font-family: "Avenir","游ゴシック","YuGothic","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 400;
  color: #2f2f2f;
  background: #ffffff;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-duration: .5s;
  transition-duration: .5s;
}
@media screen and (max-width: 320px) {
  body {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}

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

a {
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
  color: #CB9D75;
  text-decoration: none;
}
a:hover, a:active {
  color: #EBBD95;
  text-decoration: none;
}
a:visited {
  color: #CB9D75;
  text-decoration: underline;
}
@media screen and (max-width: 767px) {
  a a {
    -webkit-transition: none;
    -moz-transition: none;
    -o-transition: none;
    transition: none;
  }
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

article {
  margin-bottom: 150px;
}
@media screen and (max-width: 767px) {
  article {
    margin-bottom: 80px;
  }
}

section:last-child {
  margin-bottom: 0;
}

#wrapper {
  position: relative;
  line-height: 1.8;
  color: #2f2f2f;
  width: 100%;
  min-width: 1120px;
  max-height: 999999px;
  /*Androidブラウザフォントバグ対策*/
}
@media screen and (max-width: 767px) {
  #wrapper {
    min-width: 320px;
  }
}
@media screen and (max-width: 414px) {
  #wrapper {
    line-height: 1.6;
  }
}

.box-inner {
  position: relative;
  margin: 0 auto;
  width: 1280px;
}
.box-inner:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.btn-transition a {
  font-size: 14px;
  font-size: 0.875rem;
  display: inline-block;
  text-decoration: none;
  color: #FFF;
  padding: 7px 25px 7px 44px;
}
.btn-transition a:link, .btn-transition a:visited {
  background-color: #ffffff;
}
.btn-transition a:hover {
  background-color: #ffffff;
}

.en {
  display: none;
}

/* -------------------------------------
   sp mode
------------------------------------- */
#display-mode-sp {
  display: none;
  font-size: 48px;
  font-size: 3rem;
  margin: 30px auto;
  background-color: #7eaf94;
  width: 75%;
  text-align: center;
  font-weight: bold;
}
@media screen and (max-width: 320px) {
  #display-mode-sp {
    font-size: 45.024px;
    font-size: 2.814rem;
    font-size: 42px;
    font-size: 2.625rem;
  }
}
#display-mode-sp a {
  color: #ffffff;
  display: block;
  text-decoration: none;
  padding: 20px 30px;
}

#display-mode-pc {
  display: none;
}

@media screen and (max-width: 767px) {
  #display-mode-pc {
    display: block;
    font-size: 13px;
    font-size: 0.8125rem;
    margin: 20px 0 40px;
    border: 1px solid #fff;
    width: 100%;
    text-align: center;
    font-weight: bold;
  }
  #display-mode-pc a {
    display: block;
    color: #ffffff;
    text-decoration: none;
    width: 100%;
    padding: 10px 0 10px;
  }
}
/* -------------------------------------
   header
------------------------------------- */
#wrapper header#header {
  position: relative;
  display: block;
  width: 100%;
  height: 230px;
  background-image: url(../img/common/header_bg.png);
  background-color: #0F0F0F;
}
#wrapper header#header .header-box {
  position: relative;
  width: 1080px;
  height: 230px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #wrapper header#header .header-box {
    width: 100%;
    height: auto;
  }
}
#wrapper header#header .logo {
  position: absolute;
  top: 50px;
}
#wrapper header#header .logo img {
  width: 206px;
}
#wrapper header#header .language-box {
  position: absolute;
  right: 0;
  top: 30px;
}
#wrapper header#header .language-box .en-text {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 400;
  margin-right: 25px;
}
#wrapper header#header .language-box .en-text, #wrapper header#header .language-box .jp-text {
  float: left;
}
#wrapper header#header .language-box .en-text a, #wrapper header#header .language-box .jp-text a {
  color: #ffffff;
  border-bottom: 1px transparent solid;
  padding-bottom: 6px;
}
#wrapper header#header .language-box .en-text a:hover, #wrapper header#header .language-box .jp-text a:hover {
  border-bottom: 1px #fff solid;
  padding-bottom: 2px;
}
#wrapper header#header .language-box .en-text.selected a, #wrapper header#header .language-box .jp-text.selected a {
  border-bottom: 1px #fff solid;
  padding-bottom: 2px;
}
#wrapper header#header .language-box .jp-text a:hover {
  border-bottom: 1px #fff solid;
  padding-bottom: 5px;
}
#wrapper header#header .language-box .jp-text.selected a {
  border-bottom: 1px #fff solid;
  padding-bottom: 5px;
}
@media screen and (max-width: 767px) {
  #wrapper header#header {
    height: 160px;
    min-width: 320px;
    background-size: 55px;
  }
  #wrapper header#header .logo {
    position: relative;
    top: 25px;
    text-align: center;
  }
  #wrapper header#header .logo img {
    width: 180px;
  }
  #wrapper header#header .language-box {
    display: none;
  }
}
@media screen and (max-width: 380px) {
  #wrapper header#header .logo img {
    width: 136px;
  }
}

/* -------------------------------------
   navigation for sp
------------------------------------- */
#wrapper .sp-only {
  display: none;
}
@media screen and (max-width: 767px) {
  #wrapper .sp-only {
    display: block;
  }
}
#wrapper .sp-menu {
  display: none;
}
@media screen and (max-width: 767px) {
  #wrapper .sp-menu {
    display: block;
  }
  #wrapper .sp-menu .btn-menu-toggle {
    position: fixed;
    z-index: 999;
    top: 0px;
    right: 0px;
    font-weight: bold;
    font-size: 18px;
    font-size: 1.125rem;
    display: block;
    padding: 20px 20px;
    height: 30px;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.8);
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  #wrapper .sp-menu .btn-menu-toggle {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
@media screen and (max-width: 767px) {
  #wrapper .sp-menu .btn-menu-toggle .btn-menu {
    position: relative;
    display: inline-block;
    width: 30px;
    height: 30px;
    box-sizing: border-box;
  }
  #wrapper .sp-menu .btn-menu-toggle .bar {
    position: absolute;
    top: 0;
    left: 0;
    display: inline-block;
    width: 100%;
    height: 4px;
    background: #ffffff;
    width: 30px;
    -webkit-transition: all .4s;
    transition: all .4s;
  }
  #wrapper .sp-menu .btn-menu-toggle .bar.top {
    top: 0;
  }
  #wrapper .sp-menu .btn-menu-toggle .bar.middle {
    top: 10px;
  }
  #wrapper .sp-menu .btn-menu-toggle .bar.bottom {
    top: 20px;
  }
  #wrapper .sp-menu .btn-menu-toggle.close .bar {
    left: 0;
    width: 100%;
  }
  #wrapper .sp-menu .btn-menu-toggle.close .bar.top {
    -webkit-transform: translateY(10px) rotate(-45deg);
    -ms-transform: translateY(10px) rotate(-45deg);
    transform: translateY(10px) rotate(-45deg);
  }
  #wrapper .sp-menu .btn-menu-toggle.close .bar.middle {
    opacity: 0;
  }
  #wrapper .sp-menu .btn-menu-toggle.close .bar.bottom {
    -webkit-transform: translateY(-10px) rotate(45deg);
    -ms-transform: translateY(-10px) rotate(45deg);
    transform: translateY(-10px) rotate(45deg);
  }
}

.sp-sub-menu {
  overflow: hidden;
  padding: 20px 40px 40px 80px;
}
.sp-sub-menu .facebook, .sp-sub-menu .twitter, .sp-sub-menu .instagram {
  display: inline-block;
  float: left;
  font-size: 24px;
  font-size: 1.5rem;
  padding: 0 30px 0 0;
}
@media screen and (max-width: 320px) {
  .sp-sub-menu .facebook, .sp-sub-menu .twitter, .sp-sub-menu .instagram {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
.sp-sub-menu .facebook a, .sp-sub-menu .twitter a, .sp-sub-menu .instagram a {
  color: #ffffff;
}
.sp-sub-menu .facebook a:hover, .sp-sub-menu .facebook a:active, .sp-sub-menu .twitter a:hover, .sp-sub-menu .twitter a:active, .sp-sub-menu .instagram a:hover, .sp-sub-menu .instagram a:active {
  color: #ffffff !important;
}
.sp-sub-menu .facebook a:visited, .sp-sub-menu .twitter a:visited, .sp-sub-menu .instagram a:visited {
  color: #ffffff;
}

@media screen and (max-width: 767px) {
  .language-box.sp-only {
    overflow: hidden;
    padding: 0 40px 200px 80px;
    display: block !important;
    position: relative !important;
    right: auto !important;
    top: auto !important;
  }
}

.fixed {
  position: fixed !important;
  left: 0;
  width: 100% !important;
  z-index: 500;
}

.fixed {
  height: 80px !important;
  background-image: url(../img/common/header_bg.png);
  background-color: #0F0F0F;
}
.fixed .header-box-inner {
  position: relative;
  width: 1080px;
  margin: 0 auto;
}
.fixed .logo {
  position: absolute;
  overflow: hidden;
  top: 20px !important;
  height: 42px;
  width: 140px;
}
.fixed .logo img {
  position: absolute;
  top: -20px;
  left: 0;
  width: 140px;
}
.fixed .language-box {
  display: none;
}
.fixed .nav-header {
  top: 26px !important;
}

.bodyfixed {
  position: fixed !important;
  height: 100%;
  width: 100%;
}

.and43 #wrapper .sp-menu {
  display: block;
}

/* -------------------------------------
   navigation
------------------------------------- */
#wrapper .nav-header {
  position: absolute;
  display: block;
  top: 120px;
  right: 0px;
}
@media screen and (max-width: 767px) {
  #wrapper .nav-header {
    position: absolute;
    top: 0px;
    left: 0;
    right: 0;
    width: 100%;
  }
}
#wrapper .nav-header .nav-inner {
  position: relative;
  display: block;
}
#wrapper .nav-header .nav-inner:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
@media screen and (max-width: 767px) {
  #wrapper .nav-header .nav-inner {
    display: none;
    z-index: 800;
    position: fixed;
    background-color: rgba(0, 0, 0, 0.7);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    padding-top: 80px;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    overflow-x: hidden;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
    padding-bottom: 200px;
  }
}
#wrapper .nav-header ul.menu {
  position: relative;
  *zoom: 1;
}
@media screen and (max-width: 767px) {
  #wrapper .nav-header ul.menu {
    width: auto;
    min-width: 320px;
  }
}
#wrapper .nav-header ul.menu li {
  position: relative;
  display: block;
  float: left;
  text-align: center;
  font-size: 16px;
  font-size: 1rem;
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 400;
  padding-right: 30px;
}
@media screen and (max-width: 320px) {
  #wrapper .nav-header ul.menu li {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
@media screen and (max-width: 767px) {
  #wrapper .nav-header ul.menu li {
    font-size: 20px;
    font-size: 1.25rem;
    font-weight: bold;
    float: none;
    text-align: left;
    height: 50px;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  #wrapper .nav-header ul.menu li {
    font-size: 18.76px;
    font-size: 1.1725rem;
    font-size: 17.5px;
    font-size: 1.09375rem;
  }
}

#wrapper .nav-header ul.menu li i {
  padding-left: 10px;
}
#wrapper .nav-header ul.menu li a {
  position: relative;
  padding: 0;
  display: block;
  color: #ffffff;
  text-decoration: none;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
}
#wrapper .nav-header ul.menu li a span {
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
  padding-bottom: 6px;
  border-bottom: transparent 3px double;
}
#wrapper .nav-header ul.menu li a:hover span, #wrapper .nav-header ul.menu li a:active span {
  border-bottom: #fff 3px double;
  padding-bottom: 2px;
}
@media screen and (max-width: 767px) {
  #wrapper .nav-header ul.menu li a {
    height: 50px;
    line-height: 50px;
    padding: 0 45px 0 80px;
  }
  #wrapper .nav-header ul.menu li a:hover span, #wrapper .nav-header ul.menu li a:active span {
    background: none;
  }
}
#wrapper .nav-header ul.menu li.top {
  display: none;
}
@media screen and (max-width: 767px) {
  #wrapper .nav-header ul.menu li.top {
    display: block;
  }
}
#wrapper .nav-header ul.menu li.onlinestore {
  display: none;
}
@media screen and (max-width: 767px) {
  #wrapper .nav-header ul.menu li.onlinestore {
    display: block;
  }
}
#wrapper .nav-header ul.menu li.contact {
  padding-right: 0;
}

/*menu select*/
/*main menu*/
body#top #wrapper .nav-header ul.menu li.top span,
body#shamisen #wrapper .nav-header ul.menu li.shamisen span,
body#products #wrapper .nav-header ul.menu li.products span,
body#movies #wrapper .nav-header ul.menu li.movies span,
body#craftsmanship #wrapper .nav-header ul.menu li.craftsmanship span,
body#company #wrapper .nav-header ul.menu li.company span,
body#contact #wrapper .nav-header ul.menu li.contact span {
  padding-bottom: 6px;
  border-bottom: #fff 3px double;
}
@media screen and (max-width: 767px) {
  body#top #wrapper .nav-header ul.menu li.top span,
  body#shamisen #wrapper .nav-header ul.menu li.shamisen span,
  body#products #wrapper .nav-header ul.menu li.products span,
  body#movies #wrapper .nav-header ul.menu li.movies span,
  body#craftsmanship #wrapper .nav-header ul.menu li.craftsmanship span,
  body#company #wrapper .nav-header ul.menu li.company span,
  body#contact #wrapper .nav-header ul.menu li.contact span {
    padding-bottom: 6px;
    border-bottom: #fff 3px double;
  }
}

/* -------------------------------------
   breadcrumbs
------------------------------------- */
ul#breadcrumbs {
  position: relative;
  display: block;
  overflow: hidden;
  width: 1080px;
  margin: 30px auto;
  list-style: none;
  font-size: 14px;
  margin-bottom: 30px;
}
ul#breadcrumbs li {
  float: left;
  margin: 0 2em 0 0;
}
ul#breadcrumbs a {
  padding: .5em 1em .5em 2em;
  float: left;
  text-decoration: none;
  color: #232323;
  background: #e1e2d8;
  position: relative;
  z-index: 1;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
  border-radius: .3em 0 0 .3em;
}
ul#breadcrumbs a:hover {
  background: #dae3d8;
}
ul#breadcrumbs a::after {
  background: #e1e2d8;
  content: "";
  height: 2.5em;
  margin-top: -1.25em;
  position: absolute;
  right: -1em;
  top: 50%;
  width: 2.5em;
  z-index: -1;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
  border-radius: .4em;
}
ul#breadcrumbs a:hover::after {
  background: #dae3d8;
}
ul#breadcrumbs .current,
ul#breadcrumbs .current:hover {
  background: none;
  padding-left: 0;
  color: #4a4a4a;
}
ul#breadcrumbs .current::after {
  content: normal;
}
@media screen and (max-width: 767px) {
  ul#breadcrumbs {
    width: 95%;
  }
  ul#breadcrumbs a {
    padding: .5em 0em .5em 1em;
  }
}
@media screen and (max-width: 414px) {
  ul#breadcrumbs {
    display: none;
  }
}

/* -------------------------------------
   footer
------------------------------------- */
footer {
  position: relative;
  display: block;
  background: #ffffff;
  background-image: url(../img/common/footer_bg.png);
  color: #2f2f2f;
  width: 100%;
  padding: 100px 0 180px;
}
footer .box-inner {
  width: 1080px;
  overflow: hidden;
  margin: 0 auto;
}
footer .address {
  position: absolute;
  top: 170px;
  right: 0;
}
footer .address h2 {
  font-size: 22px;
  font-size: 1.375rem;
  font-weight: bold;
  margin-bottom: 40px;
}
@media screen and (max-width: 320px) {
  footer .address h2 {
    font-size: 20.636px;
    font-size: 1.28975rem;
    font-size: 19.25px;
    font-size: 1.20313rem;
  }
}
footer .address p {
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 10px;
  line-height: 1.6;
}
@media screen and (max-width: 320px) {
  footer .address p {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
footer .bottom {
  position: fixed;
  z-index: 3;
  opacity: 0.8;
  filter: alpha(opacity=80);
  bottom: 0px;
  right: 0px;
  width: 100%;
  height: 80px;
  color: #ffffff;
  background-color: #0F0F0F;
  line-height: 80px;
  overflow: hidden;
}
footer .bottom .facebook, footer .bottom .twitter, footer .bottom .instagram {
  display: inline-block;
  float: left;
  font-size: 24px;
  font-size: 1.5rem;
  padding: 0 20px 0 0;
}
@media screen and (max-width: 320px) {
  footer .bottom .facebook, footer .bottom .twitter, footer .bottom .instagram {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
footer .bottom .facebook a, footer .bottom .twitter a, footer .bottom .instagram a {
  color: #ffffff;
}
footer .bottom .facebook a:hover, footer .bottom .facebook a:active, footer .bottom .twitter a:hover, footer .bottom .twitter a:active, footer .bottom .instagram a:hover, footer .bottom .instagram a:active {
  color: #999999 !important;
}
footer .bottom .facebook a:visited, footer .bottom .twitter a:visited, footer .bottom .instagram a:visited {
  color: #ffffff;
}
footer .bottom .online-store {
  display: inline-block;
  font-size: 16px;
  font-size: 1rem;
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 400;
  margin: 0 auto;
  padding-left: 300px;
  float: left;
}
@media screen and (max-width: 320px) {
  footer .bottom .online-store {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
footer .bottom .online-store i {
  font-size: 24px;
  font-size: 1.5rem;
  padding: 0 20px 0 0;
}
@media screen and (max-width: 320px) {
  footer .bottom .online-store i {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
footer .bottom .online-store a {
  color: #ffffff;
  border: #ffffff 1px solid;
  padding: 4px 30px;
}
footer .bottom .online-store a:hover, footer .bottom .online-store a:active {
  background-color: #333;
}
footer .bottom .online-store a:visited {
  color: #ffffff;
}
footer .bottom small {
  display: inline-block;
  font-size: 16px;
  font-size: 1rem;
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 400;
  padding: 0 100px 0 0;
  float: right;
}
@media screen and (max-width: 320px) {
  footer .bottom small {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
footer .bottom .staff {
  font-size: 13px;
  font-size: 0.8125rem;
}
footer .bottom .staff a {
  color: #ffffff;
  text-decoration: underline;
}
footer .bottom .staff a:hover, footer .bottom .staff a:active {
  padding-bottom: 4px;
  color: #c7f8da;
}
footer .bottom .staff a:visited {
  color: #ffffff;
  text-decoration: underline;
}
@media screen and (max-width: 767px) {
  footer {
    width: 100%;
    padding: 30px 0 0;
    background-size: 55px;
    text-align: center;
  }
  footer .box-inner {
    width: auto;
    padding: 0 20px;
  }
  footer .fb-page {
    text-align: center;
  }
  footer .address {
    display: inline-block;
    position: relative;
    top: auto;
    right: auto;
    text-align: left;
    padding: 80px 0;
  }
  footer .address h2 {
    font-size: 18px;
    font-size: 1.125rem;
    font-weight: bold;
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  footer .address h2 {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
@media screen and (max-width: 767px) {
  footer .address p {
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    margin-bottom: 5px;
  }
  footer .address a {
    text-decoration: underline;
    color: #2f2f2f;
  }
  footer .bottom {
    position: relative;
    bottom: auto;
    right: auto;
    text-align: center;
  }
  footer .bottom .box-inner {
    padding-left: 20px;
  }
  footer .bottom .online-store {
    display: none;
  }
}
@media screen and (max-width: 414px) {
  footer .bottom .facebook, footer .bottom .twitter, footer .bottom .instagram {
    display: none;
  }
}

/* -------------------------------------
   btn-pagetop
------------------------------------- */
.btn-pagetop {
  position: absolute;
  display: block;
  bottom: 0px;
  right: 0px;
  width: 80px;
  height: 80px;
  line-height: 80px;
  text-align: center;
  z-index: 4;
  font-size: 60px;
  font-size: 3.75rem;
}
@media screen and (max-width: 320px) {
  .btn-pagetop {
    font-size: 56.28px;
    font-size: 3.5175rem;
    font-size: 52.5px;
    font-size: 3.28125rem;
  }
}
.btn-pagetop i {
  color: #ffffff;
}
.btn-pagetop a {
  display: block;
  width: 80px;
  height: 80px;
  background-color: #CB9D75;
}
.btn-pagetop a:hover, .btn-pagetop a:active {
  background-color: #BB8D65;
}

/* -------------------------------------
   swiper setting
------------------------------------- */
.swiper-container {
  min-width: 1070px;
  width: 100%;
}
.swiper-container .swiper-wrapper .swiper-slide img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .swiper-container {
    min-width: 320px;
  }
}

/* IE9 */
.ie9 .swiper-container .swiper-wrapper .swiper-slide,
.ie9 .swiper-container .swiper-pagination,
.ie9 .swiper-container .swiper-button-prev,
.ie9 .swiper-container .swiper-button-next {
  display: none;
}

.ie9 .swiper-container .swiper-wrapper .swiper-slide:first-child {
  display: block;
}

/* -------------------------------------
   top
------------------------------------- */
.main-image {
  position: relative;
  display: block;
}
.main-image .main-image-container .main-image-wrapper .slide {
  width: 100%;
}
.main-image .main-image-container .main-image-wrapper .slide img {
  width: 100%;
}
.main-image .main-image-container .main-image-wrapper .slide a {
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
}
.main-image .main-image-container .main-image-wrapper .slide a:hover {
  opacity: 0.8;
  filter: alpha(opacity=80);
}
.main-image .main-image-container .main-image-wrapper .slide a:after {
  font-family: FontAwesome;
  font-size: 50px;
  font-size: 3.125rem;
  content: "\f144";
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -40px 0 0 -25px;
}
@media screen and (max-width: 320px) {
  .main-image .main-image-container .main-image-wrapper .slide a:after {
    font-size: 46.9px;
    font-size: 2.93125rem;
    font-size: 43.75px;
    font-size: 2.73438rem;
  }
}

#top-about {
  position: relative;
  display: block;
  width: 988px;
  margin: 100px auto 100px;
  background-color: #ffffff;
}
#top-about h2 {
  font-family: 'Ryumin Medium KL', serif;
  font-style: normal;
  font-size: 75px;
  font-size: 4.6875rem;
  line-height: 1.4em;
  text-align: left;
  color: #796E65;
  padding: 0px;
}
@media screen and (max-width: 320px) {
  #top-about h2 {
    font-size: 70.35px;
    font-size: 4.39687rem;
    font-size: 65.625px;
    font-size: 4.10156rem;
  }
}
#top-about h2.en {
  font-family: 'Vollkorn', serif;
  font-style: normal;
  line-height: 1.2em;
}
#top-about p.top-about-text {
  font-size: 20px;
  font-size: 1.25rem;
  color: #7C7C7C;
  text-align: left;
  padding-bottom: 40px;
  width: 600px;
  margin-top: -40px;
  margin-left: auto;
}
@media screen and (max-width: 320px) {
  #top-about p.top-about-text {
    font-size: 18.76px;
    font-size: 1.1725rem;
    font-size: 17.5px;
    font-size: 1.09375rem;
  }
}
#top-about p.top-about-text.en {
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  #top-about {
    width: auto;
    margin: 0px auto;
    padding: 0 20px;
  }
  #top-about h2 {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-style: normal;
    font-size: 32px;
    font-size: 2rem;
    line-height: 1.4;
    text-align: left;
    padding: 40px 0 20px;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  #top-about h2 {
    font-size: 30.016px;
    font-size: 1.876rem;
    font-size: 28px;
    font-size: 1.75rem;
  }
}
@media screen and (max-width: 767px) {
  #top-about p.top-about-text {
    font-size: 16px;
    font-size: 1rem;
    width: auto;
    margin-top: 0px;
    text-align: left;
    padding-bottom: 40px;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  #top-about p.top-about-text {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}

@media screen and (max-width: 320px) {
  #top-about h2 {
    font-size: 32px;
    font-size: 2rem;
    text-align: left;
  }
}
@media screen and (max-width: 320px) and (max-width: 320px) {
  #top-about h2 {
    font-size: 30.016px;
    font-size: 1.876rem;
    font-size: 28px;
    font-size: 1.75rem;
  }
}
@media screen and (max-width: 320px) {
  #top-about p.top-about-text {
    padding-bottom: 40px;
  }
}

#top-products {
  position: relative;
  display: block;
  width: 100%;
  margin: 0px auto;
  overflow: hidden;
}
#top-products h2 {
  position: absolute;
  display: inline-block;
  z-index: 1;
  font-size: 34px;
  font-size: 2.125rem;
  font-weight: bold;
  color: #CB9D75;
  line-height: 1;
}
@media screen and (max-width: 320px) {
  #top-products h2 {
    font-size: 31.892px;
    font-size: 1.99325rem;
    font-size: 29.75px;
    font-size: 1.85938rem;
  }
}
#top-products h2 span {
  font-size: 20px;
  font-size: 1.25rem;
}
@media screen and (max-width: 320px) {
  #top-products h2 span {
    font-size: 18.76px;
    font-size: 1.1725rem;
    font-size: 17.5px;
    font-size: 1.09375rem;
  }
}
#top-products h2.en {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 400;
}
#top-products p.top-detail {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 400;
  position: absolute;
  display: inline-block;
  z-index: 1;
  color: #000000;
}
#top-products p.top-detail i {
  padding: 0 4px 0 0;
}
#top-products a p.top-detail i {
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
}
#top-products a .products-image {
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
}
#top-products a:hover p.top-detail i {
  padding: 0 1px 0 3px;
}
#top-products a:hover .products-image {
  opacity: 0.7;
  filter: alpha(opacity=70);
}
#top-products .top-products1 {
  position: relative;
  width: 50%;
  float: left;
}
#top-products .top-products1 h2 {
  top: 40px;
  right: 40px;
}
#top-products .top-products1 p.top-detail {
  left: 40px;
  bottom: 40px;
}
#top-products .top-products2 {
  position: relative;
  width: 50%;
  float: left;
}
#top-products .top-products2 h2 {
  bottom: 40px;
  left: 40px;
}
#top-products .top-products2 p.top-detail {
  top: 40px;
  right: 40px;
}
#top-products .products-image img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  #top-products h2 {
    font-size: 26px;
    font-size: 1.625rem;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  #top-products h2 {
    font-size: 24.388px;
    font-size: 1.52425rem;
    font-size: 22.75px;
    font-size: 1.42188rem;
  }
}
@media screen and (max-width: 767px) {
  #top-products .top-products1 {
    width: 100%;
    float: none;
    margin-bottom: 40px;
  }
  #top-products .top-products1 h2 {
    top: 20px;
    right: 20px;
  }
  #top-products .top-products1 p.top-detail {
    left: 20px;
    bottom: 20px;
  }
  #top-products .top-products2 {
    width: 100%;
    float: none;
  }
  #top-products .top-products2 h2 {
    bottom: 20px;
    left: 20px;
  }
  #top-products .top-products2 p.top-detail {
    top: 20px;
    right: 20px;
  }
}
@media screen and (max-width: 320px) {
  #top-products h2 {
    font-size: 24px;
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 320px) and (max-width: 320px) {
  #top-products h2 {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
@media screen and (max-width: 320px) {
  #top-products .top-products1 h2 {
    top: 10px;
    right: 5px;
  }
  #top-products .top-products2 h2 {
    bottom: 10px;
    left: 10px;
  }
}

/* -------------------------------------
   Page Style Common
------------------------------------- */
#page-about {
  position: relative;
  display: block;
  width: 1070px;
  margin: 30px auto 60px;
  background-color: #ffffff;
  /*Android hack*/
}
#page-about h1.page-about-title {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 40px;
  font-size: 2.5rem;
  line-height: 1.2em;
  text-align: center;
  color: #383838;
  padding: 50px 0 0 0;
  background: #fff url("../img/common/shipou.png") 50% 0 no-repeat;
  background-size: 40px;
}
@media screen and (max-width: 320px) {
  #page-about h1.page-about-title {
    font-size: 37.52px;
    font-size: 2.345rem;
    font-size: 35px;
    font-size: 2.1875rem;
  }
}
#page-about h1.page-about-title-jp {
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: bold;
  text-align: center;
  color: #383838;
}
@media screen and (max-width: 320px) {
  #page-about h1.page-about-title-jp {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
#page-about p.page-about-text {
  font-size: 16px;
  font-size: 1rem;
  color: #383838;
  text-align: left;
  padding: 80px 0 0px;
  margin: 0 auto;
}
@media screen and (max-width: 320px) {
  #page-about p.page-about-text {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
@media screen and (max-width: 767px) {
  #page-about {
    width: 90%;
    margin: 30px auto 70px;
  }
  #page-about p.page-about-text {
    padding: 40px 0 0px;
  }
}

.black-box {
  background-color: #000;
  padding: 60px;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .black-box {
    padding: 40px 20px;
  }
}

h2.sub-title {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 36px;
  font-size: 2.25rem;
  text-align: center;
}
@media screen and (max-width: 320px) {
  h2.sub-title {
    font-size: 33.768px;
    font-size: 2.1105rem;
    font-size: 31.5px;
    font-size: 1.96875rem;
  }
}
@media screen and (max-width: 767px) {
  h2.sub-title {
    padding: 0 20px;
    line-height: 1.2;
  }
}

h2.sub-title-jp {
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  text-align: center;
  padding-top: 0px;
}
@media screen and (max-width: 320px) {
  h2.sub-title-jp {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
@media screen and (max-width: 767px) {
  h2.sub-title-jp {
    padding-top: 8px;
  }
}

/*以下削除対象*/
h1.title-header {
  font-size: 30px;
  font-size: 1.875rem;
  margin-bottom: 40px;
  text-align: center;
  color: #030303;
  background-color: #ffffff;
  /*Android hack*/
}
@media screen and (max-width: 320px) {
  h1.title-header {
    font-size: 28.14px;
    font-size: 1.75875rem;
    font-size: 26.25px;
    font-size: 1.64063rem;
  }
}
@media screen and (max-width: 767px) {
  h1.title-header {
    font-size: 26px;
    font-size: 1.625rem;
    line-height: 1.4;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  h1.title-header {
    font-size: 24.388px;
    font-size: 1.52425rem;
    font-size: 22.75px;
    font-size: 1.42188rem;
  }
}

@media screen and (max-width: 414px) {
  h1.title-header {
    margin-top: 40px;
  }
}
@media screen and (max-width: 320px) {
  h1.title-header {
    font-size: 24px;
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 320px) and (max-width: 320px) {
  h1.title-header {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}

h2.title-second {
  font-family: 'Ryumin Medium KL', serif;
  font-style: normal;
  font-size: 30px;
  font-size: 1.875rem;
  text-align: left;
  color: #ff7252;
  margin: 0 0 25px;
  background-color: #ffffff;
  /*Android hack*/
}
@media screen and (max-width: 320px) {
  h2.title-second {
    font-size: 28.14px;
    font-size: 1.75875rem;
    font-size: 26.25px;
    font-size: 1.64063rem;
  }
}
@media screen and (max-width: 767px) {
  h2.title-second {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-style: normal;
    font-size: 24px;
    font-size: 1.5rem;
    line-height: 1.4;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  h2.title-second {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}

@media screen and (max-width: 414px) {
  h2.title-second {
    font-size: 22px;
    font-size: 1.375rem;
  }
}
@media screen and (max-width: 414px) and (max-width: 320px) {
  h2.title-second {
    font-size: 20.636px;
    font-size: 1.28975rem;
    font-size: 19.25px;
    font-size: 1.20313rem;
  }
}

h3.title-third {
  font-family: 'Ryumin Medium KL', serif;
  font-style: normal;
  font-size: 22px;
  font-size: 1.375rem;
  text-align: left;
  color: #030303;
  margin: 0 0 20px;
  font-weight: bold;
  background-color: #ffffff;
  /*Android hack*/
}
@media screen and (max-width: 320px) {
  h3.title-third {
    font-size: 20.636px;
    font-size: 1.28975rem;
    font-size: 19.25px;
    font-size: 1.20313rem;
  }
}
@media screen and (max-width: 767px) {
  h3.title-third {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-style: normal;
    font-weight: normal;
  }
}

p.text {
  margin-bottom: 1.5em;
  background-color: #ffffff;
  /*Android hack*/
}

.arrow-link {
  clear: both;
}
.arrow-link a {
  padding-bottom: 1px;
}
.arrow-link a i {
  padding-right: 10px;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
  color: #2f2f2f;
  text-decoration: none;
}
.arrow-link a:hover, .arrow-link a:active {
  text-decoration: none;
}
.arrow-link a:hover i, .arrow-link a:active i {
  padding-right: 5px;
  padding-left: 5px;
}

.page-inner {
  position: relative;
  display: block;
  width: 800px;
  margin: 0 auto 80px;
}
@media screen and (max-width: 767px) {
  .page-inner {
    width: 90%;
  }
}

/* ======================================================
   about shamisen page
====================================================== */
/* -------------------------------------
   about shamisen index
------------------------------------- */
#shamisen-description {
  position: relative;
}
#shamisen-description .shamisen-description1 {
  position: relative;
  display: block;
  margin-bottom: -75px;
}
#shamisen-description .shamisen-description2 {
  position: relative;
  display: block;
  margin-bottom: -75px;
}
#shamisen-description .black-box {
  position: relative;
  width: 45%;
  left: 8.2%;
  top: -175px;
}
#shamisen-description .shamisen-description-title {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: bold;
  padding-bottom: 30px;
}
@media screen and (max-width: 320px) {
  #shamisen-description .shamisen-description-title {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
#shamisen-description .shamisen-description-title.en {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 400;
}
#shamisen-description .shamisen-description-text {
  font-size: 16px;
  font-size: 1rem;
}
@media screen and (max-width: 320px) {
  #shamisen-description .shamisen-description-text {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
#shamisen-description .shamisen-description-image img {
  width: 100%;
}
#shamisen-description .shamisen-description3 {
  width: 1070px;
  margin: 0 auto;
  overflow: hidden;
}
#shamisen-description .shamisen-description3 .shamisen-description-title3 {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 36px;
  font-size: 2.25rem;
  text-align: center;
}
@media screen and (max-width: 320px) {
  #shamisen-description .shamisen-description3 .shamisen-description-title3 {
    font-size: 33.768px;
    font-size: 2.1105rem;
    font-size: 31.5px;
    font-size: 1.96875rem;
  }
}
#shamisen-description .shamisen-description3 .shamisen-description-title3-jp {
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  text-align: center;
  padding-top: 0px;
}
@media screen and (max-width: 320px) {
  #shamisen-description .shamisen-description3 .shamisen-description-title3-jp {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
#shamisen-description .shamisen-description3 .shamisen-description3-box {
  padding-top: 50px;
}
#shamisen-description .shamisen-description3 .shamisen-description-text3 {
  width: 48%;
  float: right;
}
#shamisen-description .shamisen-description3 .shamisen-description-image3 {
  width: 48%;
  float: left;
}
@media screen and (max-width: 767px) {
  #shamisen-description .shamisen-description1 {
    margin-bottom: 40px;
  }
  #shamisen-description .shamisen-description2 {
    margin-bottom: 100px;
  }
  #shamisen-description .black-box {
    width: auto;
    left: auto;
    top: auto;
  }
  #shamisen-description .shamisen-description3 {
    width: auto;
  }
  #shamisen-description .shamisen-description3 .shamisen-description-title3 {
    padding: 0 20px;
    line-height: 1.2;
  }
  #shamisen-description .shamisen-description3 .shamisen-description-title3-jp {
    padding-top: 8px;
  }
  #shamisen-description .shamisen-description3 .shamisen-description3-box {
    padding-top: 40px;
  }
  #shamisen-description .shamisen-description3 .shamisen-description-text3 {
    width: 90%;
    float: none;
    margin: 0 auto;
  }
  #shamisen-description .shamisen-description3 .shamisen-description-image3 {
    width: auto;
    float: none;
    margin-bottom: 30px;
  }
}

/* ======================================================
   products page
====================================================== */
/* -------------------------------------
   products index
------------------------------------- */
#products #page-about h1.page-about-title br {
  display: none;
}
@media screen and (max-width: 767px) {
  #products #page-about h1.page-about-title br {
    display: inline-block;
  }
}

#nagauta-shamisen,
#tsugaru-shamisen {
  padding-top: 90px;
  margin-top: -90px;
}
@media screen and (max-width: 767px) {
  #nagauta-shamisen,
  #tsugaru-shamisen {
    padding-top: 0px;
    margin-top: 0px;
  }
}

.products-list {
  position: relative;
  width: 1070px;
  margin: 0 auto 80px;
  overflow: hidden;
}
.products-list .products-image {
  width: 48%;
  float: left;
}
.products-list .products-detail {
  width: 48%;
  float: right;
}
.products-list .products-name {
  font-size: 24px;
  font-size: 1.5rem;
  color: #CB9D75;
  font-weight: bold;
  margin: 0px 0 20px;
}
@media screen and (max-width: 320px) {
  .products-list .products-name {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
.products-list .products-name.en {
  line-height: 1.4em;
}
.products-list .products-spec {
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: bold;
  list-style: none;
  margin-bottom: 30px;
}
.products-list .products-description {
  margin-bottom: 20px;
}
.products-list .products-price {
  font-weight: bold;
  list-style: none;
  margin-bottom: 10px;
}
.products-list .products-notes {
  font-size: 12px;
  font-size: 0.75rem;
  margin-bottom: 20px;
}
.products-list .products-storelinkbtn {
  float: right;
  font-size: 18px;
  font-size: 1.125rem;
}
@media screen and (max-width: 320px) {
  .products-list .products-storelinkbtn {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
.products-list .products-storelinkbtn a {
  font-weight: bold;
  display: inline-block;
  color: #ffffff;
  background-color: #CB9D75;
  padding: 8px 50px;
}
.products-list .products-storelinkbtn a:hover, .products-list .products-storelinkbtn a:active {
  background-color: #AB7D55;
}
@media screen and (max-width: 767px) {
  .products-list {
    width: auto;
  }
  .products-list .products-image {
    width: auto;
    float: none;
    margin-bottom: 30px;
  }
  .products-list .products-detail {
    width: 90%;
    float: none;
    margin: 0 auto;
  }
  .products-list .products-name {
    line-height: 1.2;
  }
  .products-list .products-storelinkbtn {
    float: none;
    margin: 0 auto;
    text-align: center;
  }
}

#products-notice {
  position: relative;
  max-width: 990px;
  width: 90%;
  margin: 0 auto 120px;
  overflow: hidden;
  padding: 40px;
  background-color: #F5EAE1;
}
#products-notice h2 {
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: bold;
  margin-bottom: 20px;
}
@media screen and (max-width: 320px) {
  #products-notice h2 {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
@media screen and (max-width: 767px) {
  #products-notice {
    padding: 5%;
    width: auto;
    max-width: 85%;
  }
}

#products-features-ripple {
  width: 1070px;
  margin: 0 auto;
  overflow: hidden;
}
#products-features-ripple #products-features-ripple-title {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 600;
  font-size: 36px;
  font-size: 2.25rem;
  text-align: center;
}
@media screen and (max-width: 320px) {
  #products-features-ripple #products-features-ripple-title {
    font-size: 33.768px;
    font-size: 2.1105rem;
    font-size: 31.5px;
    font-size: 1.96875rem;
  }
}
#products-features-ripple #products-features-ripple-title-jp {
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  text-align: center;
  padding-top: 0px;
}
@media screen and (max-width: 320px) {
  #products-features-ripple #products-features-ripple-title-jp {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
#products-features-ripple ul {
  width: 1070px;
  padding-top: 50px;
}
#products-features-ripple ul.en li h3 {
  font-size: 16px;
  font-size: 1rem;
}
@media screen and (max-width: 320px) {
  #products-features-ripple ul.en li h3 {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
#products-features-ripple li {
  float: left;
  width: 330px;
  margin: 0 40px 60px 0;
  list-style: none;
  text-align: center;
}
#products-features-ripple li img {
  height: 40px;
  margin: 0 auto 10px;
}
#products-features-ripple li h3 {
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: bold;
  padding-bottom: 10px;
  border-bottom: 2px solid #2f2f2f;
}
@media screen and (max-width: 320px) {
  #products-features-ripple li h3 {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
#products-features-ripple li p {
  padding: 10px 20px 0;
  text-align: left;
}
#products-features-ripple li:nth-child(3n) {
  margin: 0 0 60px 0;
}
@media screen and (max-width: 767px) {
  #products-features-ripple {
    width: auto;
  }
  #products-features-ripple #products-features-ripple-title {
    padding: 0 20px;
    line-height: 1.2;
  }
  #products-features-ripple #products-features-ripple-title-jp {
    padding-top: 8px;
  }
  #products-features-ripple ul {
    width: auto;
    padding-top: 40px;
  }
  #products-features-ripple li {
    float: none;
    width: 90%;
    margin: 0 auto 40px;
  }
  #products-features-ripple li:nth-child(3n) {
    margin: 0 auto 40px;
  }
}

/* ======================================================
   movies page
====================================================== */
#movies-list {
  position: relative;
  width: 1070px;
  margin: 0 auto 80px;
  overflow: hidden;
}
#movies-list ul {
  width: 1070px;
}
#movies-list li {
  float: left;
  width: 515px;
  margin: 0 40px 60px 0;
  list-style: none;
  position: relative;
}
#movies-list li img {
  height: 290px;
  margin: 0 auto 30px;
}
#movies-list li a {
  height: 290px;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
  position: relative;
}
#movies-list li a:hover {
  opacity: 0.8;
  filter: alpha(opacity=80);
}
#movies-list li h2 {
  font-size: 18px;
  font-size: 1.125rem;
  color: #CB9D75;
  font-weight: bold;
  padding-bottom: 10px;
  line-height: 1.4;
}
@media screen and (max-width: 320px) {
  #movies-list li h2 {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
#movies-list li:nth-child(2n) {
  margin: 0 0 60px 0;
}
@media screen and (max-width: 767px) {
  #movies-list {
    width: auto;
  }
  #movies-list ul {
    width: auto;
  }
  #movies-list li {
    float: none;
    width: 90%;
    margin: 0 auto 50px;
  }
  #movies-list li img {
    height: auto;
    margin: 0 auto 30px;
  }
  #movies-list li a {
    height: auto;
  }
  #movies-list li:nth-child(2n) {
    margin: 0 auto 50px;
  }
}

#movies-players {
  position: relative;
  width: 1070px;
  margin: 0 auto 80px;
  overflow: hidden;
}
#movies-players .movies-players-profile {
  padding-top: 50px;
  margin-bottom: -70px;
}
#movies-players .movies-players-profile .movies-players-profile-image img {
  width: 700px;
}
#movies-players .black-box {
  position: relative;
  width: 555px;
  left: 515px;
  top: -100px;
}
#movies-players .movies-players-profile-name {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: bold;
  padding-bottom: 30px;
}
@media screen and (max-width: 320px) {
  #movies-players .movies-players-profile-name {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
#movies-players .movies-players-profile-name.en {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 400;
}
#movies-players .movies-players-profile-text {
  width: 435px;
  font-size: 16px;
  font-size: 1rem;
}
@media screen and (max-width: 320px) {
  #movies-players .movies-players-profile-text {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
@media screen and (max-width: 767px) {
  #movies-players {
    width: auto;
  }
  #movies-players .movies-players-profile {
    padding-top: 40px;
    margin-bottom: 0;
  }
  #movies-players .movies-players-profile .movies-players-profile-image img {
    width: auto;
  }
  #movies-players .black-box {
    position: relative;
    width: auto;
    left: 0;
    top: 0;
  }
  #movies-players .movies-players-profile-text {
    width: auto;
  }
}

/* ======================================================
   craftsmanship page
====================================================== */
/* -------------------------------------
   craftsmanship index
------------------------------------- */
#craftsmanship-section .swiper-slide .black-box {
  position: relative;
  width: 70%;
  max-width: 1070px;
  top: -100px;
  margin: 0 auto -70px;
  min-height: 130px;
}
#craftsmanship-section .swiper-slide .black-box h2.craftsmanship-description-title {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 15px;
}
@media screen and (max-width: 320px) {
  #craftsmanship-section .swiper-slide .black-box h2.craftsmanship-description-title {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
#craftsmanship-section .swiper-slide .black-box h2.craftsmanship-description-title span {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 600;
  margin-right: 24px;
}
#craftsmanship-section .swiper-slide .black-box h2.craftsmanship-description-title.en {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 600;
}
#craftsmanship-section .swiper-slide .black-box p.craftsmanship-description-no {
  font-family: 'Palanquin Dark', sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 20px;
  font-size: 1.25rem;
  position: absolute;
  top: 20px;
  right: 30px;
}
@media screen and (max-width: 320px) {
  #craftsmanship-section .swiper-slide .black-box p.craftsmanship-description-no {
    font-size: 18.76px;
    font-size: 1.1725rem;
    font-size: 17.5px;
    font-size: 1.09375rem;
  }
}
#craftsmanship-section .thumb-slide {
  position: relative;
  width: 70%;
  max-width: 1070px;
}
@media screen and (max-width: 767px) {
  #craftsmanship-section .swiper-pagination {
    display: none;
  }
  #craftsmanship-section .swiper-slide .black-box {
    width: auto;
    max-width: auto;
    top: auto;
    margin: 0 auto;
    min-height: 200px;
  }
  #craftsmanship-section .swiper-slide .black-box p.craftsmanship-description-no {
    top: 10px;
    right: 20px;
  }
}
@media screen and (max-width: 380px) {
  #craftsmanship-section .swiper-slide .black-box {
    min-height: 350px;
  }
}

.swiper-pagination {
  position: relative;
  text-align: left;
  max-width: 1070px;
  margin: 0 auto;
}

.swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 10px;
  left: auto;
  right: auto;
  width: 80%;
}

.swiper-pagination-bullet {
  width: 100px;
  height: 66px;
  display: inline-block;
  border-radius: 0;
  background: #000;
  opacity: 1;
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -webkit-appearance: none;
  appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-white .swiper-pagination-bullet {
  background: #fff;
}

.swiper-pagination-bullet-active {
  opacity: 0.5;
  background: none;
}

.swiper-pagination-white .swiper-pagination-bullet-active {
  background: #fff;
}

.swiper-pagination-black .swiper-pagination-bullet-active {
  background: #000;
}

.swiper-container-vertical > .swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  -webkit-transform: translate3d(0px, -50%, 0);
  -moz-transform: translate3d(0px, -50%, 0);
  -o-transform: translate(0px, -50%);
  -ms-transform: translate3d(0px, -50%, 0);
  transform: translate3d(0px, -50%, 0);
}

.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 5px 0;
  display: block;
}

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 7px 7px 0;
}

@media screen and (max-width: 767px) {
  .swiper-button-prev,
  .swiper-button-next {
    top: 35%;
    /*50%;*/
  }
}
@media screen and (max-width: 767px) {
  .swiper-button-prev,
  .swiper-button-next {
    top: 20%;
    /*50%;*/
  }
}

/* ======================================================
   company page
====================================================== */
#company-philosophy {
  margin-bottom: 100px;
}
#company-philosophy p {
  font-size: 30px;
  font-size: 1.875rem;
  font-family: 'Ryumin Medium KL', serif;
  font-style: normal;
  color: #796E65;
  text-align: center;
  padding-top: 50px;
}
@media screen and (max-width: 320px) {
  #company-philosophy p {
    font-size: 28.14px;
    font-size: 1.75875rem;
    font-size: 26.25px;
    font-size: 1.64063rem;
  }
}
#company-philosophy p.en {
  font-family: 'Vollkorn', serif;
  font-style: normal;
}
@media screen and (max-width: 767px) {
  #company-philosophy {
    width: auto;
  }
  #company-philosophy p {
    width: 90%;
    margin: 0 auto;
    font-size: 24px;
    font-size: 1.5rem;
    padding-top: 40px;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  #company-philosophy p {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
@media screen and (max-width: 767px) {
  #company-philosophy p.en {
    line-height: 1.4em;
  }
}
@media screen and (max-width: 480px) {
  #company-philosophy p {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 480px) and (max-width: 320px) {
  #company-philosophy p {
    font-size: 18.76px;
    font-size: 1.1725rem;
    font-size: 17.5px;
    font-size: 1.09375rem;
  }
}

#company-message {
  margin-bottom: 100px;
}
#company-message #company-message-president {
  padding-top: 50px;
}
#company-message .company-message-image img {
  width: 100%;
}
#company-message .black-box {
  position: relative;
  width: 70%;
  max-width: 1070px;
  top: -100px;
  margin: 0 auto -100px;
}
#company-message .company-message-title {
  font-size: 30px;
  font-size: 1.875rem;
  width: 40%;
}
@media screen and (max-width: 320px) {
  #company-message .company-message-title {
    font-size: 28.14px;
    font-size: 1.75875rem;
    font-size: 26.25px;
    font-size: 1.64063rem;
  }
}
#company-message .company-message-title.en {
  width: 60%;
  line-height: 1.4;
  font-weight: bold;
}
#company-message .company-message-text {
  position: relative;
  width: 70%;
  top: -110px;
  left: 30%;
  margin-bottom: -50px;
}
#company-message .company-message-text.en {
  top: 20px;
  width: 80%;
  left: 20%;
  margin-bottom: 60px;
}
#company-message .company-message-text em {
  font-size: 18px;
  font-size: 1.125rem;
  font-style: normal;
  font-weight: bold;
}
@media screen and (max-width: 320px) {
  #company-message .company-message-text em {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
#company-message .company-message-signature {
  text-align: right;
}
#company-message .company-message-signature span {
  display: block;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: bold;
}
@media screen and (max-width: 320px) {
  #company-message .company-message-signature span {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
@media screen and (max-width: 767px) {
  #company-message {
    width: auto;
  }
  #company-message #company-message-president {
    padding-top: 40px;
  }
  #company-message .black-box {
    position: relative;
    width: auto;
    left: 0;
    top: 0;
    margin-bottom: 0;
  }
  #company-message .company-message-title {
    font-size: 24px;
    font-size: 1.5rem;
    width: auto;
    font-weight: bold;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  #company-message .company-message-title {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
@media screen and (max-width: 767px) {
  #company-message .company-message-title br {
    display: none;
  }
  #company-message .company-message-title.en {
    width: auto;
    line-height: 1.4;
    font-weight: bold;
  }
  #company-message .company-message-text {
    width: auto;
    top: 20px;
    left: 0;
    margin-bottom: 40px;
  }
  #company-message .company-message-text.en {
    top: 20px;
    width: auto;
    left: 0;
    margin-bottom: 40px;
  }
  #company-message .company-message-signature img {
    width: 150px;
  }
  #company-message .company-message-signature span {
    display: block;
    font-size: 18px;
    font-size: 1.125rem;
    font-weight: bold;
  }
}
@media screen and (max-width: 767px) and (max-width: 320px) {
  #company-message .company-message-signature span {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}

#company-profile {
  position: relative;
  width: 1070px;
  margin: 0 auto 80px;
  overflow: hidden;
}
#company-profile dl {
  width: 500px;
  line-height: 1.4;
  float: left;
  padding-top: 50px;
}
#company-profile dl.company-profile1 {
  margin-right: 70px;
}
#company-profile dt {
  font-weight: bold;
  display: block;
  width: 30%;
  clear: left;
  float: left;
  margin-bottom: 20px;
}
#company-profile dd {
  display: block;
  width: 70%;
  float: left;
  margin-bottom: 20px;
}
#company-profile dd li {
  list-style: none;
  margin-bottom: 10px;
}
#company-profile dd li:last-child {
  margin-bottom: 0;
}
#company-profile dd a {
  text-decoration: underline;
  color: #2f2f2f;
}
@media screen and (max-width: 767px) {
  #company-profile {
    width: auto;
  }
  #company-profile dl {
    width: 90%;
    margin: 0 auto;
    float: none;
    padding-top: 40px;
  }
  #company-profile dl.company-profile1 {
    margin: 0 auto;
  }
}
@media screen and (max-width: 480px) {
  #company-profile dl.company-profile2 {
    padding-top: 0;
  }
  #company-profile dt {
    width: auto;
    float: none;
    margin-bottom: 10px;
  }
  #company-profile dd {
    width: auto;
    float: none;
    margin-bottom: 20px;
  }
}

#company-googlemap {
  width: 100%;
  height: 600px;
  margin-top: -30px;
}
@media screen and (max-width: 767px) {
  #company-googlemap {
    height: 400px;
  }
}

/* ======================================================
   contact page
====================================================== */
/* -------------------------------------
   common
------------------------------------- */
#contact #page-about p.page-about-text {
  padding-bottom: 0;
}

#contact-form {
  position: relative;
  width: 1070px;
  margin: 0 auto;
  display: block;
}
#contact-form .form_notes {
  font-size: 14px;
  font-size: 0.875rem;
  margin: 10px 0 0 0;
}
#contact-form #mailformpro dt.form-title {
  font-weight: bold;
}
#contact-form #mailformpro dt.form-title .must {
  padding: 3px 10px;
}
#contact-form #mailformpro dt.form-title .must.not {
  visibility: hidden;
}
@media screen and (max-width: 767px) {
  #contact-form {
    width: 90%;
    margin: 0 auto;
  }
  #contact-form #mailformpro dt.form-title .must.not {
    display: none;
  }
}

.botton-link {
  text-align: center;
}
.botton-link a {
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  display: inline-block;
  padding: 20px 40px;
  margin: 30px;
  color: #fff;
  background-color: #CB9D75;
  text-align: center;
}
@media screen and (max-width: 320px) {
  .botton-link a {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
.botton-link a:hover {
  background-color: #AB7D55;
}

/* ======================================================
   mailformpro
====================================================== */
/* -------------------------------------
   mailformpro common
------------------------------------- */
/* Chromeでinputのオートフィル機能(以前submitした情報を記憶する機能)で背景色が黄色になるのを回避 */
input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #fff inset;
}

/* 全体警告テキスト */
div#mfp_error, div#mfp_warning {
  background-color: #FEE;
  border: solid 1px #F00;
  padding: 10px;
  display: none;
}

div#mfp_error p, div#mfp_warning p {
  padding: 0px;
  margin: 0px;
  font-size: 14px;
  text-align: center;
}

div#mfp_error p strong, div#mfp_warning p strong {
  font-size: 18px;
  color: #F00;
}

#mailformpro {
  width: 100%;
  color: #030303;
  margin: 40px auto 150px;
  /*
  .mfp_element_text,
  .mfp_element_number,
  .mfp_element_select-one,
  .mfp_element_email,
  .mfp_element_tel,
  .mfp_element_textarea,
  .mfp_element_date {
  	border: solid 1px #CCC;
  	border-radius: 3px;
  	box-shadow: 0px 0px 5px #CCC inset;
  	padding: 3px 8px;
  	margin: 2px;
  	vertical-align: middle;
  }*/
  /*
  .mfp_element_checkbox,
  .mfp_element_radio {
  	vertical-align: middle;
  	margin: 0px 2px;
  }
  */
  /*エラーテキスト*/
  /* 未入力・エラー時 フォームの色*/
  /* OKマーク */
  /* 送信ボタン */
  /* ラジオボタン、チェックボタン
  label {
  	//border-radius: 3px;
  	//margin: 3px;
  	display: inline-block;
  	white-space: nowrap;
  }
  label.mfp_checked {
  	//padding: 3px;
  	//border: solid 1px #CCC;
  	//background-color: #E8EEF9;
  	//box-shadow: 0px 1px 3px #CCC inset;
  }
  label.mfp_not_checked {
  	//padding: 3px;
  	//border: solid 1px #EEE;
  }*/
}
#mailformpro form {
  padding: 0;
}
#mailformpro dl {
  overflow: visible;
  margin: 0;
  padding: 0;
}
#mailformpro dt.form-title {
  line-height: 1.6;
  margin: 0;
  width: 30%;
  padding-top: 5px;
  display: block;
  float: left;
}
#mailformpro dt.form-title .must {
  font-size: 14px;
  font-size: 0.875rem;
  display: inline-block;
  background-color: #FF4D4D;
  padding: 3px 30px;
  color: #FFF;
  margin: 0 10px 0 0;
  border-radius: 4px;
  float: left;
}
#mailformpro dt.form-title .optional {
  font-size: 14px;
  font-size: 0.875rem;
  display: inline-block;
  background-color: #a7a7a7;
  padding: 3px 30px;
  color: #FFF;
  margin: 0 10px 0 0;
  border-radius: 4px;
  float: left;
}
#mailformpro dd {
  line-height: 1.6;
  margin: 0 0 30px 0;
  padding: 0;
  width: 70%;
  float: left;
}
#mailformpro ol, #mailformpro ul {
  display: inline-block;
}
#mailformpro ol li, #mailformpro ul li {
  margin: 0 0 20px;
  padding: 0;
  list-style: none;
}
#mailformpro ol li:last-child, #mailformpro ul li:last-child {
  margin: 0;
}
#mailformpro input {
  font-size: 14px;
  font-size: 0.875rem;
  margin: 0;
  padding: 10px 15px;
  margin-right: 5px;
  width: 60%;
  border: solid 1px #9e9e9e;
  -webkit-appearance: none;
  box-shadow: 0;
}
#mailformpro textarea {
  margin: 0;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  padding: 10px 15px;
  width: 85%;
  border: solid 1px #9e9e9e;
  vertical-align: middle;
}
#mailformpro .select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  box-sizing: content-box;
  text-indent: 0.01px;
  text-overflow: '';
  vertical-align: middle;
  border: solid 1px #9e9e9e;
  position: relative;
  zoom: 1;
  -webkit-border-radius: 0px;
  -moz-border-radius: 0px;
  -ms-border-radius: 0px;
  -o-border-radius: 0px;
  border-radius: 0px;
  font-size: 14px;
  font-size: 0.875rem;
  padding: 10px 30px 10px 10px;
  width: auto;
  display: inline-block;
  background: #fff url(../img/common/form_arrow.png) no-repeat 95% 50%;
  background-size: 12px;
}
#mailformpro select::-ms-expand {
  display: none;
}
#mailformpro #mfp_hidden {
  overflow: hidden;
  width: 1px;
  height: 1px;
  padding: 0px;
  margin: 0px;
}
#mailformpro #mfp_hidden input {
  margin: 10px;
}
#mailformpro .mfp_element_all {
  /*max-width: 90%;*/
}
#mailformpro .mfp_element_submit, #mailformpro .mfp_element_reset, #mailformpro .mfp_element_button {
  /*
  padding: 5px 10px;
  font-size: 24px;
  */
  cursor: pointer;
  outline: none;
}
#mailformpro .mfp_element_reset {
  color: #333;
}
#mailformpro .mfp_err {
  clear: both;
  display: none;
  text-align: left;
  margin: 5px 0px 0px 0px;
  padding: 3px 0px 5px 0;
  color: #ff3803;
  font-size: 14px;
  line-height: normal;
}
#mailformpro .mfp_err:before {
  content: "\f071";
  font-family: FontAwesome;
  margin-right: 5px;
  color: #ff3803;
}
#mailformpro .problem {
  background-color: #fcc;
}
#mailformpro .problem .select {
  background-color: #fcc;
}
#mailformpro .mfp_ok {
  font-size: 20px;
  font-size: 1.25rem;
  display: inline-block;
  padding: 0 4px;
  color: #ff7252;
  display: none;
}
@media screen and (max-width: 320px) {
  #mailformpro .mfp_ok {
    font-size: 18.76px;
    font-size: 1.1725rem;
    font-size: 17.5px;
    font-size: 1.09375rem;
  }
}
#mailformpro .mfp_buttons {
  margin-left: 30%;
  text-align: left;
}
#mailformpro .mfp_buttons button {
  letter-spacing: 0.05em;
  width: 300px;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: bold;
  border-style: none;
  padding: 20px 20px;
  cursor: pointer;
  color: #fff;
  background-color: #CB9D75;
}
@media screen and (max-width: 320px) {
  #mailformpro .mfp_buttons button {
    font-size: 16.884px;
    font-size: 1.05525rem;
    font-size: 15.75px;
    font-size: 0.98438rem;
  }
}
#mailformpro .mfp_buttons button:hover {
  background-color: #AB7D55;
}
@media screen and (max-width: 767px) {
  #mailformpro {
    margin: 40px auto 80px;
  }
  #mailformpro input {
    width: 50%;
  }
  #mailformpro textarea {
    width: 60%;
  }
}
@media screen and (max-width: 600px) {
  #mailformpro dt {
    width: 100%;
    float: none;
    padding: 0 0 5px 0;
  }
  #mailformpro dt:after {
    content: ".";
    display: block;
    clear: both;
    height: 0;
    visibility: hidden;
  }
  #mailformpro dt.form-title {
    width: 100%;
  }
  #mailformpro dd {
    width: 100%;
    float: none;
  }
  #mailformpro input {
    width: 50%;
  }
  #mailformpro textarea {
    width: 80%;
  }
  #mailformpro .mfp_buttons {
    margin-left: 0;
    text-align: center;
  }
}
@media screen and (max-width: 414px) {
  #mailformpro dt {
    width: 100%;
    float: none;
    padding: 0 0 5px 0;
    font-weight: bold;
  }
  #mailformpro dt:after {
    content: ".";
    display: block;
    clear: both;
    height: 0;
    visibility: hidden;
  }
  #mailformpro dt.form-title {
    width: 100%;
  }
  #mailformpro dt.form-title .must {
    padding: 3px 10px;
  }
  #mailformpro dt.form-title .optional {
    padding: 3px 10px;
  }
  #mailformpro dd {
    width: 100%;
    float: none;
  }
  #mailformpro textarea {
    width: 70%;
  }
}

/* -------------------------------------
   mailformpro confirm
------------------------------------- */
div#mfp_overlay {
  position: absolute;
  display: none;
  z-index: 10001;
}

div#mfp_loading_screen {
  z-index: 20000;
  opacity: 0.8;
  display: none;
  background-color: #000;
  position: absolute;
}

div#mfp_loading {
  z-index: 20001;
  position: absolute;
  display: none;
  width: 40px;
  height: 40px;
  background-image: url(images/mfp_loading.gif);
}

div#mfp_overlay_inner {
  background-color: #fff;
  padding: 15px;
  margin: 0px auto 20px;
  border-radius: 5px;
  width: 80%;
  max-width: 800px;
}

div#mfp_overlay_background {
  background-color: #000000;
  position: absolute;
  display: none;
  z-index: 10000;
}

table#mfp_confirm_table {
  border-spacing: 0px;
  border-collapse: collapse;
  width: 100%;
}

table#mfp_confirm_table tr.mfp_colored {
  background-color: #fff;
}

table#mfp_confirm_table tr.mfp_achroma {
  background-color: #f6f7f9;
}

table#mfp_confirm_table tr th, table#mfp_confirm_table tr td {
  text-align: left;
  font-size: 14px;
  font-size: 0.875rem;
  padding: 15px 10px;
}

table#mfp_confirm_table tr th {
  white-space: nowrap;
  width: 20%;
}
@media screen and (max-width: 320px) {
  table#mfp_confirm_table tr th {
    font-size: 12px;
    font-size: 0.75rem;
  }
}

table#mfp_confirm_table tr td {
  line-height: 1.5em;
  word-break: break-all;
}

div#mfp_overlay_inner h4 {
  color: #030303;
  margin: 30px 0;
  font-weight: bold;
  text-align: center;
  padding-bottom: 20px;
}

div.mfp_buttons {
  clear: both;
  padding: 20px 0px;
  text-align: center;
}

div.mfp_buttons button#mfp_button_send,
div.mfp_buttons button#mfp_button_cancel {
  width: 30%;
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  border-style: none;
  padding: 20px 20px;
  margin: 30px 10px;
  cursor: pointer;
  color: #fff;
  background-color: #CB9D75;
}
@media screen and (max-width: 320px) {
  div.mfp_buttons button#mfp_button_send,
  div.mfp_buttons button#mfp_button_cancel {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
div.mfp_buttons button#mfp_button_send:hover,
div.mfp_buttons button#mfp_button_cancel:hover {
  background-color: #AB7D55;
}
@media screen and (max-width: 767px) {
  div.mfp_buttons button#mfp_button_send,
  div.mfp_buttons button#mfp_button_cancel {
    margin: 30px 0;
    width: 45%;
  }
}
@media screen and (max-width: 414px) {
  div.mfp_buttons button#mfp_button_send,
  div.mfp_buttons button#mfp_button_cancel {
    width: 45%;
    font-size: 14px;
    font-size: 0.875rem;
    padding: 10px 5px;
  }
}

/*フラット確認画面の場合*/
/*
div#mfp_phase_confirm {
	clear: both;
}
div#mfp_phase_confirm h4 {
	font-size: 36px;
	padding: 10px 0px 0px 0px;
	text-align: center;
}*/
/* -------------------------------------
   mailformpro thanks page
------------------------------------- */
#thanks {
  font-size: 16px;
  font-size: 1rem;
  	/*
  	.home-btn {
  		a {
  			&:hover {
  
  			}
  		}
  	}*/
}
@media screen and (max-width: 320px) {
  #thanks {
    font-size: 15.008px;
    font-size: 0.938rem;
  }
}
#thanks .btn-menu-toggle {
  display: none;
}
#thanks #container {
  position: relative;
  height: auto;
}
#thanks .mfp_thanks {
  margin: 80px auto 80px;
  width: 80%;
  max-width: 600px;
  line-height: 1.6;
  /*
  ul.mfp_caution {
  	margin: 0px;
  	padding: 0px;
  }
  ul.mfp_caution li {
  	display: block;
  	color: #C00;
  	margin: 0px;
  	padding: 5px 0px;
  }*/
}
#thanks .mfp_thanks #mfp_thanks {
  font-size: 22px;
  font-size: 1.375rem;
  color: #030303;
  margin: 0 0 30px;
  text-align: center;
}
@media screen and (max-width: 320px) {
  #thanks .mfp_thanks #mfp_thanks {
    font-size: 20.636px;
    font-size: 1.28975rem;
    font-size: 19.25px;
    font-size: 1.20313rem;
  }
}
#thanks .mfp_thanks #mfp_thanks strong {
  font-size: 24px;
  font-size: 1.5rem;
}
@media screen and (max-width: 320px) {
  #thanks .mfp_thanks #mfp_thanks strong {
    font-size: 22.512px;
    font-size: 1.407rem;
    font-size: 21px;
    font-size: 1.3125rem;
  }
}
#thanks .mfp_thanks #mfp_thanks br {
  display: none;
}
#thanks .mfp_thanks p {
  margin: 0 0 15px;
  text-align: left;
  background-color: #fff;
}
#thanks .arrow-link {
  text-align: center;
  margin: 40px auto;
}
@media screen and (max-width: 414px) {
  #thanks .mfp_thanks #mfp_thanks {
    font-weight: bold;
  }
  #thanks .mfp_thanks #mfp_thanks br {
    display: inline;
  }
}

/*# sourceMappingURL=styles.css.map */
