@charset "UTF-8";
@font-face {
  font-family: "Optima Nova L";
  src: url("https://humblerich.itembox.design/item/lp202504/fonts/OptimaNovaLTProLight.otf") format("opentype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Optima Nova R";
  src: url("https://humblerich.itembox.design/item/lp202504/fonts/OptimaNovaLTProRegular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Optima nova M";
  src: url("https://humblerich.itembox.design/item/lp202504/fonts/OptimaNovaLTProMedium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Optima nova B";
  src: url("https://humblerich.itembox.design/item/lp202504/fonts/OptimaNovaLTProBold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}

body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
  margin: 0;
}

ul[role=list], ol[role=list] {
  list-style: none;
}

body {
  min-height: 100vh;
  line-height: 1.5;
}

h1, h2, h3, h4, button, input, label {
  line-height: 1.1;
}

h1, h2, h3, h4 {
  text-wrap: balance;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
  color: currentColor;
}

img, picture {
  max-width: 100%;
  display: block;
}

input, button, textarea, select {
  font: inherit;
}

textarea:not([rows]) {
  min-height: 10em;
}

:target {
  scroll-margin-block: 5ex;
}

*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:where([hidden]:not([hidden=until-found])) {
  display: none !important;
}

:where(html) {
  -webkit-text-size-adjust: none;
  color-scheme: dark light;
  tab-size: 2;
  scrollbar-gutter: stable;
  interpolate-size: allow-keywords;
  line-height: 1.5;
}

:where(html:has(dialog:modal[open])) {
  overflow: clip;
}

@media (prefers-reduced-motion: no-preference) {
  :where(html:focus-within) {
    scroll-behavior: smooth;
  }
}
:where(body) {
  line-height: inherit;
  font-family: system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
}

:where(button) {
  all: unset;
}

:where(input, button, textarea, select) {
  font: inherit;
  color: inherit;
  letter-spacing: inherit;
  word-spacing: inherit;
  font-feature-settings: inherit;
  font-variation-settings: inherit;
}

:where(textarea) {
  resize: vertical;
  resize: block;
}

:where(button, label, select, summary, [role=button], [role=option]) {
  cursor: pointer;
}

:where(:disabled, label:has(> :disabled, + disabled)) {
  cursor: not-allowed;
}

:where(a) {
  color: inherit;
  text-underline-offset: 0.2ex;
}

:where(ul, ol) {
  list-style: none;
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: block;
}

:where(img, picture, svg, video) {
  max-inline-size: 100%;
  block-size: auto;
}

:where(p, h1, h2, h3, h4, h5, h6) {
  overflow-wrap: break-word;
}

:where(h1, h2, h3) {
  line-height: calc(1em + 0.5rem);
  text-wrap: balance;
}

:where(hr) {
  border: none;
  border-block-start: 1px solid;
  color: inherit;
  block-size: 0;
  overflow: visible;
}

:where(dialog, [popover]) {
  border: none;
  background: none;
  color: inherit;
  inset: unset;
  max-width: unset;
  max-height: unset;
  overflow: unset;
}

:where(dialog:not([open], [popover]), [popover]:not(:popover-open)) {
  display: none !important;
}

:where(:focus-visible) {
  outline: 3px solid CanvasText;
  box-shadow: 0 0 0 5px Canvas;
  outline-offset: 1px;
}

:where(:focus-visible, :target) {
  scroll-margin-block: 8vh;
}

:where(.visually-hidden:not(:focus-within, :active)) {
  clip-path: inset(50%) !important;
  height: 1px !important;
  width: 1px !important;
  overflow: hidden !important;
  position: absolute !important;
  white-space: nowrap !important;
  border: 0 !important;
  user-select: none !important;
}

*, *::before, *::after {
  box-sizing: border-box;
}

* {
  margin: 0;
}

@media (prefers-reduced-motion: no-preference) {
  html {
    interpolate-size: allow-keywords;
  }
}
body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

input, button, textarea, select {
  font: inherit;
}

p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

p {
  text-wrap: pretty;
}

h1, h2, h3, h4, h5, h6 {
  text-wrap: balance;
}

#root, #__next {
  isolation: isolate;
}

* {
  margin: 0;
  padding: 0;
  line-height: calc(0.25rem + 1em + 0.25rem);
}

*, ::before, ::after {
  box-sizing: border-box;
}

*:where(:not(fieldset, progress, meter)) {
  border-width: 0;
  border-style: solid;
  background-origin: border-box;
  background-repeat: no-repeat;
}

html {
  block-size: 100%;
  -webkit-text-size-adjust: none;
}

@media (prefers-reduced-motion: no-preference) {
  html:focus-within {
    scroll-behavior: smooth;
  }
}
body {
  text-rendering: optimizeSpeed;
  min-block-size: 100%;
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: block;
}

:where(img, svg, video) {
  block-size: auto;
  max-inline-size: 100%;
}

:where(svg) {
  stroke: none;
  fill: currentColor;
}

:where(svg):where(:not([fill])) {
  stroke: currentColor;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

:where(svg):where(:not([width])) {
  inline-size: 5rem;
}

:where(input, button, textarea, select), :where(input[type=file])::-webkit-file-upload-button {
  color: inherit;
  font: inherit;
  font-size: inherit;
  letter-spacing: inherit;
  word-spacing: inherit;
}

:where(textarea) {
  resize: vertical;
}

@supports (resize: block) {
  :where(textarea) {
    resize: block;
  }
}
:where(p, h1, h2, h3, h4, h5, h6) {
  overflow-wrap: break-word;
}

h1 {
  font-size: 2em;
}

:where(ul, ol) {
  list-style-position: inside;
}

:where(ul, ol)[role=list] {
  list-style: none;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

:where(a[href], area, button, input, label[for], select, summary, textarea, [tabindex]:not([tabindex*="-"])) {
  cursor: pointer;
  touch-action: manipulation;
}

:where(input[type=file]) {
  cursor: auto;
}

:where(input[type=file])::-webkit-file-upload-button, :where(input[type=file])::file-selector-button {
  cursor: pointer;
}

@media (prefers-reduced-motion: no-preference) {
  :focus-visible {
    transition: outline-offset 145ms cubic-bezier(0.25, 0, 0.4, 1);
  }
  :where(:not(:active)):focus-visible {
    transition-duration: 0.25s;
  }
}
:where(:not(:active)):focus-visible {
  outline-offset: 5px;
}

:where(button, button[type], input[type=button], input[type=submit], input[type=reset]), :where(input[type=file])::-webkit-file-upload-button, :where(input[type=file])::file-selector-button {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  user-select: none;
  text-align: center;
}

:where(button, button[type], input[type=button], input[type=submit], input[type=reset])[disabled] {
  cursor: not-allowed;
}

* {
  margin: 0;
  padding: 0;
  line-height: calc(0.25rem + 1em + 0.25rem);
}

*, ::before, ::after {
  box-sizing: border-box;
}

*:where(:not(fieldset, progress, meter)) {
  border-width: 0;
  border-style: solid;
  background-origin: border-box;
  background-repeat: no-repeat;
}

html {
  block-size: 100%;
  -webkit-text-size-adjust: none;
}

@media (prefers-reduced-motion: no-preference) {
  html:focus-within {
    scroll-behavior: smooth;
  }
}
body {
  text-rendering: optimizeSpeed;
  min-block-size: 100%;
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: block;
}

:where(img, svg, video) {
  block-size: auto;
  max-inline-size: 100%;
}

:where(svg) {
  stroke: none;
  fill: currentColor;
}

:where(svg):where(:not([fill])) {
  stroke: currentColor;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

:where(svg):where(:not([width])) {
  inline-size: 5rem;
}

:where(input, button, textarea, select), :where(input[type=file])::-webkit-file-upload-button {
  color: inherit;
  font: inherit;
  font-size: inherit;
  letter-spacing: inherit;
  word-spacing: inherit;
}

:where(textarea) {
  resize: vertical;
}

@supports (resize: block) {
  :where(textarea) {
    resize: block;
  }
}
:where(p, h1, h2, h3, h4, h5, h6) {
  overflow-wrap: break-word;
}

h1 {
  font-size: 2em;
}

:where(ul, ol) {
  list-style-position: inside;
}

:where(ul, ol)[role=list] {
  list-style: none;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

:where(a[href], area, button, input, label[for], select, summary, textarea, [tabindex]:not([tabindex*="-"])) {
  cursor: pointer;
  touch-action: manipulation;
}

:where(input[type=file]) {
  cursor: auto;
}

:where(input[type=file])::-webkit-file-upload-button, :where(input[type=file])::file-selector-button {
  cursor: pointer;
}

@media (prefers-reduced-motion: no-preference) {
  :focus-visible {
    transition: outline-offset 145ms cubic-bezier(0.25, 0, 0.4, 1);
  }
  :where(:not(:active)):focus-visible {
    transition-duration: 0.25s;
  }
}
:where(:not(:active)):focus-visible {
  outline-offset: 5px;
}

:where(button, button[type], input[type=button], input[type=submit], input[type=reset]), :where(input[type=file])::-webkit-file-upload-button, :where(input[type=file])::file-selector-button {
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
  user-select: none;
  text-align: center;
}

:where(button, button[type], input[type=button], input[type=submit], input[type=reset])[disabled] {
  cursor: not-allowed;
}

*, *::before, *::after {
  box-sizing: border-box;
}

body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
  margin: 0;
}

ul[role=list], ol[role=list] {
  list-style: none;
}

html:focus-within {
  scroll-behavior: smooth;
}

body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

img, picture {
  max-width: 100%;
  display: block;
}

input, button, textarea, select {
  font: inherit;
}

@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
html {
  scroll-padding-top: 120px;
}

@media (max-width: 767px) {
  html {
    scroll-padding-top: 80px;
  }
}
*,
*::before,
*::after {
  box-sizing: border-box;
}

pre {
  white-space: pre-wrap;
  word-wrap: break-word;
  overflow: auto;
}

strong {
  font-weight: 700;
}

figure {
  text-align: center;
  margin: 0;
}

figure img {
  max-width: 100%;
}

main {
  display: block;
  width: 100%;
  position: relative;
}

section {
  display: block;
  width: 100%;
  margin-bottom: 100px;
}

html {
  font-size: 62.5%;
}
@media (max-width: 1024px) and (min-width: 768px) {
  html {
    font-size: 0.9vw;
  }
}

body {
  background-color: transparent !important;
  color: #36384C;
}
@media (min-width: 768px) {
  body {
    font-size: 1.6rem;
  }
}
body::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  inset: 0;
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.5); /* 任意の背景 */
  z-index: -1;
  pointer-events: none; /* 背景がクリックを邪魔しないように */
  background-image: url("https://humblerich.itembox.design/item/lp202504/images/lp/bg_section03-sp.png");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
@media (min-width: 768px) {
  body::before {
    background-image: url("https://humblerich.itembox.design/item/lp202504/images/lp/bg_section03.png");
  }
}

strong {
  font-family: "Optima Nova R", sans-serif;
  font-weight: normal;
}

/********************* 
      LP Layout
**********************/
.l-main {
  margin-top: 0;
  position: relative;
  container-type: inline-size;
}
.l-main a:hover,
.l-main a:visited {
  font-size: 1.4rem;
  font-family: "Optima Nova R", "a-otf-gothic-mb101-pr6n", sans-serif;
  font-weight: 300;
  line-height: 1.7;
  color: initial;
}
@container (min-width: 767px) {
  .l-main {
    margin-top: 0;
  }
}
.l-main a:hover,
.l-main a:visited {
  color: initial;
}

.l-section {
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  line-height: 1.5;
  margin-bottom: 0;
}

.l-section__inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: min(100%, 1440px);
  padding: 12vw 3rem;
}
@container (min-width: 767px) {
  .l-section__inner {
    padding: 6rem 3rem;
  }
}
@container (min-width: 14400px) {
  .l-section__inner {
    padding: 6rem 0;
  }
}

.fs-l-main {
  max-width: 100vw;
  margin: 0 auto !important;
  padding: 0;
}

.fs-l-page {
  margin: 0;
}

.fs-l-pageMain {
  max-width: 100vw;
}

#toTop.toTop--primary a {
  line-height: 1;
}

#ftr {
  margin-top: 0 !important;
}

.h_box {
  height: 0 !important;
}

body.home main {
  margin-top: 80px !important;
}

section.fs-l-pageMain {
  margin-bottom: 0;
}

.fs-c-heading {
  margin: 0 !important;
}

/********************* 
      section
**********************/
/* section00 */
.p-section00-wrapper {
  padding-top: 50px;
}
@container (min-width: 768px) {
  .p-section00-wrapper {
    padding-top: 0;
  }
}

#section00.l-section {
  background-image: url("https://humblerich.itembox.design/item/lp202504/images/lp/bg_section00.jpg");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  justify-content: center;
  align-items: flex-end;
  height: min(62.34vw, 720px);
}
#section00 .l-section__inner {
  align-items: flex-end;
  padding: 6rem 0 0;
}
#section00 .p-section00__contents {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: auto;
  width: 45%;
}
#section00 .p-section00__image {
  display: block;
  margin: 0 0 0 auto;
  height: auto;
  width: 100%;
  object-fit: contain;
}
@container (min-width: 768px) {
  #section00 .c-button__white {
    padding: 14px 16px 12px;
    font-size: 14px;
  }
}

/* section01 */
#section01 {
  background-color: #FFFFFF;
}
#section01 .l-section__inner {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
}
#section01 .c-text__section {
  text-align: center;
}
#section01 .p-section01__images-box {
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  margin-top: 6vw;
  height: auto;
  width: min(400px, 90%);
  aspect-ratio: 1/1;
}
@container (min-width: 768px) {
  #section01 .p-section01__images-box {
    margin-top: 6rem;
    width: 90%;
    aspect-ratio: auto;
  }
}
#section01 .p-section01__images-item {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
@container (min-width: 768px) {
  #section01 .p-section01__images-item {
    width: 50%;
    height: min(400px, 100%);
  }
}
#section01 .p-section01__images-item:nth-child(2) {
  display: none;
}
@container (min-width: 768px) {
  #section01 .p-section01__images-item:nth-child(2) {
    display: flex;
  }
}

#section02 .l-section__inner {
  padding-bottom: 0;
}
@container (min-width: 768px) {
  #section02 .l-section__inner {
    flex-direction: row;
  }
}
#section02 .c-title__section {
  margin: 0;
}
@container (max-width: 420px) {
  #section02 .c-title-sub__section {
    font-size: 1.8rem;
  }
}
#section02 .c-text__section {
  margin-top: 3.2rem;
}
@container (min-width: 768px) {
  #section02 .c-text__section {
    text-align: left;
  }
}
#section02 .p-section02__left {
  flex: 0 0 auto;
  width: 100%;
}
@container (min-width: 768px) {
  #section02 .p-section02__left {
    padding-bottom: 10%;
    width: clamp(48rem, 60%, 50rem);
  }
}
@container (min-width: 1024px) {
  #section02 .p-section02__left {
    padding-bottom: 10%;
    width: clamp(48rem, 60%, 50rem);
  }
}
#section02 .p-section02__image {
  margin-top: 3.2rem;
  width: min(40%, 32.5rem);
}
@container (min-width: 768px) {
  #section02 .p-section02__image {
    margin-top: 0;
    width: min(40%, 32.5rem);
  }
}

@container (min-width: 768px) {
  #section03 .l-section__inner {
    flex-direction: row-reverse;
  }
}
#section03 .c-title__section {
  padding-bottom: 2rem;
  border-bottom: 1px solid #AAAAAA;
}
#section03 .c-text__section {
  margin-top: 3.2rem;
}
@container (min-width: 768px) {
  #section03 .c-text__section {
    text-align: left;
  }
}
#section03 .p-section03__textbox {
  flex-direction: column;
  width: 100%;
}
@container (min-width: 768px) {
  #section03 .p-section03__textbox {
    flex-direction: row-reverse;
  }
}
#section03 .p-section03__images {
  margin-top: min(4.28vw, 6rem);
  width: 100%;
}
@container (min-width: 768px) {
  #section03 .p-section03__images {
    margin-right: min(4.28vw, 6rem);
    width: min(60%, 60rem);
  }
}

#section04 .l-section__inner {
  gap: min(4.28vw, 6rem);
}
@container (max-width: 767px) {
  #section04 .l-section__inner {
    padding-top: 0;
    padding-bottom: 0;
  }
}
@container (min-width: 768px) {
  #section04 .l-section__inner {
    flex-direction: row;
  }
}
#section04 .c-title__section {
  padding-bottom: 2rem;
  border-bottom: 1px solid #AAAAAA;
}
#section04 .c-text__section {
  margin-top: 3.2rem;
}
@container (min-width: 768px) {
  #section04 .c-text__section {
    text-align: left;
  }
}
#section04 .p-section04__textbox {
  flex-direction: column;
}
@container (min-width: 768px) {
  #section04 .p-section04__textbox {
    flex-direction: row-reverse;
  }
}
#section04 .p-section04__images {
  width: 100%;
}
@container (min-width: 768px) {
  #section04 .p-section04__images {
    width: min(55%, 60rem);
  }
}

#section05 .l-section__inner {
  gap: min(4.28vw, 6rem);
  padding: 12vw 3rem 16vw;
}
@container (min-width: 768px) {
  #section05 .l-section__inner {
    padding: 6rem 3rem 12rem;
    flex-direction: row-reverse;
  }
}
#section05 .c-title__section {
  padding-bottom: 2rem;
  border-bottom: 1px solid #AAAAAA;
}
#section05 .c-text__section {
  margin-top: 3.2rem;
}
@container (min-width: 768px) {
  #section05 .c-text__section {
    text-align: left;
  }
}
#section05 .p-section05__textbox {
  flex-direction: column;
}
@container (min-width: 768px) {
  #section05 .p-section05__textbox {
    flex-direction: row-reverse;
  }
}
#section05 .p-section05__images {
  width: calc(100% - min(8.56vw, 12rem));
}
@container (min-width: 768px) {
  #section05 .p-section05__images {
    position: relative;
    height: 60rem;
    width: min(60%, 60rem);
  }
}
@container (min-width: 768px) {
  #section05 .p-section05__images-item {
    position: absolute;
    width: 32rem;
    height: 32rem;
  }
}
@container (min-width: 768px) {
  #section05 .p-section05__images-item:nth-child(1) {
    bottom: 0;
    right: 0;
  }
}
#section05 .p-section05__images-item:nth-child(2) {
  display: none;
}
@container (min-width: 768px) {
  #section05 .p-section05__images-item:nth-child(2) {
    display: flex;
    top: 0;
    left: 0;
  }
}

#section06 .l-section__inner {
  gap: min(4.28vw, 6rem);
  flex-direction: column;
  margin-inline: auto;
  padding: min(4.28vw, 6rem);
  height: auto;
  width: calc(100% - min(8.56vw, 12rem));
}
@container (min-width: 768px) {
  #section06 .l-section__inner {
    margin-inline: auto;
    padding: min(2.14vw, 3rem);
    width: auto;
    flex-direction: row-reverse;
  }
}
@container (min-width: 1500px) {
  #section06 .l-section__inner {
    padding: min(2.14vw, 3rem);
    width: auto;
  }
}
#section06 .c-title__section {
  padding-bottom: 2rem;
  border-bottom: 1px solid #AAAAAA;
}
#section06 .c-text__section {
  margin-top: 3.2rem;
}
@container (min-width: 768px) {
  #section06 .c-text__section {
    text-align: left;
  }
}
#section06 .p-section06__textbox {
  flex-direction: column;
}
@container (min-width: 768px) {
  #section06 .p-section06__textbox {
    flex-direction: row-reverse;
  }
}
#section06 .p-section06__images {
  width: 100%;
}
@container (min-width: 768px) {
  #section06 .p-section06__images {
    flex: 0 0 auto;
    flex-grow: 1;
    height: 48rem;
    width: 48rem;
    object-fit: cover;
  }
}
#section06 .c-button__primary {
  margin: min(8.56vw, 12rem) auto;
}

#section07 {
  overflow: hidden;
}
#section07 .l-section__inner {
  position: relative;
  overflow: hidden;
  display: block;
  margin: calc(50vw - 50%);
}
#section07 .c-slideshow__item {
  scroll-snap-align: start;
  flex: 0 0 auto;
  max-width: 240px;
}
#section07__images-item {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

@container (min-width: 768px) {
  #section08 .l-section__inner {
    gap: min(4.28vw, 6rem);
    flex-direction: row-reverse;
  }
}
#section08 .p-section08__textbox {
  align-items: center;
  flex-direction: column;
}
@container (min-width: 768px) {
  #section08 .p-section08__textbox {
    justify-content: flex-start;
    border: 1px solid #fff;
    padding: 4rem;
  }
  #section08 .p-section08__textbox * {
    text-align: left;
  }
}
#section08 .p-section08__textbox .c-text__section-large {
  font-size: 2.4rem;
  text-transform: uppercase;
}
@container (min-width: 768px) {
  #section08 .p-section08__textbox .c-text__section-large {
    border-bottom: 1px solid #fff;
    margin-bottom: 4rem;
    padding-bottom: 2rem;
  }
}
#section08 .p-section08__textbox .c-text__section + .c-text__section {
  margin-top: 2rem;
}
#section08 .c-button__white {
  margin-top: 1.6rem;
  font-size: 1.2rem;
}

#section09 {
  background-color: #FFFFFF;
}
#section09 .p-section09__list {
  display: flex;
  flex-direction: column;
}
#section09 .p-section09__item {
  align-items: center;
  justify-content: center;
  text-align: center;
}
#section09 .p-section09__item:not(:first-child) {
  margin-top: 3.5vw;
}
#section09 .p-section09 .c-title__section {
  font-size: 1.6rem;
}
@container (min-width: 768px) {
  #section09 .p-section09 .c-title__section {
    font-size: 3rem;
  }
}

#section10 {
  background-color: #FFFFFF;
  margin-bottom: 0 !important;
  padding: 0 0 75px;
}
@container (min-width: 768px) {
  #section10 {
    padding: 0 0 150px;
  }
}
#section10 .l-section__inner {
  align-items: flex-start;
  flex-direction: column;
}
#section10 .c-label__section {
  text-align: left !important;
}
#section10 .c-title__section {
  font-family: "Optima nova M";
  font-weight: 500;
}
#section10 .p-section10__images {
  position: relative;
  margin: 4rem auto 0;
  aspect-ratio: 1/0.92;
  height: auto;
  width: min(100%, 1493px);
}
@container (min-width: 768px) {
  #section10 .p-section10__images {
    width: min(88%, 150rem);
  }
}
#section10 .p-section10__images .p-section10__images-item {
  position: absolute;
  display: block;
  object-fit: contain;
  height: auto;
}
#section10 .p-section10__images-01 {
  top: 0;
  left: 0;
  width: 32.7%;
  transition-delay: 0.2s;
}
#section10 .p-section10__images-02 {
  bottom: 0;
  right: 7.1%;
  width: 37.49%;
  transition-delay: 0.6s;
}
#section10 .p-section10__images-03 {
  top: 4.89%;
  right: 0;
  width: 39.34%;
  transition-delay: 1s;
}
#section10 .p-section10__images-04 {
  top: 22.715%;
  right: 32.185%;
  width: 35.63%;
  transition-delay: 1.4s;
}
#section10 .p-section10__images-05 {
  bottom: 9.44%;
  left: 11.52%;
  width: 28.6%;
  transition-delay: 1.8s;
}
#section10-2 .c-label__section {
  font-weight: 300;
}
#section10-2 .p-section10 .l-section__inner {
  padding-top: 0;
}
#section10-2 .p-section10__text {
  margin-top: 2rem;
}
#section10-3 .c-button__white-border {
  margin-top: 1.6rem;
  font-size: 1.2rem;
}

.c-button__primary {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 8px 12px 6px;
  font-size: min(11px, 1.822vw);
  background-color: #36384C;
  color: #FFFFFF;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  transition: background-color 0.3s ease;
  width: auto;
}
@container (min-width: 768px) {
  .c-button__primary {
    padding: 14px 16px 12px;
    font-size: 1.4rem;
  }
}
.c-button__primary:visited {
  color: #FFFFFF;
}

.c-button__white {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 8px 12px 6px;
  background-color: rgba(255, 255, 255, 0.42);
  width: auto;
  color: #FFFFFF;
  font-size: min(11px, 1.822vw);
  line-height: 1;
  text-align: center;
  text-decoration: none;
  transition: background-color 0.3s ease;
  font-weight: bold;
}
@container (min-width: 768px) {
  .c-button__white {
    padding: 14px 16px 12px;
    font-size: 1.6rem;
  }
}
.c-button__white:visited {
  color: #FFFFFF;
}
.c-button__white-border {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 14px 16px 12px;
  font-size: 1.4rem;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  transition: background-color 0.3s ease;
  width: auto;
  border: 1px solid #36384C;
  color: #36384C;
}
.c-button__white-border:visited {
  color: #36384C;
}

.c-bg__primary {
  background-color: #36384C;
  color: #FFFFFF;
}

.c-bg__gray {
  background-color: #F0F0F0;
}

.c-br {
  display: block;
}
@container (min-width: 768px) {
  .c-br {
    display: inline-block;
  }
}

.c-sp-only {
  display: block;
}
@container (min-width: 768px) {
  .c-sp-only {
    display: none;
  }
}

.c-pc-only {
  display: none;
}
@container (min-width: 768px) {
  .c-pc-only {
    display: block;
  }
}

.c-sc-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.c-title__section {
  margin-bottom: 1rem;
  font-size: 2.2rem;
  font-weight: 300;
  text-align: center;
  line-height: 1.7;
}
@container (min-width: 768px) {
  .c-title__section {
    margin-bottom: 4rem;
    text-align: left;
    font-size: 2.7rem;
  }
}

.c-title-sub__section {
  margin-bottom: 1rem;
  font-size: 2.2rem;
  text-align: center;
  font-family: "Optima nova M", sans-serif;
  font-weight: 500;
  line-height: 1.7;
}
@container (min-width: 768px) {
  .c-title-sub__section {
    margin-bottom: 4rem;
    text-align: left;
    font-size: 3.2rem;
  }
}

.c-text__section {
  line-height: 1.6;
  text-align: center;
}

.c-text__section-large {
  line-height: 2;
  text-align: center;
  font-size: 1.4rem;
  font-family: "Optima nova R", sans-serif;
  font-weight: 400;
}
@container (min-width: 768px) {
  .c-text__section-large {
    font-size: 2.4rem;
  }
}

.c-label__section {
  text-align: center;
  font-size: 1.4rem;
  font-family: "Optima Nova L";
  line-height: 1.45;
  color: #AAAAAA;
}
@container (min-width: 768px) {
  .c-label__section {
    text-align: left;
    font-size: 2.4rem;
  }
}

/* 横スクロール */
.c-slideshow {
  width: 100%;
  display: flex;
  position: relative;
  justify-content: flex-start;
  align-items: center;
}
.c-slideshow__wrap {
  position: absolute;
  height: var(--dynamic-height);
  padding-bottom: var(--dynamic-padding);
}
.c-slideshow__list {
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  width: calc(100% - 50px);
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.c-slideshow__list::-webkit-scrollbar {
  display: none;
}
@container (max-width: 767px) {
  .c-slideshow__list {
    overflow-x: auto;
    display: flex;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
}
.c-slideshow__item {
  flex-shrink: 0;
  width: 96.236vw;
}
.c-slideshow__item:not(:last-child) {
  margin-right: 3.764vw;
}
@container (max-width: 767px) {
  .c-slideshow__item {
    scroll-snap-align: start;
    flex-shrink: 0;
    margin-right: 4vw;
  }
}
.c-slideshow__item img,
.c-slideshow__item video {
  display: block;
  width: 100%;
  height: auto;
}

@keyframes horizontalScroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
/* modal */
.c-image__modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  min-height: 100vh;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  padding: 6rem;
}
.c-image__modal img {
  max-width: 90%;
  max-height: 90%;
  object-fit: contain;
}
.c-image__modal-close {
  position: absolute;
  top: 3rem;
  right: 3rem;
  font-size: 360%;
  color: #fff;
  background: none;
  border: none;
  cursor: pointer;
  line-height: 1;
}
.c-image__modal img,
.c-image__modal video, .c-image__modal-mv {
  width: 50%;
}

/* 矢印月スライドショー */
.c-slideshow-02.swiper,
.c-slideshow-02 {
  position: relative;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}
@container (min-width: 768px) {
  .c-slideshow-02.swiper,
  .c-slideshow-02 {
    margin: 0;
    width: min(50%, 618px);
  }
}
.c-slideshow-02.swiper__list,
.c-slideshow-02__list {
  display: flex;
  align-items: center;
  margin: 10vw 0 0 -15vw;
  aspect-ratio: 320/300;
}
@container (min-width: 768px) {
  .c-slideshow-02.swiper__list,
  .c-slideshow-02__list {
    margin: 0;
    gap: min(7%, 50px);
    aspect-ratio: 484/520;
  }
}
@container (min-width: 780px) {
  .c-slideshow-02.swiper__list,
  .c-slideshow-02__list {
    aspect-ratio: 500/450;
  }
}
@container (min-width: 1204px) {
  .c-slideshow-02.swiper__list,
  .c-slideshow-02__list {
    aspect-ratio: 484/496;
  }
}
.c-slideshow-02.swiper__item.swiper-slide, .c-slideshow-02.swiper__item,
.c-slideshow-02__item.swiper-slide,
.c-slideshow-02__item {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 0 0 35vw 0;
  width: 35vw !important;
  height: 100%;
  font-family: "Optima nova B";
  font-weight: 700;
  text-align: center;
  line-height: 1.4;
}
@container (min-width: 450px) {
  .c-slideshow-02.swiper__item.swiper-slide, .c-slideshow-02.swiper__item,
  .c-slideshow-02__item.swiper-slide,
  .c-slideshow-02__item {
    padding: 0 0 25vw 0;
  }
}
@container (min-width: 768px) {
  .c-slideshow-02.swiper__item.swiper-slide, .c-slideshow-02.swiper__item,
  .c-slideshow-02__item.swiper-slide,
  .c-slideshow-02__item {
    padding: 0 0 15% 0;
    width: 25% !important;
  }
}
@container (min-width: 1024px) {
  .c-slideshow-02.swiper__item.swiper-slide, .c-slideshow-02.swiper__item,
  .c-slideshow-02__item.swiper-slide,
  .c-slideshow-02__item {
    padding: 0 0 5% 0;
    width: 25% !important;
  }
}
.c-slideshow-02.swiper__item.swiper-slide .c-button__white, .c-slideshow-02.swiper__item .c-button__white,
.c-slideshow-02__item.swiper-slide .c-button__white,
.c-slideshow-02__item .c-button__white {
  margin-top: 0.8rem;
}
.c-slideshow-02.swiper__item.swiper-slide.prev, .c-slideshow-02.swiper__item.swiper-slide.next, .c-slideshow-02.swiper__item.prev, .c-slideshow-02.swiper__item.next,
.c-slideshow-02__item.swiper-slide.prev,
.c-slideshow-02__item.swiper-slide.next,
.c-slideshow-02__item.prev,
.c-slideshow-02__item.next {
  transition: all 0.5s ease;
  opacity: 1;
}
.c-slideshow-02.swiper__item.swiper-slide.prev img, .c-slideshow-02.swiper__item.swiper-slide.next img, .c-slideshow-02.swiper__item.prev img, .c-slideshow-02.swiper__item.next img,
.c-slideshow-02__item.swiper-slide.prev img,
.c-slideshow-02__item.swiper-slide.next img,
.c-slideshow-02__item.prev img,
.c-slideshow-02__item.next img {
  transform: scale(0.85);
  transition: all 0.5s ease;
}
.c-slideshow-02.swiper__item.swiper-slide.current, .c-slideshow-02.swiper__item.current,
.c-slideshow-02__item.swiper-slide.current,
.c-slideshow-02__item.current {
  transform: scale(1);
  transition: all 0.5s ease;
  width: 60vw !important;
  z-index: 2;
  padding: 0 20px;
}
.c-slideshow-02.swiper__item.swiper-slide.current img, .c-slideshow-02.swiper__item.current img,
.c-slideshow-02__item.swiper-slide.current img,
.c-slideshow-02__item.current img {
  transform: scale(1);
  transition: all 0.5s ease;
}
@container (min-width: 450px) {
  .c-slideshow-02.swiper__item.swiper-slide.current, .c-slideshow-02.swiper__item.current,
  .c-slideshow-02__item.swiper-slide.current,
  .c-slideshow-02__item.current {
    padding: 0 60px;
    width: 60vw !important;
  }
}
@container (min-width: 768px) {
  .c-slideshow-02.swiper__item.swiper-slide.current, .c-slideshow-02.swiper__item.current,
  .c-slideshow-02__item.swiper-slide.current,
  .c-slideshow-02__item.current {
    padding: 0 20px;
    width: 40% !important;
  }
}
@container (min-width: 1024px) {
  .c-slideshow-02.swiper__item.swiper-slide.current, .c-slideshow-02.swiper__item.current,
  .c-slideshow-02__item.swiper-slide.current,
  .c-slideshow-02__item.current {
    padding: 0;
  }
}
.c-slideshow-02.swiper__item.swiper-slide.current .c-slideshow-02__product-name,
.c-slideshow-02.swiper__item.swiper-slide.current p,
.c-slideshow-02.swiper__item.swiper-slide.current .c-button__primary, .c-slideshow-02.swiper__item.current .c-slideshow-02__product-name,
.c-slideshow-02.swiper__item.current p,
.c-slideshow-02.swiper__item.current .c-button__primary,
.c-slideshow-02__item.swiper-slide.current .c-slideshow-02__product-name,
.c-slideshow-02__item.swiper-slide.current p,
.c-slideshow-02__item.swiper-slide.current .c-button__primary,
.c-slideshow-02__item.current .c-slideshow-02__product-name,
.c-slideshow-02__item.current p,
.c-slideshow-02__item.current .c-button__primary {
  overflow: visible;
  height: auto;
  display: block;
}
.c-slideshow-02.swiper__item.swiper-slide:not(.current) .c-slideshow-02__product-name,
.c-slideshow-02.swiper__item.swiper-slide:not(.current) p,
.c-slideshow-02.swiper__item.swiper-slide:not(.current) .c-button__primary,
.c-slideshow-02.swiper__item.swiper-slide:not(.current) .c-button__white, .c-slideshow-02.swiper__item:not(.current) .c-slideshow-02__product-name,
.c-slideshow-02.swiper__item:not(.current) p,
.c-slideshow-02.swiper__item:not(.current) .c-button__primary,
.c-slideshow-02.swiper__item:not(.current) .c-button__white,
.c-slideshow-02__item.swiper-slide:not(.current) .c-slideshow-02__product-name,
.c-slideshow-02__item.swiper-slide:not(.current) p,
.c-slideshow-02__item.swiper-slide:not(.current) .c-button__primary,
.c-slideshow-02__item.swiper-slide:not(.current) .c-button__white,
.c-slideshow-02__item:not(.current) .c-slideshow-02__product-name,
.c-slideshow-02__item:not(.current) p,
.c-slideshow-02__item:not(.current) .c-button__primary,
.c-slideshow-02__item:not(.current) .c-button__white {
  overflow: hidden;
  height: 0;
  display: none;
  transition: all 0.5s ease;
}
.c-slideshow-02.swiper__item.swiper-slide.animate-left, .c-slideshow-02.swiper__item.animate-left,
.c-slideshow-02__item.swiper-slide.animate-left,
.c-slideshow-02__item.animate-left {
  animation: slide-left 0.2s ease;
}
.c-slideshow-02.swiper__item.swiper-slide.animate-right, .c-slideshow-02.swiper__item.animate-right,
.c-slideshow-02__item.swiper-slide.animate-right,
.c-slideshow-02__item.animate-right {
  animation: slide-right 0.2s ease;
}
.c-slideshow-02.swiper__product-name,
.c-slideshow-02__product-name {
  margin: 3rem 0 2.4rem;
  font-family: "Optima nova M";
  font-weight: 500;
  font-size: 2rem;
  text-align: center;
}
@container (min-width: 768px) {
  .c-slideshow-02.swiper__product-name,
  .c-slideshow-02__product-name {
    font-size: 3rem;
  }
}
.c-slideshow-02.swiper__arrow,
.c-slideshow-02__arrow {
  position: absolute;
  top: 38%;
  transform: translateY(-50%);
  width: min(2.5rem, 10vmin);
  height: min(2.5rem, 10vmin);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  z-index: 3;
}
@container (min-width: 450px) {
  .c-slideshow-02.swiper__arrow,
  .c-slideshow-02__arrow {
    top: 36%;
  }
}
@container (min-width: 768px) and (max-width: 1200px) {
  .c-slideshow-02.swiper__arrow,
  .c-slideshow-02__arrow {
    top: 34%;
  }
}
.c-slideshow-02.swiper__arrow::before,
.c-slideshow-02__arrow::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  border-bottom: solid #AAAAAA;
  border-right: solid #AAAAAA;
  border-width: 0 3px 3px 0;
}
.c-slideshow-02.swiper__arrow--prev,
.c-slideshow-02__arrow--prev {
  left: 20vw;
}
@container (min-width: 450px) {
  .c-slideshow-02.swiper__arrow--prev,
  .c-slideshow-02__arrow--prev {
    left: 23%;
  }
}
@container (min-width: 768px) {
  .c-slideshow-02.swiper__arrow--prev,
  .c-slideshow-02__arrow--prev {
    left: 25%;
  }
}
.c-slideshow-02.swiper__arrow--prev::before,
.c-slideshow-02__arrow--prev::before {
  transform: rotate(135deg);
}
.c-slideshow-02.swiper__arrow--next,
.c-slideshow-02__arrow--next {
  right: 19vw;
}
@container (min-width: 768px) {
  .c-slideshow-02.swiper__arrow--next,
  .c-slideshow-02__arrow--next {
    right: 23%;
  }
}
@container (min-width: 768px) {
  .c-slideshow-02.swiper__arrow--next,
  .c-slideshow-02__arrow--next {
    right: 25%;
  }
}
.c-slideshow-02.swiper__arrow--next::before,
.c-slideshow-02__arrow--next::before {
  transform: rotate(-45deg);
}
.c-slideshow-02.swiper__images,
.c-slideshow-02__images {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

.swiper-slide {
  transition: transform 0.5s ease;
}

.swiper-slide.current {
  transform: scale(1.2); /* 大きくしたい値に */
}

.swiper-slide:not(.current) {
  transform: scale(0.85);
}

.js-fade,
.js-fade-right {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

@container (min-width: 768px) {
  .js-fade-delay {
    transition-delay: 0.8s;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.6s ease, transform 0.6s ease;
  }
}

.fade-in {
  opacity: 1;
  transform: translateY(0);
}

.js-fade-right {
  transform: translateX(30px);
}

.fade-in-right {
  opacity: 1;
  transform: translateX(0);
}

/*# sourceMappingURL=style.css.map */
