.scrollAnim {
  opacity: 0;
  transition: all 1.5s ease-in;
}

.fadeIn {
  transform: translateY(20px);
}
.fadeIn.active {
  transform: translateY(0);
}

.scrollAnim.active {
  opacity: 1;
}

.main_title {
  display: flex;
  align-items: center;
  writing-mode: vertical-rl;
  margin: 0 auto;
  padding: 100px 0;
  letter-spacing: 0.4rem;
}
.main_title span {
  display: inline-block;
}
.main_title span.ja {
  font-size: 5rem;
  letter-spacing: 0.6rem;
}
.main_title span.en {
  font-size: 1.4rem;
  margin-top: 1em;
}
@media (max-width: 767px) {
  .main_title {
    padding: 2em 0;
  }
  .main_title span.ja {
    font-size: 2.4rem;
  }
}

.copy_sec {
  padding: 120px 0;
}
.copy_sec p {
  writing-mode: vertical-rl;
  font-size: 3.4rem;
  letter-spacing: 0.4rem;
  margin: 0 auto;
}
.copy_sec p span {
  display: inline-block;
  border-right: 2px solid var(--color_text);
  padding-right: 0.4em;
}
.copy_sec p span:not(:first-child) {
  margin-right: 1.8rem;
}
@media (max-width: 767px) {
  .copy_sec {
    padding: 4em 0;
  }
  .copy_sec p {
    font-size: 2rem;
  }
}

.story_sec {
  padding-bottom: 150px;
}
@media (max-width: 767px) {
  .story_sec {
    padding-bottom: 4em;
  }
}
.story_sec p {
  line-height: 2.2;
  text-indent: 1em;
}
.story_sec figure.gradient {
  position: relative;
  overflow: hidden;
}
.story_sec figure.gradient:before {
  content: "";
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  height: 150px;
  width: 120%;
  background: linear-gradient(180deg, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 60%, rgba(255, 255, 255, 0) 100%);
}
@media (max-width: 767px) {
  .story_sec figure.gradient:before {
    height: 15vw;
  }
}
.story_sec .contain {
  padding: 150px 0;
}
.story_sec .contain .inner {
  max-width: 820px;
  margin: auto;
  padding: 0 6%;
}
@media (max-width: 767px) {
  .story_sec .contain {
    padding: 4em 0;
  }
  .story_sec .contain .inner h3 {
    font-size: 2.4rem;
    margin-bottom: 1em;
  }
}
.story_sec .story_sec--title {
  position: relative;
  background: url(../img/story_bg.jpg) center/cover;
  height: 884px;
}
.story_sec .story_sec--title h2 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  color: #fff;
  text-align: center;
  font-size: 5rem;
  line-height: 1.8;
}
.story_sec .story_sec--title h2 span {
  display: block;
}
@media (max-width: 1000px) {
  .story_sec .story_sec--title {
    height: 30vw;
    padding: 4em 0;
  }
  .story_sec .story_sec--title h2 {
    font-size: 3.4rem;
  }
}
@media (max-width: 767px) {
  .story_sec .story_sec--title h2 {
    font-size: 2.4rem;
  }
}
.story_sec .story_sec--sentence {
  background-color: #9b9b9b;
  color: #fff;
}
.story_sec .story_sec--sentence h3 {
  font-size: 4rem;
  text-align: center;
  margin-bottom: 2em;
}
.story_sec .story_sec--sentence p {
  color: #fff;
}
.story_sec .story_sec--content .content_wrap {
  padding-top: 100px;
}
.story_sec .story_sec--content .content_wrap h3 {
  text-align: center;
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin: 0 auto;
}
.story_sec .story_sec--content .content_wrap h3 span {
  display: block;
}
.story_sec .story_sec--content .content_wrap h3 span.text {
  font-size: 2rem;
}
.story_sec .story_sec--content .content_wrap h3 span.num {
  font-size: 10rem;
  line-height: 1;
  padding: 0 0.4em 0.1em;
  margin-top: 0.3em;
  border-top: 2px solid var(--color_text);
  border-bottom: 2px solid var(--color_text);
}
.story_sec .story_sec--content .content_wrap p.sub_title {
  font-size: 4rem;
  margin: 2em 0 2em;
  text-align: center;
}
@media (max-width: 767px) {
  .story_sec .story_sec--content .content_wrap {
    padding-top: 4em;
  }
  .story_sec .story_sec--content .content_wrap h3 span.text {
    font-size: 2rem;
  }
  .story_sec .story_sec--content .content_wrap h3 span.num {
    font-size: 6rem;
    padding: 0.2em 0 0.3em;
  }
  .story_sec .story_sec--content .content_wrap p.sub_title {
    font-size: 2.4rem;
  }
}
.story_sec ul.story_slide {
  margin: 0 auto;
  padding: 0 40px;
  max-width: 900px;
}
.story_sec ul.story_slide li img {
  width: 100%;
}
.story_sec ul.story_slide button {
  width: 30px;
  height: 30px;
  border-top: 1px solid var(--color_text);
  border-right: 1px solid var(--color_text);
  transform: rotate(45deg);
}
.story_sec ul.story_slide button.slick-prev {
  left: 0;
  transform: rotate(-140deg);
}
.story_sec ul.story_slide button.slick-next {
  right: 0;
}
.story_sec ul.story_slide .slick-prev:before, .story_sec ul.story_slide .slick-next:before {
  content: "";
}
@media (max-width: 1020px) {
  .story_sec ul.story_slide {
    padding: 0 50px;
  }
  .story_sec ul.story_slide button.slick-prev {
    left: 18px;
  }
  .story_sec ul.story_slide button.slick-next {
    right: 18px;
  }
}

.thought_sec {
  background: url(../img/thought_bg.jpg) top center/cover;
  padding-bottom: 100px;
}
.thought_sec .sub_txt {
  text-align: center;
  font-size: 2.6rem;
  line-height: 2.2;
  font-weight: 600;
  padding-bottom: 100px;
}
.thought_sec .flex {
  margin: 0 auto;
  padding: 0 6%;
  gap: 1em;
}
.thought_sec .flex .inner.txt p {
  font-size: 1.6rem;
  line-height: 2;
  text-indent: 1em;
}
@media (min-width: 768px) {
  .thought_sec .flex {
    display: flex;
    justify-content: space-between;
    max-width: 820px;
  }
  .thought_sec .flex:not(:last-child) {
    margin-bottom: 100px;
  }
  .thought_sec .flex .inner {
    width: 50%;
    max-width: 380px;
  }
  .thought_sec .flex.reverse {
    flex-direction: row-reverse;
  }
}
@media (max-width: 767px) {
  .thought_sec {
    padding: 2em 0 4em;
  }
  .thought_sec .sub_txt {
    font-size: 2rem;
    padding-bottom: 2em;
  }
  .thought_sec .flex:not(:last-child) {
    margin-bottom: 3em;
  }
  .thought_sec .flex .inner:not(:last-child) {
    margin-bottom: 1em;
  }
}

.content_sec {
  padding: 100px 0;
}
.content_sec .wrap_title {
  text-align: center;
  margin-bottom: 4em;
}
.content_sec .wrap_title h3 + p {
  margin-top: 2em;
}
.content_sec .wrap_title h3 span {
  display: block;
}
.content_sec .wrap_title h3 span.txt1 {
  font-size: 2rem;
}
.content_sec .wrap_title h3 span.txt2 {
  font-size: 6rem;
}
.content_sec .wrap_title h3 span.txt3 {
  font-size: 1.6rem;
}
.content_sec .wrap_title .sub_title {
  font-size: 2.6rem;
  line-height: 2;
}
@media (max-width: 767px) {
  .content_sec {
    padding: 0 0 4em;
  }
  .content_sec .wrap_title {
    padding: 4em 0 0;
    margin-bottom: 2em;
  }
  .content_sec .wrap_title h3 + p {
    margin-top: 1em;
  }
  .content_sec .wrap_title h3 span.txt1 {
    font-size: 1.6rem;
  }
  .content_sec .wrap_title h3 span.txt2 {
    font-size: 4rem;
  }
  .content_sec .wrap_title h3 span.txt3 {
    margin-top: 1em;
  }
  .content_sec .wrap_title .sub_title {
    font-size: 2rem;
  }
}

.border_bottom {
  position: relative;
}
.border_bottom:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 88%;
  max-width: 820px;
  height: 10px;
  background: var(--color_text);
}
@media (max-width: 767px) {
  .border_bottom:after {
    height: 6px;
  }
}

.plan_row figure.img {
  max-width: 600px;
  margin: 0 auto;
  padding: 0 10%;
}
.plan_row figure.img + * {
  margin-top: 100px;
}
.plan_row .wrap_txt {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 6%;
}
.plan_row .wrap_txt h4 {
  font-size: 2.4rem;
}
.plan_row .wrap_txt p {
  line-height: 2.2;
  text-indent: 1em;
}
.plan_row .wrap_txt .inner p {
  text-indent: 0;
}
@media (max-width: 767px) {
  .plan_row figure.img + * {
    margin-top: 2em;
  }
  .plan_row .wrap_txt h4 {
    font-size: 2rem;
    margin-bottom: 0.4em;
  }
}

.color_row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 70px 20px;
  max-width: 820px;
  margin: 0 auto;
  padding: 0 6%;
}
.color_row figure {
  width: calc(50% - 10px);
}
.color_row figure figcaption {
  text-align: center;
  margin-top: 1em;
}
@media (max-width: 767px) {
  .color_row {
    gap: 40px 20px;
  }
}

.summary_row {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 6%;
}
.summary_row .inner {
  margin-bottom: 10%;
}
.summary_row .inner.last {
  margin-bottom: 5%;
}
.summary_row .inner span {
  display: inline-block;
  width: 100%;
  max-width: 100px;
  text-align: center;
  background-color: #929497;
  color: #fff;
  padding: 0.2em 1em 0.4em;
  font-weight: bold;
}
.summary_row .inner table thead th, .summary_row .inner table td {
  padding-top: 20px;
}
.summary_row ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.summary_row ul li {
  font-size: 1.4rem;
}
.summary_row ul li:not(:last-child) {
  margin-bottom: 0.4em;
}

.contact_wrap .wrap_txt {
  width: 88%;
  max-width: 820px;
  margin: 0 auto;
  padding: 2em 1em;
  border-top: 1px solid var(--color_text);
  border-bottom: 1px solid var(--color_text);
}
.contact_wrap .wrap_txt p {
  text-align: center;
}
.contact_wrap .wrap_txt p.txt1 {
  font-size: 2rem;
  margin-bottom: 1em;
}
.contact_wrap .wrap_txt p.txt2 {
  font-size: 4rem;
}
.contact_wrap .wrap_txt p.txt3 {
  font-size: 2rem;
  margin-top: 1em;
}
@media (max-width: 767px) {
  .contact_wrap .wrap_txt p.txt1 {
    font-size: 1.6rem;
  }
  .contact_wrap .wrap_txt p.txt2 {
    font-size: 2rem;
  }
  .contact_wrap .wrap_txt p.txt3 {
    font-size: 1.6rem;
  }
}
.contact_wrap .wrap_tel {
  text-align: center;
  padding-top: 4em;
}
.contact_wrap .wrap_tel p.txt1 {
  font-size: 4rem;
}
.contact_wrap .wrap_tel p.txt2 {
  font-size: 5rem;
}
.contact_wrap .wrap_tel p.txt3 {
  text-align: left;
  margin: 0.5em auto 0;
  display: inline-block;
  line-height: 2;
}
@media (max-width: 767px) {
  .contact_wrap .wrap_tel {
    padding-top: 2em;
  }
  .contact_wrap .wrap_tel p.txt2 {
    font-size: 3rem;
  }
}
.contact_wrap .wrap_web {
  padding-top: 4em;
}
.contact_wrap .wrap_web p.txt1 {
  text-align: center;
  font-size: 4rem;
  margin-bottom: 0.5em;
}
/*.contact_wrap .wrap_web ul {
  display: table;
  margin: 0 auto;
  padding-left: 0;
}
.contact_wrap .wrap_web ul li {
  margin-left: 2em;
  font-size: 3rem;
}
.contact_wrap .wrap_web ul li:not(:last-child) {
  margin-bottom: 0.5em;
}
.contact_wrap .wrap_web ul li ul {
  margin-top: 0.5em;
}
.contact_wrap .wrap_web ul li ul li {
  margin-left: 0;
}
@media (max-width: 767px) {
  .contact_wrap .wrap_web ul li {
    font-size: 2rem;
  }
}*/

footer {
  padding: 4em 0;
  border-top: 1px solid var(--color_text);
}
@media (max-width: 767px) {
  footer {
    padding: 2em;
  }
}/*# sourceMappingURL=style.css.map */



/* ----------------------------------------------
    form
---------------------------------------------- */
.contact_wrap form {
	width: 90%;
	max-width: 820px;
	margin: 0 auto;
	padding: 1em 0 0;
    box-sizing: border-box;
}
.contact_wrap form * {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
.contact_wrap form > dl {
    display: grid;
    gap: 1.5em;
}
.contact_wrap form > dl > div {
	padding: 0 0 1.5em;
	border-bottom: 1px solid #ddd;
    display: flex;
    gap: 1em 2em;
    align-items: center;
}
.contact_wrap form dl > div:has(dd .mail),
.contact_wrap form dl > div:has(dd .pass),
.contact_wrap form dl > div:has(dd .address),
.contact_wrap form dl > div:has(dd .company),
.contact_wrap form dl > div.overseas,
.contact_wrap form dl > div:has(dd textarea) {
    align-items: baseline;
}
.contact_wrap form dl dt {
	width: 220px;
	line-height: 1;
    display: flex;
    gap: .5em;
    flex-shrink: 0;
    align-items: baseline;
}
.contact_wrap form dl dt h4 {
    font-weight: 600;
}
.contact_wrap form dl dt .required {
    width: 40px;
    height: 20px;
    color: #fff;
    background: #d34242;
    font-size: 1.2rem;
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
}
.contact_wrap form dl dd {
	width: 100%;
	display: flex;
    gap: 1em 0;
    flex-direction: column;
}
.contact_wrap form input,
.contact_wrap form select,
.contact_wrap form textarea {
	appearance: none;
    -webkit-appearance: none;
    width: 100%;
    height: 40px;
    padding: .5em;
	background: #fff;
	border: 1px solid #ddd;
    font-size: 1.6rem;
    cursor: pointer;
}
.contact_wrap form .select {
	width: 100%;
    position: relative;
}
.contact_wrap form .select::after {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    border-bottom: 1px solid #333;
    border-right: 1px solid #333;
    position: absolute;
    top: 45%;
    right: 1em;
    transform: rotate(45deg) translateY(-50%);
    pointer-events: none;
}
.contact_wrap form textarea {
    min-height: 160px;
}
.contact_wrap form input:focus-visible,
.contact_wrap form select:focus-visible,
.contact_wrap form textarea:focus-visible {
    outline: none;
    border: 1px solid #333;
}
.contact_wrap form .name {
    display: flex;
    gap: 1em;
}
.contact_wrap form .name input {
    max-width: 200px;
}
.contact_wrap form .tel {
    display: flex;
    gap: 0 .5em;
    align-items: center;
}
.contact_wrap form .tel input {
    max-width: 100px;
}
.contact_wrap form .address {
    width: 100%;
}
.contact_wrap form .address dl {
    display: grid;
    gap: 1em;
}
.contact_wrap form .address dl div {
    display: flex;
    gap: 1em;
    align-items: center;
}
.contact_wrap form .address dl div dt {
    width: 130px;
    letter-spacing: 0;
}
.contact_wrap form .address dl div dd {
    width: 100%;
}
.contact_wrap form .address dl div dd .zip {
    display: flex;
    gap: 0 .5em;
    align-items: center;
}
.contact_wrap form .address dl div dd .zip input {
    max-width: 100px;
}
.contact_wrap form .address dl div dd .zip .search {
    width: 100px;
    height: 40px;
    margin: 0 0 0 1em;
    color: #fff;
    background: #333;
    font-size: 1.6rem;
    line-height: 1;
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.contact_wrap form .address dl div dd .select {
    max-width: 200px;
}

.contact_wrap form .day {
    display: flex;
    align-items: center;
    gap: .5em;
}
.contact_wrap form .day .select {
    width: 100px;
}
.contact_wrap form .day .select.time {
    width: 150px;
}

.contact_wrap form .check,
.contact_wrap form .radio {
	list-style: none;
    display: flex;
    gap: .5em 1em;
    flex-wrap: wrap;
    align-items: center;
}
.contact_wrap form .check li {
    display: flex;
    gap: .5em;
    flex-wrap: wrap;
}
.contact_wrap form .check li input[type="checkbox"],
.contact_wrap form .radio li input[type="radio"] {
	display: none;
}
.contact_wrap form .check li input[type="text"] {
    max-width: 200px;
    max-height: 35px;
}
.contact_wrap form .check li label,
.contact_wrap form .radio li label {
    font-size: 1.6rem;
	display: flex;
	gap: 0 .5em;
    align-items: center;
	cursor: pointer;
}
.contact_wrap form .check li label span,
.contact_wrap form .radio li label span {
	width: 1.3em;
    aspect-ratio: 1;
    background: #fff;
    border: 1px solid #ddd;
    display: grid;
    flex-shrink: 0;
    place-items: center;
    transition: border 0.2s linear;
    -webkit-transition: border 0.2s linear;
	transition: background 0.2s linear;
	-webkit-transition: background 0.2s linear;
}
.contact_wrap form .radio li label span {
	border-radius: 100vmax;
}
.contact_wrap form .check li label span::before,
.contact_wrap form .radio li label span::before {
    content: "";
    width: .3em;
    aspect-ratio: 7 / 10;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(45deg) translate(-.05em, -.05em);
    -ms-transform: rotate(45deg) translate(-.05em, -.05em);
    -webkit-transform: rotate(45deg) translate(-.05em, -.05em);
    transition: opacity 0.2s linear;
    -webkit-transition: opacity 0.2s linear;
    opacity: 0;
}
.contact_wrap form .radio li label span::before {
    width: .5em;
    aspect-ratio: 1;
    background: #fff;
    border-radius: 100vmax;
    transform: none;
    -ms-transform: none;
    -webkit-transform: none;
}
.contact_wrap form .check li input:checked + label span,
.contact_wrap form .radio li input:checked + label span {
	background: #333;
}
.contact_wrap form .check li input:checked + label span::before,
.contact_wrap form .radio li input:checked + label span::before {
	opacity: 1.0;
}
.contact_wrap form .privacy {
    margin: 3em 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.contact_wrap form .privacy a {
    color: var(--color-Red);
    text-decoration: underline;
}
.contact_wrap form .submit {
    margin: 3em auto 0;
}
.contact_wrap form .submit ul {
    display: flex;
    gap: 0 2em;
    align-items: center;
    justify-content: center;
}
.contact_wrap form .submit ul li {
    width: 48%;
    max-width: 280px;
    list-style: none;
}
.contact_wrap form .submit ul li button {
	appearance: none;
    -webkit-appearance: none;
    width: 100%;
    max-width: 330px;
    height: 45px;
    margin: 0 auto;
    border-radius: 100vmax;
    font-size: 2.0rem;
    font-weight: 700;
    text-align: center;
    line-height: 1;
	display: grid;
    place-content: center;
}
.contact_wrap form .submit ul li button.next {
	color: #fff;
    background: #333;
}
.contact_wrap form .submit ul li button.prev {
    background: #ddd;
}
.contact_wrap .form-end {
    width: 90%;
    margin: 0 auto;
    text-align: center;
    box-sizing: border-box;
}
.contact_wrap .form-end h4 {
    font-size: 2.6rem;
}
.contact_wrap .form-end p {
    margin: 1em 0 0;
}
@media (min-width: 768px) {
	.contact_wrap form .address dl div dd .zip .search br {
	    display: none;
	}
}
@media (max-width: 767px) {
	.contact_wrap form > dl > div {
	    flex-direction: column;
	}
	.contact_wrap form dl dt {
	    width: 100%;
	}
	.contact_wrap form input,
	.contact_wrap form select,
	.contact_wrap form textarea {
	    height: 40px;
	    font-size: 1.4rem;
	}
	.contact_wrap form .address dl div dt {
	    width: 100px;
	}
	.contact_wrap form .address dl div dd .zip .search {
	    width: 50px;
	    height: 40px;
        margin: 0 0 0 .5em;
	    font-size: 1.2rem;
	}
	.contact_wrap form .address dl div dd .select {
	    max-width: 150px;
	}
	.contact_wrap form .day {
		gap: 1em .5em;
	    flex-wrap: wrap;
	}
	.contact_wrap form .day .select {
	    width: 70px;
	}
	.contact_wrap form .check,
	.contact_wrap form .radio {
	    align-items: flex-start;
	    flex-direction: column;
	}
	.contact_wrap form .check li label,
	.contact_wrap form .radio li label {
	    font-size: 1.4rem;
	}
	.contact_wrap form .submit ul {
	    gap: 1em 0;
	    flex-direction: column;
	}
	.contact_wrap form .submit ul li {
	    width: 100%;
	}
	.contact_wrap form .submit ul li button {
	    font-size: 1.6rem;
	}
	.contact_wrap form .submit ul li button i {
	    width: 1em;
	}
	
	.contact_wrap .form-end h4 {
	    font-size: 2.0rem;
	}
}