@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@300;500;700&family=Zen+Kaku+Gothic+New:wght@500;700&display=swap");
@carset "UTF-8";
/* rule */
img {
  display: inline-block; }

ul, li, dl, dt, dd {
  list-style: none;
  padding: 0;
  margin: 0; }

table {
  border-collapse: collapse;
  border-spacing: 0;
  table-layout: fixed; }
  table th {
    font-weight: normal; }

@media only screen and (min-width: 768px) {
  .-view_sp {
    display: none !important; }

  a[href*="tel"] {
    pointer-events: none; } }
@media only screen and (max-width: 767px) {
  .-view_over_sp, .-view_pc {
    display: none !important; } }
.-align-center {
  text-align: center !important; }

.-align-right {
  text-align: right !important; }
  @media screen and (max-width: 767px) {
    .-align-right:is(p) {
      text-align: left !important; } }

.-indent {
  text-indent: -1em;
  padding-left: 1em; }
  .-indent:has(li) {
    line-height: 1.2; }
    .-indent:has(li) * + li {
      margin-top: .4em; }

.w-indent {
  padding-left: 1.5em; }

.-w-default {
  width: var(--width-default) !important; }

/* margin */
.-mg_t0 {
  margin-top: 0 !important; }

.-mg_t10 {
  margin-top: var(--size010) !important; }

.-mg_t20 {
  margin-top: var(--size020) !important; }

.-mg_t30 {
  margin-top: var(--size030) !important; }

.-mg_t40 {
  margin-top: var(--size040) !important; }

.-mg_t50 {
  margin-top: var(--size050) !important; }

.-mg_t60 {
  margin-top: var(--size060) !important; }

.-mg_t70 {
  margin-top: var(--size070) !important; }

.-mg_t80 {
  margin-top: var(--size080) !important; }

.-mg_t100 {
  margin-top: var(--size100) !important; }
  @media screen and (max-width: 767px) {
    .-mg_t100 {
      margin-top: var(--size080) !important; } }

.-mg_t120 {
  margin-top: var(--size120) !important; }

.-pd_t0 {
  padding-top: 0 !important; }

.fs-smaller {
  font-size: var(--size012) !important; }

.fs-small {
  font-size: var(--size014) !important; }

.fs-copy {
  font-size: var(--size040);
  line-height: 1.4 !important; }
  @media screen and (max-width: 767px) {
    .fs-copy {
      font-size: var(--size035); } }

/* slick */
.js-slider {
  opacity: 0;
  transition: .3s; }

.js-slider.slick-initialized {
  opacity: 1; }

/* font */
.ff-zen-kaku {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal; }

.ff-zen-kaku.-bold {
  font-weight: 700; }

.ff-poppins {
  font-family: 'Poppins', sans-serif;
  font-weight: 300; }

.ff-poppins.-bold {
  font-weight: 500; }

.l-crumb {
  border-bottom: none; }

/*bg*/
.content-pride_17-lower {
  position: relative; }
  .content-pride_17-lower::before {
    content: '';
    display: flex;
    width: 100%;
    height: 100%;
    position: absolute;
    top: -48px;
    left: 0;
    background: url("/pride/pride_17/assets/img/bg.webp") 0 0 no-repeat;
    background-attachment: fixed;
    background-position: 0 0;
    background-size: 75vw auto;
    z-index: -1;
    opacity: .75; }
    @media screen and (max-width: 700px) {
      .content-pride_17-lower::before {
        top: 0;
        background-size: 140vw auto; } }

.hl-cont_title {
  display: flex;
  flex-direction: column;
  gap: 20px;
  filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.4));
  transition: .3s scale;
  transform-origin: top right; }
  .hl-cont_title span {
    display: block;
    width: clamp(50px, 5vw, 80px); }
  .hl-cont_title .c-img {
    aspect-ratio: 90 / 328;
    display: block;
    background: #fff;
    mask: url("/pride/pride_17/assets/img/ttl-copy.svg") no-repeat center center/cover;
    -webkit-mask: url("/pride/pride_17/assets/img/ttl-copy.svg") no-repeat center center/cover;
    transition: .3s background; }
    .hl-cont_title .c-img img {
      opacity: 0; }
  .hl-cont_title .c-number {
    font-size: clamp(2.2rem, 2.5vw, 3rem);
    text-align: center;
    color: #fff;
    transition: .3s color; }
    .hl-cont_title .c-number b {
      font-size: clamp(3rem, 3.2vw, 4rem);
      padding-left: 5px;
      letter-spacing: -.1em; }
    .hl-cont_title .c-number::before {
      content: '';
      display: flex;
      width: 90%;
      height: 1px;
      background: #fff;
      opacity: .5;
      margin: 0 auto 12px;
      transition: .3s background; }
  .hl-cont_title.-large {
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.1)); }
    .hl-cont_title.-large span {
      width: 130px; }
    @media screen and (max-width: 912px) {
      .hl-cont_title.-large .c-img {
        aspect-ratio: 300 / 76;
        mask: url("/pride/pride_17/assets/img/ttl-copy_sp.svg") no-repeat center center/cover;
        -webkit-mask: url("/pride/pride_17/assets/img/ttl-copy_sp.svg") no-repeat center center/cover; } }
    @media screen and (max-width: 912px) {
      .hl-cont_title.-large {
        filter: drop-shadow(0px 0px 5px rgba(255, 255, 255, 0.5)); }
        .hl-cont_title.-large span {
          width: auto;
          height: min(18vw, 120px); } }
  .hl-cont_title.-blue .c-img {
    background: #003b87; }
  .hl-cont_title.-blue .c-number {
    color: #003b87; }
    .hl-cont_title.-blue .c-number::before {
      background: #003b87; }
  @media screen and (min-width: 1121px) {
    .hl-cont_title.is-exchange {
      scale: .85;
      filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0)); }
      .hl-cont_title.is-exchange .c-img {
        background: #003b87; }
      .hl-cont_title.is-exchange .c-number {
        color: #003b87; }
        .hl-cont_title.is-exchange .c-number::before {
          background: #003b87; } }

.blk-btn {
  text-align: center;
  padding: 5em 0 10vw; }
  @media screen and (max-width: 700px) {
    .blk-btn {
      padding: 5em 5vw 10vw; } }

.btn-conversion {
  display: inline-flex;
  font-size: clamp(1.5rem, 1.8vw, 1.8rem);
  letter-spacing: .02em;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  color: #fff;
  background: #003B87;
  padding: .6em 3em;
  text-decoration: none;
  border-radius: 100vmax;
  gap: 1.1em;
  align-items: center; }
  .btn-conversion .c-ico img {
    width: 2.25em;
    height: 2.25em; }
  .btn-conversion:after {
    content: '';
    display: flex;
    background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2236%22%20height%3D%2236%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-width%3D%221%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22ai%20ai-ChevronRight%22%3E%3Cpath%20d%3D%22M8%204l8%208-8%208%22%2F%3E%3C%2Fsvg%3E") 50% 50% no-repeat;
    background-size: cover;
    width: 1.4em;
    aspect-ratio: 1/1; }

.sec-content {
  margin: 10vw 0 0 max(15vw, 150px);
  width: 80vw;
  max-width: 1320px;
  /* &.-pickup {
      margin: 0 auto;
      max-width: 1600px;
      width: 96%;
      position: relative;
      padding: 15vw 0;
  } */ }
  @media screen and (max-width: 1120px) {
    .sec-content {
      margin: max(12vw, 120px) auto;
      width: 86vw; } }

@media screen and (max-width: 912px) {
  .w-main .l-main {
    padding: 0 !important; } }
.btn-round_border {
  font-size: 1.5rem;
  display: inline-flex;
  padding: .75em 5em;
  line-height: 1;
  border-radius: 100vmax;
  border: 1px solid currentColor;
  text-decoration: none;
  position: relative;
  transition: .5s background, .3s text-shadow; }
  .btn-round_border::after {
    content: '';
    display: flex;
    background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2248.207%22%20height%3D%2213.414%22%20viewBox%3D%220%200%2048.207%2013.414%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4%22%20data-name%3D%22%E3%83%91%E3%82%B9%204%22%20d%3D%22M30%2C8H-17M30%2C8l-6%2C6m6-6L24%2C2%22%20transform%3D%22translate(17.5%20-1.293)%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%221%22%2F%3E%3C%2Fsvg%3E") 100% 50% no-repeat;
    background-size: auto 100%;
    width: 1.2em;
    height: 12px;
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    transition: .3s width, .3s translate; }
  .btn-round_border.-col_white {
    color: #fff;
    border-color: #fff; }
  .btn-round_border:hover {
    text-shadow: 0 0 5px white;
    background: rgba(255, 255, 255, 0.2); }
    .btn-round_border:hover::after {
      width: 47px;
      translate: calc(60px - 1.2em) -50%; }

.blk-return {
  text-align: center; }

.link-return {
  font-size: clamp(1.3rem, 1.6vw, 1.6rem);
  display: inline-flex;
  gap: 1.5em;
  position: relative;
  align-items: center;
  text-decoration: none; }
  .link-return::before {
    content: '';
    display: flex;
    width: 1.4em;
    aspect-ratio: 1/1;
    border: 1px solid currentColor;
    border-radius: 100vmax; }
  .link-return::after {
    content: '';
    display: flex;
    background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2248.207%22%20height%3D%2213.414%22%20viewBox%3D%220%200%2048.207%2013.414%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4%22%20data-name%3D%22%E3%83%91%E3%82%B9%204%22%20d%3D%22M30%2C8H-17M30%2C8l-6%2C6m6-6L24%2C2%22%20transform%3D%22translate(17.5%20-1.293)%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%221%22%2F%3E%3C%2Fsvg%3E") 100% 50% no-repeat;
    background-size: auto 100%;
    width: 1.5em;
    height: 9px;
    position: absolute;
    left: .6em;
    top: calc(50% - 4.5px);
    transition: .3s width, .3s translate;
    rotate: 180deg; }

/* CSS Document */
.blk-text-scroll {
  position: fixed;
  z-index: 10;
  left: 50%;
  bottom: 60px;
  translate: -50% 0;
  transition: .3s opacity; }
  .blk-text-scroll span {
    font-size: 1.7rem;
    position: relative; }
    .blk-text-scroll span::after {
      content: '';
      display: block;
      width: 1px;
      height: 50px;
      scale: 1 0;
      background: #292929;
      right: 50%;
      top: 110%;
      transform-origin: center top;
      position: absolute;
      animation: border_anim 2s linear 1s infinite; }
  .blk-text-scroll.is-scrolled {
    opacity: 0; }
  @media screen and (max-width: 700px) {
    .blk-text-scroll {
      bottom: 40px; }
      .blk-text-scroll span {
        font-size: 1.4rem; } }

@keyframes border_anim {
  0% {
    scale: 1 0;
    transform-origin: center top; }
  25% {
    scale: 1 1;
    transform-origin: center top; }
  26% {
    scale: 1 1;
    transform-origin: center bottom; }
  50% {
    scale: 1 0;
    transform-origin: center bottom; }
  100% {
    scale: 1 0;
    transform-origin: center bottom; } }
.sec-mv-root {
  position: relative; }

.blk-mv-root {
  position: sticky;
  z-index: -1;
  top: 4svh;
  width: 100%;
  height: 92svh;
  /* overflow: clip; */
  display: grid;
  grid-template-columns: 20vw 14vw 26.6vw 20vw 14vw;
  justify-content: space-between; }
  @media screen and (max-width: 912px) {
    .blk-mv-root {
      grid-template-columns: 32.5vw 28vw 32.5vw;
      padding: 0 1.5vw 20svh;
      height: 75svh;
      top: 4vw;
      gap: 1vw; } }
  @media screen and (max-width: 700px) {
    .blk-mv-root {
      padding: 4vw 1.5vw 17svh;
      height: 80svh;
      /* top: 4vw;
      gap: 1vw; */ } }
  .blk-mv-root > div {
    display: flex;
    flex-direction: column;
    gap: 1vw;
    justify-content: space-between;
    transition: .3s box-shadow, 1s opacity; }
    .blk-mv-root > div div {
      overflow: hidden;
      border-radius: 3px; }
    .blk-mv-root > div.row-blk3 div {
      height: calc((100% - 1.3vw * 2) / 3);
      box-shadow: 3px 3px 15px rgba(0, 0, 0, 0.12);
      opacity: 1; }
      .blk-mv-root > div.row-blk3 div:is(.is-scrolled div) {
        box-shadow: 0 0 0 rgba(0, 0, 0, 0); }
      @media screen and (max-width: 912px) {
        .blk-mv-root > div.row-blk3 div {
          box-shadow: 0 0 0 rgba(0, 0, 0, 0); } }
      @media screen and (min-width: 701px) and (max-width: 912px) {
        .blk-mv-root > div.row-blk3 div {
          height: calc((100% - 1.3vw) / 2); }
          .blk-mv-root > div.row-blk3 div:last-of-type {
            display: none; } }
    .blk-mv-root > div.row-blk2 div {
      height: calc((100% - 1.3vw) / 2);
      box-shadow: 3px 3px 15px rgba(0, 0, 0, 0.12);
      opacity: 1; }
      .blk-mv-root > div.row-blk2 div:is(.is-scrolled div) {
        box-shadow: 0 0 0 rgba(0, 0, 0, 0); }
      @media screen and (max-width: 912px) {
        .blk-mv-root > div.row-blk2 div {
          box-shadow: 0 0 0 rgba(0, 0, 0, 0); } }
      @media screen and (min-width: 701px) and (max-width: 912px) {
        .blk-mv-root > div.row-blk2 div {
          height: 100%; }
          .blk-mv-root > div.row-blk2 div:last-of-type {
            display: none; } }
    @media screen and (max-width: 912px) {
      .blk-mv-root > div {
        gap: 1.3vw; }
        .blk-mv-root > div:nth-of-type(5) {
          display: none; } }
    .blk-mv-root > div img {
      object-fit: cover;
      width: 100%;
      height: 100%;
      display: block; }
    .blk-mv-root > div.row-title {
      position: relative; }
      .blk-mv-root > div.row-title .hl-cont_title {
        position: absolute;
        left: 50%;
        top: 35%;
        translate: -50% -50%;
        transition: .5s opacity, .3s filter;
        opacity: 1; }
        .blk-mv-root > div.row-title .hl-cont_title.is-hide {
          opacity: 0;
          filter: drop-shadow(0 0 0 rgba(0, 0, 0, 0)); }
        @media screen and (min-width: 701px) and (max-width: 912px) {
          .blk-mv-root > div.row-title .hl-cont_title {
            top: auto;
            bottom: -7vw; } }
        @media screen and (max-width: 700px) {
          .blk-mv-root > div.row-title .hl-cont_title {
            top: auto;
            bottom: 0; } }
      @media screen and (max-width: 912px) {
        .blk-mv-root > div.row-title {
          position: absolute;
          width: 100%;
          height: 100%; } }

.blk-main {
  position: relative;
  z-index: 1;
  width: 100%; }
  .blk-main > div {
    height: 100svh;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center; }

.sec-introduction-root {
  padding: 100svh 0 100svh; }
  .sec-introduction-root p {
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-size: clamp(1.5rem, 2vw, 2.2rem);
    line-height: 2;
    letter-spacing: .1em;
    text-align: center;
    text-shadow: 0 0 5px white; }
    @media screen and (max-width: 912px) {
      .sec-introduction-root p {
        text-align: left; }
        .sec-introduction-root p br {
          display: none; } }
  .sec-introduction-root * + * {
    margin-top: 1em; }
  .sec-introduction-root::before {
    content: '';
    display: flex;
    width: 120%;
    left: -10%;
    height: 100%;
    background: rgba(255, 255, 255, 0.1);
    position: absolute;
    z-index: -1;
    backdrop-filter: blur(8px);
    mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, black 20%, black 90%, rgba(0, 0, 0, 0) 100%); }
    @media screen and (max-width: 912px) {
      .sec-introduction-root::before {
        background: rgba(255, 255, 255, 0.7);
        backdrop-filter: blur(4px); } }
  @media screen and (max-width: 912px) {
    .sec-introduction-root div {
      padding: 0 10vw; } }

.list-idea_pickup {
  margin: 0 auto;
  max-width: 1600px;
  width: 96%;
  position: relative;
  padding: 20vw 0 5vw; }
  @media screen and (max-width: 912px) {
    .list-idea_pickup {
      width: 100%; } }

.c-item_pickup {
  position: sticky;
  height: calc(100svh - 10svh);
  top: 5svh; }
  * + .c-item_pickup {
    margin-top: 45vw; }
  @media screen and (max-width: 912px) {
    .c-item_pickup {
      height: 100svh;
      top: 0;
      opacity: 1 !important;
      transform: perspective(500px) scale3d(1, 1, 1) !important;
      padding: 1.5vw; } }
  @media screen and (min-width: 913px) {
    .c-item_pickup {
      transform-origin: center 20%; } }
  .c-item_pickup .c-img {
    position: relative;
    z-index: 1;
    height: 100%;
    width: 100%;
    overflow: clip;
    border-radius: 5px;
    box-shadow: 0 0 35px rgba(230, 230, 230, 0.8); }
    .c-item_pickup .c-img img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    .c-item_pickup .c-img::before {
      content: '';
      display: flex;
      width: 100%;
      height: 100%;
      background: #122947;
      opacity: .45;
      position: absolute;
      left: 0;
      top: 0;
      z-index: 1;
      mix-blend-mode: multiply; }
  .c-item_pickup .c-text {
    position: absolute;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    color: #fff; }
    @media screen and (max-width: 767px) {
      .c-item_pickup .c-text {
        padding: 0 2vw; } }
    .c-item_pickup .c-text .c-number {
      font-size: 3rem;
      margin-bottom: 1em;
      text-shadow: 0 0 7px rgba(0, 0, 0, 0.3); }
      .c-item_pickup .c-text .c-number b {
        font-size: 4.4rem;
        padding-left: .2em;
        letter-spacing: -.05em; }
    .c-item_pickup .c-text .hl-shoulder-title {
      font-size: 4.8rem; }
      @media screen and (max-width: 767px) {
        .c-item_pickup .c-text .hl-shoulder-title {
          font-size: 3.1rem;
          text-align: center;
          letter-spacing: 0;
          line-height: 1.7; } }
      .c-item_pickup .c-text .hl-shoulder-title span.c-box {
        background: #2E3B4C;
        /* -webkit-background-clip: text; */
        box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); }
      .c-item_pickup .c-text .hl-shoulder-title span:not(.c-box) {
        text-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
        margin-right: .075em;
        letter-spacing: -.02em;
        position: relative; }
        .c-item_pickup .c-text .hl-shoulder-title span:not(.c-box)::before {
          content: '';
          display: flex;
          width: 100%;
          height: 1px;
          background: #fff;
          opacity: .5;
          position: absolute;
          bottom: 0; }
          @media screen and (max-width: 767px) {
            .c-item_pickup .c-text .hl-shoulder-title span:not(.c-box)::before {
              display: none; } }
    .c-item_pickup .c-text .c-ideaname {
      font-family: "Zen Kaku Gothic New", sans-serif;
      font-weight: 500;
      font-size: clamp(2.2rem, 2.5vw, 2.8rem);
      text-shadow: 0 0 7px rgba(0, 0, 0, 0.3); }
      .c-item_pickup .c-text .c-ideaname b {
        font-weight: 500;
        font-size: clamp(2.8rem, 3vw, 3.2rem); }
    .c-item_pickup .c-text .blk-btn {
      padding: 0;
      margin: 6em auto 0; }

/* CSS Document */
.content-pride_17-lower {
  padding-top: 15px; }
  @media screen and (max-width: 1120px) {
    .content-pride_17-lower {
      padding-top: 0; } }

.frm-main-lower {
  display: grid;
  grid-template-columns: 100% 0px; }
  .frm-main-lower .row-main {
    position: relative;
    z-index: 1; }
  .frm-main-lower .row-copy {
    position: relative;
    z-index: 5;
    right: calc(80px + 2.5vw); }
    .frm-main-lower .row-copy .hl-cont_title {
      position: sticky;
      right: 3vw;
      top: 0;
      padding-top: max(7vw, 50px); }
  @media screen and (max-width: 1120px) {
    .frm-main-lower .row-copy {
      position: static;
      right: 0; }
      .frm-main-lower .row-copy .hl-cont_title {
        position: absolute; } }

.hl-sec_around {
  font-size: clamp(2.8rem, 3.6vw, 5.6rem);
  letter-spacing: .1em;
  font-family: 'Poppins', sans-serif;
  font-weight: 300;
  text-align: center; }

.list-ideas {
  display: grid;
  margin: 0 auto 5vw;
  width: 94%;
  max-width: 1400px;
  /* @include mq(under_912) {
      grid-template-columns: repeat(2, 1fr);
      gap: 2px;
  } */ }
  @media screen and (max-width: 1120px) {
    .list-ideas {
      width: 94%; } }
  .list-ideas.-around {
    grid-template-columns: repeat(3, 1fr);
    gap: .5vw;
    margin-bottom: 3vw; }
    @media screen and (max-width: 912px) {
      .list-ideas.-around {
        grid-template-columns: repeat(2, 1fr);
        gap: 3px; } }
  .list-ideas.-root {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.2vw; }
    @media screen and (max-width: 912px) {
      .list-ideas.-root {
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 0 2vw; } }
    .list-ideas.-root .c-thumb::after {
      display: block !important;
      background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2248.207%22%20height%3D%2213.414%22%20viewBox%3D%220%200%2048.207%2013.414%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4%22%20data-name%3D%22%E3%83%91%E3%82%B9%204%22%20d%3D%22M30%2C8H-17M30%2C8l-6%2C6m6-6L24%2C2%22%20transform%3D%22translate(17.5%20-1.293)%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%221.5%22%2F%3E%3C%2Fsvg%3E") 100% 50% no-repeat;
      background-size: auto 100%;
      width: 2.5em;
      height: 16px;
      opacity: 1 !important; }
      @media screen and (max-width: 700px) {
        .list-ideas.-root .c-thumb::after {
          width: 2em;
          height: 13px; } }
  * + .list-ideas {
    margin-top: 4em; }

.c-item_ideas {
  transition: .3s opacity, .3s scale, .3s translate;
  opacity: 0;
  scale: .7;
  translate: 0 50px; }
  .c-item_ideas a {
    display: block;
    overflow: clip;
    position: relative;
    text-decoration: none; }
    .c-item_ideas a:hover .c-thumb::before {
      opacity: .2; }
  .c-item_ideas .c-thumb {
    position: relative;
    z-index: 1;
    aspect-ratio: 3/2;
    overflow: clip;
    border-radius: 2px; }
    .c-item_ideas .c-thumb img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: .3s scale;
      position: relative;
      z-index: -1; }
      .c-item_ideas .c-thumb img:is(a:hover img) {
        scale: 1.1; }
    .c-item_ideas .c-thumb::before {
      content: '';
      display: flex;
      width: 100%;
      height: 100%;
      position: absolute;
      left: 0;
      top: 0;
      background: rgba(146, 154, 165, 0.7);
      mix-blend-mode: multiply;
      transition: .3s opacity; }
    .c-item_ideas .c-thumb:is(.-root div) {
      aspect-ratio: 1/.8; }
    .c-item_ideas .c-thumb::after {
      content: '';
      display: flex;
      background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2248.207%22%20height%3D%2213.414%22%20viewBox%3D%220%200%2048.207%2013.414%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4%22%20data-name%3D%22%E3%83%91%E3%82%B9%204%22%20d%3D%22M30%2C8H-17M30%2C8l-6%2C6m6-6L24%2C2%22%20transform%3D%22translate(17.5%20-1.293)%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3C%2Fsvg%3E") 100% 50% no-repeat;
      background-size: auto 100%;
      width: 2em;
      height: 14px;
      position: absolute;
      bottom: 2em;
      right: 2em;
      z-index: 2; }
      @media screen and (max-width: 700px) {
        .c-item_ideas .c-thumb::after {
          opacity: 0; } }
  .c-item_ideas.is-show {
    opacity: 1;
    scale: 1;
    translate: 0 0 0; }
  @media screen and (max-width: 912px) {
    .c-item_ideas .c-thumb {
      aspect-ratio: 1/.6; }
      .c-item_ideas .c-thumb img {
        width: 100%;
        height: 100%; }
      .c-item_ideas .c-thumb::before {
        background: rgba(146, 154, 165, 0); } }

.hl-list-ideas {
  display: flex;
  color: #fff;
  gap: 1.1em;
  text-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
  font-feature-settings: "palt";
  letter-spacing: .1em; }
  .hl-list-ideas .c-number {
    font-family: "Poppins", sans-serif;
    font-weight: 300;
    font-size: clamp(1.1rem, 1.5vw, 1.5rem);
    padding-top: .15em; }
    .hl-list-ideas .c-number:is(.-root h3 span) {
      font-size: clamp(1.3rem, 1.5vw, 1.7rem);
      white-space: nowrap;
      padding: .25em .5em 0 0; }
    .hl-list-ideas .c-number b {
      font-size: clamp(1.3rem, 2vw, 2rem);
      font-weight: 500;
      padding-left: .2em;
      letter-spacing: -.1em; }
      .hl-list-ideas .c-number b:is(.-root h3 span b) {
        font-size: clamp(1.6rem, 2.1vw, 2.8rem); }
  .hl-list-ideas .c-title {
    font-size: clamp(1.3rem, 1.6vw, 2rem);
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-weight: 500;
    line-height: 1.4; }
    .hl-list-ideas .c-title:is(.-root h3 span) {
      font-size: clamp(1.6rem, 2.1vw, 2.8rem);
      white-space: nowrap; }
      @media screen and (max-width: 912px) {
        .hl-list-ideas .c-title:is(.-root h3 span) {
          white-space: normal; } }
  .c-item_ideas .hl-list-ideas {
    position: absolute;
    z-index: 2;
    bottom: 1.7em;
    left: 1.7em; }
    .c-item_ideas .hl-list-ideas:is(.-root h3) {
      right: 50%;
      bottom: 48%;
      translate: 50% 50%; }
      @media screen and (max-width: 912px) {
        .c-item_ideas .hl-list-ideas:is(.-root h3) {
          translate: 0; } }
  @media screen and (max-width: 912px) {
    .hl-list-ideas {
      color: currentColor;
      text-shadow: 0 0 0 rgba(0, 0, 0, 0);
      padding: 1em .5em 1.5em; }
      .hl-list-ideas .c-title br {
        display: none; }
      .c-item_ideas .hl-list-ideas {
        position: static;
        z-index: 2;
        bottom: 0;
        right: 0; } }

.hl-sec-gallery {
  font-size: clamp(2rem, 2.2vw, 3rem);
  line-height: 1.875;
  font-feature-settings: "palt";
  letter-spacing: .1em;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  color: #6C7581;
  margin-bottom: 1.8em; }
  .hl-sec-gallery span {
    background: linear-gradient(transparent 98%, #dde 0%); }

.blk-img {
  margin: 0 auto;
  max-width: 1000px;
  transition: .5s opacity, .5s transform;
  opacity: 0;
  transform: perspective(500px) translate3d(0, 100px, -100px);
  transform-origin: center top; }
  .blk-img img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 2px; }
  * + .blk-img {
    margin-top: 3em; }
  .blk-img.is-show {
    opacity: 1;
    transform: perspective(500px) translate3d(0, 0, 0); }

.blk-flex-imgs {
  display: grid;
  gap: 20px;
  max-width: 1200px;
  grid-template-columns: repeat(2, 1fr);
  margin: 0 auto; }
  .blk-flex-imgs div img {
    width: 100%;
    height: auto; }
  .blk-flex-imgs div:nth-of-type(2) {
    position: relative;
    margin-top: 6.7vw; }
  .blk-flex-imgs.-no_gap div:nth-of-type(2) {
    margin-top: 0; }
  @media screen and (max-width: 912px) {
    .blk-flex-imgs {
      gap: 0; } }

.txt-caption-gallery {
  font-size: clamp(1.45rem, 1.5vw, 1.7rem);
  text-align: center;
  font-feature-settings: "palt"; }
  * + .txt-caption-gallery {
    margin-top: 2em;
    line-height: 2; }
  @media screen and (max-width: 700px) {
    .txt-caption-gallery {
      text-align: left; }
      .txt-caption-gallery br {
        display: none; } }

.blk-introduction {
  margin: 0 0 0 max(15vw, 150px);
  width: 74svw;
  max-width: 1320px;
  padding-top: 8vw; }
  .blk-introduction .c-inner {
    display: grid;
    grid-template-columns: auto auto;
    gap: 10em;
    align-items: flex-start;
    justify-content: space-between; }
  .blk-introduction .row-text {
    max-width: 520px;
    padding-top: 7em; }
    .blk-introduction .row-text p {
      font-size: clamp(1.5rem, 1.8vw, 1.8rem);
      line-height: 2;
      color: #6C7581;
      text-align: justify; }
  @media screen and (max-width: 1120px) {
    .blk-introduction {
      margin: 0 auto;
      width: 90%; }
      .blk-introduction .c-inner {
        grid-template-columns: auto;
        gap: 4em; }
      .blk-introduction .row-text {
        max-width: none;
        padding-top: 0; } }
  .blk-introduction .p-text_award {
    display: block;
    margin: 3em 0 0;
    text-decoration: none; }
    .blk-introduction .p-text_award figure {
      display: grid;
      grid-template-columns: auto 1fr;
      gap: 1em;
      margin: 0; }
      .blk-introduction .p-text_award figure img {
        width: 90%;
        max-width: 140px;
        height: auto; }
      .blk-introduction .p-text_award figure figcaption {
        font-weight: bold;
        font-size: clamp(1.4rem, 1.7vw, 1.7rem);
        display: inline-flex;
        align-items: center;
        gap: .5em;
        /* &:before {
        	@include set-pseudo-selector;
        	width: 1.5em;
        	aspect-ratio: 1/1;
        	background: 		url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2224px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2224px%22%20fill%3D%22%236C7581%22%3E%3Cpath%20d%3D%22M280-120v-80h160v-124q-49-11-87.5-41.5T296-442q-75-9-125.5-65.5T120-640v-40q0-33%2023.5-56.5T200-760h80v-80h400v80h80q33%200%2056.5%2023.5T840-680v40q0%2076-50.5%20132.5T664-442q-18%2046-56.5%2076.5T520-324v124h160v80H280Zm0-408v-152h-80v40q0%2038%2022%2068.5t58%2043.5Zm400%200q36-13%2058-43.5t22-68.5v-40h-80v152Z%22%2F%3E%3C%2Fsvg%3E') 50% 50% no-repeat;
        	background-size: cover;
        } */ }
        .blk-introduction .p-text_award figure figcaption:after {
          content: '';
          display: flex;
          width: 1.2em;
          aspect-ratio: 1/1;
          background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2224px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2224px%22%20fill%3D%22%235f6368%22%3E%3Cpath%20d%3D%22M200-120q-33%200-56.5-23.5T120-200v-560q0-33%2023.5-56.5T200-840h280v80H200v560h560v-280h80v280q0%2033-23.5%2056.5T760-120H200Zm188-212-56-56%20372-372H560v-80h280v280h-80v-144L388-332Z%22%2F%3E%3C%2Fsvg%3E") 50% 50% no-repeat;
          background-size: cover; }
    @media screen and (max-width: 767px) {
      .blk-introduction .p-text_award {
        text-align: center;
        margin-top: 3em; } }

.row-title {
  display: flex;
  gap: 3em;
  line-height: 1; }
  .row-title .c-number {
    font-size: clamp(2.1rem, 2.5vw, 3rem); }
    .row-title .c-number b {
      font-size: clamp(3.6rem, 4vw, 4.8rem);
      padding-left: .02em;
      letter-spacing: -.1em; }
  .row-title .box-line {
    border-left: 1px solid #969CA5;
    padding-left: 2em; }
  @media screen and (max-width: 767px) {
    .row-title {
      flex-direction: column; }
      .row-title .c-number {
        display: none; }
      .row-title .box-line {
        border-left: none;
        padding-left: 0; } }

.hl-shoulder-title {
  font-size: clamp(1.8rem, 2.2vw, 2.5rem);
  font-feature-settings: "palt";
  letter-spacing: .05em;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  margin-bottom: .7em;
  line-height: 1.4; }
  .hl-shoulder-title.-large {
    font-size: clamp(2.2rem, 2.6vw, 3rem); }
  .hl-shoulder-title .c-box {
    display: inline-flex;
    color: #fff;
    background: #2E3B4C;
    aspect-ratio: 1/1;
    line-height: 1;
    justify-content: center;
    align-items: center;
    margin-left: .12em;
    padding: .12em .1em .25em .15em;
    /* font-weight: 600; */ }

.hl-title-gallery {
  font-feature-settings: "palt";
  letter-spacing: .05em;
  font-size: clamp(3rem, 3.5vw, 4rem);
  line-height: 1.2; }
  .hl-title-gallery b {
    font-size: clamp(3.6rem, 4vw, 5rem);
    margin-left: .1em;
    font-weight: 700; }

.sec-mv {
  overflow: hidden; }

.blk-mv {
  height: 680px;
  margin-left: 5vw;
  position: relative; }
  .blk-mv img {
    object-fit: cover;
    width: 100%;
    height: 100%; }
  .blk-mv:after {
    content: '';
    display: flex;
    width: 40%;
    height: 100%;
    background: linear-gradient(90deg, #fff 0%, #808080 100%);
    opacity: 0.6;
    position: absolute;
    right: 0;
    top: 0;
    mix-blend-mode: multiply; }
  @media screen and (max-width: 1120px) {
    .blk-mv {
      margin-left: 0;
      height: 60vw; } }
  @media screen and (max-width: 700px) {
    .blk-mv {
      height: 105vw; } }

.blk-mv-group {
  padding-left: 5vw; }
  @media screen and (max-width: 1120px) {
    .blk-mv-group {
      padding-left: 0; } }

.list-mv {
  display: flex;
  width: max-content; }
  .list-mv div {
    width: 43vw;
    height: 650px;
    overflow: hidden;
    position: relative; }
    .list-mv div:nth-of-type(2) {
      top: 3vw;
      left: -3vw;
      z-index: 2;
      box-shadow: 0 0 20px rgba(0, 0, 0, 0.2); }
    .list-mv div:nth-of-type(3) {
      left: -6vw;
      background: currentColor; }
      .list-mv div:nth-of-type(3) img {
        opacity: .9; }
    .list-mv div img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    @media screen and (max-width: 1120px) {
      .list-mv div {
        width: 51vw;
        height: 60vw; }
        .list-mv div:nth-of-type(3) {
          display: none; }
        .list-mv div:nth-of-type(2n):after {
          content: '';
          display: flex;
          width: 40%;
          height: 100%;
          background: linear-gradient(90deg, #fff 0%, #808080 100%);
          opacity: 0.6;
          position: absolute;
          right: 0;
          top: 0;
          mix-blend-mode: multiply; } }
    @media screen and (max-width: 700px) {
      .list-mv div:nth-of-type(2n+1) {
        display: none; }
      .list-mv div:nth-of-type(2n) {
        width: 100%;
        height: 105vw;
        top: 0;
        left: 0;
        box-shadow: unset; } }

.sec-content.-thoughts {
  margin: 16vw 0 0;
  padding-left: max(15vw, 150px);
  overflow-x: clip;
  max-width: none;
  width: auto;
  align-items: flex-start; }
  .sec-content.-thoughts .c-inner {
    display: grid;
    grid-template-columns: 44% 1fr;
    width: 80vw;
    max-width: 1320px; }
  .sec-content.-thoughts .row-text {
    padding-top: 2em;
    position: relative;
    z-index: 6;
    display: flex;
    align-items: center; }
    .sec-content.-thoughts .row-text p {
      font-size: clamp(1.45rem, 1.8vw, 1.7rem);
      font-feature-settings: "palt";
      letter-spacing: .05em;
      font-family: "Zen Kaku Gothic New", sans-serif;
      font-weight: 500;
      line-height: 1.875;
      padding-right: 4em;
      text-align: justify; }
      * + .sec-content.-thoughts .row-text p {
        margin-top: 2em; }
    .sec-content.-thoughts .row-text > div {
      opacity: 0;
      translate: 0 5em;
      transition: .5s opacity, .5s translate; }
  .sec-content.-thoughts .row-img {
    position: relative;
    border: none;
    z-index: 5; }
    .sec-content.-thoughts .row-img .blk-sticky {
      top: 4vw; }
      .sec-content.-thoughts .row-img .blk-sticky img {
        width: 130%;
        height: auto;
        display: block;
        transition: .5s box-shadow; }
    .sec-content.-thoughts .row-img::before {
      content: '';
      display: flex;
      width: 110%;
      height: calc(100% + 120px);
      position: absolute;
      right: 90%;
      top: -60px;
      background: #F5F4EE;
      opacity: .6;
      z-index: -1;
      scale: 0 1;
      transform-origin: left top;
      transition: .5s scale; }
  .sec-content.-thoughts.is-scrolled .row-text > div {
    opacity: 1;
    translate: 0 0; }
  .sec-content.-thoughts.is-scrolled .row-img .blk-sticky img {
    transition-delay: .7s;
    box-shadow: 0 0 40px rgba(0, 0, 0, 0.2); }
  .sec-content.-thoughts.is-scrolled .row-img::before {
    scale: 1 1; }
  @media screen and (max-width: 1280px) {
    .sec-content.-thoughts {
      margin: 12vw auto;
      padding-left: 0; }
      .sec-content.-thoughts .c-inner {
        grid-template-columns: auto;
        margin: 0 auto;
        width: 100%;
        position: relative; }
      .sec-content.-thoughts .row-img {
        order: 0;
        padding: 0 5vw;
        position: static; }
        .sec-content.-thoughts .row-img .blk-sticky img {
          width: 100%;
          height: 100%;
          object-fit: cover; }
        .sec-content.-thoughts .row-img::before {
          width: 100%;
          height: 95%;
          right: 0;
          top: 10%;
          opacity: .6; }
      .sec-content.-thoughts .row-text {
        order: 1;
        padding: 6em 10vw 6em 17vw; } }
  @media screen and (max-width: 1120px) {
    .sec-content.-thoughts .row-img {
      padding: 0; }
      .sec-content.-thoughts .row-img .blk-sticky img {
        box-shadow: 0 0 0 rgba(0, 0, 0, 0); }
    .sec-content.-thoughts .row-text {
      padding: 6em 10vw; }
      .sec-content.-thoughts .row-text p {
        padding-right: 0; } }
  @media screen and (max-width: 700px) {
    .sec-content.-thoughts .row-img {
      position: sticky;
      top: 0; }
      .sec-content.-thoughts .row-img::before {
        display: none; }
    .sec-content.-thoughts .row-text {
      padding: 8em 8vw;
      background: rgba(245, 244, 238, 0.75); } }

.sec-content.-excursion {
  margin: 16vw 0 0 4vw;
  width: auto;
  max-width: none; }
  @media screen and (max-width: 1120px) {
    .sec-content.-excursion {
      margin: 14vw auto 12vw; } }

.blk-sticky {
  position: sticky; }
