body {
  margin: 0;
  padding-top: 0;
}

.sp {
  padding-top: 64px;
}

.sp {
  max-width: 375px;
  width: 100%;
  min-height: 100vh;
  margin: 0 auto;
  position: relative;
  overflow-x: hidden;
  background: #fff;
  padding-bottom: 120px;
}
.sp {
  background-color: var(--color-white);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  isolation: isolate;
  gap: var(--gap-8);
  line-height: normal;
  letter-spacing: normal;
  text-align: left;
  font-size: var(--fs-16);
  color: var(--color-gray-100);
  font-family: var(--font-noto-sans-jp);
  
  
}
.header {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 375px;
  max-width: 100vw;
  height: 64px;
  background-color: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 3000;

  display: flex;
  align-items: flex-end;
  padding: 4px 24px;
  box-sizing: border-box;
}
.logo {
  height: var(--height-48);
  width: 256px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.rectangle-icon {
  width: 62px;
  position: relative;
  max-height: 100%;
  object-fit: cover;
}
.instagramlogo {
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--padding-0) var(--padding-8) var(--padding-3) var(--padding-0);
  box-sizing: border-box;
  width: px;
  height: px;
  top: 3px;
  cursor: pointer;
}
.hamburgerbutton-icon,
.vector-icon {
  cursor: pointer;
  border: 0;
  padding: 0;
  background-color: transparent;
  height: 20px;
  width: var(--width-20);
  position: relative;
}
.hamburgerbutton-icon {
  height: 30px;
  width: var(--width-30);
}
.hero,
.herocopy {
  width: var(--width-375);
  display: flex;
  box-sizing: border-box;
  margin-top: 24px;
}
.hero {
  background-color: var(--color-white);
  flex-direction: column;
  align-items: center;
  padding: 86px var(--padding-0) var(--padding-0);
  z-index: 13;
  padding-top: 0;
}
.herocopy {
  height: 104px;
  align-items: flex-start;
  justify-content: space-between;
  padding: var(--padding-0) var(--padding-24);
  gap: 20px;
}
.h2 {
  margin: 0;
  position: relative;
  font-size: inherit;
  letter-spacing: 0.25em;
  line-height: 200%;
  font-weight: 300;
  font-family: inherit;
  text-shadow: var(--text-shadow-1);
}
.heroimage-icon,
.logo-icon {
  position: relative;
  object-fit: cover;
}
.logo-icon {
  width: 80px;
  max-height: 100%;
}
.heroimage-icon {
  width: var(--width-375);
  height: 275px;
  margin-top: -1px;
}
.experiencecard,
.zerotorelogo {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.zerotorelogo {
  width: var(--width-375);
  height: 120px;
  padding: var(--padding-16) var(--padding-0);
  box-sizing: border-box;
  z-index: 12;
  text-align: center;
  font-size: var(--fs-14);
  color: var(--color-dimgray-100);
  font-family: var(--font-noto-sans-jp);
}
.experiencecard {
  flex-shrink: 0;
}
.tvsns {
  margin: 0;
  width: 306px;
  height: 25px;
  font-size: inherit;
  letter-spacing: 0.25em;
  line-height: 157%;
  font-weight: 400;
  font-family: inherit;
  display: inline-block;
}
.button,
.h3,
.tvsns {
  position: relative;
}
.h3 {
  margin: 0;
  font-size: var(--fs-24);
  letter-spacing: 0.25em;
  line-height: 167%;
  font-weight: 400;
  font-family: inherit;
  color: var(--color-darkslategray);
}
.button {
  cursor: pointer;
  border: 0;
  padding: 0;
  background-color: transparent;
  font-size: var(--fs-16);
  letter-spacing: 0.37em;
  line-height: 157%;
  font-weight: 700;
  font-family: var(--font-noto-sans-jp);
  color: var(--color-tan);
  text-align: center;
  display: inline-block;
  text-shadow: var(--text-shadow-2);
}
.abouthanare,
.hanareintro,
.hanaretitle {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hanareintro {
  width: var(--width-375);
  overflow: hidden;
  padding: var(--padding-16) var(--padding-0);
  box-sizing: border-box;
  z-index: 11;
  text-align: center;
  font-size: var(--fs-24);
  color: var(--color-darkslategray);
  font-family: var(--font-noto-sans-jp);
}
.abouthanare,
.hanaretitle {
  flex-shrink: 0;
}
.abouthanare {
  width: 343px;
  height: 424px;
  background-color: var(--color-whitesmoke);
  overflow: hidden;
  padding: var(--padding-16) var(--padding-0);
  box-sizing: border-box;
  gap: var(--gap-16);
}
.hanaretitle {
  width: var(--width-350);
}
.hanare {
  margin: 0;
  position: relative;
  font-size: inherit;
  letter-spacing: 0.08em;
  line-height: 167%;
  font-weight: 500;
  font-family: var(--font-zen-kaku-gothic-new);
  color: var(--color-dimgray-100);
}
.div {
  font-size: var(--fs-12);
  letter-spacing: 0.12em;
}
.div,
.h32,
.yuka {
  position: relative;
  line-height: 167%;
}
.h32 {
  margin: 0;
  align-self: stretch;
  font-size: var(--fs-15);
  letter-spacing: 0.12em;
  font-weight: 400;
  font-family: inherit;
}
.yuka {
  width: 302px;
  font-size: var(--fs-11);
  letter-spacing: 0.1em;
  display: inline-block;
  flex-shrink: 0;
}
.aboutzerotore {
  width: var(--width-375);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 13px var(--padding-0) var(--padding-8);
  box-sizing: border-box;
  gap: var(--gap-8);
  z-index: 10;
  text-align: center;
  font-size: 13px;
  color: var(--color-darkslategray);
  font-family: var(--font-noto-sans-jp);
}
.div2 {
  width: 256px;
  position: relative;
  letter-spacing: 0.11em;
  display: inline-block;
}
.div2,
.span,
.span2 {
  line-height: 174%;
}
.span2 {
  font-size: var(--fs-15);
}
.zerotoremessage {
  width: 100%;
  background-color: var(--color-white);
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: var(--padding-0) 40px var(--padding-0) 57px;
  box-sizing: border-box;
  gap: 3.5px;
  font-size: var(--fs-20);
  color: var(--color-cadetblue);
}
.h33,
.h34 {
  margin: 0;
  position: relative;
  line-height: 159%;
  font-weight: 400;
  font-family: inherit;
}
.h33 {
  font-size: inherit;
  letter-spacing: 0.15em;
  text-shadow: var(--text-shadow-3);
}
.h34 {
  font-size: var(--fs-14);
  color: var(--color-darkslategray);
}
.span4,
.span5 {
  letter-spacing: 0.12em;
  line-height: 159%;
}
.span5 {
  letter-spacing: 0.15em;
}
.decorationfeather-icon {
  height: 22.7px;
  width: var(--width-14);
  position: relative;
  object-fit: cover;
}
.worrieslist {
  width: var(--width-350);
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  align-content: flex-start;
  gap: 0;
}
.onayami01-icon {
  width: var(--width-350);
  position: relative;
  max-height: 100%;
  object-fit: cover;
}
.aboutzerotore2 {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--padding-0) var(--padding-0) var(--padding-8);
  gap: var(--gap-8);
  text-align: center;
  font-size: var(--fs-20);
  color: var(--color-cadetblue);
  font-family: var(--font-noto-sans-jp);
}
.logodecorationfeather {
  width: var(--width-350);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--padding-9) var(--padding-10);
  box-sizing: border-box;
}
.logotext {
  height: var(--height-48);
  width: 140px;
  position: relative;
  background-color: var(--color-white);
  overflow: hidden;
  flex-shrink: 0;
}
.h35,
.h36 {
  margin: 0;
  position: absolute;
  letter-spacing: 0.15em;
  line-height: 167%;
  font-weight: 400;
  font-family: inherit;
}
.h35 {
  top: 2px;
  left: 8px;
  font-size: inherit;
  text-shadow: var(--text-shadow-3);
}
.h36 {
  top: 7px;
  left: 100px;
  font-size: var(--fs-14);
  color: var(--color-darkslategray);
}
.logotext-child {
  position: absolute;
  top: 35.5px;
  left: 7.5px;
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.25));
  border-top: var(--border-11);
  box-sizing: border-box;
  width: 129px;
  height: var(--height-1);
}
.decorationfeather-icon2 {
  width: var(--width-14);
  position: relative;
  max-height: 100%;
  object-fit: cover;
}
.hanare2 {
  width: 328px;
  height: 256px;
  position: relative;
  font-size: var(--fs-12);
  letter-spacing: 0.1em;
  line-height: 167%;
  color: var(--color-darkslategray);
  text-align: left;
  display: inline-block;
}
.stepsimage,
.zerotreimage {
  display: flex;
  flex-direction: column;
  gap: var(--gap-8);
}
.zerotreimage {
  overflow: hidden;
  align-items: center;
  font-size: var(--fs-17);
}
.stepsimage {
  align-items: flex-start;
}
.stepslogo {
  width: var(--width-350);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--padding-10) var(--padding-0);
  box-sizing: border-box;
}
.h22 {
  margin: 0;
  position: relative;
  font-size: inherit;
  letter-spacing: 0.15em;
  font-weight: 400;
  font-family: inherit;
  text-shadow: var(--text-shadow-3);
}
.div3,
.h22,
.span7 {
  line-height: 167%;
}
.div3 {
  position: relative;
  letter-spacing: 0.15em;
  color: var(--color-darkslategray);
  font-size: var(--fs-12);
}
.span7 {
  font-size: var(--fs-15);
}
.cycleimage,
.cyclelogo {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.cycleimage {
  gap: var(--gap-8);
  font-size: var(--fs-12);
  color: var(--color-darkslategray);
}
.cyclelogo {
  overflow: hidden;
  padding: var(--padding-0) 100px;
  gap: var(--gap-6);
}
.div4 {
  width: 150px;
  letter-spacing: 0.1em;
  line-height: 167%;
}
.div4,
.div6,
.h23 {
  position: relative;
  display: inline-block;
}
.h23 {
  margin: 0;
  width: 91px;
  font-size: var(--fs-17);
  letter-spacing: 0.15em;
  line-height: 160%;
  font-weight: 400;
  font-family: inherit;
  color: var(--color-cadetblue);
  text-shadow: var(--text-shadow-3);
}
.div6 {
  width: 328px;
  font-size: var(--fs-10);
  letter-spacing: 0.1em;
  line-height: 167%;
}
.zerotorecycle-icon {
  width: 343px;
  position: relative;
  max-height: 100%;
  object-fit: cover;
}
.beforeafter {
  width: var(--width-375);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--gap-8);
  z-index: 9;
  text-align: left;
  font-size: var(--fs-17);
  color: var(--color-darkslategray);
  font-family: var(--font-noto-sans-jp);
}
.logotext2 {
  height: var(--height-48);
  width: 246px;
  position: relative;
  background-color: var(--color-white);
  overflow: hidden;
  flex-shrink: 0;
}
.beforeafter2 {
  position: absolute;
  top: 6px;
  left: 5.5px;
  letter-spacing: 0.15em;
  display: inline-block;
  width: 240px;
  flex-shrink: 0;
}
.before,
.beforeafter2,
.span9 {
  line-height: 167%;
}
.span9 {
  font-size: 13px;
}
.logotext-item {
  position: absolute;
  top: 35.5px;
  left: 7.5px;
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.25));
  border-top: var(--border-11);
  box-sizing: border-box;
  width: 230px;
  height: var(--height-1);
  flex-shrink: 0;
}
.div8 {
  position: relative;
  font-size: var(--fs-9);
  letter-spacing: 0.1em;
  line-height: 167%;
}
.beforeaftergallery {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  z-index: 8;
}
.beforeaftercarousel,
.carouseltrack {
  width: var(--width-375);
  display: flex;
  align-items: flex-start;
}
.beforeaftercarousel {
  overflow-x: auto;
  flex-direction: column;
  padding: var(--padding-0) var(--padding-0) var(--padding-32);
  box-sizing: border-box;
}
.carouseltrack {
  height: 330px;
  background-color: var(--color-white);
  overflow: hidden;
  flex-shrink: 0;
  gap: 23px;
}
.beforeaftercard01-icon {
  height: 330px;
  width: 330px;
  position: relative;
  object-fit: cover;
  flex-shrink: 0;
}
.instructor {
  width: var(--width-375);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--padding-0) var(--padding-8) var(--padding-16);
  box-sizing: border-box;
  gap: var(--gap-16);
  z-index: 7;
  text-align: left;
  font-size: var(--fs-17);
  color: var(--color-darkslategray);
  font-family: var(--font-noto-sans-jp);
}
.div9 {
  height: var(--height-48);
  width: auto;
  min-width: 186px;
  position: relative;
  background-color: var(--color-white);
  overflow: hidden;
  flex-shrink: 0;
}
.child,
.div10 {
  position: absolute;
  flex-shrink: 0;
}
.child {
  top: 35.5px;
  left: 7.5px;
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.25));
  border-top: var(--border-11);
  box-sizing: border-box;
  width: 182px;
  height: var(--height-1);
}
.div10 {
  top: 7px;
  left: 0.5px;
  line-height: 167%;
}
.span10,
.span14 {
  letter-spacing: 0.15em;
  line-height: 167%;
}
.span14 {
  letter-spacing: 0.14em;
}
.aboutyuka,
.instructorimage {
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  box-sizing: border-box;
}
.instructorimage {
  width: 343px;
  height: 252px;
  align-items: center;
  justify-content: flex-end;
  padding: var(--padding-0) var(--padding-16);
  background-image: url(./public/InstructorImage@3x.png);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top;
  text-align: right;
  font-size: var(--fs-10);
  color: var(--color-black);
}
.aboutyuka {
  width: 173px;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--padding-16) var(--padding-0);
  gap: var(--gap-16);
}
.div11 {
  align-self: stretch;
  letter-spacing: 0.1em;
}
.div11,
.instagram,
.yuka2 {
  position: relative;
  line-height: 167%;
}
.yuka2 {
  margin: 0;
  align-self: stretch;
  font-size: var(--fs-15);
  letter-spacing: 0.15em;
  font-weight: 400;
  font-family: inherit;
}
.instagram {
  width: 170px;
  height: 120px;
  letter-spacing: 0.1em;
  display: inline-block;
}
.story {
  width: 343px;
  background-color: var(--color-whitesmoke);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--padding-10) var(--padding-16);
  box-sizing: border-box;
  gap: var(--gap-10);
  font-size: var(--fs-12);
}
.div12,
.div13,
.div14,
.ny {
  position: relative;
  line-height: 167%;
  display: inline-block;
}
.div12 {
  width: 255px;
  letter-spacing: 0.15em;
}
.div13,
.div14,
.ny {
  letter-spacing: 0.1em;
}
.ny {
  width: 304px;
  font-size: var(--fs-10);
}
.div13,
.div14 {
  width: 217px;
}
.div14 {
  width: 304px;
  height: 207px;
  font-size: var(--fs-10);
}
.aboutlesson,
.logodecorationfeather4 {
  overflow: hidden;
  display: flex;
  align-items: center;
  box-sizing: border-box;
}
.aboutlesson {
  width: var(--width-375);
  background-color: var(--color-white);
  flex-direction: column;
  padding: var(--padding-16) var(--padding-10) var(--padding-24);
  gap: var(--gap-8);
  z-index: 6;
  text-align: left;
  font-size: var(--fs-9);
  color: var(--color-darkslategray);
  font-family: var(--font-noto-sans-jp);
}
.logodecorationfeather4 {
  width: var(--width-350);
  justify-content: center;
  padding: var(--padding-9) var(--padding-10);
  font-size: var(--fs-17);
}
.div15 {
  height: var(--height-48);
  width: 150px;
  position: relative;
  background-color: var(--color-white);
  overflow: hidden;
  flex-shrink: 0;
}
.div16,
.item {
  position: absolute;
  flex-shrink: 0;
}
.item {
  top: 35.5px;
  left: -0.5px;
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.25));
  border-top: var(--border-11);
  box-sizing: border-box;
  width: 146px;
  height: var(--height-1);
}
.div16 {
  top: 7px;
  left: 0;
  letter-spacing: 0.15em;
  line-height: 167%;
}
.div16 {
  letter-spacing: 0;
}

.div16 .before {
  letter-spacing: 0.15em;
}

.div16 .span7 {
  letter-spacing: 0.15em;
}
.div17,
.lessoncard01 {
  height: 54px;
  flex-shrink: 0;
}
.lessoncard01 {
  width: var(--width-310);
  background-color: var(--color-white);
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  align-content: flex-start;
  gap: 0 var(--gap-10);
}
.div17 {
  width: var(--width-73);
  position: relative;
  letter-spacing: 0.1em;
  display: inline-block;
}
.div17,
.line,
.span18 {
  line-height: 167%;
}
.line {
  height: 54px;
  width: 201px;
  position: relative;
  letter-spacing: 0.1em;
  display: inline-block;
  flex-shrink: 0;
  font-size: var(--fs-10);
}
.span18 {
  font-size: var(--fs-12);
}
.lessoncard02 {
  width: var(--width-310);
  background-color: var(--color-white);
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  align-content: flex-start;
  gap: var(--gap-10);
}
.div18 {
  width: var(--width-73);
  position: relative;
  letter-spacing: 0.1em;
  line-height: 167%;
  display: inline-block;
}
.div18,
.lessoncard03,
.line3 {
  height: var(--height-40);
  flex-shrink: 0;
}
.line3 {
  width: 208px;
  position: relative;
  font-size: var(--fs-10);
  letter-spacing: 0.1em;
  line-height: 167%;
  display: inline-block;
}
.lessoncard03 {
  width: var(--width-310);
  background-color: var(--color-white);
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  align-content: flex-start;
  gap: var(--gap-10);
}
.div19 {
  height: 45px;
  width: var(--width-73);
  position: relative;
  letter-spacing: 0.1em;
  line-height: 167%;
  display: inline-block;
  flex-shrink: 0;
}
.div20 {
  width: 208px;
  font-size: var(--fs-10);
}
.befoerafter-ok,
.div20,
.div21 {
  position: relative;
  letter-spacing: 0.1em;
  line-height: 167%;
  display: inline-block;
  flex-shrink: 0;
}
.div21 {
  width: var(--width-73);
}
.befoerafter-ok {
  height: 128px;
  width: 208px;
  font-size: var(--fs-10);
  white-space: pre-wrap;
}
.faq {
  width: var(--width-375);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gap-16);
  z-index: 5;
  text-align: left;
  font-size: var(--fs-15);
  color: var(--color-black);
  font-family: var(--font-noto-sans-jp);
}
.logotext3 {
  height: var(--height-48);
  width: 132px;
  position: relative;
  background-color: var(--color-white);
  overflow: hidden;
  flex-shrink: 0;
}
.logotext-inner {
  position: absolute;
  top: 35.5px;
  left: 0.5px;
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.25));
  border-top: var(--border-11);
  box-sizing: border-box;
  width: 127px;
  height: var(--height-1);
  flex-shrink: 0;
}
.div24,
.span23 {
  line-height: 167%;
}
.div24 {
  position: absolute;
  top: 7px;
  left: 0.5px;
  letter-spacing: 0.15em;
  flex-shrink: 0;
}
.span23 {
  font-size: var(--fs-17);
}
.faqfield {
  width: var(--width-375);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gap-16);
  font-size: var(--fs-14);
  color: var(--color-mediumturquoise);
}
.faqcard01,
.question {
  display: flex;
  align-items: center;
  box-sizing: border-box;
}
.faqcard01 {
  width: var(--width-320);
  height: 130px;
  box-shadow: var(--shadow-drop);
  background-color: var(--color-white);
  border: var(--border-1);
  flex-direction: column;
  padding: var(--padding-8);
}
.question {
  width: var(--width-298);
  overflow: hidden;
  padding: var(--padding-6) var(--padding-0);
  gap: var(--gap-6);
}
.div25,
.q {
  position: relative;
  letter-spacing: 0.15em;
  line-height: 167%;
}
.q {
  margin: 0;
  font-size: inherit;
  font-weight: 900;
  font-family: inherit;
}
.div25 {
  font-size: var(--fs-11);
  color: var(--color-darkslategray);
}
.line4 {
  width: var(--width-298);
  height: var(--height-4);
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--padding-0) var(--padding-32);
}
.answer,
.line-child,
.line4 {
  box-sizing: border-box;
}
.line-child {
  width: var(--width-318);
  height: var(--height-1);
  position: relative;
  filter: drop-shadow(0 5.1px 5.1px rgba(0, 0, 0, 0.25));
  border-top: var(--border-2);
  flex-shrink: 0;
}
.answer {
  width: var(--width-298);
  height: var(--height-70);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--padding-8) var(--padding-0);
  font-size: var(--fs-9);
  color: var(--color-darkslategray);
}
.div26,
.div27,
.q2 {
  position: relative;
  flex-shrink: 0;
}
.div26 {
  width: var(--width-288);
  height: var(--height-70);
  letter-spacing: 0.1em;
  line-height: 149%;
  display: inline-block;
}
.div27,
.q2 {
  letter-spacing: 0.15em;
  line-height: 167%;
}
.q2 {
  margin: 0;
  font-size: inherit;
  font-weight: 900;
  font-family: inherit;
}
.div27 {
  width: 308px;
  font-size: var(--fs-11);
  color: var(--color-darkslategray);
  display: inline-block;
}
.answer3,
.faqcard03 {
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}
.faqcard03 {
  width: var(--width-320);
  height: 214px;
  box-shadow: var(--shadow-drop);
  background-color: var(--color-white);
  border: var(--border-1);
  align-items: center;
  padding: var(--padding-8);
}
.answer3 {
  width: var(--width-298);
  height: 154px;
  align-items: flex-start;
  padding: var(--padding-8) var(--padding-0);
  font-size: var(--fs-9);
  color: var(--color-darkslategray);
}
.div30,
.div31,
.div33 {
  position: relative;
  display: inline-block;
}
.div30 {
  width: var(--width-288);
  height: var(--height-70);
  letter-spacing: 0.1em;
  line-height: 149%;
}
.div31,
.div33 {
  width: 250px;
  font-size: var(--fs-11);
  letter-spacing: 0.15em;
  line-height: 167%;
  color: var(--color-darkslategray);
  flex-shrink: 0;
}
.div33 {
  width: 236px;
}
.access,
.logodecorationfeather6 {
  overflow: hidden;
  display: flex;
  align-items: center;
  box-sizing: border-box;
  flex-shrink: 0;
}
.access {
  width: var(--width-375);
  height: 439px;
  flex-direction: column;
  padding: var(--padding-8) var(--padding-0);
  gap: var(--gap-16);
  z-index: 4;
  text-align: left;
  font-size: var(--fs-17);
  color: var(--color-darkslategray);
  font-family: var(--font-noto-sans-jp);
}
.logodecorationfeather6 {
  width: var(--width-350);
  justify-content: center;
  padding: var(--padding-9) var(--padding-10);
}
.logotext4 {
  height: var(--height-48);
  width: 154px;
  position: relative;
  background-color: var(--color-white);
  overflow: hidden;
  flex-shrink: 0;
}
.logotext-child2 {
  position: absolute;
  top: 35.5px;
  left: -0.5px;
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.25));
  border-top: var(--border-11);
  box-sizing: border-box;
  width: 150px;
  height: var(--height-1);
  flex-shrink: 0;
}
.accesssummary,
.hanare4 {
  overflow: hidden;
  display: flex;
}
.accesssummary {
  width: 300px;
  height: 109px;
  flex-shrink: 0;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--padding-3) var(--padding-4);
  box-sizing: border-box;
  font-size: var(--fs-9);
}
.hanare4 {
  width: var(--width-286);
  background-color: var(--color-white);
  align-items: center;
  flex-wrap: wrap;
  align-content: center;
  gap: var(--gap-10) 9px;
}
.div35 {
  width: 39px;
  position: relative;
  letter-spacing: 0.1em;
  line-height: 167%;
  display: inline-block;
  flex-shrink: 0;
}
.place {
  width: var(--width-286);
  background-color: var(--color-white);
  overflow: hidden;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  align-content: center;
  padding: var(--padding-2) var(--padding-0);
  box-sizing: border-box;
  gap: 17px var(--gap-8);
}
.div36,
.f {
  position: relative;
  letter-spacing: 0.1em;
  line-height: 167%;
}
.f {
  font-size: var(--fs-10);
}
.adress,
.parking {
  width: var(--width-286);
  background-color: var(--color-white);
  overflow: hidden;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  align-content: center;
  padding: var(--padding-2) var(--padding-0);
  box-sizing: border-box;
}
.adress {
  gap: 17px 9px;
}
.parking {
  gap: 17px var(--gap-8);
  color: var(--color-white);
}
.div42 {
  position: relative;
  font-size: var(--fs-10);
  letter-spacing: 0.1em;
  line-height: 167%;
  color: var(--color-darkslategray);
}
.map-icon {
  width: 300px;
  height: 221px;
  position: relative;
  object-fit: cover;
  flex-shrink: 0;
}
.inquiry,
.logotext5 {
  overflow: hidden;
  flex-shrink: 0;
}
.inquiry {
  width: var(--width-375);
  height: 192px;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--padding-8) var(--padding-0);
  box-sizing: border-box;
  gap: var(--gap-16);
  z-index: 3;
  text-align: left;
  font-size: var(--fs-15);
  color: var(--color-darkslategray);
  font-family: var(--font-noto-sans-jp);
}
.logotext5 {
  height: var(--height-48);
  width: 108px;
  position: relative;
  background-color: var(--color-white);
}
.h37,
.logotext-child3 {
  position: absolute;
  flex-shrink: 0;
}
.logotext-child3 {
  top: 35.5px;
  left: 7.5px;
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.25));
  border-top: var(--border-11);
  box-sizing: border-box;
  width: 129px;
  height: var(--height-1);
}
.h37 {
  margin: 0;
  top: 7px;
  left: 0.5px;
  font-size: inherit;
  letter-spacing: 0.15em;
  line-height: 167%;
  font-weight: 400;
  font-family: inherit;
}
.inquirytext {
  width: 280px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--padding-3) var(--padding-4);
  box-sizing: border-box;
  font-size: var(--fs-10);
}
.line-line {
  width: 331px;
  height: 80px;
  position: relative;
  letter-spacing: 0.1em;
  line-height: 167%;
  display: inline-block;
  flex-shrink: 0;
}
.footer {
  width: var(--width-375);
  height: 43px;
  background-color: var(--color-dimgray-200);
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 2;
  font-size: var(--fs-10);
  color: var(--color-white);
}
.hanare-all-rights {
  position: relative;
  letter-spacing: 0.1em;
  line-height: 167%;
  white-space: pre-wrap;
}
.logo2,
.reterntop {
  height: var(--height-64);
  display: flex;
  flex-direction: column;
}
.reterntop {
  position: fixed;
  cursor: pointer;
  border: 0;
  padding: var(--padding-0) var(--padding-8);
  background-color: transparent;
  width: auto;
  margin: 0 !important;
  position: fixed;
  bottom: 72px;
  right: calc((100vw - min(375px, 100vw)) / 2 + -24px);
  left: auto;
  align-items: flex-end;
  justify-content: center;
  box-sizing: border-box;
  z-index: 1000;
}
.reterntop:hover img {
  animation: flyUp 0.8s ease;
 } 
.logo2 {
  width: 72px;
  overflow: hidden;
  flex-shrink: 0;
  align-items: center;
  gap: 4px;
}
.icon,
.page-top {
  position: relative;
}
.page-top {
  width: 44px;
  font-size: var(--fs-10);
  letter-spacing: 0.04em;
  line-height: 157%;
  font-family: var(--font-noto-sans-jp);
  color: var(--color-dimgray-100);
  text-align: right;
  display: inline-block;
}
.icon {
  width: var(--width-20);
  max-height: 100%;
  object-fit: cover;
  cursor: pointer;
}
.footercta {
  width: min(375px, calc(100vw - 32px));
  height: 78px;
  position: fixed;
  left: 50%;
  bottom: 0;
  padding-top: 4px;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
background-color: rgba(255,255,255,0.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 1000;
  font-family: var(--font-zen-kaku-gothic-new);
}

.cta {
  width: 301px;
  height: 53px;
  border-radius: 13px;
  background: linear-gradient(90deg, #50d5da 2.4%, #4a9295 100%);
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 11px 16px 8px 50px;
  box-sizing: border-box;
  gap: 8px;
  opacity: 1;
  filter: none;
}
.line9,
.div43,
.div44 {
  opacity: 1 !important;
  color: #fff;
}
.line-parent {
display: flex;
flex-direction: column;
justify-content: center;
}
.line9 {
  margin: 0;
  margin-bottom: 2px;
  width: 196px;
  height: auto;
  font-size: 14px;
  line-height: 1.3;
  white-space: nowrap;
  letter-spacing: 0.05em;
  font-weight: 700;
  font-family: inherit;
  display: inline-block;
  flex-shrink: 0;
  z-index: 1;
}
.div43,
.line9,
.wrapper {
  position: relative;
}
.wrapper {
  display: flex;
  align-items: flex-start;
  padding: var(--padding-0) 34px var(--padding-0) 42px;
  z-index: 2;
  margin-top: -1px;
  font-size: 11px;
}
.div43 {
  height: 19px;
  width: 117px;
  font-weight: 500;
  display: inline-block;
  flex-shrink: 0;
}
.bxsup-arrow-wrapper {
  cursor: pointer;
  border: 0;
  padding: var(--padding-0) var(--padding-0) var(--padding-3);
  background-color: transparent;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
}
.bxsup-arrow-icon {
  width: var(--width-30);
  position: relative;
  max-height: 100%;
}
.div44 {
  position: relative;
  font-size: var(--fs-12);
  letter-spacing: 0.04em;
  line-height: 157%;
  font-weight: 500;
  font-family: var(--font-noto-sans-jp);
  color: var(--color-darkslategray);
  text-align: right;
}

/* 見出しの文字切れだけ修正 */
.beforeafter2,
.div10,
.div16,
.div24,
.h37 {
  white-space: nowrap;
}

/* インストラクター紹介 */
.div9 {
  width: 200px;
}

/* レッスンについて */
.div15 {
  width: 153px;
}

/* よくあるご質問 */
.logotext3 {
  width: 137px;
}

/* 教室へのアクセス */
.logotext4 {
  width: 157px;
}

/* 下線を各タイトル幅に合わせる */
.child {
  width: 210px;
}

.item {
  width: 160px;
}

.logotext-inner {
  width: 140px;
}

.logotext-child2 {
  width: 180px;
}

/* Before & Afterだけ */
.logotext2 {
  width: 248px;
}

.logotext-item {
  width: 260px;
}

/* レッスンについて：カード高さと配置修正 */
.lessoncard01,
.lessoncard02,
.lessoncard03 {
  height: auto;
  min-height: 54px;
  align-items: flex-start;
  overflow: visible;
}

.lessoncard01 > div:first-child,
.lessoncard02 > div:first-child,
.lessoncard03 > div:first-child,
.lessoncard01 .div17,
.lessoncard02 .div18,
.lessoncard03 .div19,
.lessoncard03 .div21 {
  height: auto;
  min-height: 40px;
}

.lessoncard01 .line,
.lessoncard02 .line3,
.lessoncard03 .div20,
.lessoncard03 .befoerafter-ok {
  height: auto;
  min-height: 40px;
  overflow: visible;
}

.aboutlesson {
  height: auto;
  overflow: visible;
}

.befoerafter-ok {
  white-space: normal;
}

/* 羽根のスクロールアクション */
.footercta,
.footercta a,
.footercta a:visited,
.footercta a:hover,
.footercta a:active {
  text-decoration: none !important;
}

@keyframes featherFloat {
  0% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-6px);
  }

  100% {
    transform: translateY(0);
  }
}

.reterntop:hover .icon {
  animation: featherFloat 0.8s ease;
}

/* Googleマップ埋め込み */
.map-embed {
  width: 300px;
  height: 221px;
  overflow: hidden;
}

.map-embed iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}


/* SPメニュー画面 */
.mobile-menu-overlay {
  position: fixed;
  inset: 0;
  width: min(375px, 100vw);
  margin: 0 auto;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  z-index: 3000;
  display: none;
}

.mobile-menu-overlay.is-open {
  display: block;
}

.mobile-menu-header {
  height: 88px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 24px 24px 0;
}

.mobile-menu-logo {
  width: 72px;
  height: auto;
}

.mobile-menu-close {
  border: 0;
  background: transparent;
  font-size: 36px;
  line-height: 1;
  color: #8a8a8a;
  cursor: pointer;
}

.mobile-menu-panel {
  margin-left: 80px;
  width: calc(100% - 80px);
  min-height: calc(100vh - 88px);
  background: rgba(80, 213, 218, 0.55);
  display: flex;
  flex-direction: column;
  padding: 28px 0 0 44px;
  gap: 24px;
  box-sizing: border-box;
}

.mobile-menu-item {
  color: #555;
  text-decoration: none;
  font-size: 11px;
  letter-spacing: 0.12em;
}
/* SPメニューからのジャンプ位置調整 */
#hanare,
#about,
#beforeafter,
#instructor,
#lesson,
#faq,
#access,
#inquiry {
  scroll-margin-top: 90px;
}
/* Befoer＆Afterカルーセル */
.beforeaftercarousel {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 0 16px 32px;
  box-sizing: border-box;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.carouseltrack {
  width: max-content;
  height: auto;
  display: flex;
  gap: 16px;
  overflow: visible;
}

.beforeaftercard01-icon {
  width: 330px;
  height: 330px;
  object-fit: cover;
  flex-shrink: 0;
  cursor: pointer;
  scroll-snap-align: center;
}
.beforeafter-overlay {
  position: fixed;
  inset: 0;
  width: min(375px, 100vw);
  margin: 0 auto;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(255, 255, 255, 0.92);
  z-index: 4000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  box-sizing: border-box;
}

.beforeafter-overlay.is-open {
  display: flex;
}

.beforeafter-overlay-image {
  width: 100%;
  max-width: 343px;
  height: auto;
  object-fit: contain;
}

.beforeafter-overlay-close {
  position: absolute;
  top: 20px;
  right: 24px;
  border: 0;
  background: transparent;
  font-size: 32px;
  line-height: 1;
  color: #666;
  cursor: pointer;
}
.beforeaftergallery {
  width: 100%;
  max-width: 375px;
  overflow: hidden;
}

.beforeaftercarousel {
  width: 100%;
  overflow-x: auto !important;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  padding: 0 16px 32px;
  box-sizing: border-box;
}

.carouseltrack {
  width: max-content !important;
  height: auto !important;
  display: flex;
  flex-direction: row;
  gap: 16px;
  overflow: visible !important;
}

.beforeaftercard01-icon {
  width: 330px;
  height: 330px;
  flex: 0 0 auto;
  object-fit: cover;
  scroll-snap-align: center;
  cursor: pointer;
}
.beforeaftercarousel {
  scroll-snap-type: x mandatory;
}

.beforeaftercard01-icon {
  scroll-snap-align: center;
}
.js-beforeafter-card {
  cursor: pointer;
}
.pc-nav {
display: none;
}

.header {
  position: fixed;
  top: 0;
  z-index: 3000;
}

@media screen and (min-width: 768px) {
  .header {
    left: 0;
    transform: none;
    width: 100%;
  }
}
/* SPのFV応急処置 */
@media screen and (max-width: 767px) {
  .sp {
    max-width: 375px;
    width: 100%;
    margin: 0 auto;
    align-items: flex-start;
    padding-top: 64px;
    font-family: var(--font-noto-sans-jp);
  }

  .header {
    position: fixed;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 375px;
    max-width: 100vw;
    height: 64px;
    z-index: 3000;
  }

  .hero,
  .herocopy,
  .zerotorelogo,
  .hanareintro,
  .aboutzerotore,
  .beforeafter,
  .instructor,
  .aboutlesson,
  .faq,
  .access,
  .inquiry,
  .footer {
    width: 375px;
  }

  .h2 {
    font-family: var(--font-noto-sans-jp);
    font-size: var(--fs-16);
    line-height: 200%;
    letter-spacing: 0.25em;
  }

  .pc-nav {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .sp {
    padding-bottom: 88px;
  }

  .footer {
    margin-bottom: -10px;
  }
}
/* SPフッター幅調整 */
@media screen and (max-width: 767px) {
  .footer {
    width: 375px;
    max-width: 100vw;
    margin-left: 0;
    margin-right: 0;
    box-sizing: border-box;
  }
}
@media screen and (max-width: 767px) {
  .footer {
    width: 100vw !important;
    max-width: none !important;
    margin-left: 50% !important;
    margin-right: 0 !important;
    transform: translateX(-50%) !important;
    box-sizing: border-box;
  }
}
/* SPフッター幅調整 */
.logo-link {
  display: block;
  line-height: 0;
}

.logo-link img {
  display: block;
}

html {
  scroll-behavior: smooth;
}
/* ＬＩＮＥリッチメニューアンカー調整 */
.line-anchor {
  display: block;
  height: 1px;
}