@charset "UTF-8";
/* ===============================================================================
Reset
=============================================================================== */
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section {
  display: block;
  position: relative;
}

ol,ul {
  list-style: none;
}

blockquote,q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}
*,
:before,
:after {
  background-repeat: no-repeat;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}

button {
  border: none;
}

/* ===============================================================================
Body Setting
=============================================================================== */
html {
  font-size: 62.5%;
}
body {
  font-family: 'Roboto', sans-serif;
  font-weight: 700;
  color: #000;
  font-size: 1.5rem;
  line-height: 1.93;
  letter-spacing: 0;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
   -ms-text-size-adjust: 100%;
       text-size-adjust: 100%;
  opacity: 0;
  transition: opacity .3s;
}
body.fadein {
  opacity: 1;
}
.spOnly{
  display: none;
}
.hidden {
  display: none;
}
@media screen and (max-width: 640px) {
  body {
    font-size: 1.2rem;
  }  
  .pcOnly{
    display: none;
  }
  .spOnly{
    display: block;
  }
}

a {
  text-decoration: none;
  color: #000;
  tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
a:hover {
  text-decoration: none;
}
a[target=_blank].open-in-new::after {
    font-family: "Hobonichi-Icons";
    content: "\e914";
    font-weight: normal;
    font-size: 90%;
    position: relative;
}
img {
  vertical-align: top;
  max-width: 100%;
  width: auto;
}
#page{
  overflow: hidden;
  position: relative;
}
@media (min-width: 641px){
  body {
      min-width: 1150px;
  }
  .btn-permeate {
    -webkit-transition: opacity 0.3s;
    -moz-transition: opacity 0.3s;
    -ms-transition: opacity 0.3s;
    -o-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
  .btn-permeate:hover {
    opacity: 0.4;
    filter: alpha(opacity=40);
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
  }  
}
/* ===============================================================================
Header
=============================================================================== */
.lang ul {
  display: flex;
  justify-content: space-evenly;
}
.lang ul {
  text-align: center;
  font-family: "Puhu Picnic", sans-serif;
  /* font-family: A P-OTF PuhuPicnic Min2; */
  font-size: 1.2rem;
  font-feature-settings: "palt";
  border-radius: 4px;
  border: 2px solid #000;
  line-height: 1.8;
  position: absolute;
  top: 8px;
  left: 17.2vw;
  z-index: 2;
}
.lang ul li {
  width: 70px;
  border-radius: 0 0 4px 0;
}
.lang ul li:first-of-type {
  border-right: 2px solid;
  border-radius: 4px 0 0 4px;
}
.lang ul li a {
  background: #FFF;
  display: block;
  box-shadow: -2px -2px 0 rgba(0,0,0,0.4) inset;
  transition: .3s;
}
.lang ul li a:hover {
  transform: translate3d(0, 1px, 0);
  box-shadow: 1px 1px 0 rgba(0,0,0,0.4) inset;
  opacity: 1;
}
.lang ul li:not(a) {
  background: #F3DE30;
  box-shadow: 2px 2px 0 rgba(0,0,0,0.4) inset;
  border-radius: 0 !important;
}
.lang ul li a {
  color: #000;
}
.sns {
  position: absolute;
  z-index: 2;
  top: 8px;
  right: 17.2vw;
}
.sns ul {
  display: flex;
  gap: 8px;
}
.sns p {
  color: #000;
  text-align: center;
  font-family: 'Roboto Condensed', sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 120%;
  letter-spacing: 0;
}
@media screen and (max-width: 640px) {
  .sns p {
    padding-top: 0.4em;
  }
}
/* ----------------------------------------------
 * Generated by Animista on 2023-7-20 10:19:40
 * Licensed under FreeBSD License.
 * See http://animista.net/license for more info. 
 * w: http://animista.net, t: @cssanimista
 * ---------------------------------------------- */
/**
 * ----------------------------------------
 * animation scale-up-top
 * ----------------------------------------
 */
 @-webkit-keyframes scale-up-top {
  0% {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
    -webkit-transform-origin: 50% 0%;
            transform-origin: 50% 0%;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: 50% 0%;
            transform-origin: 50% 0%;
  }
}
@keyframes scale-up-top {
  0% {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
    -webkit-transform-origin: 50% 0%;
            transform-origin: 50% 0%;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: 50% 0%;
            transform-origin: 50% 0%;
  }
}
/**
 * ----------------------------------------
 * animation scale-up-bottom
 * ----------------------------------------
 */
 @-webkit-keyframes scale-up-bottom {
  0% {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
    -webkit-transform-origin: 50% 100%;
            transform-origin: 50% 100%;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: 50% 100%;
            transform-origin: 50% 100%;
  }
}
@keyframes scale-up-bottom {
  0% {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
    -webkit-transform-origin: 50% 100%;
            transform-origin: 50% 100%;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: 50% 100%;
            transform-origin: 50% 100%;
  }
}
/**
 * ----------------------------------------
 * animation scale-up-br
 * ----------------------------------------
 */
 @-webkit-keyframes scale-up-br {
  0% {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
    -webkit-transform-origin: 100% 100%;
            transform-origin: 100% 100%;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: 100% 100%;
            transform-origin: 100% 100%;
  }
}
@keyframes scale-up-br {
  0% {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
    -webkit-transform-origin: 100% 100%;
            transform-origin: 100% 100%;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: 100% 100%;
            transform-origin: 100% 100%;
  }
}
/**
 * ----------------------------------------
 * animation scale-up-bl
 * ----------------------------------------
 */
 @-webkit-keyframes scale-up-bl {
  0% {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
    -webkit-transform-origin: 0% 100%;
            transform-origin: 0% 100%;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: 0% 100%;
            transform-origin: 0% 100%;
  }
}
@keyframes scale-up-bl {
  0% {
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
    -webkit-transform-origin: 0% 100%;
            transform-origin: 0% 100%;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-transform-origin: 0% 100%;
            transform-origin: 0% 100%;
  }
}
/**
 * ----------------------------------------
 * animation slide-bottom
 * ----------------------------------------
 */
 @-webkit-keyframes slide-bottom {
  0% {
    -webkit-transform: translateY(-20vw);
            transform: translateY(-20vw);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes slide-bottom {
  0% {
    -webkit-transform: translateY(-20vw);
            transform: translateY(-20vw);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
/**
 * ----------------------------------------
 * animation slide-right
 * ----------------------------------------
 */
 @-webkit-keyframes slide-right {
  0% {
    -webkit-transform: translateX(-20vw);
            transform: translateX(-20vw);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes slide-right {
  0% {
    -webkit-transform: translateX(-20vw);
            transform: translateX(-20vw);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/**
 * ----------------------------------------
 * animation slide-left
 * ----------------------------------------
 */
 @-webkit-keyframes slide-left {
  0% {
    -webkit-transform: translateX(20vw);
            transform: translateX(20vw);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes slide-left {
  0% {
    -webkit-transform: translateX(20vw);
            transform: translateX(20vw);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/**
 * ----------------------------------------
 * animation swing-top-fwd
 * ----------------------------------------
 */
@-webkit-keyframes swing-top-fwd {
  0% {
    -webkit-transform: rotateX(0);
            transform: rotateX(0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  25% {
    -webkit-transform: rotateX(30deg);
            transform: rotateX(30deg);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  75% {
    -webkit-transform: rotateX(-30deg);
            transform: rotateX(-30deg);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  100% {
    -webkit-transform: rotateX(0);
            transform: rotateX(0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
}
@keyframes swing-top-fwd {
  0% {
    -webkit-transform: rotateX(0);
            transform: rotateX(0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  25% {
    -webkit-transform: rotateX(30deg);
            transform: rotateX(30deg);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  75% {
    -webkit-transform: rotateX(-30deg);
            transform: rotateX(-30deg);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  100% {
    -webkit-transform: rotateX(0);
            transform: rotateX(0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
}
@media screen and (max-width: 640px) {
 @-webkit-keyframes slide-right {
  0% {
    -webkit-transform: translateX(-40vw);
            transform: translateX(-40vw);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  }
  @keyframes slide-right {
    0% {
      -webkit-transform: translateX(-40vw);
              transform: translateX(-40vw);
    }
    100% {
      -webkit-transform: translateX(0);
              transform: translateX(0);
    }
  }
  @-webkit-keyframes slide-left {
    0% {
      -webkit-transform: translateX(40vw);
              transform: translateX(40vw);
    }
    100% {
      -webkit-transform: translateX(0);
              transform: translateX(0);
    }
  }
  @keyframes slide-left {
    0% {
      -webkit-transform: translateX(40vw);
              transform: translateX(40vw);
    }
    100% {
      -webkit-transform: translateX(0);
              transform: translateX(0);
    }
  }  
}
/* ===============================================================================
Main
=============================================================================== */
main {
  width: 100%;
}
main section {
  position: relative;
  text-align: center;
}
main .wrapper {
  max-width: 960px;
  margin: 0 auto;
}
#top {
  width: 100%;
  padding-top: 55.555%;
  background: url(../img/bg_mainimg.jpg) no-repeat;
  background-size: cover;
  background-position: center bottom;
  position: relative;
  z-index: 1;
}
.title_main {
  position: absolute;
  left: 50%;
  top: 2.4vw;
  transform: translateX(-50%);
  width: 47.222vw;
}
#top .credit {
  position: absolute;
  bottom: 0.5vw;
  right: 1.3vw;
  color: rgba(0, 0, 0, 0.75);
  font-size: 1.2rem;
}
main p {
  position: absolute;
  width: 200px;
}
main p.js-scroll {
  opacity: 0;
}
main p.is-animated {
  opacity: 1;
}
main p.illust01.is-animated2 picture img {
  -webkit-animation: swing-top-fwd 1.8s cubic-bezier(0.250, 0.460, 0.450, 0.940) infinite both;
        animation: swing-top-fwd 1.8s cubic-bezier(0.250, 0.460, 0.450, 0.940) infinite both;
}
main p.illust02.is-animated {
  -webkit-animation: slide-right 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
        animation: slide-right 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}
main p.illust03.is-animated {
  -webkit-animation: slide-left 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
        animation: slide-left 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}
main p.illust04.is-animated {
  -webkit-animation: slide-right 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
        animation: slide-right 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}
main p.illust05.is-animated {
  -webkit-animation: slide-left 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
        animation: slide-left 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}
main p.illust07.is-animated {
  -webkit-animation: slide-right 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
        animation: slide-right 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}
.title_section {
  padding-top: 35px;
  max-width: 480px;
  width: 92.3vw;
  margin: 0 auto;
}
.title_section h2 {
  font-family: "Puhu Picnic", sans-serif;
  /* font-family: A P-OTF PuhuPicnic Min2; */
  font-size: 4rem;
  line-height: 40px;
  letter-spacing: 0;
  font-feature-settings: "palt";
  text-align: left;
  padding-bottom: 5px;
}
.title_section > div {
  padding-bottom: 30px;
  font-size: 1.6rem;
  line-height: 150%;
  text-align: left;
}
.calendar {
  padding: 0 0 40px;
}
.calendar .new a::after {
  content: '';
  display: block;
  background: url(../img/icon_new.svg) no-repeat;
  background-size: contain;
  width: 64px;
  height: 32px;
  position: absolute;
  top: 20px;
  left: 10px;
}
.calendar ul {
  display: flex;
  justify-content: center;
  align-items: baseline;
  max-width: 786px;
  margin: 0 auto;
  flex-wrap: wrap;
  gap: 37px 30px;
}
.calendar li {
  width: 237px;
  position: relative;
  border-radius: 8px;
  background: rgba(131, 234, 228, 0.50);
  box-shadow: 4px 4px 0px 0px rgba(0, 0, 0, 0.25);
  padding: 16px 0;
  transition: .3s;
}
.calendar li.off {
  background: rgba(217, 217, 217, 0.50) !important;
  box-shadow: none;
}
#covers .calendar li.off {
  background: rgba(191, 191, 191, 0.50) !important;
}
.calendar li dt {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 150%; /* 21px */
  margin-top: .3em;
  font-feature-settings: 'halt';
}
.calendar li dt h3 {
  text-align: left;
  display: flex;
  justify-content: center;
}
#covers .calendar li dt h3 {
  text-align: center;
}
.calendar li dt.line1 {
  margin-bottom: 40px;
}
.calendar li dd {
  width: 168px;
  margin: 0 auto;
}
.calendar li.off a {
  pointer-events: none;
}
.calendar li.day1 {
  z-index: 1;
}
.comment {
  position: absolute;
  opacity: 0;
}
.comment img {
  max-width: initial;
  height: 64px;
}
/* .comment2 {
  position: absolute;
} */
.comment2 img {
  max-width: initial;
}
.comment.active {
  opacity: 1;
  -webkit-animation: scale-up-bottom 0.4s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
	        animation: scale-up-bottom 0.4s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
}
.comment-t.active {
  -webkit-animation: scale-up-top 0.4s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
	        animation: scale-up-top 0.4s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
}
.js-scroll:not(.is-animated) .comment.active {
  opacity: 0;
}
.js-scroll:not(.is-animated) .comment.active {
  opacity: 0;
}
.comment_top01 {
  bottom: 15.8vw;
  left: 18.4vw;
}
.comment_top02 {
  top: 5.4vw;
  left: auto;
  right: 7.1vw;
}
section::before {
  content: '';
  background-color: rgba(255, 255, 240, 0.50);
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
}
#top::before {
  background-color: initial;
}
.wrapper {
  position: relative;
}
#theme {
  background: url(../img/bg1.jpg);
  background-size: 730px 1060px;
}
#theme .wrapper {
  background: url(../img/bg1.jpg);
  background-size: 730px 1060px;
}
#basic {
  background: url(../img/bg3.jpg);
  background-size: 730px 1060px;
}
#basic .wrapper {
  background: url(../img/bg3.jpg);
  background-size: 730px 1060px;
}
#covers {
  background: url(../img/bg1.jpg);
  background-size: 730px 1060px;
}
#covers .wrapper {
  background: url(../img/bg1.jpg);
  background-size: 730px 1060px;
}
#covers .calendar li {
  height: 283px;
}
#covers .calendar li {
  background: rgba(153, 204, 153, 0.50);
}
#covers  .calendar li dd {
  width: 160px;
}
#covers .calendar li dt {
  transform: rotate(-5deg);
  font-family: "Puhu Picnic", sans-serif;
  /* font-family: A P-OTF PuhuPicnic Min2; */
  font-size: 2rem;
  font-style: normal;
  line-height: 105%;
}
#topics {
  background: url(../img/bg2.jpg);
  background-size: 730px 1060px;
}
#topics .wrapper {
  background: url(../img/bg2.jpg);
  background-size: 730px 1060px;
}
#topics .calendar li {
  background: rgba(211, 217, 184, 0.5);
}
#maindish {
  background: url(../img/bg3.jpg);
  background-size: 730px 1060px;
}
#maindish .wrapper {
  background: url(../img/bg3.jpg);
  background-size: 730px 1060px;
}
#maindish2 {
  background: url(../img/bg1.jpg);
  background-size: 730px 1060px;
}
#maindish2 .wrapper {
  background: url(../img/bg1.jpg);
  background-size: 730px 1060px;
  padding: 40px 0;
}
#link_footer {
  background: url(../img/bg4.jpg);
  background-size: 730px 1060px;
}
#link_footer .wrapper {
  background: url(../img/bg4.jpg);
  background-size: 730px 1060px;
  padding: 70px 0 40px;
}

.maindish .wrapper {
  padding: 96px 0;
}
.maindish .calendar li {
  max-width: 720px;
  width: auto;
  background: none;
  box-shadow: none;
  padding: 0;
}
.maindish .calendar li.day32 a img {
  box-shadow: 4px 4px 0px 0px rgba(0, 0, 0, 0.25);
}
.maindish .calendar li.day32.off a img {
  box-shadow: none;
}
#teatime {
  background: url(../img/bg4.jpg);
  background-size: 730px 1060px;
}
#teatime .wrapper {
  background: url(../img/bg4.jpg);
  background-size: 730px 1060px;
}
#teatime .calendar li {
  background:rgba(216, 217, 206, 0.50);;
}
#page.off main section {
  background: #000 !important;
}
#page.off main section div, #page.off main section h3, #page.off main section ul{
  visibility: hidden;
}
#page.off .illust {
  display: none;
}
#page.illust {
  display: absolute;
}
#page.off .tolineup {
  visibility: hidden;
}
@media screen and (min-width: 641px) {
  main p.illust01 {
    top: 0;
    right: calc(((100% - 960px) / 2) - 77px);
  }
  main p.illust01.is-animated {
    -webkit-animation: slide-bottom 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
	        animation: slide-bottom 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
  }
  main p.illust02 {
    top: 290px;
    left: calc(((100% - 960px) / 2) - 75px);
  }  
  main p.illust03 {
    top: -35px;
    right: calc(((100% - 960px) / 2) - 48px);
  }  
  main p.illust04 {
    top: -70px;
    left: calc(((100% - 960px) / 2) - 50px);
  }
  main p.illust05 {
    top: 0;
    right: calc(((100% - 960px) / 2) - 100px);
  }
  main p.illust06 {
    width: 160px;
    top: -70px;
    left: calc(((100% - 960px) / 2) - 55px);
  }
  main p.illust06.is-animated {
    -webkit-animation: slide-right 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
	        animation: slide-right 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
  }
  main p.illust07 {
    width: 152px;
    top: 7px;
    left: calc(((100% - 960px) / 2) + 60px);
  }
  main p.illust08 {
    width: 160px;
    top: 45px;
    right: calc(((100% - 960px) / 2) + 35px);
  }
  main p.illust09 {
    width: 160px;
    top: 213px;
    left: calc(((100% - 960px) / 2) + 73px);
  }
  main p.illust10 {
    width: 160px;
    bottom: -10px;
    right: calc(((100% - 960px) / 2) + 113px);
  }
  #theme .title_section h2 {
    padding-bottom: 20px;
  }
  .yodogawa {
    max-width: 460px;
    width: 31vw;
    margin: 0 auto;
    position: absolute;
    left: 0;
    right: 0;
    top: 31.2vw;
    color: #000;
    font-size: 1.25vw;
    line-height: 150%;
  }  
  .calendar li:not(.off):hover {
    transform: scale(1.05);
  }
  .tilt01 {
    transform: rotate(1deg);
  }
  .calendar li.tilt01:not(.off):hover {
    transform: scale(1.05) rotate(1deg);
  }  
  .tilt02 {
    transform: rotate(2deg);
  }
  .calendar li.tilt02:not(.off):hover {
    transform: scale(1.05) rotate(2deg);
  }  
  .tilt03 {
    transform: rotate(3deg);
  }
  .calendar li.tilt03:not(.off):hover {
    transform: scale(1.05) rotate(3deg);
  }  
  .tilt04 {
    transform: rotate(-1deg);
  }
  .calendar li.tilt04:not(.off):hover {
    transform: scale(1.05) rotate(-1deg);
  }  
  .tilt05 {
    transform: rotate(-2deg);
  }
  .calendar li.tilt05:not(.off):hover {
    transform: scale(1.05) rotate(-2deg);
  }  
  .tilt06 {
    transform: rotate(-3deg);
  }
  .calendar li.tilt06:not(.off):hover {
    transform: scale(1.05) rotate(-3deg);
  }  
  .calendar li.day1 {
    margin-left: 50px;
  }
  .calendar li.day2 {
    margin-right: 50px;
  }
  .calendar li:hover .comment,
  .illust:hover .comment {
    opacity: 1;
    -webkit-animation: scale-up-bottom 0.4s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
                       animation: scale-up-bottom 0.4s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
  }
  .calendar li:hover .comment-t,
  .illust:hover .comment-t {
    -webkit-animation: scale-up-top 0.4s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
                       animation: scale-up-top 0.4s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
  }
  .illust01 .comment {
    bottom: -80px;
    left: 28px;
  }
  .illust02 .comment {
    top: -85px;
    left: -60px;
  }
  .illust03 .comment {
    top: -50px;
    left: -40px;
  }
  .illust04 .comment {
    top: -60px;
    left: -17px;
  }
  .illust05 .comment {
    bottom: -30px;
    right: 93px;
  }
  .illust06 .comment {
    top: -53px;
    left: 0;
  }
  .illust07 .comment {
    bottom: -35px;
    left: -20px;
  }
  .illust08 .comment {
    top: -40px;
    left: -40px;
  }
  .illust09 .comment {
    bottom: -64px;
    left: 9px;
  }
  .illust10 .comment {
    top: -66px;
    right: 5px;
  }
  .day1 .comment {
    top: 38px;
    left: 9px;
  }
  .day2 .comment {
    bottom: 30px;
    right: -5px;
  }
  .day3 .comment {
    top: 40px;
    left: -10px;
  }
  .day4 .comment {
    top: 15px;
    left: -20px;
  }
  .day4 .comment img {
    height: 92px;
  }
  .day5 .comment {
    bottom: 20px;
    left: 20px;
  }
  .day6 .comment {
    top: 12px;
    left: -40px;
  }
  .day6 .comment img {
    height: 92px;
  }
  .day7 .comment {
    bottom: 28px;
    left: 15px;
  }
  .day22 .comment {
    bottom: 24px;
    right: -10px;
  }
  .day22 .comment img {
    height: 92px;
  }
  .day22 .comment2 {
    margin: -25px 0 -7px 75px;
    transform: rotate(-3deg);
  }
  .day23 .comment {
    top: 38px;
    left: -38px;
  }
  .day23 .comment2 {
    margin: -50px 0 -10px 65px;
    transform: rotate(1deg);
  }
  .day24 .comment {
    bottom: 46px;
    left: 23px;
  }
  .day24 .comment2 {
    margin: -27px 0 -9px 75px;
    transform: rotate(-2deg);
  }
  .day26 .comment {
    bottom: 50px;
    right: 25px;
  }
  .day27 .comment {
    bottom: 22px;
    left: -29px;
  }
  .day28 .comment {
    bottom: 5px;
    left: 55px;
  }
  .day29 .comment {
    top: 55px;
    left: -40px;
  }
  .day30 .comment {
    bottom: 5px;
    left: 36px;
  }
  .day31 .comment {
    bottom: 15px;
    left: 0;
  }
  .day32 .comment {
    bottom: 93px;
    right: 117px;
  }
  .maindish .calendar li img {
    border-radius: 16px;
  }  
}
@media screen and (max-width: 640px) {
  .lang ul {
    top: 1.8vw;
    left: 1.8vw;
  }
  .sns {
    top: 1.8vw;
    right: 1.8vw;
  }
  #top {
    background: url(../img/bg_mainimg_sp.jpg) no-repeat;
    background-size: 100% auto;
    background-position: center top;
    padding-top: 181.7%;
  }  
  .title_main {
    top: 67vw;
    width: 84.735vw;
  }
  #top .credit {
    bottom: .5vw;
    right: 2vw;
  }
  .comment.comment_top01 {
    bottom: 17.8vw;
    left: initial;
    right: 5vw;
  }
  .comment.comment_top02 {
    top: 38vw;
    right: 5vw;
  }
  .yodogawa.spOnly {
    color: rgba(0, 0, 0, 0.80);
    text-align: justify;
    font-size: 1.4rem;
    line-height: 150%;
    display: flex;
    justify-content: center;
    padding: 4.5vw 4vw;
  }  
  .title_section h2 {
    font-size: 7.69vw;
    letter-spacing: -.06em;
  }
  #theme .title_section h2 {
    padding-bottom: 16px;
  }
  .title_section > div {
    max-width: 92.3vw;
    font-size: 3.36vw;
    line-height: 21px; /* 150% */
    padding-bottom: 20px;
    letter-spacing: 1.05px;
  }
  #theme .wrapper {
    padding-bottom: 40px;
  }
  .title_section {
    padding-top: 55px;
  }
  #theme .title_section {
    padding-top: 20px;
  }
  .maindish .wrapper {
    padding: 0 !important;
  }
  .calendar {
    padding: 0 0 84px;
  }
  .calendar ul {
    width: 92.4vw;
    margin: 0 auto;
    gap: 7.69vw 3.84vw;
    justify-content: flex-start;
  }
  .maindish .calendar ul {
    width: 100vw;
  }
  .calendar li {
    width: 44.23vw;
  }
  .calendar li dt {
    font-size: 1.2rem;
    line-height: 18px; /* 150% */
    margin-top: 0.3em;
  }
  .calendar li dd {
    width: 91.3%;
  }
  #covers .calendar {
    padding-bottom: 74px;
  } 
  #covers .calendar li dt {
    font-size: 4.32vw;
    margin-top: 0.6em;
  }
  #covers .calendar li dt img {
    width: 33.349vw;
  }
  #covers .calendar li dd {
    width: 86.95%;
  }
  #covers .calendar li {
    height: auto;
    padding-bottom: 19px;
  }
  #teatime .calendar {
    padding-bottom: 50px;
  }
  main p.illust01 {
    width: 34.615vw;
    position: relative;
    margin-top: -1vw;
    margin-left: auto;
    margin-right: 4vw;
  }
  main p.illust01.is-animated {
    -webkit-animation: slide-left 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
	        animation: slide-left 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
  }
  main p.illust02 {
    width: 19.23vw;
    position: relative;
    margin-top: -13vw;
    margin-left: 8vw;
  }
  main p.illust03 {
    width: 23vw;
    top: -8vw;
    right: 27vw;
  }
  main p.illust04 {
    width: 25vw;
    top: -11vw;
    left: 25vw;
  }
  main p.illust05 {
    width: 24vw;
    top: -11vw;
    right: 6vw;
  }
  main p.illust06 {
    width: 30.769vw;
    top: -31vw;
    left: initial;
    right: 7vw;
  }
  main p.illust06.is-animated {
    -webkit-animation: slide-left 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
          animation: slide-left 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
  }
  main p.illust07 {
    width: 23.076vw;
    top: -8.5vw;
    left: 51.5vw;
  }
  main p.illust08 {
    position: relative;
    width: 23.076vw;
    margin-top: -1vw;
    margin-left: auto;
    margin-right: 5vw;
  }
  main p.illust09 {
    position: relative;
    width: 19.23vw;
    margin-top: -13vw;
    margin-left: 10.5vw;
    margin-bottom: 2vw;
  }
  main p.illust10 {
    width: 23.076vw;
    bottom: 0.2vw;
    right: 3vw;
  }
  .comment img {
    height: 11.5vw;
  }
  .illust01 .comment {
    bottom: -11vw;
    right: -0.5vw;
  }
  .illust02 .comment {
    top: -11vw;
    left: -6vw;
  }
  .illust03 .comment {
    top: -9vw;
    left: 0;
  }
  .illust04 .comment {
    top: -7vw;
    left: -5.5vw;
  }
  .illust05 .comment {
    bottom: -6.5vw;
    right: -4.5vw;
  }
  .illust06 .comment {
    top: -9vw;
    left: 2.5vw;
  }
  .illust07 .comment {
    bottom: -6vw;
    left: -1.5vw;
  }
  .illust08 .comment {
    top: -7.5vw;
    left: -8vw;
  }
  .illust09 .comment {
    bottom: -9vw;
    left: 1vw;
  }
  .illust10 .comment {
    top: -9vw;
    right: 0;
  }
  .day1 .comment {
    top: 17vw;
    left: 5vw;
  }
  .day2 .comment {
    bottom: 6vw;
    right: -2vw;
  }
  .day3 .comment {
    top: 14vw;
    left: -2vw;
  }
  .day4 .comment {
    top: 14vw;
    left: -5vw;
  }
  .day4 .comment img {
    height: 16.5vw;
  }
  .day5 .comment {
    bottom: 8vw;
    right: -5vw;
  }
  .day6 .comment {
    top: 10.5vw;
    left: -6.5vw;
  }
  .day6 .comment img {
    height: 16.5vw;
  }
  .day7 .comment {
    bottom: 7.5vw;
    right: -5.5vw;
  }
  .day22 .comment {
    bottom: -1vw;
    left: -1vw;
  }
  .day22 .comment img {
    height: 16.5vw;
  }
  .day22 .comment2 {
    margin: -4.5vw auto -1.3vw 13vw;
    transform: rotate(-3deg);
  }
  .day22 .comment2 img {
    width: 33vw;
  }
  .day23 .comment {
    top: 16.5vw;
    left: -6vw;
  }
  .day23 .comment2 {
    margin: -8.7vw auto -2vw 13vw;
    transform: rotate(1deg);
  }
  .day23 .comment2 img {
    width: 33vw;
  }
  .day24 .comment {
    top: 51.5vw;
    left: 5.5vw;
  }
  .day24 .comment2 {
    margin: -5.3vw auto -1.5vw 13.5vw;
    transform: rotate(-3deg);
  }
  .day24 .comment2 img {
    width: 33vw;
  }
  .day26 .comment {
    top: 45.5vw;
    right: 1vw;
  }
  .day27 .comment {
    top: 46.5vw;
    left: -2.5vw;
  }
  .day28 .comment {
    top: 48.5vw;
    left: 8vw;
  }
  .day29 .comment {
    top: 10.5vw;
    left: -5vw;
  }
  .day30 .comment {
    top: 50.5vw;
    left: 4.5vw;
  }
  .day31 .comment {
    top: 47vw;
    right: -2.5vw;
  }
  .day32 .comment {
    bottom: 22vw;
    right: 10vw;
  }
  .maindish .calendar li.day32 a img {
    box-shadow: none;
  }
}
/* ===============================================================================
Footer
=============================================================================== */
#link_footer a {
  font-size: 1.6rem;
  font-feature-settings: 'palt';
  font-weight: 400;
}
#link_footer .wrapper > div {
  max-width: 450px;
  width: 92.3vw;
  margin: 0 auto;
}
#link_footer .site {
  border-bottom: 1px solid #aaa;
  padding-bottom: 20px;
  margin-bottom: 30px;
}
#link_footer .site a::after {
  display: inline-block;
  content: '';
  vertical-align: -4px;
  background: url(../img/arrow.svg) no-repeat;
  -webkit-background-size: 100% 100%;
  -moz-background-size: 100% 100%;
  background-size: 100% 100%;
  width: 20px;
  height: 20px;
  margin-left: 1em;
}
#link_footer .guide {
  padding: 6px 15px 70px;
  display: flex;
  align-items: center;
  gap: 8.5px;
  text-align: left;
  line-height: 150%; /* 28px */
  font-weight: 400;
  letter-spacing: 0.04em;
}
#link_footer .guide a {
  text-decoration: underline;
}
#link_footer .guide img {
  width: 63px;
}
#link_footer .lineup img {
  max-width: 384px;
  width: 100%;
}
#link_footer .index {
  margin: 50px auto 40px;
}
#link_footer .index a {
  font-weight: 700;
}
#link_footer .share ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px 16px;
}
#link_footer .share ul:before {
  content: "Share";
  width: 100%;
  display: block;
  text-align: center;
  color: #000;
  font-size: 13px;
  line-height: 175%;
  letter-spacing: 0.975px;
}
[class*=mdi-]:before {
  line-height: 1;
  font-weight: 400;
  font-style: normal;
  font-variant: normal;
  text-transform: none;
  letter-spacing: normal;
  word-wrap: normal;
  white-space: nowrap;
  direction: ltr;
  speak: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: "Material Design Icons";
}
footer {
  background: url(../img/bg1.jpg);
  background-size: 730px 1060px;
  letter-spacing: 0;
  padding-bottom: 40px;
}
footer a {
  color: #333;
}
footer section::before {
  display: none;
}
section[role=social]>div {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  max-width: 960px;
  margin: 0 auto;
  padding-top: 40px;
}
section[role=social]>div>ul:first-of-type {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
}
section[role=social]>div>ul:nth-of-type(2) {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}
section[role=social]>div>ul:first-of-type li+li {
  margin-left: 32px;
}
section[role=social]>div>ul:nth-of-type(2):before {
  content: attr(data-title) "";
  display: block;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 700;
  color: #333;
}
section[role=social]>div>ul:nth-of-type(2) li {
  margin-left: 8px;
}
section[role=social]>div>ul:first-of-type li a {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}
section[role=social]>div>ul:first-of-type li a:before {
  font-size: 18px;
  color: #ff8733;
  margin-right: 9px;
  display: block;
}
section[role=social]>div>ul:first-of-type li a span {
  display: block;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 700;
}
.mdi-email-outline:before {
  content: "\F1F0";
}
.mdi-email-outline:before {
  content: "\F1F0";
}
section[role=social]>div>ul:nth-of-type(2) li a {
  display: block;
  width: 24px;
  height: 24px;
  overflow: hidden;
  position: relative;
}
section[role=social]>div>ul:nth-of-type(2) li a:before {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate3d(-50%,-50%,0);
  -moz-transform: translate3d(-50%,-50%,0);
  -o-transform: translate3d(-50%,-50%,0);
  -ms-transform: translate3d(-50%,-50%,0);
  transform: translate3d(-50%,-50%,0);
  font-size: 24px;
  color: #ff8733;
}
.mdi-facebook-box:before {
  display: none;
}
section[role=social]>div>ul:nth-of-type(2) li a>div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: .01;
  -webkit-transform: scale(1,1.6);
  -moz-transform: scale(1,1.6);
  -o-transform: scale(1,1.6);
  -ms-transform: scale(1,1.6);
  transform: scale(1,1.6);
  -webkit-transform-origin: 0 0;
  -moz-transform-origin: 0 0;
  -o-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  transform-origin: 0 0;
}
section[role=bottom]>div {
  max-width: 960px;
  margin: 0 auto;
  padding-top: 40px;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-pack: justify;
  -moz-box-pack: justify;
  -o-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 400;
}
section[role=bottom]>div:last-of-type {
  padding-top: 46px;
  font-weight: 700;
}
section[role=bottom]>div ul {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
}
ul[role=translate] li a.btn-translate, ul[role=translate] li span.btn-translate {
  cursor: pointer;
}
ul[role=translate] li+li {
  margin-left: 12px !important;
  padding-left: 12px;
  border-left: 1px #333 solid;
}
ul[role=translate] li a, ul[role=translate] li span {
  display: block;
  font-size: 12px;
  line-height: 1;
  font-weight: 700;
  margin: -10px 0;
  padding: 10px 0;
}
ul[role=translate] li a:not(.btn-translate), ul[role=translate] li span:not(.btn-translate) {
  opacity: .4;
}
@media screen and (min-width: 641px) {
  section[role=social]>div>ul:nth-of-type(2) {
    margin-left: 32px;
  }
  section[role=bottom]>div ul li+li {
    margin-left: 34px;
  }
}
@media screen and (max-width: 640px) {
  #link_footer a {
    font-size: 3.125vw;
  }
  #link_footer .index a {
    font-size: 3.846vw;
  }
  #link_footer .wrapper {
    padding: 30px 0 50px;
  }
  #link_footer .site a::after {
    margin-left: 1em;
  }
  #link_footer .site {
    padding-bottom: 28px;
  }
  #link_footer .guide {
    padding: 0 16px;
    letter-spacing: 0.035em;
  }
  #link_footer .guide img {
    width: 11.538vw;
  }
  section[role=social]>div {
    display: block;
    padding-top: 30px;
  }
  section[role=social]>div>ul {
    justify-content: center;
  }
  section[role=social]>div>ul:first-of-type {
    padding-bottom: 27px;
  }
  section[role=bottom]>div {
    display: block;
    padding-top: 50px;
  }
  section[role=bottom]>div ul {
    display: block;
    text-align: center;
  }
  section[role=bottom]>div ul li+li{
    padding-top: 1.3em;
  }
  section[role=bottom]>div:last-of-type {
    display: flex; 
    width: 92.3vw;
  }
  section[role=bottom]>div ul[role=translate] {
    gap: 0;
    display: flex;
    justify-content: center;
    text-align: center;
  }
  ul[role=translate] li+li {
    padding-top: 0 !important;
  }
  section[role=bottom]>div ul li a {
    font-size: 2.88vw;
  } 
}