@charset "UTF-8";
/* ===============================================
00_foundation
=============================================== */
/*
  Reset
----------------------------------------------- */
/*
  # Global
---------------------------------------------- */
*,
::before,
::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/*
  # Document & Sections
---------------------------------------------- */
:where(html) {
  block-size: 100%;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: none;
}

:where(body) {
  min-block-size: 100%;
  text-rendering: optimizeLegibility;
  line-height: 1.8;
  font-family: system-ui, sans-serif;
  font-feature-settings: "palt";
  -webkit-font-smoothing: antialiased;
}

/*
  # Grouping content
---------------------------------------------- */
:where(p, h1, h2, h3, h4, h5, h6) {
  overflow-wrap: break-word;
  font-size: 100%;
  font: inherit;
}

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

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

/*
  # Text-level semantics
---------------------------------------------- */
:where(a:not([class])) {
  -webkit-text-decoration-skip: ink;
  text-decoration-skip-ink: auto;
}

/*
  # Embedded content
---------------------------------------------- */
:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: block;
}

:where(img, picture, svg) {
  max-inline-size: 100%; /* max-with:100%;と同じ */
  block-size: auto;
}

:where(svg:not([fill])) {
  fill: currentColor;
}

/*
  # Tabular data
---------------------------------------------- */
:where(table) {
  border-collapse: collapse;
}

/*
  # Forms
---------------------------------------------- */
:where(input, button, textarea, select, optgroup) {
  font: inherit;
  color: inherit;
}

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

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

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

:where(:disabled) {
  cursor: not-allowed;
}

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

:where(button) {
  border-style: solid;
}

/*
  # Interactive & Misc
---------------------------------------------- */
:where(template, [hidden]:not([hidden=until-found])) {
  display: none;
}

/*
  # Accessibility
---------------------------------------------- */
:where([disabled], [aria-disabled=true]) {
  cursor: not-allowed;
}

:where([aria-busy=true]) {
  cursor: progress;
}

:where([aria-controls]) {
  cursor: pointer;
}

:where([aria-hidden=false][hidden]) {
  display: initial;
}

:where([aria-hidden=false][hidden]):not(:focus) {
  position: absolute;
  clip: rect(0, 0, 0, 0);
}

:where(:focus:not(:focus-visible), ::before:focus:not(:focus-visible), ::after:focus:not(:focus-visible)) {
  outline: none;
}

/**
 * Prettier ignore
 */
@media (prefers-reduced-motion: reduce) {
  *,
  *:before,
  *:after,
  ::backdrop {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
    view-transition-name: none !important;
  }
}
/*
  # Other
---------------------------------------------- */
table {
  border-collapse: collapse;
  border-spacing: 0;
}
table th, table td {
  font-weight: 400;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  width: 100%;
  max-width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  vertical-align: bottom;
}

/* ===============================================
font-size
=============================================== */
/* ===============================================
hover
=============================================== */
/*
  Base
----------------------------------------------- */
@font-face {
  font-family: "Hannari";
  font-style: normal;
  font-weight: 500;
  src: url("../../assets/font/subsets/HannariMincho-Regular.woff2") format("woff2"), url("../../assets/font/subsets/HannariMincho-Regular.woff") format("woff");
}
/* Custom Property */
:root {
  --mainColor: #191919;
  --whiteColor: #fff;
  --beige-600: #b3886a;
  --beige-100: #e0cfc1;
  --lightGrayColor: #ccc;
  --grayColor01: #666;
  --grayColor02: #333;
  --grayColor03: #999;
  --bgColor: #232323;
  --lineColor: #e6e6e6;
  --content-width: 540px;
  --sansFont: "Zen Kaku Gothic New", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo",
    sans-serif;
  --serifFont: "Hannari", serif;
}

/********** media query **********/
@media screen and (min-width: 768px) {
  :root {
    --content-width: 1000px;
  }
}
/* Default Style */
body {
  position: relative;
  font-family: var(--sansFont);
  font-weight: 500;
  color: var(--mainColor);
  background-image: url(../../assets/images/common/kotoriko_bg@2x.png);
  background-attachment: fixed;
  background-size: 1440px;
  background-color: var(--beige-600);
}

.br,
.spbr,
.tabbr {
  display: block;
}

.spNone {
  display: none;
}

.grecaptcha-badge {
  visibility: hidden;
}

/********** media query **********/
@media screen and (min-width: 768px) {
  .spbr {
    display: inline;
  }
  .pcbr {
    display: block;
  }
  .spNone {
    display: block;
  }
  .pcNone {
    display: none;
  }
}
@media screen and (min-width: 1150px) {
  .tabbr {
    display: inline;
  }
}
/*
  Accesibility
----------------------------------------------- */
.visuallyHidden:not(:focus) {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  margin: -1px;
}

@media (min-width: 751px) {
  a[href*="tel:"],
  a[href*="Tel:"] {
    pointer-events: none;
    cursor: default;
  }
}
/* ===============================================
L-Container
=============================================== */
.l-S01,
.l-S02,
.l-S03 {
  position: relative;
}

.l-S01 {
  width: 100%;
}

.l-S02 {
  width: 85%;
  margin: 0 auto;
}

@media screen and (min-width: 768px) {
  .l-S02 {
    max-width: var(--content-width);
  }
}
.l-L01,
.l-L02,
.l-L03,
.l-L04,
.l-L05,
.l-L06,
.l-L07,
.l-L08,
.l-L09,
.l-L10 {
  position: relative;
  width: 100%;
}

.l-L01 {
  grid-area: l-L01;
}

.l-L02 {
  grid-area: l-L02;
}

.l-L03 {
  grid-area: l-L03;
}

.l-L04 {
  grid-area: l-L04;
}

.l-L05 {
  grid-area: l-L05;
}

.l-L06 {
  grid-area: l-L06;
}

.l-L07 {
  grid-area: l-L07;
}

.l-L08 {
  grid-area: l-L08;
}

.l-L09 {
  grid-area: l-L09;
}

.l-L10 {
  grid-area: l-L10;
}

/* ===============================================
L-Header
=============================================== */
.l-header {
  display: none;
}

/********** media query **********/
@media screen and (min-width: 1024px) {
  .l-header {
    display: block;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    height: 60px;
    z-index: 9999;
    background-color: var(--whiteColor);
  }
  .l-header .l-S02, .l-header .l-L01 {
    height: 100%;
  }
  .l-header .l-S02 {
    width: 100%;
    max-width: 92%;
  }
  .l-header .l-L01 {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0 88px;
    justify-content: space-between;
    padding-left: 20px;
  }
  .l-header .b-header__sns {
    display: flex;
    gap: 0 50px;
  }
  .l-header .b-header__sns .access {
    width: 15px;
  }
  .l-header .b-header__sns .instagram {
    width: 20px;
  }
}
/* ===============================================
L-Main
=============================================== */
:root {
  --vh-gap: calc(1080px - 100vh);
}

.l-container {
  overflow: hidden;
  padding-bottom: 60px;
}

.b-sectionTitle {
  display: grid;
  justify-items: center;
  row-gap: 6px;
}
.b-sectionTitle .en {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0 12px;
}
.b-sectionTitle .en::before, .b-sectionTitle .en::after {
  content: "";
  width: 26px;
  height: 0.5px;
  background-color: var(--mainColor);
}

.text-space {
  padding: 0 8px;
}

.s-contents .l-L01 {
  position: relative;
  max-width: 500px;
  margin: 0 auto;
}
.s-contents .l-L02 {
  position: relative;
  display: grid;
  justify-items: center;
  row-gap: 38px;
  padding: 0 7.5% 0 10%;
  z-index: 1;
}
.s-contents .b-content__text .margin-bottom {
  display: block;
  margin-bottom: 1.6em;
}
.s-contents .b-content__text .margin-bottom:last-child {
  margin-bottom: 0;
}
.s-contents .b-contentImage {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}
.s-contents .b-scroll {
  position: absolute;
  bottom: 572px;
  left: -48px;
  display: flex;
  align-items: center;
  -moz-column-gap: 16px;
       column-gap: 16px;
  transform: rotate(90deg);
}
.s-contents .b-scroll::after {
  content: "";
  position: relative;
  background-image: url(../../assets/images/common/kotoriko_arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
  width: 57px;
  height: 10px;
}
.s-contents .b-scroll.spNone {
  display: none;
}

/********** media query **********/
@media screen and (min-width: 1024px) {
  .l-container {
    height: 100vh;
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior: none;
    padding-bottom: 0;
  }
  .s-contents {
    flex: 0 0 clamp(1100px, 180vh, 1440px);
  }
  .s-contents .l-L01 {
    max-width: 100%;
    height: calc(100vh - 60px);
    margin: 0;
    display: grid;
    align-content: center;
    align-items: center;
    justify-content: center;
  }
  .s-contents .l-L02 {
    top: -6.8vh;
    padding: 0;
  }
  .s-contents .b-scroll {
    position: absolute;
    top: 47%;
    bottom: auto;
    left: auto;
    right: 3%;
    transform: rotate(0);
  }
  .s-contents .b-scroll.spNone {
    display: flex;
  }
}
/*
  hero
----------------------------------------------- */
.s-hero .l-L01 {
  padding: 250px 0 585px;
}
.s-hero .l-L02 {
  row-gap: 24px;
}
.s-hero .b-hero__logo {
  max-width: 200px;
}
.s-hero .b-content__text {
  line-height: 2;
}
.s-hero .b-heroImage__item {
  position: absolute;
}
.s-hero .b-heroImage__item:nth-child(1) {
  width: 440px;
  top: 0;
  left: -32px;
  right: -32px;
  margin: 0 auto;
}
.s-hero .b-heroImage__item:nth-child(2) {
  width: 72px;
  top: 312px;
  right: 2px;
  right: clamp(-0.625rem, -4.9886363636rem + 21.8181818182vw, 0.125rem);
}
.s-hero .b-heroImage__item:nth-child(3) {
  width: 380px;
  bottom: 311px;
  left: -94px;
  left: clamp(-6.875rem, -12.6931818182rem + 29.0909090909vw, -5.875rem);
  z-index: 1;
}
.s-hero .b-heroImage__item:nth-child(4) {
  display: none;
}
.s-hero .b-heroImage__item:nth-child(5) {
  width: 218px;
  bottom: 223px;
  left: -14px;
  right: 0;
  margin: 0 auto;
}
.s-hero .b-heroImage__item:nth-child(6) {
  width: 150px;
  top: 292px;
  left: -50px;
  left: clamp(-3.75rem, -7.3863636364rem + 18.1818181818vw, -3.125rem);
}
.s-hero .b-heroImage__item:nth-child(7) {
  width: 165px;
  top: 170px;
  left: 8px;
}
.s-hero .b-heroImage__item:nth-child(8) {
  display: none;
}
.s-hero .b-heroImage__item:nth-child(9) {
  width: 140px;
  bottom: 456px;
  left: -16px;
  right: 0;
  margin: 0 auto;
  z-index: 1;
}
.s-hero .b-heroImage__item:nth-child(10) {
  width: 176px;
  top: 80px;
  right: -21px;
  right: clamp(-2.5rem, -9.4090909091rem + 34.5454545455vw, -1.3125rem);
}
.s-hero .b-heroImage__item:nth-child(11) {
  width: 375px;
  bottom: 0;
  right: 0;
}
.s-hero .b-heroImage__item:nth-child(12) {
  width: 300px;
  bottom: 338px;
  right: -77px;
  right: clamp(-6.875rem, -18.875rem + 60vw, -4.8125rem);
  z-index: 0;
}

/********** media query **********/
@media screen and (min-width: 1024px) {
  .s-hero {
    left: clamp(-20.625rem, -44.196rem + 49.11vw, 0rem);
  }
  .s-hero .l-L01 {
    padding: 0;
  }
  .s-hero .l-L02 {
    top: -40px;
    left: -12px;
  }
  .s-hero .b-hero__logo {
    width: clamp(200px, 171.43px + 8.57vh, 264px);
    max-width: 264px;
  }
  .s-hero .b-content__text {
    padding-left: 54px;
  }
  .s-hero .b-heroImage__item {
    height: auto;
  }
  .s-hero .b-heroImage__item:nth-child(1) {
    width: min(40vh, 433px);
    left: 0;
    right: auto;
    margin: 0;
  }
  .s-hero .b-heroImage__item:nth-child(2) {
    width: min(14vh, 148px);
    top: 32vh;
    left: 1.3%;
    right: auto;
  }
  .s-hero .b-heroImage__item:nth-child(3) {
    width: min(52vh, 560px);
    top: 28.2vh;
    bottom: auto;
    left: 5%;
  }
  .s-hero .b-heroImage__item:nth-child(4) {
    display: inline-block;
    width: min(20.8vh, 222px);
    bottom: calc(206px - var(--vh-gap) * 70 / 380);
    left: 4.5%;
  }
  .s-hero .b-heroImage__item:nth-child(5) {
    width: min(41vh, 440px);
    bottom: calc(38px - var(--vh-gap) * 70 / 380);
    left: 10.8%;
    right: auto;
    margin: 0;
  }
  .s-hero .b-heroImage__item:nth-child(6) {
    width: min(24.5vh, 262px);
    top: 8.2vh;
    left: 29%;
  }
  .s-hero .b-heroImage__item:nth-child(7) {
    width: min(24vh, 258px);
    top: 9vh;
    left: auto;
    right: 26%;
  }
  .s-hero .b-heroImage__item:nth-child(8) {
    display: inline-block;
    width: min(11.3vh, 122px);
    top: 28.8vh;
    right: 27.2%;
  }
  .s-hero .b-heroImage__item:nth-child(9) {
    width: min(30vh, 334px);
    bottom: calc(88px - var(--vh-gap) * 120 / 380);
    left: auto;
    right: 32.5%;
    margin: 0;
  }
  .s-hero .b-heroImage__item:nth-child(10) {
    width: min(34.5vh, 373px);
    top: auto;
    bottom: calc(30px - var(--vh-gap) * 60 / 380);
    right: 5%;
  }
  .s-hero .b-heroImage__item:nth-child(11) {
    width: min(45.5vh, 490px);
    top: 7vh;
    bottom: auto;
    right: -10.5%;
  }
  .s-hero .b-heroImage__item:nth-child(12) {
    width: min(35vh, 378px);
    bottom: calc(158px - var(--vh-gap) * 100 / 380);
    right: -11.5%;
  }
}
/*
  About
----------------------------------------------- */
.s-about .l-L01 {
  padding: 80px 0 656px;
}
.s-about .b-about__address {
  display: grid;
  justify-items: center;
  row-gap: 4px;
}
.s-about .b-aboutImage__item {
  position: absolute;
}
.s-about .b-aboutImage__item:nth-child(1) {
  width: 120px;
  top: 286px;
  right: -47px;
  right: clamp(-3.5rem, -6.7727272727rem + 16.3636363636vw, -2.9375rem);
}
.s-about .b-aboutImage__item:nth-child(2) {
  width: 122px;
  top: 54px;
  left: -20px;
  left: clamp(-2.5rem, -9.7727272727rem + 36.3636363636vw, -1.25rem);
}
.s-about .b-aboutImage__item:nth-child(3) {
  width: 210px;
  bottom: 468px;
  right: -23px;
  right: clamp(-2.25rem, -6.9772727273rem + 23.6363636364vw, -1.4375rem);
}
.s-about .b-aboutImage__item:nth-child(4) {
  width: 192px;
  top: 34px;
  right: -52px;
  right: clamp(-4.5rem, -11.7727272727rem + 36.3636363636vw, -3.25rem);
}
.s-about .b-aboutImage__item:nth-child(5) {
  display: none;
}
.s-about .b-aboutImage__item:nth-child(6) {
  width: 204px;
  bottom: 176px;
  right: 0;
  right: clamp(-1rem, -6.8181818182rem + 29.0909090909vw, 0rem);
}
.s-about .b-aboutImage__item:nth-child(7) {
  display: none;
}
.s-about .b-aboutImage__item:nth-child(8) {
  width: 314px;
  bottom: 0;
  left: 16px;
  right: 0;
  margin: 0 auto;
}
.s-about .b-aboutImage__item:nth-child(9) {
  width: 96px;
  top: 414px;
  left: -34px;
  left: clamp(-3.5rem, -11.5rem + 40vw, -2.125rem);
  transform: rotate(-2deg);
}
.s-about .b-aboutImage__item:nth-child(10) {
  display: none;
}

/********** media query **********/
@media screen and (min-width: 768px) {
  .s-about .b-aboutImage__item:nth-child(1) {
    right: -24.5%;
  }
  .s-about .b-aboutImage__item:nth-child(9) {
    left: -19%;
  }
}
@media screen and (min-width: 1024px) {
  .s-about .l-L01 {
    padding: 0;
  }
  .s-about .b-aboutImage__item:nth-child(1) {
    width: min(14.3vh, 154px);
    top: 9.7vh;
    left: 14.3%;
    right: auto;
  }
  .s-about .b-aboutImage__item:nth-child(2) {
    width: min(17.2vh, 185px);
    top: 37.8vh;
    left: 9.6%;
  }
  .s-about .b-aboutImage__item:nth-child(3) {
    width: min(30.3vh, 327px);
    bottom: calc(172px - var(--vh-gap) * 100 / 380);
    left: 6.8%;
    right: auto;
  }
  .s-about .b-aboutImage__item:nth-child(4) {
    width: min(34.9vh, 376px);
    top: auto;
    bottom: calc(38px - var(--vh-gap) * 50 / 380);
    left: 18.6%;
    right: auto;
  }
  .s-about .b-aboutImage__item:nth-child(5) {
    display: inline-block;
    width: min(28vh, 302px);
    bottom: calc(0px - var(--vh-gap) * 40 / 380);
    left: 0;
    right: 20px;
    margin: 0 auto;
  }
  .s-about .b-aboutImage__item:nth-child(6) {
    width: min(25vh, 270px);
    top: 5.2vh;
    bottom: auto;
    right: 0;
  }
  .s-about .b-aboutImage__item:nth-child(7) {
    display: inline-block;
    width: min(23.4vh, 252px);
    top: 52vh;
    right: 4%;
  }
  .s-about .b-aboutImage__item:nth-child(8) {
    width: min(36.6vh, 395px);
    bottom: calc(84px - var(--vh-gap) * 80 / 380);
    left: auto;
    right: 8.2%;
    margin: 0;
  }
  .s-about .b-aboutImage__item:nth-child(9) {
    display: none;
  }
  .s-about .b-aboutImage__item:nth-child(10) {
    display: inline-block;
    width: min(12.6vh, 136px);
    bottom: calc(58px - var(--vh-gap) * 80 / 380);
    left: 5.7%;
  }
}
/*
  Sakan
----------------------------------------------- */
.s-sakan .l-L01 {
  padding: 60px 0 290px;
}
.s-sakan .b-mainButton {
  margin-top: 40px;
}
.s-sakan .b-sakanImage__item {
  position: absolute;
}
.s-sakan .b-sakanImage__item:nth-child(1) {
  width: 173px;
  top: -618px;
  left: 33px;
  left: clamp(0.3125rem, -9.8693181818rem + 50.9090909091vw, 2.0625rem);
}
.s-sakan .b-sakanImage__item:nth-child(2) {
  width: 305px;
  bottom: 0;
  left: 0;
  right: 20px;
  margin: 0 auto;
}
.s-sakan .b-sakanImage__item:nth-child(3) {
  display: none;
}
.s-sakan .b-sakanImage__item:nth-child(4) {
  width: 74px;
  top: 122px;
  left: -23px;
  left: clamp(-1.75rem, -3.5681818182rem + 9.0909090909vw, -1.4375rem);
}
.s-sakan .b-sakanImage__item:nth-child(5) {
  width: 71px;
  top: 120px;
  right: -15px;
  right: clamp(-1.125rem, -2.2159090909rem + 5.4545454545vw, -0.9375rem);
}
.s-sakan .b-sakanImage__item:nth-child(6) {
  display: none;
}
.s-sakan .b-sakanImage__item:nth-child(7) {
  display: none;
}
.s-sakan .b-sakanImage__item:nth-child(8) {
  width: 175px;
  top: -362px;
  left: -15px;
  left: clamp(-2.1875rem, -9.4602272727rem + 36.3636363636vw, -0.9375rem);
}
.s-sakan .b-sakanImage__item:nth-child(9) {
  display: none;
}
.s-sakan .b-sakanImage__item:nth-child(10) {
  display: none;
}
.s-sakan .b-sakanImage__item:nth-child(11) {
  width: 120px;
  bottom: 90px;
  right: -60px;
}
.s-sakan .b-sakanImage__item:nth-child(12) {
  display: none;
}

/********** media query **********/
@media screen and (min-width: 1024px) {
  .s-sakan .l-L01 {
    padding: 0;
  }
  .s-sakan .b-sakanImage__item:nth-child(1) {
    width: min(26.5vh, 286px);
    top: 4.3vh;
    left: 6.5%;
  }
  .s-sakan .b-sakanImage__item:nth-child(2) {
    width: min(45vh, 485px);
    top: 43vh;
    bottom: auto;
    left: 1.5%;
    right: 0;
    margin: 0;
  }
  .s-sakan .b-sakanImage__item:nth-child(3) {
    display: inline-block;
    width: min(34vh, 366px);
    bottom: calc(120px - var(--vh-gap) * 80 / 380);
    left: 6.4%;
  }
  .s-sakan .b-sakanImage__item:nth-child(4) {
    width: min(7vh, 76px);
    top: 17.8vh;
    left: 30.3%;
  }
  .s-sakan .b-sakanImage__item:nth-child(5) {
    width: min(6.6vh, 71px);
    top: 18vh;
    right: 33.9%;
  }
  .s-sakan .b-sakanImage__item:nth-child(6) {
    display: inline-block;
    width: min(26.8vh, 289px);
    bottom: calc(78px - var(--vh-gap) * 126 / 380);
    left: 0;
    right: 0;
    margin: 0 auto;
  }
  .s-sakan .b-sakanImage__item:nth-child(7) {
    display: inline-block;
    width: min(22.5vh, 242px);
    top: 5.8vh;
    right: 14.5%;
  }
  .s-sakan .b-sakanImage__item:nth-child(8) {
    width: min(27.4vh, 295px);
    top: auto;
    bottom: calc(338px - var(--vh-gap) * 120 / 380);
    left: auto;
    right: 8.6%;
  }
  .s-sakan .b-sakanImage__item:nth-child(9) {
    display: inline-block;
    width: min(16.6vh, 178px);
    bottom: 0;
    right: 11.1%;
  }
  .s-sakan .b-sakanImage__item:nth-child(10) {
    display: inline-block;
    width: min(49.7vh, 536px);
    top: 2.3vh;
    right: -16.5%;
  }
  .s-sakan .b-sakanImage__item:nth-child(11) {
    width: min(39.5vh, 420px);
    bottom: 0;
    right: -15.3%;
  }
  .s-sakan .b-sakanImage__item:nth-child(12) {
    display: inline-block;
    width: min(11.5vh, 124px);
    bottom: calc(242px - var(--vh-gap) * 120 / 380);
    right: 28.2%;
  }
}
/*
  Engei
----------------------------------------------- */
.s-engei .l-L01 {
  padding: 80px 0 500px;
}
.s-engei .b-engeiImage__item {
  position: absolute;
}
.s-engei .b-engeiImage__item:nth-child(1) {
  display: none;
}
.s-engei .b-engeiImage__item:nth-child(2) {
  width: 105px;
  top: -4px;
  left: 23px;
  left: clamp(0rem, -8.3636363636rem + 41.8181818182vw, 1.4375rem);
}
.s-engei .b-engeiImage__item:nth-child(3) {
  width: 221px;
  bottom: 48px;
  left: 16px;
  right: 0;
  margin: 0 auto;
}
.s-engei .b-engeiImage__item:nth-child(4) {
  width: 120px;
  top: 218px;
  left: -33px;
  left: clamp(-3.5rem, -7.5rem + 20vw, -2.8125rem);
}
.s-engei .b-engeiImage__item:nth-child(5) {
  display: none;
}
.s-engei .b-engeiImage__item:nth-child(6) {
  display: none;
}
.s-engei .b-engeiImage__item:nth-child(7) {
  width: 132px;
  top: -278px;
  left: -71px;
}
.s-engei .b-engeiImage__item:nth-child(8) {
  width: 266px;
  top: -22px;
  right: -19px;
  right: clamp(-1.875rem, -5.875rem + 20vw, -1.1875rem);
}
.s-engei .b-engeiImage__item:nth-child(9) {
  width: 105px;
  bottom: 220px;
  left: 8px;
  left: clamp(-0.5rem, -6.3181818182rem + 29.0909090909vw, 0.5rem);
}
.s-engei .b-engeiImage__item:nth-child(10) {
  display: none;
}
.s-engei .b-engeiImage__item:nth-child(11) {
  display: none;
}
.s-engei .b-engeiImage__item:nth-child(12) {
  width: 232px;
  bottom: 348px;
  right: 5px;
  right: clamp(-0.625rem, -6.0795454545rem + 27.2727272727vw, 0.3125rem);
}
.s-engei .b-engeiImage__item:nth-child(13) {
  display: none;
}
.s-engei .b-engeiImage__item:nth-child(14) {
  display: none;
}

/********** media query **********/
@media screen and (min-width: 1024px) {
  .s-engei .l-L01 {
    padding: 0;
  }
  .s-engei .b-engeiImage__item:nth-child(1) {
    display: inline-block;
    width: min(12vh, 130px);
    top: 6.9vh;
    left: 11.5%;
  }
  .s-engei .b-engeiImage__item:nth-child(2) {
    width: min(16.7vh, 180px);
    top: 5.8vh;
    left: 24.2%;
  }
  .s-engei .b-engeiImage__item:nth-child(3) {
    width: min(23.7vh, 255px);
    top: 24vh;
    bottom: auto;
    left: 12.5%;
    right: auto;
    margin: 0;
  }
  .s-engei .b-engeiImage__item:nth-child(4) {
    width: min(15vh, 160px);
    top: auto;
    bottom: calc(92px - var(--vh-gap) * 80 / 380);
    left: 6%;
  }
  .s-engei .b-engeiImage__item:nth-child(5) {
    display: inline-block;
    width: min(30.6vh, 330px);
    bottom: calc(222px - var(--vh-gap) * 80 / 380);
    left: 18%;
  }
  .s-engei .b-engeiImage__item:nth-child(6) {
    display: inline-block;
    width: min(29.5vh, 318px);
    bottom: calc(48px - var(--vh-gap) * 80 / 380);
    left: 17%;
  }
  .s-engei .b-engeiImage__item:nth-child(7) {
    width: min(16vh, 171px);
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
  }
  .s-engei .b-engeiImage__item:nth-child(8) {
    width: min(29.3vh, 316px);
    top: 4.5vh;
    right: 18.9%;
  }
  .s-engei .b-engeiImage__item:nth-child(9) {
    width: min(10.8vh, 166px);
    top: 5.6vh;
    bottom: auto;
    left: auto;
    right: 5%;
  }
  .s-engei .b-engeiImage__item:nth-child(10) {
    display: inline-block;
    width: min(29.7vh, 320px);
    top: 32vh;
    right: 0;
  }
  .s-engei .b-engeiImage__item:nth-child(11) {
    display: inline-block;
    width: min(42.5vh, 386px);
    top: 45vh;
    right: 9.2%;
  }
  .s-engei .b-engeiImage__item:nth-child(12) {
    width: min(30.6vh, 330px);
    bottom: calc(52px - var(--vh-gap) * 70 / 380);
    right: 16.5%;
  }
  .s-engei .b-engeiImage__item:nth-child(13) {
    display: inline-block;
    width: min(12.8vh, 138px);
    bottom: calc(64px - var(--vh-gap) * 70 / 380);
    right: 2.8%;
  }
  .s-engei .b-engeiImage__item:nth-child(14) {
    display: inline-block;
    width: min(11.5vh, 124px);
    top: 32vh;
    right: 28%;
  }
}
/*
  Map
----------------------------------------------- */
.s-map iframe {
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
}

/********** media query **********/
@media screen and (min-width: 1024px) {
  .s-map {
    display: none;
  }
}
/* ===============================================
L-Footer
=============================================== */
/********** media query **********/
/* ===============================================
M-Header
=============================================== */
/* ===============================================
M-Main
=============================================== */
/*
  Common
----------------------------------------------- */
/********** media query **********/
/*
  Top
----------------------------------------------- */
/********** media query **********/
/* ===============================================
M-Footer
=============================================== */
/* ===============================================
hamburger
=============================================== */
/********** media query **********/
@media screen and (min-width: 1024px) {
  .globalNav {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
    gap: 0 70px;
  }
  .b-header__nav {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    gap: 0 50px;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
    transform: translateX(-150%);
  }
  50% {
    opacity: 0;
    transform: translateX(0%);
  }
  100% {
    opacity: 1;
    transform: translateX(0%);
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
    transform: translateX(0%);
  }
  50% {
    opacity: 0;
    transform: translateX(0%);
  }
  100% {
    opacity: 0;
    transform: translateX(-100%);
  }
}
/* ===============================================
  b-text
=============================================== */
/*
  Common
----------- */
.b-text-lv1 {
  font-size: 1rem;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
.b-text-lv1.--uppercase {
  text-transform: uppercase;
}
.b-text-lv1.--beige {
  color: var(--beige-100);
}

.b-sectionTitle-lv1 {
  font-size: 1rem;
  letter-spacing: 0.01em;
}
.b-sectionTitle-lv1 .en {
  font-size: 0.9em;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

.b-content__text {
  font-size: 0.9375rem;
  line-height: 1.6;
  letter-spacing: -0.025em;
  font-family: var(--serifFont);
}

.b-mainButton {
  font-size: 0.875rem;
  text-transform: uppercase;
}

.b-scroll {
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/*
  Header
----------- */
.b-header__title {
  font-size: 1rem;
  letter-spacing: -0.05em;
}

.b-header__text {
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/*
  Footer
----------- */
/*
  about
----------- */
.b-about__address {
  font-size: 0.875rem;
  color: var(--beige-100);
  font-style: normal;
}
.b-about__address .title {
  letter-spacing: -0.05em;
}
.b-about__address .text {
  letter-spacing: 0.09em;
}

/********** media query **********/
@media screen and (min-width: 1024px) {
  /*
    Common
  ----------- */
  .b-text-lv1 {
    font-size: clamp(0.825rem, 1.98vh, 1.0625rem);
  }
  .b-sectionTitle-lv1 {
    font-size: clamp(0.825rem, 1.98vh, 1.0625rem);
  }
  .b-content__text {
    font-size: clamp(0.75rem, 1.85vh, 1rem);
  }
}
/* ===============================================
b-button
=============================================== */
.b-button {
  position: relative;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 100%;
  border-radius: 0;
}

.b-mainButton {
  width: 168px;
  padding: 0px 8px;
  color: var(--beige-100);
  border: 1px solid var(--beige-100);
  border-radius: 100px;
}

/********** media query **********/
@media screen and (min-width: 1024px) {
  .b-mainButton {
    width: 210px;
    padding: 4px 8px;
  }
}
/* ===============================================
b-pagination
=============================================== */
/* ===============================================
b-parts
=============================================== */
/*
  Common
----------------------------------------------- */
.b-width100 {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
}

.space {
  display: flex;
  justify-content: space-between;
}

/********** media query **********/
@media screen and (min-width: 768px) {
  .space--pc {
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (min-width: 1000px) {
  .b-width100 {
    width: 100%;
    margin: 0;
  }
}
/* ===============================================
Hover
=============================================== */
a {
  transition: opacity 0.2s ease-in-out;
}
a:hover {
  opacity: 0.5;
}

/*
  Common
----------------------------------------------- */
/* ===============================================
animation
=============================================== */
/*
  common
----------------------------------------------- */
body {
  animation: fade 2s both;
}

/*
  header
----------------------------------------------- */
/*
  Top
----------------------------------------------- */
.b-scroll::after {
  animation: b-scroll-arrow-slide 2s ease-in-out infinite;
  will-change: transform, opacity;
}

@media (prefers-reduced-motion: reduce) {
  .b-scroll::after {
    animation: none;
    opacity: 1;
    transform: none;
  }
}
/*
  @keyframes
----------------------------------------------- */
@keyframes fade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fade0ut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes b-scroll-arrow-slide {
  0% {
    transform: translateX(-40px) scale(0, 1);
    opacity: 0;
  }
  15% {
    opacity: 1;
  }
  80% {
    opacity: 1;
  }
  100% {
    transform: translateX(0px) scale(1, 1);
    opacity: 0;
  }
}