@charset "UTF-8";
button, hr, input {
  overflow: visible;
}

progress, sub, sup {
  vertical-align: baseline;
}

[type=checkbox], [type=radio], legend {
  box-sizing: border-box;
  padding: 0;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

details, main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

hr {
  box-sizing: content-box;
  height: 0;
}

code, kbd, pre, samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b, strong {
  font-weight: bolder;
}

small {
  font-size: 80%;
}

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
}

button, input, optgroup, select, textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button, select {
  text-transform: none;
}

[type=button], [type=reset], [type=submit], button {
  -webkit-appearance: button;
}

[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring, button:-moz-focusring {
  outline: ButtonText dotted 1px;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  color: inherit;
  display: table;
  max-width: 100%;
  white-space: normal;
}

textarea {
  overflow: auto;
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

summary {
  display: list-item;
}

[hidden], template {
  display: none;
}

/* basic-tags */
*, *:before, *:after {
  box-sizing: border-box;
}

html, body {
  background-color: #000;
  color: #000;
  font-family: "Noto Sans JP", "Hiragino Sans", "ヒラギノ角ゴシック", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "Yu Gothic", "游ゴシック", "YuGothic", "游ゴシック体", "Meiryo", "メイリオ", "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
  font-weight: 500;
  line-height: 1.6;
  position: relative;
  width: 100%;
  font-size: 14px;
}
@media screen and (min-width: 375px) {
  html, body {
    font-size: 15px;
  }
}
@media screen and (min-width: 576px) {
  html, body {
    font-size: 14px;
  }
}
@media screen and (min-width: 768px) {
  html, body {
    font-size: 13px;
  }
}
@media screen and (min-width: 992px) {
  html, body {
    font-size: 15px;
  }
}
@media screen and (min-width: 1200px) {
  html, body {
    font-size: 18px;
  }
}
@media screen and (min-width: 1360px) {
  html, body {
    font-size: 20px;
  }
}

html {
  scroll-behavior: smooth;
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

main {
  padding-top: 60px;
}
@media screen and (min-width: 768px) {
  main {
    padding-top: 80px;
  }
}

h1, h2, h3, h4, h5, h6, p, figure {
  margin: 0;
}

h1, h2, h3, h4, h5, h6 {
  line-height: 1;
}

a {
  text-decoration: none;
  -webkit-transition: color 0.15s linear 0s;
  -moz-transition: color 0.15s linear 0s;
  -ms-transition: color 0.15s linear 0s;
  -o-transition: color 0.15s linear 0s;
  transition: color 0.15s linear 0s;
}

picture {
  display: block;
}

picture > img,
figure > img {
  display: block;
  width: 100%;
  height: auto;
}

/* --------------------
  common-classes
-------------------- */
.cmn-contentWidth {
  margin: 0 auto;
  width: calc(100% - 50px);
}
@media screen and (min-width: 576px) {
  .cmn-contentWidth {
    width: 518px;
  }
}
@media screen and (min-width: 768px) {
  .cmn-contentWidth {
    width: 622px;
  }
}
@media screen and (min-width: 992px) {
  .cmn-contentWidth {
    width: 802px;
  }
}
@media screen and (min-width: 1200px) {
  .cmn-contentWidth {
    width: 970px;
  }
}
@media screen and (min-width: 1360px) {
  .cmn-contentWidth {
    width: 1100px;
  }
}

span {
  letter-spacing: calc(-1em * var(--ls));
}

.fadein {
  opacity: 0;
  transform: translateY(5vh);
  transition: opacity 1s ease-out, transform 1s ease-out;
}
.fadein.faded {
  opacity: 1;
  transform: translateY(0);
}
.fadein.later {
  transition-delay: 1s;
}

/* --------------------
  utility-classes
-------------------- */
.sr-only {
  display: none;
}

@media screen and (min-width: 768px) {
  .sp-only {
    display: none;
  }
}

@media screen and (min-width: 375px) {
  .xs-only {
    display: none;
  }
}

@media screen and (min-width: 576px) {
  .xs-and-ssm {
    display: none;
  }
}

@media screen and (max-width: 374px) {
  .ssm-only {
    display: none;
  }
}
@media screen and (min-width: 576px) {
  .ssm-only {
    display: none;
  }
}

@media screen and (max-width: 374px) {
  .ssm-over {
    display: none;
  }
}

@media screen and (max-width: 575px) {
  .sm-over {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .pc-only {
    display: none;
  }
}

.no-bullet {
  list-style: none;
  padding-left: 0;
}

.no-margin {
  margin: 0;
}

.inblock {
  display: inline-block;
}

/*===== cmn-styles =====*/
.cmn-tiled {
  background-position: 0 0;
  background-repeat: repeat;
  background-size: 6.3em auto;
}
@media screen and (min-width: 768px) {
  .cmn-tiled {
    background-size: 12.6em auto;
  }
}

.cmn-sectHead {
  padding-top: 4em;
}
.cmn-sectHead h2 {
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: contain;
  font-size: 1rem;
  height: 4.5em;
  margin-bottom: 3.5em;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
@media screen and (min-width: 576px) {
  .cmn-sectHead h2 {
    height: 1.8em;
  }
}

.cmn-datalist {
  display: grid;
  gap: 0.55em 2em;
  grid-template-columns: 4em 1fr;
  grid-template-rows: auto;
  margin: 0;
}
.cmn-datalist dt {
  text-align-last: justify;
}
.cmn-datalist dd {
  margin-left: 0;
}

/*
  header: フォントサイズは sp / pc それぞれで固定.
  メニュー項目名の変更により
*/
header {
  background-color: #000;
  font-size: 16px;
  height: 60px;
  position: fixed;
  z-index: 10;
  width: 100%;
}
@media screen and (min-width: 768px) {
  header {
    height: 80px;
  }
}
header .content {
  height: 100%;
  padding: 0 20px;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 768px) {
  header .content {
    padding: 0 50px;
  }
}
@media screen and (min-width: 1360px) {
  header .content {
    display: flex;
    gap: 30px;
  }
}
header .logo-and-toggle {
  align-items: center;
  background-color: #000;
  display: flex;
  height: 100%;
  justify-content: space-between;
  position: relative;
  width: 100%;
  z-index: 11;
}
@media screen and (min-width: 1360px) {
  header .logo-and-toggle {
    display: block;
    width: auto;
  }
}
header .logo {
  height: 100%;
  width: 217px;
}
@media screen and (min-width: 375px) {
  header .logo {
    width: 272px;
  }
}
@media screen and (min-width: 768px) {
  header .logo {
    width: 398px;
  }
}
header .logo > a {
  background: url(../img/psp-logo-8@2x.png) 0 50%/contain no-repeat;
  display: block;
  height: 100%;
  width: 100%;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  header .logo > a {
    transition: filter 0.15s linear, translate 0.25s ease-in;
  }
  header .logo > a:hover {
    filter: drop-shadow(0 2px 0 rgba(255, 255, 255, 0.25));
    translate: 0 -2px;
  }
}
header nav {
  background-color: rgba(0, 0, 0, 0.9);
  translate: 0 calc(-100% - 80px);
  transition: translate 0.25s ease-out;
  width: 100%;
  position: absolute;
  left: 0;
  top: 60px;
}
@media screen and (min-width: 768px) {
  header nav {
    top: 80px;
  }
}
@media screen and (min-width: 1360px) {
  header nav {
    translate: 0 0;
    position: relative;
    width: auto;
    left: auto;
    top: auto;
  }
}
@media screen and (max-width: 1359px) {
  header nav.active {
    translate: 0 0;
  }
}
header nav ul {
  font-family: "Noto Serif", serif;
  font-size: 16px;
  font-weight: 500;
  list-style: none;
  margin: 0;
  padding: 25px;
}
@media screen and (min-width: 768px) {
  header nav ul {
    padding: 50px;
  }
}
@media screen and (min-width: 1360px) {
  header nav ul {
    align-items: center;
    display: flex;
    gap: 40px;
    height: 100%;
    padding: 0;
  }
}
header nav ul a {
  border-bottom: 1px solid transparent;
  color: #fff;
  display: block;
  padding: 0.5em 0;
}
@media screen and (min-width: 1360px) {
  header nav ul a {
    padding: 6px 10px 0;
  }
}
@media screen and (min-width: 768px) {
  header nav ul a {
    transition: border-bottom-color 0.5s linear;
  }
  header nav ul a:hover {
    border-bottom-color: rgba(255, 255, 255, 0.75);
  }
}
header .toggle {
  background: url(../img/toggle-open@2x.png) 0 0/contain no-repeat;
  cursor: pointer;
  height: 33px;
  width: 33px;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
@media screen and (min-width: 1360px) {
  header .toggle {
    display: none;
  }
}
header .toggle.opened {
  background-image: url(../img/toggle-close@2x.png);
}

/*  footer: 共通設定  */
footer {
  background-color: #fff;
  font-size: 0.625rem;
  line-height: 1.6875;
  padding: 50px 0 35px;
  text-align: center;
}
@media screen and (min-width: 768px) {
  footer {
    font-size: 0.85rem;
    padding-top: 100px;
    padding-top: 5rem;
  }
}
footer ul {
  display: flex;
  gap: 20px;
  justify-content: center;
  list-style: none;
  margin: 45px auto;
  padding: 0;
}
footer ul a {
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
  height: 38px;
  width: 38px;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  footer ul a {
    transition: opacity 0.15s linear;
  }
  footer ul a:hover {
    opacity: 0.8;
  }
}
footer ul a.xt {
  background-image: url(../img/sns-xt-81@2x.png);
}
footer ul a.fa {
  background-image: url(../img/sns-fa-81@2x.png);
}
footer ul a.in {
  background-image: url(../img/sns-in-81@2x.png);
}
footer .colophon {
  font-size: 0.55rem;
}

#linkToTop {
  bottom: 16px;
  height: 32px;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  right: 16px;
  transition: opacity 0.5s linear;
  width: 32px;
}
#linkToTop.active {
  opacity: 1;
  pointer-events: all;
}
#linkToTop a {
  background: url(../img/baktop-arrow.svg) 0 0/contain no-repeat;
  display: block;
  height: 100%;
  width: 100%;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}

/*===== title__sect =====*/
.title__sect .content {
  background: url(../img/pagetitle@1x.jpg) 50% 0/cover no-repeat;
  height: 90vw;
  height: 95svw;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
@media screen and (min-width: 576px) {
  .title__sect .content {
    height: 62.64705882vw;
    height: 62.64705882svw;
  }
}

/*===== "DECORATION" =====*/
.decor__sect {
  background-image: url(../img/decor-bgtile@1x.jpg);
  padding-bottom: 4.5em;
  scroll-margin-top: 2em;
}
@media screen and (min-width: 768px) {
  .decor__sect {
    background-image: url(../img/decor-bgtile@2x.jpg);
    scroll-margin-top: 4em;
  }
}

.decor__head {
  margin-bottom: 7.1em;
}
.decor__head h2 {
  background-image: url(../img/decor-title-sp@2x.png);
}
@media screen and (min-width: 576px) {
  .decor__head h2 {
    background-image: url(../img/decor-title@2x.png);
  }
}

article[class*=decor__post-] {
  position: relative;
}
@media screen and (min-width: 576px) {
  article[class*=decor__post-] {
    display: grid;
    grid-template-areas: "main fig";
    grid-template-columns: 52.91% 42.36%;
    justify-content: space-between;
  }
}
@media screen and (min-width: 576px) {
  article[class*=decor__post-] .post-fig {
    grid-area: fig;
    padding-top: 0.5em;
  }
}
article[class*=decor__post-] .post-fig figure {
  margin-bottom: 2em;
}
@media screen and (min-width: 576px) {
  article[class*=decor__post-] .post-fig figure {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 576px) {
  article[class*=decor__post-] .post-fig figure + figure {
    margin-top: 2em;
  }
}
article[class*=decor__post-] .post-main {
  position: relative;
}
@media screen and (min-width: 576px) {
  article[class*=decor__post-] .post-main {
    grid-area: main;
  }
}
article[class*=decor__post-] .post-main h3 {
  color: #c94e13;
  font-size: 1.5em;
  font-weight: 500;
  line-height: 1.6;
  margin-bottom: 0.6666666667em;
}
article[class*=decor__post-] .post-main .cmn-datalist {
  margin-bottom: 4em;
}
article[class*=decor__post-] .post-main > p {
  text-align: justify;
}
article[class*=decor__post-] + article {
  margin-top: 1.5em;
  padding-top: 5em;
  border-top: 1px solid rgba(0, 0, 0, 0.5);
}
@media screen and (min-width: 576px) {
  article[class*=decor__post-] + article {
    margin-top: 5em;
  }
}

.decor__post-a div.orns {
  height: 12.9375em;
  margin-top: 1em;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 576px) {
  .decor__post-a div.orns {
    bottom: -125px;
    height: 8.625em;
    left: 0.5em;
    margin-top: 0;
    position: absolute;
    width: 10.8em;
    z-index: 2;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-a div.orns {
    bottom: -30px;
    height: 17.25em;
    left: 0.5em;
    width: 21.6em;
  }
}
@media screen and (min-width: 992px) {
  .decor__post-a div.orns {
    bottom: -0.3em;
  }
}
.decor__post-a div.orns img {
  animation-delay: 0s;
  animation-fill-mode: both;
  animation-iteration-count: infinite;
  height: auto;
  position: absolute;
}
.decor__post-a div.orns .jack {
  animation-duration: 3s;
  animation-name: anm_jack;
  animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  transform-origin: 50% 100%;
  left: 0.375em;
  top: 3.5625em;
  width: 6.6em;
}
@media screen and (min-width: 576px) {
  .decor__post-a div.orns .jack {
    left: 0;
    top: 2.375em;
    width: 4.4em;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-a div.orns .jack {
    top: 4.75em;
    width: 8.8em;
  }
}
.decor__post-a div.orns .bat-l {
  animation-duration: 0.5s;
  animation-name: anm_bat;
  animation-timing-function: cubic-bezier(0.445, 0.05, 0.55, 0.95);
  transform-origin: 100% 100%;
  left: 7.8375em;
  top: 3.0375em;
  width: 8.3625em;
}
@media screen and (min-width: 576px) {
  .decor__post-a div.orns .bat-l {
    left: 4.975em;
    top: 2.025em;
    width: 5.575em;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-a div.orns .bat-l {
    left: 9.95em;
    top: 4.05em;
    width: 11.15em;
  }
}
.decor__post-a div.orns .bat-s {
  animation-direction: reverse;
  animation-duration: 0.35s;
  animation-name: anm_bat;
  animation-timing-function: cubic-bezier(0.445, 0.05, 0.55, 0.95);
  transform-origin: 100% 100%;
  left: 9.675em;
  top: 0;
  width: 5.25em;
}
@media screen and (min-width: 576px) {
  .decor__post-a div.orns .bat-s {
    left: 6.2em;
    width: 3.5em;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-a div.orns .bat-s {
    left: 12.4em;
    width: 7em;
  }
}

@keyframes anm_jack {
  0% {
    transform: rotateZ(-8deg);
  }
  40% {
    transform: rotateZ(8deg);
  }
  50% {
    transform: rotateZ(8deg);
  }
  90% {
    transform: rotateZ(-8deg);
  }
  100% {
    transform: rotateZ(-8deg);
  }
}
@keyframes anm_bat {
  0% {
    transform: translateY(0) rotateZ(0deg) scale(0.96);
    margin-top: 0;
  }
  40% {
    transform: translateY(0.25em) rotateZ(-5deg) scale(1);
    margin-top: -0.5em;
  }
  50% {
    transform: translateY(0.25em) rotateZ(-5deg) scale(1);
    margin-top: -0.5em;
  }
  90% {
    transform: translateY(0) rotateZ(0deg) scale(0.96);
    margin-top: 0;
  }
  100% {
    transform: translateY(0) rotateZ(0deg) scale(0.96);
    margin-top: 0;
  }
}
.decor__post-b div.orns {
  height: 5.5125em;
  margin-top: 1em;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 576px) {
  .decor__post-b div.orns {
    bottom: -50px;
    left: 260px;
    margin-top: 0;
    position: absolute;
    width: 12.675em;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-b div.orns {
    bottom: -4.4em;
    height: 7.35em;
    left: 4em;
    width: 16.9em;
  }
}
@media screen and (min-width: 992px) {
  .decor__post-b div.orns {
    bottom: -2.9em;
  }
}
.decor__post-b div.orns img {
  animation-fill-mode: both;
  animation-iteration-count: infinite;
  animation-name: anm_leaf;
  animation-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
  height: auto;
  position: absolute;
}
.decor__post-b div.orns .leaf-m {
  animation-duration: 3.5s;
  left: 3em;
  top: 1.7625em;
  width: 3.15em;
}
@media screen and (min-width: 576px) {
  .decor__post-b div.orns .leaf-m {
    left: 0;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-b div.orns .leaf-m {
    top: 2.35em;
    width: 4.2em;
  }
}
.decor__post-b div.orns .leaf-s {
  animation-duration: 2.5s;
  animation-direction: reverse;
  left: 7.6875em;
  top: 0.075em;
  width: 2.0625em;
}
@media screen and (min-width: 576px) {
  .decor__post-b div.orns .leaf-s {
    left: 4.6875em;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-b div.orns .leaf-s {
    left: 6.25em;
    top: 0.1em;
    width: 2.75em;
  }
}
.decor__post-b div.orns .leaf-l {
  animation-duration: 5.5s;
  left: 11.1375em;
  top: 0;
  width: 4.5375em;
}
@media screen and (min-width: 576px) {
  .decor__post-b div.orns .leaf-l {
    left: 8.1375em;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-b div.orns .leaf-l {
    left: 10.85em;
    width: 6.05em;
  }
}

@keyframes anm_leaf {
  0% {
    transform: rotateZ(0deg) rotateX(0deg);
    filter: brightness(1) contrast(1);
  }
  50% {
    transform: rotateZ(10deg) rotateX(40deg);
    filter: brightness(1.35) contrast(1.25);
  }
  95% {
    transform: rotateZ(0deg) rotateX(0deg);
    filter: brightness(1) contrast(1);
  }
  100% {
    transform: rotateZ(0deg) rotateX(0deg);
    filter: brightness(1) contrast(1);
  }
}
@media screen and (min-width: 576px) {
  .decor__post-c {
    padding-bottom: 6.6em;
  }
}
.decor__post-c h4 {
  color: #6d5b4d;
  font-size: 1.35em;
  font-weight: 500;
  margin-top: 4.2592592593em;
}
.decor__post-c .artist-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.decor__post-c .artist-list li {
  margin-top: 1.8em;
}
.decor__post-c .artist-list li span:not(.inblock) {
  display: block;
}
.decor__post-c .artist-list li .group {
  font-weight: 300;
}
.decor__post-c .artist-list li .name {
  font-size: 1.35em;
}
.decor__post-c .post-orns {
  height: 10.6125em;
  margin-top: 2em;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 576px) {
  .decor__post-c .post-orns {
    bottom: 0;
    position: absolute;
    right: 40px;
    width: 9.1875em;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-c .post-orns {
    height: 14.15em;
    right: 5.65em;
    width: 12.25em;
  }
}
.decor__post-c .post-orns img {
  animation-name: anm_ball;
  animation-iteration-count: infinite;
  animation-delay: 0s;
  animation-fill-mode: both;
  animation-timing-function: cubic-bezier(0.445, 0.05, 0.55, 0.95);
  display: block;
  height: auto;
  position: absolute;
}
.decor__post-c .post-orns .ball-l {
  animation-duration: 5s;
  transform-origin: 90% 100%;
  left: 9.675em;
  top: 0;
  width: 4.6125em;
}
@media screen and (min-width: 576px) {
  .decor__post-c .post-orns .ball-l {
    left: 0;
    width: 4.6125em;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-c .post-orns .ball-l {
    width: 6.15em;
  }
}
.decor__post-c .post-orns .ball-r {
  animation-direction: reverse;
  animation-duration: 6s;
  transform-origin: 40% 100%;
  left: 15.3em;
  top: 0.9375em;
  width: 3.5625em;
}
@media screen and (min-width: 576px) {
  .decor__post-c .post-orns .ball-r {
    left: 5.625em;
  }
}
@media screen and (min-width: 768px) {
  .decor__post-c .post-orns .ball-r {
    left: 7.5em;
    top: 1.25em;
    width: 4.75em;
  }
}

@keyframes anm_ball {
  0% {
    transform: rotateZ(0deg);
  }
  40% {
    transform: rotateZ(10deg);
  }
  50% {
    transform: rotateZ(10deg);
  }
  90% {
    transform: rotateZ(0deg);
  }
  100% {
    transform: rotateZ(0deg);
  }
}
.decor__callout {
  background-color: #fff2cf;
  margin-bottom: 4.5em;
  padding: 1.75em 1.5em;
}
@media screen and (min-width: 576px) {
  .decor__callout {
    padding: 2.5em;
  }
}
.decor__callout h3 {
  background: url(../img/decor-CO-title-sp@2x.png) 0 0/contain no-repeat;
  font-size: 1rem;
  height: 5em;
  margin-bottom: 2em;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
@media screen and (min-width: 576px) {
  .decor__callout h3 {
    background-image: url(../img/decor-CO-title@2x.png);
    height: 2em;
  }
}
.decor__callout p {
  text-align: justify;
}
.decor__callout .callout-post {
  padding-top: 2.5em;
}
@media screen and (min-width: 576px) {
  .decor__callout .callout-post {
    display: grid;
    grid-template-columns: 44% 50%;
    justify-content: space-between;
  }
}
.decor__callout .callout-post .post-fig {
  margin-bottom: 1.2em;
}
@media screen and (min-width: 576px) {
  .decor__callout .callout-post .post-fig {
    margin-bottom: 0;
  }
}
.decor__callout .callout-post .post-main h4 {
  color: #6d5b4d;
  font-size: 1.2em;
  font-weight: 500;
  line-height: 1.4166666667;
  margin-bottom: 1em;
}
.decor__callout .callout-post + .callout-post {
  margin-top: 2.5em;
  border-top: 1px solid rgba(0, 0, 0, 0.5);
}

.decor__map {
  margin: 0 auto;
  max-width: 40em;
  position: relative;
}
.decor__map h3 {
  font-size: 1rem;
  font-weight: 500;
  margin-bottom: 0.3em;
}
.decor__map .legend {
  margin-top: 0.5em;
  text-align: right;
}
@media screen and (min-width: 768px) {
  .decor__map .legend {
    bottom: 0.3em;
    margin-top: 0;
    position: absolute;
    right: 0;
  }
}
.decor__map .legend .blue {
  color: #009ee5;
}

/*===== "STAMP RALLY" =====*/
.stamp__sect {
  background-image: url(../img/stamp-bgtile@1x.jpg);
  padding-bottom: 1.5em;
  scroll-margin-top: 2em;
}
@media screen and (min-width: 576px) {
  .stamp__sect {
    padding-bottom: 5em;
  }
}
@media screen and (min-width: 768px) {
  .stamp__sect {
    background-image: url(../img/stamp-bgtile@2x.jpg);
    scroll-margin-top: 4em;
  }
}
.stamp__sect .content {
  position: relative;
}

.stamp__head h2 {
  background-image: url(../img/stamp-title-sp@2x.png);
}
@media screen and (min-width: 576px) {
  .stamp__head h2 {
    background-image: url(../img/stamp-title@2x.png);
  }
}

.stamp__post {
  margin-bottom: 4.5em;
}
@media screen and (min-width: 576px) {
  .stamp__post {
    display: grid;
    grid-template-areas: "main fig";
    grid-template-columns: 52.91% 42.36%;
    justify-content: space-between;
  }
}
@media screen and (min-width: 768px) {
  .stamp__post {
    grid-template-columns: 46.64% 42.36%;
  }
}
.stamp__post .post-fig figure {
  margin-bottom: 2em;
}
@media screen and (min-width: 576px) {
  .stamp__post .post-fig figure {
    grid-area: fig;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 576px) {
  .stamp__post .post-main {
    grid-area: main;
  }
}
.stamp__post .post-main h3 {
  color: #c74370;
  font-size: 1.5em;
  font-weight: 500;
  margin-bottom: 1.1666666667em;
}
.stamp__post .post-main h3 span {
  display: block;
}
.stamp__post .post-main h3 .lead {
  font-size: 0.6666666667em;
  margin-bottom: 0.85em;
}
.stamp__post .post-main .cmn-datalist {
  margin-bottom: 3.3em;
}
.stamp__post .post-main .body {
  text-align: justify;
  line-height: 1.95;
}

.stamp__map {
  margin: 0 auto;
  max-width: 40em;
}
.stamp__map h3 {
  font-size: 1rem;
  font-weight: 500;
  margin-bottom: 0.9em;
}

.stamp__orns {
  height: 7.125em;
  margin: -3.5em 0 0 auto;
  position: relative;
  width: 11.775em;
}
@media screen and (min-width: 576px) {
  .stamp__orns {
    bottom: -1.85em;
    margin: 0;
    position: absolute;
    right: -0.25em;
  }
}
@media screen and (min-width: 768px) {
  .stamp__orns {
    height: 9.5em;
    width: 15.7em;
  }
}
.stamp__orns img {
  animation-name: anm_pump;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
  transform-origin: 50% 100%;
  display: block;
  height: auto;
  position: absolute;
}
.stamp__orns .pump-s {
  animation-duration: 2.5s;
  left: 0;
  bottom: 0;
  width: 5.625em;
}
@media screen and (min-width: 768px) {
  .stamp__orns .pump-s {
    width: 7.5em;
  }
}
.stamp__orns .pump-l {
  animation-duration: 4s;
  animation-direction: reverse;
  bottom: 0.075em;
  right: 0;
  width: 8.175em;
}
@media screen and (min-width: 768px) {
  .stamp__orns .pump-l {
    bottom: 0.1em;
    width: 10.9em;
  }
}

@keyframes anm_pump {
  0% {
    transform: rotateZ(0deg);
  }
  5% {
    transform: rotateZ(5deg);
  }
  10% {
    transform: rotateZ(-5deg);
  }
  15% {
    transform: rotateZ(5deg);
  }
  20% {
    transform: rotateZ(-5deg);
  }
  25% {
    transform: rotateZ(5deg);
  }
  30% {
    transform: rotateZ(-5deg);
  }
  35% {
    transform: rotateZ(0deg);
  }
  100% {
    transform: rotateZ(0deg);
  }
}
/*===== "ILLUMINATION" =====*/
.illum__sect {
  background-image: url(../img/illum-bgtile@1x.jpg);
  padding-bottom: 6em;
  scroll-margin-top: 2em;
}
@media screen and (min-width: 576px) {
  .illum__sect {
    padding-bottom: 5em;
  }
}
@media screen and (min-width: 768px) {
  .illum__sect {
    background-image: url(../img/illum-bgtile@2x.jpg);
    scroll-margin-top: 4em;
  }
}
.illum__sect .content {
  position: relative;
}

.illum__head h2 {
  background-image: url(../img/illum-title-sp@2x.png);
}
@media screen and (min-width: 576px) {
  .illum__head h2 {
    background-image: url(../img/illum-title@2x.png);
  }
}

@media screen and (min-width: 576px) {
  .illum__post {
    display: grid;
    grid-template-areas: "main fig";
    grid-template-columns: 52.91% 42.36%;
    justify-content: space-between;
  }
}
@media screen and (min-width: 768px) {
  .illum__post {
    grid-template-columns: 46.64% 42.36%;
  }
}
.illum__post .post-fig figure {
  margin-bottom: 2em;
}
@media screen and (min-width: 576px) {
  .illum__post .post-fig figure {
    grid-area: fig;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 576px) {
  .illum__post .post-main {
    grid-area: main;
  }
}
.illum__post .post-main h3 {
  color: #4e3199;
  font-size: 1.5em;
  font-weight: 500;
  margin-bottom: 1.1666666667em;
}
.illum__post .post-main .cmn-datalist {
  margin-bottom: 2.5em;
}
.illum__post .post-main .body {
  line-height: 1.95;
  text-align: justify;
}
.illum__post .post-main .body-note {
  font-size: 0.75em;
  margin-top: 0.4em;
}

.illum__orns {
  bottom: -5em;
  height: 4.05em;
  position: absolute;
  right: 0;
  width: 11.1em;
}
@media screen and (min-width: 576px) {
  .illum__orns {
    bottom: 0;
  }
}
@media screen and (min-width: 768px) {
  .illum__orns {
    bottom: auto;
    top: 3em;
    right: -2em;
  }
}
@media screen and (min-width: 992px) {
  .illum__orns {
    height: 5.4em;
    right: 0;
    top: 2.4em;
    width: 14.8em;
  }
}
.illum__orns img {
  animation-name: anm_ilm_leaf;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
  animation-delay: 0s;
  display: block;
  height: auto;
  position: absolute;
}
.illum__orns .leaf-l {
  animation-duration: 5.5s;
  left: 0;
  top: 0.1125em;
  width: 4.575em;
}
@media screen and (min-width: 992px) {
  .illum__orns .leaf-l {
    top: 0.15em;
    width: 6.1em;
  }
}
.illum__orns .leaf-m {
  animation-duration: 3.5s;
  left: 4.3875em;
  top: 0;
  width: 2.625em;
}
@media screen and (min-width: 992px) {
  .illum__orns .leaf-m {
    left: 5.85em;
    width: 3.5em;
  }
}
.illum__orns .leaf-r {
  animation-duration: 4.5s;
  right: 0;
  top: 1.5375em;
  width: 4.575em;
}
@media screen and (min-width: 992px) {
  .illum__orns .leaf-r {
    top: 2.05em;
    width: 6.1em;
  }
}

@keyframes anm_ilm_leaf {
  0% {
    transform: rotateY(0deg);
    filter: brightness(1);
  }
  25% {
    transform: rotateY(90deg);
    filter: brightness(0.35);
  }
  50% {
    transform: rotateY(180deg);
    filter: brightness(0.8);
  }
  75% {
    transform: rotateY(270deg);
    filter: brightness(0.1);
  }
  100% {
    transform: rotateY(360deg);
    filter: brightness(1);
  }
}
/*# sourceMappingURL=index.css.map */
