@charset "UTF-8";
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/NotoSansJP-R-Subset.woff2") format("woff2"), url("../fonts/NotoSansJP-R-Subset.woff") format("woff");
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/NotoSansJP-B-Subset.woff2") format("woff2"), url("../fonts/NotoSansJP-B-Subset.woff") format("woff");
}
@font-face {
  font-family: "Noto Serif JP";
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/NotoSerifJP-Black-Subset.woff2") format("woff2"), url("../fonts/NotoSerifJP-Black-Subset.woff") format("woff");
}
/*****************************************************
* Base
*****************************************************/
:root {
  --theme-color: #005cb9;
}

* {
  box-sizing: border-box;
}

html {
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  font-size: 62.5%;
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
  color: #1a1a1a;
  scroll-padding: 6em;
  overflow-y: scroll;
}

body {
  position: relative;
  width: 100%;
  height: 100%;
  font-size: 1.6em;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", 游ゴシック体, YuGothic, 游ゴシック, "Yu Gothic", NotoSansCJKjp, メイリオ, sans-serif;
  font-weight: 400;
  font-optical-sizing: auto;
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}

.sans {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", 游ゴシック体, YuGothic, 游ゴシック, "Yu Gothic", NotoSansCJKjp, メイリオ, sans-serif;
}

.serif {
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", 游明朝体, YuMincho, 游明朝, "Yu Mincho", "MS PMincho", "Times New Roman", serif;
}

/*****************************************************
* Contents
*****************************************************/
main {
  width: 100%;
  padding-top: 60px;
  position: relative;
  overflow: hidden;
  margin: 0 auto;
  flex: 1 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  transition: filter 0.3s, opacity 0.3s;
}
main > .content {
  width: 100%;
  padding: 2em;
  margin: 0 auto;
  position: relative;
}
main > .content h1 {
  text-align: center;
  font-size: 2.5em;
  color: var(--theme-color);
  line-height: 1;
  font-weight: 900;
  font-family: "Noto Serif JP", "Hiragino Mincho ProN", 游明朝体, YuMincho, 游明朝, "Yu Mincho", "MS PMincho", "Times New Roman", serif;
  letter-spacing: 0.25em;
  padding-left: 0.25em;
}
@media screen and (max-width: 768px) {
  main > .content h1 {
    font-size: 2em;
  }
}
main > .content h2 {
  text-align: center;
  font-size: 2.1875em;
  color: var(--theme-color);
  font-weight: bold;
}
main > .content h3 {
  text-align: center;
  font-size: 2em;
  color: var(--theme-color);
  font-weight: bold;
}

.siteFooter {
  width: 100%;
  margin: 0 auto;
  text-align: center;
  padding: 1em;
  background-color: white;
  flex-shrink: 0;
  position: relative;
}
.siteFooter > p {
  font-size: 0.75em;
}

/*****************************************************
* Utility
*****************************************************/
.ripples {
  background-color: #d4edfa;
}
.ripples::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #d4edfa;
  background-image: url(../img/back_l.png), url(../img/back_r.png);
  background-position: top left, top right;
  background-size: auto min(120vw, 900px);
  background-repeat: repeat-y, repeat-y;
  overflow-y: hidden;
}

.inproduction {
  font-size: 2.5em;
  text-align: center;
  white-space: nowrap;
  position: relative;
}

.rippleWrapper {
  display: flex;
  width: 100%;
  max-width: 40vw;
  flex: 1;
  position: relative;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
}
.rippleWrapper::before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  content: "";
  background-image: url(../img/titlebgi.png);
  background-size: cover;
  width: 500px;
  padding-top: 500px;
}
.rippleWrapper p {
  position: relative;
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 100%;
  }
}
@keyframes expandX {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}
@keyframes scaleX {
  from {
    transform: scaleX(0%);
  }
  to {
    transform: scaleX(100%);
  }
}
@keyframes zoomOut {
  from {
    transform: scale(250%);
    opacity: 0;
  }
  to {
    transform: scale(100%);
    opacity: 1;
  }
}
@keyframes irisOut {
  0% {
    opacity: 0;
    clip-path: circle(0% at 50% 50%);
  }
  50% {
    opacity: 1;
    clip-path: circle(50% at 50% 50%);
  }
  100% {
    opacity: 1;
    clip-path: circle(100% at 50% 50%);
  }
}
/*****************************************************
* Index
*****************************************************/
.index {
  background-color: #ebf5ec;
}

.landing {
  position: relative;
  height: -moz-fit-content;
  height: fit-content;
}
.landing > .track {
  width: 100%;
  display: flex;
  white-space: nowrap;
}
.landing > .track > .item {
  width: 14.28571429%;
  background: #ccc;
  flex-shrink: 0;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 1200px) {
  .landing > .track > .item {
    width: 20%;
  }
}
@media screen and (max-width: 768px) {
  .landing > .track > .item {
    width: 33%;
  }
}
.landing > .track > .item::before {
  content: "";
  display: block;
  padding-top: 100%;
  position: relative;
}
.landing > .track > .item > img {
  position: absolute;
  top: 0;
  left: 0;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.greeting {
  width: 100%;
  font-size: 1.25em;
  text-align: center;
  flex: 1;
  overflow: hidden;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .greeting {
    font-size: 1em;
  }
}
.greeting::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  display: block;
  background-image: url(../img/leaf_t_transparent.png), url(../img/leaf_b_transparent.png), url(../img/left.png), url(../img/right.png);
  background-position: top center, bottom center, left max(-46.666vw, -800px + (100vw - 720px) / 2) center, right max(-46.666vw, -800px + (100vw - 720px) / 2) center;
  background-size: min(100vw, 1200px) auto, min(100vw, 1200px) auto, auto min(66.666vw, 800px), auto min(66.666vw, 800px);
  background-repeat: no-repeat, no-repeat, repeat-y, repeat-y;
}
@media screen and (max-width: 576px) {
  .greeting::before {
    background-image: url(../img/leaf_t_transparent_sp.png), url(../img/leaf_b_transparent_sp.png);
    background-size: 80vw auto, 80vw auto;
    background-position: top center, bottom center;
    background-repeat: repeat-x, repeat-x;
  }
}
.greeting .inner {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
  padding: min(13vw, 156px);
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 576px) {
  .greeting .inner {
    padding: min(13vw, 240px) 1em;
  }
}
.greeting .slogan {
  width: 100%;
  font-size: 3.25em;
  color: var(--theme-color);
  font-weight: bold;
  position: relative;
  padding-bottom: 0.35em;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .greeting .slogan {
    font-size: 2.5em;
  }
}
.greeting .slogan > img {
  width: 7em;
  max-width: 100%;
  height: auto;
}
.greeting .slogan::after {
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  width: 110%;
  height: 0.1em;
  background: linear-gradient(to left, transparent, #eb7197 20%, #eb7197 80%, transparent 100%);
}
.greeting .message {
  line-height: 2.3;
  margin-top: 1em;
  position: relative;
}
@media screen and (max-width: 1180px) {
  .greeting .message {
    text-align: justify;
  }
  .greeting .message br {
    display: none;
  }
}

/*****************************************************
* Company
*****************************************************/
.company .inner {
  display: flex;
  margin: 0 auto;
  justify-content: center;
  transform: translateX(-1em);
}
@media screen and (max-width: 1024px) {
  .company .inner {
    flex-direction: column;
    width: -moz-fit-content;
    width: fit-content;
    transform: unset;
  }
}
.company .titleWrapper {
  display: flex;
  max-width: 450px;
  flex: 1;
  position: relative;
  justify-content: center;
  align-items: center;
}
.company .titleWrapper::before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  content: "";
  background-image: url(../img/titlebgi.png);
  background-size: cover;
  width: 130%;
  padding-top: 130%;
}
@media screen and (max-width: 1024px) {
  .company .titleWrapper::before {
    display: none;
  }
}
.company .titleWrapper h1 {
  position: relative;
  white-space: nowrap;
}
@media screen and (max-width: 1024px) {
  .company .titleWrapper h1 {
    margin-bottom: 1em;
  }
}
.company dl {
  width: 100%;
  max-width: 500px;
  line-height: 2;
  border-top: solid 1px var(--theme-color);
}
.company dl > div {
  display: flex;
  border-bottom: solid 1px var(--theme-color);
  gap: 2em;
}
.company dl dt {
  width: 5em;
  padding: 0.5em 0;
  -moz-text-align-last: justify;
  text-align-last: justify;
}
@media screen and (max-width: 576px) {
  .company dl dt {
    width: 4em;
  }
}
.company dl dd {
  flex: 1;
  padding: 0.5em 0;
}
.company dl dd > ol > li {
  padding-left: 1em;
  text-indent: -1em;
}
.company dl dd > ol > li::before {
  content: "●";
  font-size: 0.8em;
  padding: 0.1em;
  color: var(--theme-color);
}

/*****************************************************
* business
*****************************************************/
.business .inner {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  max-width: 100%;
  padding: 0 0 4em;
}
@media screen and (max-width: 768px) {
  .business .inner {
    padding: 0 0 2em;
  }
}
.business h1 {
  margin: 1em;
}
.business .oda {
  width: 100%;
  max-width: 800px;
  margin: 4em auto 5em;
}
@media screen and (max-width: 768px) {
  .business .oda {
    font-size: 0.75em;
  }
}
.business .oda img {
  width: 100%;
  height: auto;
}
.business .oda .caption {
  text-align: right;
}
.business ol {
  text-align: center;
  margin-bottom: 3em;
}
.business ol > li {
  margin-bottom: 2em;
}
.business ol > li:not(:last-child):after {
  content: "";
  display: block;
  width: 1em;
  height: 1em;
  border-radius: 0.5em;
  background-color: #7dbde7;
  margin: 2em auto 0;
}
.business ol h2 {
  margin-bottom: 0.25em;
}
@media screen and (max-width: 768px) {
  .business ol h2 {
    font-size: 1.4em;
  }
}
.business ol p {
  line-height: 2.3;
}
@media screen and (max-width: 768px) {
  .business ol p {
    text-align: justify;
  }
  .business ol p br {
    display: none;
  }
}

/*****************************************************
* Product
*****************************************************/
/*****************************************************
* Shop
*****************************************************/
/*****************************************************
* Animation
*****************************************************/
.index .track {
  opacity: 0;
  animation: fadeIn 1s ease-out forwards;
}
.index .greeting::before {
  animation: zoomOut 1s ease-out forwards;
}
.index .slogan {
  opacity: 0;
  animation: fadeIn 1s ease-out forwards;
  animation-delay: 1s;
}
.index .slogan::after {
  width: 0;
  animation: expandX 0.35s ease-out forwards;
  animation-delay: 1.5s;
}
.index .message {
  opacity: 0;
  animation: fadeIn 1s ease-out forwards;
  animation-delay: 2s;
}

.company .titleWrapper {
  opacity: 0;
  animation: fadeIn 0.3s ease-out forwards;
  animation-delay: 0.3s;
}
.company dl {
  transform: scaleX(0%);
  transform-origin: top left;
  animation: scaleX 0.5s ease-in-out forwards;
  animation-delay: 0.3s;
}
.company dl > div > * {
  opacity: 0;
  animation: fadeIn 0.4s ease-out forwards;
  animation-delay: 0.8s;
}

.fadeIn {
  opacity: 0;
  animation: fadeIn 1s ease-out forwards;
}

.fadeItem {
  opacity: 0;
}
.fadeItem.is-visible {
  animation: fadeIn 0.7s ease-out forwards;
  animation-delay: 0.1s;
}

/*****************************************************
* Header
*****************************************************/
.siteHeader {
  display: block;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  width: 100%;
  margin: 0 auto;
  height: 60px;
  z-index: 1000;
  padding: 1em 1.5em;
  border-bottom: solid 1px rgba(176, 176, 176, 0.4666666667);
  background-color: rgba(255, 255, 255, 0.8);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  transition: opacity 1s ease-in, background-color 0.2s linear;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .siteHeader {
    padding: 0.5em;
  }
}
.siteHeader > .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin: 0 auto;
}

.logoWrapper {
  display: flex;
  gap: 0.75em;
  width: -moz-fit-content;
  width: fit-content;
  max-width: 80%;
  height: 24px;
}
@media screen and (max-width: 768px) {
  .logoWrapper {
    margin-left: 0.5em;
  }
}
.logoWrapper > img {
  width: auto;
  height: 100%;
}
@media screen and (max-width: 360px) {
  .logoWrapper > img:last-child {
    display: none;
  }
}

.navigationList {
  display: flex;
  font-size: 14px;
}
@media screen and (max-width: 768px) {
  .navigationList {
    display: block;
    width: -moz-fit-content;
    width: fit-content;
  }
}
.navigationList > li {
  margin: 0 1em;
  text-transform: capitalize;
  position: relative;
}
.navigationList > li::after {
  position: absolute;
  display: block;
  content: "";
  width: 0;
  top: 100%;
  height: 2px;
  left: 50%;
  transform: translateX(-50%);
  transition: width 0.25s ease;
  background-color: var(--theme-color);
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .navigationList > li::after {
    display: none;
  }
}
.navigationList > li:hover, .navigationList > li.active {
  color: var(--theme-color);
}
@media screen and (max-width: 768px) {
  .navigationList > li:hover, .navigationList > li.active {
    color: white;
  }
}
.navigationList > li:hover::after {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .navigationList > li {
    display: block;
    margin-top: 0.5em;
    margin-left: 0;
    padding: 0;
    background-color: var(--theme-color);
    color: white;
    -webkit-backdrop-filter: saturate(150%) blur(20px);
    backdrop-filter: saturate(150%) blur(20px);
    font-size: 1em;
    text-align: left;
    width: -moz-fit-content;
    width: fit-content;
    min-width: 100%;
    transition: transform 0.25s cubic-bezier(0.6, -0.28, 0.74, 0.05);
    transition: transform 0.25s ease;
    font-weight: 400;
  }
  .navigationList > li:nth-child(1) {
    transition-delay: 0s;
  }
  .navigationList > li:nth-child(2) {
    transition-delay: 0.04s;
  }
  .navigationList > li:nth-child(3) {
    transition-delay: 0.08s;
  }
  .navigationList > li:nth-child(4) {
    transition-delay: 0.12s;
  }
  .navigationList > li:nth-child(5) {
    transition-delay: 0.16s;
  }
  .navigationList > li:nth-child(6) {
    transition-delay: 0.2s;
  }
  .navigationList > li > a {
    display: block;
    width: 100%;
    padding: 1em 1em;
    padding-right: 2em;
    min-width: 33.333vw;
  }
}

@media screen and (max-width: 768px) {
  .navigationInner {
    display: block;
    position: absolute;
    top: 100%;
    left: 100%;
    z-index: 998;
    width: 100%;
    height: 100%;
    height: 0;
    height: -moz-fit-content;
    height: fit-content;
  }
  .siteHeader ~ * {
    transition: filter 0.3s ease;
  }
  .navigationButton {
    display: block;
    position: relative;
    z-index: 0;
    width: 40px;
    height: 40px;
  }
  .hamburgerIcon {
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 1;
    transform: translate(-50%, -50%);
    width: 75%;
    height: 4px;
    border-radius: 2px;
    background: var(--theme-color);
    transition: rotate 0.2s, translate 0.2s;
    transition: 0.25s;
  }
  .hamburgerIcon::before, .hamburgerIcon::after {
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 1;
    transform: translate(-50%, -50%);
    width: 75%;
    height: 4px;
    border-radius: 2px;
    background: var(--theme-color);
    transition: rotate 0.2s, translate 0.2s;
    transition: 0.25s;
    right: 0;
    transform-origin: 50% 50%;
    width: 100%;
    content: "";
  }
  .hamburgerIcon::before {
    top: -200%;
  }
  .hamburgerIcon::after {
    top: 300%;
  }
  #navigationToggle:checked ~ .siteHeader {
    -webkit-backdrop-filter: unset;
    backdrop-filter: unset;
  }
  #navigationToggle:checked ~ .siteHeader .hamburgerIcon {
    background-color: transparent;
  }
  #navigationToggle:checked ~ .siteHeader .hamburgerIcon::before {
    top: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
  }
  #navigationToggle:checked ~ .siteHeader .hamburgerIcon::after {
    top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
  }
  #navigationToggle:checked ~ .siteHeader .navigationItem {
    transform: translateX(calc(-100% + 1em));
    transition-timing-function: cubic-bezier(0.18, 0.89, 0.32, 1.27);
    transition-timing-function: ease;
  }
  #navigationToggle:checked ~ main,
  #navigationToggle:checked ~ .siteFooter {
    filter: blur(6px);
    opacity: 0.3;
  }
}/*# sourceMappingURL=style.css.map */