@charset "UTF-8";
/* CSS Document */

/*

font-family:"din-2014", sans-serif;
font-weight:400;
font-weight:600;
font-weight:700;

font-family:'zen-kaku-gothic-new', sans-serif;
font-weight:400;
font-weight:500;
font-weight:700;

*/

:root{
  --base:94,92,92; /*#5E5C5C*/
  --white:255,255,255;
  --black:100,110,120;
  --gray:125,135,145;
  --red:191,88,75;
  --blue:63,81,158;
  --pink:220,90,130;
  --highpink:227,0,127;
  --green:35,180,175;
  --yellow:245,230,0;
}

* {
  color:rgba(var(--white),1);
  font-family:'din-2014', 'zen-kaku-gothic-new', sans-serif;
  font-style:normal;
  font-weight:500;
  box-sizing:border-box;
  text-decoration:none;
}
body {
  font-size:20px;
  text-align:justify;
  line-height:2.5;
  word-break:break-all;
  margin:0;
  padding:0;
}
h1,h2,h3,h4,div,dl,dt,dd,ul,li,img,a,p,span,iframe,small,strong,figure,address,select,input,button,textarea,i,b,u,hr,em,sub,time {
  margin:0;
  padding:0;
  color:inherit;
  font-family:inherit;
  font-size:inherit;
  font-style:inherit;
  font-weight:inherit;
  list-style:none;
  text-align:justify;
  word-break:break-all;
  outline:none;
  background:none;
  border:none;
}
select,input {
  cursor:pointer;
  background:transparent;
  background-image:none;
  box-shadow:none;
  -webkit-appearance:none;
  appearance:none;
}
button {
  cursor:pointer;
}
picture {
  display:block;
}
br {
  line-height:1;
}
sub {
  bottom:initial;
}
svg {
  display:block;
}
small {
  font-size:93%;
}
img {
  display:block;
  width:100%;
}
.brNar {
  display: none;
}

.cover {
  width:auto;
  height:100%;
  object-fit:cover;
}

.underconstruction {
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  width:100%;
  height:100vh;
  max-width:325px;
  padding:0 0 0 25px;
  color:rgba(35,120,225,1);
}
.underconstruction h1 {
  width:100%;
  margin:0 0 25px 0;
}
.underconstruction ul {
  margin:25px 0 0 0;
}

[data-load="lazy"] {
  opacity: 0;
  transition: opacity 1.5s ease;
}

/* header */
header {
  display: block;
  height:100vh;
  height:100lvh;
  min-height:750px;
  overflow:hidden;
  position: relative;
}

/* mainvisual */
.surface {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  pointer-events: none;
}
.surface picture {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.surface.logo picture {
  width: 285px;
  height: auto;
  top: initial;
  left: 25px;
  bottom: 27px;
}
.surface.date picture {
  width: 172px;
  height: auto;
  left: 20px;
}
.surface.copy picture {
  width: 165px;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(80px,-310px);
}
.surface.copy img {
  height: auto;
}

[data-effect="switch"] picture {
  transition: opacity 6s ease-in-out;
}
[data-effect="switch"] .view-show {
  opacity: 1;
}
[data-effect="switch"] .view-hidden {
  opacity: 0;
}

header .surface {
  transition: .6s ease;
}
.surface.copy {
  transition-delay: .5s;
}
.surface.filter-under {
  transition-delay: .4s;
}
.surface.filter-middle {
  transition-delay: .3s;
}
.surface.dot {
  transition-delay: .2s;
}
.surface.overcover {
  transition-delay: .1s;
}
.surface.date {
  transition-delay: 0s;
}
.surface.logo {
  transition-delay: 0s;
}
.surface img {
  height: 100%;
  object-fit: cover;
}
header.has-effect .surface {
  transform: scale(1.06);
  opacity: 0;
  visibility: hidden;
}

.background {
  width:100vw;
  height:100vh;
  height:100lvh;
  position:fixed;
  top:0;
  left:0;
  z-index:-10;
  overflow:hidden;
  pointer-events: none;
}

.eventday {
  display:inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  white-space: nowrap;
  line-height:1.4;
  letter-spacing:-.14rem;
}
.eventday .date i {
  font-size:275%;
}
.eventday .date i + i:before {
  content:'/';
  margin:0 3px;
  font-size: 80%;
  position: relative;
  top: -2px;
}
.eventday .date b {
  margin: 0 0 0 12px;
  font-size:260%;
}
.eventday .date b:before,
.eventday .date b:after {
  font-size:90%;
  position: relative;
  top: -2px;
}
.eventday .date b:before {
  content:'(';
  margin:0 4px 0 0;
}
.eventday .date b:after {
  content:')';
  margin:0 0 0 6px;
}
.eventday .time i {
  font-size:275%;
}
.eventday .time i + i:before {
  content:'-';
  margin:0 0 0 6px;
}
.place {
  width: 350px;
  margin:60px auto 0 auto;
  padding: 0 0 2px 0;
  border: 2px solid;
  border-radius: 3px;
}
.place a {
  display:flex;
  justify-content: center;
  align-items:center;
  width: 100%;
  padding: 16px 0;
  font-weight:700
}
.place i {
  width:30px;
  aspect-ratio:1;
}
.place b {
  margin:3px 0 0 5px;
  letter-spacing: .02rem;
}

.sns {
  display:flex;
}
.sns a {
  width:42px;
  aspect-ratio:1;
}
.sns > a + a {
  margin:0 0 0 12px;
}

/* main */
section {
  width:100%;
  position:relative;
}
.frame {
  display:flex;
  flex-direction:column;
  width:calc(100% - 150px);
  max-width: 1200px;
  margin:auto;
}

.basic {
  display:flex;
  justify-content:flex-start;
  align-items:center;
  width:100%;
  font-weight:700;
  position:relative;
}
.basic i {
  font-size: 900%;
  line-height: 1;
  letter-spacing:-.02rem;
  opacity: .22;
  position:absolute;
  top: 50%;
  left:-95px;
  transform: translate(0,-50%);
  z-index:-1;
  white-space: nowrap;
}
.basic b {
  font-size:275%;
}

.square {
  display:flex;
  justify-content: center;
  align-items:center;
  font-size:160%;
  font-weight:700;
  line-height:1.6;
  position: relative;
}
.square hr {
  width: 200px;
  height: 200px;
  background-color: rgba(var(--white),.3);
  box-shadow: 15px 10px 15px 0 rgba(var(--black),.5);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%) rotate(45deg);
  z-index: -1;
}
.square i {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.square i small {
  margin: 0 0 20px 0;
  font-size: 75%;
}

.deco {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  opacity: .5;
  z-index: -1;
}
.deco picture {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
}
.deco picture img {
  height: 1300px;
  object-fit: contain;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-52.5%);
}

/* footer */
footer {
  display:flex;
  justify-content: space-between;
  align-items:center;
  width:calc(100% - 150px);
  max-width: 1200px;
  margin:auto;
  padding:200px 0 225px;
  position:relative;
}
footer .copyright {
  display:flex;
  justify-content: center;
  align-items:center;
  font-size:90%;
}
footer .copyright small {
  margin: 0 2px 0 0;
  position: relative;
  top: -1px;
}

nav {
  display:flex;
  position:fixed;
  top:0;
  right:0;
  z-index:100;
  transition:.6s ease;
}

.opener {
  display:flex;
  flex-wrap: wrap;
  justify-content:center;
  align-items:center;
  width:60px;
  margin: 35px;
  position:fixed;
  top:0;
  right:0;
  transform:translate(0,0);
  transition:.6s ease;
}
.opener.is-hidden {
  transform:translate(calc(100% + 60px),0);
}
.opener hr {
  width: 11px;
  height: 11px;
  margin: 4px;
  background-color: rgba(var(--white),.97);
  transform-origin: center;
  transition: .4s ease;
  animation: switchshadow 18s linear infinite alternate;
}
.opener:hover hr {
  transform: rotate(45deg);
} 
@keyframes switchshadow {
  0% {
    box-shadow: 4px 4px 0 0 rgba(var(--red),.93);
  }
  100% {
    box-shadow: 4px 4px 0 0 rgba(var(--blue),.93);
  }
}

.menuboard {
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  width:50vw;
  height:100vh;
  height:100dvh;
  padding:0 0 50px 0;
  color:rgba(var(--white),1);
  box-shadow:0 0 0 rgba(var(--base),0);
  position:fixed;
  top:0;
  right:0;
  transform:translate(100%,0);
  transition:.6s ease;
  animation: switchcolor 18s linear infinite alternate;
}
@keyframes switchcolor {
  0% {
    background-color:rgba(var(--red),.93);
  }
  100% {
    background-color:rgba(var(--blue),.93);
  }
}

.menuboard.is-show {
  box-shadow:-9px 0 15px rgba(var(--base),.25);
  transform:translate(0,0);
}
.closer {
  width:65px;
  aspect-ratio:1;
  position:fixed;
  top:30px;
  right:30px;
  z-index:10;
}
.closer hr {
  width:100%;
  height:2px;
  background-color:rgba(var(--white),1);
  position:absolute;
  top:50%;
  left:50%;
  transition:.6s ease;
}
.closer.js-close-modal hr {
  background-color:rgba(var(--base),1);
}
.closer hr:first-child {
  transform:translate(-50%,-50%) rotate(45deg);
}
.closer hr:last-child {
  transform:translate(-50%,-50%) rotate(-45deg);
}
.closer:hover hr:first-child {
  transform:translate(-50%,-50%) rotate(0deg);
}
.closer:hover hr:last-child {
  transform:translate(-50%,-50%) rotate(0deg);
}
.menuboard .global {
  display:flex;
  justify-content:center;
  width:100%;
}
.menuboard .global ul {
  margin:auto;
}
.menuboard .global li {
  font-size:105%;
  letter-spacing:-.04rem;
}
.menuboard .global li + li {
  margin:9px 0 0 0;
}
.menuboard .global li a {
  display:flex;
  align-items:center;
  position:relative;
  cursor:pointer;
}
.menuboard .global li a hr {
  width:16px;
  height:16px;
  margin:0 9px 0 0;
  border:1px solid;
  border-radius:50%;
  position:relative;
  top:-1px;
  transition:.6s ease;
}
.menuboard .global li a:hover hr {
  background-color:rgba(var(--white),1);
}
.menuboard .global em {
  margin:0 2px 0 0;
  font-size:105%;
  letter-spacing:.05rem;
}
.menuboard .sns {
  margin:40px auto 0;
}
.menuboard .sns a {
  width:38px;
}
.menuboard .pagetop {
  display:flex;
  flex-direction:column;
  align-items:center;
  width:30px;
  aspect-ratio:1;
  position:absolute;
  bottom:35px;
  left:50%;
  transform:translate(-50%,0);
}
.menuboard .pagetop hr {
  width:30px;
  height:30px;
  border-style:solid;
  border-color:rgba(var(--white),1);
  border-width:0 1.5px 1.5px 0;
  position:absolute;
  top:0;
  left:50%;
  transform:translate(-50%,0) rotate(-135deg);
}
.menuboard .pagetop i {
  margin:22px 0 0 0;
  font-size:75%;
  letter-spacing:.05rem;
  white-space:nowrap;
}

.generic {
  width:100%;
}
.generic + .generic {
  margin:100px 0 0 0;
}
.generic h2 {
  display:flex;
  align-items:center;
  margin:0 0 25px 0;
  font-size:150%;
  font-weight: 700;
}
.generic h2 hr {
  width:22px;
  height:22px;
  margin:0 6px 0 0;
  border:2px solid;
  border-radius:50%;
}
.generic * * hr {
  width:12px;
  height:12px;
  margin:0 12px 0 4px;
  border:1px solid;
  position: relative;
  top:-1px;
}
.generic picture {
  height:450px;
  margin:60px 0 0 0;
}

.list-generic {
  display:flex;
  flex-wrap:wrap;
  width:calc(100% - 150px);
}
.list-generic .box {
  display:flex;
  flex-direction:column;
  width:calc(100% / 2 - 30px);
  margin:15px ;
}
.list-generic picture {
  height:325px;
}
.list-generic picture img {
  height:100%;
}
.list-generic h3 {
  display:flex;
  align-items:center;
  margin:40px 0 15px 0;
}
.list-generic h3 i {
  font-size: 125%;
}
.list-generic h3 b {
  margin:0 0 0 3px;
  padding:0 0 0 25px;
  position:relative;
}
.list-generic h3 b:before {
  content:'';
  width:20px;
  height:1px;
  background-color:rgba(var(--base),1);
  position:absolute;
  top:50%;
  left:0;
  transform:translate(0,-50%) rotate(-45deg);
}
.list-generic h4 {
  font-size:80%;
}
.list-generic h4 i {
  padding:3px 25px;
  border:1px solid;
  border-radius:15px;
}
.list-generic p {
  font-size:90%;
  line-height:2;
}
.list-generic .viewmore {
  display:flex;
  width:100%;
  margin:40px 0 0 0;
  font-size:80%;
}
.list-generic .viewmore i {
  display:flex;
  justify-content:center;
  align-items:center;
  width:100%;
  height:50px;
  color:rgba(var(--white),1);
  background-color:rgba(var(--highpink),1);
  border-radius:5px;
}
.list-generic .sns {
  margin:30px 0 0 0;
}
.list-generic .sns a {
  width:35px;
}

.list-generic.painter .box {
  width:calc(100% / 3 - 30px);
}
.list-generic.painter .box > * {
  justify-content:center;
  text-align:center;
}
.list-generic.painter picture {
  height:auto;
}
.list-generic.painter h3 {
  margin:30px 0 5px 0;
}
.list-generic.painter h3 i {
  font-size: 100%;
}
.list-generic.painter .sns {
  margin:20px 0 0 0;
}

.note + .note {
  margin: 20px 0 0 0;
}
.note dt {
  display: flex;
  align-items: center;
}
.note dd {
  margin: 0 0 0 28px;
  font-size:90%;
  line-height:1.8;
}
.note dd span {
  display: block;
  margin: 10px 0 0 0;
}
.note dd a {
  text-decoration: underline;
}

.note li {
  display:flex;
  font-size:90%;
  line-height:1.8;
}
.note li + li {
  margin:10px 0 0 0;
}
.note li > * {
  position:relative;
}
.note li i {
  width:calc(100% - 20px);
}


@media screen and (max-width:1240px) {}


@media screen and (max-width:1080px) {

  .frame,footer {
    width: calc(100% - 100px);
  }
  .basic i {
    left: -65px;
  }

}


@media screen and (max-width:880px) {

  body {
    font-size:18px;
    line-height:2.3;
  }

  .surface.copy picture {
    width: 150px;
    transform: translate(35px,-280px);
  }
  .surface.date picture {
    top: -10px;
  }

  .frame,footer {
    width: calc(100% - 60px);
  }
  .basic i {
    font-size: 20vw;
    left: -40px;
  }
  .deco {
    width: calc(100% + 60%);
  }

  .place {
    width: 100%;
    max-width: 400px;
  }

  .generic li hr {
    top: 8px;
  }

  .menuboard {
    width: 70vw;
  }

}


@media screen and (max-width:640px) {

  body {
    font-size:17px;
    line-height:2.2;
  }

  .brNar {
    display: block;
  }

  header {
    min-height: initial;
  }

  .surface.logo picture {
    width: 190px;
    left: 15px;
    bottom: 15px;
  }
  .surface.date picture {
    width: 115px;
    left: 6px;
  }
  .surface.copy picture {
    width: 97px;
    transform: translate(8px, -160px);
  }
  header .surface {
    transition: .4s ease;
  }
  .surface.copy {
    transition-delay: .25s;
  }
  .surface.filter-under {
    transition-delay: .2s;
  }
  .surface.filter-middle {
    transition-delay: .15s;
  }
  .surface.dot {
    transition-delay: .1s;
  }
  .surface.overcover {
    transition-delay: .05s;
  }
  .surface.date {
    transition-delay: 0s;
  }
  .surface.logo {
    transition-delay: 0s;
  }
    
  .opener {
    margin: 22px;
    width: 52px;
  }
  .opener hr {
    width: 11px;
    height: 11px;
    margin: 3px;
  }
  .closer {
    width: 55px;
    top: 20px;
    right: 20px;
  }

  .menuboard {
    width:90vw;
    padding:0 0 35px 0;
  }
  .menuboard .sns a {
    width: 35px;
  }

  .modal .closer {
    width:55px;
    top:15px;
    right:15px;
  }
  .modal .block .frame {
    width:90%;
    top:100px;
  }
  .modal .block picture {
    height:auto ;
  }
  .myField .swiper-button-next,
  .myField .swiper-button-prev {
    width:25px;
    top:55px;
  }
  .myField .swiper-button-next {
    left:75px;
    right:initial;
  }
  .myField .swiper-button-prev {
    left:25px;
  }

  footer {
    flex-direction: column;
    justify-content: center;
    padding: 200px 0 275px;
  }
  footer .copyright {
    margin: 25px 0 0 0;
    font-size: 100%;
  }

  .frame,footer {
    width: calc(100% - 50px);
  }

  .sns a {
    width: 38px;
  }
  .sns > a + a {
    margin: 0 0 0 10px;
  }

  .basic {
    justify-content: center;
  }
  .basic i {
    font-size: 21vw;
    left: 50%;
    transform: translate(-50%,-90%);
  }
  .basic b {
    font-size: 200%;
  }

  .square {
    font-size: 145%;
  }
  .square hr {
    width: 125px;
    height: 125px;
  }
  .square i small {
    margin: 0 0 15px 0;
    font-size: 65%;
  }

  .deco {
    width: calc(100% + 75%);
  }

  .eventday {
    line-height: 1.2;
  }
  .eventday .date i {
    font-size: 250%;
  }
  .eventday .date b {
    font-size: 240%;
  }
  .place a {
    padding: 11px 0;
  }
  .place i {
    width: 20px;
  }
  .place b {
    margin: 3px 0 0 9px;
  }

  .generic h2 {
    margin: 0 0 30px 0;
    font-size: 150%;
  }
  .generic h2 hr {
    width: 15px;
    height: 15px;
  }
  .generic * * hr {
    margin: 0 8px 0 2px;
  }
  .generic li hr {
    top: 6px;
  }
  
  .note dd {
    margin: 3px 0 0 0;
    font-size: 85%;
  }
  .note dd p + p {
    margin: 5px 0 0 0;
  }

  .note li {
    font-size: 85%;
  }


}

.comtemporary {
  display: none;
  height: 0;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}
