:root {
  --ホワイト: white;
  --transparent: transparent;
  --メインテキスト: #333;
  --見出し: "GFS Didot", sans-serif;
  --130: 130%;
  --サブテキスト: #777;
  --サブ見出し: "Noto Sans JP", sans-serif;
  --本文: "Noto Sans JP", sans-serif;
  --180: 180%;
  --150: 150%;
  --背景サブカラー: whitesmoke;
  --100: 100%;
  --アクセントカラー: darkslategrey;
  --メインカラー: #436d63;
  --japanese: "Noto Serif JP", sans-serif;
}

html {
  margin-top: 0px !important;
}
.none {
  display: none !important;
}
body.no-scroll {
  overflow: hidden;
}

.loading-animation.active {
  z-index: 999;
  opacity: 1;
  flex-flow: column;
  display: flex;
}

.loading-animation-text._2 {
  padding-left: 40px;
}

.loading-animation-wrap {
  grid-column-gap: 24px;
  justify-content: flex-start;
  align-items: center;
  padding-left: 4%;
  padding-right: 4%;
  display: flex;
  font-family: var(--見出し);
  overflow: hidden;
}

/* テキストの外枠（アニメーション対象） */
.loading-animation-text {
  overflow: hidden;
  white-space: nowrap;
  opacity: 0;
  width: 0;
  gap: 24px;
  font-family: "Noto Serif JP", sans-serif;
  grid-column-gap: 24px;
  grid-row-gap: 24px;
  font-size: 48px;
  line-height: var(--150);
  letter-spacing: 0.96px;
  justify-content: flex-start;
  align-items: center;
  font-weight: 700;
  display: flex;
}
/* アニメーション開始で可視化＆幅拡大 */
.loading-animation-text.show {
  animation: revealFromLeft 1.5s ease forwards;
}
/* 実際のテキスト要素 */
.loading-animation-txt {
  display: inline-block;
  padding-left: 4px; /* 左側の余白（好みで調整） */
  font-family: "Noto Serif JP", sans-serif;
}
/* アニメーション定義 */
@keyframes revealFromLeft {
  0% {
    width: 0;
    opacity: 0;
  }
  100% {
    width: 100%;
    opacity: 1;
  }
}
/* ローディング自体のフェードアウト */
.loading-animation.fade-out {
  opacity: 0;
  transition: opacity 1s ease;
}
/* 完全に消す */
.loading-animation.hidden {
  display: none;
}
.fv-slider-area {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.fv-slider-card {
  opacity: 0;
  transform: scale(1);
  animation: fadeZoom 12s infinite;
  animation-timing-function: ease-in-out;
}
.fv-slider-card:nth-child(1) {
  animation-delay: 0s;
}
.fv-slider-card:nth-child(2) {
  animation-delay: 6s;
}
@keyframes fadeZoom {
  0% {
    opacity: 0;
    transform: scale(1);
  }
  8% {
    opacity: 1;
    transform: scale(1.01);
  }
  40% {
    opacity: 1;
    transform: scale(1.05);
  }
  50% {
    opacity: 0;
    transform: scale(1.08);
  }
  100% {
    opacity: 0;
    transform: scale(1.1);
  }
}
.loading-animation {
  z-index: 99;
  grid-column-gap: 24px;
  background-color: white;
  opacity: 0;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100vh;
  transition: opacity 0.4s;
  display: none;
  position: fixed;
}

.w-embed-youtubevideo {
  background-image: url("https://d3e54v103j8qbb.cloudfront.net/static/youtube-placeholder.2b05e7d68d.svg");
  background-position: 50%;
  background-size: cover;
  width: 100%;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  position: relative;
}

.w-embed-youtubevideo:empty {
  min-height: 75px;
}

.w-form-formradioinput--inputType-custom {
  border: 1px solid #ccc;
  border-radius: 50%;
  width: 12px;
  height: 12px;
}

.w-form-formradioinput--inputType-custom.w--redirected-focus {
  box-shadow: 0 0 3px 1px #3898ec;
}

.w-form-formradioinput--inputType-custom.w--redirected-checked {
  border-width: 4px;
  border-color: #3898ec;
}

.w-checkbox {
  margin-bottom: 5px;
  padding-left: 20px;
  display: block;
}

.w-checkbox:before {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox:after {
  content: " ";
  clear: both;
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox-input {
  float: left;
  margin: 4px 0 0 -20px;
  line-height: normal;
}

.w-checkbox-input--inputType-custom {
  border: 1px solid #ccc;
  border-radius: 2px;
  width: 12px;
  height: 12px;
}

.w-checkbox-input--inputType-custom.w--redirected-checked {
  background-color: #3898ec;
  background-image: url("https://d3e54v103j8qbb.cloudfront.net/static/custom-checkbox-checkmark.589d534424.svg");
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  border-color: #3898ec;
}

.w-checkbox-input--inputType-custom.w--redirected-focus {
  box-shadow: 0 0 3px 1px #3898ec;
}

.side-bar {
  z-index: 99;
  background-color: var(--ホワイト);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100px;
  max-width: 100px;
  height: 100vh;
  min-height: 100vh;
  max-height: 100vh;
  padding-top: 44px;
  display: flex;
  position: fixed;
  top: 0;
  left: 0;
  box-shadow: 0 5px 10px #0000001a;
}

.menu-botton {
  grid-row-gap: 8px;
  aspect-ratio: 1;
  cursor: pointer;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
  position: relative;
}

.menu-line {
  background-color: var(--メインテキスト);
  width: 50px;
  height: 1px;
  transition: opacity 0.6s;
}

.menu-line.bottom.active {
  transform: translate(0, -9px) rotate(-20deg);
}

.menu-line.active {
  transform: rotate(20deg);
}

.mail-image {
  aspect-ratio: 1;
  background-image: url("../images/ant-design_mail-outlined_1.svg");
  background-position: 0 0;
  background-size: cover;
  width: 24px;
}

.mail-image.opposite {
  display: none;
}

.mail-wrapper {
  aspect-ratio: 1;
  cursor: pointer;
  justify-content: center;
  align-items: center;
  width: 50px;
  transition: all 0.2s;
  display: flex;
}

.mail-wrapper:hover {
  transform: scale(1.1);
}

.branding-body {
  justify-content: flex-end;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

.branding-right-body {
  width: calc(100% - 100px);
  max-width: calc(100% - 100px);
}

.fv-brand-section {
  aspect-ratio: 1440 / 959.04;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-height: 100vh;
  display: flex;
  position: relative;
  overflow: hidden;
}

.brand-fv-slider-area {
  z-index: -1;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  max-height: 100vh;
  display: flex;
  position: relative;
}

.fv-animation-image {
  width: 100%;
  height: 100%;
  max-height: 100vh;
}

.image-cover-black {
  z-index: 0;
  background-color: #00000059;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.fv-animation-txt {
  z-index: 2;
  aspect-ratio: 547 / 143;
  width: 41%;
  min-width: 318.889px;
  max-width: 547px;
  position: absolute;
}

.logo-link {
  z-index: 80;
  width: 22%;
  min-width: 248px;
  max-width: 324px;
  transition: opacity 0.6s;
  display: block;
}

.footer-logo {
  z-index: 80;
  width: 22%;
  min-width: 248px;
  max-width: 324px;
  transition: opacity 0.6s;
}

.logo-link.footer {
  position: static;
  top: auto;
  right: auto;
}

.logo-link.top-fv {
  width: 100%;
  min-width: 248px;
  position: static;
}

.logo-link.active {
  width: 10%;
  min-width: 160px;
}

.scroll-wrap {
  z-index: 50;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  text-decoration: none;
  position: absolute;
  bottom: 95px;
  right: 5.6%;
}

.scroll-wrap.top {
  flex-flow: column-reverse;
  top: 70%;
  bottom: auto;
  transform: rotate(180deg);
  position: fixed;
}

.scroll-txt {
  font-family: var(--見出し);
  color: var(--ホワイト);
  font-size: 14px;
  line-height: var(--130);
  margin-bottom: 24px;
  padding-top: 4px;
  transform: rotate(90deg);
}

.scroll-txt.top {
  color: var(--サブテキスト);
  transform: rotate(-90deg);
}

.scroll-down-arrow {
  aspect-ratio: 4 / 70;
  object-fit: cover;
  height: 70px;
  display: none;
}

.fv-below-brand-section {
  grid-row-gap: 80px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  padding-top: 180px;
  padding-bottom: 210px;
  display: flex;
}

.brand-titles {
  color: var(--メインテキスト);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.brand-titles.white {
  color: var(--ホワイト);
}

.brand-title-txt {
  font-family: var(--見出し);
  font-size: 40px;
  line-height: var(--130);
  letter-spacing: 0.8px;
  font-weight: 700;
}

.brand-title-subtxt {
  font-family: var(--サブ見出し);
  font-size: 24px;
  line-height: var(--130);
  letter-spacing: 0.48px;
  font-weight: 700;
}

._16px-basetxt {
  font-family: var(--本文);
  color: var(--メインテキスト);
  font-size: 16px;
  line-height: var(--180);
  text-align: center;
  letter-spacing: 0.32px;
  margin-bottom: 0;
  font-weight: 400;
}

._16px-basetxt._150 {
  line-height: var(--150);
}

._16px-basetxt.white {
  color: var(--ホワイト);
}

._16px-basetxt._777 {
  color: var(--サブテキスト);
}

._16px-basetxt.contact-txt {
  line-height: var(--150);
  text-align: left;
}

.service-brand-section {
  background-color: var(--背景サブカラー);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
  position: relative;
}

.brand-1100px-wrapper {
  z-index: 1;
  grid-row-gap: 80px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 90%;
  max-width: 1100px;
  padding-top: 180px;
  padding-bottom: 180px;
  display: flex;
  position: relative;
}

.service-mono-wrap {
  justify-content: center;
  align-items: flex-start;
  display: flex;
  position: absolute;
  top: -100px;
}

.service-mono-gray {
  font-family: var(--見出し);
  color: var(--背景サブカラー);
  font-size: 160px;
  line-height: var(--100);
  height: 63%;
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
}

.service-mono-image {
  width: 100%;
  display: block;
  position: absolute;
  top: 25px;
}

.service-brand-wrapper {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  padding-top: 180px;
  display: flex;
}

.service-video-wrapper {
  grid-row-gap: 24px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 800px;
  display: flex;
}

.brand-botton {
  border: 1px solid var(--アクセントカラー);
  background-color: var(--アクセントカラー);
  font-family: var(--見出し);
  color: var(--ホワイト);
  font-size: 16px;
  line-height: var(--130);
  letter-spacing: 2px;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 600px;
  padding-top: 25px;
  padding-bottom: 30px;
  text-decoration: none;
  transition: all 0.6s;
  display: flex;
}

.brand-botton:hover {
  border-color: var(--メインテキスト);
  color: var(--メインテキスト);
  background-color: #fff9;
}

.brand-botton.form {
  max-width: 500px;
}

.botton-txt.noto-sans {
  font-family: var(--本文);
  line-height: var(--150);
  font-weight: 700;
}

.brand-grid {
  grid-column-gap: 4%;
  grid-row-gap: 56px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.youtube-card {
  grid-row-gap: 24px;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
}

.card-title {
  font-family: var(--本文);
  color: var(--メインテキスト);
  font-size: 16px;
  line-height: var(--150);
  letter-spacing: 0.32px;
  font-weight: 700;
}

.media-section {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.top-youtube-video {
  z-index: -1;
  aspect-ratio: 16 / 9;
}

.youtube-grid-video {
  aspect-ratio: 16 / 9;
  transform-style: preserve-3d;
  background-image: url("../images/FV_画像-1-1_1.avif");
  transition: all 0.6s;
  width: 100%;
  height: 100%;
}

.youtube-grid-video:hover {
  transform: scale3d(1.05, 1.05, 1.05);
}

.gap-wrapper {
  grid-row-gap: 64px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  display: flex;
}

.media-card {
  grid-row-gap: 24px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  text-decoration: none;
  display: flex;
}

.media-image {
  aspect-ratio: 33 / 20;
  object-fit: cover;
  transform-style: preserve-3d;
  background-color: #e0e0e0;
  width: 100%;
  transition: transform 0.6s;
}

.media-image:hover {
  transform: scale3d(1.05, 1.05, 1.05);
}

.media-bottom {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  display: flex;
}

.card-more {
  grid-column-gap: 2px;
  font-family: var(--本文);
  color: var(--メインテキスト);
  line-height: var(--150);
  justify-content: flex-start;
  align-items: center;
  text-decoration: none;
  display: flex;
}

.agent-section {
  background-color: var(--背景サブカラー);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.thambnail-image {
  width: 100%;
  max-width: 900px;
  box-shadow: 5px 5px 10px #0000001a;
}

.thambnail-image.mobile {
  display: none;
}

.contact-brand-section {
  z-index: 2;
  background-image: url("../images/AdobeStock_650593340_1.avif");
  background-position: 0 0;
  background-size: cover;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
  position: relative;
}

.tap-to-top {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  text-decoration: none;
  display: none;
  position: absolute;
  top: 15px;
  right: 5.6%;
}

.tap-arrow {
  aspect-ratio: 4 / 70;
  object-fit: cover;
  height: 70px;
}

.tap-to-txt {
  font-family: var(--見出し);
  color: var(--サブテキスト);
  font-size: 14px;
  line-height: var(--130);
  margin-top: 12px;
  padding-top: 4px;
  text-decoration: none;
  transform: rotate(90deg);
}

.brand-footer-section {
  z-index: 2;
  background-color: var(--背景サブカラー);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  padding-top: 80px;
  padding-bottom: 80px;
  display: flex;
  position: relative;
}

._1200px-brand-wrapper {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 90%;
  max-width: 1200px;
  display: flex;
}

.space-between-wrap {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  display: flex;
}

.brand-logo-image {
  width: 100%;
}

.footer-inside-wrap {
  grid-column-gap: 32px;
  justify-content: center;
  align-items: center;
  display: flex;
}

.footer-anker {
  text-decoration: none;
}

.footer-botton-wrapper {
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  max-width: 800px;
  margin-top: 73px;
  margin-bottom: 56px;
  display: flex;
}

.footer-botton {
  grid-column-gap: 8px;
  border: 1px solid var(--アクセントカラー);
  background-color: var(--アクセントカラー);
  color: var(--ホワイト);
  justify-content: center;
  align-items: center;
  width: 350px;
  padding-top: 25px;
  padding-bottom: 25px;
  font-size: 16px;
  text-decoration: none;
  transition: all 0.6s;
  display: flex;
}

.footer-botton:hover {
  border: 1px solid var(--メインテキスト);
  background-color: var(--ホワイト);
  color: var(--メインテキスト);
}

.footer-botton-wrap {
  grid-row-gap: 9px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.footer-image {
  z-index: 1;
  aspect-ratio: 1;
  width: 100%;
  transition: all 0.6s;
  position: absolute;
  top: 0;
}

.footer-image.hover {
  z-index: 0;
}

.copy-write {
  font-family: var(--本文);
  color: var(--サブテキスト);
  font-size: 10px;
  line-height: var(--180);
}

.menu-modal {
  z-index: -1;
  opacity: 0;
  justify-content: flex-start;
  align-items: flex-start;
  width: calc(100vw - 100px);
  height: 100vh;
  min-height: 100vh;
  transition-property: all;
  transition-duration: 0.4s;
  transition-timing-function: ease;
  display: flex;
  position: fixed;
  top: 0;
  right: 0;
}

.menu-modal.active {
  z-index: 100;
  opacity: 1;
  width: calc(100vw - 100px);
  min-width: auto;
  display: flex;
}

.menu-inside {
  grid-row-gap: 80px;
  background-color: var(--ホワイト);
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  height: 100vh;
  padding: 108px 60px 108px 20px;
  display: flex;
  position: relative;
}

.menu-title {
  font-family: var(--見出し);
  color: var(--メインテキスト);
  font-size: 32px;
  line-height: var(--130);
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
}

.menu-titles {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  text-decoration: none;
  display: flex;
}

.menu-txt {
  font-family: var(--本文);
  color: var(--メインテキスト);
  font-size: 16px;
  line-height: var(--130);
  letter-spacing: 0.32px;
  font-weight: 700;
}

.menu-wrap {
  grid-row-gap: 48px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.modal-side {
  z-index: 0;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100px;
  height: 100%;
  padding-top: 44px;
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
}

.menu-black-back {
  z-index: -1;
  background-color: #0009;
  width: 100%;
  height: 100%;
  position: absolute;
}

.kasou-fv-brand-section {
  background-image: url("../images/AdobeStock_1105314733-1_1.avif");
  background-position: 0 0;
  background-size: auto;
  height: 300px;
  max-height: 300px;
  position: relative;
  width: 100%;
  max-width: 100%;
}

.form-brand-section {
  z-index: 0;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
  position: relative;
  width: 100%;
  max-width: 100%;
}

.form-block-brand {
  width: 100%;
  max-width: 900px;
  margin-bottom: 0;
}

.form-brand {
  grid-row-gap: 40px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  max-width: 900px;
  display: flex;
}

.form-input-wrap {
  width: 72%;
  max-width: 700px;
}

.mw_wp_form.mw_wp_form_imput form {
  grid-row-gap: 40px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  display: flex;
}

.mw_wp_form {
  grid-row-gap: 40px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  display: flex;
}

form {
  width: 100%;
  display: block;
  margin-top: 0em;
  unicode-bidi: isolate;
}

.form-cover {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  display: flex;
}

.form-cover.align-top {
  justify-content: space-between;
  align-items: flex-start;
}

.form-cover.align-right {
  justify-content: flex-end;
  align-items: center;
}

.brand-text-field {
  z-index: -1;
  background-color: var(--背景サブカラー);
  font-family: var(--本文);
  color: var(--サブテキスト);
  font-size: 14px;
  line-height: var(--150);
  letter-spacing: 0.28px;
  border: 1px solid #0000;
  width: 100%;
  max-width: 700px;
  height: 53px;
  margin-bottom: 0;
}

._700bold {
  font-weight: 700;
}

.red-astarisc {
  color: #a00;
  padding-left: 3px;
}

.brand-radio-cover {
  grid-column-gap: 3%;
  justify-content: flex-start;
  align-items: center;
  width: 72%;
  max-width: 700px;
  display: flex;
}

.brand-radio-field {
  grid-column-gap: 8px;
  justify-content: center;
  align-items: center;
  padding-top: 16px;
  padding-bottom: 16px;
  padding-left: 0;
  display: flex;
}

.radio-button-label {
  font-family: var(--本文);
  font-size: 16px;
  line-height: var(--150);
  margin-bottom: 0;
  font-weight: 400;
}

.radio-button {
  margin-left: 0;
}

.brand-date-select-wrap {
  grid-column-gap: 32px;
  flex-flow: row;
  justify-content: flex-start;
  align-items: center;
  width: 72%;
  display: flex;
}

.date-select-card {
  justify-content: flex-start;
  align-items: center;
  width: 78%;
  display: flex;
}

.brand-select-field {
  border: 1px solid var(--メインテキスト);
  background-color: var(--ホワイト);
  font-family: var(--本文);
  color: var(--メインテキスト);
  font-size: 14px;
  line-height: var(--150);
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 30px;
  margin-bottom: 0;
  padding: 3px 8px;
  display: flex;
}

.selecter-card {
  grid-column-gap: 5px;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.selecter-wrap {
  grid-column-gap: 16px;
  justify-content: flex-start;
  align-items: center;
  display: flex;
  width: 100%;
}

.select-right {
  grid-row-gap: 24px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 78%;
  max-width: 700px;
  display: flex;
}

.select-right.check {
  grid-row-gap: 8px;
}

.brand-checkbox-field {
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 0;
  padding-left: 0;
  display: flex;
}

.brand-checkbox {
  margin-left: 0;
  margin-right: 8px;
  width: 14px;
  height: 14px;
}

.textarea {
  z-index: -8;
  border: 1px solid var(--メインテキスト);
  font-family: var(--本文);
  font-size: 14px;
  line-height: var(--150);
  letter-spacing: 0.28px;
  width: 100%;
  max-width: 700px;
  min-height: 250px;
  margin-bottom: 0;
}

.privacy-txt {
  color: #07008a;
  text-underline-offset: 2px;
  font-weight: 700;
  text-decoration-color: #07008a;
}

.slider-wrapper {
  width: 100%;
}

.brand-slider-item {
  width: 100%;
  height: 100%;
  max-height: 100vh;
  position: absolute;
  top: 0;
}

.arrow-animation {
  transform: rotate(0);
}

.scroll-indicator {
  justify-content: center;
  align-items: flex-end;
  max-height: 70px;
}

.scroll-indicator.top {
  top: 70px;
}

.side-bar-wrap {
  grid-row-gap: 40px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.mobile {
  display: none;
}

.mobile-none {
  display: block;
}

._90--wrapper {
  grid-row-gap: 80px;
  flex-flow: column;
  width: 90%;
  display: flex;
}

.scroll-arrow {
  width: 100%;
}

.card-image-wrap {
  width: 100%;
  overflow: hidden;
}

.service-mono-white {
  font-family: var(--見出し);
  color: var(--ホワイト);
  font-size: 160px;
  line-height: var(--100);
}

.footer-image-wrap {
  width: 25px;
  height: 25px;
  position: relative;
}

.footer-image-hover {
  width: 100%;
}

.logo-wrapper {
  z-index: 90;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  padding-top: 60px;
  padding-right: 8%;
  transition: background-color 0.3s, padding 0.3s;
  display: flex;
  position: fixed;
  top: 0;
  right: 0;
}

.logo-wrapper.active {
  z-index: 99;
  background-color: var(--ホワイト);
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  min-width: auto;
  max-width: none;
  padding-top: 5px;
  padding-bottom: 8px;
  padding-right: 20px;
  display: flex;
}

.logo-wrapper.header {
  display: none;
}

.scroll-indicator,
.scroll-indicator.top {
  width: 24px;
  height: 70px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.scroll-indicator {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
}
.scroll-indicator.top {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
}
.scroll-arrow,
.scroll-arrow.top {
  width: 24px;
  height: 70px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  animation: scroll-arrow-animation 2.5s infinite;
  transform-origin: top;
}
.scroll-arrow {
  background-image: url("https://cdn.prod.website-files.com/684eaf00423d781d4d727d09/684ec9895a2b95252b655f56_Vector%201.svg");
}
.scroll-arrow.top {
  height: 24px;
  background-image: url("../images/fixed-arrow.png");
}
@keyframes scroll-arrow-animation {
  0% {
    transform: scaleY(0);
    transform-origin: top;
  }
  50% {
    transform: scaleY(1);
    transform-origin: top;
  }
  50.1% {
    transform-origin: bottom;
  }
  100% {
    transform: scaleY(0);
    transform-origin: bottom;
  }
}

.scroll-indicator,
.scroll-indicator.top {
  width: 24px;
  height: 70px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.scroll-indicator {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
}
.scroll-indicator.top {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
}
.scroll-arrow,
.scroll-arrow.top {
  width: 24px;
  height: 70px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  animation: scroll-arrow-animation 2.5s infinite;
  transform-origin: top;
}
.scroll-arrow {
  background-image: url("https://cdn.prod.website-files.com/684eaf00423d781d4d727d09/684ec9895a2b95252b655f56_Vector%201.svg");
}
.scroll-arrow.top {
  background-image: url("../images/fixed-arrow.png");
}
@keyframes scroll-arrow-animation {
  0% {
    transform: scaleY(0);
    transform-origin: top;
  }
  50% {
    transform: scaleY(1);
    transform-origin: top;
  }
  50.1% {
    transform-origin: bottom;
  }
  100% {
    transform: scaleY(0);
    transform-origin: bottom;
  }
}
/* FVの画像スライダー */
.brand-slider {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.brand-slider-item {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transform: scale(1);
  animation: fadeZoom 18s infinite;
  animation-timing-function: ease-in-out;
}
.brand-slider-item:nth-child(1) {
  animation-delay: 0s;
}
.brand-slider-item:nth-child(2) {
  animation-delay: 6s;
}
.brand-slider-item:nth-child(3) {
  animation-delay: 12s;
}
@keyframes fadeZoom {
  0% {
    opacity: 0;
    transform: scale(1);
  }
  10% {
    opacity: 1;
    transform: scale(1.01);
  }
  40% {
    opacity: 1;
    transform: scale(1.05);
  }
  60% {
    opacity: 0;
    transform: scale(1.1);
  }
  100% {
    opacity: 0;
    transform: scale(1.1);
  }
}
/* セクションのフェードイン */
.fade-trigger {
  opacity: 0;
  transform: scale(0.95);
}
.fade-in-animation {
  animation: fadeInZoom 1.2s ease-out forwards;
}
@keyframes fadeInZoom {
  0% {
    opacity: 0;
    transform: scale(0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
/* footer:hover */
.footer-botton .footer-image {
  opacity: 1;
  z-index: 1;
}
.footer-botton .footer-image-hover {
  opacity: 0;
  z-index: 2;
}
.footer-botton:hover .footer-image {
  opacity: 0;
}
.footer-botton:hover .footer-image-hover {
  opacity: 1;
}

.menu-line,
.menu-line.bottom {
  transition: all 0.4s ease;
}
/* 例：回転させる */
.menu-line.active {
  transform: rotate(20deg) translateY(5px);
}
.menu-line.bottom.active {
  transform: rotate(-20deg) translateY(-5px);
}

.mw_wp_form .horizontal-item + .horizontal-item {
  margin-left: 0px !important;
}

dd {
  display: flex;
  margin-inline-start: 0px;
  unicode-bidi: isolate;
  width: 100%;
  max-width: 700px;
  height: 53px;
}

.transparent {
  color: transparent;
}

.wpcf7-form-control.wpcf7-checkbox.wpcf7-validates-as-required.brand-checkbox {
  display: flex;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-end;
}

.wpcf7-list-item {
  margin: 0 1rem 0 0;
}
._16px-basetxt.pp {
  text-align: left;
}

.pp-wrapper {
  padding: 5% 2%;
  box-shadow: 0 5px 20px #0003;
}

@media screen and (max-width: 991px) {
  .loading-animation-text {
    font-size: 40px;
  }
  .side-bar {
    width: 80px;
    padding-top: 40px;
  }

  .menu-line,
  .mail-wrapper {
    width: 44px;
  }

  .branding-right-body {
    width: calc(100% - 80px);
    max-width: calc(100% - 80px);
  }

  .fv-brand-section {
    height: 700px;
  }

  .brand-fv-slider-area {
    height: 700px;
    max-height: none;
  }

  .fv-animation-image {
    object-fit: cover;
    object-position: 50% 50%;
    height: 100%;
  }

  .footer-logo {
    min-width: 190px;
  }

  .logo-link.top-fv {
    width: 24%;
  }

  .logo-link.mobile-nav {
    display: none;
  }

  .scroll-txt {
    font-size: 12px;
  }

  .scroll-down-arrow {
    aspect-ratio: auto;
    height: 50px;
  }

  .fv-below-brand-section {
    padding-top: 160px;
    padding-bottom: 160px;
  }

  .brand-titles {
    grid-row-gap: 8px;
  }

  .brand-title-txt {
    font-size: 32px;
  }

  .brand-title-subtxt {
    font-size: 20px;
  }

  .brand-1100px-wrapper {
    grid-row-gap: 72px;
    padding-top: 160px;
    padding-bottom: 160px;
  }

  .service-mono-wrap {
    top: -81px;
  }

  .service-mono-gray {
    font-size: 128px;
  }

  .brand-botton {
    max-width: 520px;
    height: 75px;
    padding-top: 0px;
    padding-bottom: 0px;
  }

  .brand-grid.youtube {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    column-gap: 4%;
    row-gap: 56px;
  }

  .brand-grid {
    grid-template-columns: 1fr 1fr;
  }

  .youtube-card {
  grid-row-gap: 24px;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
}

  .gap-wrapper {
    grid-row-gap: 56px;
  }

  .brand-footer-section {
    padding-bottom: 60px;
  }

  .footer-botton {
    width: 300px;
  }

  .menu-modal.active {
    width: calc(100vw - 80px);
  }

  .menu-inside {
    grid-row-gap: 72px;
    padding-top: 80px;
  }

  .menu-title {
    font-size: 28px;
  }

  .menu-wrap {
    grid-row-gap: 40px;
  }

  .modal-side {
    width: 80px;
  }

  .form-block-brand {
    width: 100%;
  }

  .brand-text-field {
    width: 100%;
  }

  .brand-radio-field {
    justify-content: flex-start;
    align-items: center;
  }

  .select-right,
  .textarea {
    width: 100%;
  }

  .brand-slider-item {
    height: 100%;
  }

  .side-bar-wrap {
    grid-row-gap: 52px;
  }

  ._90--wrapper {
    grid-row-gap: 72px;
  }

  .service-mono-white {
    font-size: 128px;
  }
}

@media screen and (max-width: 767px) {
  .loading-animation.active {
    grid-column-gap: 18px;
    grid-row-gap: 0px;
    flex-flow: wrap;
    justify-content: center;
    align-items: center;
  }

  .loading-animation-text {
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    font-size: 32px;
  }
  .selecter-wrap {
    grid-column-gap: 8px;
  }
  .brand-select-field {
    width: 52px;
    height: 30px;
  }

  .brand-date-select-wrap {
    grid-column-gap: 32px;
    flex-flow: row;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    display: flex;
  }

  .form-input-wrap {
    width: 100%;
  }

  .side-bar {
    z-index: 990;
    background-color: var(--transparent);
    box-shadow: none;
    flex-flow: row;
    justify-content: space-between;
    align-items: center;
    width: 90%;
    max-width: 100%;
    height: 120px;
    min-height: 120px;
    max-height: 120px;
    padding-top: 0;
    padding-left: 5%;
    padding-right: 5%;
    transition: background-color 0.2s;
  }

  .side-bar.scrolled {
    background-color: var(--ホワイト);
    display: flex;
  }

  .side-bar.active {
    background-color: var(--ホワイト);
  }

  .menu-botton.cross {
    top: 4px;
  }

  .menu-line {
    background-color: var(--ホワイト);
    width: 40px;
  }

  .menu-line.bottom.black,
  .menu-line.active,
  .menu-line.black {
    background-color: var(--メインテキスト);
  }

  .mail-image {
    background-image: url("../images/プロパティ1デフォルト-1.svg");
    background-position: 0 0;
    background-repeat: no-repeat;
    background-size: cover;
  }

  .mail-image.opposite {
    display: block;
  }

  .mail-image.active {
    background-image: url("../images/ant-design_mail-outlined_1.svg");
  }

  .branding-right-body {
    width: 100%;
    max-width: 100%;
  }

  .fv-brand-section {
    height: 500px;
    min-height: auto;
  }

  .brand-fv-slider-area {
    height: 100%;
    max-height: none;
  }

  .fv-animation-image {
    object-fit: cover;
  }

  .logo-link {
    width: 100% !important;
    min-width: 98px;
    max-width: 170px;
    position: relative;
    top: 0;
    right: 0%;
  }

  .footer-logo {
    aspect-ratio: 241 / 48;
    width: 50%;
    max-width: 241px;
  }

  .logo-link.top-fv {
    display: none;
  }

  .logo-link.mobile-nav {
    position: static;
  }

  .scroll-wrap {
    display: none;
  }

  .fv-below-brand-section {
    padding-top: 120px;
    padding-bottom: 120px;
  }

  .brand-title-txt {
    text-align: center;
    font-size: 28px;
  }

  .brand-title-subtxt {
    font-size: 18px;
  }

  ._16px-basetxt.contact-txt {
    font-size: 14px;
  }

  .brand-1100px-wrapper {
    grid-row-gap: 68px;
    padding-top: 120px;
    padding-bottom: 120px;
  }

  .service-mono-wrap {
    top: -63px;
  }

  .service-mono-gray {
    font-size: 100px;
  }

  .service-mono-image {
    top: 20px;
  }

  .brand-botton {
    max-width: 440px;
  }

  .botton-txt.noto-sans {
    text-align: center;
  }

  .brand-grid {
    grid-column-gap: 4%;
    grid-row-gap: 56px;
    flex-flow: column;
    grid-template-rows: auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    justify-content: flex-start;
    place-items: start center;
    display: grid;
  }

  .brand-grid.youtube {
    grid-column-gap: 4%;
    grid-row-gap: 56px;
    flex-flow: column;
    grid-template-rows: auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    justify-content: flex-start;
    place-items: start center;
    display: grid;
  }

  .youtube-card,
  .media-card {
    width: 100%;
    max-width: 400px;
  }

  .media-image {
    object-fit: fill;
  }

  .thambnail-image {
    max-width: 400px;
    display: none;
  }

  .thambnail-image.mobile {
    display: block;
  }

  .brand-footer-section {
    padding-bottom: 40px;
  }

  .space-between-wrap {
    grid-row-gap: 64px;
    flex-flow: column;
    justify-content: flex-start;
    align-items: center;
  }

  .space-between-wrap.bottom {
    grid-row-gap: 24px;
    flex-flow: column-reverse;
  }

  .brand-logo-image {
    height: 100%;
  }

  .footer-inside-wrap {
    grid-row-gap: 24px;
    flex-flow: column;
  }

  .footer-botton-wrapper {
    grid-row-gap: 56px;
    flex-flow: column;
    justify-content: flex-start;
    align-items: center;
    margin-top: 64px;
    margin-bottom: 116px;
  }

  .footer-botton,
  .footer-botton.navbar {
    width: 335px;
  }

  .menu-modal {
    width: 100%;
    height: auto;
    min-height: auto;
    right: auto;
  }

  .menu-modal.active {
    z-index: 100;
    width: 100%;
    height: auto;
    min-height: auto;
    right: auto;
  }

  .menu-inside {
    grid-row-gap: 68px;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    height: auto;
    padding-top: 140px;
  }

  .menu-title {
    font-size: 24px;
  }

  .menu-titles {
    justify-content: flex-start;
    align-items: center;
  }

  .menu-wrap {
    justify-content: flex-start;
    align-items: center;
    width: 100%;
  }

  .modal-side {
    flex-flow: row;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    height: 120px;
    padding-top: 0;
    padding-left: 5%;
    padding-right: 5%;
  }

  .menu-black-back {
    height: 100vh;
  }

  .kasou-fv-brand-section {
    height: 120px;
    max-height: 120px;
  }

  .form-block-brand {
    width: 90%;
  }

  .form-cover {
    grid-row-gap: 12px;
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-start;
  }

  .brand-text-field,
  .brand-radio-cover,
  .select-right {
    width: 100%;
	max-width: 330px;
  }

  .select-right.privacy {
    justify-content: flex-start;
    align-items: center;
  }

  .textarea {
    width: 100%;
	  max-width: 330px;
  }

  .brand-slider-item {
    height: 100%;
  }

  .side-bar-wrap {
    grid-column-gap: 14px;
    grid-row-gap: 0px;
    flex-flow: row-reverse;
  }

  .mobile {
    display: block;
  }

  .mobile-none {
    display: none;
  }

  ._90--wrapper {
    grid-row-gap: 68px;
  }

  .service-mono-white {
    font-size: 100px;
  }

  .side-bar-scrolled {
    z-index: 100;
    background-color: var(--ホワイト);
    justify-content: space-between;
    align-items: center;
    width: 100%;
    height: 120px;
    padding-left: 5%;
    padding-right: 5%;
    display: flex;
    position: fixed;
  }

  .logo-wrapper {
    display: none;
  }

  .logo-wrapper.header {
    padding-top: 0;
    padding-right: 0%;
    display: block;
    position: relative;
    top: auto;
    right: auto;
  }

  ._16px-basetxt.footer {
    font-size: 16px;
  }
}

@media screen and (max-width: 479px) {
  .loading-animation-text {
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    font-size: 28px;
  }
  .side-bar {
    height: 80px;
    min-height: 80px;
    max-height: 80px;
  }

  .menu-line {
    width: 32px;
  }

  .branding-body {
    position: relative;
  }

  .fv-animation-txt {
    min-width: 300px;
  }

  .logo-link {
    width: 100%;
    min-width: 98px;
    max-width: 127px;
    top: auto;
    right: auto;
  }

  .footer-logo {
    width: 100%;
    min-width: 98px;
    max-width: 160px;
    top: auto;
    right: auto;
  }

  .fv-below-brand-section {
    padding-top: 100px;
    padding-bottom: 100px;
  }

  .brand-title-txt {
    font-size: 24px;
  }

  .brand-title-subtxt {
    letter-spacing: 0;
    font-size: clamp(14px, 4.26vw, 16px);
  }

  ._16px-basetxt {
    letter-spacing: 0;
    font-size: clamp(12px, 0.97vw, 14px);
  }

  .brand-1100px-wrapper {
    grid-row-gap: 64px;
    padding-top: 100px;
    padding-bottom: 100px;
  }

  .service-mono-wrap {
    top: -50px;
  }

  .service-mono-gray {
    font-size: 80px;
  }

  .service-mono-image {
    top: 13px;
  }

  .brand-botton {
    width: 80%;
    max-width: 335px;
    height: 50px;
    transition: all 0.6s;
  }

  .botton-txt.noto-sans {
    text-align: center;
    font-weight: 500;
    font-size: 14px;
  }

  .brand-grid.media {
    grid-row-gap: 40px;
  }

  .brand-footer-section {
    padding-bottom: 20px;
  }

  .space-between-wrap {
    grid-row-gap: 48px;
  }

  .footer-botton {
    width: 80%;
    max-width: 335px;
    height: 50px;
    padding-top: 0px;
    padding-bottom: 0px;
  }

  .footer-botton.navbar {
    width: 275px;
    min-width: auto;
  }

  .footer-botton-wrap {
    width: 100%;
  }

  .menu-inside {
    grid-row-gap: 64px;
    padding: 120px 0 60px;
  }

  .menu-titles {
    justify-content: flex-start;
    align-items: center;
  }

  .menu-wrap {
    width: 100%;
  }

  .modal-side {
    height: 80px;
  }

  .kasou-fv-brand-section {
    height: 100px;
    max-height: 100px;
  }

  .form-block-brand {
    width: 100%;
  }

  .form-cover {
    grid-row-gap: 8px;
  }

  .form-cover.align-top {
    grid-row-gap: 16px;
  }

  .brand-date-select-wrap {
    grid-row-gap: 8px;
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-start;
  }

  .brand-select-field {
    width: 60px;
    height: 30px;
  }

  ._90--wrapper {
    grid-row-gap: 64px;
  }

  .service-mono-white {
    font-size: 80px;
  }

  .div-block {
    max-height: 100px;
  }

  .side-bar-scrolled {
    height: 80px;
  }

  .mwform-checkbox-field label,
  .mwform-radio-field label {
    font-size: 12px;
  }

  .select-right.check.submit {
    align-items: center;
  }
}
