@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
body {
  font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "MS Pゴシック", "MS PGothic", sans-serif;
}

html {
  font-size: 0.08333333vw;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.odk-fade-in-section {
  opacity: 0;
  transform: translateY(40rem);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.odk-fade-in-section.is-visible {
  opacity: 1;
  transform: translateY(0);
}

dl dt {
  -webkit-margin-start: 0rem;
          margin-inline-start: 0rem;
}
dl dd {
  -webkit-margin-start: 0rem;
          margin-inline-start: 0rem;
}

/* -------------------------------------------------------
   Challenge Item - match SVG layout (1200x491 canvas)
------------------------------------------------------- */
.odk-section-challenge {
  /* Badge block (orange ring + text + avatars) */
  /* Title and description block to the right of image */
  /* Image display control */
  /* Reversed layout */
  /* Only the 3rd challenge card's second avatar (avator_6.webp) */
}
@media screen and (max-width: 650px) {
  .odk-section-challenge {
    overflow-x: hidden;
  }
}
.odk-section-challenge .odk-section-challenge__item {
  position: relative;
  max-width: 1200rem;
  /* SVG canvas width */
  min-height: 392rem;
  /* card height */
  margin: 0 auto 80rem;
  border: 1rem solid #fff;
  border-radius: 10rem;
  background: rgba(255, 255, 255, 0.01);
  box-shadow: 0 10rem 20rem rgba(0, 0, 0, 0.1);
}
.odk-section-challenge .odk-section-challenge__item__flow {
  position: absolute;
  left: 19rem;
  /* x per svg */
  top: 20rem;
  bottom: 20rem;
  width: 353rem;
  height: auto;
  border-radius: 10rem;
  overflow: hidden;
}
.odk-section-challenge .odk-section-challenge__item__flow img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.odk-section-challenge .odk-section-challenge__item__content {
  position: relative;
  padding: 80rem 180rem 60rem 440rem;
  /* left aligns to svg text x=440 */
  min-height: 100%;
  box-sizing: border-box;
}
.odk-section-challenge .odk-section-challenge__item__content__title {
  position: absolute;
  top: -62rem;
  /* half of circle height (164/2) positioned outside the box */
  right: 0rem;
  /* half of circle width (164/2) positioned outside the box */
  width: 164rem;
  height: 164rem;
  /* outer circle diameter */
  display: flex;
  align-items: center;
  justify-content: center;
  /* outer ring */
  /* inner white circle */
  /* stacked texts inside circle */
  /* right-side avatars */
}
.odk-section-challenge .odk-section-challenge__item__content__title::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: #F08200;
  box-shadow: 0 0 0 10rem #fff inset;
  /* white ring ~10px */
}
.odk-section-challenge .odk-section-challenge__item__content__title::after {
  content: "";
  position: absolute;
  width: 136rem;
  height: 136rem;
  /* r=68 */
  border-radius: 50%;
  background: #fff;
}
.odk-section-challenge .odk-section-challenge__item__content__title__text {
  position: relative;
  z-index: 1;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 6rem;
}
.odk-section-challenge .odk-section-challenge__item__content__title__text__title {
  margin: 0;
  font-size: 18rem;
  font-weight: 700;
  color: #F08200;
  letter-spacing: 0em;
}
.odk-section-challenge .odk-section-challenge__item__content__title__text__subtitle {
  margin: 0;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 6rem;
  font-size: 25rem;
  font-weight: 700;
  color: #F08200;
  letter-spacing: 0em;
}
.odk-section-challenge .odk-section-challenge__item__content__title__text__subtitle span {
  font-size: 32rem;
  line-height: 1;
}
.odk-section-challenge .odk-section-challenge__item__content__title__image__1 {
  position: absolute;
  right: 120rem;
  top: -60rem;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 6rem;
  z-index: 2;
}
.odk-section-challenge .odk-section-challenge__item__content__title__image__2 {
  position: absolute;
  right: -30rem;
  top: 40rem;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 6rem;
  z-index: 2;
}
.odk-section-challenge .odk-section-challenge__item__content__text {
  position: relative;
  color: #fff;
}
.odk-section-challenge .odk-section-challenge__item__content__text__title {
  margin: 0 0 24rem 0;
  font-size: 34rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.35;
  position: relative;
  /* underline short line (x1=439 -> x2=581) => 142px */
}
.odk-section-challenge .odk-section-challenge__item__content__text__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -12rem;
  width: 142rem;
  height: 2rem;
  background: #fff;
}
.odk-section-challenge .odk-section-challenge__item__content__text__description {
  margin: 36rem 0 0 0;
  font-size: 18rem;
  font-weight: 400;
  line-height: 1.9;
}
.odk-section-challenge .odk-section-challenge__item__flow--mobile {
  display: none;
  /* Hidden on desktop */
}
.odk-section-challenge .odk-section-challenge__item__flow--desktop {
  display: block;
  /* Shown on desktop */
}
.odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__flow--desktop {
  left: auto;
  right: 19rem;
}
.odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content {
  padding: 80rem 440rem 60rem 140rem;
}
.odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content__title {
  right: auto;
  left: -40rem;
}
.odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content__title__image__1 {
  right: auto;
  left: -75rem;
  top: 50rem;
  transform: scaleX(1);
}
.odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content__title__image__2 {
  right: auto;
  left: 130rem;
  top: -30rem;
}
.odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content__text__title::after {
  left: 0;
  right: auto;
}
.odk-section-challenge .odk-section-challenge__container .odk-section-challenge__item:nth-of-type(3) .odk-section-challenge__item__content__title__image__2 {
  right: -95rem;
}
@media screen and (max-width: 650px) {
  .odk-section-challenge .odk-section-challenge__container .odk-section-challenge__item:nth-of-type(3) .odk-section-challenge__item__content__title__image__2 {
    right: -62rem;
  }
}
@media screen and (max-width: 650px) {
  .odk-section-challenge {
    /* Mobile image display control */
    /* Override --rev styles for mobile to match normal layout */
  }
  .odk-section-challenge .odk-section-challenge__item__flow--mobile {
    display: block;
    /* Show mobile version */
  }
  .odk-section-challenge .odk-section-challenge__item__flow--desktop {
    display: none;
    /* Hide desktop version */
  }
  .odk-section-challenge .odk-section-challenge__item {
    max-width: 100%;
    margin-bottom: 174rem;
    /* 42 * 1.75 */
    min-height: auto;
    padding: 35rem 35rem 49rem;
    /* 20 * 1.75, 28 * 1.75 */
    border-radius: 18rem;
    /* 10 * 1.75 */
  }
  .odk-section-challenge .odk-section-challenge__item:last-child {
    margin-bottom: 0rem;
  }
  .odk-section-challenge .odk-section-challenge__item__flow {
    position: relative;
    left: auto;
    top: auto;
    right: auto;
    width: 100%;
    height: 500rem;
    border-radius: 18rem;
    /* 10 * 1.75 */
    margin: 30rem 0 35rem;
    /* top 30rem, bottom 35rem */
  }
  .odk-section-challenge .odk-section-challenge__item__flow img {
    height: 100%;
  }
  .odk-section-challenge .odk-section-challenge__item__content {
    padding: 0;
  }
  .odk-section-challenge .odk-section-challenge__item__content__title {
    position: absolute;
    top: -760rem;
    right: -62rem;
    left: auto;
    margin: 0;
    /* place at card's top-right */
    width: 210rem;
    height: 210rem;
    /* Use desktop positions on mobile as requested */
  }
  .odk-section-challenge .odk-section-challenge__item__content__title::after {
    width: 176rem;
    height: 176rem;
  }
  .odk-section-challenge .odk-section-challenge__item__content__title__text {
    gap: 11rem;
    /* 6 * 1.75 */
  }
  .odk-section-challenge .odk-section-challenge__item__content__title__text__title {
    font-size: 22rem;
  }
  .odk-section-challenge .odk-section-challenge__item__content__title__text__subtitle {
    gap: 11rem;
    /* 6 * 1.75 */
    font-size: 32rem;
  }
  .odk-section-challenge .odk-section-challenge__item__content__title__text__subtitle span {
    font-size: 42rem;
  }
  .odk-section-challenge .odk-section-challenge__item__content__title__image__1, .odk-section-challenge .odk-section-challenge__item__content__title__image__2 {
    position: absolute;
    transform: none;
  }
  .odk-section-challenge .odk-section-challenge__item__content__title__image__1 {
    right: 180rem;
    top: -20rem;
    height: 179rem;
  }
  .odk-section-challenge .odk-section-challenge__item__content__title__image__2 {
    right: -10rem;
    top: 140rem;
    height: 182rem;
  }
  .odk-section-challenge .odk-section-challenge__item__content__text__title {
    font-size: 39rem;
    /* 22 * 1.75 */
    margin-bottom: 42rem;
    /* 24 * 1.75 */
  }
  .odk-section-challenge .odk-section-challenge__item__content__text__title::after {
    width: 196rem;
    /* 112 * 1.75 */
    bottom: -18rem;
    /* -10 * 1.75 */
    height: 4rem;
    /* 2 * 1.75 */
  }
  .odk-section-challenge .odk-section-challenge__item__content__text__description {
    margin-top: 63rem;
    /* 36 * 1.75 */
    font-size: 26rem;
    /* 15 * 1.75 */
    line-height: 1.8;
    letter-spacing: 0.02em;
  }
  .odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content {
    padding: 0;
    /* Reset rev padding */
  }
  .odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content__title {
    position: absolute;
    top: -760rem;
    right: -62rem;
    left: auto;
    margin: 0;
    /* Match desktop positions for avatars on mobile */
  }
  .odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content__title__image__1 {
    right: auto;
    left: -95rem;
    top: 50rem;
    transform: none;
    height: 179rem;
  }
  .odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content__title__image__2 {
    right: auto;
    left: 100rem;
    top: 140rem;
    transform: none;
    height: 182rem;
  }
  .odk-section-challenge .odk-section-challenge__item--rev .odk-section-challenge__item__content__text__title::after {
    left: 0;
    /* Reset to default left alignment */
  }
}

select {
  /* 初期化 */
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  background: none;
  border: none;
  color: #333;
  font-size: 16px;
  width: 100%;
  height: 100%;
  padding: 0 10px;
}

/* -------------------------------------------------------
   Vision Item - match SVG layout (1371x761 canvas)
------------------------------------------------------- */
.odk-section-vision {
  padding-top: 170rem;
  padding-right: 40rem;
  padding-left: 40rem;
  background-color: #F1F1F1;
  /* Title "Our Vision" */
  /* Sub-heading (Japanese) */
  /* Body text (Japanese) */
  /* Second vision row (mirror layout): place image right */
  /* Desktop Large */
  /* Medium Desktop */
}
.odk-section-vision .odk-section-vision__container {
  max-width: 1371rem;
  margin: 0 auto;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 60rem;
  position: relative;
  z-index: 10;
}
.odk-section-vision .odk-section-vision__item {
  position: relative;
  /* two variants: first item has left image, second item may mirror */
}
.odk-section-vision .odk-section-vision__item__flow {
  position: absolute;
  left: 0;
  top: 0;
  bottom: auto;
  width: 684rem;
  /* exact flow width per requirement */
  height: auto;
  overflow: hidden;
}
.odk-section-vision .odk-section-vision__item__flow img {
  width: 100%;
  height: auto;
  /* show full image without cropping */
  -o-object-fit: contain;
     object-fit: contain;
  display: block;
}
.odk-section-vision .odk-section-vision__item__content {
  position: relative;
  padding-left: 771rem;
  /* align with flow width */
  padding-bottom: 80rem;
  box-sizing: border-box;
  color: #000;
}
.odk-section-vision .odk-section-vision__item__content__title {
  margin: 0;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 600;
  font-size: 96rem;
  letter-spacing: 0.02em;
  line-height: 1.1;
  color: #1E284B;
  position: relative;
  /* underline (x1=771 -> x2=923 length 152) */
  margin-bottom: 64rem;
  /* spacing down to sub-heading */
}
.odk-section-vision .odk-section-vision__item__content__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -22rem;
  /* approx 129.5 - 87.168 = 42 -> half due to line height differences */
  width: 152rem;
  height: 2rem;
  background: #000;
}
.odk-section-vision .odk-section-vision__item__content__text__title {
  margin: 0 0 48rem 0;
  font-family: Meiryo, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Noto Sans JP", sans-serif;
  font-size: 32rem;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1.5;
  color: #000;
}
.odk-section-vision .odk-section-vision__item__content__text__title__highlight {
  position: relative;
  display: inline-block;
  padding: 4rem 0;
}
.odk-section-vision .odk-section-vision__item__content__text__title__highlight::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(1.3);
  width: 100%;
  height: 100%;
  background: url("../img/circle_check_2.svg") center center/contain no-repeat;
}
.odk-section-vision .odk-section-vision__item__content__text__title__highlight b {
  position: relative;
  z-index: 1;
}
.odk-section-vision .odk-section-vision__item__content__text__description,
.odk-section-vision .odk-section-vision__item__content__text__description__text {
  margin: 0 0 24rem 0;
  font-family: Meiryo, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Noto Sans JP", sans-serif;
  font-size: 18rem;
  font-weight: 400;
  letter-spacing: 0em;
  line-height: 2;
  /* ~36px line gap from svg */
  color: #000;
}
@media screen and (max-width: 650px) {
  .odk-section-vision .odk-section-vision__item__content__text__description sup,
.odk-section-vision .odk-section-vision__item__content__text__description__text sup {
    font-size: 1.2em;
  }
}
.odk-section-vision .odk-section-vision__item:nth-of-type(2) .odk-section-vision__item__flow {
  left: auto;
  right: 0;
  top: -100rem;
}
.odk-section-vision .odk-section-vision__item:nth-of-type(2) .odk-section-vision__item__content {
  padding-left: 0rem;
  padding-right: 771rem;
  /* mirror flow width */
}
.odk-section-vision .odk-section-vision__item:nth-of-type(2) .odk-section-vision__item__content__title::after {
  left: 0;
  right: auto;
}
@media screen and (max-width: 1340px) {
  .odk-section-vision .odk-section-vision__item__flow {
    width: 484rem;
  }
  .odk-section-vision .odk-section-vision__item__content {
    padding-left: 571rem;
  }
  .odk-section-vision .odk-section-vision__item:nth-of-type(2) .odk-section-vision__item__content {
    padding-left: 0;
    padding-right: 571rem;
  }
}
@media screen and (max-width: 650px) {
  .odk-section-vision {
    padding: 100rem 0 0;
    /* top 100rem, sides 0, bottom 0 */
  }
  .odk-section-vision .odk-section-vision__container {
    gap: 0;
    padding: 0 35rem;
    /* 20 * 1.75 */
  }
  .odk-section-vision .odk-section-vision__item {
    min-height: auto;
  }
  .odk-section-vision .odk-section-vision__item__flow {
    position: relative;
    width: 100%;
    height: auto;
    margin-bottom: 35rem;
    /* 20 * 1.75 */
  }
  .odk-section-vision .odk-section-vision__item__flow img {
    height: auto;
  }
  .odk-section-vision .odk-section-vision__item__content {
    padding: 0;
  }
  .odk-section-vision .odk-section-vision__item__content__title {
    font-size: 90rem;
    margin-bottom: 112rem;
    /* 64 * 1.75 */
  }
  .odk-section-vision .odk-section-vision__item__content__title::after {
    width: 266rem;
    /* 152 * 1.75 */
    height: 4rem;
    /* 2 * 1.75 */
    bottom: -39rem;
    /* -22 * 1.75 */
  }
  .odk-section-vision .odk-section-vision__item__content__text__title {
    font-size: 34rem;
    margin-bottom: 40rem;
    line-height: 1.5;
  }
  .odk-section-vision .odk-section-vision__item__content__text__title br:first-of-type {
    display: none;
  }
  .odk-section-vision .odk-section-vision__item__content__text__description,
.odk-section-vision .odk-section-vision__item__content__text__description__text {
    font-size: 24rem;
    line-height: 1.7;
    margin-bottom: 42rem;
    /* 24 * 1.75 */
  }
  .odk-section-vision .odk-section-vision__item:nth-of-type(2) .odk-section-vision__item__content {
    padding: 0;
  }
  .odk-section-vision .odk-section-vision__item:nth-of-type(2) .odk-section-vision__item__flow {
    margin-top: 0;
    top: 0;
  }
}

/* Button Section */
.odk-section-vision__item__content__button {
  text-align: center;
  padding: 120rem 40rem;
  max-width: 1200rem;
  margin: 0 auto;
  box-sizing: border-box;
  /* Responsive styles */
}
.odk-section-vision__item__content__button .odk-section-vision__item__content__title {
  font-size: 48rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.02em;
  color: #000;
  margin: 0 0 60rem;
}
.odk-section-vision__item__content__button .odk-section-vision__item__content__title::after {
  display: none;
  /* Remove underline for button section */
}
.odk-section-vision__item__content__button__link {
  display: flex;
  justify-content: center;
}
.odk-section-vision__item__content__button__link__link {
  display: inline-block;
  background: #F08200;
  color: #fff;
  font-size: 24rem;
  font-weight: 700;
  padding: 20rem 60rem;
  border-radius: 50rem;
  text-decoration: none;
  transition: all 0.3s ease;
  box-shadow: 0 8rem 24rem rgba(240, 130, 0, 0.3);
}
.odk-section-vision__item__content__button__link__link:hover {
  background: #e07300;
  box-shadow: 0 12rem 32rem rgba(240, 130, 0, 0.4);
  transform: translateY(-2rem);
  opacity: 1;
}
@media screen and (max-width: 1024px) and (min-width: 651px) {
  .odk-section-vision__item__content__button {
    padding: 100rem 30rem;
  }
  .odk-section-vision__item__content__button .odk-section-vision__item__content__title {
    font-size: 38rem;
    margin-bottom: 50rem;
  }
  .odk-section-vision__item__content__button__link__link {
    font-size: 20rem;
    padding: 18rem 50rem;
  }
}
@media screen and (max-width: 650px) {
  .odk-section-vision__item__content__button {
    padding: 210rem 70rem;
    /* 120 * 1.75, 40 * 1.75 */
  }
  .odk-section-vision__item__content__button .odk-section-vision__item__content__title {
    font-size: 84rem;
    /* 48 * 1.75 */
    margin-bottom: 105rem;
    /* 60 * 1.75 */
    line-height: 1.4;
  }
  .odk-section-vision__item__content__button__link__link {
    font-size: 42rem;
    /* 24 * 1.75 */
    padding: 35rem 105rem;
    /* 20 * 1.75, 60 * 1.75 */
    border-radius: 88rem;
    /* 50 * 1.75 */
    box-shadow: 0 14rem 42rem rgba(240, 130, 0, 0.3);
    /* 8 * 1.75, 24 * 1.75 */
  }
  .odk-section-vision__item__content__button__link__link:hover {
    box-shadow: 0 21rem 56rem rgba(240, 130, 0, 0.4);
    /* 12 * 1.75, 32 * 1.75 */
    transform: translateY(-4rem);
    /* -2 * 1.75 */
  }
}

a {
  transition-duration: 0.3s;
}

/* Vision CTA background */
.odk-section-vision__cta {
  background: url("../img/bg_map_2.webp") center center/cover no-repeat;
  padding: 120rem 20rem;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
}
.odk-section-vision__cta .odk-section-vision__cta__container {
  max-width: 1200rem;
  margin: 0 auto;
  text-align: center;
}
.odk-section-vision__cta .odk-section-vision__cta__title {
  margin: 0 0 60rem 0;
  font-family: Meiryo, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Noto Sans JP", sans-serif;
  font-size: 38rem;
  font-weight: 700;
  letter-spacing: 0em;
  line-height: 1.6;
  /* 行送り約62px相当 */
  color: #333;
}
.odk-section-vision__cta .odk-section-vision__cta__title .odk-section-vision__cta__highlight {
  position: relative;
  display: inline-block;
  padding: 4rem 16rem;
}
.odk-section-vision__cta .odk-section-vision__cta__title .odk-section-vision__cta__highlight::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(1.3);
  width: 100%;
  height: 100%;
  background: url("../img/circle_check_2.svg") center center/contain no-repeat;
}
.odk-section-vision__cta .odk-section-vision__cta__title .odk-section-vision__cta__highlight b {
  position: relative;
  z-index: 1;
}
.odk-section-vision__cta .odk-section-vision__cta__button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  width: auto;
  height: 88rem;
  padding: 0 45rem 0 111rem;
  /* アイコン右30remの余白を確保 (24+57+30) */
  border: 1rem solid #1E284B;
  border-radius: 44rem;
  background: #fff;
  text-decoration: none;
  transition: opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease, background-color 0.3s ease, color 0.3s ease;
  box-shadow: 0 6rem 18rem rgba(30, 40, 75, 0.1);
}
.odk-section-vision__cta .odk-section-vision__cta__button:hover {
  transform: translateY(-2rem);
  box-shadow: 0 10rem 24rem rgba(30, 40, 75, 0.16);
  opacity: 1;
  background-color: #1E284B;
  color: #fff;
}
.odk-section-vision__cta .odk-section-vision__cta__button:hover .odk-section-vision__cta__button__icon {
  background-color: #fff !important;
}
.odk-section-vision__cta .odk-section-vision__cta__button:hover .odk-section-vision__cta__button__icon img {
  filter: brightness(0.2);
}
.odk-section-vision__cta .odk-section-vision__cta__button:hover .odk-section-vision__cta__button__label {
  color: #fff;
}
.odk-section-vision__cta .odk-section-vision__cta__button__icon {
  position: absolute;
  left: 24rem;
  width: 57rem;
  height: 57rem;
  /* 円径 ≒ 2*28.5 */
  border-radius: 50%;
  background-color: #1E284B;
  display: flex;
  align-items: center;
  justify-content: center;
}
.odk-section-vision__cta .odk-section-vision__cta__button__label {
  font-family: Meiryo, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Noto Sans JP", sans-serif;
  font-size: 22rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #1E284B;
  display: inline-block;
  line-height: 1;
}
.odk-section-vision__cta .odk-section-vision__cta__button__label .--reg {
  font-size: 1em;
  font-weight: 700;
}
@media screen and (max-width: 1024px) {
  .odk-section-vision__cta {
    padding: 100rem 20rem;
  }
  .odk-section-vision__cta .odk-section-vision__cta__title {
    font-size: 32rem;
    margin-bottom: 48rem;
    line-height: 1.6;
  }
  .odk-section-vision__cta .odk-section-vision__cta__button {
    height: 78rem;
    padding-left: 104rem;
    /* 24+50+30 */
  }
  .odk-section-vision__cta .odk-section-vision__cta__button__icon {
    width: 50rem;
    height: 50rem;
  }
  .odk-section-vision__cta .odk-section-vision__cta__button__label {
    font-size: 20rem;
  }
}
@media screen and (max-width: 650px) {
  .odk-section-vision__cta {
    padding: 210rem 35rem;
    /* 120 * 1.75, 20 * 1.75 */
  }
  .odk-section-vision__cta .odk-section-vision__cta__title {
    font-size: 38rem;
    margin-bottom: 105rem;
    /* 60 * 1.75 */
    line-height: 1.6;
    text-align: left;
  }
  .odk-section-vision__cta .odk-section-vision__cta__title br:last-of-type {
    display: none;
  }
  .odk-section-vision__cta .odk-section-vision__cta__button {
    height: 154rem;
    /* 88 * 1.75 */
    padding-left: 135rem;
    /* 42+100+30 */
    border-radius: 77rem;
    /* 44 * 1.75 */
  }
  .odk-section-vision__cta .odk-section-vision__cta__button__icon {
    left: 42rem;
    /* 24 * 1.75 */
    width: 100rem;
    height: 100rem;
    /* 57 * 1.75 ≈ 100 */
    background: #1E284B url("../img/arrow_right.svg") center center/50% no-repeat;
  }
}
@media screen and (max-width: 650px) and (max-width: 650px) {
  .odk-section-vision__cta .odk-section-vision__cta__button__icon {
    background: #1E284B;
  }
}
@media screen and (max-width: 650px) {
  .odk-section-vision__cta .odk-section-vision__cta__button__label {
    font-size: 36rem;
  }
}
@media screen and (max-width: 650px) and (max-width: 650px) {
  .odk-section-vision__cta .odk-section-vision__cta__button__label {
    font-size: 32rem;
  }
  .odk-section-vision__cta .odk-section-vision__cta__button__label sup {
    font-size: 1em;
  }
}

a:hover {
  opacity: 0.6;
}

@media screen and (min-width: 1201px) {
  html {
    /* font-size:0.06849315vw; */
    font-size: 1px;
  }
}
@media screen and (max-width: 650px) {
  html {
    font-size: 0.14765vw;
  }
}
dl {
  margin: 0px;
}
dl dt {
  margin: 0px;
}
dl dd {
  margin: 0px;
}

ul,
ol {
  padding: 0px;
  margin: 0px;
}
ul li,
ol li {
  list-style-type: none;
}

body {
  margin: 0px;
  font-size: 18rem;
  overflow-x: hidden;
}
@media screen and (max-width: 650px) {
  body {
    font-size: 24rem;
    line-height: 42rem;
  }
}

figure {
  margin: 0px;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  padding: 0px;
  margin: 0px;
  font-weight: 200;
}

p {
  margin: 0px;
}

a {
  text-decoration: none;
  color: #000;
}
a:hover {
  opacity: 0.6;
}

sup {
  font-size: 0.6em;
}
@media screen and (max-width: 650px) {
  sup {
    font-size: 0.8em;
  }
}

.odk-img-map-wrapper {
  grid-column: 1;
  grid-row: 1;
  width: 100%;
  overflow: hidden;
  position: relative;
}

.odk-img-map-loader {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.odk-img-map-loader.is-loading {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.odk-img-map-loader__spinner {
  width: 60rem;
  height: 60rem;
  border: 4rem solid rgba(30, 40, 75, 0.1);
  border-top-color: #1E284B;
  border-radius: 50%;
  -webkit-animation: odk-spin 1s linear infinite;
          animation: odk-spin 1s linear infinite;
}

@-webkit-keyframes odk-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes odk-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.odk-img-map-track {
  width: 200%;
  display: flex;
  transition: opacity 0.4s ease-in-out, transform 0.4s ease-in-out;
}
@media screen and (max-width: 650px) {
  .odk-img-map-track {
    -webkit-animation: odk-map-loop 60s linear infinite;
            animation: odk-map-loop 60s linear infinite;
  }
}

.odk-img-map {
  flex: 0 0 100%;
  width: 100%;
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
  transition: opacity 0.4s ease-in-out, transform 0.4s ease-in-out, filter 0.4s ease-in-out;
}
@media screen and (max-width: 650px) {
  .odk-img-map {
    height: 872rem;
    -o-object-fit: inherit;
       object-fit: inherit;
    width: auto !important;
    max-width: -webkit-fit-content;
    max-width: -moz-fit-content;
    max-width: fit-content;
    margin: 0 auto;
    -webkit-animation: odk-map-drift 16s linear infinite;
            animation: odk-map-drift 16s linear infinite;
  }
}

.odk-mv-section {
  position: relative;
  display: grid;
  grid-template-columns: 100%;
  padding-bottom: 300rem;
  margin-bottom: -300rem;
}

@-webkit-keyframes odk-map-loop {
  0% {
    transform: translateX(-174%);
  }
  100% {
    transform: translateX(-62%);
  }
}

@keyframes odk-map-loop {
  0% {
    transform: translateX(-174%);
  }
  100% {
    transform: translateX(-62%);
  }
}
.odk-mv-selector {
  position: absolute;
  top: 135rem;
  right: 20rem;
  width: 165rem;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  padding: 30rem 12rem 30rem;
  border-radius: 10rem;
  background: #fff;
  box-shadow: 0 20rem 40rem rgba(30, 40, 75, 0.15);
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 15rem;
  box-sizing: border-box;
  isolation: isolate;
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.odk-mv-selector.is-fixed {
  position: fixed;
  top: 20rem;
}
@media screen and (max-width: 650px) {
  .odk-mv-selector {
    width: auto;
    min-height: auto;
    flex-direction: row;
    justify-content: space-between;
    padding: 24rem 20rem;
  }
}
.odk-mv-selector__title {
  text-align: center;
  font-size: 20rem;
  line-height: 1.4;
  font-weight: 900;
  color: #f08200;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0;
}
@media screen and (max-width: 650px) {
  .odk-mv-selector__title {
    font-size: 24rem;
  }
}
.odk-mv-selector__list {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10rem;
  margin: 0;
  padding: 0;
  align-items: center;
}
@media screen and (max-width: 650px) {
  .odk-mv-selector__list {
    flex-direction: row;
    gap: 24rem;
  }
}
.odk-mv-selector__item {
  width: 100%;
  display: flex;
  justify-content: center;
  cursor: pointer;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.odk-mv-selector__item:hover {
  transform: scale(1.02);
  opacity: 0.9;
}
.odk-mv-selector__card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5rem;
  width: 100%;
  position: relative;
}
.odk-mv-selector__card::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40rem;
  height: 40rem;
  background: url("../img/icon_finger.svg") center/contain no-repeat;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  z-index: 2;
}
.odk-mv-selector__card:hover::before {
  opacity: 1;
}
.odk-mv-selector__thumb {
  width: 105rem;
  height: 105rem;
  border-radius: 50%;
  border: 5rem solid #f08200;
  background: #d9d9d9;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  box-shadow: inset 0 8rem 18rem rgba(0, 0, 0, 0.08);
  cursor: pointer;
  position: relative;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.odk-mv-selector__thumb:hover {
  transform: scale(1.05);
  opacity: 0.8;
}
.odk-mv-selector__thumb--1 {
  box-shadow: inset 0 8rem 18rem rgba(0, 0, 0, 0.08), 0 0 0 0 transparent;
}
.odk-mv-selector__thumb--2 {
  box-shadow: inset 0 8rem 18rem rgba(0, 0, 0, 0.08), 0 0 0 0 transparent;
}
.odk-mv-selector__thumb--3 {
  box-shadow: inset 0 8rem 18rem rgba(0, 0, 0, 0.08), 0 0 0 0 transparent;
}
.odk-mv-selector__label {
  width: 100%;
  min-height: 32rem;
  border-radius: 16rem;
  background: #1e284b;
  color: #fff;
  font-size: 12rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 12rem;
  position: relative;
  box-sizing: border-box;
  line-height: 1.4;
  z-index: 1;
}
.odk-mv-selector__label::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border-left: 10rem solid transparent;
  border-right: 10rem solid transparent;
  border-top: 12rem solid #1e284b;
}
@media screen and (max-width: 650px) {
  .odk-mv-selector__label {
    font-size: 18rem;
    min-height: 48rem;
  }
}
.odk-mv-selector__item:last-child .odk-mv-selector__label {
  letter-spacing: -0.12em;
}
.odk-mv-selector.is-visible {
  display: flex;
  opacity: 1 !important;
  visibility: visible;
  transition-duration: 0.3s;
}
@media screen and (max-width: 650px) {
  .odk-mv-selector.is-visible {
    display: none;
  }
}

.odk-mv-sp-title {
  display: none;
  width: 100%;
  justify-content: center;
  padding: 40rem 20rem 0;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 650px) {
  .odk-mv-sp-title {
    display: flex;
  }
}
.odk-mv-sp-title__card {
  width: 100%;
  max-width: 562rem;
  min-height: 133rem;
  background: #fff;
  border-radius: 10rem;
  box-shadow: 0 20rem 40rem rgba(23, 44, 75, 0.18);
  padding: 24rem 20rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12rem;
}
.odk-mv-sp-title__lead {
  font-size: 32rem;
  font-weight: 500;
  color: #283060;
  margin: 0;
}
.odk-mv-sp-title__heading {
  font-size: 56rem;
  font-weight: 700;
  color: #f08200;
  line-height: 1.35;
  letter-spacing: 0.06em;
  margin: 0;
  text-align: center;
}

.odk-section-message-wrapper {
  background: url("../img/bg_concept.svg") top center/cover no-repeat;
}

.odk-section-message {
  width: 100%;
  max-width: 1150rem;
  margin: 0 auto;
  padding: 80rem 40rem;
  box-sizing: border-box;
  position: relative;
  padding-bottom: 300rem;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-message {
    padding: 100rem 42rem 180rem;
    /* top, sides, bottom */
    margin-bottom: 0rem;
    padding-bottom: 350rem;
  }
}
.odk-section-message > header {
  text-align: center;
  margin-bottom: 40rem;
  position: relative;
  z-index: 1;
  margin-bottom: 80rem;
  background: transparent !important;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-message > header {
    margin-bottom: 90rem;
  }
}
.odk-section-message > header::after {
  content: "";
  position: absolute;
  bottom: -40rem;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 560rem);
  max-width: 590rem;
  height: 6rem;
  background-image: repeating-linear-gradient(to right, transparent 0, transparent 9rem, #f08200 9rem, #f08200 20rem);
  background-size: 20rem 100%;
  pointer-events: none;
}
@media screen and (max-width: 650px) {
  .odk-section-message > header::after {
    width: 100%;
    margin-top: 40rem;
  }
}
.odk-section-message > header h2 {
  font-size: 36rem;
  font-weight: 600;
  line-height: 1.6;
  color: #000;
  /* Mobile */
}
.odk-section-message > header h2 .odk-section-message__highlight {
  background: url("../img/line_1.svg") center bottom/contain no-repeat;
  padding-bottom: 8rem;
}
@media screen and (max-width: 650px) {
  .odk-section-message > header h2 {
    font-size: 42rem;
    line-height: 1.5;
  }
}
.odk-section-message > div {
  max-width: 900rem;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  text-align: center;
}
.odk-section-message > div p {
  font-size: 18rem;
  font-weight: 400;
  line-height: 2;
  color: #333;
  margin-bottom: 32rem;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-message > div p {
    font-size: 24rem;
    line-height: 1.8;
    margin-bottom: 32rem;
  }
  .odk-section-message > div p br {
    display: none;
  }
}
.odk-section-message > div p:last-child {
  margin-bottom: 0;
}

.odk-section-box > div {
  display: flex;
  flex-direction: column;
  gap: 40rem;
  align-items: center;
  max-width: 1150rem;
  margin: 0 auto;
  padding: 80rem 40rem;
  box-sizing: border-box;
}
@media screen and (max-width: 650px) {
  .odk-section-box > div {
    padding: 60rem 24rem;
    gap: 32rem;
  }
}

.odk-section-message__items {
  display: flex;
  gap: 60rem;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  position: relative;
  top: -150rem;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-message__items {
    flex-direction: column;
    gap: 105rem;
    /* 60 * 1.75 */
    align-items: center;
    padding: 0 35rem;
    /* 20 * 1.75 */
    position: relative;
    padding-bottom: 100rem;
    margin-bottom: 0rem;
    background-color: #fff;
  }
  .odk-section-message__items::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 70rem);
    /* 100% - (35rem * 2) */
    height: 6rem;
    background-image: repeating-linear-gradient(to right, transparent 0, transparent 9rem, #f08200 9rem, #f08200 20rem);
    background-size: 20rem 100%;
    pointer-events: none;
    display: none;
  }
  .odk-section-message__items:last-child {
    padding-bottom: 0;
    margin-bottom: 0;
  }
  .odk-section-message__items:last-child::after {
    display: none;
  }
}

.odk-section-story {
  background-color: #F0F5FB;
  padding-bottom: 200rem;
}

@media screen and (max-width: 650px) {
  .odk-section-story {
    padding-bottom: 60rem;
  }
}
.odk-section-story__header {
  width: 100%;
  max-width: 740rem;
  /* header SVG width ~679, allow some breathing room */
  margin: 0 auto;
  padding: 0 40rem;
  box-sizing: border-box;
  text-align: center;
  position: relative;
  margin-bottom: 60rem;
  background-color: transparent !important;
}
@media screen and (max-width: 650px) {
  .odk-section-story__header {
    padding: 0 42rem;
    /* 24 * 1.75 */
    margin-bottom: 84rem;
    /* 48 * 1.75 */
  }
}
.odk-section-story__header p {
  font-size: 27rem;
  /* SVG: 27 */
  font-weight: 700;
  color: #000;
  margin-bottom: 18rem;
  line-height: 1.4;
  letter-spacing: 0.04em;
  /* SVG: 0.04em */
}
@media screen and (max-width: 650px) {
  .odk-section-story__header p {
    font-size: 34rem;
    /* 27 * 1.75 */
    margin-bottom: 20rem;
    /* 18 * 1.75 */
  }
}
.odk-section-story__header h2 {
  margin: 0;
  color: #F08200;
  font-weight: 700;
  letter-spacing: 0.04em;
  /* SVG: 0.04em */
  line-height: 1.1;
  font-size: 64rem;
  /* base for 「つの」「の」: 64 */
  /* First span (「3」) larger, second span（「未来」） medium */
}
@media screen and (max-width: 650px) {
  .odk-section-story__header h2 {
    font-size: 42rem;
    /* 64 * 1.75 */
    line-height: 1.2;
  }
}
.odk-section-story__header h2 span:first-child {
  display: inline-block;
  font-size: 90rem;
  /* SVG: 90 */
  line-height: 1;
  vertical-align: baseline;
  color: #F08200;
}
@media screen and (max-width: 650px) {
  .odk-section-story__header h2 span:first-child {
    font-size: 80rem;
    /* 90 * 1.75 */
  }
}
.odk-section-story__header h2 span:last-child {
  display: inline-block;
  font-size: 82rem;
  /* SVG: 82 */
  line-height: 1;
  vertical-align: baseline;
  color: #F08200;
}
@media screen and (max-width: 650px) {
  .odk-section-story__header h2 span:last-child {
    font-size: 80rem;
    /* 82 * 1.75 */
  }
}
.odk-section-story__header::after {
  content: "";
  position: absolute;
  bottom: -20rem;
  /* place at bottom like SVG bottom line */
  left: 68rem;
  right: 68rem;
  height: 6rem;
  background-image: repeating-linear-gradient(to right, transparent 0, transparent 9rem, #F08200 9rem, #F08200 20rem);
  background-size: 20rem 100%;
  pointer-events: none;
}

.odk-section-message__item {
  flex: 1;
  min-width: 0;
  max-width: 563rem;
  margin: 0;
  position: relative;
  background: #1e284b;
  border-radius: 20rem;
  padding: 72rem 49rem 40rem;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-message__item {
    max-width: 100%;
    padding: 126rem 43rem 35rem;
    /* keep top, halve sides/bottom */
    border-radius: 35rem;
    /* 20*1.75 */
  }
}
.odk-section-message__item > div:first-child {
  position: absolute;
  top: -70rem;
  left: 50%;
  transform: translateX(-50%);
  width: 140rem;
  height: 140rem;
  border-radius: 50%;
  background: #f08200;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-message__item > div:first-child {
    top: -98rem;
    /* -70*1.75*0.8 */
    width: 196rem;
    /* 140*1.75*0.8 */
    height: 196rem;
    /* 140*1.75*0.8 */
  }
}
.odk-section-message__item > div:first-child::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%) rotate(45deg);
  width: 20rem;
  height: 20rem;
  background: #f08200;
  margin-top: -5rem;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-message__item > div:first-child::after {
    width: 35rem;
    /* 20*1.75 */
    height: 35rem;
    /* 20*1.75 */
    margin-top: -9rem;
    /* -5*1.75 */
  }
}
.odk-section-message__item > div:first-child img {
  width: auto;
  height: auto;
  display: block;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 650px) {
  .odk-section-message__item > div:first-child img {
    transform: scale(0.8);
  }
}
.odk-section-message__item h2 {
  padding-top: 30rem;
  width: 100%;
  font-size: 33rem;
  font-weight: 600;
  color: #fff;
  margin-bottom: 24rem;
  padding-bottom: 24rem;
  border-bottom: 1rem solid #fff;
  line-height: 1.5;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-message__item h2 {
    font-size: 38rem;
    /* 24*1.75 */
    padding-top: 35rem;
    /* 20*1.75 */
    margin-bottom: 42rem;
    /* 24*1.75 */
    padding-bottom: 22rem;
    /* 24*1.75 */
    border-bottom: 2rem solid #fff;
    /* 1*1.75 */
  }
}
.odk-section-message__item p {
  font-size: 18rem;
  font-weight: 400;
  color: #fff;
  line-height: 2;
  margin: 0;
  text-align: left;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-message__item p {
    font-size: 24rem;
    /* 16*1.75 */
    line-height: 1.8;
  }
}

.odk-mv-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 20;
  width: min(742rem, 100% - 120rem);
  padding: 40rem;
  border-radius: 36rem;
  border: none;
  background: #fff;
  box-shadow: 0 40rem 90rem rgba(23, 44, 75, 0.2);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  isolation: isolate;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.6s ease, visibility 0.6s ease, transform 0.6s ease;
}
@media screen and (max-width: 1024px) {
  .odk-mv-modal {
    padding: 40rem;
    gap: 40rem;
  }
}
@media screen and (max-width: 640px) {
  .odk-mv-modal {
    display: none;
  }
}
.odk-mv-modal.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(0.96);
}
.odk-mv-modal.is-soft-hidden {
  /* scroll-driven, reversible */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(0.98);
}
.odk-mv-modal > header {
  display: flex;
  flex-direction: column;
  gap: 5rem;
  text-align: center;
}
.odk-mv-modal > header div:first-child {
  font-size: 24rem;
  font-weight: 400;
  color: #606778;
}
.odk-mv-modal > header div:last-child {
  font-size: 28rem;
  font-weight: 500;
  color: #e57b10;
  font-weight: 600;
  padding-top: 10rem;
}
@media screen and (max-width: 640px) {
  .odk-mv-modal > header div:first-child {
    font-size: 24rem;
    letter-spacing: 0.2em;
  }
  .odk-mv-modal > header div:last-child {
    font-size: 32rem;
    line-height: 1.4;
  }
}
.odk-mv-modal__close {
  position: absolute;
  width: 47rem;
  height: 47rem;
  top: 0;
  right: 0;
  border: none;
  border-radius: 0 10rem 0 10rem;
  background: #f5821f;
  cursor: pointer;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.2s ease;
}
.odk-mv-modal__close:hover {
  opacity: 0.8;
}
.odk-mv-modal__close::before, .odk-mv-modal__close::after {
  content: "";
  position: absolute;
  width: 21rem;
  height: 3rem;
  background: #fff;
  border-radius: 2rem;
}
.odk-mv-modal__close::before {
  transform: rotate(45deg);
}
.odk-mv-modal__close::after {
  transform: rotate(-45deg);
}
.odk-mv-modal > ul {
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 32rem;
  margin: 0;
  padding: 0;
  padding-top: 30rem;
}
@media screen and (max-width: 900px) {
  .odk-mv-modal > ul {
    gap: 24rem;
  }
}
@media screen and (max-width: 640px) {
  .odk-mv-modal > ul {
    gap: 20rem;
  }
}
.odk-mv-modal > ul li {
  flex: 1;
  max-width: 194rem;
  width: 194rem;
  display: flex;
  justify-content: center;
  position: relative;
}
@media screen and (max-width: 640px) {
  .odk-mv-modal > ul li {
    max-width: 194rem;
    width: 194rem;
  }
}
.odk-mv-modal > ul li figure {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24rem;
  width: 100%;
  position: relative;
  cursor: pointer;
}
.odk-mv-modal > ul li figure::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 50rem;
  height: 50rem;
  background: url("../img/icon_finger.svg") center/contain no-repeat;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  z-index: 2;
}
.odk-mv-modal > ul li figure:hover::before {
  opacity: 1;
}
.odk-mv-modal > ul li img {
  width: 156rem;
  height: 156rem;
  border-radius: 50%;
  background: #f8f4ed;
  -o-object-fit: cover;
     object-fit: cover;
  box-shadow: inset 0 8rem 18rem rgba(0, 0, 0, 0.08);
  cursor: pointer;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.odk-mv-modal > ul li img:hover {
  transform: scale(1.05);
  opacity: 0.8;
}
.odk-mv-modal > ul li figcaption {
  background: #283060;
  color: #fff;
  width: 100%;
  box-sizing: border-box;
  padding: 12rem 12rem;
  border-radius: 999rem;
  font-size: 12rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  position: relative;
}
@media screen and (max-width: 640px) {
  .odk-mv-modal > ul li figcaption {
    font-size: 24rem;
  }
}
.odk-mv-modal > ul li figcaption::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -12rem;
  border-width: 14rem 14rem 0 14rem;
  border-style: solid;
  border-color: #283060 transparent transparent transparent;
}
.odk-mv-modal > div:last-child {
  margin-top: 20rem;
  width: 100%;
}
.odk-mv-modal > div:last-child p {
  font-size: 26rem;
  font-weight: 400;
  color: #4c4c4c;
}
@media screen and (max-width: 640px) {
  .odk-mv-modal > div:last-child p {
    font-size: 28rem;
    line-height: 1.5;
  }
}

.f-contents-link-box {
  display: none;
}

.odk-section-story__inner {
  background: url("../img/bg_story.svg") top center/cover no-repeat;
}

.odk-section-story__container {
  position: relative;
  padding-top: 160rem;
  border-bottom: 0;
  /* Mobile */
}
@media screen and (max-width: 650px) {
  .odk-section-story__container {
    display: flex;
    flex-direction: column;
    padding-left: 35rem;
    /* 20 * 1.75 */
    padding-right: 35rem;
    /* 20 * 1.75 */
    padding-top: 0rem;
    border-bottom: 1rem solid #ccd6e1;
  }
}

.odk-section-story__items {
  margin: 0 auto;
  max-width: 1200rem;
  box-sizing: border-box;
}

/* 3つ目のセクションのcontainerのpadding-topを変更 */
#odk-section-story__items--last .odk-section-story__container {
  padding-top: 140rem;
  margin-top: 100rem;
  border-bottom: none;
}
@media screen and (max-width: 650px) {
  #odk-section-story__items--last .odk-section-story__container {
    margin-top: 0;
  }
}

.odk-section-story__item__flow {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  /* オプションクラスが付いているflowの右下に白い丸を配置 */
  /* Mobile */
}
.odk-section-story__item__flow--with-circle:first-of-type::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 367rem;
  height: 367rem;
  background: #fff;
  border-radius: 50%;
  z-index: -1;
  bottom: -150rem;
}
@media screen and (max-width: 650px) {
  .odk-section-story__item__flow--with-circle:first-of-type::after {
    width: 267rem;
    height: 267rem;
    bottom: -30rem;
    left: 280rem;
  }
}
.odk-section-story__item__flow__image__1 {
  width: 624rem;
}
.odk-section-story__item__flow__image__2 {
  width: 331rem;
}
.odk-section-story__item__flow__image__3 {
  width: 408rem;
}
@media screen and (max-width: 650px) {
  .odk-section-story__item__flow {
    position: relative;
    top: auto;
    right: auto;
    margin-bottom: 100rem;
    width: 100%;
    order: 4;
    /* companyの下に配置 */
  }
  .odk-section-story__item__flow__image__1 {
    width: 624rem;
    margin-left: auto;
    margin-right: auto;
  }
  .odk-section-story__item__flow__image__2 {
    width: 430rem;
    margin-left: auto;
    margin-right: auto;
  }
  .odk-section-story__item__flow__image__3 {
    width: 408rem;
    margin-left: auto;
    margin-right: auto;
  }
  .odk-section-story__item__flow__image__3__sp {
    width: 430rem;
    margin-left: auto;
    margin-right: auto;
  }
}

.odk-section-story__item {
  position: relative;
  width: 100%;
  max-width: 841rem;
  /* SVG width */
  height: 429rem;
  /* SVG height */
  box-sizing: border-box;
  /* Left image block (536x368, r=20) */
  /* Right small label pill (x=498,y=190,w=340,h=46,r=5) */
  /* Name heading near the label */
  /* Bottom description box (SVG 835x359, y offset 41, r=20) */
  /* Inline description inside right column */
  /* Mobile */
}
.odk-section-story__item__thumb {
  position: absolute;
  top: 0;
  left: 0;
  width: 536rem;
  height: 368rem;
  border-radius: 20rem;
  overflow: hidden;
}
.odk-section-story__item__thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.odk-section-story__item__content {
  position: absolute;
  width: 100%;
  max-width: 578rem;
  margin: 0 auto;
  left: 255rem;
  top: 189rem;
  display: flex;
  flex-direction: column;
  gap: 10rem;
  justify-content: flex-end;
  align-items: flex-end;
  text-align: right;
}
.odk-section-story__item__content__title {
  max-width: 440rem;
  background: #fff;
  border-radius: 5rem;
  padding: 10rem 20rem 5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24rem;
  font-weight: 600;
  color: #222;
  line-height: 1.4;
  letter-spacing: 0.04em;
  box-shadow: 0 2rem 6rem rgba(0, 0, 0, 0.06);
}
.odk-section-story__item h3 {
  margin: 10rem 0;
  font-size: 38rem;
  font-weight: 700;
  color: #1a1a1a;
  letter-spacing: 0.04em;
}
.odk-section-story__item__text {
  position: relative;
  width: 835rem;
  /* SVG width */
  margin-top: 61rem;
  /* rect y offset */
  background: #1E284B;
  border-radius: 25rem;
  box-sizing: border-box;
  padding: 80rem;
  /* generous top to clear quote/ornaments */
  color: #fff;
}
.odk-section-story__item__text > span {
  position: absolute;
  left: 36rem;
  top: -40rem;
  /* slight lift to mimic SVG overlay */
  display: block;
}
.odk-section-story__item__text > span img {
  width: 120rem;
  height: auto;
  display: block;
}
@media screen and (max-width: 650px) {
  .odk-section-story__item__text > span img {
    transform: scale(0.8);
  }
}
.odk-section-story__item__text p {
  margin: 0;
  font-size: 18rem;
  line-height: 2;
  letter-spacing: 0.02em;
}
.odk-section-story__item__content__description {
  max-width: 548rem;
  background: #fff;
  border-radius: 10rem;
  padding: 20rem 20rem;
  box-shadow: 0 6rem 20rem rgba(0, 0, 0, 0.06);
  margin: 0;
  text-align: left;
  font-size: 32rem;
  line-height: 1.5;
  font-weight: 600;
  color: #F08200;
  letter-spacing: -0.02em;
  box-sizing: border-box;
  /* Mobile - hide br tags */
}
@media screen and (max-width: 650px) {
  .odk-section-story__item__content__description {
    width: 100%;
  }
  .odk-section-story__item__content__description br {
    display: none;
  }
}
@media screen and (max-width: 650px) {
  .odk-section-story__item {
    order: 1;
    /* 最初に配置 */
    height: auto;
    max-width: 100%;
  }
  .odk-section-story__item__thumb {
    position: relative;
    width: 100%;
    height: auto;
    border-radius: 28rem;
    /* 16 * 1.75 */
    overflow: hidden;
    margin-bottom: 35rem;
    /* 20 * 1.75 */
  }
  .odk-section-story__item__thumb img {
    width: 100%;
    height: auto;
    display: block;
  }
  .odk-section-story__item__content {
    position: relative;
    left: auto;
    top: auto;
    max-width: 100%;
    align-items: center;
    text-align: center;
    gap: 18rem;
    /* 10 * 1.75 */
  }
  .odk-section-story__item__content__title {
    font-size: 32rem;
    min-height: 81rem;
    /* 46 * 1.75 */
    max-width: 100%;
    margin: 0 auto 0;
    padding: 0 35rem;
    /* 20 * 1.75 */
    border-radius: 9rem;
    /* 5 * 1.75 */
  }
  .odk-section-story__item h3 {
    font-size: 67rem;
    /* 38 * 1.75 */
    margin: 28rem auto 0;
    /* 16 * 1.75 */
  }
  .odk-section-story__item__text {
    order: 2;
    /* itemの後に配置 */
    width: 100% !important;
    margin: 42rem auto 0;
    /* 24 * 1.75 */
    padding: 98rem 42rem 42rem;
    /* 56 * 1.75, 24 * 1.75 */
    border-radius: 25rem;
  }
  .odk-section-story__item__text > span {
    left: 35rem;
    /* 20 * 1.75 */
    top: -44rem;
    /* -14rem - 30rem */
  }
  .odk-section-story__item__text > span img {
    width: 168rem;
    /* 96 * 1.75 */
  }
  .odk-section-story__item__text p {
    font-size: 26rem;
    /* 15 * 1.75 */
    line-height: 1.8;
  }
  .odk-section-story__item__content__description {
    position: static;
    max-width: 100%;
    margin: 42rem auto 0;
    /* 24 * 1.75 */
    font-size: 32rem;
    line-height: 1.4;
    text-align: left;
    padding: 25rem;
    border-radius: 18rem;
    /* 10 * 1.75 */
    box-sizing: border-box;
  }
}

.odk-section-story__item__company {
  position: relative;
  width: 1135rem;
  /* SVG width */
  height: 464rem;
  /* SVG height */
  box-sizing: border-box;
  margin-top: -30rem;
  z-index: 2;
  /* removed top-level ::before panel */
  /* Hide mobile thumb on desktop */
}
.odk-section-story__item__company__thumb {
  position: absolute;
  left: 11rem;
  top: 202rem;
  width: 287rem;
  height: 312rem;
  border-radius: 20rem;
  overflow: hidden;
  z-index: 3;
  /* ensure above orange background */
}
.odk-section-story__item__company__thumb img {
  width: 287rem;
  -o-object-fit: contain;
     object-fit: contain;
  display: block;
}
.odk-section-story__item__company__content {
  position: absolute;
  left: 170rem;
  top: 5rem;
  width: 970rem;
  border-radius: 25rem;
  background: #F08200;
  border: 10rem solid #F0F5FB;
  /* stroke */
  box-sizing: border-box;
  z-index: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding: 70rem 32rem 70rem 202rem;
  /* top right bottom left - match original positioning */
  z-index: 2;
}
.odk-section-story__item__company__content__title {
  /* white pill */
  max-width: 271rem;
  background: #fff;
  border-radius: 10rem;
  padding: 10rem 20rem 5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Meiryo, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Noto Sans JP", sans-serif;
  font-size: 22rem;
  font-weight: 600;
  color: #344C57;
  line-height: 1;
  letter-spacing: 0.04em;
  margin: 0 0 32rem 0;
  /* bottom margin to match original gap */
  flex-shrink: 0;
}
.odk-section-story__item__company__content__subtitle {
  /* big headline */
  margin: 0 0 20rem 0;
  /* bottom margin to match original gap */
  max-width: 690rem;
  font-family: Meiryo, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Noto Sans JP", sans-serif;
  font-size: 42rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.03em;
  line-height: 1.3;
  flex-shrink: 0;
}
.odk-section-story__item__company__content__subtitle br {
  display: none;
}
.odk-section-story__item__company__content__description {
  /* body text */
  max-width: 690rem;
  margin: 0;
  font-size: 18rem;
  line-height: 1.9;
  letter-spacing: 0.02em;
  color: #fff;
  text-align: left;
  flex: 1;
}
.odk-section-story__item__company__content__thumb {
  display: none;
}
@media screen and (max-width: 650px) {
  .odk-section-story__item__company {
    order: 3;
    /* textの後に配置 */
    width: 100%;
    height: auto;
    margin-top: 0;
    padding: 42rem 0;
    /* 24 * 1.75 */
    padding-top: 30rem;
    /* Hide desktop thumb on mobile */
    /* Show and style mobile content */
    /* Very small mobile adjustment */
  }
  .odk-section-story__item__company__thumb {
    display: none;
  }
  .odk-section-story__item__company__content {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    height: auto;
    min-height: auto;
    border-radius: 25rem;
    /* 14 * 1.75 */
    border-width: 7rem;
    /* 4 * 1.75 */
    border: 0;
    padding: 42rem;
    /* 24 * 1.75 */
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    /* Show mobile thumb inside content */
  }
  .odk-section-story__item__company__content__thumb {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    margin: 0 0 35rem;
    /* bottom margin: 20 * 1.75 */
    border-radius: 25rem;
    /* 14 * 1.75 */
    box-shadow: 0 7rem 18rem rgba(0, 0, 0, 0.1);
    /* 4 * 1.75, 10 * 1.75 */
    order: 1;
  }
  .odk-section-story__item__company__content__thumb img {
    width: 100%;
    height: auto;
    border-radius: 25rem;
    display: block;
  }
  .odk-section-story__item__company__content__title {
    font-size: 35rem;
    /* 20 * 1.75 */
    min-height: 77rem;
    /* 44 * 1.75 */
    margin-bottom: 21rem;
    /* 12 * 1.75 */
    padding: 0 35rem;
    /* 20 * 1.75 */
    order: 2;
  }
  .odk-section-story__item__company__content__subtitle {
    font-size: 49rem;
    /* 28 * 1.75 */
    margin-top: 0;
    margin-bottom: 28rem;
    /* 16 * 1.75 */
    line-height: 1.3;
    order: 3;
  }
  .odk-section-story__item__company__content__subtitle br {
    display: inline;
  }
  .odk-section-story__item__company__content__description {
    font-size: 26rem;
    /* 15 * 1.75 */
    line-height: 1.8;
    margin-top: 0;
    text-align: left;
    order: 4;
  }
  .odk-section-story__item__company__content__title, .odk-section-story__item__company__content__subtitle, .odk-section-story__item__company__content__description {
    position: relative;
    left: auto;
    top: auto;
    max-width: 100%;
    z-index: 1;
  }
}
@media screen and (max-width: 650px) and (max-width: 480px) {
  .odk-section-story__item__company__content {
    padding: 35rem;
    /* 20 * 1.75 */
  }
  .odk-section-story__item__company__content__thumb {
    width: 100%;
    max-width: 100%;
    /* 180 * 1.75 */
    margin-bottom: 28rem;
    /* 16 * 1.75 */
  }
  .odk-section-story__item__company__content__title {
    font-size: 32rem;
    /* 18 * 1.75 */
    min-height: 70rem;
    /* 40 * 1.75 */
    padding: 0 28rem;
    /* 16 * 1.75 */
  }
  .odk-section-story__item__company__content__subtitle {
    font-size: 44rem;
    /* 25 * 1.75 */
  }
  .odk-section-story__item__company__content__description {
    font-size: 23rem;
    /* 13 * 1.75 */
  }
}

/* ---------------------------------------------
   Reversed layout option for .odk-section-story__item
   Usage: add class .odk-section-story__item--rev to swap left/right
---------------------------------------------- */
.odk-section-story__item--rev {
  position: relative;
  /* Left-align only the company block while keeping others right-aligned */
  /* Mobile specific adjustments */
}
.odk-section-story__item--rev .odk-section-story__container {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-end;
  padding-top: 100rem;
  position: relative;
  margin-top: 100rem;
}
@media screen and (max-width: 1024px) {
  .odk-section-story__item--rev .odk-section-story__container {
    padding-top: 0rem;
  }
}
.odk-section-story__item--rev .odk-section-story__item__company {
  align-self: flex-start;
}
.odk-section-story__item--rev .odk-section-story__item__company__thumb {
  left: auto;
  right: 0rem;
  top: 160rem;
}
.odk-section-story__item--rev .odk-section-story__item__company__content {
  left: 0rem;
  padding: 70rem 140rem 80rem 62rem;
}
.odk-section-story__item--rev .odk-section-story__item {
  max-width: 100%;
  /* override default max-width */
  position: relative !important;
  z-index: 10 !important;
}
.odk-section-story__item--rev .odk-section-story__item__thumb {
  left: auto;
  right: 0;
  /* move thumb to right */
}
.odk-section-story__item--rev .odk-section-story__item__flow {
  left: -15rem;
  right: auto;
  /* move flow image to left */
}
.odk-section-story__item--rev .odk-section-story__item__content {
  left: auto;
  right: 385rem;
  /* adjusted per --rev layout */
  align-items: flex-start;
  /* switch alignment for left text */
  text-align: left;
}
.odk-section-story__item--rev .odk-section-story__item__text {
  width: 960rem;
  /* expand text box width for --rev layout */
}
@media screen and (max-width: 650px) {
  .odk-section-story__item--rev .odk-section-story__item__text {
    margin: 42rem auto 0;
    /* 24 * 1.75 */
  }
  .odk-section-story__item--rev .odk-section-story__item__content {
    right: auto;
    left: auto;
  }
  .odk-section-story__item--rev .odk-section-story__item__company__content {
    padding: 35rem;
  }
}

.odk-section-challenge {
  background: url(../img/bg_map.webp) no-repeat top center;
  background-size: cover;
  padding-top: 180rem;
  padding-bottom: 80rem;
  color: #fff;
}
.odk-section-challenge .odk-section-challenge__container {
  max-width: 1200rem;
  margin: 0 auto;
  box-sizing: border-box;
}
.odk-section-challenge .odk-section-challenge__header {
  position: relative;
  max-width: 928rem;
  /* SVG width */
  margin: 0 auto 130rem;
  text-align: center;
  background-color: transparent !important;
}
.odk-section-challenge .odk-section-challenge__title {
  position: relative;
  font-size: 48rem;
  /* match svg 48 */
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.35;
  margin: 0 0 40rem;
}
.odk-section-challenge .odk-section-challenge__title::before {
  content: "";
  position: absolute;
  top: -235rem;
  left: 50%;
  transform: translateX(-50%);
  width: 1rem;
  height: 155rem;
  background: #000;
}
.odk-section-challenge .odk-section-challenge__header__line {
  display: block;
  width: 313rem;
  /* 621-308 from svg */
  height: 2rem;
  background: #fff;
  margin: 0 auto 36rem;
}
.odk-section-challenge .odk-section-challenge__description {
  font-size: 24rem;
  /* match svg 24 */
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.8;
}
@media screen and (max-width: 650px) {
  .odk-section-challenge {
    padding-top: 160rem;
    padding-bottom: 140rem;
    /* 80 * 1.75 */
  }
  .odk-section-challenge .odk-section-challenge__header {
    margin-bottom: 184rem;
    /* 48 * 1.75 */
    max-width: 100%;
    padding: 0 0;
  }
  .odk-section-challenge .odk-section-challenge__title {
    font-size: 34rem;
    line-height: 1.4;
    margin-bottom: 49rem;
    /* keep spacing */
  }
  .odk-section-challenge .odk-section-challenge__header__line {
    width: 350rem;
    /* 200 * 1.75 */
    height: 4rem;
    /* 2 * 1.75 */
    margin-bottom: 49rem;
    /* 28 * 1.75 */
  }
  .odk-section-challenge .odk-section-challenge__description {
    font-size: 24rem;
    line-height: 2;
    font-weight: 400;
    text-align: left;
  }
  .odk-section-challenge .odk-section-challenge__container {
    padding: 0 35rem;
    /* 20 * 1.75 */
  }
}

.u-z-index-3 {
  z-index: 3 !important;
}

.u-sp-only {
  display: none;
}
@media screen and (max-width: 650px) {
  .u-sp-only {
    display: block;
  }
}

.u-pc-only {
  display: block;
}
@media screen and (max-width: 650px) {
  .u-pc-only {
    display: none;
  }
}

.u-sp-only {
  display: none;
}
@media screen and (max-width: 650px) {
  .u-sp-only {
    display: block;
  }
}

.pageTop {
  z-index: 200;
}
/*# sourceMappingURL=styles.css.map */