@charset "utf-8";

/*--FONT--*/
.fs-jp-m {
  font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}
.fs-jp-b {
  font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}
.fs-en {
  font-family: "modesto-open-inline-fill", sans-serif;
  font-weight: 400;
  font-style: normal;
}


/*--SP--*/
@media only screen and (max-width: 767px) {
.sp {
  display: block;
}
.pc {
  display: none;
}

html {
  font-size: 62.5%;
}

body {
  width: 100vw;
  height: 100vh;
  background: #ffffff;
}

img {
  width: 100%;
}

/*--Logo--*/
#logo {
  width: 50px;
  position: fixed;
  top: 30px;
  left: 20px;
  z-index: 5;
  cursor: pointer;
  user-select: none;
  mix-blend-mode: difference;
}

/*--Hamburger Menu--*/
#overlay-button {
  padding: 20px 10px;
  position: fixed;
  top: 15px;
  right: 10px;
  z-index: 5;
  cursor: pointer;
  user-select: none;
  mix-blend-mode: difference;
}
#overlay-button span {
  height: 2px;
  width: 30px;
  background: #ffffff;
  position: relative;
  display: block;
  transition: all .2s ease-in-out;
}
#overlay-button span:before {
  top: -10px;
  visibility: visible;
}
#overlay-button span:after {
  top: 10px;
}
#overlay-button span:before, 
#overlay-button span:after {
  height: 2px;
  width: 30px;
  background: #ffffff;
  position: absolute;
  content: "";
  transition: all .2s ease-in-out;
}
#overlay-button:hover span, 
#overlay-button:hover span:before, 
#overlay-button:hover span:after {
  background: #ffffff;
}
input[type=checkbox] {
  display: none; 
}
input[type=checkbox]:checked ~ #overlay {
  visibility: visible; 
}
input[type=checkbox]:checked ~ #overlay-button:hover span,
input[type=checkbox]:checked ~ #overlay-button span {
  background: transparent;
}
input[type=checkbox]:checked ~ #overlay-button span:before {
  transform: rotate(45deg) translate(7px, 7px);
}
input[type=checkbox]:checked ~ #overlay-button span:after {
  transform: rotate(-45deg) translate(7px, -7px);
}
#overlay {
  height: 100vh;
  width: 100vw;
  background: rgba(0,0,0,0.8);
  visibility: hidden;
  position: fixed;
  z-index: 2;
  text-align: center;
}
#overlay ul {
  margin-top: 200px;
  text-align: left;
  display: inline-block;
}
#overlay ul li {
  padding: 5px 0;
  font-size: 1.6rem;
  color: #ffffff;
}
#overlay ul li a {
  font-size: 1.6rem;
  color: #ffffff;
  text-decoration: none;
}
#overlay ul li a:hover {
  text-decoration: underline;
}

/*--Key Visual--*/
#kv {
  width: 100vw;
  height: 100svh;
  position: relative;
  overflow: hidden;
}

#kv .title {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10;
  text-align: center;
}
#kv .title h1 {
  margin-bottom: 60px;
  font-size: 2rem;
  line-height: 2;
  color: #ffffff;
}
#kv .title p {
  font-size: 1.4rem;
  line-height: 2;
  color: #ffffff;
}

#kv .slide-txt{
  opacity: 0;
  animation: slideTxt 2s ease forwards;
}
@keyframes slideTxt {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
#kv .txt1 {animation-delay: 1s;}
#kv .txt2 {animation-delay: 2s;}
#kv .txt3 {animation-delay: 3s;}

#kv .swiper-slide img {
  height: 100svh;
  width: 100%;
  object-fit: cover;
}
#kv .swiper-slide-active .swiper-img,
#kv .swiper-slide-duplicate-active .swiper-img,
#kv .swiper-slide-prev .swiper-img {
  animation: fadeZoom 5s linear 0s normal both;
}
@keyframes fadeZoom {
  0% {
    transform: scale(2);
  }
  100% {
    transform: scale(1);
  }
}

/*--Introduction--*/
#intro {
  margin: 0 30px;
  padding: 60px 0;
  text-align: center;
  border-bottom: #eeeeee 1px solid;
}
#intro p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: left;
  display: inline-block;
}
#intro p span {
  margin-top: 10px;
  font-size: 1.6rem;
  color: #B7251D;
  display: block;
}

/*--Lead--*/
#lead {
  width: calc(100% - 120px);
  margin: 0 auto;
  padding: 60px 0;
}
#lead p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

/*--Menu--*/
#menu {
  width: calc(100% - 120px);
  margin: 0 auto 120px;
  text-align: center;
}
#menu h2 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}
#menu ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

/*--Catalog01--*/
#catalog01 .main2 {
  width: 100%;
  margin: 0 auto;
  position: relative;
}
#catalog01 .main-img1 {
  position: absolute;
  top: 0;
  left: 0;
}

#catalog01 .catalog-txt {
  width: calc(100% - 60px);
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#catalog01 .catalog-txt h2 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #E64D35;
}
#catalog01 .catalog-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#item01-men, 
#item01-women {
  width: 100%;
  overflow: hidden;
  text-align: center;
}
#item01-men {
  margin: 0 auto 60px;
}
#item01-women {
  margin: 0 auto 120px;
}
#item01-men h3, 
#item01-women h3 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}
#item01-men .swiper, 
#item01-women .swiper {
  width: calc(100% - 60px);
}
#item01-men .slide-img, 
#item01-women .slide-img {
  padding-top: 120%;
}
#item01-men .slide-txt, 
#item01-women .slide-txt {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: justify;
  padding: 20px 0;
}
#item01-men .credit, 
#item01-women .credit {
  margin-bottom: 10px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
#item01-men .name, 
#item01-women .name {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: left;
}
#item01-men .btn, 
#item01-men .btn a, 
#item01-women .btn, 
#item01-women .btn a {
  font-size: 1.4rem;
  line-height: 1.6;
  color: #E64D35;
  text-decoration: underline;
}
#item01-men .thumb-wrapper, 
#item01-women .thumb-wrapper {
  width: calc(100% - 10px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
#item01-men .thumb-img, 
#item01-women .thumb-img {
  padding-top: 110%;
  cursor: pointer;
}
#item01-men .slide-img,
#item01-men .thumb-img, 
#item01-women .slide-img,
#item01-women .thumb-img {
  position: relative;
  overflow: hidden;
}
#item01-men .slide-img img,
#item01-men .thumb-img img, 
#item01-women .slide-img img,
#item01-women .thumb-img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
  
/*--Catalog02--*/
#catalog02 .main2 {
  width: 100%;
  margin: 0 auto;
  position: relative;
}
#catalog02 .main-img1 {
  position: absolute;
  top: 0;
  left: 0;
}

#catalog02 .catalog-txt {
  width: calc(100% - 60px);
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#catalog02 .catalog-txt h2 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #2D558D;
}
#catalog02 .catalog-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#item02 {
  width: calc(100% - 60px);
  margin: 0 auto 120px;
  text-align: center;
}
#item02 h3 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}
#item02 .random-box {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 5px;
}
#item02 .item-box {
  position: relative;
  cursor: pointer;
}
#item02 .item-box .txt-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.8);
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: all 0.2s ease;
}
#item02 .item-box p, 
#item02 .item-box p a {
  font-size: 1rem;
  line-height: 1.4;
  color: #ffffff;
}
#item02 .item-box:hover .txt-bg {
  opacity: 1;
}

/*--Catalog03--*/
#catalog03 .main2 {
  width: 100%;
  margin: 0 auto;
  position: relative;
}
#catalog03 .main-img1 {
  position: absolute;
  top: 0;
  left: 0;
}

#catalog03 .catalog-txt {
  width: calc(100% - 60px);
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#catalog03 .catalog-txt h2 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #E0A755;
}
#catalog03 .catalog-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#item03-men, 
#item03-women {
  width: calc(100% - 60px);
  text-align: center;
}
#item03-men {
  margin: 0 auto 60px;
}
#item03-women {
  margin: 0 auto 120px;
}
#item03-men h3, 
#item03-women h3 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}
#item03-men .item-box, 
#item03-women .item-box {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

/*-Modal-*/
.modaal-close {
  width: 30px;
  height: 30px;
  color: #000000;
}
.modaal-close:focus:after,.modaal-close:focus:before,.modaal-close:hover:after,.modaal-close:hover:before {
  background: #000000
}
.modaal-close:after, .modaal-close:before {
  width: 2px;
  height: 30px;
  top: 0;
  left: 14px;
  background: #000000;
}
.modaal-inner-wrapper {
  padding: 0 30px;
}
.modaal-container {
  box-shadow: none;
}
.modaal-content-container {
  padding: 70px 0 30px;
}
.modaal-content-container h4 {
  width: calc(100% - 30px);
  margin: 20px auto;
  font-size: 1.2rem;
  line-height: 1.8;
  color: #000000;
  text-align: left;
}
.modaal-content-container .caption {
  width: calc(100% - 30px);
  margin: 20px auto;
  font-size: 1.2rem;
  line-height: 2;
  color: #000000;
  text-align: justify;
}
.modaal-content-container .credit {
  width: calc(100% - 30px);
  margin: 10px auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modaal-content-container .name, 
.modaal-content-container .name {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: left;
}
.modaal-content-container .btn, 
.modaal-content-container .btn a {
  font-size: 1.4rem;
  line-height: 1.6;
  color: #ffffff;
}
.modaal-content-container .btn a {
  padding: 3px 10px;
  background: #E0A755;
  border-radius: 20px;
}

/*--Catalog04--*/
#catalog04 .main2 {
  width: 100%;
  margin: 0 auto;
  position: relative;
}
#catalog04 .main-img1 {
  position: absolute;
  top: 0;
  left: 0;
}

#catalog04 .catalog-txt {
  width: calc(100% - 60px);
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#catalog04 .catalog-txt h2 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #108D63;
}
#catalog04 .catalog-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#item04 {
  width: 100%;
  margin: 0 auto 120px;
  text-align: center;
}
#item04 h3 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}

#item04 .item-box {
	display: flex;
	justify-content: space-between;
	position: relative;
}
#item04 .main-wrapper { 
  width: 65.11%;
	height: 100vh;
	display: flex;
	align-items: center;
	position: sticky;
	position: -webkit-sticky;
	top:0;
}
#item04 .main-wrapper > div {
	height: 100vh;
  background: #ffffff;
	display: none;
	position: absolute;
	top: 0;
	bottom: 0;
}
#item04 .main-wrapper > div:first-child,
#item04 .main-wrapper > div.active {
	display: block;
}
#item04 .main-wrapper > div.none, 
#item04 .thumb-wrapper > div.none {
  display: none;
}
#item04 .main-wrapper .number {
  width: calc(100% - 40px);
  margin: -70px auto -15px;
  font-size: 7rem;
  line-height: 1.8;
  color: #118D63;
  text-align: right;
}
#item04 .main-wrapper h4 {
  width: calc(100% - 40px);
  margin: 0 auto 20px;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: left;
}
#item04 .main-wrapper .caption {
  width: calc(100% - 40px);
  margin: 0 auto 20px;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: justify;
}
#item04 .main-wrapper .credit {
  width: calc(100% - 40px);
  margin: 10px auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
#item04 .main-wrapper .name, 
#item04 .main-wrapper .name {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: left;
}
#item04 .main-wrapper .btn, 
#item04 .main-wrapper .btn a {
  font-size: 1.4rem;
  line-height: 1.6;
  color: #108D63;
  text-decoration: underline;
}
#item04 .thumb-wrapper {
	width: 30.23%;
  position: relative;
}
#item04 .thumb-wrapper div img {
  margin-bottom: 20px;
}
#item04 .thumb-wrapper div:nth-of-type(12) img {
  margin-bottom: 100vh;
}
#item04 .thumb-wrapper .scroll {
  width: 25px;
  margin: 0 10px 0 auto;
  position: sticky;
  position: -webkit-sticky;
  bottom: 10px;
  animation: floating-y 1s ease-in-out infinite alternate-reverse;
}
@keyframes floating-y {
  0% {
    transform: translateY(-10%);
  }
  100% {
    transform: translateY(10%);
  }
}

/*--View All--*/
#all {
  padding: 30px 0 120px;
  background: #F8F1E8;
  text-align: center;
}
#all h2 {
  margin-bottom: 20px;
  font-size: 1.8rem;
  line-height: 1.8;
  color: #000000;
}

#all .tab-container {
  width: calc(100% - 60px);
  margin: 0 auto 40px;
  border-radius: 20px;
  background-color: #EFEFEF;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
#all .tab {
  padding: 10px;
  border-radius: 20px;
  background-color: #EFEFEF;
  color: #999999;
  font-size: 1.4rem;
  text-align: center;
  cursor: pointer;
}
#all .tab.active {
  background-color: #E64D35;
  color: #ffffff;
}
#all .content-container {
  width: calc(100% - 60px);
  margin: 0 auto 60px;
}
#all .content {
  display: none;
}
#all .content.show {
  display: block;
}
#all .random-box {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 5px;
}
#all .item-box {
  position: relative;
  cursor: pointer;
}
#all .item-box .txt-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.8);
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: all 0.2s ease;
}
#all .item-box p, 
#all .item-box p a {
  font-size: 1rem;
  line-height: 1.4;
  color: #ffffff;
}
#all .item-box:hover .txt-bg {
  opacity: 1;
}

#all .other {
  width: calc(100% - 60px);
  margin: 0 auto;
}
#all .other h3 {
  margin-bottom: 30px;
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
}
#all .other ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
#all .other li a {
  width: 100%;
  padding: 10px;
  display: block;
  background: #E64D35;
  border-radius: 20px;
  font-size: 1.4rem;
  color: #ffffff;
}

/*--Information--*/
#info .info-txt {
  width: calc(100% - 60px);
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#info .info-txt h2 {
  margin-bottom: 20px;
  font-size: 1.8rem;
  line-height: 1.8;
  color: #000000;
}
#info .info-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#info .service-box {
  width: calc(100% - 60px);
  margin: 0 auto 60px;
  text-align: center;
}
#info .service-box:last-child {
  margin: 0 auto 120px;
}
#info .title {
  margin-bottom: 20px;
}
#info .title h3 {
  font-size: 1.8rem;
  line-height: 1.8;
  color: #000000;
}
#info .number {
  display: flex;
  justify-content: center;
  align-items: center;
}
#info .number .line {
  width: 70px;
}
#info .number p {
  width: 100px;
  font-size: 3rem;
  line-height: 1.8;
  color: #000000;
}
#info .img-box {
  margin-bottom: 20px;
}
#info .txt-box h4 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.6;
  color: #000000;
}
#info .txt-box p {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: justify;
}
#info .txt-box p a {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-decoration: underline;
}

/*--Footer--*/
#footer {
  padding: 40px 30px;
  background: #eeeeee;
  text-align: center;
}

#footer .staff {
  margin-bottom: 60px;
}
#footer .staff h2 {
  margin-bottom: 40px;
  font-size: 1.8rem;
  line-height: 1.6;
  color: #000000;
}
#footer .staff p {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
}

#footer .social {
  margin-bottom: 60px;
}
#footer .social h2 {
  margin-bottom: 40px;
  font-size: 1.8rem;
  line-height: 1.6;
  color: #000000;
}
#footer .social ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
}
#footer .social li {
  width: 30px;
}

#footer .copy p {
  font-size: 1.4rem;
  line-height: 1.6;
  color: #000000;
}

}


/*--PC--*/
@media only screen and (min-width: 768px) {
.sp {
  display: none;
}
.pc {
  display: block;
}

html {
  font-size: 62.5%;
}

body {
  width: 100vw;
  height: 100vh;
  background: #ffffff;
}

img {
  width: 100%;
}

/*--Logo--*/
#logo {
  width: 50px;
  position: fixed;
  top: 30px;
  left: 20px;
  z-index: 5;
  cursor: pointer;
  user-select: none;
  mix-blend-mode: difference;
}

/*--Hamburger Menu--*/
#overlay-button {
  padding: 20px 10px;
  position: fixed;
  top: 15px;
  right: 10px;
  z-index: 5;
  cursor: pointer;
  user-select: none;
  mix-blend-mode: difference;
}
#overlay-button span {
  height: 2px;
  width: 30px;
  background: #ffffff;
  position: relative;
  display: block;
  transition: all .2s ease-in-out;
}
#overlay-button span:before {
  top: -10px;
  visibility: visible;
}
#overlay-button span:after {
  top: 10px;
}
#overlay-button span:before, 
#overlay-button span:after {
  height: 2px;
  width: 30px;
  background: #ffffff;
  position: absolute;
  content: "";
  transition: all .2s ease-in-out;
}
#overlay-button:hover span, 
#overlay-button:hover span:before, 
#overlay-button:hover span:after {
  background: #ffffff;
}
input[type=checkbox] {
  display: none; 
}
input[type=checkbox]:checked ~ #overlay {
  visibility: visible; 
}
input[type=checkbox]:checked ~ #overlay-button:hover span,
input[type=checkbox]:checked ~ #overlay-button span {
  background: transparent;
}
input[type=checkbox]:checked ~ #overlay-button span:before {
  transform: rotate(45deg) translate(7px, 7px);
}
input[type=checkbox]:checked ~ #overlay-button span:after {
  transform: rotate(-45deg) translate(7px, -7px);
}
#overlay {
  height: 100vh;
  width: 100vw;
  background: rgba(0,0,0,0.8);
  visibility: hidden;
  position: fixed;
  z-index: 2;
  text-align: center;
}
#overlay ul {
  margin-top: 200px;
  text-align: left;
  display: inline-block;
}
#overlay ul li {
  padding: 5px 0;
  font-size: 1.6rem;
  color: #ffffff;
}
#overlay ul li a {
  font-size: 1.6rem;
  color: #ffffff;
  text-decoration: none;
}
#overlay ul li a:hover {
  text-decoration: underline;
}

/*--Key Visual--*/
#kv {
  width: 100vw;
  height: 100svh;
  position: relative;
  overflow: hidden;
}

#kv .title {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10;
  text-align: center;
}
#kv .title h1 {
  margin-bottom: 80px;
  font-size: 2.2rem;
  line-height: 2;
  color: #ffffff;
}
#kv .title p {
  font-size: 1.6rem;
  line-height: 2;
  color: #ffffff;
}

#kv .slide-txt{
  opacity: 0;
  animation: slideTxt 2s ease forwards;
}
@keyframes slideTxt {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
#kv .txt1 {animation-delay: 1s;}
#kv .txt2 {animation-delay: 2s;}
#kv .txt3 {animation-delay: 3s;}

#kv .swiper-slide img {
  height: 100svh;
  width: 100%;
  object-fit: cover;
}
#kv .swiper-slide-active .swiper-img,
#kv .swiper-slide-duplicate-active .swiper-img,
#kv .swiper-slide-prev .swiper-img {
  animation: fadeZoom 5s linear 0s normal both;
}
@keyframes fadeZoom {
  0% {
    transform: scale(2);
  }
  100% {
    transform: scale(1);
  }
}

/*--Introduction--*/
#intro {
  margin: 0 60px;
  padding: 60px 0;
  text-align: center;
  border-bottom: #eeeeee 1px solid;
}
#intro p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: left;
  display: inline-block;
}
#intro p span {
  margin-top: 10px;
  font-size: 1.6rem;
  color: #B7251D;
  display: block;
}

/*--Lead--*/
#lead {
  width: 600px;
  margin: 0 auto;
  padding: 60px 0;
}
#lead p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

/*--Menu--*/
#menu {
  width: 600px;
  margin: 0 auto 120px;
  text-align: center;
}
#menu h2 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}
#menu ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

/*--Catalog01--*/
#catalog01 .main2 {
  width: 600px;
  margin: 0 auto;
  position: relative;
}
#catalog01 .main-img1 {
  position: absolute;
  top: 0;
  left: 0;
}

#catalog01 .catalog-txt {
  width: 540px;
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#catalog01 .catalog-txt h2 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #E64D35;
}
#catalog01 .catalog-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#item01-men, 
#item01-women {
  width: calc(100% - 60px);
  overflow: hidden;
  text-align: center;
}
#item01-men {
  margin: 0 auto 60px;
}
#item01-women {
  margin: 0 auto 120px;
}
#item01-men h3, 
#item01-women h3 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}
#item01-men .swiper, 
#item01-women .swiper {
  width: 500px;
}
#item01-men .slide-img, 
#item01-women .slide-img {
  padding-top: 120%;
}
#item01-men .slide-txt, 
#item01-women .slide-txt {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: justify;
  padding: 20px;
}
#item01-men .credit, 
#item01-women .credit {
  margin: 0 20px 10px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
#item01-men .name, 
#item01-women .name {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: left;
}
#item01-men .btn, 
#item01-men .btn a, 
#item01-women .btn, 
#item01-women .btn a {
  font-size: 1.4rem;
  line-height: 1.6;
  color: #E64D35;
  text-decoration: underline;
}
#item01-men .thumb-wrapper, 
#item01-women .thumb-wrapper {
  width: 900px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(8, 1fr);
}
#item01-men .thumb-img, 
#item01-women .thumb-img {
  padding-top: 110%;
  cursor: pointer;
}
#item01-men .slide-img,
#item01-men .thumb-img, 
#item01-women .slide-img,
#item01-women .thumb-img {
  position: relative;
  overflow: hidden;
}
#item01-men .slide-img img,
#item01-men .thumb-img img, 
#item01-women .slide-img img,
#item01-women .thumb-img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
  
/*--Catalog02--*/
#catalog02 .main2 {
  width: 600px;
  margin: 0 auto;
  position: relative;
}
#catalog02 .main-img1 {
  position: absolute;
  top: 0;
  left: 0;
}

#catalog02 .catalog-txt {
  width: 540px;
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#catalog02 .catalog-txt h2 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #2D558D;
}
#catalog02 .catalog-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#item02 {
  width: 700px;
  margin: 0 auto 120px;
  text-align: center;
}
#item02 h3 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}
#item02 .random-box {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 5px;
}
#item02 .item-box {
  position: relative;
  cursor: pointer;
}
#item02 .item-box .txt-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.8);
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: all 0.2s ease;
}
#item02 .item-box p, 
#item02 .item-box p a {
  font-size: 1rem;
  line-height: 1.4;
  color: #ffffff;
}
#item02 .item-box:hover .txt-bg {
  opacity: 1;
}

/*--Catalog03--*/
#catalog03 .main2 {
  width: 600px;
  margin: 0 auto;
  position: relative;
}
#catalog03 .main-img1 {
  position: absolute;
  top: 0;
  left: 0;
}

#catalog03 .catalog-txt {
  width: 540px;
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#catalog03 .catalog-txt h2 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #E0A755;
}
#catalog03 .catalog-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#item03-men, 
#item03-women {
  width: 700px;
  text-align: center;
}
#item03-men {
  margin: 0 auto 60px;
}
#item03-women {
  margin: 0 auto 120px;
}
#item03-men h3, 
#item03-women h3 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}
#item03-men .item-box, 
#item03-women .item-box {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

/*-Modal-*/
.modaal-close {
  width: 30px;
  height: 30px;
  color: #000000;
}
.modaal-close:focus:after,.modaal-close:focus:before,.modaal-close:hover:after,.modaal-close:hover:before {
  background: #000000
}
.modaal-close:after, .modaal-close:before {
  width: 2px;
  height: 30px;
  top: 0;
  left: 14px;
  background: #000000;
}
.modaal-inner-wrapper {
  padding: 0 30px;
}
.modaal-container {
  width: 400px;
  box-shadow: none;
}
.modaal-content-container {
  width: 400px;
  padding: 70px 0 30px;
}
.modaal-content-container h4 {
  width: calc(100% - 30px);
  margin: 20px auto;
  font-size: 1.2rem;
  line-height: 1.8;
  color: #000000;
  text-align: left;
}
.modaal-content-container .caption {
  width: calc(100% - 30px);
  margin: 20px auto;
  font-size: 1.2rem;
  line-height: 2;
  color: #000000;
  text-align: justify;
}
.modaal-content-container .credit {
  width: calc(100% - 30px);
  margin: 10px auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modaal-content-container .name, 
.modaal-content-container .name {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: left;
}
.modaal-content-container .btn, 
.modaal-content-container .btn a {
  font-size: 1.4rem;
  line-height: 1.6;
  color: #ffffff;
}
.modaal-content-container .btn a {
  padding: 3px 10px;
  background: #E0A755;
  border-radius: 20px;
}

/*--Catalog04--*/
#catalog04 .main2 {
  width: 600px;
  margin: 0 auto;
  position: relative;
}
#catalog04 .main-img1 {
  position: absolute;
  top: 0;
  left: 0;
}

#catalog04 .catalog-txt {
  width: 540px;
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#catalog04 .catalog-txt h2 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #108D63;
}
#catalog04 .catalog-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#item04 {
  width: 100%;
  margin: 0 auto 120px;
  text-align: center;
}
#item04 h3 {
  margin-bottom: 30px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}

#item04 .item-box {
  width: 500px;
  margin: 0 auto;
	display: flex;
	justify-content: space-between;
	position: relative;
}
#item04 .main-wrapper { 
  width: 65.11%;
	height: 100vh;
	display: flex;
	align-items: center;
	position: sticky;
	position: -webkit-sticky;
	top:0;
}
#item04 .main-wrapper > div {
	height: 100vh;
  background: #ffffff;
	display: none;
	position: absolute;
	top: 0;
	bottom: 0;
}
#item04 .main-wrapper > div:first-child,
#item04 .main-wrapper > div.active {
	display: block;
}
#item04 .main-wrapper > div.none, 
#item04 .thumb-wrapper > div.none {
  display: none;
}
#item04 .main-wrapper .number {
  width: calc(100% - 40px);
  margin: -70px auto -30px;
  font-size: 7rem;
  line-height: 1.8;
  color: #118D63;
  text-align: right;
}
#item04 .main-wrapper h4 {
  width: calc(100% - 40px);
  margin: 0 auto 20px;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: left;
}
#item04 .main-wrapper .caption {
  width: calc(100% - 40px);
  margin: 0 auto 20px;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: justify;
}
#item04 .main-wrapper .credit {
  width: calc(100% - 40px);
  margin: 10px auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
#item04 .main-wrapper .name, 
#item04 .main-wrapper .name {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: left;
}
#item04 .main-wrapper .btn, 
#item04 .main-wrapper .btn a {
  font-size: 1.4rem;
  line-height: 1.6;
  color: #108D63;
  text-decoration: underline;
}
#item04 .thumb-wrapper {
	width: 30.23%;
  position: relative;
}
#item04 .thumb-wrapper div img {
  margin-bottom: 20px;
}
#item04 .thumb-wrapper div:nth-of-type(12) img {
  margin-bottom: 100vh;
}
#item04 .thumb-wrapper .scroll {
  width: 25px;
  margin: 0 10px 0 auto;
  position: sticky;
  position: -webkit-sticky;
  bottom: 10px;
  animation: floating-y 1s ease-in-out infinite alternate-reverse;
}
@keyframes floating-y {
  0% {
    transform: translateY(-10%);
  }
  100% {
    transform: translateY(10%);
  }
}

/*--View All--*/
#all {
  padding: 30px 0 120px;
  background: #F8F1E8;
  text-align: center;
}
#all h2 {
  margin-bottom: 20px;
  font-size: 1.8rem;
  line-height: 1.8;
  color: #000000;
}

#all .tab-container {
  width: 600px;
  margin: 0 auto 40px;
  border-radius: 20px;
  background-color: #EFEFEF;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
#all .tab {
  padding: 10px;
  border-radius: 20px;
  background-color: #EFEFEF;
  color: #999999;
  font-size: 1.4rem;
  text-align: center;
  cursor: pointer;
}
#all .tab.active {
  background-color: #E64D35;
  color: #ffffff;
}
#all .content-container {
  width: 700px;
  margin: 0 auto 60px;
}
#all .content {
  display: none;
}
#all .content.show {
  display: block;
}
#all .random-box {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 5px;
}
#all .item-box {
  position: relative;
  cursor: pointer;
}
#all .item-box .txt-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.8);
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: all 0.2s ease;
}
#all .item-box p, 
#all .item-box p a {
  font-size: 1rem;
  line-height: 1.4;
  color: #ffffff;
}
#all .item-box:hover .txt-bg {
  opacity: 1;
}

#all .other {
  width: 600px;
  margin: 0 auto;
}
#all .other h3 {
  margin-bottom: 30px;
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
}
#all .other ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
#all .other li a {
  width: 100%;
  padding: 10px;
  display: block;
  background: #E64D35;
  border-radius: 20px;
  font-size: 1.4rem;
  color: #ffffff;
}

/*--Information--*/
#info .info-main {
  width: 600px;
  margin: 120px auto 0;
}
#info .info-txt {
  width: 540px;
  margin: 0 auto;
  padding: 40px 0 60px;
  text-align: center;
}
#info .info-txt h2 {
  margin-bottom: 20px;
  font-size: 1.8rem;
  line-height: 1.8;
  color: #000000;
}
#info .info-txt p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #000000;
  text-align: justify;
}

#info .service-box {
  width: 600px;
  margin: 0 auto 60px;
  text-align: center;
}
#info .service-box:last-child {
  margin: 0 auto 120px;
}
#info .title {
  margin-bottom: 20px;
}
#info .title h3 {
  font-size: 1.8rem;
  line-height: 1.8;
  color: #000000;
}
#info .number {
  display: flex;
  justify-content: center;
  align-items: center;
}
#info .number .line {
  width: 70px;
}
#info .number p {
  width: 100px;
  font-size: 3rem;
  line-height: 1.8;
  color: #000000;
}
#info .service {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  place-items: center;
}
#info .service.noimg {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
}
#info .service.noimg .txt-box {
  width: 540px;
}
#info .txt-box h4 {
  margin-bottom: 20px;
  font-size: 1.6rem;
  line-height: 1.6;
  color: #000000;
}
#info .txt-box p {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-align: justify;
}
#info .txt-box p a {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
  text-decoration: underline;
}

/*--Footer--*/
#footer {
  padding: 40px 30px;
  background: #eeeeee;
  text-align: center;
}

#footer .staff {
  margin-bottom: 60px;
}
#footer .staff h2 {
  margin-bottom: 40px;
  font-size: 1.8rem;
  line-height: 1.6;
  color: #000000;
}
#footer .staff p {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #000000;
}

#footer .social {
  margin-bottom: 60px;
}
#footer .social h2 {
  margin-bottom: 40px;
  font-size: 1.8rem;
  line-height: 1.6;
  color: #000000;
}
#footer .social ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
}
#footer .social li {
  width: 30px;
}

#footer .copy p {
  font-size: 1.4rem;
  line-height: 1.6;
  color: #000000;
}

}


/*--アニメーション--*/
.fadeIn {
  opacity: 0;
  transform: translate(0, 30px);
  transition: 3s;
}
.fadeIn.active {
  opacity: 1;
  transform: translate(0, 0);
}

.main-img1 {
  opacity: 1;
}
.main-img1.active {
  animation: fadeOut 3s linear 1.5s normal forwards;
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}