@charset "utf-8";
/* CSS Document */
body {
  width: 100vw;
  overflow-x: hidden;
}
#content {
  font-family: "Montserrat", "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    padding: 0;
    min-width: 100%;
    margin-bottom: 0;
}
.wp-block-group__inner-container>* {
  margin-bottom: auto;
}
.content-wrapper {
  width: 100vw;
  margin: 0 auto;
}
.site-header, .site-footer {
  background: #fff;
  width: 100vw;
}
 .site-footer {
background: #ebf7f7 ;
}
.header-img, .footer-img {
  margin: 0 auto;
  display: block;
}
.hero {
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: absolute;
  overflow: hidden;
  background: transparent;
  z-index: 1;
  top: 0;
  left: 0;
}
.hero::before {
  content: "";
  position: absolute;
  width: 200%;
  height: 200%;
  background: rgba(0,0,0,.35);
}
.hero-text {
  font-size: 2rem;
  font-weight: 400;
  margin: 0;
  padding: 0;
  color: #fff;
  text-align: center;
  opacity: 0;
  animation: fadeIn 1s ease forwards;
}
.typing-container {
  display: inline-block;
  position: relative;
}
.typing-text {
  display: inline-block;
  white-space: nowrap;
  overflow: hidden;
  background: #fff;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  border-right: 0.1em solid #70d5e0; 
  letter-spacing: .1em;
}
.subtitle {
  text-align: center;
  color: #fff;
  font-size: 1.1rem;
  margin-top: 28px;
  opacity: 0;
  transform: translateY(20px);
  animation: slideUp 0.5s ease forwards 2.125s;
  letter-spacing: .225em;
  font-weight: 300;
}
@keyframes typing {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}
@keyframes blink-caret {
  from,
  to {
    border-color: transparent;
  }
  50% {
    border-color: #70d5e0;
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.scroll-indicator {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  color: #fff;
  font-size: 1.75rem;
  opacity: 0;
  animation: bounce 2s infinite, fadeIn 1s ease forwards 2.125s;
  cursor: pointer;
}
@keyframes bounce {
  0%,
  20%,
  50%,
  80%,
  100% {
    transform: translateX(-50%) translateY(0);
  }
  40% {
    transform: translateX(-50%) translateY(-10px);
  }
  60% {
    transform: translateX(-50%) translateY(-5px);
  }
}
.section {
  position: relative;
}
.section:has(.banner-container) {
  height: 360px;
  position: relative;
}
.swiper {
  height: 360px;
}
.swiper-wrapper {
    max-width: 100%;
  height: 100vh;
}
.swiper-wrapper img {
min-width: 100%;
min-height: 100%;
    position: absolute;
    top: calc(50% - 4px);
    left: calc(50% - 6px);
    transform: translate(-50%, -50%) scale(1);
    transition: transform 10s ease;
    filter: blur(3px);
}
.swiper-wrapper img.blur-photo {
    filter: blur(4px);
}
.swiper-slide-active img {
  transform: translate(-50%, -50%) scale(1.1);
}
.banner-container {
  /*position: fixed;*/ 
  top: 0;
  left: -12px;
  min-height: 100vh;
  width: calc(100% + 24px);
  z-index: -1; 
}
.text-area {
  background: #fff;
  padding: 44px 0 /*108px*/54px;
  position: relative;
}
.text-area p {
  max-width: 554px;
  position: relative;
  width: calc(100% - 40px);
  white-space: pre-wrap;
  display: block;
  margin:0 auto;
  padding: 24px 0;
  letter-spacing: .05em;
  line-height: 1.85;
  /*color: #444;*/
  z-index: 1;
}
.text-area svg {
  position: absolute;
  top: 0;
  z-index: 0;
  height: 100%;
  width: 100%;
}
.text-area p:last-of-type {
  /*color: #444;*/
    font-size: 1.1rem;
    font-weight: 500;
    padding: 24px 0;
}

.fade-in {
  opacity: 0;
  transform: translateY(50px);
	transition: opacity 0.8s ease, transform 0.8s ease;
}
.fade-in-active {
  opacity: 1;
  transform: translateY(0);
}

.underline-before {
	background: linear-gradient(#d7fafa, #d7fafa) 0 100%/0 .65em no-repeat;
	transition: background 1s;
	text-decoration: none;
  font-weight: 500;
/*color: #404040;*/
}
.underline-after {
	background-size: 100% .65em;
}

.bg-anim {
  width: 100%;
  height: auto;
  display: block;
}
.anim {
  transform-origin: 50% 50%;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  animation-fill-mode: both;
}
.rect1 {
  animation: drift1 120s infinite linear, sway1 30s infinite ease-in-out;
}
@keyframes drift1 {
  0%   { transform: translateX(-10%) }
  100% { transform: translateX(120%) }
}
@keyframes sway1 {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(3%) rotate(2deg); }
}
.rect2 {
  animation: drift2 150s infinite linear, sway2 40s infinite ease-in-out;
}
@keyframes drift2 {
  0%   { transform: translateX(0%) }
  100% { transform: translateX(130%) }
}
@keyframes sway2 {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-2%) rotate(-2deg); }
}
.rect3 {
  animation: drift3 200s infinite linear, sway3 50s infinite ease-in-out;
}
@keyframes drift3 {
  0%   { transform: translateX(-5%) }
  100% { transform: translateX(125%) }
}
@keyframes sway3 {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(2%) rotate(1deg); }
}


@media screen and (max-width: 1366px) {
  .header-img, .footer-img {
width: 100%;
  }
}
@media screen and (min-width: 640px) {
.sp {
display: none;
}
.typing-text {
  line-height: 1;
  animation: typing 2s steps(40, end), blink-caret 0.75s step-end infinite;
}
}
@media screen and (max-width: 639px) {
    .section:has(.banner-container) {
  height: calc(100vh - 84px - 32px);
  overflow: hidden;
}
.text-area p {
    padding: 20px 0;
    line-height: 2;
}
.swiper {
  height: 100vh;
}
.swiper-wrapper img {
    filter: blur(2px);
}
.swiper-wrapper img.blur-photo {
    filter: blur(4px);
}
.scroll-indicator {
  bottom: 27.5%;
}
.swiper-wrapper img {
   min-height: 100%;
   width: auto;
   min-width: 100%;
   object-fit: cover;
}
.swiper-wrapper img.shift-left {
object-position: 45% center;
}
.swiper-wrapper img.shift-left-half {
   object-position: 60% 40%;
}
.swiper-wrapper img.shift-right {
   object-position: calc(50% + 104px) center;
}
.pc {
display: none;
}
.typing-container {
  position: relative;
  display: inline-block;
  font-size: 1.65rem;
  font-weight: 300;
  line-height: 1.75;
  letter-spacing: .15em;
  white-space: nowrap;
  background: #fff;
  -webkit-background-clip: text;
  background-clip: text;
  /*-webkit-text-fill-color: transparent;*/
}
.cursor {
  display: inline-block;
  vertical-align: bottom;
  font-weight: 500;
  color: #70d5e0;
  animation: blink 2.25s ease-in-out infinite;
  margin-left: 2px;
  line-height: 1.9;
}
.typing-line {
  display: inline;
}
.subtitle {
  animation: slideUp 0.5s ease forwards 2s;
}
.scroll-indicator {
  animation: bounce 2s infinite, fadeIn 1s ease forwards 2s;
}
@keyframes blink {
  0%, 50%, 100% { opacity: 1; }
  25%, 75% { opacity: 0; }
}
.text-area {
    background: #fff;
    padding: 24px 0 72px;
}
}
.page-under-img {
  width: calc(100% - 40px);
  max-width: 554px;
    margin: 36px auto 0;
    display: block;
    z-index: 3;
    position: relative;
    opacity: .45;
        filter: blur(1px);
}
.spacing-narrow  {
letter-spacing: -.025em;
}
.entry-title-mv {
 position: absolute;
  left: -9999px;
  top: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden; 
}