@charset "UTF-8";
/* 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;
  vertical-align: baseline;
}

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;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

/* General */
.cf {
  *zoom: 1;
}
.cf:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
}

form ::-webkit-input-placeholder {
  color: #C6C6C6;
}
form :-moz-placeholder {
  opacity: 1;
  color: #C6C6C6;
}
form ::-moz-placeholder {
  opacity: 1;
  color: #C6C6C6;
}
form :-ms-input-placeholder {
  color: #C6C6C6;
}

::-moz-selection {
  color: #FFF;
  background: rgba(31, 127, 194, 0.7);
}

::selection {
  color: #FFF;
  background: rgba(31, 127, 194, 0.7);
}

/* Base */
/* Layout */
body {
  position: relative;
  height: 100%;
  background: url("../img/common/main_bg.jpg") repeat top center, #f4f3ed;
  font-family: 'Noto Serif JP', serif;
  color: #221815;
}

img {
  backface-visibility: hidden;
}

/*==============================
共通要素
==============================*/
.l-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  background: url("../img/common/main_bg_river.png") top center repeat, url("../img/common/main_bg_wave1.png") center top no-repeat;
  overflow: hidden;
}
.l-bg .l-bg-wave {
  position: absolute;
  top: 831px;
  left: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  background: url("../img/common/main_bg_wave2.png") center top repeat-y, url("../img/common/main_bg_wave3.png") center top repeat-y;
}
.l-bg .l-bg-cloud {
  position: relative;
  width: 100%;
  height: 100%;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .l-bg-cloud-box {
  position: absolute;
  left: 0;
  width: 100%;
  height: 100%;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .l-bg-cloud-box.box1 {
  top: 112px;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .l-bg-cloud-box.box2 {
  top: 914px;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .bg-cloud {
  position: absolute;
  left: calc(50% + 0px);
  width: 396px;
  height: 54px;
  background: #fff;
  border-radius: 50px;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .bg-cloud.c1 {
  top: 0;
  transform: translate3d(-1125px, 0, 0);
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .bg-cloud.c2 {
  top: 54px;
  transform: translate3d(-1235px, 0, 0);
  animation-delay: 0.9s;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .bg-cloud.c3 {
  top: 185px;
  transform: translate3d(-1064px, 0, 0);
  animation-delay: 0.6s;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .bg-cloud.c4 {
  top: 0;
  transform: translate3d(894px, 0, 0);
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .bg-cloud.c5 {
  top: 54px;
  transform: translate3d(807px, 0, 0);
  animation-delay: 0.9s;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner .bg-cloud.c6 {
  top: 174px;
  transform: translate3d(951px, 0, 0);
  animation-delay: 0.6s;
}
.l-bg .l-bg-cloud .l-bg-cloud-inner.shadow .bg-cloud {
  box-shadow: 2px 2px 10px 0 rgba(159, 128, 87, 0.7);
}

.cloud-anim {
  animation: yurayura 3s infinite ease-in-out alternate;
}

@media only screen and (min-width: 2001px) {
  .l-bg {
    background: url("../img/common/main_bg_river.png") top center repeat, url("../img/common/main_bg_wave1.png") left top no-repeat;
  }
  .l-bg .l-bg-wave {
    background: url("../img/common/main_bg_wave2.png") right top repeat-y, url("../img/common/main_bg_wave3.png") left top repeat-y;
  }
}
@keyframes yurayura {
  0% {
    left: calc(50% + 0px);
  }
  100% {
    left: calc(50% + -100px);
  }
}
.wrapper {
  display: flex;
  position: relative;
  margin: 0 auto;
  max-width: 1300px;
  width: 90%;
  height: auto;
  z-index: 20;
}

@media only screen and (max-width: 1300px) {
  .wrapper {
    width: 100%;
  }
}
.l-main-contents {
  transition: opacity 0.3s;
}
.l-main-contents.open {
  opacity: 0;
  pointer-events: none;
}

footer {
  position: relative;
  padding: 50px 0;
  margin-top: 150px;
  background: #221815;
  box-shadow: 0 -3px 10px 0 rgba(159, 128, 87, 0.7);
  box-sizing: border-box;
  z-index: 10;
  transition: opacity 1s;
}
footer .l-share-button ul {
  display: flex;
  justify-content: center;
}
footer .l-share-button ul li:nth-of-type(2) {
  margin: 0 10px;
}
footer .l-share-button ul li .share-button-hover {
  background: #bddef3;
}
footer .l-footer-banner {
  display: flex;
  justify-content: center;
  margin: 40px 0 50px 0;
}
footer .l-footer-banner img {
  max-width: 234px;
  width: 100%;
  transition: opacity 0.5s;
}
footer .l-footer-banner img:hover {
  opacity: 0.5;
}
footer .l-footer-banner a:nth-of-type(2) img {
  margin: 0 20px;
}
footer > p {
  font-size: 13px;
  color: #fff;
  text-align: center;
}

@media only screen and (max-width: 768px) {
  footer {
    margin-top: 0;
    box-shadow: none;
  }
  footer .l-footer-banner {
    display: block;
  }
  footer .l-footer-banner img {
    display: block;
    margin-right: auto;
    margin-left: auto;
    max-width: none;
    width: 90%;
  }
  footer .l-footer-banner a:nth-of-type(2) img {
    margin: 25px auto;
  }
  footer > p {
    font-size: 12px;
  }
  footer.open {
    opacity: 0;
    pointer-events: none;
  }
}
header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
header .l-menu-button {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  max-width: 70px;
  width: 100%;
  cursor: pointer;
  z-index: 30;
}
header .l-menu-button img {
  width: 100%;
}
header .l-menu-button .l-menu-button-line {
  position: absolute;
  top: 8px;
  right: 8px;
  transform: rotate(0deg);
  width: 26px;
  height: 21px;
  transition: 0.3s ease;
}
header .l-menu-button .l-menu-button-line .menu-button-line {
  position: absolute;
  top: 0%;
  right: 0%;
  transform: translate3d(0%, 0%, 0);
  width: 100%;
  height: 1px;
  background: #fff;
  transition: 0.3s ease;
}
header .l-menu-button .l-menu-button-line .menu-button-line:nth-of-type(2) {
  top: 50%;
  width: 100%;
  background: none;
}
header .l-menu-button .l-menu-button-line .menu-button-line:nth-of-type(2) .menu-button-line-inner {
  margin-left: auto;
  width: 61.54%;
  height: 100%;
  background: #fff;
}
header .l-menu-button .l-menu-button-line .menu-button-line:nth-of-type(3) {
  top: 100%;
  transform: translate3d(0, -1px, 0);
  width: 23.08%;
}
header .l-menu-button .l-menu-button-line.open {
  top: 3px;
  right: 3px;
  width: 26px;
  height: 26px;
  transform: rotate(45deg);
}
header .l-menu-button .l-menu-button-line.open .menu-button-line {
  position: absolute;
  top: 50%;
  right: 50%;
  transform: translate3d(50%, -50%, 0);
}
header .l-menu-button .l-menu-button-line.open .menu-button-line:nth-of-type(2) {
  transform: translate3d(50%, -50%, 0) rotate(90deg);
}
header .l-menu-button .l-menu-button-line.open .menu-button-line:nth-of-type(2) .menu-button-line-inner {
  width: 100%;
}
header .l-menu-button .l-menu-button-line.open .menu-button-line:nth-of-type(3) {
  opacity: 0;
}

@media only screen and (max-width: 768px) {
  header .l-menu-button {
    display: block;
  }
}
nav {
  max-width: 370px;
  width: 100%;
  transition: 0.3s 0.2s;
}
nav .l-header-logo a img {
  display: block;
  margin: 20px auto 0 auto;
  max-width: 275px;
  width: 100%;
  transition: opacity 0.3s;
}
nav .l-header-logo a img:hover {
  opacity: 0.7;
}
nav .l-onair-info {
  position: relative;
  padding: 9px;
  margin: 18px auto 0 auto;
  max-width: 326px;
  width: 100%;
  height: auto;
  background: #690000;
  border: solid 4px #ad9902;
  box-sizing: border-box;
  color: #fff;
  font-size: 17px;
  font-weight: 900;
  text-align: center;
  text-shadow: 0 0 5px #221815,0 0 5px #221815,0 0 5px #221815;
}
nav .l-onair-info .onair-info-addtext {
  margin-bottom: 3px;
  font-size: 14.5px;
}
nav .l-onair-info .onair-info-addtext .onair-info-space {
  margin-left: -0.5em;
}
nav .l-onair-info .onair-info-addtext br {
  display: none;
}
nav .l-onair-info .onair-info1 {
  font-size: 31px;
}
nav .l-onair-info .onair-info2 {
  font-size: 20px;
}
nav .l-onair-info .l-soul-box {
  display: flex;
  justify-content: space-between;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: calc(100% + 26px);
  height: 100%;
}
nav .l-onair-info .l-soul-box .soul-box {
  position: absolute;
  top: 25%;
  left: 0;
  width: 25px;
  height: 42px;
  animation: circle_anim_outer 5s infinite linear;
  transform-origin: 50% 40%;
}
nav .l-onair-info .l-soul-box .soul-box img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  animation: circle_anim_inner 5s infinite linear reverse;
  transform-origin: 50% 50%;
}
nav .l-onair-info .l-soul-box .soul-box:last-child {
  left: auto;
  right: 0;
  animation: circle_anim_outer 5s 2.5s infinite linear;
}
nav .l-onair-info .l-soul-box .soul-box:last-child img {
  left: auto;
  right: 0;
  animation: circle_anim_inner 5s 2.5s infinite linear reverse;
}
nav .l-grobalnavigetion {
  display: flex;
  justify-content: center;
  margin-top: 47px;
}
nav .l-grobalnavigetion ul li {
  margin-bottom: 25px;
}
nav .l-grobalnavigetion ul li a {
  text-decoration: none;
}
nav .l-grobalnavigetion ul li a .l-grobalnavigetion-jp {
  display: flex;
  align-items: center;
  margin-bottom: 4px;
  font-size: 22px;
  font-weight: 700;
  color: #221815;
}
nav .l-grobalnavigetion ul li a .l-grobalnavigetion-jp p {
  text-shadow: 0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed;
  transition: filter 0.7s 0.5s,transform 0.7s 0.5s ease,opacity 0.3s 0.5s;
  transform-origin: right bottom;
}
nav .l-grobalnavigetion ul li a .l-grobalnavigetion-en {
  display: flex;
  align-items: center;
  font-size: 12px;
  color: #ab9911;
}
nav .l-grobalnavigetion ul li a .l-grobalnavigetion-en .l-nav-line {
  opacity: 0;
}
nav .l-grobalnavigetion ul li a .l-grobalnavigetion-en p {
  text-shadow: 0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed;
  transition: filter 0.7s 0.55s,transform 0.7s 0.55s ease,opacity 0.3s 0.55s;
  transform-origin: left bottom;
}
nav .l-grobalnavigetion ul li a .l-nav-line {
  position: relative;
  margin-right: 10px;
  width: 25px;
  height: 3px;
}
nav .l-grobalnavigetion ul li a .l-nav-line .nav-line {
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background: #690000;
  transition: width 0.3s ease;
}
nav .l-grobalnavigetion ul li a .l-nav-line .nav-line:first-child {
  top: 1px;
}
nav .l-grobalnavigetion ul li a .l-nav-line .nav-line:last-child {
  top: 0;
  width: 0;
  height: 3px;
}
nav .l-grobalnavigetion ul li.active a .l-nav-line .nav-line:last-child {
  width: 100%;
}
nav .l-grobalnavigetion ul li:hover a .l-nav-line .nav-line:last-child {
  width: 100%;
}
nav .l-grobalnavigetion ul li:nth-of-type(2) a .l-grobalnavigetion-jp p {
  transition-delay: 0.6s;
}
nav .l-grobalnavigetion ul li:nth-of-type(2) a .l-grobalnavigetion-en p {
  transition-delay: 0.65s;
}
nav .l-grobalnavigetion ul li:nth-of-type(3) a .l-grobalnavigetion-jp p {
  transition-delay: 0.7s;
}
nav .l-grobalnavigetion ul li:nth-of-type(3) a .l-grobalnavigetion-en p {
  transition-delay: 0.75s;
}
nav .l-grobalnavigetion ul li:nth-of-type(4) a .l-grobalnavigetion-jp p {
  transition-delay: 0.8s;
}
nav .l-grobalnavigetion ul li:nth-of-type(4) a .l-grobalnavigetion-en p {
  transition-delay: 0.85s;
}
nav .l-grobalnavigetion ul li:nth-of-type(5) a .l-grobalnavigetion-jp p {
  transition-delay: 0.9s;
}
nav .l-grobalnavigetion ul li:nth-of-type(5) a .l-grobalnavigetion-en p {
  transition-delay: 0.95s;
}
nav .l-grobalnavigetion ul li:nth-of-type(6) a .l-grobalnavigetion-jp p {
  transition-delay: 1s;
}
nav .l-grobalnavigetion ul li:nth-of-type(6) a .l-grobalnavigetion-en p {
  transition-delay: 1.05s;
}
nav .l-grobalnavigetion ul li:nth-of-type(7) a .l-grobalnavigetion-jp p {
  transition-delay: 1.1s;
}
nav .l-grobalnavigetion ul li:nth-of-type(7) a .l-grobalnavigetion-en p {
  transition-delay: 1.15s;
}
nav .l-grobalnavigetion ul li:nth-of-type(8) a .l-grobalnavigetion-jp p {
  transition-delay: 1.2s;
}
nav .l-grobalnavigetion ul li:nth-of-type(8) a .l-grobalnavigetion-en p {
  transition-delay: 1.25s;
}
nav .l-grobalnavigetion ul li:nth-of-type(9) a .l-grobalnavigetion-jp p {
  transition-delay: 1.3s;
}
nav .l-grobalnavigetion ul li:nth-of-type(9) a .l-grobalnavigetion-en p {
  transition-delay: 1.35s;
}
nav .l-grobalnavigetion ul li:nth-of-type(10) a .l-grobalnavigetion-jp p {
  transition-delay: 1.4s;
}
nav .l-grobalnavigetion ul li:nth-of-type(10) a .l-grobalnavigetion-en p {
  transition-delay: 1.45s;
}
nav .l-grobalnavigetion ul li:nth-of-type(11) a .l-grobalnavigetion-jp p {
  transition-delay: 1.5s;
}
nav .l-grobalnavigetion ul li:nth-of-type(11) a .l-grobalnavigetion-en p {
  transition-delay: 1.55s;
}
nav .l-share-button {
  display: none;
  justify-content: center;
  align-items: center;
}
nav .l-share-button p {
  font-size: 12px;
}
nav .l-share-button .share-button-line {
  margin: 0 10px;
  width: 20px;
  height: 1px;
  background: #221815;
}
nav .l-share-button ul {
  display: flex;
  justify-content: center;
}
nav .l-share-button ul li:nth-of-type(2) {
  margin: 0 10px;
}
nav .l-share-button ul li .share-button-hover {
  background: #bddef3;
}

@media only screen and (max-width: 1300px) {
  nav {
    max-width: 220px;
  }
  nav .l-header-logo a img {
    margin: 14px auto 0 auto;
    max-width: 160px;
  }
  nav .l-onair-info {
    padding: 4px;
    margin: 13px auto 0 auto;
    max-width: 228px;
    width: 90%;
    border: solid 3px #ad9902;
    font-size: 10px;
    text-shadow: 0 0 3.5px #221815,0 0 3.5px #221815,0 0 3.5px #221815;
  }
  nav .l-onair-info .onair-info-addtext br {
    display: block;
  }
  nav .l-onair-info .onair-info1 {
    font-size: 18px;
  }
  nav .l-onair-info .onair-info2 {
    font-size: 12px;
  }
  nav .l-onair-info .l-soul-box {
    width: calc(100% + 18px);
  }
  nav .l-onair-info .l-soul-box .soul-box {
    width: 18px;
    height: 29px;
  }
  nav .l-grobalnavigetion {
    margin-top: 33px;
  }
  nav .l-grobalnavigetion ul li {
    margin-bottom: 17.5px;
  }
  nav .l-grobalnavigetion ul li a .l-grobalnavigetion-jp {
    margin-bottom: 3px;
    font-size: 15px;
  }
  nav .l-grobalnavigetion ul li a .l-grobalnavigetion-en {
    font-size: 10px;
  }
  nav .l-grobalnavigetion ul li a .l-nav-line {
    margin-right: 7px;
    width: 17.5px;
  }
  nav .l-grobalnavigetion ul li a .l-nav-line .nav-line {
    height: 1px;
  }
}
@media only screen and (max-width: 768px) {
  nav {
    position: fixed;
    top: 0;
    left: 0;
    max-width: none;
    width: 100%;
    height: 100%;
    z-index: 100;
    overflow-y: auto;
    opacity: 0;
    pointer-events: none;
  }
  nav .l-header-logo {
    text-align: center;
  }
  nav .l-header-logo a img {
    display: inline;
    margin: 15px auto 0 auto;
    max-width: 161px;
  }
  nav .l-onair-info {
    display: none;
  }
  nav .l-grobalnavigetion {
    margin-top: 25px;
  }
  nav .l-grobalnavigetion ul li a .l-grobalnavigetion-jp {
    margin-bottom: 3px;
    font-size: 22px;
  }
  nav .l-grobalnavigetion ul li a .l-grobalnavigetion-jp p {
    filter: blur(0px);
    transform: translate3d(0px, 0px, 0px);
    opacity: 1;
  }
  nav .l-grobalnavigetion ul li a .l-grobalnavigetion-en {
    font-size: 12px;
  }
  nav .l-grobalnavigetion ul li a .l-grobalnavigetion-en p {
    filter: blur(0px);
    transform: translate3d(0px, 0px, 0px);
    opacity: 1;
  }
  nav .l-grobalnavigetion ul li.close .l-grobalnavigetion-jp p {
    filter: blur(20px);
    transform: translate3d(30px, -20px, 0px);
    opacity: 0;
  }
  nav .l-grobalnavigetion ul li.close .l-grobalnavigetion-en p {
    filter: blur(20px);
    transform: translate3d(-30px, -20px, 0px) scale(0.8, 1) skewY(-5deg);
    opacity: 0;
  }
  nav.open {
    opacity: 1;
    pointer-events: auto;
  }
  nav .l-share-button {
    display: flex;
  }
}
@keyframes circle_anim_outer {
  0% {
    transform: translate3d(0, -10%, 0) rotate(0deg);
  }
  100% {
    transform: translate3d(0, -10%, 0) rotate(360deg);
  }
}
@keyframes circle_anim_inner {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.l-share-button.following {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: fixed;
  top: 50%;
  right: 1.15%;
  transform: translate3d(0, -50%, 0);
  z-index: 20;
}
.l-share-button.following p {
  margin-left: 5px;
  writing-mode: vertical-rl;
  font-size: 13px;
  text-shadow: 0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed;
}
.l-share-button.following .share-button-line {
  margin: 10px 0;
  width: 1px;
  height: 30px;
  background: #221815;
}
.l-share-button ul li {
  position: relative;
  max-width: 50px;
  width: 100%;
}
.l-share-button ul li:nth-of-type(2) {
  margin: 5px 0;
}
.l-share-button ul li .share-button-hover {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 30px;
  height: 30px;
  transform: translate3d(-50%, -50%, 0) rotate(45deg);
  background: #00629e;
  transition: width 0.3s ease,height 0.3s ease;
}
.l-share-button ul li a {
  position: relative;
}
.l-share-button ul li img {
  display: block;
  width: 100%;
}
.l-share-button ul li:hover .share-button-hover {
  width: 40px;
  height: 40px;
}

@media only screen and (max-width: 768px) {
  .l-share-button.following {
    display: none;
  }
  .l-share-button ul li {
    max-width: 45px;
  }
}
.l-top-button {
  position: fixed;
  bottom: 40px;
  right: 1.15%;
  width: 50px;
  z-index: 20;
  transition: opacity 1s;
}
.l-top-button a {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  height: 100%;
  color: #221815;
  text-decoration: none;
}
.l-top-button a .l-top-button-arrow {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.l-top-button a .l-top-button-arrow .top-button-arrow {
  margin: 0 0 -2px 5px;
  transform: rotate(40deg);
  width: 5px;
  height: 1px;
  background: #221815;
}
.l-top-button a .l-top-button-arrow .top-button-arrow-line {
  width: 1px;
  height: 25px;
  background: #221815;
  transition: height 0.3s;
}
.l-top-button a p {
  margin: 10px 0 0 5px;
  writing-mode: vertical-rl;
  font-size: 13px;
  text-shadow: 0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed,0 0 5px #f4f3ed;
}
.l-top-button a > img {
  display: none;
}
.l-top-button:hover a .l-top-button-arrow .top-button-arrow-line {
  height: 40px;
}
.l-top-button.scroll-bottom a .l-top-button-arrow .top-button-arrow {
  background: #fff;
}
.l-top-button.scroll-bottom a .l-top-button-arrow .top-button-arrow-line {
  background: #fff;
}
.l-top-button.scroll-bottom a p {
  color: #fff;
  text-shadow: none;
}

@media only screen and (max-width: 768px) {
  .l-top-button {
    position: relative;
    margin-top: 80px;
    bottom: auto;
    right: auto;
    width: 100%;
    height: 70px;
    background: #690000;
    box-shadow: 0 -3px 10px 0 rgba(159, 128, 87, 0.7);
    z-index: 10;
  }
  .l-top-button a {
    justify-content: center;
    flex-direction: row;
    color: #ab9911;
  }
  .l-top-button a .l-top-button-arrow {
    display: none;
  }
  .l-top-button a p {
    margin: 0 18px;
    writing-mode: horizontal-tb;
    text-shadow: none;
  }
  .l-top-button a > img {
    display: block;
    width: 11px;
  }
  .l-top-button.scroll-bottom a p {
    color: #ab9911;
  }
  .l-top-button.open {
    opacity: 0;
    pointer-events: none;
  }
}
.l-general-box {
  position: relative;
  /*max-width: 200px;*/
}
.l-general-box .l-general-box-frame {
  position: absolute;
  width: 100%;
  height: 100%;
}
.l-general-box .l-general-box-frame .general-box-frame-line {
  position: absolute;
  width: 1px;
  height: 1px;
  background: #221815;
}
.l-general-box .l-general-box-frame .l-general-box-frame-top {
  position: absolute;
  top: -1px;
  left: 0;
  width: 100%;
  height: 1px;
}
.l-general-box .l-general-box-frame .l-general-box-frame-top .general-box-frame-line:first-child {
  left: -15px;
  width: calc(100% + 30px);
  transition: width 1s ease;
}
.l-general-box .l-general-box-frame .l-general-box-frame-top .general-box-frame-line:last-child {
  top: -4px;
  left: -25px;
  width: calc(100% + 20px);
  transition: width 1s 0.2s ease;
}
.l-general-box .l-general-box-frame .l-general-box-frame-top .frame-line-default {
  width: 0 !important;
}
.l-general-box .l-general-box-frame .l-general-box-frame-right {
  position: absolute;
  top: 0;
  right: -1px;
  width: 1px;
  height: 100%;
}
.l-general-box .l-general-box-frame .l-general-box-frame-right .general-box-frame-line:first-child {
  top: -10px;
  height: calc(100% + 20px);
  transition: height 1s 0.4s ease;
}
.l-general-box .l-general-box-frame .l-general-box-frame-right .general-box-frame-line:last-child {
  top: -20px;
  right: -4px;
  height: calc(100% + 10px);
  transition: height 1s 0.6s ease;
}
.l-general-box .l-general-box-frame .l-general-box-frame-right .frame-line-default {
  height: 0 !important;
}
.l-general-box .l-general-box-frame .l-general-box-frame-bottom {
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 1px;
}
.l-general-box .l-general-box-frame .l-general-box-frame-bottom .general-box-frame-line:first-child {
  right: -15px;
  width: calc(100% + 30px);
  transition: width 1s 0.2s ease;
}
.l-general-box .l-general-box-frame .l-general-box-frame-bottom .general-box-frame-line:last-child {
  bottom: -4px;
  right: -25px;
  width: calc(100% + 20px);
  transition: width 1s 0.4s ease;
}
.l-general-box .l-general-box-frame .l-general-box-frame-bottom .frame-line-default {
  width: 0 !important;
}
.l-general-box .l-general-box-frame .l-general-box-frame-left {
  position: absolute;
  top: 0;
  left: -1px;
  width: 1px;
  height: 100%;
}
.l-general-box .l-general-box-frame .l-general-box-frame-left .general-box-frame-line:first-child {
  bottom: -10px;
  height: calc(100% + 20px);
  transition: height 1s 0.6s ease;
}
.l-general-box .l-general-box-frame .l-general-box-frame-left .general-box-frame-line:last-child {
  bottom: -20px;
  left: -4px;
  height: calc(100% + 10px);
  transition: height 1s 0.8s ease;
}
.l-general-box .l-general-box-frame .l-general-box-frame-left .frame-line-default {
  height: 0 !important;
}
.l-general-box .l-general-box-content {
  position: relative;
  padding: 10px;
  background: #fff;
  transition: opacity 1.8s;
}
.l-general-box .l-general-box-content.content-default {
  opacity: 0;
}

.test-button {
  margin-top: 100px;
  margin-left: 100px;
  width: 100px;
  height: 100px;
  background: #000;
  color: #fff;
}

.l-page-maincontents {
  position: relative;
  padding: 0 60px;
  max-width: 930px;
  width: 100%;
  box-sizing: border-box;
  transition: opacity 1s;
}
.l-page-maincontents .l-title {
  position: relative;
  margin: 60px auto 50px auto;
  width: 227px;
  height: 227px;
}
.l-page-maincontents .l-title .title-jp {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  writing-mode: vertical-rl;
  font-size: 22px;
  font-weight: 700;
}
.l-page-maincontents .l-title .title-en {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(calc(-50% + 23px), -50%, 0);
  writing-mode: vertical-rl;
  font-size: 12px;
  color: #ab9911;
}

@media only screen and (max-width: 1300px) {
  .l-page-maincontents {
    padding-right: 80px;
  }
}
@media only screen and (max-width: 768px) {
  .l-page-maincontents {
    margin: 0 auto;
    padding: 0;
    width: 90%;
  }
  .l-page-maincontents .l-title {
    margin: 25px auto;
    width: 155px;
    height: 155px;
  }
  .l-page-maincontents .l-title .title-jp {
    font-size: 15px;
  }
  .l-page-maincontents .l-title .title-en {
    font-size: 10px;
    transform: translate3d(calc(-50% + 18px), -50%, 0);
  }
  .l-page-maincontents.open {
    opacity: 0;
    pointer-events: none;
  }
}
.l-pagination {
  position: relative;
  display: flex;
  justify-content: center;
  margin: 80px auto 0 auto;
}
.l-pagination .pagination-button {
  position: relative;
  width: 50px;
  height: 50px;
}
.l-pagination .pagination-button a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: #221815;
  transition: color 0.5s;
}
.l-pagination .pagination-button a .pagination-bg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0) rotate(45deg);
  width: 35px;
  height: 35px;
  border: solid 1px #221815;
  transform-origin: center;
  box-sizing: border-box;
  transition: background 0.5s;
}
.l-pagination .pagination-button a span {
  position: relative;
  font-size: 15px;
}
.l-pagination .pagination-button.prev a img {
  position: absolute;
  top: 50%;
  left: 4px;
  transform: translate3d(0, -50%, 0);
  width: 10px;
  transition: width 0.5s ease;
}
.l-pagination .pagination-button.prev a:hover img {
  width: 20px;
}
.l-pagination .pagination-button.next a img {
  position: absolute;
  top: 50%;
  right: 4px;
  transform: translate3d(0, -50%, 0) rotate(180deg);
  width: 10px;
  transition: width 0.5s ease;
}
.l-pagination .pagination-button.next a:hover img {
  width: 20px;
}
.l-pagination .pagination-button.num a:hover {
  color: #fff;
}
.l-pagination .pagination-button.num a:hover .pagination-bg {
  background: #221815;
}
.l-pagination .pagination-button.active a {
  color: #fff;
  pointer-events: none;
}
.l-pagination .pagination-button.active a .pagination-bg {
  border: solid 3px #221815;
  background: #690000;
}
.l-pagination .pagination-button.active a .pagination-bg:after {
  content: '';
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: 100%;
  height: 100%;
  border: solid 3px #ad9902;
  box-sizing: border-box;
}
.l-pagination .pagination-button.off {
  opacity: 0.3;
  pointer-events: none;
}
.l-pagination ul {
  display: flex;
  justify-content: center;
}
.l-pagination .pagination-sp {
  display: none;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 100px;
  height: 100px;
  text-decoration: none;
  color: #221815;
  transition: color 0.5s;
}
.l-pagination .pagination-sp .pagination-bg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0) rotate(45deg);
  width: 70px;
  height: 70px;
  border: solid 1px #221815;
  transform-origin: center;
  box-sizing: border-box;
  transition: background 0.5s;
}

@media only screen and (max-width: 768px) {
  .l-pagination {
    align-items: center;
  }
  .l-pagination .pagination-button {
    width: 45px;
    height: 45px;
  }
  .l-pagination .pagination-button a .pagination-bg {
    width: 32px;
    height: 32px;
  }
  .l-pagination .pagination-button a span {
    font-size: 13px;
  }
  .l-pagination ul {
    display: none;
  }
  .l-pagination .pagination-sp {
    display: flex;
  }
}
.l-loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/common/main_bg.jpg") repeat top center, #f4f3ed;
  z-index: 1000;
  opacity: 1;
  transition: opacity 0.5s 1.5s;
}
.l-loading .l-load-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: 227px;
  height: 227px;
}
.l-loading .l-load-logo .l-load-bg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0) rotate(-45deg);
  transform-origin: 50% 50%;
  width: 161px;
  height: 161px;
}
.l-loading .l-load-logo .l-load-bg .bg-frame {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: 0;
  height: 100%;
  border: solid rgba(216, 199, 170, 0.4);
  border-width: 0px;
  box-sizing: border-box;
  transition: width 0.25s ease,border-width 0.25s ease;
}
.l-loading .l-load-logo .l-load-bg .bg-nuri {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: 73.91%;
  height: 0;
  background: rgba(105, 0, 0, 0.1);
  opacity: 1;
  transition: height 0.25s 0.1s ease,opacity 0.05s 0.6s;
}
.l-loading .l-load-logo .l-load-bg-tenshotai {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  transform-origin: 50% 50%;
  width: 161px;
  height: 161px;
}
.l-loading .l-load-logo .l-load-bg-tenshotai .load-bg-tenshotai {
  width: 100%;
  opacity: 0;
  transition: opacity 0.25s 0.6s linear;
}
.l-loading .l-load-logo .l-tenshotai {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: 77.53%;
  height: 77.53%;
  transition: 0.25s 0.6s;
}
.l-loading .l-load-logo .l-tenshotai .tenshotai {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: 120%;
  filter: drop-shadow(0px 0px 5px #fff443);
  opacity: 0;
  transition: opacity 0.25s 0.25s linear, width 0.25s 0.25s ease;
}
.l-loading .l-load-logo .l-load-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: 22px;
  height: 0;
  transition: height 0.25s 0.75s ease;
}
.l-loading .l-load-logo .l-load-text .l-load-text-inner {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate3d(0, -50%, 0);
  width: 0;
  height: 100%;
  overflow: hidden;
  border-right: solid 1px #221815;
  transition: width 0.35s 1s ease,border-right 0.5s 1.25s;
}
.l-loading .l-load-logo .l-load-text .l-load-text-inner .load-text {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate3d(0, -50%, 0);
  width: 22px;
  font-size: 22px;
  writing-mode: vertical-rl;
  white-space: nowrap;
}
.l-loading .l-load-logo .l-load-text .l-load-text-inner .load-text-en {
  font-size: 12px;
  color: #ab9911;
  writing-mode: vertical-rl;
}
.l-loading .l-load-logo .l-load-text.en {
  transform: translate3d(10px, -50%, 0);
  transition: height 0.25s 0.85s ease;
}
.l-loading .l-load-logo .l-load-text.en .l-load-text-inner {
  border-right: solid 1px #ab9911;
}
.l-loading .l-load-logo .l-load-text.en .l-load-text-inner .load-text {
  font-size: 12px;
  color: #ab9911;
}
.l-loading .load-overlay {
  position: relative;
  width: 100%;
  height: 100%;
  background: #fff;
  opacity: 0;
  transition: opacity 0.25s 1.35s;
}
.l-loading.anim {
  opacity: 0;
}
.l-loading.anim .l-load-logo .l-load-bg .bg-frame {
  width: 100%;
  border-width: 10px;
}
.l-loading.anim .l-load-logo .l-load-bg .bg-nuri {
  height: 73.91%;
  opacity: 0;
}
.l-loading.anim .l-load-logo .l-load-bg-tenshotai .load-bg-tenshotai {
  opacity: 1;
}
.l-loading.anim .l-load-logo .l-tenshotai {
  width: 100%;
  height: 100%;
  opacity: 0;
}
.l-loading.anim .l-load-logo .l-tenshotai .tenshotai {
  width: 100%;
  opacity: 1;
}
.l-loading.anim .l-load-logo .l-load-text .l-load-text-inner {
  width: 22px;
  border-right: solid 1px rgba(34, 24, 21, 0);
}
.l-loading.anim .l-load-logo .l-load-text.en .l-load-text-inner {
  border-right: solid 1px rgba(171, 153, 17, 0);
}
.l-loading.anim .load-overlay {
  opacity: 1;
}
.l-loading.anim-short {
  opacity: 0;
  transition: opacity 0.5s 0.5s;
}
.l-loading.anim-short .l-load-logo .l-load-bg .bg-frame {
  width: 100%;
  border-width: 10px;
  transition: width 0.25s ease,border-width 0.25s ease;
}
.l-loading.anim-short .l-load-logo .l-load-bg-tenshotai .load-bg-tenshotai {
  opacity: 1;
  transition: opacity 0.25s;
}
.l-loading.anim-short .l-load-logo .l-load-text {
  transition: height 0.25s ease;
}
.l-loading.anim-short .l-load-logo .l-load-text .l-load-text-inner {
  width: 22px;
  border-right: solid 1px rgba(34, 24, 21, 0);
  transition: width 0.35s ease,border-right 0.5s;
}
.l-loading.anim-short .l-load-logo .l-load-text.en {
  border-right: solid 1px rgba(171, 153, 17, 0);
  transition: height 0.25s ease;
}

.l-page-maincontents.nf404 {
  position: relative;
  max-width: 100%;
  width: 100%;
  height: 100vh;
}
.l-page-maincontents.nf404 .l-title {
  display: none;
}
.l-page-maincontents.nf404 .l-contents {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
}
.l-page-maincontents.nf404 .l-contents .l-interactive {
  position: relative;
  max-width: 278px;
  width: 100%;
}
.l-page-maincontents.nf404 .l-contents .l-interactive > .tenshotai404 {
  display: block;
  width: 100%;
  opacity: 0.2;
  transition: opacity 0.5s;
}
.l-page-maincontents.nf404 .l-contents .l-interactive > .tenshotai404.dragItemHover {
  opacity: 0.5;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-tenshotai404-meter {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.3s 0.3s,opacity 0.3s 0.3s;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-tenshotai404-meter .tenshotai404-meter {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0%;
  overflow: hidden;
  transition: height 0.5s ease;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-tenshotai404-meter .tenshotai404-meter img {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-tenshotai404-meter.clear {
  transform: scale(1.2);
  opacity: 0;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama {
  position: absolute;
  pointer-events: auto;
  cursor: grab;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama:active {
  cursor: grabbing;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama:first-child {
  bottom: 0;
  left: -70px;
  width: 37px;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama:first-child img {
  animation: hitodamayurayura 2s infinite ease-in-out alternate;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama:first-child.purupuru img {
  animation: hitodamayurayura 0.03s infinite ease-in-out alternate;
  opacity: 0.8;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama:last-child {
  top: 0;
  right: -50px;
  width: 22px;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama:last-child img {
  animation: hitodamayurayura 1.5s 0.5s infinite ease-in-out alternate;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama:last-child.purupuru img {
  animation: hitodamayurayura 0.03s infinite ease-in-out alternate;
  opacity: 0.8;
}
.l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama img {
  display: block;
  width: 100%;
  opacity: 0.2;
}
.l-page-maincontents.nf404 .l-contents .main-text {
  margin-top: 64px;
  font-size: 29px;
  font-weight: 700;
}
.l-page-maincontents.nf404 .l-contents .sub-text {
  margin-top: 50px;
  margin-bottom: 90px;
  font-size: 16px;
}

@media only screen and (max-width: 1000px) {
  .l-page-maincontents.nf404 .l-contents {
    width: 90%;
  }
  .l-page-maincontents.nf404 .l-contents img {
    max-width: 278px;
    width: 100%;
  }
  .l-page-maincontents.nf404 .l-contents .main-text {
    margin-top: 30px;
    font-size: 20px;
  }
  .l-page-maincontents.nf404 .l-contents .sub-text {
    margin-top: 25px;
    margin-bottom: 45px;
    font-size: 13px;
  }
}
@media only screen and (max-width: 768px) {
  .l-page-maincontents.nf404 .l-contents .l-interactive {
    width: 60%;
  }
  .l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama:first-child {
    left: -30px;
    width: 30px;
  }
  .l-page-maincontents.nf404 .l-contents .l-interactive .l-hitodama-field .l-hitodama:last-child {
    right: -20px;
    width: 20px;
  }
}
@keyframes hitodamayurayura {
  0% {
    transform: translate3d(0, 0px, 0);
  }
  100% {
    transform: translate3d(0, 10px, 0);
  }
}
