@charset "UTF-8";
/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー */
/* テスト用背景色 */
/* ------------------------
 default
------------------------- */
* {
  margin: 0;
  padding: 0;
  font-family: 'Shin Go Medium','メイリオ','Meiryo','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック'; }

* {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

/* webfont */
.wf-shingo-m {
  font-family: 'Shin Go Medium'; }

body {
  font-size: 16px;
  color: #000;
  line-height: 1.5;
  text-align: center; }

/* link */
a {
  text-decoration: none;
  color: #000; }

a:link {
  text-decoration: none; }

a:visited {
  text-decoration: none; }

a:hover,
a:active,
a:focus {
  text-decoration: underline; }

a img {
  border: none; }

a.hv:hover,
a:hover img {
  /* マウスオーバーで背景を透過 */
  opacity: 0.7;
  filter: alpha(opacity=70);
  -moz-opacity: 0.7;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=70)"; }

/* PCでは電話発信しない */
@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none; } }
img {
  vertical-align: bottom; }

li {
  list-style-type: none; }

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

.inner h1 {
  font-size: 2.5rem;
  font-weight: bolder; }
.inner h2 {
  font-size: 1.8rem;
  font-weight: bolder; }
.inner h3 {
  font-size: 1.5rem;
  font-weight: bolder; }
.inner .txt {
  font-size: 0.9rem; }
.inner .txt.notes {
  font-size: 0.8rem; }
.inner p {
  font-size: 80%; }
@media only screen and (max-width: 1140px) {
  .inner h1 {
    font-size: 2rem; }
  .inner h2 {
    font-size: 1.5rem; }
  .inner h3 {
    font-size: 1.3rem; } }
@media only screen and (max-width: 1140px) and (max-width: 767px) {
  .inner h1 {
    font-size: 1.5rem; }
  .inner h2 {
    font-size: 1.3rem; }
  .inner h3 {
    font-size: 0.9rem; } }

@media only screen and (max-width: 1140px) and (max-width: 767px) and (max-width: 390px) {
  .inner h1 {
    font-size: 1.3rem; }
  .inner h2 {
    font-size: 1.2rem; }
  .inner h3 {
    font-size: 0.9rem; }
  .inner .txt {
    font-size: 0.9rem; } }

.ruby {
  font-size: 50%; }

/* ------------------------
 view_timer
------------------------- */
.page-wrap.pre {
  text-align: center; }
  .page-wrap.pre p {
    width: 50vw;
    padding: 5vw 0;
    margin: 0 auto;
    text-align: center;
    line-height: 1.8; }
    .page-wrap.pre p span {
      display: inline-block; }
    .page-wrap.pre p span:first-of-type {
      display: block; }
  @media only screen and (max-width: 1140px) {
    .page-wrap.pre p {
      width: 100%;
      padding: 8vw; } }
@media only screen and (max-width: 1140px) and (max-width: 1024px) {
  .page-wrap.pre p {
    padding: 8vw; } }

@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .page-wrap.pre p {
    padding: 2em; } }

@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 390px) {
  .page-wrap.pre p {
    padding: 10vw; }
    .page-wrap.pre p span {
      font-size: 4vw; } }

/* ------------------------
 販社リンク(ヘッダー・フッター)
------------------------- */
.extlink {
  display: block;
  font-size: 1.2rem; }
  .extlink br {
    display: none; }
  @media only screen and (max-width: 1140px) {
    .extlink {
      font-size: 1.1rem; } }
  @media only screen and (max-width: 1140px) and (max-width: 390px) {
    .extlink {
      font-size: 0.8rem; }
      .extlink br {
        display: block; } }
  @media only screen and (max-width: 1140px) and (max-width: 767px) {
    .extlink {
      width: 48%;
      margin-bottom: 5px;
      font-size: 0.9rem; } }

/* ------------------------
 販社リンク(店舗検索)
------------------------- */
.search {
  width: 100% !important;
  padding: 1em;
  margin: 1em 0 2em;
  z-index: 9998;
  text-align: center; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .search {
    padding: 0.5em 0;
    margin: 0.5rem 0 1rem; } }

.search a {
  display: inline-block;
  font-weight: bold;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  -ms-border-radius: 5px;
  border-radius: 5px;
  text-decoration: none; }

.search .notes {
  padding-left: 1em;
  font-weight: bold;
  font-size: 110%;
  text-indent: -1em; }
  .search .notes:before {
    content: "* ";
    font-weight: bold; }
  .search .notes:last-of-type {
    margin-bottom: 0.5em; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .search .notes {
    text-align: left;
    font-size: 90%; } }

.search .search-ttl {
  display: inline-block !important;
  padding: 0.5em 3em;
  font-size: 160%;
  font-weight: bold;
  transition-property: all;
  transition-duration: 0.3s;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .search .search-ttl {
    display: block;
    width: 100%;
    padding: 0.5em 1em;
    font-size: 110%; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 390px) {
    .search .search-ttl {
      font-size: 100%; } }

.search .search-ttl {
  text-align: center;
  cursor: pointer;
  /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ffffff+0,1e60ba+33,1e60ba+100,207cca+100 */
  	/*
      &:before{
  		content: "\f3cd";
  		font-family: "Font Awesome 5 Free";
  		font-weight: 900;
  		margin-right: 0.5em;
  		display: inline-block;
  		-moz-transform: rotate(-25deg);
  		-webkit-transform: rotate(-25deg);
  		-o-transform: rotate(-25deg);
  		-ms-transform: rotate(-25deg);
  	}
      */ }
  .search .search-ttl:after {
    content: "\f107";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    margin-left: 0.5em; }

.search .search-ttl.open {
  border-bottom: 0; }
  .search .search-ttl.open:after {
    content: "\f106";
    font-family: "Font Awesome 5 Free";
    font-weight: 900; }

.search .search-desc {
  display: none;
  width: 100%;
  text-align: left;
  clear: both;
  margin-top: 1em; }
  .search .search-desc p {
    font-size: 150%;
    margin-bottom: 0.5em;
    font-weight: bold; }
  .search .search-desc a {
    font-size: 150%;
    padding: 0.2em 1em;
    margin-bottom: 5px; }
  @media only screen and (max-width: 767px) {
    .search .search-desc p {
      font-size: 100%; }
    .search .search-desc a {
      font-size: 100%; } }

/* ------------------------
 ptop follow
------------------------- */
.ptop {
  position: fixed;
  right: 0.5rem;
  bottom: 0.5rem;
  z-index: 9999;
  display: none; }
  .ptop a {
    display: block;
    color: #ccc;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0 0.8rem;
    margin: 0;
    text-decoration: none;
    font-weight: bold;
    font-size: 4rem;
    z-index: 9999; }
  .ptop a:hover {
    color: #000; }
  @media only screen and (max-width: 1140px) {
    .ptop {
      right: 0.7rem;
      bottom: 3rem; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    .ptop a {
      font-size: 2.5rem; } }

@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  .ptop {
    padding: 10px;
    right: 5px;
    bottom: 3.5rem; }
    .ptop a {
      color: #666; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 390px) {
    .ptop {
      bottom: 3rem;
      padding: 5px;
      right: 5px; } }

/* ------------------------
 responsive
------------------------- */
.md {
  display: block !important; }
  @media only screen and (max-width: 767px) {
    .md {
      display: none !important; } }

.sp {
  display: none !important; }
  @media only screen and (max-width: 767px) {
    .sp {
      display: block !important; } }

/* ------------------------
 link
------------------------- */
.extlink {
  display: block;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  padding: 10px;
  margin: 3px;
  background-color: #fff;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  -ms-border-radius: 5px;
  border-radius: 5px;
  border: 1px solid #ccc;
  text-align: center;
  font-weight: bold;
  color: #000; }
  .extlink:hover {
    text-decoration: none;
    background-color: #C3002F;
    color: #fff; }
  @media only screen and (max-width: 1140px) {
    .extlink {
      padding: 0.8771929825vw;
      -js-display: flex;
      display: -webkit-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      -webkit-align-items: center;
      -ms-align-items: center;
      align-items: center;
      -webkit-box-pack: center;
      -moz-box-pack: center;
      -ms-flex-pack: center;
      -webkit-justify-content: center;
      -ms-justify-content: center;
      justify-content: center; } }

/* ------------------------
 view_timer
------------------------- */
.page-wrap#index0 .txt {
  padding: 5em;
  text-align: center;
  font-size: 150%; }

.view_timer {
  display: none; }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー */
/* テスト用背景色 */
/*-----------------------
 default structure
------------------------*/
.wrap-content,
footer {
  width: 100%;
  text-align: center; }

.content-body,
.footer-body {
  width: 1140px;
  margin: 0 auto; }
  @media only screen and (max-width: 1140px) {
    .content-body,
    .footer-body {
      width: 100%; } }

@media only screen and (max-width: 1140px) {
  .content-body,
  .footer-body {
    padding: 0 15px; } }
  @media only screen and (max-width: 1140px) and (max-width: 767px) {
    .content-body,
    .footer-body {
      padding: 0 10px; } }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー */
/* テスト用背景色 */
/* ------------------------
 nav
------------------------- */
#nav-top {
  padding: 0; }

#nav-top .inner {
  padding: 15px 0; }
  @media only screen and (max-width: 1140px) {
    #nav-top .inner {
      padding: 1.3157894737vw 0; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    #nav-top .inner {
      padding: 1.46484375vw 0; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    #nav-top .inner {
      padding: 0; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 390px) {
    #nav-top .inner {
      padding: 0; } }

#nav-top nav {
  width: 1140px;
  text-align: center; }
  @media only screen and (max-width: 1140px) {
    #nav-top nav {
      width: 100%;
      padding: 0; } }

nav .list-root {
  width: 100%;
  padding: 0;
  margin: 0 auto;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 0; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  nav .list-root {
    width: 100%; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 390px) {
    nav .list-root {
      padding: 0; } }

nav .list-item {
  width: 14%;
  margin: 1px;
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  transition-property: all;
  transition-duration: .5s; }
  @media only screen and (max-width: 1140px) {
    nav .list-item {
      width: 14%; } }
  @media only screen and (max-width: 1140px) and (max-width: 1024px) {
    nav .list-item {
      width: 14%;
      min-height: 4em; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    nav .list-item {
      width: 13%;
      padding: 0; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 390px) {
    nav .list-item {
      width: 13%;
      padding: auto; } }

nav .list-item a {
  display: block;
  width: 100%;
  line-height: 1.2;
  min-height: 3.5em;
  padding: 0.5em;
  background-color: #1D2087;
  color: #fff;
  font-weight: bold;
  font-size: 80%;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  -ms-border-radius: 3px;
  border-radius: 3px;
  -moz-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.4);
  -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.4);
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.4);
  filter: progid:DXImageTransform.Microsoft.Shadow(color="#d9d9d9", Direction=145, Strength=5);
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }
  nav .list-item a br {
    display: none; }
  nav .list-item a:hover {
    background-color: #40210F;
    color: #FDDF4D;
    text-decoration: none; }
  nav .list-item a span {
    display: inline-block; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) {
  nav .list-item a {
    min-height: 4em; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
    nav .list-item a {
      padding: 2px;
      line-height: 1.2;
      font-size: 60%; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 390px) {
    nav .list-item a {
      min-height: 6em;
      padding: 0;
      font-size: 50%;
      font-weight: normal;
      line-height: 1.1; }
      nav .list-item a br {
        display: block; } }

nav#nav-bottom {
  width: 1140px;
  margin: 0 auto !important;
  text-align: center;
  display: none;
  position: fixed !important;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  background-color: transparent;
  z-index: 9999; }
  @media only screen and (max-width: 1140px) {
    nav#nav-bottom {
      width: 100%;
      padding: 0; } }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  nav#nav-bottom {
    padding: 0; } }

nav#nav-bottom a {
  background-color: #1D2087;
  color: #fff;
  transition-property: all;
  transition-duration: .3s; }
  nav#nav-bottom a br {
    display: none; }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  nav#nav-bottom a {
    line-height: 1.3; } }

nav#nav-bottom a:hover {
  background-color: #000;
  color: #FDDF4D; }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー */
/* テスト用背景色 */
/* ------------------------
 content
------------------------- */
/* content common */
main .content {
  width: 100%;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  text-align: center; }

main .inner.content-body {
  padding: 0 0 40px;
  margin: 0 auto;
  text-align: left; }
  @media only screen and (max-width: 1140px) {
    main .inner.content-body {
      padding: 0 15px; } }
@media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) {
  main .inner.content-body {
    padding: 0 15px; } }

  @media only screen and (max-width: 1140px) and (max-width: 1024px) and (max-width: 767px) and (max-width: 390px) {
    main .inner.content-body {
      padding: 0 10px; } }

/* スライドするButton Hover Effects 左から */
/* スライドするButton Hover Effects 左下から */
/* 画像を丸くトリミング */
/* 縦横中央・GRID */
/* テスト用ボーダー */
/* テスト用背景色 */
/* ------------------------
 footer
------------------------- */
footer {
  margin-bottom: 3em; }

footer .inner {
  padding: 30px 0;
  -js-display: flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }
  footer .inner .copyright {
    width: 100%;
    padding: 10px 0;
    text-align: center;
    color: #000 !important; }
  @media only screen and (max-width: 1140px) {
    footer .inner {
      width: 100%;
      padding: 2.6315789474vw 0; } }
  @media only screen and (max-width: 1140px) and (max-width: 767px) {
    footer .inner .copyright {
      padding: 5px 10px;
      font-size: 70%; } }
